harperdb 4.6.1 → 4.6.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/bin/harperdb.js +2 -2
- package/bin/lite.js +1 -1
- package/launchServiceScripts/launchNatsIngestService.js +1 -1
- package/launchServiceScripts/launchNatsReplyService.js +1 -1
- package/launchServiceScripts/launchUpdateNodes4-0-0.js +1 -1
- package/npm-shrinkwrap.json +26 -26
- package/package.json +1 -1
- package/server/jobs/jobProcess.js +1 -1
- package/server/threads/threadServer.js +1 -1
- package/studio/build-local/asset-manifest.json +2 -2
- package/studio/build-local/index.html +1 -1
- package/studio/build-local/static/js/{main.1faf79b7.js → main.447848b8.js} +2 -2
- package/utility/scripts/restartHdb.js +1 -1
- /package/studio/build-local/static/js/{main.1faf79b7.js.LICENSE.txt → main.447848b8.js.LICENSE.txt} +0 -0
|
@@ -10,7 +10,7 @@
|
|
|
10
10
|
|
|
11
11
|
`:`data: ${e}
|
|
12
12
|
|
|
13
|
-
`},"serialize"),compressible:!1,q:.8});nn.set("application/x-www-form-urlencoded",{deserialize(e){let t=Buffer.isBuffer(e)?e.toString("utf8"):e,r={};for(let[n,s]of new URLSearchParams(t))if(r.hasOwnProperty(n)){let i=r[n];Array.isArray(i)?i.push(s):r.key=[i,s]}else r[n]=s;return r},serialize(e){let t=new URLSearchParams;for(let r in e)t.set(r,e);return t.toString()}});wv={type:"application/json",serializeStream:Zf,serialize:em,deserialize:QZ,q:.5};nn.set("*/*",wv);nn.set("",wv);o(QZ,"tryJSONParse");o(rm,"registerContentHandlers");JZ=(0,Iv.default)(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:a,type:c}=j_(n.raw);s.type(c),s.serializer(function(l){let u;if(typeof l=="object"&&l&&(l[Symbol.iterator]||l[Symbol.asyncIterator])&&a.serializeStream){if(l.mapError){let d=l.getColumns;l=l.mapError(f=>(f.toJSON=()=>({error:f.name,message:f.message,...f.partialObject}),f)),l.getColumns=d}u=a.serializeStream}else u=a.serialize;return u(l,{headers:{set:o((d,f)=>{s.header(d,f)},"set")}})})}),r()},{name:"content-type-negotiation"});o(j_,"findBestSerializer");Tv=uA.default.get(U.HTTP_COMPRESSIONTHRESHOLD);o(nm,"serialize");o(Sa,"serializeMessage");o(hA,"asyncSerialization");o(pA,"hasAsyncSerialization");o(XZ,"streamToBuffer");ZZ=["ascii","utf8","utf-8","utf16le","utf-16le","ucs2","ucs-2","base64","base64url","latin1","binary","hex"];o(e6,"isBufferEncoding");o(t6,"parseContentType");o(_o,"getDeserializer");o(r6,"deserializerUnknownType");o(n6,"transformIterable");o(z_,"toCsvStream")});var TA={};Ce(TA,{Blob:()=>Ss,blobsWereEncoded:()=>Gc,databasePaths:()=>EA,decodeBlobsWithWrites:()=>sE,decodeFromDatabase:()=>qc,decodeWithBlobCallback:()=>iE,deleteBlob:()=>tE,deleteBlobsInObject:()=>Ta,deleteRootBlobPathsForDB:()=>SA,encodeBlobsAsBuffers:()=>m6,encodeBlobsWithFilePath:()=>nE,findBlobsInObject:()=>gu,getFileId:()=>rE,getFilePathForBlob:()=>Fv,getRootBlobPathsForDB:()=>am,setDeletionDelay:()=>a6});function Uv(){}function tE(e){let t=Fv(e);t&&setTimeout(()=>{(0,Ze.unlink)(t,r=>{r&&go.default.debug?.("Error trying to remove blob file",r)})},xv)}function a6(e){xv=e}function Bv(e){let t=bn.get(e);if(!t)t={storageIndex:0,fileId:null,store:In},bn.set(e,t);else{if(t.saving)return t;t.store=In}return l6(t),t.source?_A(e,t.source,t):t.contentBuffer?c6(e,t):_A(e,im.Readable.from(e.stream()),t),t}function _A(e,t,r){let{filePath:n,fileId:s,store:i,compress:a,flush:c}=r;return r.saving=new Promise((l,u)=>{let d=s+":blob";if(!i.attemptLock(d,0))throw new Error(`Unable to get lock for blob file ${s}`);let f=(0,Ze.createWriteStream)(n,{autoClose:!1,flags:"w"});if(t.errored){let g=Buffer.from(t.errored.toString());f.end(Buffer.concat([p(BigInt(g.length)+0xff000000000000n),g]));return}let m=!1;e.size!==void 0&&(f.write(p(e.size)),m=!0);let h;a?(m||f.write(i6),h=(0,Z_.createDeflate)(),t.pipe(h).pipe(f)):(m||f.write(s6),t.pipe(f)),t.on("error",E);function p(g){let y=BigInt(g),T=new Uint8Array(Rr),R=new DataView(T.buffer);return y|=BigInt(a?gA:vv)<<48n,R.setBigInt64(0,y),T}o(p,"createHeader");function E(g){i.unlock(d,0);let y=f.fd;g?(y&&(0,Ze.close)(y),u(g)):c?(0,Ze.fdatasync)(y,T=>{T&&u(T),l(),(0,Ze.close)(y)}):(l(),(0,Ze.close)(y))}o(E,"finished"),f.on("error",E).on("finish",()=>{if(m)E();else{let g=h?h.bytesWritten:f.bytesWritten-Rr;e.size=g,(0,Ze.write)(f.fd,p(g),0,Rr,0,E)}})}),e}function rE(e){return bn.get(e)?.fileId}function Fv(e){let t=bn.get(e);return t?.fileId&&om(t)}function am(e){if(!e)throw new Error("No store specified, can not determine blob storage path");let t=EA.get(e);if(!t){if(!e.databaseName)return go.default.warn?.("No database name specified, can not determine blob storage path"),[];let r=(0,eE.get)(U.STORAGE_BLOBPATHS);r?t=r.map(n=>(0,To.join)(n,e.databaseName)):t=[(0,To.join)((0,eE.getHdbBasePath)(),"blobs",e.databaseName)],EA.set(e,t)}return t}async function SA(e){let t=am(e);t&&await Promise.all(t.map(r=>Hv(r)))}async function Hv(e){if((0,Ze.existsSync)(e)){for(let t of await(0,Qs.readdir)(e,{withFileTypes:!0}))if(t.isDirectory())await Hv((0,To.join)(e,t.name));else try{await(0,Qs.unlink)((0,To.join)(e,t.name))}catch(r){go.default.warn?.("Error deleting file",r)}try{await(0,Qs.rmdir)(e)}catch(t){go.default.warn?.("Error deleting directory",t)}}}function om({storageIndex:e,fileId:t,store:r}){let n=am(r);return(0,To.join)(n[e],t.slice(-9,-6)||"0",t.slice(-6,-3)||"0",t.length<=9?t.slice(-3):t.slice(0,-9)+t.slice(-3))}function c6(e,t){let r=t.contentBuffer,n=r.length;if(!(n<Mv))return e.size=n,_A(e,im.Readable.from([r]),t)}function l6(e){let t=am(e.store),r=u6(),n=t?.length>1?d6(t,r):0,s=r.toString(16);e.storageIndex=n,e.fileId=s;let i=om(e),a=(0,To.dirname)(i);(0,Ze.existsSync)(a)||(0,Dv.ensureDirSync)(a),e.filePath=i}function u6(){let e=Lv.get(In);if(!e){let t=0,r=am(In);for(let n of r){let s=0;for(let i=0;i<3;i++){s=s*4096;let a=0;if((0,Ze.existsSync)(n))for(let c of(0,Ze.readdirSync)(n)){let l=parseInt(c,16);i===2&&c.length>3&&(l=parseInt(c.slice(-3),16),l+=parseInt(c.slice(0,-3),16)*68719476736),l>a&&(a=l)}s+=a,n=(0,To.join)(n,a.toString(16))}t=Math.max(t,s)}e=new BigInt64Array([BigInt(t)+1n]),e=new BigInt64Array(In.getUserSharedBuffer("blob-file-id",e.buffer)),Lv.set(In,e)}return Number(Atomics.add(e,0,1n))}function d6(e,t){let r=Date.now();if(!e.frequencyTable){e.lastUpdated=0;let s=new Array(X_);for(let i=0;i<s.length;i++)s[i]=i%e.length;e.frequencyTable=s}return(e.lastUpdated??0)+6e4<r&&(e.lastUpdated=r,f6(e)),e.frequencyTable[t%X_]}async function f6(e){if(!Qs.statfs)return;let t=await Promise.all(e.map(async(s,i)=>{let a=await(0,Qs.statfs)(s),c=a.bavail*a.bsize;return Math.pow(c,.8)})),r=new Array(X_),n=t.map(s=>1/s);for(let s=0;s<X_;s++){let i=1/0,a=0;for(let c=0;c<n.length;c++)n[c]<i&&(a=c,i=n[c]);n[a]+=1/t[a],r[s]=a}e.frequencyTable=r}function nE(e,t,r){Eu=t,In=r,Gc=!1;try{return e()}finally{Eu=void 0,In=void 0}}function m6(e){Gr=[];let t;try{t=e()}catch(n){throw Gr=void 0,n}let r=Gr.length<2?Gr[0]:Promise.all(Gr);return Gr=void 0,r?r.then(()=>e()):t}function sE(e,t){try{Gr=[],kc=t,e()}catch(n){throw kc=void 0,Gr=void 0,n}kc=void 0;let r=Gr.length<2?Gr[0]:Promise.all(Gr);return Gr=void 0,r}function iE(e,t,r){In=r;try{return kc=t,e()}finally{kc=void 0}}function qc(e,t){return In=t,e()}function Ta(e){gu(e,t=>{tE(t)})}function gu(e,t){if(e instanceof Ss)t(e);else if(Array.isArray(e))for(let r of e)typeof r=="object"&&r&&gu(r,t);else if(e&&typeof e=="object"&&!e[Symbol.iterator])for(let r in e){let n=e[r];typeof n=="object"&&n&&gu(e[r],t)}}function h6(){return class{static{o(this,"Blob")}content;constructor(t){this.content=t[0]}stream(){return new ReadableStream({start(t){t.enqueue(this.content),t.close()}})}text(){return Promise.resolve(this.content.toString())}arrayBuffer(){return Promise.resolve(this.content.buffer)}get size(){return this.content.length}slice(){throw new Error("Not implemented")}bytes(){return Promise.resolve(this.content)}get type(){return""}}}var So,Qs,Ze,Z_,im,Dv,eE,To,go,Mv,Rr,vv,gA,Cv,s6,i6,Pv,bn,kc,Ss,Eu,Gr,In,Gc,sm,Q_,o6,J_,xv,EA,Lv,X_,Ts=fe(()=>{So=require("msgpackr"),Qs=require("node:fs/promises"),Ze=require("node:fs"),Z_=require("node:zlib"),im=require("node:stream"),Dv=require("fs-extra"),eE=w(ce());k();To=require("path"),go=w(wi());Eo();Mv=8192,Rr=8,vv=0,gA=1,Cv=255,s6=new Uint8Array([0,vv,255,255,255,255,255,255]),i6=new Uint8Array([0,gA,255,255,255,255,255,255]),Pv=0xffffffffffff,bn=new WeakMap,Ss=global.Blob||h6(),Gc=!1,sm=new Uint8Array(8),Q_=new DataView(sm.buffer),o6=6e4;o(Uv,"InstanceOfBlobWithNoConstructor");Uv.prototype=Ss.prototype;J_=class e extends Uv{static{o(this,"FileBackedBlob")}type="";size;#e;#t;constructor(t){super(),t?.type&&(this.type=t.type),t?.size!=null&&(this.size=t.size)}on(t,r){if(t==="error")this.#e??=[],this.#e.push(r);else if(t==="size")this.#t??=[],this.#t.push(r);else throw new Error("Only 'error' and 'size' events are supported")}toJSON(){if(this.type?.startsWith("text")){let t=bn.get(this),{start:r,end:n,contentBuffer:s,asString:i}=t;return i||(s&&(n!==void 0||r!==void 0)&&(s=s.subarray(r??0,n??t.contentBuffer.length)),s?(t.asString=s.toString(),t.asString):(pA()&&hA(this.bytes().then(a=>t.contentBuffer=a)),`[blob: ${this.type}, ${this.size} bytes]`))}return{description:"Blobs that are not of type text/* can not be directly serialized as JSON, use as the body of a response or convert to another type"}}async text(){return(await this.bytes()).toString()}bytes(){let t=bn.get(this),{start:r,end:n,contentBuffer:s}=t;if(s)return(n!==void 0||r!==void 0)&&(s=s.subarray(r??0,n??t.contentBuffer.length)),Promise.resolve(s);let i=om(t),a,c=o(async()=>{let l,u=Rr;try{if(l=await(0,Qs.readFile)(i),l.length>=Rr){l.copy(sm,0,0,Rr);let f=Q_.getBigUint64(0);if(Number(f>>48n)===Cv)throw new Error("Error in blob: "+buffer.subarray(Rr));if(u=Number(f&0xffffffffffffn),u<n&&(u=n),u<Pv&&(this.size=u,this.#t))for(let m of this.#t)m(u)}}catch(f){if(f.code!=="ENOENT")throw f;l=Buffer.alloc(0)}function d(f){if(u>f.length){let m=t.store,h=t.fileId+":blob";if(a)throw new Error("Incomplete blob");return new Promise((p,E)=>{if(m.attemptLock(h,0,()=>(a=!0,m.unlock(h,0),p(c()))))return a=!0,m.unlock(h,0),p(c())})}return(n!=null||r!=null)&&(f=f.subarray(r??0,n??f.length)),f}return o(d,"checkCompletion"),l[1]===gA?new Promise((f,m)=>{(0,Z_.deflate)(l.subarray(Rr),(h,p)=>{h?m(h):f(d(p))})}):d(l.subarray(Rr))},"readContents");return c()}async arrayBuffer(){let t=await this.bytes(),r=new ArrayBuffer(t.length);return new Uint8Array(r).set(t),r}stream(){let t=bn.get(this),{contentBuffer:r,start:n,end:s}=t;if(r)return(s!=null||n!=null)&&(r=r.subarray(n??0,s??t.contentBuffer.length)),new ReadableStream({pull(E){E.enqueue(r),E.close()}});let i=om(t),a,c=0,l=0,u,d,f,m=!1,h=this;return new ReadableStream({start(){let E=1e3,g=o((y,T)=>{(0,Ze.open)(i,"r",(R,I)=>{if(R){if(R.code==="ENOENT"&&f!==!1&&(go.default.debug?.("File does not exist yet, waiting for it to be created",i,E),E-- >0))return setTimeout(()=>{p(),g(y,T)},20).unref();T(R),h.#e?.forEach(P=>P(R))}else a=I,y(I)})},"openFile");return new Promise(g)},pull:o(E=>{let g=0,y=100;return new Promise(o(function T(R,I){function P(te){(0,Ze.close)(a),clearTimeout(d),u&&u.close(),I(te),h.#e?.forEach(x=>x(te))}o(P,"onError");let Y=Buffer.allocUnsafe(262144);(0,Ze.read)(a,Y,0,Y.length,c,(te,x,$)=>{if(l+=x,te)return P(te);if(c===0){if(x<Rr){y-- >0&&f!==!1?(p(),go.default.debug?.("File was empty, waiting for data to be written",i,y),setTimeout(()=>T(R,I),20).unref()):(go.default.debug?.("File was empty, throwing error",i,y),I(new Error(`Blob ${t.fileId} was empty`)));return}$.copy(sm,0,0,Rr);let j=Q_.getBigUint64(0);if(Number(j>>48n)===Cv)return P(new Error("Error in blob: "+$.subarray(Rr)));if(g=Number(j&0xffffffffffffn),g<Pv&&h.size!==g&&(h.size=g,h.#t))for(let V of h.#t)V(g);$=$.subarray(Rr,x),l-=Rr}else if(x===0){let j=Buffer.allocUnsafe(8);return(0,Ze.read)(a,j,0,Rr,0,V=>{if(V)return P(V);if(sm.set(j),g=Number(Q_.getBigUint64(0)&0xffffffffffffn),g>l){p()?u?d=setTimeout(()=>{P(new Error("File read timed out"))},o6).unref():(u=(0,Ze.watch)(i,{persistent:!1},()=>{u.close(),u=null,d&&(clearTimeout(d),d=null,T(R,I))}),T(R,I)):m?P(new Error("Blob is incomplete")):(m=!0,T(R,I));return}(0,Ze.close)(a),E.close(),R()})}else $=$.subarray(0,x);if(n!==void 0||s!==void 0){if(n&&l<n)return c+=x,T(R,I);s&&l>=s&&(l>s&&($=$.subarray(0,s-c)),l=g=s),n&&n>c&&($=$.subarray(n-c))}c+=x;try{E.enqueue($)}catch(j){return go.default.debug?.("Error enqueuing chunk",j),R()}l===g&&((0,Ze.close)(a),E.close()),R()})},"readMore"))},"pull"),cancel(){(0,Ze.close)(a),clearTimeout(d),u&&u.close()}});function p(){if(f===void 0){let E=t.store,g=t.fileId+":blob";f=!E.attemptLock(g,0,()=>{f=!1,E.unlock(g,0)}),f||E.unlock(g,0)}return f}}slice(t,r,n){let s=bn.get(this),i=new e(n&&{type:n});if(s?.fileId){let a={...s,start:t,end:r};bn.set(i,a),this.size!=null&&(i.size=(r==null?this.size:Math.min(r,this.size))-(t??0))}else if(s?.contentBuffer&&!s.storageBuffer){let a={...s,contentBuffer:s.contentBuffer.subarray(t,r)};bn.set(i,a),i.size=(r??this.size)-t}else throw new Error("Can not slice a streaming blob that is not backed by a file");return i}save(t){if(In=t?.primaryStore?.rootStore,!In)throw new Error("No target table specified");return Bv(this).saving??Promise.resolve()}},xv=500;o(tE,"deleteBlob");o(a6,"setDeletionDelay");global.createBlob=function(e,t){let r=new J_(t),n={storageIndex:0,fileId:null,flush:t?.flush,compress:t?.compress};if(bn.set(r,n),e instanceof Uint8Array)r.size=e.length,n.contentBuffer=e;else if(e instanceof im.Readable)n.source=e;else if(typeof e=="string")n.contentBuffer=Buffer.from(e);else if(e?.[Symbol.asyncIterator]||e?.[Symbol.iterator])n.source=im.Readable.from(e);else throw new Error("Invalid source type");return r};o(Bv,"saveBlob");o(_A,"writeBlobWithStream");o(rE,"getFileId");o(Fv,"getFilePathForBlob");EA=new Map;o(am,"getRootBlobPathsForDB");o(SA,"deleteRootBlobPathsForDB");o(Hv,"rimrafSteadily");o(om,"getFilePath");o(c6,"writeBlobWithBuffer");o(l6,"generateFilePath");Lv=new Map;o(u6,"getNextFileId");X_=128;o(d6,"getNextStorageIndex");o(f6,"createFrequencyTableForStoragePaths");o(nE,"encodeBlobsWithFilePath");o(m6,"encodeBlobsAsBuffers");o(sE,"decodeBlobsWithWrites");o(iE,"decodeWithBlobCallback");o(qc,"decodeFromDatabase");o(Ta,"deleteBlobsInObject");o(gu,"findBlobsInObject");(0,So.addExtension)({Class:Ss,type:11,unpack:o(function(e){let t=(0,So.unpack)(e),r=new J_;if(Object.assign(r,t[0]),typeof t[1]!="object"){if(bn.set(r,{storageIndex:t[1],fileId:t[2],store:In}),kc)return kc(r)??r;if(!In)throw new Error("No store specified, cannot load blob from storage")}else bn.set(r,{storageIndex:0,fileId:null,storageBuffer:e,contentBuffer:t[1]}),r.size=t[1]?.length;return r},"unpack"),pack:o(function(e){let t=bn.get(e);if(Eu!==void 0&&(Gc=!0,t?.recordId!==void 0&&t.recordId!==Eu))throw new Error("Cannot use the same blob in two different records");let r={...e};if(e.type&&(r.type=e.type),e.size!==void 0&&(r.size=e.size),t){if(t.storageBuffer)return t.storageBuffer;if(t.contentBuffer?.length<Mv)return r.size=t.contentBuffer.length,(0,So.pack)([r,t.contentBuffer])}if(Eu!==void 0){if(t=Bv(e),!t.fileId)throw new Error("Unable to save blob without file id");return t.recordId=Eu,(0,So.pack)([r,t.storageIndex,t.fileId])}if(t)try{let n=(0,Ze.readFileSync)(om(t));if(n.length>=Rr&&(n.copy(sm,0,0,Rr),Number(Q_.getBigUint64(0)&0xffffffffffffn)===n.length-Rr))return Buffer.concat([(0,So.pack)([r]),n]);if(Gr)Gr.push(e.bytes());else throw new Error("Incomplete blob");return Buffer.alloc(0)}catch(n){if(n.code==="ENOENT"&&Gr)return Gr.push(e.bytes()),Buffer.alloc(0);throw n}else throw new Error("Blob has no storage info or buffer attached to it")},"pack")});(0,So.addExtension)({Class:Promise,type:12,pack(){throw new Error("Cannot encode a promise")}});o(h6,"polyfillBlob")});var Vv={};Ce(Vv,{onStorageReclamation:()=>cm,runReclamationHandlers:()=>bA,setAvailableSpaceRatioGetter:()=>_6});function cm(e,t,r){(r||(0,aE.getWorkerIndex)()===(0,aE.getWorkerCount)()-1)&&(oE.has(e)||oE.set(e,[]),oE.get(e).push({priority:0,handler:t}),AA||(AA=setTimeout(bA,Gv).unref()))}async function bA(){for(let[e,t]of oE)try{let r=await $v(e),n=p6/r;for(let s of t){let{priority:i,handler:a}=s;if(s.priority=n,n>1||i>1){let c=a(n>1?n:0);c&&(yA.default.info?.(`Running storage reclamation handler for ${e} with priority ${n}`),await c)}}}catch(r){yA.default.error?.("Error running storage reclamation handlers",r)}AA=setTimeout(bA,Gv).unref()}function _6(e){$v=e??qv}var RA,aE,yA,cE,kv,oE,p6,Gv,AA,qv,$v,lE=fe(()=>{RA=require("node:fs/promises"),aE=w(st()),yA=w(wi());k();cE=w(ce()),kv=w(ie());cE.default.initSync();oE=new Map,p6=cE.default.get(U.STORAGE_RECLAMATION_THRESHOLD)??.4,Gv=(0,kv.convertToMS)(cE.default.get(U.STORAGE_RECLAMATION_INTERVAL))||36e5;o(cm,"onStorageReclamation");qv=o(async e=>{if(RA.statfs){let t=await(0,RA.statfs)(e);return t.bavail/t.blocks}else return new Promise((t,r)=>{import("hdd-space").then(n=>{n.default(s=>{for(let i of s.parts)if(e.startsWith(i.place))return t(i.free/i.size);return t(1)})})})},"defaultGetAvailableSpaceRatio"),$v=qv;o(bA,"runReclamationHandlers");o(_6,"setAvailableSpaceRatioGetter")});var nU={};Ce(nU,{ACTION_32_BIT:()=>hE,ACTION_64_BIT:()=>S6,AUDIT_STORE_OPTIONS:()=>dm,Decoder:()=>Vc,HAS_BLOBS:()=>Nn,HAS_CURRENT_RESIDENCY_ID:()=>Kc,HAS_EXPIRATION_EXTENDED_TYPE:()=>hm,HAS_ORIGINATING_OPERATION:()=>mm,HAS_PREVIOUS_RESIDENCY_ID:()=>Yc,REMOTE_SEQUENCE_UPDATE:()=>pE,createAuditEntry:()=>Tu,getLastRemoved:()=>PA,openAuditStore:()=>fE,readAuditEntry:()=>Ut,removeAuditEntry:()=>mE,setAuditRetention:()=>g6,transactionKeyEncoder:()=>Zv});function fE(e){let t=e.auditStore=e.openDB(IA.AUDIT_STORE_NAME,{create:!1,...dm});t||(t=e.auditStore=e.openDB(IA.AUDIT_STORE_NAME,dm),Yv(t,1)),t.rootStore=e,t.tableStores=[];let r=[];t.addDeleteRemovalCallback=function(l,u,d){return r[l]=d,t.tableStores[l]=u,t.deleteCallbacks=r,{remove(){delete r[l]}}};let n=null,s,i=0,a=wA;cm(t.env.path,l=>{if(i=l,l)return c(100)});function c(l){l&&(a=l),clearTimeout(n);let u=new Promise(d=>{n=setTimeout(async()=>{if(await s,s=u,t.rootStore.status==="closed"||t.rootStore.status==="closing")return;let f=0,m,h;try{for(let{key:p,value:E}of t.getRange({start:1,snapshot:!1,end:Date.now()-NA/(1+i*i)})){try{m=mE(t,p,E)}catch(g){Su.warn("Error removing audit entry",g)}if(h=p,await new Promise(setImmediate),++f>=E6){a=10;break}}await m}finally{f===0?a=Math.min(a<<1,NA/10):(Yv(t,h),a>100&&(a=a>>1)),d(void 0),c()}},a).unref()});return u}if(o(c,"scheduleAuditCleanup"),t.scheduleAuditCleanup=c,(0,um.getWorkerIndex)()===(0,um.getWorkerCount)()-1&&c(),(0,um.getWorkerIndex)()===0&&!Kv)for(let l of t.getKeys({reverse:!0,limit:1}))l>Date.now()&&(Kv=!0,Su.error("The current time is before the last recorded entry in the audit log. Time reversal can undermine the integrity of data tracking and certificate validation and the time must be corrected."));return t}function mE(e,t,r){let n=T6(r),s;if(n&Nn){s=Ut(r);let i=e.tableStores[s.tableId],a=i?.getEntry(s.recordId);(!a||a.version!==s.version||!a.value)&&qc(()=>Ta(s.getValue(i)),i.rootStore)}if((n&15)===OA){s=s||Ut(r);let i=s.tableId;e.tableStores[s.tableId]?.getEntry(s.recordId).version===s.version&&e.deleteCallbacks?.[i]?.(s.recordId,s.version)}return e.remove(t)}function Yv(e,t){CA[0]=t,e.put(Symbol.for("last-removed"),eU)}function PA(e){let t=e.get(Symbol.for("last-removed"));if(t)return eU.set(t),CA[0]}function g6(e,t=wA){NA=e,wA=t}function Tu(e,t,r,n,s,i,a,c,l,u,d,f,m){let h=tU[a];if(!h)throw new Error(`Invalid audit entry type ${a}`);let p=1;if(n&&(n>1?Ra.setFloat64(0,n):Rs.set(LA),p=9),l){if(l&255)throw new Error("Illegal extended type");p+=3}y(s),y(t),g(r),Ra.setFloat64(p,e),p+=8,l&Kc&&y(u),l&Yc&&y(d),l&hm&&(Ra.setFloat64(p,f),p+=8),l&mm&&y(rU[m]),i?g(i):Rs[p++]=0,l?Ra.setUint32(n?8:0,h|l|3221225472):Rs[n?8:0]=h;let E=Rs.subarray(0,p);if(c)return Buffer.concat([E,c]);return E;function g(T){let R=p;p+=1,p=(0,$c.writeKey)(T,Rs,p);let I=p-R-1;I>127?I>16383?(Su.error("Key or username was too large for audit entry",T),p=R+1,Rs[R]=0):(Rs.copyWithin(R+2,R+1,p),Ra.setUint16(R,I|32768),p++):Rs[R]=I}function y(T){T<128?Rs[p++]=T:T<16384?(Ra.setUint16(p,T|32768),p+=2):T<1056964608?(Ra.setUint32(p,T|3221225472),p+=4):(Rs[p]=255,Ra.setUint32(p+1,T),p+=5)}}function T6(e){let t=0;e[0]==66&&(t=8);let r=e[t];if(r<128)return r;let n=e.dataView||(e.dataView=new Vc(e.buffer,e.byteOffset,e.byteLength));return n.position=t,n.readInt()}function Ut(e,t=0,r=void 0){try{let n=e.dataView||(e.dataView=new Vc(e.buffer,e.byteOffset,e.byteLength));n.position=t;let s;e[n.position]==66&&(s=n.readFloat64());let i=n.readInt(),a=n.readInt(),c=n.readInt(),l=n.readInt(),u=n.position,d=n.position+=l,f=n.readFloat64(),m,h,p,E;if(i&Kc&&(m=n.readInt()),i&Yc&&(h=n.readInt()),i&hm&&(p=n.readFloat64()),i&mm){let R=n.readInt();E=rU[R]}l=n.readInt();let g=n.position,y=n.position+=l,T;return{type:tU[i&7],tableId:c,nodeId:a,get recordId(){return(0,$c.readKey)(e,u,d)},getBinaryRecordId(){return e.subarray(u,d)},version:f,previousLocalTime:s,get user(){return y>g?(0,$c.readKey)(e,g,y):void 0},get encoded(){return t?e.subarray(t,r):e},getValue(R,I,P){if(i&uE||i&lm&&!I)return T||(T=qc(()=>R.decoder.decode(e.subarray(n.position,r)),R.rootStore)),T;if(i&lm&&P)return sA(R.getEntry(this.recordId),P,R)},getBinaryValue(){return i&(uE|lm)?e.subarray(n.position,r):void 0},extendedType:i,residencyId:m,previousResidencyId:h,expiresAt:p,originatingOperation:E}}catch(n){return Su.error("Reading audit entry error",n,e),{}}}var $c,dE,IA,um,Xv,Su,Rs,Ra,Zv,dm,NA,E6,CA,eU,wA,Kv,uE,lm,Wv,OA,zv,jv,Qv,Jv,hE,S6,pE,Kc,Yc,mm,hm,Nn,tU,rU,Vc,mo=fe(()=>{$c=require("ordered-binary"),dE=w(ce()),IA=w(kt());k();um=w(st()),Xv=w(ie());Wc();Su=w(z());K_();Ts();lE();(0,dE.initSync)();Rs=Buffer.alloc(2816),Ra=new DataView(Rs.buffer,Rs.byteOffset,2816),Zv={writeKey(e,t,r){return e===fm?(t.set(fm,r),r+8):typeof e=="number"?((t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).setFloat64(r,e),r+8):(0,$c.writeKey)(e,t,r)},readKey(e,t,r){return e[t]===66?(e.dataView||(e.dataView=new DataView(e.buffer,e.byteOffset,e.byteLength))).getFloat64(t):(0,$c.readKey)(e,t,r)}},dm={encoding:"binary",keyEncoder:Zv},NA=(0,Xv.convertToMS)((0,dE.get)(U.LOGGING_AUDITRETENTION))||86400*3,E6=1e3,CA=new Float64Array(1),eU=new Uint8Array(CA.buffer),wA=1e4,Kv=!1;o(fE,"openAuditStore");o(mE,"removeAuditEntry");o(Yv,"updateLastRemoved");o(PA,"getLastRemoved");o(g6,"setAuditRetention");uE=16,lm=32,Wv=1,OA=2,zv=3,jv=4,Qv=5,Jv=6,hE=14,S6=15,pE=11,Kc=512,Yc=1024,mm=2048,hm=4096,Nn=8192,tU={put:Wv|uE,[Wv]:"put",delete:OA,[OA]:"delete",message:zv|uE,[zv]:"message",invalidate:jv|lm,[jv]:"invalidate",patch:Qv|lm,[Qv]:"patch",relocate:Jv,[Jv]:"relocate"},rU={insert:1,update:2,upsert:3,1:"insert",2:"update",3:"upsert"};o(Tu,"createAuditEntry");o(T6,"readAction");o(Ut,"readAuditEntry");Vc=class extends DataView{static{o(this,"Decoder")}position=0;readInt(){let t;return t=this.getUint8(this.position++),t>=128?t>=192?t===255?(t=this.getUint32(this.position),this.position+=4,t):(t=this.getUint32(this.position-1)&1073741823,this.position+=3,t):(t=this.getUint16(this.position-1)&32767,this.position++,t):t}readFloat64(){try{let t=this.getFloat64(this.position);return this.position+=8,t}catch(t){throw t.message=`Error reading float64: ${t.message} at position ${this.position}`,t}}}});var cU={};Ce(cU,{ENTRY:()=>y6,HAS_EXPIRATION:()=>gE,HAS_RESIDENCY_ID:()=>BA,HAS_STRUCTURE_UPDATE:()=>SE,LAST_TIMESTAMP_PLACEHOLDER:()=>fm,LOCAL_TIMESTAMP:()=>R6,METADATA:()=>yu,NEW_TIMESTAMP_PLACEHOLDER:()=>iU,NO_TIMESTAMP:()=>DA,PENDING_LOCAL_TIME:()=>FA,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>LA,RecordEncoder:()=>xA,TIMESTAMP_ASSIGN_LAST:()=>b6,TIMESTAMP_ASSIGN_NEW:()=>oU,TIMESTAMP_ASSIGN_PREVIOUS:()=>aU,TIMESTAMP_PLACEHOLDER:()=>_E,TIMESTAMP_RECORD_PREVIOUS:()=>MA,entryMap:()=>ya,handleLocalTimeForGets:()=>TE,lastMetadata:()=>ct,recordUpdater:()=>HA,removeEntry:()=>jc});function N6(){return Em[0]=Em[0]^64,A6.getFloat64(0)}function TE(e,t){let r=e.getEntry;e.readCount=0,e.cachePuts=!1,e.rootStore=t,e.encoder.rootStore=t,e.getEntry=function(a,c){e.readCount++,ct=null;let l=r.call(this,a,c);return l&&(ct&&(l.metadataFlags=ct[yu],l.localTime=ct.localTime,l.residencyId=ct.residencyId,ct.expiresAt>=0&&(l.expiresAt=ct.expiresAt),ct=null),l.value&&ya.set(l.value,l),l.key=a),l};let n=e.get;e.get=function(a,c){ct=null;let l=n.call(this,a,c);return ct&&l&&(ya.set(l,ct),ct=null),l};let s=e.getRange;e.getRange=function(a){let c=s.call(this,a);return a.valuesForKey?c.map(l=>l?.value):a.values===!1||a.onlyCount?c:c.map(l=>(ct&&(l.metadataFlags=ct[yu],l.localTime=ct.localTime,l.residencyId=ct.residencyId,ct.expiresAt>=0&&(l.expiresAt=ct.expiresAt),ct=null),l))};let i=e.useReadTransaction();if(i.done(),!i.done.isTracked){let a=i.constructor,c=i.use,l=i.done;a.prototype.use=function(){this.timerTracked||(this.timerTracked=!0,zc.push(new WeakRef(this))),c.call(this)},a.prototype.done=function(){if(l.call(this),this.isDone)for(let u=0;u<zc.length;u++){let d=zc[u].deref();(!d||d.isDone||d.isCommitted)&&zc.splice(u--,1)}},a.prototype.done.isTracked=!0}return e}function HA(e,t,r){return function(n,s,i,a,c=-1,l,u,d="put",f,m){f||l==null?Ru=i?.localTime?MA|aU:DA:Ru=l?i?.localTime?MA|16384:oU|16384:DA;let h=u?.expiresAt;if(h>=0&&(c|=gE),_m=c,vA=h,i?.version===a&&l===!1)throw new Error("Must retain local time if version is not changed");let p={version:a,instructedWrite:Ru>0},E,g=0;try{let y=i?.residencyId,T=u?.residencyId;T&&(UA=T,_m|=BA,g|=Kc),y!==T&&(g|=Yc,y||(y=0)),c&gE&&(g|=hm),u?.originatingOperation&&(g|=mm),f&&(p.ifVersion=E=i?.version??null),i&&i.value&&i.metadataFlags&Nn&&(r.getBinaryFast(i.localTime)||Ta(i.value));let R;if(s!==void 0&&(R=nE(()=>e.put(n,s,p),n,e.rootStore),Gc&&(g|=Nn)),l){let I=u?.user?.username;if(m&&(nE(()=>e.encoder.encode(m),n,e.rootStore),Gc&&(g|=Nn)),e.encoder.hasStructureUpdate&&(g|=SE,e.encoder.hasStructureUpdate=!1),f&&i?.localTime){let P=i?.localTime,Y=r.get(P);if(Y){let te=Ut(Y).previousLocalTime;return R=r.put(P,Tu(a,t,n,te,u?.nodeId??server.replication.getThisNodeId(r)??0,I,d,pm,g,T,y,h),{ifVersion:E}),R}}R=r.put(s===void 0?iU:fm,Tu(a,t,n,i?.localTime?1:0,u?.nodeId??server.replication?.getThisNodeId(r)??0,I,d,pm,g,T,y,h,u?.originatingOperation),{append:d!=="invalidate",instructedWrite:!0,ifVersion:E})}return R}catch(y){throw y.message+=" id: "+n+" options: "+p,y}}}function jc(e,t,r){if(t)return t.value&&t.metadataFlags&Nn&&!e.auditStore.getBinaryFast(t.localTime)&&Ta(t.value),e.remove(t.key,r)}var sU,EE,_E,fm,LA,iU,R6,yu,y6,Em,A6,DA,oU,b6,aU,MA,gE,BA,FA,SE,ya,I6,pm,Ru,_m,vA,UA,ct,xA,zc,Wc=fe(()=>{sU=require("msgpackr");mo();EE=w(z());Ts();Ts();_E=new Uint8Array([1,1,1,1,4,64,0,0]),fm=new Uint8Array([1,1,1,1,1,0,0,0]),LA=new Uint8Array([1,1,1,1,3,64,0,0]),iU=new Uint8Array([1,1,1,1,0,64,0,0]),R6=Symbol("local-timestamp"),yu=Symbol("metadata"),y6=Symbol("entry"),Em=new Uint8Array(8),A6=new DataView(Em.buffer,0,8),DA=0,oU=0,b6=1,aU=3,MA=4,gE=16,BA=32,FA=1,SE=256,ya=new WeakMap,Ru=0,_m=-1,vA=-1,UA=0,ct=null,xA=class extends sU.Encoder{static{o(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0;class r{static{o(this,"RecordObject")}getUpdatedTime(){return ya.get(this)?.version}getExpiresAt(){return ya.get(this)?.expiresAt}}t.structPrototype=r.prototype,super(t);let n=this.encode;this.encode=function(i,a){if(Ru||_m>=0){let c=0,l=Ru;l&&(c+=8,Ru=0);let u=_m,d=vA,f=UA;u>=0&&(c+=4,_m=-1,d>=0&&(c+=8,vA=-1),f&&(c+=4,UA=0));let m=I6=n.call(this,i,a|2048|c);pm=m.subarray((m.start||0)+c,m.end);let h=m.start||0;return l&&(_E[4]=l,_E[5]=l>>8,m.set(_E,h),h+=8),Gc&&(u|=Nn),u>=0&&((m.dataView||(m.dataView=new DataView(m.buffer,m.byteOffset,m.byteLength))).setUint32(h,u|hE<<24),h+=4,d>=0&&((m.dataView||(m.dataView=new DataView(m.buffer,m.byteOffset,m.byteLength))).setFloat64(h,d),h+=8),f&&(m.dataView||(m.dataView=new DataView(m.buffer,m.byteOffset,m.byteLength))).setUint32(h,f)),m}else return pm=n.call(this,i,a),pm};let s=this.saveStructures;this.saveStructures=function(i,a){let c=s.call(this,i,a);return this.hasStructureUpdate=!0,c}}decode(t,r){ct=null;let n=r?.start||0,s=r>-1?r:r?.end||t.length,i=t[n],a=0;try{if(i<32&&s>2){let c=n,l;if(i===2){if(t.copy)t.copy(Em,0,c),c+=8;else for(let m=0;m<8;m++)Em[m]=t[c++];l=N6(),i=t[c]}let u,d;i<32&&(i===hE?(a=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4):(a=i|t[c+1]<<5,c+=2),a&gE&&(u=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8),a&BA&&(d=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4));let f=qc(()=>r?.valueAsBuffer?t.subarray(c,s):super.decode(t.subarray(c,s),s-c),this.rootStore);return ct={localTime:l,[yu]:a,expiresAt:u,residencyId:d},f}return r?.valueAsBuffer?t:qc(()=>super.decode(t,r),this.rootStore)}catch(c){return EE.error("Error decoding record",c,"data: "+t.slice(0,40).toString("hex")),null}}};o(N6,"getTimestamp");o(TE,"handleLocalTimeForGets");zc=[];setInterval(()=>{for(let e=0;e<zc.length;e++){let t=zc[e].deref();!t||t.isDone||t.isCommitted?zc.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(EE.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):EE.error("Read transaction detected that has been open too long (over one minute), make sure read transactions are quickly closed",t)),t.openTimer++):t.openTimer=1)}},15e3).unref();o(HA,"recordUpdater");o(jc,"removeEntry")});function qA(e,t,r,n,s,i,a,c){let l=e[0];if(t==="or"){let f=u(l);for(let h=1;h<e.length;h++){let p=e[h],E=u(p);f=f.concat(E)}let m=new Set;return f.filter(h=>{let p=h.key??h;return m.has(p)?!1:(m.add(p),!0)})}else{let f=u(l),m=d(e.slice(1),!0,l.estimated_count);return m.length>0?a(f,m):f}function u(f){return f.conditions?qA(f.conditions,f.operator,r,n,s,i,a,c):Nu(f,n,f.descending||s.reverse===!0,r,s.allowFullScan,c,i)}o(u,"executeCondition");function d(f,m,h){return f.map((p,E)=>{if(p.conditions){let T=p.operator==="or",R=d(p.conditions,!T,h);return T?(I,P)=>R.some(Y=>Y(I,P)):(I,P)=>R.every(Y=>Y(I,P))}let g=(p.attribute||p[0])===r.primaryKey,y=Sm(p,r,i,c,g,h);return m&&E<f.length-1&&h&&(h=U6(r.primaryStore,p.estimated_count,h)),y}).filter(Boolean)}o(d,"mapConditionsToFilters")}function Nu(e,t,r,n,s,i,a){let c=e[0]??e.attribute,l=e[1]??e.value,u=e.comparator;if(l===void 0&&u!=="sort")throw new qr.ClientError(`Search condition for ${c} must have a value`);if(Array.isArray(c)){let R=c[0],I=Pi(n.attributes,R);if(I.relationship){if(c.length<2)throw new qr.ClientError("Can not directly query a relational attribute, must query an attribute within the target table");let P=I.definition?.tableClass||I.elements?.definition?.tableClass,Y=new Map,te=Nu({attribute:c.length>2?c.slice(1):c[1],value:l,comparator:u},t,r,P,s,Y);if(I.relationship.to){i[c[0]]=Y;let x=!!Pi(P.attributes,I.relationship.to)?.elements;te=L6(te,I,P.primaryStore,x,Y)}if(I.relationship.from){let x=o($=>($?.key!==void 0&&($=$.key),Nu({attribute:I.relationship.from,value:$},t,r,n,s,Y)),"searchEntry");I.elements?(i[c[0]]=Y,te=D6(te,I,P.primaryStore,Y,x)):te=te.flatMap(x)}return te}else if(c.length===1)c=c[0];else throw new qr.ClientError("Unable to query by attribute "+JSON.stringify(c))}let d=c===n.primaryKey||c==null,f=d?n.primaryStore:n.indices[c],m,h,p,E;l instanceof Date&&(l=l.getTime());let g;switch($A[u]||u){case"lt":m=!0,h=l;break;case"le":m=!0,h=l,p=!0;break;case"gt":m=l,E=!0;break;case"ge":m=l;break;case"prefix":Array.isArray(l)?l[l.length-1]!=null&&(l=l.concat(null)):l=[l,null],m=l,h=l.slice(0),h[h.length-1]=Ci.MAXIMUM_KEY;break;case"starts_with":m=l.toString(),h=l+"\uFFFF";break;case"between":case"gele":case"gelt":case"gtlt":case"gtle":m=l[0],m instanceof Date&&(m=m.getTime()),h=l[1],h instanceof Date&&(h=h.getTime()),p=u==="gele"||u==="gtle"||u==="between",E=u==="gtlt"||u==="gtle";break;case"equals":case void 0:m=l,h=l,p=!0;break;case"ne":if(l===null){m=l,E=!0;break}case"sort":case"contains":case"ends_with":m=!0,g=!0;break;default:throw new qr.ClientError(`Unknown query comparator "${u}"`)}let y;if(typeof m=="string"&&m.length>ys.MAX_SEARCH_KEY_LENGTH&&(m=m.slice(0,ys.MAX_SEARCH_KEY_LENGTH)+ys.OVERFLOW_MARKER,E=!1,y=Sm(e,n,null,i,d)),typeof h=="string"&&h.length>ys.MAX_SEARCH_KEY_LENGTH&&(h=h.slice(0,ys.MAX_SEARCH_KEY_LENGTH)+ys.OVERFLOW_MARKER,p=!0,y=y??Sm(e,n,null,i,d)),r){let R=m;m=h,h=R,R=!E,E=!p,p=R}if(!f||f.isIndexing||g||l===null&&!f.indexNulls){if(s===!1&&!f)throw new qr.ClientError(`"${c}" is not indexed, can not search for this attribute`,404);if(s===!1&&g)throw new qr.ClientError(`Can not use ${u||"equal"} operator without combining with a condition that uses an index, can not search for attribute ${c}`,403);if(f?.isIndexing)throw new qr.ServerError(`"${c}" is not indexed yet, can not search for this attribute`,503);if(l===null&&f&&!f.indexNulls)throw new qr.ClientError(`"${c}" is not indexed for nulls, index needs to be rebuilt to search for nulls, can not search for this attribute`,400);if(y=y??Sm(e,n,null,i,d),!y)throw new qr.ClientError(`Unknown search operator ${e.comparator}`)}let T={start:m,end:h,inclusiveEnd:p,exclusiveStart:E,values:!0,versions:d,transaction:t,reverse:r};if(d){let R=f.getRange(T).map(y?function({key:I,value:P}){return this?.isSync?P&&y(P)?I:Aa.SKIP:new Promise((Y,te)=>setImmediate(()=>{try{Y(P&&y(P)?I:Aa.SKIP)}catch(x){te(x)}}))}:I=>I.value==null&&!(I.metadataFlags&(wn|ba))?Aa.SKIP:I);return R.hasEntries=!0,R}else return f?f.customIndex?f.customIndex.search(e,a).map(R=>{if(typeof R=="object"&&R){let{key:I,...P}=R,Y=n.primaryStore.getEntry(I);return{...P,...Y}}return R}):f.getRange(T).map(y?function({key:R,value:I}){let P;return typeof R=="string"&&R.length>ys.MAX_SEARCH_KEY_LENGTH?P=n.primaryStore.get(I):P={[c]:R},this.isSync?y(P)?I:Aa.SKIP:new Promise((Y,te)=>setImmediate(()=>{try{Y(y(P)?I:Aa.SKIP)}catch(x){te(x)}}))}:({value:R})=>R):n.primaryStore.getRange(r?{end:!0,transaction:t,reverse:!0}:{start:!0,transaction:t}).map(function({key:R,value:I}){return this.isSync?I&&y(I)?R:Aa.SKIP:new Promise((P,Y)=>setImmediate(()=>{try{P(I&&y(I)?R:Aa.SKIP)}catch(te){Y(te)}}))})}function Pi(e,t){if(Array.isArray(t))if(t.length>1){let r=Pi(e,t[0]),n=(r?.definition?.tableClass||r?.elements?.definition?.tableClass)?.attributes??r?.properties;return n?Pi(n,t.slice(1)):void 0}else t=t.toString();else typeof t!="string"&&(t=t.toString());return e.find(r=>r.name===t)}function L6(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i;return s.hasMappings=!0,{next(){if(!i){let c=t.relationship.to,l=o((u,d)=>{let f=s.get(u);f?f.push(d):s.set(u,f=[d])},"addEntry");for(let u of e){let d=u.value??r.get(u.key??u),f=d?.[c];if(f!=null&&!s.filters?.some(m=>!m(d)))if(n)for(let m=0;m<f.length;m++)l(f[m],u);else l(f,u)}return i=s.keys()[Symbol.iterator](),this.next()}let a=i.next();return a.done?a:{value:a.value}},return(){if(i?.return)return i.return()}}}})}function D6(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i,a,c=new Set;return{next(){let l;if(a)for(;l=a.next(),!l.done;){let u=l.value;if(!c.has(u))return c.add(u),l}if(!i){let u=new Set;n.fromRecord=d=>d[t.relationship.from]?.filter?.(f=>u.has(f));for(let d of e){if(n.filters){let f=r.get(d);if(n.filters.some(m=>!m(f)))continue}u.add(d)}return i=u[Symbol.iterator](),this.next()}do{let u=i.next();return u.done?u:(a=s(u.value)[Symbol.iterator](),this.next())}while(!0)},return(){return a?.return?.()},throw(){return a?.throw?.()}}}})}function Sm(e,t,r,n,s,i){let a=e.comparator,c=e[0]??e.attribute,l=e[1]??e.value;if(Array.isArray(c)){if(c.length===0)return()=>!0;if(c.length===1)c=c[0];else if(c.length>1){let d=c[0],f=Pi(t.attributes,d),m=f.definition?.tableClass||f.elements.definition?.tableClass,h=n?.[d],p=Sm({attribute:c.length>2?c.slice(1):c[1],value:l,comparator:a},m,r,h?.[d]?.joined,c[1]===m.primaryKey,i);if(!p)return;if(h){h.filters||(h.filters=[]),h.filters.push(p);return}let E=t.propertyResolvers?.[d];E.to&&(p.to=E.to);let g,y=o((R,I)=>{let P,Y;return E?E.returnDirect?(P=E(R,r,I),Y=ct):(Y=E(R,r,I,!0),Array.isArray(Y)?(P=Y.map(te=>te.value),Y=null):P=Y?.value):P=R[d],{subObject:P,subEntry:Y}},"getSubObject"),T=o((R,I)=>{if(E&&p.idFilter){if(!g)if(p.idFilter.idSet?.size===1){for(let $ of p.idFilter.idSet)e={attribute:E.from??t.primaryKey,value:$};g=u(E.from??t.primaryKey,p.idFilter,!0,!0)}else g=u(E.from??t.primaryKey,p.idFilter,!1,!0);let x=g(R);return g.idFilter&&(T.idFilter=g.idFilter),x}let{subObject:P,subEntry:Y}=y(R,I);return P?Array.isArray(P)?(!n?.[d]&&n&&(n[d]={fromRecord(x){let $=y(x).subObject;return Array.isArray($)?$.filter(p).map(j=>j[m.primaryKey]):$}}),P.some(p)):p(P,Y):!1},"recordFilter");return T}}switch(l instanceof Date&&(l=l.getTime()),$A[a]||a){case ys.SEARCH_TYPES.EQUALS:case void 0:return u(c,d=>d===l,!0);case"contains":return u(c,d=>d?.toString().includes(l));case"ends_with":return u(c,d=>d?.toString().endsWith(l));case"starts_with":return u(c,d=>typeof d=="string"&&d.startsWith(l),!0);case"prefix":return Array.isArray(l)?l[l.length-1]==null&&(l=l.slice(0,-1)):l=[l],u(c,d=>{if(!Array.isArray(d))return!1;for(let f=0,m=l.length;f<m;f++)if(d[f]!==l[f])return!1;return!0},!0);case"between":return l[0]instanceof Date&&(l[0]=l[0].getTime()),l[1]instanceof Date&&(l[1]=l[1].getTime()),u(c,d=>(0,Ci.compareKeys)(d,l[0])>=0&&(0,Ci.compareKeys)(d,l[1])<=0,!0);case"gt":return u(c,d=>(0,Ci.compareKeys)(d,l)>0);case"ge":return u(c,d=>(0,Ci.compareKeys)(d,l)>=0);case"lt":return u(c,d=>(0,Ci.compareKeys)(d,l)<0);case"le":return u(c,d=>(0,Ci.compareKeys)(d,l)<=0);case"ne":return u(c,d=>(0,Ci.compareKeys)(d,l)!==0,!1,!0);case"sort":return()=>!0;default:throw new qr.ClientError(`Unknown query comparator "${a}"`)}function u(d,f,m,h){let p;m=m&&!s&&t?.indices[d]&&i>3,m&&(e.estimated_count==null&&yE(t)(e),p=e.estimated_count>>4,(isNaN(p)||p>=i)&&(m=!1));let E=0,g=3;function y(T){let R=T[d],I;if(typeof R!="object"||!R||h?I=f(R):Array.isArray(R)?I=R.some(f):R instanceof Date&&(I=f(R.getTime())),m&&(g++,!I&&!y.idFilter&&++E/g*i>p)){let P=Nu(e,r.transaction.getReadTxn(),!1,t),Y;y.to?Y=P.flatMap(x=>t.primaryStore.get(x)[y.to]):Y=P.map(wu);let te=new Set(Y);y.idFilter=x=>te.has(wu(x)),y.idFilter.idSet=te}return I}return o(y,"recordFilter"),s&&(y.idFilter=f),y}o(u,"attributeComparator")}function yE(e){function t(r){if(r.estimated_count===void 0){if(r.conditions){let s;if(r.operator==="or"){s=0;for(let i of r.conditions)t(i),s+=i.estimated_count}else{s=1/0;for(let i of r.conditions)t(i),s=isFinite(s)?s*i.estimated_count/Ro(e.primaryStore):i.estimated_count}return r.estimated_count=s,r.estimated_count}let n=r.comparator||r.search_type;if(n=$A[n]||n,n===ys.SEARCH_TYPES.EQUALS||!n){let s=r[0]??r.attribute;if(s==null||s===e.primaryKey)r.estimated_count=1;else if(Array.isArray(s)&&s.length>1){let i=Pi(e.attributes,s[0]),a=i.definition?.tableClass||i.elements.definition?.tableClass,c=yE(a)({value:r.value,attribute:s.length>2?s.slice(1):s[1],comparator:"equals"}),l=e.indices[i.relationship.from];r.estimated_count=c+(l?c*Ro(e.indices[i.relationship.from])/(Ro(a.primaryStore)||1):c)}else{let i=e.indices[s];r.estimated_count=i?i.getValuesCount(r[1]??r.value):1/0}}else if(n==="contains"||n==="ends_with"||n==="ne"){let s=r[0]??r.attribute,i=e.indices[s];r.value===null&&n==="ne"?r.estimated_count=Ro(e.primaryStore)-(i?i.getValuesCount(null):0):r.estimated_count=1/0}else if(n==="starts_with"||n==="prefix")r.estimated_count=C6*Ro(e.primaryStore)+1;else if(n==="between")r.estimated_count=O6*Ro(e.primaryStore)+1;else if(n==="sort"){let s=r[0]??r.attribute,i=e.indices[s];i?.customIndex?.estimateCountAsSort?r.estimated_count=i.customIndex.estimateCountAsSort(r):r.estimated_count=Ro(e.primaryStore)+1}else{let s=r[0]??r.attribute,i=e.indices[s];i?.customIndex?.estimateCount?r.estimated_count=i.customIndex.estimateCount(r.value):r.estimated_count=w6*Ro(e.primaryStore)+1}typeof r.descending=="boolean"&&(r.estimated_count/=2)}return r.estimated_count}return o(t,"estimateConditionForTable"),t}function AE(e,t){if(e)if(yo=e,Au.lastIndex=0,M6.test(e))try{if(t&&(t.conditions=[]),Js=t??new Iu,gm(Js,""),Lr!==yo.length&&Gt("Unable to parse query, unexpected end of query"),Js.parseErrorMessage&&(Js.parseError=new kA(t.parseErrorMessage),!t))throw Js.parseError;return Js}catch(r){if(r.statusCode=400,r.message=`Unable to parse query, ${r.message} at position ${Lr} in '${yo}'`,Js.parseErrorMessage&&(r.message+=", "+Js.parseErrorMessage),t)t.parseError=r;else throw r}else return t??new URLSearchParams(e)}function Gt(e){let t=`${e} at position ${Lr}`;Js.parseErrorMessage=Js.parseErrorMessage?Js.parseErrorMessage+", "+t:t}function gm(e,t){let r=Au,n,s,i,a,c,l=decodeURIComponent,u;for(;n=r.exec(yo);){Lr=r.lastIndex;let[,d,f]=n;a?(d&&Gt(`expected operator, but encountered '${d}'`),a=!1,c=!1):c=!0;let m;switch(f){case"=":s!=null?(d.length<=2?i=d:Gt(`invalid FIQL operator ${d}`),l=lU):(l=decodeURIComponent,i="equals",d||Gt("attribute must be specified before equality comparator"),s=bu(d));break;case"==":case"!=":case"<":case"<=":case">":case">=":case"===":case"!==":i=P6[f],l=GA[i]?lU:decodeURIComponent,d||Gt(`attribute must be specified before comparator ${f}`),s=bu(d);break;case"&=":case"|=":case"|":case"&":case"":case void 0:if(s==null)s===void 0&&(t&&Gt(`expected '${t}', but encountered ${f[0]?"'"+f[0]+"'":"end of string"}}`),Gt(`no comparison specified before ${f?"'"+f+"'":"end of string"}`));else{e.conditions||Gt("conditions/comparisons are not allowed in a property list");let p={comparator:i,attribute:s||null,value:l(d)};if(i==="eq"&&uU(p,d),s===""){let E=e.conditions[e.conditions.length-1];E.chainedConditions=E.chainedConditions||[],E.chainedConditions.push(p),E.operator=u}else RE(e,u),e.conditions.push(p)}f==="&"?(u="and",s=void 0):f==="|"?(u="or",s=void 0):f==="&="?(u="and",s=""):f==="|="&&(u="or",s="");break;case",":e.conditions?Gt("conditions/comparisons are not allowed in a property list"):e.push(bu(d)),s=void 0;break;case"(":Au.lastIndex=Lr;let h=gm(d?[]:new Iu,")");switch(d){case"":RE(e,u),e.conditions.push(h);break;case"limit":switch(h.length){case 1:e.limit=+h[0];break;case 2:e.offset=+h[0],e.limit=h[1]-e.offset;break;default:Gt("limit must have 1 or 2 arguments")}break;case"select":Array.isArray(h[0])&&h.length===1&&!h[0].name?(e.select=h[0],e.select.asArray=!0):h.length===1?e.select=h[0]:h.length===2&&h[1]===""?e.select=h.slice(0,1):e.select=h;break;case"group-by":Gt("group by is not implemented yet");case"sort":e.sort=dU(h);break;default:Gt(`unknown query function call ${d}`)}yo[Lr]===","?r.lastIndex=++Lr:a=!0,s=null;break;case"{":e.conditions&&Gt("property sets are not allowed in a queries"),d||Gt("property sets must have a defined parent property name"),Au.lastIndex=Lr,m=gm([],"}"),m.name=d,e.push(m),yo[Lr]===","?r.lastIndex=++Lr:a=!0;break;case"[":if(Au.lastIndex=Lr,d?(m=gm(new Iu,"]"),m.name=d):m=gm(e.conditions?new Iu:[],"]"),e.conditions)if(RE(e,u),yo[Lr]==="="){l=decodeURIComponent,i="equals",s=bu(d),r.lastIndex=++Lr;break}else e.conditions.push(m),s=null;else e.push(m);yo[Lr]===","?r.lastIndex=++Lr:a=!0;break;case")":case"]":case"}":if(t===f[0]){if(e.conditions)if(s){let p={comparator:i||"equals",attribute:s,value:l(d)};i==="eq"&&uU(p,d),RE(e,u),e.conditions.push(p)}else d&&Gt("no attribute or comparison specified");else(d||e.length>0&&c)&&e.push(bu(d));return e}else Gt(t?`expected '${t}', but encountered '${f[0]}'`:`unexpected token '${f[0]}'`);default:Gt(`unexpected operator '${f}'`)}if(t!==")"&&(r=s?v6:Au,r.lastIndex=Lr),Lr===yo.length)return e}t&&Gt(`expected '${t}', but encountered end of string`)}function RE(e,t){e.conditions.length>0&&(e.operator?e.operator!==t&&Gt("Can not mix operators within a condition grouping"):e.operator=t)}function bu(e){return e.indexOf(".")>-1?e.split(".").map(bu):decodeURIComponent(e)}function lU(e){if(e==="null")return null;if(e.indexOf(":")>-1){let[t,r]=e.split(":");if(t==="number")return r[0]==="$"?parseInt(r.slice(1),36):+r;if(t==="boolean")return r==="true";if(t==="date")return new Date(isNaN(r)?decodeURIComponent(r):+r);if(t==="string")return decodeURIComponent(r);throw new qr.ClientError(`Unknown type ${t}`)}return decodeURIComponent(e)}function uU(e,t){if(t.indexOf("*")>-1)if(t.endsWith("*"))e.comparator="starts_with",e.value=decodeURIComponent(t.slice(0,-1));else throw new qr.ClientError("wildcard can only be used at the end of a string")}function dU(e){let t=fU(e[0]);return e.length>1&&(t.next=dU(e.slice(1))),t}function fU(e){if(Array.isArray(e)){let t=fU(e[0]);return e[0]=t.attribute,t.attribute=e,t}if(typeof e=="string")switch(e[0]){case"-":return{attribute:e.slice(1),descending:!0};case"+":return{attribute:e.slice(1),descending:!1};default:return{attribute:e,descending:!1}}Gt(`Unknown sort type ${e}`)}function wu(e){return Array.isArray(e)?e.join("\0"):e}function Ro(e){let t=Date.now();return(e.estimatedEntryCountExpires||0)<t&&(e.estimatedEntryCount=e.getStats().entryCount,e.estimatedEntryCountExpires=t+1e4),e.estimatedEntryCount}function U6(e,t,r){return t*r/Ro(e)}var qr,ys,Ci,Aa,w6,O6,C6,P6,GA,$A,kA,M6,Au,v6,Lr,Js,yo,Iu,bE=fe(()=>{qr=w(_e()),ys=w(kt()),Ci=require("ordered-binary"),Aa=require("lmdb");Tm();Wc();w6=.3,O6=.1,C6=.05,P6={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},GA={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};o(qA,"executeConditions");o(Nu,"searchByIndex");o(Pi,"findAttribute");o(L6,"joinTo");o(D6,"joinFrom");$A={eq:"equals",greater_than:"gt",greaterThan:"gt",greater_than_equal:"ge",greaterThanEqual:"ge",less_than:"lt",lessThan:"lt",less_than_equal:"le",lessThanEqual:"le",not_equal:"ne",notEqual:"ne",equal:"equals",sw:"starts_with",startsWith:"starts_with",ew:"ends_with",endsWith:"ends_with",ct:"contains",">":"gt",">=":"ge","<":"lt","<=":"le","...":"between"};o(Sm,"filterByType");o(yE,"estimateCondition");kA=class extends qr.Violation{static{o(this,"SyntaxViolation")}},M6=/[()[\]|!<>.]|(=\w*=)/,Au=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,v6=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/g;o(AE,"parseQuery");o(Gt,"recordError");o(gm,"parseBlock");o(RE,"assignOperator");o(bu,"decodeProperty");o(lU,"typedDecoding");o(uU,"wildcardDecoding");o(dU,"toSortObject");o(fU,"toSortEntry");Iu=class{static{o(this,"Query")}constructor(){this.conditions=[]}[Symbol.iterator](){return this.conditions[Symbol.iterator]()}get(t){for(let r=0;r<this.conditions.length;r++){let n=this.conditions[r];if(n.attribute===t)return n.value}}getAll(){let t=[];for(let r=0,n=this.conditions.length;r<n;r++){let s=this.conditions[r];s.attribute&&t.push(s.value)}return t}};o(wu,"flattenKey");o(Ro,"estimatedEntryCount");o(U6,"intersectionEstimate")});var mU,Xs,IE=fe(()=>{mU=w(zs());Ia();Xs=class extends URLSearchParams{static{o(this,"RequestTarget")}#e;pathname;search;id;isCollection;constructor(t){let r,n;if(t&&(r=t.indexOf("?"))>-1){n=t.slice(0,r);let s=t.slice(r+1);super(s),this.search=s}else super(),n=t;this.pathname=n??"",this.#e=t}toString(){return this.#e?this.#e:this.size>0?this.pathname+"?"+super.toString():this.pathname}get url(){return this.toString()}delete(t){super.delete(t),this.conditions&&(this.conditions=this.conditions.filter(r=>r.attribute!==t)),this.#e=void 0}set(t,r){this.delete(t),super.set(t,r),this.conditions?.push({attribute:t,value:r})}append(t,r){super.append(t,r),this.#e=void 0,this.conditions?.push({attribute:t,value:r})}};(0,mU._assignPackageExport)("Resource",Dr)});var gU={};Ce(gU,{MultiPartId:()=>NE,Resource:()=>Dr,contextStorage:()=>Cu,snakeCase:()=>B6,transformForSelect:()=>wE});function B6(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function hU(e,t){if(Qc=!1,e==="")return null;if(e=e.slice(1),t.splitSegments){if(e.indexOf("/")===-1)return e===""?(Qc=!0,null):t.coerceId(decodeURIComponent(e));let r=e.split("/"),n=new NE;for(let s=0;s<r.length;s++){let i=r[s];if(!i&&s===r.length-1){Qc=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}else{if(e==="")return Qc=!0,null;e[e.length-1]==="/"&&(Qc=!0)}return t.coerceId(decodeURIComponent(e))}function On(e,t){n.reliesOnPrototype=!0;let r=t.hasContent;return n;function n(s,i,a){let c,l,u,d;if(r){if(a)d=i,a=a.getContext?.()||a;else if(i)typeof s=="object"&&s&&(!Array.isArray(s)||typeof s[0]=="object")?(d=s,c=d[this.primaryKey]??null,a=i.getContext?.()||i):i?.transaction instanceof fo?a=i:d=i;else if(s&&typeof s=="object")d=s,s=void 0,c=d.getId?.()??d[this.primaryKey];else throw new Ou.ClientError(`Invalid argument for data, must be an object, but got ${s}`);c===null&&(u=!0)}else i?a=i.getContext?.()||i:s&&typeof s=="object"&&!Array.isArray(s)&&(a=s);if(c===void 0)if(typeof s=="object"&&s){if(l=s,c=s instanceof URLSearchParams?s.toString():s.url,s.conditions)c=s.id;else if(typeof c=="string")if(this.directURLMapping)c=c.slice(1),l.id=c;else{let E=c.indexOf("?");E>-1&&(l=this.parseQuery(c.slice(E+1),s),c=c.slice(0,E),c===""&&(u=!0));let g=this.parsePath(c,a,l);g?.id!==void 0?(g.query&&(l?l=Object.assign(g.query,l):l=g.query),u=g.isCollection,c=g.id):c=g,c&&(l.id=c)}else if(s[Symbol.iterator]){c=[],u=!0;for(let E of s){if(typeof E=="object"&&E)break;c.push(E)}c.length===0?c=null:(c.length===1&&(c=c[0]),l.slice&&(l=l.slice(c.length,l.length),l.length===0&&(l=new Xs,l.id=c,u=!1)))}c===void 0&&(c=s.id??null,c==null&&(u=!0))}else c=s,l=new Xs,l.id=c,c==null&&(u=!0);l||(l=new Xs,l.id=c),u&&(l.isCollection=!0);let f;a||(a=Cu.getStore()??{}),l.ensureLoaded!=null||l.async||u?(f={...t},l.ensureLoaded!=null&&(f.ensureLoaded=l.ensureLoaded),l.async&&(f.async=l.async),u&&(f.isCollection=!0)):f=t;let m=this.loadAsInstance,h=p;if((m===!1?!this.explicitContext:this.explicitContext===!1)&&(h=o(E=>Cu.run(a,()=>p(E)),"runAction")),a?.transaction){let E=this.getResource(c,a,f);return E.then?E.then(h):h(E)}else return vt(a,()=>{let E=this.getResource(c,a,f);return E.then?E.then(h):h(E)},f);function p(E){if(m!==!1&&a.authorize){a.authorize=!1;let g=t.type==="read"?E.allowRead(a.user,l,a):t.type==="update"?E.doesExist?.()===!1?E.allowCreate(a.user,d,a):E.allowUpdate(a.user,d,a):t.type==="create"?E.allowCreate(a.user,d,a):E.allowDelete(a.user,l,a);if(g?.then)return g.then(y=>{if(!y)throw new Ou.AccessViolation(a.user);return typeof d?.then=="function"?d.then(T=>e(E,l,a,T)):e(E,l,a,d)});if(!g)throw new Ou.AccessViolation(a.user)}return typeof d?.then=="function"?d.then(g=>e(E,l,a,g)):e(E,l,a,d)}o(p,"authorizeActionOnResource")}}function Vn(e,t){let r=new Ou.ClientError(`The ${e.constructor.name} does not have a ${t} method implemented`,405);r.allow=[],r.method=t;for(let n of["get","put","post","delete","query","move","copy"])typeof e[n]=="function"&&r.allow.push(n);throw r}function VA(e,t,r){let n=e.getRecord?.();if(n){let s=e.getChanges?.();return i=>{let a,c;return e.hasOwnProperty(i)&&typeof(a=e[i])!="function"?a:s&&i in s?s[i]:(c=t?.[i])?c(e,r):n[i]}}else return t?s=>{let i=t[s];return i?i(e,r):e[s]}:s=>e[s]}function wE(e,t){let r=t.propertyResolvers,n=t.getContext?.(),s;if(typeof e=="string")return o(function a(c){return c.then?c.then(a):Array.isArray(c)?c.map(a):VA(c,r,n)(e)},"transform");if(typeof e=="object"){if(e.asArray)return o(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(c);let u=[],d=i(VA(l,r,n));for(let f of e)u.push(d(f));return u},"transform");let a=e.forceNulls;return o(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(m=>m&&typeof m=="object"?c(m):m);let u={},d=i(VA(l,r,n)),f;for(let m of e){let h=d(m);h===void 0&&a&&(h=null),h?.then?(f||(f=[]),f.push(h.then(p=>u[m.name||m]=p))):u[m.name||m]=h}return f?Promise.all(f).then(()=>u):u},"transform")}else throw new Error("Invalid select argument type "+typeof e);function i(a){return c=>{if(typeof c=="string")return a(c);if(typeof c=="object")if(c.name){s||(s={});let l=s[c.name];if(!l){let d=r[c.name]?.definition?.tableClass;l=s[c.name]=wE(c.select||c,d)}let u=a(c.name);return l(u)}else return a(c);else return c}}o(i,"handleProperty")}var pU,_U,Ou,EU,Cu,x6,Dr,Qc,NE,Ia=fe(()=>{pU=require("crypto");Jf();_u();_U=w(zs()),Ou=w(_e());xc();bE();EU=require("async_hooks");IE();Cu=new EU.AsyncLocalStorage,x6={json:"application/json",cbor:"application/cbor",msgpack:"application/x-msgpack",csv:"text/csv"},Dr=class{static{o(this,"Resource")}#e;#t;#r;static transactions;static directURLMapping=!1;static loadAsInstance;constructor(t,r){this.#e=t;let n=r?.getContext?r.getContext()??null:void 0;this.#t=n!==void 0?n:r||null}static get=On(function(t,r,n,s){let i=t.get?.(r);if(i?.then)return i.then(a);return a(i);function a(c){let l;if((l=r?.select)&&c!=null&&!c.selectApplied){let u=wE(l,t.constructor);return typeof c?.map=="function"?c.map(u):u(c)}return c}},{type:"read",letItLinger:!0,ensureLoaded:!0,async:!0});static put=On(function(t,r,n,s){if(Array.isArray(s)&&t.#r&&t.constructor.loadAsInstance!==!1){let i=[];for(let a of s){let c=t.constructor,l=a[c.primaryKey],u=c.getResource(l,n,{async:!0});u.then?i.push(u.then(d=>d.put(a,n))):i.push(u.put(a,n))}return Promise.all(i)}return t.put?t.constructor.loadAsInstance===!1?t.put(r,s):t.put(s,r):Vn(t,"put")},{hasContent:!0,type:"update"});static patch=On(function(t,r,n,s){return t.patch?t.constructor.loadAsInstance===!1?t.patch(r,s):t.patch(s,r):Vn(t,"patch")},{hasContent:!0,type:"update"});static delete=On(function(t,r,n,s){return t.delete?t.delete(r):Vn(t,"delete")},{hasContent:!1,type:"delete"});static getNewId(){return(0,pU.randomUUID)()}static create(t,r,n){n?n.getContext&&(n=n.getContext()):n=Cu.getStore()??{};let s;return this.loadAsInstance===!1?s=t:t==null?s=r?.[this.primaryKey]??this.getNewId():Array.isArray(t)&&typeof t[0]!="object"?s=r?.[this.primaryKey]??[...t,this.getNewId()]:typeof t!="object"?s=r?.[this.primaryKey]??[t,this.getNewId()]:(s=t?.[this.primaryKey]??this.getNewId(),n=r||{},r=t),vt(n,async()=>{let i=new this(s,n),a=await i.create?i.create(s,r):Vn(i,"create");return n.newLocation=s??a?.[this.primaryKey],n.createdResource=!0,this.loadAsInstance===!1?a:i})}static invalidate=On(function(t,r,n,s){return t.invalidate?t.invalidate(r):Vn(t,"delete")},{hasContent:!1,type:"update"});static post=On(function(t,r,n,s){return t.#e!=null&&t.update?.(),t.constructor.loadAsInstance===!1?t.post(r,s):t.post(s,r)},{hasContent:!0,type:"create"});static update=On(function(t,r,n,s){return t.update(r,s)},{hasContent:!0,type:"create"});static connect=On(function(t,r,n,s){return t.connect?t.constructor.loadAsInstance===!1?t.connect(r,s):t.connect(s,r):Vn(t,"connect")},{hasContent:!0,type:"read"});static subscribe=On(function(t,r,n,s){return t.subscribe?t.subscribe(r):Vn(t,"subscribe")},{type:"read"});static publish=On(function(t,r,n,s){return t.#e!=null&&t.update?.(),t.publish?t.constructor.loadAsInstance===!1?t.publish(r,s):t.publish(s,r):Vn(t,"publish")},{hasContent:!0,type:"create"});static search=On(function(t,r,n){let s=t.search?t.search(r):Vn(t,"search"),i=n.select;if(i&&n.hasOwnProperty("select")&&s!=null&&!s.selectApplied){let a=wE(i,t.constructor);return s.map(a)}return s},{type:"read"});static query=On(function(t,r,n,s){return t.search?t.constructor.loadAsInstance===!1?t.search(r,s):t.search(s,r):Vn(t,"search")},{hasContent:!0,type:"read"});static copy=On(function(t,r,n,s){return t.copy?t.constructor.loadAsInstance===!1?t.copy(r,s):t.copy(s,r):Vn(t,"copy")},{hasContent:!0,type:"create"});static move=On(function(t,r,n,s){return t.move?t.constructor.loadAsInstance===!1?t.move(r,s):t.move(s,r):Vn(t,"move")},{hasContent:!0,type:"delete"});async post(t){if(this.#r)return(await this.constructor.create(this.#e,t,this.#t)).#e;Vn(this,"post")}static isCollection(t){return t&&t.#r}get isCollection(){return this.#r}static coerceId(t){return t}static parseQuery(t,r){return AE(t,r)}static parsePath(t,r,n){let s=t.indexOf(".");if(s>-1){let a=t.slice(s+1),c=r?.headers&&x6[a];if(c)r.requestedContentType=c,t=t.slice(0,s);else if(this.attributes?.find(l=>l.name===a))if(t=t.slice(0,s),n)n.property=a;else return{query:{property:a},id:hU(t,this),isCollection:Qc}}let i=hU(t,this);return Qc?{id:i,isCollection:!0}:i}static getResource(t,r,n){let s,i=r.getContext?.(),a;typeof r.isCollection=="boolean"&&r.hasOwnProperty("isCollection")?a=r.isCollection:a=n?.isCollection;let c=a&&this.Collection||this;if(i||(i=i===void 0?r:{}),i.transaction){let l;if(i.resourceCache?l=i.resourceCache:l=i.resourceCache=[],l.asMap){let u=l.asMap.get(t);if(s=u?.find(d=>d.constructor===c),s)return s;u||l.asMap.set(t,u=[]),u.push(s=new c(t,i))}else{if(s=l.find(u=>u.#e===t&&u.constructor===c),s)return s;if(l.push(s=new c(t,i)),l.length>10){let u=new Map;for(let d of l){let f=d.#e,m=u.get(f);m?m.push(d):u.set(f,[d])}i.resourceCache.length=0,i.resourceCache.asMap=u}}}else s=new c(t,i);return a&&(s.#r=!0),s}subscribe(t){return new $n}connect(t,r){return r?.subscribe!==!1?this.subscribe?.(r):new $n}allowRead(t,r){return t?.role.permission.super_user}allowUpdate(t,r,n){return t?.role.permission.super_user}allowCreate(t,r,n){return t?.role.permission.super_user}allowDelete(t,r){return t?.role.permission.super_user}getId(){return this.#e}getContext(){return this.#t}};(0,_U._assignPackageExport)("Resource",Dr);o(B6,"snakeCase");o(hU,"pathToId");NE=class extends Array{static{o(this,"MultiPartId")}toString(){return this.join("/")}};o(On,"transactional");o(Vn,"missingMethod");o(VA,"selectFromObject");o(wE,"transformForSelect")});var Jc,KA=fe(()=>{Jc=class{static{o(this,"ErrorResource")}error;constructor(t){this.error=t}isError=!0;allowRead(){throw this.error}allowUpdate(){throw this.error}allowCreate(){throw this.error}allowDelete(){throw this.error}getId(){throw this.error}getContext(){throw this.error}get(){throw this.error}post(){throw this.error}put(){throw this.error}delete(){throw this.error}connect(){throw this.error}getResource(){return this}publish(){throw this.error}subscribe(){throw this.error}}});var RU={};Ce(RU,{Resources:()=>OE,keyArrayToString:()=>Pu,resetResources:()=>F6,resources:()=>As});function F6(){return As=new OE,ve.resources=As,As}function Pu(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var SU,TU,OE,As,Lu=fe(()=>{xc();KA();SU=w(z()),TU=w(_e());Pr();OE=class extends Map{static{o(this,"Resources")}isWorker=!0;loginPath;set(t,r,n,s){if(!r)throw new Error("Must provide a resource");t.startsWith("/")&&(t=t.replace(/^\/+/,""));let i={Resource:r,path:t,exportTypes:n,hasSubPaths:!1,relativeURL:""},a=super.get(t);if(a&&(a.Resource.databaseName!==r.databaseName||a.Resource.tableName!==r.tableName)&&!s){let c=new TU.ServerError(`Conflicting paths for ${t}`);SU.default.error(c),i.Resource=new Jc(c)}super.set(t,i);for(let[c,l]of this){let u=2;for(;(u=c.indexOf("/",u))>-1;){let d=this.get(c.slice(0,u));d&&(d.hasSubPaths=!0),u+=2}}}getMatch(t,r){let n=2,s=0,i,a=t.length;for(;n<a;){s=n,n=t.indexOf("/",n),n===-1&&(n=a);let u=n===a?t:t.slice(0,n),d=this.get(u),f=-1;if(!d&&n===a&&(f=u.indexOf("?",s),f!==-1)){let m=u.slice(0,f);d=this.get(m)}if(d&&(!r||d.exportTypes?.[r]!==!1)){if(d.relativeURL=t.slice(f!==-1?f:n),!d.hasSubPaths)return d;i=d}n+=2}if(i)return i;let c=t.indexOf("?"),l=c>-1?t.slice(0,c):t;return i=this.get(l),!i&&l.indexOf(".")>-1&&(i=this.get(l.split(".")[0])),i&&(!r||i.exportTypes?.[r]!==!1)?i.relativeURL=c>-1?t.slice(c):"":i||(i=this.get(""),i&&(!r||i.exportTypes?.[r]!==!1)&&(t.charAt(0)!=="/"&&(t="/"+t),i.relativeURL=t)),i}getResource(t,r){let n=this.getMatch(t);if(n)return t=n.relativeURL,n.Resource.getResource(this.pathToId(t,n.Resource),r)}call(t,r,n){return vt(r,async()=>{let s=this.getMatch(t);if(s)return t=s.relativeURL,n(s.Resource,s.path,t)})}setRepresentation(t,r,n){}};o(F6,"resetResources");o(Pu,"keyArrayToString")});function zA(e,t,r,n,s){let i=e.primaryStore.env.path,a=e.primaryStore.tableId,c;s?.crossThreads===!1?(c=AU,H6(e.primaryStore,e.auditStore)):(c=yU,e.primaryStore.env.hasSubscriptionCommitListener||(e.primaryStore.env.hasSubscriptionCommitListener=!0,e.primaryStore.on("committed",()=>{bU(yU[i])})));let l=c[i]||(c[i]=[]);if(l.auditStore=e.auditStore,l.lastTxnTime==null&&(l.lastTxnTime=Date.now()),s?.scope==="full-database")return;let u=l[a];u||(u=l[a]=new Map,u.envs=l,u.tableId=a,u.store=e.primaryStore),t=Pu(t);let d=new WA(r);d.startTime=n;let f=u.get(t);return f?f.push(d):(u.set(t,f=[d]),f.tables=u,f.key=t),d.subscriptions=f,d}function bU(e){if(!e)return;let t=e.auditStore;t.resetReadTxn(),IU(e.auditStore);let r;for(let{key:n,value:s}of t.getRange({start:e.lastTxnTime,exclusiveStart:!0})){e.lastTxnTime=n;let i=Ut(s),a=e[i.tableId];if(!a)continue;let c=i.recordId,l=Pu(c),u=0;do{let d=a.get(l);if(d){for(let m of d)if(!(u>0&&!(m.includeDescendants&&!(m.onlyChildren&&u>1)))){if(m.startTime>=n){(0,YA.info)("omitting",c,m.startTime,n);continue}try{let h;m.supportsTransactions&&m.txnInProgress!==i.version&&(h=!0,m.txnInProgress||(r?r.push(m):r=[m]),m.txnInProgress=i.version),m.listener(c,i,n,h)}catch(h){console.error(h),(0,YA.info)(h)}}}if(l==null)break;let f=l.lastIndexOf?.("/",l.length-2);f!==l.length-1&&u++,f>-1?l=l.slice(0,f+1):l=null}while(!0)}if(r)for(let n of r)n.txnInProgress=null,n.listener(null,{type:"end_txn"},e.lastTxnTime,!0)}function H6(e,t){let r=t||e,n=r.env;if(!n.hasAfterCommitListener){n.hasAfterCommitListener=!0;let s=n.path;r.on("aftercommit",({next:i,last:a,txnId:c})=>{let l=AU[s];if(!l)return;let u=o(()=>{r.threadLocalWrites||(r.threadLocalWrites=new Float64Array(r.getUserSharedBuffer("last-thread-local-write",new ArrayBuffer(8)))),l.txnTime=r.threadLocalWrites[0]||Date.now();try{bU(l)}finally{r.threadLocalWrites[0]=l.lastTxnTime,r.unlock("thread-local-writes")}},"acquiredLock");r.attemptLock("thread-local-writes",u)&&u()})}}function IU(e){e.nextTransaction?.resolve();let t;e.nextTransaction=new Promise(r=>{t=r}),e.nextTransaction.resolve=t}function NU(e){return e.nextTransaction||(zA({primaryStore:e,auditStore:e},null,null,0,{scope:"full-database"}),IU(e)),e.nextTransaction}var YA,yU,AU,WA,jA=fe(()=>{YA=w(z());_u();Lu();mo();yU=Object.create(null),AU=Object.create(null);o(zA,"addSubscription");WA=class extends $n{static{o(this,"Subscription")}listener;subscriptions;startTime;includeDescendants;supportsTransactions;onlyChildren;constructor(t){super(),this.listener=t,this.on("close",()=>this.end())}end(){if(this.subscriptions){if(this.subscriptions.splice(this.subscriptions.indexOf(this),1),this.subscriptions.length===0){let t=this.subscriptions.tables;if(t){let r=this.subscriptions.key;if(t.delete(r),t.size===0){let n=t.envs,s=t.dbi;delete n[s]}}}this.subscriptions=null}}toJSON(){return{name:"subscription"}}};o(bU,"notifyFromTransactionData");o(H6,"listenToCommits");o(IU,"nextTransaction");o(NU,"whenNextTransaction")});var OU=M((VNe,wU)=>{"use strict";var QA=class{static{o(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};wU.exports=QA});var PU=M((YNe,CU)=>{"use strict";var JA=class{static{o(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};CU.exports=JA});var Rm=M((zNe,DU)=>{"use strict";var LU=ce(),k6=(k(),v(K)),{RecordEncoder:G6}=(Wc(),v(cU));LU.initSync();var q6=LU.get(k6.CONFIG_PARAMS.STORAGE_CACHING)!==!1,XA=class{static{o(this,"OpenDBIObject")}constructor(t,r=!1){this.dupSort=t===!0,this.encoding=t?"ordered-binary":"msgpack",this.useVersions=r,this.sharedStructuresKey=Symbol.for("structures"),r&&(this.cache=q6&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:G6})}};DU.exports=XA});var ym=M((QNe,MU)=>{"use strict";var Kn=ce(),bs=(k(),v(K));Kn.initSync();var CE=class{static{o(this,"OpenEnvironmentObject")}constructor(t,r=!1){this.path=t,this.mapSize=1073741824,this.maxDbs=1e4,this.maxReaders=2048,this.sharedStructuresKey=Symbol.for("structures"),this.readOnly=r,this.trackMetrics=!0,this.eventTurnBatching=!1,this.noSync=Kn.get(bs.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Kn.get(bs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Kn.get(bs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Kn.get(bs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Kn.get(bs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Kn.get(bs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Kn.get(bs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Kn.get(bs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Kn.get(bs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Kn.get(bs.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Kn.get(bs.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Kn.get(bs.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};MU.exports=CE;CE.MAX_DBS=1e4});var Et=M((XNe,$U)=>{"use strict";var eb=require("lmdb"),Zs=require("fs-extra"),Yn=require("path"),PE=An(),xU=z(),Cn=tn().LMDB_ERRORS_ENUM,LE=PU(),tb=Rm(),BU=ym(),Na=kt(),vU=(k(),v(K)),{table:$6,resetDatabases:V6}=(Le(),v(ft)),UU=ce(),ei=Na.INTERNAL_DBIS_NAME,FU=Na.DBI_DEFINITION_NAME,K6="data.mdb",Y6="lock.mdb",Am=".mdb",W6="-lock",ZA=class{static{o(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=Is(t,r),this.key_type=this.dbi[Na.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[Na.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new eb.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function DE(e,t){if(e===void 0)throw new Error(Cn.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(Cn.ENV_NAME_REQUIRED)}o(DE,"pathEnvNameValidation");async function rb(e,t,r=!0){try{await Zs.access(e)}catch(n){throw n.code==="ENOENT"?new Error(Cn.INVALID_BASE_PATH):n}try{let n=Yn.join(e,t+Am);return await Zs.access(n,Zs.constants.R_OK|Zs.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await Zs.access(Yn.join(e,t,K6),Zs.constants.R_OK|Zs.constants.F_OK),Yn.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(Cn.INVALID_ENVIRONMENT)}else throw new Error(Cn.INVALID_ENVIRONMENT);throw n}}o(rb,"validateEnvironmentPath");function ME(e,t){if(PE.validateEnv(e),t===void 0)throw new Error(Cn.DBI_NAME_REQUIRED)}o(ME,"validateEnvDBIName");async function z6(e,t,r=!1,n=!1){DE(e,t);let s=Yn.basename(e);t=t.toString();let i=UU.get(vU.CONFIG_PARAMS.DATABASES);i||UU.setProperty(vU.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await rb(e,t,n),HU(e,t,r)}catch(a){if(a.message===Cn.INVALID_ENVIRONMENT){let c=Yn.join(e,t);await Zs.mkdirp(n?c:e);let l=new BU(n?c:c+Am,!1),u=eb.open(l);u.dbis=Object.create(null);let d=new tb(!1);u.openDB(ei,d),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let f=nb(e,t,r);return u[Na.ENVIRONMENT_NAME_KEY]=f,global.lmdb_map[f]=u,u}throw a}}o(z6,"createEnvironment");async function j6(e,t,r,n=!0){DE(e,t),t=t.toString();let s=Yn.join(e,t);return $6({table:t,database:Yn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}o(j6,"copyEnvironment");async function HU(e,t,r=!1){DE(e,t),t=t.toString();let n=nb(e,t,r);if(global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null)),global.lmdb_map[n]!==void 0)return global.lmdb_map[n];let s=await rb(e,t),i=Yn.join(e,t+Am),a=s!=i,c=new BU(s,a),l=eb.open(c);l.dbis=Object.create(null);let u=GU(l);for(let d=0;d<u.length;d++)Is(l,u[d]);return l[Na.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}o(HU,"openEnvironment");async function Q6(e,t,r=!1){DE(e,t),t=t.toString();let n=Yn.join(e,t+Am),s=await rb(e,t);if(global.lmdb_map!==void 0){let i=nb(e,t,r);if(global.lmdb_map[i]){let a=global.lmdb_map[i];await kU(a),delete global.lmdb_map[i]}}await Zs.remove(s),await Zs.remove(s===n?s+W6:Yn.join(Yn.dirname(s),Y6))}o(Q6,"deleteEnvironment");async function kU(e){PE.validateEnv(e);let t=e[Na.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}o(kU,"closeEnvironment");function nb(e,t,r=!1){let s=`${Yn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}o(nb,"getCachedEnvironmentName");function J6(e){PE.validateEnv(e);let t=Object.create(null),r=Is(e,ei);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==ei)try{t[n]=Object.assign(new LE,s)}catch{xU.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}o(J6,"listDBIDefinitions");function GU(e){PE.validateEnv(e);let t=[],r=Is(e,ei);for(let{key:n}of r.getRange({start:!1}))n!==ei&&t.push(n);return t}o(GU,"listDBIs");function X6(e,t){let n=Is(e,ei).getEntry(t),s=new LE;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{xU.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}o(X6,"getDBIDefinition");function qU(e,t,r,n=!r){if(ME(e,t),t=t.toString(),t===ei)throw new Error(Cn.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return Is(e,t)}catch(s){if(s.message===Cn.DBI_DOES_NOT_EXIST){let i=new tb(r,n===!0),a=e.openDB(t,i),c=new LE(r===!0,n);return a[FU]=c,Is(e,ei).putSync(t,c),e.dbis[t]=a,a}throw s}}o(qU,"createDBI");function Is(e,t){if(ME(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==ei?r=X6(e,t):r=new LE,r===void 0)throw new Error(Cn.DBI_DOES_NOT_EXIST);let n;try{let s=new tb(r.dup_sort,r.useVersions);if(n=e.openDB(t,s),n.db===void 0)throw new Error("MDB_NOTFOUND")}catch(s){throw s.message.includes("MDB_NOTFOUND")===!0?new Error(Cn.DBI_DOES_NOT_EXIST):s}return n[FU]=r,e.dbis[t]=n,n}o(Is,"openDBI");function Z6(e,t){ME(e,t),t=t.toString();let r=Is(e,t),n=r.getStats();return r[Na.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}o(Z6,"statDBI");async function e8(e,t){try{let r=Yn.join(e,t+Am);return(await Zs.stat(r)).size}catch{throw new Error(Cn.INVALID_ENVIRONMENT)}}o(e8,"environmentDataSize");function t8(e,t){if(ME(e,t),t=t.toString(),t===ei)throw new Error(Cn.CANNOT_DROP_INTERNAL_DBIS_NAME);Is(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],Is(e,ei).removeSync(t)}o(t8,"dropDBI");function r8(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{Is(e,i)}catch(a){if(a.message===Cn.DBI_DOES_NOT_EXIST)qU(e,i,i!==t,i===t),n=!0;else throw a}}n&&V6()}o(r8,"initializeDBIs");$U.exports={openDBI:Is,openEnvironment:HU,createEnvironment:z6,listDBIs:GU,listDBIDefinitions:J6,createDBI:qU,dropDBI:t8,statDBI:Z6,deleteEnvironment:Q6,initializeDBIs:r8,TransactionCursor:ZA,environmentDataSize:e8,copyEnvironment:j6,closeEnvironment:kU}});var YU=M((ewe,KU)=>{"use strict";var sb=Et(),n8=z(),VU=tn().LMDB_ERRORS_ENUM;KU.exports=s8;async function s8(e){try{if(global.lmdb_map!==void 0&&e.operation!==void 0){let t=Object.keys(global.lmdb_map),r;switch(e.operation){case"drop_schema":for(let i=0;i<t.length;i++){let a=t[i];if(a.startsWith(`${e.schema}.`)||a.startsWith(`txn.${e.schema}.`))try{await sb.closeEnvironment(global.lmdb_map[a])}catch(c){if(c.message!==VU.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await sb.closeEnvironment(global.lmdb_map[n]),await sb.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==VU.ENV_REQUIRED)throw i}break;case"drop_attribute":r=global.lmdb_map[`${e.schema}.${e.table}`],r!==void 0&&typeof r.dbis=="object"&&r.dbis[`${e.attribute}`]!==void 0&&delete r.dbis[`${e.attribute}`];break;default:break}}}catch(t){n8.error(t)}}o(s8,"cleanLMDBMap")});var Ao=M((rwe,i8)=>{i8.exports={hdb_user:{hash_attribute:"username",name:"hdb_user",schema:"system",residence:["*"],attributes:[{attribute:"username"},{attribute:"password"},{attribute:"role"},{attribute:"active"},{attribute:"hash"},{attribute:"refresh_token"},{attribute:"hash_function"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_role:{hash_attribute:"id",name:"hdb_role",schema:"system",attributes:[{attribute:"id"},{attribute:"role"},{attribute:"permission"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}],residence:["*"]},hdb_job:{hash_attribute:"id",name:"hdb_job",schema:"system",attributes:[{attribute:"id"},{attribute:"user"},{attribute:"type"},{attribute:"status"},{attribute:"start_datetime"},{attribute:"end_datetime"},{attribute:"message"},{attribute:"created_datetime"},{attribute:"request"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_license:{hash_attribute:"license_key",name:"hdb_license",schema:"system",attributes:[{attribute:"license_key"},{attribute:"company"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_info:{hash_attribute:"info_id",name:"hdb_info",schema:"system",attributes:[{attribute:"info_id"},{attribute:"data_version_num"},{attribute:"hdb_version_num"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_nodes:{hash_attribute:"name",name:"hdb_nodes",schema:"system",attributes:[{attribute:"name"},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"},{attribute:"revoked_certificates"},{attribute:"shard"}]},hdb_certificate:{hash_attribute:"name",name:"hdb_certificate",schema:"system",attributes:[{attribute:"name"},{attribute:"uses"},{attribute:"certificate"},{attribute:"is_authority"},{attribute:"private_key_name"},{attribute:"details"},{attribute:"is_self_signed"},{attribute:"__updatedtime__"}]},hdb_analytics_hostname:{hash_attribute:"id",name:"hdb_analytics_hostname",schema:"system",attributes:[{attribute:"id"},{attribute:"hostname"}]},hdb_analytics:{hash_attribute:"id",name:"hdb_analytics",schema:"system",attributes:[{attribute:"id"},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]},hdb_raw_analytics:{hash_attribute:"id",name:"hdb_raw_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{attribute:"time"},{attribute:"metrics"}]},hdb_temp:{hash_attribute:"id",name:"hdb_temp",schema:"system",attributes:[{attribute:"id"}]},hdb_durable_session:{hash_attribute:"id",name:"hdb_durable_session",schema:"system",attributes:[{attribute:"id"}]},hdb_session_will:{hash_attribute:"id",name:"hdb_session_will",schema:"system",attributes:[{attribute:"id"}]}}});var Ns=M((nwe,jU)=>{var o8=Ao(),{promisify:a8}=require("util"),{getDatabases:zU}=(Le(),v(ft));jU.exports={setSchemaDataToGlobal:WU,getTableSchema:c8,getSystemSchema:l8,setSchemaDataToGlobalAsync:a8(WU)};function WU(e){global.hdb_schema=zU(),e&&e()}o(WU,"setSchemaDataToGlobal");function c8(e,t,r){let n=zU()[e];if(!n)return r(`schema ${e} does not exist`);let s=n[t];return s?r(null,{schema:e,name:t,hash_attribute:s.primaryKey}):r(`table ${e}.${t} does not exist`)}o(c8,"getTableSchema");function l8(){return o8}o(l8,"getSystemSchema")});var c0=M((owe,a0)=>{"use strict";var ib=require("recursive-iterator"),u8=require("alasql"),ob=require("clone"),QU=ie(),{handleHDBError:JU,hdbErrors:d8}=_e(),{HDB_ERROR_MSGS:XU,HTTP_STATUS_CODES:ZU}=d8,{getDatabases:f8}=(Le(),v(ft)),m8=["DISTINCT_ARRAY"],e0=Symbol("validateTables"),ab=Symbol("validateTable"),iwe=Symbol("getAllColumns"),t0=Symbol("validateAllColumns"),vE=Symbol("findColumn"),r0=Symbol("validateOrderBy"),bm=Symbol("validateSegment"),cb=Symbol("validateColumn"),n0=Symbol("setColumnsForTable"),s0=Symbol("checkColumnsForAsterisk"),i0=Symbol("validateGroupBy"),o0=Symbol("hasColumns"),lb=class{static{o(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[e0](),this[s0](),this[t0]()}[e0](){if(this[o0]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[ab](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[ab](t.table)})}}[o0](){let t=!1,r=new ib(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[ab](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=f8();if(!r[t.databaseid])throw JU(new Error,XU.SCHEMA_NOT_FOUND(t.databaseid),ZU.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw JU(new Error,XU.TABLE_NOT_FOUND(t.databaseid,t.tableid),ZU.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=ob(s);i.table=ob(t),this.attributes.push(i)})}[vE](t){return this.attributes.filter(r=>t.tableid?(r.table.as===t.tableid||r.table.tableid===t.tableid)&&r.attribute===t.columnid:r.attribute===t.columnid)}[s0](){let t=new ib(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[n0](r.tableid)}[n0](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new u8.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[t0](){this[bm](this.statement.columns,!1),this[bm](this.statement.joins,!1),this[bm](this.statement.where,!1),this[i0](this.statement.group,!1),this[bm](this.statement.order,!0)}[bm](t,r){if(!t)return;let n=new ib(t),s=[];for(let{node:i,path:a}of n)!QU.isEmpty(i)&&!QU.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[r0](i):s.push(this[cb](i)));return s}[i0](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&m8.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=ob(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[vE](n)[0];s&&r.push(s)}}}),this.statement.group.forEach(n=>{let s=null;if(!n.columnid)r.forEach((i,a)=>{if(i.toString()===n.toString()){s=i,r.splice(a,1);return}});else{let i=this[vE](n);if(!i||i.length===0)throw`unknown column '${group_column.toString()}' in group by`;if(i.length>1)throw`ambiguously defined column '${group_column.toString()}' in group by`;r.forEach((a,c)=>{if(a.attribute===i[0].attribute&&a.table.tableid===i[0].table.tableid){s=a,r.splice(c,1);return}})}if(!s)throw`group by column '${group_column.toString()}' must be in select`}),r.length>0)throw`select column '${r[0].attribute?r[0].attribute:r[0].toString()}' must be in group by`}[r0](t){let r=this.statement.columns.filter(n=>n.as===t.columnid);if(r.length>1)throw`ambiguous column reference ${(t.tableid?t.tableid+".":"")+t.columnid} in order by`;r.length===0&&this[cb](t)}[cb](t){let r=this[vE](t),n=(t.tableid?t.tableid+".":"")+t.columnid;if(r.length===0)throw`unknown column ${n}`;if(r.length>1)throw`ambiguous column reference ${n}`;return r[0]}};a0.exports=lb});var u0=M((cwe,l0)=>{"use strict";var ub=class{static{o(this,"BridgeMethods")}createSchema(){throw new Error("createSchema bridge method is not defined")}dropSchema(){throw new Error("dropSchema bridge method is not defined")}createTable(){throw new Error("createTable bridge method is not defined")}dropTable(){throw new Error("dropTable bridge method is not defined")}createRecords(){throw new Error("createRecords bridge method is not defined")}updateRecords(){throw new Error("updateRecords bridge method is not defined")}async upsertRecords(){throw new Error("upsertRecords bridge method is not defined")}deleteRecords(){throw new Error("deleteRecords bridge method is not defined")}createAttribute(){throw new Error("createAttribute bridge method is not defined")}dropAttribute(){throw new Error("dropAttribute bridge method is not defined")}searchByConditions(){throw new Error("searchByConditions bridge method is not defined")}searchByHash(){throw new Error("searchByHash bridge method is not defined")}searchByValue(){throw new Error("searchByValue bridge method is not defined")}getDataByHash(){throw new Error("getDataByHash bridge method is not defined")}getDataByValue(){throw new Error("getDataByValue bridge method is not defined")}deleteRecordsBefore(){throw new Error("deleteRecordsBefore bridge method is not defined")}deleteAuditLogsBefore(){throw new Error("deleteAuditLogsBefore bridge method is not defined")}async readAuditLog(){throw new Error("readAuditLog bridge method is not defined")}};l0.exports=ub});var f0=M((uwe,d0)=>{"use strict";var db=class{static{o(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};d0.exports=db});var h0=M((fwe,m0)=>{"use strict";var fb=class{static{o(this,"UpdateRecordsResponseObject")}constructor(t=[],r=[],n=void 0,s=[]){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n,this.original_records=s}};m0.exports=fb});var _0=M((hwe,p0)=>{"use strict";var mb=class{static{o(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};p0.exports=mb});var Zc=M((Swe,S0)=>{"use strict";var h8=Et(),p8=f0(),_8=h0(),E8=_0(),Li=An(),Im=tn().LMDB_ERRORS_ENUM,g8=kt(),bo=(k(),v(K)),S8=ie(),T8=require("uuid"),_we=require("lmdb"),{handleHDBError:R8,hdbErrors:y8}=_e(),{OVERFLOW_MARKER:Ewe,MAX_SEARCH_KEY_LENGTH:gwe}=g8,E0=ce();E0.initSync();var UE=E0.get(bo.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),hb=bo.TIME_STAMP_NAMES_ENUM.CREATED_TIME,Xc=bo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function A8(e,t,r,n,s=Li.getNextMonotonicTime()){gb(e,t,r,n),pb(e,t,r);let i=new p8,a=[],c=[];for(let l=0;l<n.length;l++){let u=n[l];g0(u,!0,s);let d=b8(e,t,r,u),f=u[t];a.push(d),c.push(f)}return _b(a,c,n,i,s)}o(A8,"insertRecords");function b8(e,t,r,n){let s=n[t];return e.dbis[t].ifNoExists(s,()=>{for(let i=0;i<r.length;i++){let a=r[i];if(a===t||n.hasOwnProperty(a)===!1)continue;let c=n[a];if(typeof c=="function"){let d=c([[{}]]);Array.isArray(d)&&(c=d[0][bo.FUNC_VAL],n[a]=c)}let l=Li.getIndexedValues(c),u=e.dbis[a];if(l){UE&&u.prefetch(l.map(d=>({key:d,value:s})),xE);for(let d=0,f=l.length;d<f;d++)u.put(l[d],s)}}UE&&e.dbis[t].prefetch([s],xE),e.dbis[t].put(s,n,n[Xc])})}o(b8,"insertRecord");function I8(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}o(I8,"removeSkippedRecords");function g0(e,t,r){let n=r>0;(n||!Number.isInteger(e[Xc]))&&(e[Xc]=r||(r=Li.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[hb]))&&(e[hb]=r||Li.getNextMonotonicTime()):delete e[hb]}o(g0,"setTimestamps");function pb(e,t,r){r.indexOf(bo.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(bo.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(bo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(bo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),h8.initializeDBIs(e,t,r)}o(pb,"initializeTransaction");async function N8(e,t,r,n,s=Li.getNextMonotonicTime()){gb(e,t,r,n),pb(e,t,r);let i=new _8,a=[],c=[],l=[];for(let u=0;u<n.length;u++){let d=n[u],f=d[t],m;try{m=Eb(e,t,d,f,i,!0,s)}catch{i.skipped_hashes.push(f),a.push(u);continue}c.push(m),l.push(f)}return _b(c,l,n,i,s,a)}o(N8,"updateRecords");async function w8(e,t,r,n,s=Li.getNextMonotonicTime()){try{gb(e,t,r,n)}catch(l){throw R8(l,l.message,y8.HTTP_STATUS_CODES.BAD_REQUEST)}pb(e,t,r);let i=new E8,a=[],c=[];for(let l=0;l<n.length;l++){let u=n[l],d;S8.isEmpty(u[t])?(d=T8.v4(),u[t]=d):d=u[t];let f=Eb(e,t,u,d,i,!1,s);a.push(f),c.push(d)}return _b(a,c,n,i,s)}o(w8,"upsertRecords");async function _b(e,t,r,n,s,i=[]){let a=await Promise.all(e);for(let c=0,l=a.length;c<l;c++)a[c]===!0?n.written_hashes.push(t[c]):(n.skipped_hashes.push(t[c]),i.push(c));return n.txn_time=s||Li.getNextMonotonicTime(),I8(r,i),n}o(_b,"finalizeWrite");function Eb(e,t,r,n,s,i=!1,a){let c=e.dbis[t],l=c.getEntry(n),u=l?.value,d=u;if(!u){if(i)return!1;u={}}if(g0(r,!d,a),Number.isInteger(r[Xc])&&u[Xc]>r[Xc])return!1;d&&s.original_records.push(u);let f,m=o(()=>{for(let p in r){if(!r.hasOwnProperty(p)||p===t)continue;let E=r[p],g=e.dbis[p];if(g===void 0)continue;let y=u[p];if(typeof E=="function"){let R=E([[u]]);Array.isArray(R)&&(E=R[0][bo.FUNC_VAL],r[p]=E)}if(E===y)continue;let T=Li.getIndexedValues(y);if(T){UE&&g.prefetch(T.map(R=>({key:R,value:n})),xE);for(let R=0,I=T.length;R<I;R++)g.remove(T[R],n)}if(T=Li.getIndexedValues(E),T){UE&&g.prefetch(T.map(R=>({key:R,value:n})),xE);for(let R=0,I=T.length;R<I;R++)g.put(T[R],n)}}let h={...u,...r};c.put(n,h,h[Xc])},"doPut");return l?f=c.ifVersion(n,l.version,m):f=c.ifNoExists(n,m),f.then(h=>h?!0:Eb(e,t,r,n,s,i,a))}o(Eb,"updateUpsertRecord");function O8(e,t,r){if(Li.validateEnv(e),t===void 0)throw new Error(Im.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(Im.WRITE_ATTRIBUTES_REQUIRED):new Error(Im.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}o(O8,"validateBasic");function gb(e,t,r,n){if(O8(e,t,r),!Array.isArray(n))throw n===void 0?new Error(Im.RECORDS_REQUIRED):new Error(Im.RECORDS_MUST_BE_ARRAY)}o(gb,"validateWrite");function xE(){}o(xE,"noop");S0.exports={insertRecords:A8,updateRecords:N8,upsertRecords:w8}});var R0=M((Rwe,T0)=>{"use strict";var C8=require("uuid"),Sb=class{static{o(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||C8.v4(),this.schema_table=`${this.schema}.${this.table}`}};T0.exports=Sb});var BE=M((Awe,y0)=>{"use strict";var P8=R0(),Tb=class extends P8{static{o(this,"LMDBCreateAttributeObject")}constructor(t,r,n,s,i=!0,a=!1){super(t,r,n,s),this.dup_sort=i,this.is_hash_attribute=a}};y0.exports=Tb});var b0=M((Iwe,A0)=>{"use strict";A0.exports=D8;var L8="inserted";function D8(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===L8?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}o(D8,"returnObject")});var FE=M((Owe,N0)=>{"use strict";var M8=(k(),v(K)),Rb=Et(),v8=Zc(),{getSystemSchemaPath:U8,getSchemaPath:x8}=At(),wwe=Ao(),{validateBySchema:B8}=at(),Nm=require("joi"),F8=BE(),H8=b0(),{handleHDBError:k8,hdbErrors:G8,ClientError:q8}=_e(),I0=ie(),{HTTP_STATUS_CODES:$8}=G8,V8="inserted";N0.exports=K8;async function K8(e){let t=B8(e,Nm.object({database:Nm.string(),schema:Nm.string(),table:Nm.string().required(),attribute:Nm.string().required()}));if(t)throw new q8(t.message);let r=!e.skip_table_check&&I0.checkGlobalSchemaTable(e.schema,e.table);if(r)throw k8(new Error,r,$8.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=I0.isEmpty(e.dup_sort)||e.dup_sort=="true";let n=[];if(global.hdb_schema[e.schema]&&global.hdb_schema[e.schema][e.table]&&(n=global.hdb_schema[e.schema][e.table].attributes),Array.isArray(n)&&n.length>0){for(let i of n)if(i.attribute===e.attribute)throw new Error(`attribute '${i.attribute}' already exists in ${e.schema}.${e.table}`)}let s=new F8(e.schema,e.table,e.attribute,e.id);try{let i=await Rb.openEnvironment(x8(e.schema,e.table),e.table);if(i.dbis[e.attribute]!==void 0)throw new Error(`attribute '${create_attribute_obj.attribute}' already exists in ${e.schema}.${e.table}`);Rb.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let a=await Rb.openEnvironment(U8(),M8.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await v8.insertRecords(a,HDB_TABLE_INFO.hash_attribute,hdbAttributeAttributes,[s]);return H8(V8,c,{records:[s]},l)}catch(i){throw i}}o(K8,"lmdbCreateAttribute")});var Mi=M((Pwe,O0)=>{"use strict";var w0=ie(),Y8=(k(),v(K)),Du=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Di=require("joi"),wa={schema_format:{pattern:Du,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},W8=Di.alternatives(Di.string().min(1).max(wa.schema_length.maximum).pattern(Du).messages({"string.pattern.base":"{:#label} "+wa.schema_format.message}),Di.number(),Di.array()).required(),z8=Di.alternatives(Di.string().min(1).max(wa.schema_length.maximum).pattern(Du).messages({"string.pattern.base":"{:#label} "+wa.schema_format.message}),Di.number()),j8=Di.alternatives(Di.string().min(1).max(wa.schema_length.maximum).pattern(Du).messages({"string.pattern.base":"{:#label} "+wa.schema_format.message}),Di.number()).required();function Q8(e,t){return t?typeof t!="string"?`'${property_name}' must be a string`:t.length?t.length>wa.schema_length.maximum?`'${property_name}' maximum of 250 characters`:Du.test(t)?"":`'${property_name}' has illegal characters`:`'${property_name}' must be at least one character`:`'${property_name}' is required`}o(Q8,"checkValidTable");function J8(e,t){return w0.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}o(J8,"validateSchemaExists");function X8(e,t){let r=t.state.ancestors[0].schema;return w0.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}o(X8,"validateTableExists");function Z8(e,t){return e.toLowerCase()===Y8.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${hdb_terms.SYSTEM_SCHEMA_NAME}' name is reserved`):e}o(Z8,"validateSchemaName");O0.exports={commonValidators:wa,schemaRegex:Du,hdbSchemaTable:W8,validateSchemaExists:J8,validateTableExists:X8,validateSchemaName:Z8,checkValidTable:Q8,hdbDatabase:z8,hdbTable:j8}});var Ab=M((Dwe,P0)=>{var{hdbTable:e5,hdbDatabase:C0}=Mi(),t5=at(),yb=require("joi"),r5={undefined:"undefined",null:"null"},n5=o((e,t)=>{let r=Object.keys(e),n=r.length,s;for(let i=0;i<n;i++){let a=r[i];(!a||a.length===0||r5[a]!==void 0)&&(s===void 0?s=`Invalid attribute name: '${a}'`:s+=`. Invalid attribute name: '${a}'`)}return s?t.message(s):e},"customRecordsVal"),s5=yb.object({database:C0,schema:C0,table:e5,records:yb.array().items(yb.object().custom(n5)).required()});P0.exports=function(e){return t5.validateBySchema(e,s5)}});var wm=M((Uwe,D0)=>{"use strict";var Io=ie(),L0=z(),vwe=Ab(),{getDatabases:i5}=(Le(),v(ft)),{ClientError:el}=_e();D0.exports=o5;function o5(e){if(Io.isEmpty(e))throw new el("invalid update parameters defined.");if(Io.isEmptyOrZeroLength(e.schema))throw new el("invalid schema specified.");if(Io.isEmptyOrZeroLength(e.table))throw new el("invalid table specified.");if(!Array.isArray(e.records))throw new el("records must be an array");let t=i5()[e.schema]?.[e.table];if(Io.isEmpty(t))throw new el(`could not retrieve schema:${e.schema} and table ${e.table}`);let r=t.primaryKey,n=new Set,s={},i=!1;return e.operation==="update"&&(i=!0),e.records.forEach(a=>{if(i&&Io.isEmptyOrZeroLength(a[r]))throw L0.error("a valid hash attribute must be provided with update record:",a),new el("a valid hash attribute must be provided with update record, check log for more info");if(!Io.isEmptyOrZeroLength(a[r])&&(a[r]==="null"||a[r]==="undefined"))throw L0.error(`a valid hash value must be provided with ${e.operation} record:`,a),new el(`Invalid hash value: '${a[r]}' is not a valid hash attribute value, check log for more info`);!Io.isEmpty(a[r])&&a[r]!==""&&n.has(Io.autoCast(a[r]))&&(a.skip=!0),n.add(Io.autoCast(a[r]));for(let c in a)s[c]=1}),s[r]=1,{schema_table:t,hashes:Array.from(n),attributes:Object.keys(s)}}o(o5,"insertUpdateValidate")});var HE=M((Bwe,v0)=>{"use strict";var M0=ie(),a5=(k(),v(K)),c5=z(),l5=FE(),u5=BE(),d5=No(),{SchemaEventMsg:f5}=ti(),m5="already exists in";v0.exports=h5;async function h5(e,t,r){if(M0.isEmptyOrZeroLength(r))return r;let n=[];M0.isEmptyOrZeroLength(t.attributes)||t.attributes.forEach(i=>{n.push(i.attribute)});let s=r.filter(i=>n.indexOf(i)<0);return s.length===0||await Promise.all(s.map(async i=>{await p5(e,t.schema,t.name,i)})),s}o(h5,"lmdbCheckForNewAttributes");async function p5(e,t,r,n){let s=new u5(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await _5(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(m5))c5.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}o(p5,"createNewAttribute");async function _5(e){let t;return t=await l5(e),d5.signalSchemaChange(new f5(process.pid,a5.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}o(_5,"createAttribute")});var Mu=M((Hwe,U0)=>{"use strict";var bb=class{static{o(this,"LMDBTransactionObject")}constructor(t,r,n,s,i=void 0){this.operation=t,this.user_name=r,this.timestamp=n,this.hash_values=s,this.origin=i}};U0.exports=bb});var B0=M((Gwe,x0)=>{"use strict";var E5=Mu(),g5=(k(),v(K)).OPERATIONS_ENUM,Ib=class extends E5{static{o(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(g5.INSERT,r,n,s,i),this.records=t}};x0.exports=Ib});var H0=M(($we,F0)=>{"use strict";var S5=Mu(),T5=(k(),v(K)).OPERATIONS_ENUM,Nb=class extends S5{static{o(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,a=void 0){super(T5.UPDATE,n,s,i,a),this.records=t,this.original_records=r}};F0.exports=Nb});var G0=M((Kwe,k0)=>{"use strict";var R5=Mu(),y5=(k(),v(K)).OPERATIONS_ENUM,wb=class extends R5{static{o(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,a=void 0){super(y5.UPSERT,n,s,i,a),this.records=t,this.original_records=r}};k0.exports=wb});var $0=M((Wwe,q0)=>{"use strict";var A5=Mu(),b5=(k(),v(K)).OPERATIONS_ENUM,Ob=class extends A5{static{o(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(b5.DELETE,n,s,t,i),this.original_records=r}};q0.exports=Ob});var Om=M((Qwe,W0)=>{"use strict";var jwe=require("path"),V0=Et(),I5=B0(),N5=H0(),w5=G0(),O5=$0(),vu=kt(),K0=ie(),{CONFIG_PARAMS:C5}=(k(),v(K)),Y0=ce();Y0.initSync();var kE=(k(),v(K)).OPERATIONS_ENUM,{getTransactionAuditStorePath:P5}=At();W0.exports=L5;async function L5(e,t){if(Y0.get(C5.LOGGING_AUDITLOG)===!1)return;let r=P5(e.schema,e.table),n=await V0.openEnvironment(r,e.table,!0),s=D5(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){V0.initializeDBIs(n,vu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,vu.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[vu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[vu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),K0.isEmpty(s.user_name)||n.dbis[vu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let a=0;a<s.hash_values.length;a++)n.dbis[vu.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[a],i)})}}o(L5,"writeTransaction");function D5(e,t){let r=K0.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===kE.INSERT)return new I5(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===kE.UPDATE)return new N5(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===kE.UPSERT)return new w5(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===kE.DELETE)return new O5(t.deleted,t.original_records,r,t.txn_time,e.__origin)}o(D5,"createTransactionObject")});var Cb=M((Zwe,z0)=>{"use strict";var M5=wm(),Xwe=zf(),Cm=(k(),v(K)),v5=jf(),U5=Zc().insertRecords,x5=Et(),B5=z(),F5=HE(),{getSchemaPath:H5}=At(),k5=Om();z0.exports=G5;async function G5(e){try{let{schemaTable:t,attributes:r}=M5(e);v5(e,r,t.hash_attribute),e.schema!==Cm.SYSTEM_SCHEMA_NAME&&(r.includes(Cm.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(Cm.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(Cm.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(Cm.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await F5(e.hdb_auth_header,t,r),s=H5(e.schema,e.table),i=await x5.openEnvironment(s,e.table),a=await U5(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await k5(e,a)}catch(c){B5.error(`unable to write transaction due to ${c.message}`)}return{written_hashes:a.written_hashes,skipped_hashes:a.skipped_hashes,schemaTable:t,new_attributes:n,txn_time:a.txn_time}}catch(t){throw t}}o(G5,"lmdbCreateRecords")});var J0=M((tOe,Q0)=>{"use strict";var j0=(k(),v(K)),q5=Cb(),$5=zf(),V5=require("fs-extra"),{getSchemaPath:K5}=At();Q0.exports=Y5;async function Y5(e){let t=[{name:e.schema,createddate:Date.now()}],r=new $5(j0.SYSTEM_SCHEMA_NAME,j0.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await q5(r),await V5.mkdirp(K5(e.schema))}o(Y5,"lmdbCreateSchema")});var Z0=M((nOe,X0)=>{"use strict";var Pb=class{static{o(this,"DeleteRecordsResponseObject")}constructor(t=[],r=[],n=void 0,s=[]){this.deleted=t,this.skipped=r,this.txn_time=n,this.original_records=s}};X0.exports=Pb});var nx=M((cOe,rx)=>{"use strict";var ex=Et(),Lb=An(),Db=tn().LMDB_ERRORS_ENUM,W5=kt(),tx=z(),iOe=ie(),z5=require("lmdb"),j5=Z0(),Q5=(k(),v(K)),{OVERFLOW_MARKER:oOe,MAX_SEARCH_KEY_LENGTH:aOe}=W5,J5=Q5.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function X5(e,t,r,n){if(Lb.validateEnv(e),t===void 0)throw new Error(Db.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(Db.IDS_REQUIRED):new Error(Db.IDS_MUST_BE_ITERABLE);try{let s=ex.listDBIs(e);ex.initializeDBIs(e,t,s);let i=new j5,a,c=[],l=[];for(let m=0,h=r.length;m<h;m++)try{a=r[m];let p=e.dbis[t].get(a);if(!p||n&&p[J5]>n){i.skipped.push(a);continue}let E=e.dbis[t].ifVersion(a,z5.IF_EXISTS,()=>{e.dbis[t].remove(a);for(let g=0;g<s.length;g++){let y=s[g];if(!p.hasOwnProperty(y)||y===t)continue;let T=e.dbis[y],R=p[y];if(R!=null)try{let I=Lb.getIndexedValues(R);if(I)for(let P=0,Y=I.length;P<Y;P++)T.remove(I[P],a)}catch{tx.warn(`cannot delete from attribute: ${y}, ${R}:${a}`)}}});c.push(E),l.push(a),i.original_records.push(p)}catch(p){tx.warn(p),i.skipped.push(a)}let u=[],d=await Promise.all(c);for(let m=0,h=d.length;m<h;m++)d[m]===!0?i.deleted.push(l[m]):(i.skipped.push(l[m]),u.push(m));let f=0;for(let m=0;m<u.length;m++){let h=u[m];i.original_records.splice(h-f,1),f++}return i.txn_time=Lb.getNextMonotonicTime(),i}catch(s){throw s}}o(X5,"deleteRecords");rx.exports={deleteRecords:X5}});var Pm=M((uOe,ix)=>{"use strict";var Uu=ie(),Z5=nx(),e9=Et(),{getSchemaPath:t9}=At(),r9=Om(),n9=z();ix.exports=s9;async function s9(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(Uu.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(Uu.isEmptyOrZeroLength(e.hash_values)&&!Uu.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];Uu.isEmpty(l)||e.hash_values.push(l)}}if(Uu.isEmptyOrZeroLength(e.hash_values))return sx([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(Uu.isEmptyOrZeroLength(e.records)){e.records=[];for(let c=0;c<e.hash_values.length;c++)e.records[c]={[n]:e.hash_values[c]}}let s=t9(e.schema,e.table),i=await e9.openEnvironment(s,e.table),a=await Z5.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await r9(e,a)}catch(c){n9.error(`unable to write transaction due to ${c.message}`)}return sx(a.deleted,a.skipped,a.txn_time)}catch(s){throw s}}o(s9,"lmdbDeleteRecords");function sx(e,t,r){let n=e.length+t.length,s=n===1?"record":"records";return{message:`${e.length} of ${n} ${s} successfully deleted`,deleted_hashes:e,skipped_hashes:t,txn_time:r}}o(sx,"createDeleteResponse")});var vb=M((mOe,ox)=>{"use strict";var i9=(k(),v(K)),fOe=An();function Mb(e,t){let r=Object.create(null);if(t.length===1&&i9.SEARCH_WILDCARDS.indexOf(t[0])>=0)Object.assign(r,e);else for(let n=0;n<t.length;n++){let s=t[n],i=e[s];r[s]=i===void 0?null:i}return r}o(Mb,"parseRow");function o9(e,t,r,n){let s=Mb(r,e);n.push(s)}o(o9,"searchAll");function a9(e,t,r,n){let s=Mb(r,e);n[t]=s}o(a9,"searchAllToMap");function c9(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}o(c9,"iterateDBI");function tl(e,t,r,n,s){let i=Object.create(null);i[s]=e;let a;n===s?a=e:(a=t,n!==void 0&&(i[n]=a)),r[0].push(a),r[1].push(i)}o(tl,"pushResults");function l9(e,t,r,n,s,i){t.toString().endsWith(e)&&tl(t,r,n,s,i)}o(l9,"endsWith");function u9(e,t,r,n,s,i){t.toString().includes(e)&&tl(t,r,n,s,i)}o(u9,"contains");function d9(e,t,r,n,s,i){t>e&&tl(t,r,n,s,i)}o(d9,"greaterThanCompare");function f9(e,t,r,n,s,i){t>=e&&tl(t,r,n,s,i)}o(f9,"greaterThanEqualCompare");function m9(e,t,r,n,s,i){t<e&&tl(t,r,n,s,i)}o(m9,"lessThanCompare");function h9(e,t,r,n,s,i){t<=e&&tl(t,r,n,s,i)}o(h9,"lessThanEqualCompare");ox.exports={parseRow:Mb,searchAll:o9,searchAllToMap:a9,iterateDBI:c9,endsWith:l9,contains:u9,greaterThanCompare:d9,greaterThanEqualCompare:f9,lessThanCompare:m9,lessThanEqualCompare:h9,pushResults:tl}});var xu=M((gOe,mx)=>{"use strict";var Oa=Et(),pOe=z(),Wn=An(),GE=kt(),Jt=tn().LMDB_ERRORS_ENUM,_Oe=ie(),p9=(k(),v(K)),qE=vb(),{parseRow:_9}=qE,EOe=require("lmdb"),{OVERFLOW_MARKER:ax,MAX_SEARCH_KEY_LENGTH:E9}=GE;function cx(e,t,r,n=!1,s=void 0,i=void 0){return rl(e,t,r,(a,c)=>c.getRange({transaction:a,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}))}o(cx,"iterateFullIndex");function Lm(e,t,r,n,s,i=!1,a=void 0,c=void 0,l=!1,u=!1){return rl(e,t,r,(d,f,m,h)=>{let T={transaction:d,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:a,offset:c,inclusiveEnd:i===!0?!l:!u,exclusiveStart:i===!0?u:l};return h===r?(T.values=!1,f.getRange(T).map(R=>({value:R}))):f.getRange(T)})}o(Lm,"iterateRangeBetween");function rl(e,t,r,n){let s=e.database||e,i=Oa.openDBI(s,r);i[GE.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&Oa.openDBI(s,t);let a;e.database?a=e:(a=e.useReadTransaction(),a.database=e);let c=n(a,i,s,t);return c.transaction=a,e.database||(c.onDone=()=>{a.done()}),c}o(rl,"setupTransaction");function lx(e,t,r,n){let s;return function(i,a){if(typeof i=="string"&&i.endsWith(ax)){if(!s)if(r)s=Oa.openDBI(e,r);else{let l=Oa.listDBIs(e);for(let u=0,d=l.length;u<d&&(s=Oa.openDBI(e,l[u]),!s[GE.DBI_DEFINITION_NAME].is_hash_attribute);u++);}i=s.get(a,{transaction:t,lazy:!0})[n]}return i}}o(lx,"getOverflowCheck");function g9(e,t,r,n=!1,s=void 0,i=void 0){if(Wn.validateEnv(e),t===void 0)throw new Error(Jt.HASH_ATTRIBUTE_REQUIRED);return rl(e,t,t,(a,c,l)=>($E(r),r=Dm(l,r),c.getRange({transaction:a,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(u=>_9(u.value,r))))}o(g9,"searchAll");function S9(e,t,r,n=!1,s=void 0,i=void 0){if(Wn.validateEnv(e),t===void 0)throw new Error(Jt.HASH_ATTRIBUTE_REQUIRED);$E(r),r=Dm(e.database||e,r);let a=new Map;for(let{key:c,value:l}of cx(e,t,t,n,s,i))a.set(c,qE.parseRow(l,r));return a}o(S9,"searchAllToMap");function T9(e,t,r=!1,n=void 0,s=void 0){if(Wn.validateEnv(e),t===void 0)throw new Error(Jt.ATTRIBUTE_REQUIRED);let i=Object.create(null),a=cx(e,void 0,t,r,n,s),c=a.transaction,l=lx(c.database,c,void 0,t);for(let{key:u,value:d}of a){let f=l(u,d);i[f]===void 0&&(i[f]=[]),i[f].push(d)}return i}o(T9,"iterateDBI");function R9(e,t){if(Wn.validateEnv(e),t===void 0)throw new Error(Jt.HASH_ATTRIBUTE_REQUIRED);return Oa.statDBI(e,t).entryCount}o(R9,"countAll");function y9(e,t,r,n,s=!1,i=void 0,a=void 0){return Ca(e,r,n),rl(e,t,r,(c,l,u,d)=>(n=Wn.convertKeyValueToWrite(n),d===r?l.get(n,{transaction:c,lazy:!0})===void 0?[]:[{key:n,value:n}]:l.getValues(n,{transaction:c,reverse:s,limit:i,offset:a}).map(f=>({key:n,value:f}))))}o(y9,"equals");function A9(e,t,r){return Ca(e,t,r),Oa.openDBI(e,t).getValuesCount(r)}o(A9,"count");function b9(e,t,r,n,s=!1,i=void 0,a=void 0){return Ca(e,r,n),rl(e,null,r,(c,l)=>{n=Wn.convertKeyValueToWrite(n);let u=!0;typeof n=="number"&&(u=!1);let d;if(s===!0){let f;for(let m of l.getKeys({transaction:c,start:n}))if(!m.startsWith(n)){f=m;break}return f!==void 0&&(Number.isInteger(a)?a++:i++),d=l.getRange({transaction:c,start:f,end:void 0,reverse:s,limit:i,offset:a}).map(m=>{let{key:h}=m;if(h!==f){if(h.toString().startsWith(n))return m;if(u===!0)return d.DONE}}),d.filter(m=>m)}else return d=l.getRange({transaction:c,start:n,reverse:s,limit:i,offset:a}).map(f=>{if(f.key.toString().startsWith(n))return f;if(u===!0)return d.DONE}),u?d:d.filter(f=>f)})}o(b9,"startsWith");function I9(e,t,r,n,s=!1,i=void 0,a=void 0){return ux(e,t,r,n,s,i,a,!0)}o(I9,"endsWith");function ux(e,t,r,n,s=!1,i=void 0,a=void 0,c=!1){return Ca(e,r,n),rl(e,null,r,(l,u,d,f)=>{let m=lx(d,l,f,r);return a=Number.isInteger(a)?a:0,u.getKeys({transaction:l,end:s?!1:void 0,reverse:s}).flatMap(h=>{let p=h.toString();return p.endsWith(ax)?u.getValues(h,{transaction:l}).map(E=>{let g=m(h,E);if(c?g.endsWith(n):g.includes(n))return{key:g,value:E}}).filter(E=>E):(c?p.endsWith(n):p.includes(n))?u[GE.DBI_DEFINITION_NAME].is_hash_attribute?{key:h,value:h}:u.getValues(h,{transaction:l}).map(E=>({key:h,value:E})):[]}).slice(a,i===void 0?void 0:i+(a||0))})}o(ux,"contains");function N9(e,t,r,n,s=!1,i=void 0,a=void 0){Ca(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),Lm(e,t,r,n,l,s,i,a,!0,!1)}o(N9,"greaterThan");function w9(e,t,r,n,s=!1,i=void 0,a=void 0){Ca(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),Lm(e,t,r,n,l,s,i,a,!1,!1)}o(w9,"greaterThanEqual");function O9(e,t,r,n,s=!1,i=void 0,a=void 0){Ca(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),Lm(e,t,r,l,n,s,i,a,!1,!0)}o(O9,"lessThan");function C9(e,t,r,n,s=!1,i=void 0,a=void 0){Ca(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),Lm(e,t,r,l,n,s,i,a,!1,!1)}o(C9,"lessThanEqual");function P9(e,t,r,n,s,i=!1,a=void 0,c=void 0){if(Wn.validateEnv(e),r===void 0)throw new Error(Jt.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(Jt.START_VALUE_REQUIRED);if(s===void 0)throw new Error(Jt.END_VALUE_REQUIRED);if(n=Wn.convertKeyValueToWrite(n),s=Wn.convertKeyValueToWrite(s),n>s)throw new Error(Jt.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return Lm(e,t,r,n,s,i,a,c)}o(P9,"between");function L9(e,t,r,n){Wn.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(Jt.HASH_ATTRIBUTE_REQUIRED);if($E(r),r=Dm(s,r),n===void 0)throw new Error(Jt.ID_REQUIRED);let a=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(a=qE.parseRow(c,r)),a}o(L9,"searchByHash");function D9(e,t,r){Wn.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(Jt.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Jt.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}o(D9,"checkHashExists");function M9(e,t,r,n,s=[]){return fx(e,t,r,n,s),dx(e,t,r,n,s).map(i=>i[1])}o(M9,"batchSearchByHash");function v9(e,t,r,n,s=[]){fx(e,t,r,n,s);let i=new Map;for(let[a,c]of dx(e,t,r,n,s))i.set(a,c);return i}o(v9,"batchSearchByHashToMap");function dx(e,t,r,n,s=[]){return rl(e,t,t,(i,a,c)=>{r=Dm(c,r);let l=r.length<3;return n.map(u=>{let d=c.dbis[t].get(u,{transaction:i,lazy:l});if(d)return[u,qE.parseRow(d,r)];s.push(u)}).filter(u=>u)})}o(dx,"batchHashSearch");function fx(e,t,r,n,s){if(Wn.validateEnv(e),t===void 0)throw new Error(Jt.HASH_ATTRIBUTE_REQUIRED);if($E(r),n==null)throw new Error(Jt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(Jt.IDS_MUST_BE_ITERABLE)}o(fx,"initializeBatchSearchByHash");function $E(e){if(!Array.isArray(e))throw e===void 0?new Error(Jt.FETCH_ATTRIBUTES_REQUIRED):new Error(Jt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}o($E,"validateFetchAttributes");function Ca(e,t,r){if(Wn.validateEnv(e),t===void 0)throw new Error(Jt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Jt.SEARCH_VALUE_REQUIRED);if(r?.length>E9)throw new Error(Jt.SEARCH_VALUE_TOO_LARGE)}o(Ca,"validateComparisonFunctions");function Dm(e,t){return t.length===1&&p9.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=Oa.listDBIs(e)),t}o(Dm,"setGetWholeRowAttributes");mx.exports={searchAll:g9,searchAllToMap:S9,count:A9,countAll:R9,equals:y9,startsWith:b9,endsWith:I9,contains:ux,searchByHash:L9,setGetWholeRowAttributes:Dm,batchSearchByHash:M9,batchSearchByHashToMap:v9,checkHashExists:D9,iterateDBI:T9,greaterThan:N9,greaterThanEqual:w9,lessThan:O9,lessThanEqual:C9,between:P9}});var Bu=M((TOe,gx)=>{var hx=require("lodash"),px=at(),$e=require("joi"),U9=ie(),{hdbSchemaTable:Mm,checkValidTable:_x,hdbTable:Ex,hdbDatabase:VE}=Mi(),{handleHDBError:x9,hdbErrors:B9}=_e(),{getDatabases:F9}=(Le(),v(ft)),{HTTP_STATUS_CODES:H9}=B9,k9=$e.object({database:VE,schema:VE,table:Ex,search_attribute:Mm,search_value:$e.any().required(),get_attributes:$e.array().min(1).items($e.alternatives(Mm,$e.object())).optional(),desc:$e.bool(),limit:$e.number().integer().min(1),offset:$e.number().integer().min(0)}),G9=$e.object({database:VE,schema:VE,table:Ex,operator:$e.string().valid("and","or").default("and").lowercase(),offset:$e.number().integer().min(0),limit:$e.number().integer().min(1),get_attributes:$e.array().min(1).items($e.alternatives(Mm,$e.object())).optional(),sort:$e.object({attribute:$e.alternatives(Mm,$e.array().min(1)),descending:$e.bool().optional()}).optional(),conditions:$e.array().min(1).items($e.alternatives($e.object({operator:$e.string().valid("and","or").default("and").lowercase(),conditions:$e.array()}),$e.object({search_attribute:$e.alternatives(Mm,$e.array().min(1)),search_type:$e.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:$e.when("search_type",{switch:[{is:"equals",then:$e.any()},{is:"between",then:$e.array().items($e.alternatives([$e.string(),$e.number()])).length(2)}],otherwise:$e.alternatives($e.string(),$e.number())}).required()}))).required()});gx.exports=function(e,t){let r=null;switch(t){case"value":r=px.validateBySchema(e,k9);break;case"hashes":let i=function(a){s?s+=". "+a:s=a};var n=i;o(i,"addError");let s;i(_x("database",e.schema)),i(_x("table",e.table)),e.hash_values?Array.isArray(e.hash_values)?e.hash_values.every(a=>typeof a=="string"||typeof a=="number")||i("'hash_values' must be strings or numbers"):i("'hash_values' must be an array"):i("'hash_values' is required"),e.get_attributes?Array.isArray(e.get_attributes)?e.get_attributes.length===0?i("'get_attributes' must contain at least 1 item"):e.get_attributes.every(a=>typeof a=="string"||typeof a=="number")||i("'get_attributes' must be strings or numbers"):i("'get_attributes' must be an array"):i("'get_attributes' is required"),s&&(r=new Error(s.trim()));break;case"conditions":r=px.validateBySchema(e,G9);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=U9.checkGlobalSchemaTable(e.schema,e.table);if(s)return x9(new Error,s,H9.NOT_FOUND);let a=F9()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let l=o(d=>{for(let f=0,m=d.conditions.length;f<m;f++){let h=d.conditions[f];h.conditions?l(h):c.push(h.search_attribute)}},"addConditions");t==="conditions"&&l(e);let u=hx.filter(c,d=>d!=="*"&&!d.startsWith?.("$")&&d.attribute!=="*"&&!Array.isArray(d)&&!d.name&&!hx.some(a,f=>f===d||f.attribute===d||f.attribute===d.attribute));if(u&&u.length>0){let d=u.join(", ");return d=d.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${d}'`)}}return r}});var Ub=M((yOe,Sx)=>{"use strict";var q9=Et(),$9=Bu(),{getSchemaPath:V9}=At();Sx.exports=K9;function K9(e){let t=$9(e,"hashes");if(t)throw t;let r=V9(e.schema,e.table);return q9.openEnvironment(r,e.table)}o(K9,"initialize")});var xb=M((bOe,Tx)=>{"use strict";var Y9=xu(),W9=Ub();Tx.exports=z9;async function z9(e){let t=await W9(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return Y9.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}o(z9,"lmdbGetDataByHash")});var Fu=M((NOe,Rx)=>{"use strict";var Bb=class{static{o(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};Rx.exports=Bb});var Ax=M((COe,yx)=>{"use strict";var OOe=Fu(),j9=xu(),Q9=Ub();yx.exports=J9;async function J9(e){let t=await Q9(e),r=global.hdb_schema[e.schema][e.table];return j9.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}o(J9,"lmdbSearchByHash")});var ri=M((LOe,bx)=>{"use strict";var Fb=class{static{o(this,"SearchObject")}constructor(t,r,n,s,i,a,c,l=!1,u=void 0,d=void 0){this.schema=t,this.table=r,this.search_attribute=n,this.search_value=s,this.hash_attribute=i,this.get_attributes=a,this.end_value=c,this.reverse=l,this.limit=u,this.offset=d}};bx.exports=Fb});var KE=M((MOe,Px)=>{"use strict";var sn=xu(),X9=Et(),Z9=ie(),Ve=kt(),nl=(k(),v(K)),e7=Ao(),Ix=tn().LMDB_ERRORS_ENUM,{getSchemaPath:t7}=At(),wo=nl.SEARCH_WILDCARDS;async function r7(e,t,r){let n;e.schema===nl.SYSTEM_SCHEMA_NAME?n=e7[e.table]:n=global.hdb_schema[e.schema][e.table];let s=Cx(e,n.hash_attribute,r,t);return wx(e,s,n.hash_attribute,r)}o(r7,"prepSearch");async function wx(e,t,r,n){let s=t7(e.schema,e.table),i=await X9.openEnvironment(s,e.table),a=Ox(i,e,t,r),c=a.transaction||i;if([Ve.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,Ve.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,Ve.SEARCH_TYPES.SEARCH_ALL,Ve.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return a;if(n7(e,r)===!1){let d=e.search_attribute;if(d===r)return n?Nx(a,()=>!0):a.map(m=>({[r]:m.key}));let f=o(m=>({[r]:m.value,[d]:m.key}),"toObject");return n?Nx(a,f):a.map(f)}let u=e.search_attribute===r?a.map(d=>d.key):a.map(d=>d.value);return n===!0?sn.batchSearchByHashToMap(c,r,e.get_attributes,u):sn.batchSearchByHash(c,r,e.get_attributes,u)}o(wx,"executeSearch");function Ox(e,t,r,n){let s,i=n;t.get_attributes.indexOf(n)<0&&(i=void 0);let{reverse:a,limit:c,offset:l}=t;switch(a=typeof a=="boolean"?a:!1,c=Number.isInteger(c)?c:void 0,l=Number.isInteger(l)?l:void 0,r){case Ve.SEARCH_TYPES.EQUALS:s=sn.equals(e,i,t.search_attribute,t.search_value,a,c,l);break;case Ve.SEARCH_TYPES.CONTAINS:s=sn.contains(e,i,t.search_attribute,t.search_value,a,c,l);break;case Ve.SEARCH_TYPES.ENDS_WITH:case Ve.SEARCH_TYPES._ENDS_WITH:s=sn.endsWith(e,i,t.search_attribute,t.search_value,a,c,l);break;case Ve.SEARCH_TYPES.STARTS_WITH:case Ve.SEARCH_TYPES._STARTS_WITH:s=sn.startsWith(e,i,t.search_attribute,t.search_value,a,c,l);break;case Ve.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return sn.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case Ve.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return sn.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case Ve.SEARCH_TYPES.SEARCH_ALL:return sn.searchAll(e,n,t.get_attributes,a,c,l);case Ve.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return sn.searchAllToMap(e,n,t.get_attributes,a,c,l);case Ve.SEARCH_TYPES.BETWEEN:s=sn.between(e,i,t.search_attribute,t.search_value,t.end_value,a,c,l);break;case Ve.SEARCH_TYPES.GREATER_THAN:case Ve.SEARCH_TYPES._GREATER_THAN:s=sn.greaterThan(e,i,t.search_attribute,t.search_value,a,c,l);break;case Ve.SEARCH_TYPES.GREATER_THAN_EQUAL:case Ve.SEARCH_TYPES._GREATER_THAN_EQUAL:s=sn.greaterThanEqual(e,i,t.search_attribute,t.search_value,a,c,l);break;case Ve.SEARCH_TYPES.LESS_THAN:case Ve.SEARCH_TYPES._LESS_THAN:s=sn.lessThan(e,i,t.search_attribute,t.search_value,a,c,l);break;case Ve.SEARCH_TYPES.LESS_THAN_EQUAL:case Ve.SEARCH_TYPES._LESS_THAN_EQUAL:s=sn.lessThanEqual(e,i,t.search_attribute,t.search_value,a,c,l);break;default:return Object.create(null)}return s}o(Ox,"searchByType");function Nx(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}o(Nx,"createMapFromIterable");function n7(e,t){if(e.get_attributes.length===1&&e.get_attributes[0]==="*")return!0;let r=[e.search_attribute];e.get_attributes.indexOf(t)>=0&&r.push(t);let n=!1;for(let s=0;s<e.get_attributes.length;s++)if(r.indexOf(e.get_attributes[s])<0){n=!0;break}return n}o(n7,"checkToFetchMore");function Cx(e,t,r,n){if(Z9.isEmpty(n)){let s=e.search_value;typeof s=="object"?s=JSON.stringify(s):s=s.toString();let i=s.charAt(0),a=s.charAt(s.length-1),c=!1;if(e.search_attribute===t&&(c=!0),wo.indexOf(s)>-1)return r===!0?Ve.SEARCH_TYPES.SEARCH_ALL_TO_MAP:Ve.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(wo[0])<0&&s.indexOf(wo[1])<0)return c===!0?r===!0?Ve.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:Ve.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:Ve.SEARCH_TYPES.EQUALS;if(wo.indexOf(i)>=0&&wo.indexOf(a)>=0)return e.search_value=e.search_value.slice(1,-1),Ve.SEARCH_TYPES.CONTAINS;if(wo.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),Ve.SEARCH_TYPES.ENDS_WITH;if(wo.indexOf(a)>=0)return e.search_value=e.search_value.slice(0,-1),Ve.SEARCH_TYPES.STARTS_WITH;if(s.includes(wo[0])||s.includes(wo[1]))return Ve.SEARCH_TYPES.EQUALS;throw new Error(Ix.UNKNOWN_SEARCH_TYPE)}else switch(n){case nl.VALUE_SEARCH_COMPARATORS.BETWEEN:return Ve.SEARCH_TYPES.BETWEEN;case nl.VALUE_SEARCH_COMPARATORS.GREATER:return Ve.SEARCH_TYPES.GREATER_THAN;case nl.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return Ve.SEARCH_TYPES.GREATER_THAN_EQUAL;case nl.VALUE_SEARCH_COMPARATORS.LESS:return Ve.SEARCH_TYPES.LESS_THAN;case nl.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return Ve.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(Ix.UNKNOWN_SEARCH_TYPE)}}o(Cx,"createSearchTypeFromSearchObject");Px.exports={executeSearch:wx,createSearchTypeFromSearchObject:Cx,prepSearch:r7,searchByType:Ox}});var Dx=M((xOe,Lx)=>{"use strict";var UOe=ri(),s7=Bu(),i7=ie(),o7=(k(),v(K)),a7=KE();Lx.exports=c7;function c7(e,t){if(!i7.isEmpty(t)&&o7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=s7(e,"value");if(n)throw n;return a7.prepSearch(e,t,!0)}o(c7,"lmdbGetDataByValue")});var vm=M((HOe,Mx)=>{"use strict";var FOe=ri(),l7=Bu(),u7=ie(),d7=(k(),v(K)),f7=KE();Mx.exports=m7;async function m7(e,t){if(!u7.isEmpty(t)&&d7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=l7(e,"value");if(n)throw n;return f7.prepSearch(e,t,!1)}o(m7,"lmdbSearchByValue")});var Ux=M((qOe,vx)=>{"use strict";var GOe=kt(),Hb=class{static{o(this,"SearchByConditionsObject")}constructor(t,r,n,s,i=void 0,a=void 0,c="and"){this.schema=t,this.table=r,this.get_attributes=n,this.limit=i,this.offset=a,this.conditions=s,this.operator=c}},kb=class{static{o(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},Gb=class{static{o(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};vx.exports={SearchByConditionsObject:Hb,SearchCondition:kb,SortAttribute:Gb}});var kx=M((YOe,Hx)=>{"use strict";var VOe=Ux().SearchByConditionsObject,h7=ri(),p7=Bu(),qb=xu(),YE=kt(),{Resource:KOe}=(Ia(),v(gU)),Fx=KE(),_7=vb(),E7=require("lodash"),{getSchemaPath:g7}=At(),xx=Et(),{handleHDBError:S7,hdbErrors:T7}=_e(),{HTTP_STATUS_CODES:R7}=T7,y7=1e8;Hx.exports=A7;async function A7(e){let t=p7(e,"conditions");if(t)throw S7(t,t.message,R7.BAD_REQUEST,void 0,void 0,!0);e.operator=e.operator?e.operator.toLowerCase():void 0,e.offset=Number.isInteger(e.offset)?e.offset:0;let r=g7(e.schema,e.table),n=await xx.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let u of e.conditions)xx.openDBI(n,u.search_attribute);let i=E7.sortBy(e.conditions,u=>{if(u.estimated_count===void 0){let d=u.search_type;d===YE.SEARCH_TYPES.EQUALS?u.estimated_count=qb.count(n,u.search_attribute,u.search_value):d===YE.SEARCH_TYPES.CONTAINS||d===YE.SEARCH_TYPES.ENDS_WITH?u.estimated_count=1/0:u.estimated_count=y7}return u.estimated_count}),a=n.useReadTransaction();a.database=n;let c=await Bx(a,e,i[0],s.hash_attribute),l;if(!e.operator||e.operator.toLowerCase()==="and"){let u=n.dbis[s.hash_attribute],d=i.slice(1).map(Fx.filterByType),f=d.length,m=qb.setGetWholeRowAttributes(n,e.get_attributes);l=c.map(h=>u.get(h,{transaction:a,lazy:!0})),f>0&&(l=l.filter(h=>{for(let p=0;p<f;p++)if(!d[p](h))return!1;return!0})),(e.offset||e.limit!==void 0)&&(l=l.slice(e.offset,e.limit!==void 0?(e.offset||0)+e.limit:void 0)),l=l.map(h=>_7.parseRow(h,m))}else{for(let f=1;f<i.length;f++){let m=i[f],h=await Bx(a,e,m,s.hash_attribute);c=c.concat(h)}let u=new Set,d=e.offset||0;c=c.filter(f=>u.has(f)?!1:(u.add(f),!0)).slice(d,e.limit&&e.limit+d),l=qb.batchSearchByHash(a,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{a.done()},l}o(A7,"lmdbSearchByConditions");async function Bx(e,t,r,n){let s=new h7(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===YE.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,Fx.searchByType(e,s,i,n).map(a=>a.value)}o(Bx,"executeConditionSearch")});var Um=M((zOe,Gx)=>{"use strict";var b7=(k(),v(K)).OPERATIONS_ENUM,$b=class{static{o(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=b7.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};Gx.exports=$b});var Vb=M((QOe,jx)=>{"use strict";var Kx=ri(),Yx=Um(),Wx=vm(),zx=Pm(),Pn=(k(),v(K)),qx=ie(),$x=Et(),{getTransactionAuditStorePath:I7,getSchemaPath:N7}=At(),Vx=z();jx.exports=w7;async function w7(e){try{if(qx.isEmpty(global.hdb_schema[e.schema])||qx.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await O7(e),await C7(e);let t=N7(e.schema,e.table);try{await $x.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")Vx.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=I7(e.schema,e.table);await $x.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")Vx.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}o(w7,"lmdbDropTable");async function O7(e){let t=new Kx(Pn.SYSTEM_SCHEMA_NAME,Pn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Pn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Pn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await Wx(t)),n=[];for(let i=0;i<r.length;i++){let a=r[i];n.push(a.id)}if(n.length===0)return;let s=new Yx(Pn.SYSTEM_SCHEMA_NAME,Pn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await zx(s)}o(O7,"deleteAttributesFromSystem");async function C7(e){let t=new Kx(Pn.SYSTEM_SCHEMA_NAME,Pn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Pn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[Pn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,Pn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,Pn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await Wx(t))}catch(i){throw i}for(let i=0;i<r.length;i++){let a=r[i];a.name===e.table&&a.schema===e.schema&&(n=a)}if(!n)throw new Error(`${e.schema}.${e.table} was not found`);let s=new Yx(Pn.SYSTEM_SCHEMA_NAME,Pn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await zx(s)}catch(i){throw i}}o(C7,"dropTableFromSystem")});var Jx=M((XOe,Qx)=>{"use strict";var P7=require("fs-extra"),L7=ri(),D7=Fu(),M7=Um(),v7=Vb(),U7=Pm(),x7=xb(),B7=vm(),Oo=(k(),v(K)),{getSchemaPath:F7}=At(),{handleHDBError:H7,hdbErrors:k7}=_e(),{HDB_ERROR_MSGS:G7,HTTP_STATUS_CODES:q7}=k7;Qx.exports=$7;async function $7(e){let t;try{t=await V7(e.schema);let r=new L7(Oo.SYSTEM_SCHEMA_NAME,Oo.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Oo.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[Oo.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await B7(r));for(let a=0;a<n.length;a++){let c={schema:t,table:n[a].name};try{await v7(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new M7(Oo.SYSTEM_SCHEMA_NAME,Oo.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await U7(s);let i=F7(t);await P7.remove(i)}catch(r){throw r}}o($7,"lmdbDropSchema");async function V7(e){let t=new D7(Oo.SYSTEM_SCHEMA_NAME,Oo.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[Oo.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await x7(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw H7(new Error,G7.SCHEMA_NOT_FOUND(e),q7.NOT_FOUND,void 0,void 0,!0);return n}o(V7,"validateDropSchema")});var xm=M((eCe,Xx)=>{"use strict";var Kb=class{static{o(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};Xx.exports=Kb});var Wb=M((nCe,Zx)=>{"use strict";var K7=require("fs-extra"),WE=Et(),{getTransactionAuditStorePath:Y7}=At(),Yb=kt(),rCe=xm();Zx.exports=W7;async function W7(e){let t;try{let r=Y7(e.schema,e.table);await K7.mkdirp(r),t=await WE.createEnvironment(r,e.table,!0)}catch(r){throw r.message=`unable to create transactions audit environment for ${e.schema}.${e.table} due to: ${r.message}`,r}try{WE.createDBI(t,Yb.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),WE.createDBI(t,Yb.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),WE.createDBI(t,Yb.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME,!0,!1)}catch(r){throw r.message=`unable to create dbi for ${e.schema}.${e.table} due to: ${r.message}`,r}return t}o(W7,"createTransactionsAuditEnvironment")});var rB=M((oCe,tB)=>{"use strict";var zb=(k(),v(K)),eB=Et(),z7=Zc(),{getSystemSchemaPath:j7,getSchemaPath:Q7}=At(),iCe=Ao(),J7=FE(),jb=BE(),X7=z(),Z7=Wb();tB.exports=eee;async function eee(e,t){let r=Q7(t.schema,t.table),n=new jb(t.schema,t.table,zb.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new jb(t.schema,t.table,zb.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new jb(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await eB.createEnvironment(r,t.table),e!==void 0){let a=await eB.openEnvironment(j7(),zb.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await z7.insertRecords(a,HDB_TABLE_INFO.hash_attribute,hdbTableAttributes,[e]),n.skip_table_check=!0,s.skip_table_check=!0,i.skip_table_check=!0,await Qb(n),await Qb(s),await Qb(i)}await Z7(t)}catch(a){throw a}}o(eee,"lmdbCreateTable");async function Qb(e){try{await J7(e)}catch(t){X7.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}o(Qb,"createAttribute")});var sB=M((cCe,nB)=>{"use strict";var tee=wm(),ree=jf(),nee=HE(),Bm=(k(),v(K)),see=Zc().updateRecords,iee=Et(),{getSchemaPath:oee}=At(),aee=Om(),cee=z();nB.exports=lee;async function lee(e){try{let{schemaTable:t,attributes:r}=tee(e);ree(e,r,t.hash_attribute),e.schema!==Bm.SYSTEM_SCHEMA_NAME&&(r.includes(Bm.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(Bm.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(Bm.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(Bm.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await nee(e.hdb_auth_header,t,r),s=oee(e.schema,e.table),i=await iee.openEnvironment(s,e.table),a=await see(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await aee(e,a)}catch(c){cee.error(`unable to write transaction due to ${c.message}`)}return{written_hashes:a.written_hashes,skipped_hashes:a.skipped_hashes,schemaTable:t,new_attributes:n,txn_time:a.txn_time}}catch(t){throw t}}o(lee,"lmdbUpdateRecords")});var oB=M((uCe,iB)=>{"use strict";var uee=(k(),v(K)).OPERATIONS_ENUM,Jb=class{static{o(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=uee.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};iB.exports=Jb});var cB=M((mCe,aB)=>{"use strict";var fCe=oB(),dee=wm(),fee=jf(),mee=HE(),Fm=(k(),v(K)),hee=Zc().upsertRecords,pee=Et(),{getSchemaPath:_ee}=At(),Eee=Om(),gee=z(),{handleHDBError:See,hdbErrors:Tee}=_e();aB.exports=Ree;async function Ree(e){let t;try{t=dee(e)}catch(l){throw See(l,l.message,Tee.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schemaTable:r,attributes:n}=t;fee(e,n,r.hash_attribute),e.schema!==Fm.SYSTEM_SCHEMA_NAME&&(n.includes(Fm.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(Fm.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(Fm.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(Fm.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await mee(e.hdb_auth_header,r,n),i=_ee(e.schema,e.table),a=await pee.openEnvironment(i,e.table),c=await hee(a,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await Eee(e,c)}catch(l){gee.error(`unable to write transaction due to ${l.message}`)}return{written_hashes:c.written_hashes,schemaTable:r,new_attributes:s,txn_time:c.txn_time}}o(Ree,"lmdbUpsertRecords")});var uB=M((pCe,lB)=>{"use strict";var Xb=class{static{o(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};lB.exports=Xb});var fB=M((ECe,dB)=>{"use strict";var Zb=class{static{o(this,"DeleteAuditLogsBeforeResults")}constructor(t=void 0,r=void 0,n=0){this.start_timestamp=t,this.end_timestamp=r,this.transactions_deleted=n}};dB.exports=Zb});var pB=M((TCe,hB)=>{"use strict";var eI=Et(),{getTransactionAuditStorePath:yee}=At(),SCe=uB(),Hm=kt(),Aee=ie(),mB=fB(),bee=require("util").promisify,Iee=bee(setTimeout),Nee=1e4,wee=100;hB.exports=Oee;async function Oee(e){let t=yee(e.schema,e.table),r=await eI.openEnvironment(t,e.table,!0),n=eI.listDBIs(r);eI.initializeDBIs(r,Hm.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new mB;do s=await Cee(r,e.timestamp),i.start_timestamp===void 0&&(i.start_timestamp=s.start_timestamp),s.end_timestamp!==void 0&&(i.end_timestamp=s.end_timestamp),i.transactions_deleted+=s.transactions_deleted,await Iee(wee);while(s.transactions_deleted>0);return i}o(Oee,"deleteAuditLogsBefore");async function Cee(e,t){let r=new mB;try{let n=e.dbis[Hm.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],s;for(let{key:i,value:a}of n.getRange({start:!1})){if(i>=t)break;r.start_timestamp===void 0&&(r.start_timestamp=i),s=n.remove(i);let c=a[Hm.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];Aee.isEmpty(c)||(s=e.dbis[Hm.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<a.hash_values.length;l++)s=e.dbis[Hm.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(a.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>Nee)break}return await s,r}catch(n){throw n}}o(Cee,"deleteTransactions")});var EB=M((yCe,_B)=>{"use strict";var tI=class{static{o(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};_B.exports=tI});var SB=M((ICe,gB)=>{"use strict";var Pee=ri(),Lee=Um(),bCe=EB(),vi=(k(),v(K)),Dee=ie(),rI=Et(),Mee=Ao(),vee=vm(),Uee=Pm(),{getSchemaPath:xee}=At();gB.exports=Bee;async function Bee(e,t=!0){let r;e.schema===vi.SYSTEM_SCHEMA_NAME?r=Mee[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await Hee(e),s=xee(e.schema,e.table),i=await rI.openEnvironment(s,e.table);return t===!0&&await Fee(e,i,r.hash_attribute),rI.dropDBI(i,e.attribute),n}o(Bee,"lmdbDropAttribute");async function Fee(e,t,r){let n=rI.openDBI(t,r),s,i=e.attribute;for(let{key:a,value:c,version:l}of n.getRange({start:!1,versions:!0})){let u={};for(let d in c)d!==i&&(u[d]=c[d]);s=t.dbis[r].put(a,u,l)}await s}o(Fee,"removeAttributeFromAllObjects");async function Hee(e){let t=new Pee(vi.SYSTEM_SCHEMA_NAME,vi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,vi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[vi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,vi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await vee(t)).filter(a=>a[vi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(Dee.isEmptyOrZeroLength(n))throw new Error(`Attribute '${drop_attribute_obj.attribute}' was not found in '${drop_attribute_obj.schema}.${drop_attribute_obj.table}'`);let s=n.map(a=>a[vi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new Lee(vi.SYSTEM_SCHEMA_NAME,vi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return Uee(i)}o(Hee,"dropAttributeFromSystem")});var IB=M((OCe,bB)=>{"use strict";var nI=Et(),Hu=kt(),wCe=An(),sI=(k(),v(K)),TB=ie(),{getTransactionAuditStorePath:kee}=At(),Gee=xu(),zE=Mu(),qee=z();bB.exports=$ee;async function $ee(e){let t=kee(e.schema,e.table),r=await nI.openEnvironment(t,e.table,!0),n=nI.listDBIs(r);nI.initializeDBIs(r,Hu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case sI.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return RB(r,e.search_values);case sI.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,Kee(r,e.search_values,s);case sI.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return Vee(r,e.search_values);default:return RB(r)}}o($ee,"readAuditLog");function RB(e,t=[0,Date.now()]){TB.isEmpty(t[0])&&(t[0]=0),TB.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[Hu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],n;for(let s of r.getKeys({start:t[1]}))if(s!==t[1]){n=s;break}return r.getRange({start:t[0],end:n}).map(({value:s})=>Object.assign(new zE,s))}o(RB,"searchTransactionsByTimestamp");function Vee(e,t=[]){let r=new Map;for(let n=0;n<t.length;n++){let s=t[n],i=[];for(let a of e.dbis[Hu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(a);r.set(s,AB(e,i))}return Object.fromEntries(r)}o(Vee,"searchTransactionsByUsername");function Kee(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let u=t[c],d=Gee.equals(e,Hu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Hu.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,u);for(let{value:f}of d){let m=Number(f);n.has(m)?n.get(m).push(u.toString()):n.set(m,[u.toString()])}}let s=Array.from(n.keys()),i=AB(e,s),a=new Map;for(let c=0;c<i.length;c++){let l=i[c],u=l.timestamp,d=n.get(u);yB(l,"records",r,d,a),yB(l,"original_records",r,d,a)}return Object.fromEntries(a)}o(Kee,"searchTransactionsByHashValues");function yB(e,t,r,n,s){let i=e.timestamp;if(e[t])for(let a=0;a<e[t].length;a++){let c=e[t][a],l=c[r].toString();if(n.indexOf(l)>=0)if(s.has(l)){let u=s.get(l),d=u[u.length-1];if(d.timestamp===i)d[t]=[c];else{let f=new zE(e.operation,e.user_name,i,void 0);f[t]=[c],u.push(f)}}else{let u=new zE(e.operation,e.user_name,i,void 0);u[t]=[c],s.set(l,[u])}}}o(yB,"loopRecords");function AB(e,t){let r=[];try{let n=e.dbis[Hu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP];for(let s=0;s<t.length;s++)try{let i=n.get(t[s]);if(i){let a=Object.assign(new zE,i);r.push(a)}}catch(i){qee.warn(i)}return r}catch(n){throw n}}o(AB,"batchSearchTransactions")});var wB=M((DCe,NB)=>{"use strict";var{getSchemaPath:PCe}=At(),LCe=Et(),{database:Yee}=(Le(),v(ft));NB.exports={writeTransaction:Wee};async function Wee(e,t,r){return Yee({database:e,table:t}).transaction(r)}o(Wee,"writeTransaction")});var LB=M((vCe,PB)=>{"use strict";var{getSchemaPath:OB}=At(),CB=Et();PB.exports={flush:zee,resetReadTxn:jee};async function zee(e,t){return(await CB.openEnvironment(OB(e,t),t.toString())).flushed}o(zee,"flush");async function jee(e,t){try{(await CB.openEnvironment(OB(e,t),t.toString())).resetReadTxn()}catch{}}o(jee,"resetReadTxn")});var UB=M((xCe,vB)=>{"use strict";var{Readable:Qee}=require("stream"),{getDatabases:Jee}=(Le(),v(ft)),{readSync:Xee,openSync:Zee,createReadStream:DB}=require("fs"),{open:ete}=require("lmdb"),MB=Rm(),tte=ym(),{AUDIT_STORE_OPTIONS:rte}=(mo(),v(nU)),{INTERNAL_DBIS_NAME:nte,AUDIT_STORE_NAME:ste}=kt();vB.exports=ote;var iI=32768,ite=100;async function ote(e){let t=e.database||e.schema||"data",r=Jee()[t],n=new Date().toISOString(),s=e.tables||e.table&&[e.table];if(s){let u=r[s[0]];if(!u)throw new Error(`Can not find table ${s[0]}`);let d=u.dbisDB,f=ete({noSync:!0,maxDbs:tte.MAX_DBS}),m,h=f.openDB(nte,new MB(!1)),p=d.useReadTransaction(),E=0,g=o(async function(T,R){R.encoding="binary",R.encoder=void 0;let I=f.openDB(T,R),P=d.openDB(T,R);for(let{key:Y,version:te,value:x}of P.getRange({start:null,transaction:p,versions:P.useVersions}))m=I.put(Y,x,te),E++%ite===0&&(await new Promise($=>setTimeout($,20)),p.openTimer&&(p.openTimer=0))},"copyDatabase");for(let{key:T,value:R}of d.getRange({transaction:p,start:!1}))if(s.some(I=>T.startsWith?.(I+"/"))){h.put(T,R);let[,I]=T.split("/"),P=!I,Y=new MB(!P,P);await g(T,Y)}e.include_audit&&await g(ste,{...rte}),await m;let y=DB(f.path);return y.headers=l(),y.on("close",()=>{p.done(),f.close()}),y}let a=r[Object.keys(r)[0]].primaryStore,c=Zee(a.path);return a.transaction(()=>{let u=Buffer.alloc(iI);Xee(c,u,0,iI),a.resetReadTxn();let d=a.useReadTransaction();d.renew();let f=DB(null,{fd:c,start:iI}),m=new Qee.from(async function*(){yield u;for await(let h of f)d.openTimer&&(d.openTimer=0),yield h;d.done()}());return m.headers=l(),m});function l(){let u=new Map;return u.set("content-type","application/octet-stream"),u.set("content-disposition",`attachment; filename="${t}"`),u.set("date",n),u}}o(ote,"getBackup")});var FB=M((FCe,BB)=>{"use strict";var ate=z(),{handleHDBError:cte}=_e(),lte=u0(),ute=FE(),dte=Cb(),fte=J0(),mte=Pm(),hte=xb(),pte=Ax(),_te=Dx(),Ete=vm(),gte=kx(),Ste=Jx(),Tte=rB(),Rte=sB(),yte=cB(),Ate=pB(),bte=Vb(),Ite=SB(),Nte=IB(),wte=wB(),xB=LB(),Ote=UB(),oI=class extends lte{static{o(this,"LMDBBridge")}async searchByConditions(t){return gte(t)}async getDataByHash(t){return await hte(t)}async searchByHash(t){return await pte(t)}async getDataByValue(t,r){return await _te(t,r)}async searchByValue(t){return await Ete(t)}async createSchema(t){return await fte(t)}async dropSchema(t){return await Ste(t)}async createTable(t,r){return await Tte(t,r)}async dropTable(t){return await bte(t)}async createAttribute(t){return await ute(t)}async createRecords(t){return await dte(t)}async updateRecords(t){return await Rte(t)}async upsertRecords(t){try{return await yte(t)}catch(r){throw cte(r,null,null,ate.ERR,r)}}async deleteRecords(t){return await mte(t)}async dropAttribute(t){return await Ite(t)}async deleteAuditLogsBefore(t){return await Ate(t)}async readAuditLog(t){return await Nte(t)}writeTransaction(t,r,n){return wte.writeTransaction(t,r,n)}flush(t,r){return xB.flush(t,r)}resetReadTxn(t,r){return xB.resetReadTxn(t,r)}getBackup(t){return Ote(t)}};BB.exports=oI});function Ln(e){let t=e.getChanges();return t||(t=Object.create(null),e._setChanges(t)),t}function Gm(e,t,r=!1){let n=e.prototype,s={},i=t.attributes||t.properties||[];for(let l of i){let u=l.name,d,f;if(l.resolve)f={get(){return l.resolve(this,this.getContext?.())},set(m){return l.set(this,m)},configurable:!0};else{switch(l.type){case"String":d=o(function(m){if(!(typeof m=="string"||m==null&&l.nullable!==!1))throw new zn.ClientError(`${u} must be a string, attempt to assign ${m}`);Ln(this)[u]=m},"set");break;case"ID":d=o(function(m){if(!(typeof m=="string"||m?.length>0&&m.every?.(h=>typeof h=="string")||m==null&&l.nullable!==!1))throw new zn.ClientError(`${u} must be a string, attempt to assign ${m}`);Ln(this)[u]=m},"set");break;case"Float":case"Number":d=o(function(m){let h=m?.__op__?m.value:m;if(!(typeof h=="number"||m==null&&l.nullable!==!1))throw new zn.ClientError(`${u} must be a number, attempt to assign ${h}`);Ln(this)[u]=m},"set");break;case"Int":d=o(function(m){let h=m?.__op__?m.value:m;if(!(h>>0===h||m==null&&l.nullable!==!1))if(typeof h=="number"&&Math.abs((h>>0)-h)<=1)h=Math.round(h),m?.__op__?m.value=h:m=h;else throw new zn.ClientError(`${u} must be an integer between -2147483648 and 2147483647, attempt to assign ${m}`);Ln(this)[u]=m},"set");break;case"Long":d=o(function(m){let h=m?.__op__?m.value:m;if(!(Math.round(h)===m&&Math.abs(h)<=9007199254740992||m==null&&l.nullable!==!1))if(typeof h=="number"&&Math.abs(h)<=9007199254740992)h=Math.round(h),m?.__op__?m.value=h:m=h;else throw new zn.ClientError(`${u} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${m}`);Ln(this)[u]=m},"set");break;case"BigInt":d=o(function(m){let h=m?.__op__?m.value:m;if(!(typeof h=="bigint"||m==null&&l.nullable!==!1))if(typeof h=="string"||typeof h=="number")h=BigInt(h),m?.__op__?m.value=h:m=h;else throw new zn.ClientError(`${u} must be a number, attempt to assign ${m}`);Ln(this)[u]=m},"set");break;case"Boolean":d=o(function(m){if(!(typeof m=="boolean"||m==null&&l.nullable!==!1))throw new zn.ClientError(`${u} must be a boolean, attempt to assign ${m}`);Ln(this)[u]=m},"set");break;case"Date":d=o(function(m){if(!(m instanceof Date||m==null&&l.nullable!==!1))if(typeof m=="string"||typeof m=="number")m=new Date(m);else throw new zn.ClientError(`${u} must be a Date, attempt to assign ${m}`);Ln(this)[u]=m},"set");break;case"Bytes":d=o(function(m){if(!(m instanceof Uint8Array||m==null&&l.nullable!==!1))throw new zn.ClientError(`${u} must be a Buffer or Uint8Array, attempt to assign ${m}`);Ln(this)[u]=m},"set");break;case"Blob":d=o(function(m){if(!(m instanceof Ss||m==null&&l.nullable!==!1))throw new zn.ClientError(`${u} must be a Blob, attempt to assign ${m}`);Ln(this)[u]=m},"set");break;case"Any":case void 0:d=o(function(m){Ln(this)[u]=m},"set");break;default:d=o(function(m){if(!(typeof m=="object"||m==null&&l.nullable!==!1))throw new zn.ClientError(`${u} must be an object, attempt to assign ${m}`);Ln(this)[u]=m},"set")}f={get(){let m=this.getChanges?.();if(m&&u in m){let p=m[u];if(p?.__op__){let E=this.getRecord()?.[u];return p.update(E)}return p}let h=this.getRecord()?.[u];if(h&&typeof h=="object"){let p=aI(h,l);if(p)return m||this._setChanges(m=Object.create(null)),m[u]=p}return h},set:d,enumerable:!0,configurable:!0}}f.get.isAttribute=!0,s[u]=f,(!(u in n)||Object.getOwnPropertyDescriptor(n,u)?.get?.isAttribute)&&Object.defineProperty(n,u,f)}a("getProperty",function(l){let u=s[l];if(u)return u.get.call(this);let d=this.getChanges();return d?.[l]!==void 0?d[l]:this.getRecord()?.[l]}),a("set",function(l,u){let d=s[l];if(d)return d.set.call(this,u);if(t.sealed)throw new zn.ClientError("Can not add a property to a sealed table schema");Ln(this)[l]=u}),a("deleteProperty",function(l){Ln(this)[l]=void 0}),a("toJSON",function(){let l=this.getChanges?.(),u;for(let f in l){u||(u={...this.getRecord()});let m=l[f];if(m?.__op__){let h=u[f];m=m.update(h)}u[f]=m}return Object.keys(this).length>0&&(u||(u={...this.getRecord()}),Object.assign(u,this)),u||this.getRecord()}),n.get||a("get",n.getProperty),n.delete||a("delete",n.deleteProperty),n.then||a("then",null);function a(l,u){Object.defineProperty(n,l,{value:u,configurable:!0})}o(a,"setMethod");let c=n;do{let l=Object.getPrototypeOf(c);if(l===Object.prototype){Object.setPrototypeOf(c,r?GB:kB);break}c=l}while(c&&c!==kB&&c!==GB)}function qB(e,t,r){if(typeof t=="string"){if(t==="then"||t==="getRecord"||t==="getChanges")return;if(HB[t])return HB[t];let n=r.getChanges?.();if(n&&t in n)return n[t];let s=r.getRecord?.()?.[t];if(s&&typeof s=="object"){let i=aI(s);if(i)return n||(n=Object.create(null),r._setChanges(n)),n[t]=i,i}return s}}function Cte(e,t,r,n){if(typeof t=="string"){let s=n.getChanges?.();s||(s={},n._setChanges(s)),s[t]=r}else Object.defineProperty(n,t,{value:r,configurable:!0,writable:!0});return!0}function aI(e,t){let r;switch(e.constructor){case Object:return t?(r=t.TrackedObject,r||(t.TrackedObject=r=class extends il{static{o(this,"TrackedObject")}},Gm(r,t)),new r(e)):new il(e);case Array:let n=new QE(e.length,e);for(let s=0,i=e.length;s<i;s++){let a=e[s];a&&typeof a=="object"&&(a=aI(a,t?.elements)),n[s]=a}return n;default:return e}}function JE(e){let t=e.getChanges?.(),r;for(let s in t){r||(r=e.getRecord?{...e.getRecord()}:{});let i=t[s];if(i&&typeof i=="object")if(i.__op__){let a=r[s];i=i.update(a)}else i=JE(i);r[s]=i}return Object.keys(e).length>0&&(r||(r=e.getRecord?{...e.getRecord()}:{}),Object.assign(r,e)),r||e.getRecord?.()||e}function Pa(e,t=e.getChanges?.()){let r;if(!e)return t;if(e.getRecord&&e.constructor===Array&&!Object.isFrozen(e)){r=e;for(let n=0,s=e.length;n<s;n++){let i=e[n];if(i&&typeof i=="object"){let a=Pa(i);a!==i&&r===e&&(r=e.slice(0)),i=a}r[n]=i}return Object.freeze(r)}for(let n in t){r||(r={...e.getRecord?e.getRecord():e});let s=t[n];if(s&&typeof s=="object")if(s.__op__){let i=iA[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=Pa(s);r[n]=s}if(!Array.isArray(e)&&e.getRecord)for(let n in e)Pte.call(e,n)&&(r||(r={...e.getRecord()}),r[n]=e[n]);return r?Object.freeze(r):e.getRecord?e.getRecord():e}function jE(e){let t=e.getRecord?.();if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[sl]||e.length!==t.length)return!0;for(let r=0,n=e.length;r<n;r++){let s=t[r],i=e[r];if(s&&i?.getRecord?.()===s){if(jE(i))return!0}else return!0}}else{let r=e.getChanges?.();if(r&&!t)return!0;for(let n in r){let s=r[n];if(s&&typeof s=="object"){let i=t[n];if(i&&s.getRecord?.()===i){if(jE(s))return!0}else return!0}else return!0}}return!1}var zn,HB,kB,GB,il,Pte,sl,QE,km,cI=fe(()=>{zn=w(_e());K_();Ts();o(Ln,"getChanges");o(Gm,"assignTrackedAccessors");HB=Object.prototype,kB=new Proxy({},{get:qB}),GB=new Proxy({},{get:qB,set:Cte});o(qB,"getProxiedProperty");o(Cte,"setProxiedProperty");o(aI,"trackObject");il=class{static{o(this,"GenericTrackedObject")}#e;#t;constructor(t){if(t?.getRecord)throw new Error("Can not track an already tracked object, check for circular references");this.#e=t}getRecord(){return this.#e}setRecord(t){this.#e=t}getChanges(){return this.#t}_setChanges(t){this.#t=t}};Gm(il,{},!0);o(JE,"collapseData");Pte=Object.prototype.hasOwnProperty;o(Pa,"updateAndFreeze");o(jE,"hasChanges");sl=Symbol.for("has-array-changes"),QE=class extends Array{static{o(this,"TrackedArray")}#e;[sl];constructor(t,r){super(t),this.#e=r}getRecord(){return this.#e}splice(...t){return this[sl]=!0,super.splice(...t)}push(...t){return this[sl]=!0,super.push(...t)}pop(){return this[sl]=!0,super.pop()}unshift(...t){return this[sl]=!0,super.unshift(...t)}shift(){return this[sl]=!0,super.shift()}};QE.prototype.constructor=Array;km=class{static{o(this,"Addition")}__op__="add";value;constructor(t){this.value=t}update(t){return(+t||0)+this.value}}});var QB={};Ce(QB,{ResourceBridge:()=>dI});function fI({get_attributes:e},t){if(e){if(e[0]==="*"){if(t.schemaDefined)return;e=t.attributes.map(r=>r.name)}return e.forceNulls=!0,e}}function $B(e,t){let r=Ui(e),n=fI(e,r);if(!r)throw new ni.ClientError(`Table ${e.table} not found`);let s;n&&r.attributes.length-n.length>2&&n.length<5&&(s=!0);let i={user:e.hdb_user,onlyIfCached:e.onlyIfCached,noCacheStore:e.noCacheStore,noCache:e.noCache,replicateFrom:e.replicateFrom},a;vt(i,()=>new Promise(u=>a=u));let c=e.ids||e.hash_values,l=0;return{[Symbol.asyncIterator](){return{async next(){if(l<c.length){let u=c[l++],d;try{d=await r.get({id:u,lazy:s,select:n},i),d=d&&JE(d)}catch(f){d={message:(0,jB.errorToString)(f)}}return t?{value:{key:u,value:d}}:{value:d}}else return a(),{done:!0}},return(u){return a(),{value:u,done:!0}},throw(u){return a(),{done:!0}}}}}}function Ui(e){let t=e.database||e.schema||Dte,r=it()[t];if(!r)throw(0,ni.handleHDBError)(new Error,Lte.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function VB(e,t,r){let n=e.length+t.length,s=n===1?"record":"records";return{message:`${e.length} of ${n} ${s} successfully deleted`,deleted_hashes:e,skipped_hashes:t,txn_time:r}}async function*KB(e,t,r,n){let s,i=0;for await(let a of e.getHistory(t,r)){let c=a.operation??a.type;c==="put"&&(c="upsert");let{id:l,version:u,value:d}=a;if(s?.timestamp===u)s.hash_values.push(l),s.records.push(d);else{if(s&&(yield s,i++,n&&n<=i)){s=void 0;break}s={operation:c,user_name:a.user,timestamp:u,hash_values:[l],records:[d]}}}s&&(yield s)}var YB,XE,ni,WB,lI,uI,zB,jB,Lte,Dte,Mte,vte,dI,JB=fe(()=>{YB=w(FB()),XE=w(Bu()),ni=w(_e());Le();WB=w(wm());k();lI=w(No()),uI=w(ti()),zB=w(ie());xc();cI();jB=w(z()),{HDB_ERROR_MSGS:Lte}=ni.hdbErrors,Dte="data",Mte=1e4,vte=10,dI=class extends YB.default{static{o(this,"ResourceBridge")}async searchByConditions(t){t.select!==void 0&&(t.get_attributes=t.select);for(let a of t.conditions||[])a?.attribute!==void 0&&(a.search_attribute=a.attribute),a?.comparator!==void 0&&(a.search_type=a.comparator),a?.value!==void 0&&(a.search_value=a.value);let r=(0,XE.default)(t,"conditions");if(r)throw(0,ni.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=Ui(t);if(!n)throw new ni.ClientError(`Table ${t.table} not found`);let s=t.conditions.map(i);function i(a){if("conditions"in a&&a.conditions)return a.conditions=a.conditions.map(i),a;{let c=a;return{attribute:c.search_attribute??c.attribute,comparator:c.search_type??c.comparator,value:c.search_value!==void 0?c.search_value:c.value}}}return o(i,"mapCondition"),n.search({conditions:s,operator:t.operator?t.operator.toLowerCase():void 0,limit:t.limit,offset:t.offset,reverse:t.reverse,select:fI(t,n),sort:t.sort,allowFullScan:!0},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async createTable(t,r){let n=r.attributes,s=!!n,i=r.primary_key||r.hash_attribute;if(n)for(let a of n)a.is_primary_key?(a.isPrimaryKey=!0,delete a.is_primary_key):a.name===i&&i&&(a.isPrimaryKey=!0);else{if(!i)throw new ni.ClientError("A primary key must be specified with a `primary_key` property or with `attributes`");n=[{name:i,isPrimaryKey:!0},{name:"__createdtime__",indexed:!0},{name:"__updatedtime__",indexed:!0}]}et({database:r.database??r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration,audit:r.audit})}async createAttribute(t){return await Ui(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=Ui(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=o((a,c,l)=>(c={...c},delete c[n],r.primaryStore.ifVersion(a,l,()=>r.primaryStore.put(a,c,l)).then(u=>{if(!u){let{value:d,version:f}=r.primaryStore.getEntry(a);return i(a,d,f)}})),"deleteRecord");for(let{key:a,value:c,version:l}of r.primaryStore.getRange({start:!0,versions:!0}))s=i(a,c,l),await new Promise(u=>setImmediate(u));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){return Ui(t).dropTable()}createSchema(t){return ku({database:t.schema,table:null}),lI.signalSchemaChange(new uI.SchemaEventMsg(process.pid,G.CREATE_SCHEMA,t.schema))}async dropSchema(t){await mI(t.schema),lI.signalSchemaChange(new uI.SchemaEventMsg(process.pid,G.DROP_SCHEMA,t.schema))}async updateRecords(t){return t.requires_existing=!0,this.upsertRecords(t)}async createRecords(t){return t.requires_no_existing=!0,this.upsertRecords(t)}async upsertRecords(t){let{schemaTable:r,attributes:n}=(0,WB.default)(t),s,i=it()[t.schema][t.table],a={user:t.hdb_user,expiresAt:t.expiresAt,originatingOperation:t.operation};return t.replicateTo&&(a.replicateTo=t.replicateTo),t.replicatedConfirmation&&(a.replicatedConfirmation=t.replicatedConfirmation),vt(a,async c=>{if(!i.schemaDefined){s=[];for(let d of n)i.attributes.find(m=>m.name==d)||s.push(d);s.length>0&&await i.addAttributes(s.map(d=>({name:d,indexed:!0})))}let l=[],u=[];for(let d of t.records){let f=d[i.primaryKey],m=f!=null&&await i.get(f,a);if(t.requires_existing&&!m||t.requires_no_existing&&m){u.push(d[i.primaryKey]);continue}m&&(m=JE(m));for(let h in d)if(Object.prototype.hasOwnProperty.call(d,h)){let p=d[h];if(typeof p=="function")try{let E=p([[m]]);Array.isArray(E)&&(p=E[0].func_val,d[h]=p)}catch(E){throw E.message+="Trying to set key "+h+" on object"+JSON.stringify(d),E}}if(m)for(let h in m)Object.prototype.hasOwnProperty.call(d,h)||(d[h]=m[h]);await(f==null?i.create(d,a):i.put(d,a)),l.push(d[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:l,new_attributes:s,skipped_hashes:u}})}async deleteRecords(t){let r=it()[t.schema][t.table],n={user:t.hdb_user};return t.replicateTo&&(n.replicateTo=t.replicateTo),t.replicatedConfirmation&&(n.replicatedConfirmation=t.replicatedConfirmation),vt(n,async s=>{let i=t.hash_values||t.records.map(l=>l[r.primaryKey]),a=[],c=[];for(let l of i)await r.delete(l,n)?a.push(l):c.push(l);return VB(a,c,s.timestamp)})}async deleteRecordsBefore(t){let r=it()[t.schema][t.table];if(!r.createdTimeProperty)throw new ni.ClientError("Table must have a '__createdtime__' attribute or @createdTime timestamp defined to perform this operation");let n=await r.search({conditions:[{attribute:r.createdTimeProperty.name,value:Date.parse(t.date),comparator:N_.LESS}]}),s=!1,i=[],a=[],c=0,l=[],u=o(async()=>{let d=await this.deleteRecords({schema:t.schema,table:t.table,hash_values:l});i.push(...d.deleted_hashes),a.push(...d.skipped_hashes),await(0,zB.asyncSetTimeout)(vte),l=[],s=!0},"chunkDelete");for await(let d of n)l.push(d[r.primaryKey]),c++,c%Mte===0&&await u();return l.length>0&&await u(),s?VB(i,a,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,XE.default)(t,"hashes");if(r)throw r;return $B(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of $B(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&By[r]===void 0)throw new Error(`Value search comparator - ${r} - is not valid`);t.select!==void 0&&(t.get_attributes=t.select),t.attribute!==void 0&&(t.search_attribute=t.attribute),t.value!==void 0&&(t.search_value=t.value);let n=(0,XE.default)(t,"value");if(n)throw n;let s=Ui(t);if(!s)throw new ni.ClientError(`Table ${t.table} not found`);let i=t.search_value;i.includes?.("*")&&(i.startsWith("*")?i.endsWith("*")?i!=="*"&&(r="contains",i=i.slice(1,-1)):(r="ends_with",i=i.slice(1)):i.endsWith("*")&&(r="starts_with",i=i.slice(0,-1))),r===N_.BETWEEN&&(i=[i,t.end_value]);let a=i==="*"?[]:[{attribute:t.search_attribute,value:i,comparator:r}];return s.search({conditions:a,allowFullScan:!0,limit:t.limit,offset:t.offset,reverse:t.reverse,sort:t.sort,select:fI(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async getDataByValue(t,r){let n=new Map,s=Ui(t);t.get_attributes&&!t.get_attributes.includes(s.primaryKey)&&t.get_attributes[0]!=="*"&&t.get_attributes.push(s.primaryKey);for await(let i of this.searchByValue(t,r))n.set(i[s.primaryKey],i);return n}resetReadTxn(t,r){Ui({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return Ui(t).deleteHistory(t.timestamp,t.cleanup_deleted_records)}async readAuditLog(t){let r=Ui(t),n={};switch(t.search_type){case w_.HASH_VALUE:for(let s of t.search_values)n[s]=(await r.getHistoryOfRecord(s)).map(i=>{let a=i.operation??i.type;return a==="put"&&(a="upsert"),{operation:a,timestamp:i.version,user_name:i.user,hash_values:[s],records:[i.value]}});return n;case w_.USERNAME:{let s=t.search_values;for await(let i of KB(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n}default:return KB(r,t.search_values?.[0],t.search_values?.[1],t.limit)}}};o(fI,"getSelect");o($B,"getRecords");o(Ui,"getTable");o(VB,"createDeleteResponse");o(KB,"groupRecordsInHistory")});var jn=M((jCe,XB)=>{"use strict";var{ResourceBridge:Ute}=(JB(),v(QB)),xte=ce();xte.initSync();var ZE;function Bte(){return ZE||(ZE=new Ute,ZE)}o(Bte,"getBridge");XB.exports=Bte()});var rF=M((JCe,tF)=>{"use strict";var ZB=require("lodash"),qm=require("mathjs"),Fte=require("jsonata"),eF=ie();tF.exports={distinct_array:o(e=>Array.isArray(e)&&e.length>1?ZB.uniqWith(e,ZB.isEqual):e,"distinct_array"),searchJSON:Hte,mad:$m.bind(null,qm.mad),mean:$m.bind(null,qm.mean),mode:$m.bind(null,qm.mode),prod:$m.bind(null,qm.prod),median:$m.bind(null,qm.median)};function $m(e,t,r,n){return n===1?t==null?[]:[t]:n===2?(t!=null&&r.push(t),r):r!=null&&r.length>0?e(r):null}o($m,"aggregateFunction");function Hte(e,t){if(typeof e!="string"||e.length===0)throw new Error("search json expression must be a non-empty string");let r="__"+e+"__";if(eF.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),eF.isEmpty(this.__ala__.res[r])){let n=Fte(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}o(Hte,"searchJSON")});var sF=M((ZCe,nF)=>{"use strict";var ar=require("moment"),hI="YYYY-MM-DDTHH:mm:ss.SSSZZ";ar.suppressDeprecationWarnings=!0;nF.exports={current_date:o(()=>ar().utc().format("YYYY-MM-DD"),"current_date"),current_time:o(()=>ar().utc().format("HH:mm:ss.SSS"),"current_time"),extract:o((e,t)=>{switch(t.toLowerCase()){case"year":return ar(e).utc().format("YYYY");case"month":return ar(e).utc().format("MM");case"day":return ar(e).utc().format("DD");case"hour":return ar(e).utc().format("HH");case"minute":return ar(e).utc().format("mm");case"second":return ar(e).utc().format("ss");case"millisecond":return ar(e).utc().format("SSS");default:break}},"extract"),date:o(e=>ar(e).utc().format(hI),"date"),date_format:o((e,t)=>ar(e).utc().format(t),"date_format"),date_add:o((e,t,r)=>ar(e).utc().add(t,r).valueOf(),"date_add"),date_sub:o((e,t,r)=>ar(e).utc().subtract(t,r).valueOf(),"date_sub"),date_diff:o((e,t,r)=>{let n=ar(e).utc(),s=ar(t).utc();return r?n.diff(s,r,!0):n.diff(s)},"date_diff"),now:o(()=>ar().utc().valueOf(),"now"),get_server_time:o(()=>ar().format(hI),"get_server_time"),offset_utc:o((e,t)=>ar(e).utc().utcOffset(t).format(hI),"offset_utc")}});var cF=M((tPe,aF)=>{"use strict";var kte=require("@turf/area"),Gte=require("@turf/length"),qte=require("@turf/circle"),$te=require("@turf/difference"),Vte=require("@turf/distance"),Kte=require("@turf/boolean-contains"),Yte=require("@turf/boolean-equal"),Wte=require("@turf/boolean-disjoint"),zte=require("@turf/helpers"),iF=(k(),v(K)),Ye=ie(),Co=z();aF.exports={geoArea:jte,geoLength:Qte,geoCircle:Jte,geoDifference:Xte,geoDistance:oF,geoNear:Zte,geoContains:ere,geoEqual:tre,geoCrosses:rre,geoConvert:nre};function jte(e){if(Ye.isEmpty(e))return NaN;typeof e=="string"&&(e=Ye.autoCastJSON(e));try{return kte.default(e)}catch(t){return Co.trace(t,e),NaN}}o(jte,"geoArea");function Qte(e,t){if(Ye.isEmpty(e))return NaN;typeof e=="string"&&(e=Ye.autoCastJSON(e));try{return Gte.default(e,{units:t||"kilometers"})}catch(r){return Co.trace(r,e),NaN}}o(Qte,"geoLength");function Jte(e,t,r){if(Ye.isEmpty(e))return NaN;if(Ye.isEmpty(t))return NaN;typeof e=="string"&&(e=Ye.autoCastJSON(e));try{return qte.default(e,t,{units:r||"kilometers"})}catch(n){return Co.trace(n,e,t),NaN}}o(Jte,"geoCircle");function Xte(e,t){if(Ye.isEmpty(e))return NaN;if(Ye.isEmpty(t))return NaN;typeof e=="string"&&(e=Ye.autoCastJSON(e)),typeof t=="string"&&(t=Ye.autoCastJSON(t));try{return $te(e,t)}catch(r){return Co.trace(r,e,t),NaN}}o(Xte,"geoDifference");function oF(e,t,r){if(Ye.isEmpty(e))return NaN;if(Ye.isEmpty(t))return NaN;typeof e=="string"&&(e=Ye.autoCastJSON(e)),typeof t=="string"&&(t=Ye.autoCastJSON(t));try{return Vte.default(e,t,{units:r||"kilometers"})}catch(n){return Co.trace(n,e,t),NaN}}o(oF,"geoDistance");function Zte(e,t,r,n){if(Ye.isEmpty(e)||Ye.isEmpty(t))return!1;if(Ye.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=Ye.autoCastJSON(e)),typeof t=="string"&&(t=Ye.autoCastJSON(t)),isNaN(r))throw new Error("distance must be a number");try{return oF(e,t,n)<=r}catch(s){return Co.trace(s,e,t),!1}}o(Zte,"geoNear");function ere(e,t){if(Ye.isEmpty(e)||Ye.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Ye.autoCastJSON(e)),typeof t=="string"&&(t=Ye.autoCastJSON(t));try{return Kte.default(e,t)}catch(r){return Co.trace(r,e,t),!1}}o(ere,"geoContains");function tre(e,t){if(Ye.isEmpty(e)||Ye.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Ye.autoCastJSON(e)),typeof t=="string"&&(t=Ye.autoCastJSON(t));try{return Yte.default(e,t)}catch(r){return Co.trace(r,e,t),!1}}o(tre,"geoEqual");function rre(e,t){if(Ye.isEmpty(e)||Ye.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Ye.autoCastJSON(e)),typeof t=="string"&&(t=Ye.autoCastJSON(t));try{return!Wte.default(e,t)}catch(r){return Co.trace(r,e,t),!1}}o(rre,"geoCrosses");function nre(e,t,r){if(Ye.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if(Ye.isEmpty(t))throw new Error("geo_type is required");if(Ye.isEmpty(iF.GEO_CONVERSION_ENUM[t]))throw new Error(`geoType of ${t} is invalid please use one of the following types: ${Object.keys(iF.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Ye.autoCastJSON(e)),zte[t](e,r)}o(nre,"geoConvert")});var eg=M((nPe,lF)=>{var ol=rF(),Qn=sF(),xi=cF();lF.exports=e=>{e.aggr.mad=e.aggr.MAD=ol.mad,e.aggr.mean=e.aggr.MEAN=ol.mean,e.aggr.mode=e.aggr.MODE=ol.mode,e.aggr.prod=e.aggr.PROD=ol.prod,e.aggr.median=e.aggr.MEDIAN=ol.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=ol.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=ol.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=Qn.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Qn.current_time,e.fn.extract=e.fn.EXTRACT=Qn.extract,e.fn.date=e.fn.DATE=Qn.date,e.fn.date_format=e.fn.DATE_FORMAT=Qn.date_format,e.fn.date_add=e.fn.DATE_ADD=Qn.date_add,e.fn.date_sub=e.fn.DATE_SUB=Qn.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Qn.date_diff,e.fn.now=e.fn.NOW=Qn.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Qn.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Qn.get_server_time,e.fn.getdate=e.fn.GETDATE=Qn.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Qn.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=xi.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=xi.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=xi.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=xi.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=xi.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=xi.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=xi.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=xi.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=xi.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=xi.geoNear}});var mF=M((sPe,fF)=>{"use strict";var Vm=require("lodash"),Dn=require("alasql");Dn.options.cache=!1;var sre=eg(),uF=require("clone"),tg=require("recursive-iterator"),ke=z(),tt=ie(),Gu=jn(),ire=(k(),v(K)),{hdbErrors:ore}=_e(),{getDatabases:dF}=(Le(),v(ft)),are="IS NULL",si="There was a problem performing this search. Please check the logs and try again.";sre(Dn);var pI=class{static{o(this,"SQLSearch")}constructor(t,r){if(tt.isEmpty(t))throw ke.error("AST statement for SQL select process cannot be empty"),"statement cannot be null";this.statement=t,this.columns={},this.all_table_attributes=r,this.fetch_attributes=[],this.exact_search_values={},this.comparator_search_values={},this.tables=[],this.data={},this.has_aggregator=!1,this.has_ordinal=!1,this.has_outer_join=!1,this._getColumns(),this._getTables(),this._conditionsToFetchAttributeValues(),this._setAliasesForColumns(),tt.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!tt.isEmptyOrZeroLength(n))return ke.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw ke.error("Error thrown from checkEmptySQL in SQLSearch class method search."),ke.error(n),new Error(si)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw ke.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),ke.error(n),new Error(si)}if(Object.keys(this.data).length===0)return ke.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw ke.error("Error thrown from processJoins in SQLSearch class method search."),ke.error(n),new Error(si)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw ke.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),ke.error(n),new Error(si)}try{return t=await this._finalSQL(),t}catch(n){throw ke.error("Error thrown from finalSQL in SQLSearch class method search."),ke.error(n),new Error(si)}}_getColumns(){let t=new tg(this.statement);for(let{node:r,path:n}of t)r&&r.columnid&&(this.columns[n[0]]||(this.columns[n[0]]=[]),this.columns[n[0]].push(uF(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=Vm.uniqBy(t,r=>[r.databaseid,r.tableid,r.as].join()),this.tables.forEach(r=>{let n=`${r.databaseid}_${r.as?r.as:r.tableid}`;this.data[n]={},this.data[n].__hashName=dF()[r.databaseid][r.tableid].primaryKey,this.data[n].__mergedData={},this.data[n].__mergedAttributes=[],this.data[n].__mergedAttrMap={}})}_conditionsToFetchAttributeValues(){if(tt.isEmpty(this.statement.where)){ke.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new tg(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!tt.isEmpty(r)&&r.right)if(tt.isNotEmptyAndHasValue(r.right.value)){let n=tt.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new Dn.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=tt.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new Dn.yy.LogicValue({value:i}):n instanceof Dn.yy.StringValue&&tt.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new Dn.yy.NumValue({value:i}))});if(t){ke.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new tg(this.statement.where))if(r&&r.left&&r.right&&(r.left.columnid||r.right.value)&&r.op){let n=new Set,s=r.left.columnid?r.left:r.right,i=this._findColumn(s);if(!i)continue;let a=[i.table.databaseid,i.table.tableid,i.attribute].join("/");if(!tt.isEmpty(ire.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(tt.isEmpty(this.comparator_search_values[a])&&(this.comparator_search_values[a]={ignore:!1,comparators:[]}),!this.comparator_search_values[a].ignore){if(tt.isEmptyOrZeroLength(r.left.columnid)||tt.isEmptyOrZeroLength(r.right.value)){this.comparator_search_values[a].ignore=!0,this.comparator_search_values[a].comparators=[];continue}this.comparator_search_values[a].comparators.push({attribute:r.left.columnid,operation:r.op,search_value:r.right.value})}continue}if(tt.isEmpty(this.exact_search_values[a])&&(this.exact_search_values[a]={ignore:!1,values:new Set}),!this.exact_search_values[a].ignore){let c=!1;switch(r.op){case"=":!tt.isEmpty(r.right.value)||!tt.isEmpty(r.left.value)?n.add(tt.isEmpty(r.right.value)?r.left.value:r.right.value):c=!0;break;case"IN":let l=Array.isArray(r.right)?r.right:r.left;for(let u=0;u<l.length;u++)if(l[u].value)n.add(l[u].value);else{c=!0;break}break;default:c=!0;break}this.exact_search_values[a].ignore=c,c?this.exact_search_values[a].values=new Set:this.exact_search_values[a].values=new Set([...this.exact_search_values[a].values,...n])}}}_setAliasesForColumns(){if(tt.isEmptyOrZeroLength(this.all_table_attributes)&&tt.isEmptyOrZeroLength(this.statement.from)&&tt.isEmptyOrZeroLength(this.columns.columns))return;let t=[],r={};this.statement.columns.forEach((n,s)=>{if(n.columnid==="*"){t.push(s);return}if(n.aggregatorid&&(this.has_aggregator=!0),!n.aggregatorid&&!n.funcid)if(n.as_orig=n.as?n.as:n.columnid,this.statement.joins)if(r[n.as_orig]>=0){let i=r[n.as_orig]+1;n.as=`[${n.as_orig+i}]`,r[n.as_orig]=i}else n.as=`[${n.as_orig}]`,r[n.as_orig]=0;else n.as=`[${n.as_orig}]`;!n.aggregatorid&&n.funcid&&n.args&&(n.as_orig=n.as?n.as:n.toString().replace(/'/g,'"'),n.as=`[${n.as_orig}]`),n.aggregatorid&&n.expression.columnid!=="*"&&(n.as_orig=n.as?n.as:n.expression.tableid?`${n.aggregatorid}(${n.expression.tableid}.${n.expression.columnid})`:`${n.aggregatorid}(${n.expression.columnid})`,n.as=`[${n.as_orig}]`)}),this.statement.columns.length>1&&t.length>0&&Vm.pullAt(this.statement.columns,t)}_findColumn(t){let r=this.all_table_attributes.filter(n=>{if(t.columnid_orig&&t.tableid_orig)return(n.table.as===t.tableid_orig||n.table.tableid===t.tableid_orig)&&n.attribute===t.columnid_orig;if(t.tableid)return(n.table.as===t.tableid||n.table.tableid===t.tableid)&&n.attribute===t.columnid;let s=t.columnid_orig?t.columnid_orig:t.columnid;return n.attribute===s});if(tt.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);tt.isEmptyOrZeroLength(n)||(r=this.all_table_attributes.filter(s=>s.attribute===n[0].columnid&&n[0].tableid&&n[0].tableid===(s.table.as?s.table.as:s.table.tableid)))}return r[0]}async _checkEmptySQL(){let t=[];if(tt.isEmptyOrZeroLength(this.all_table_attributes)&&!tt.isEmptyOrZeroLength(this.columns.columns))return t;if(tt.isEmptyOrZeroLength(this.all_table_attributes)&&tt.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await Dn.promise(r)}catch(r){throw ke.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),ke.error(r),new Error("There was a problem with the SQL statement")}return t}_addFetchColumns(t){t&&t.length>0&&t.forEach(r=>{let n=this._findColumn(r);n&&this.fetch_attributes.push(uF(n))})}_addColumnToMergedAttributes(t,r){this.data[t].__mergedAttributes.push(r),this.data[t].__mergedAttrMap[r]=this.data[t].__mergedAttributes.length-1}_setMergedHashAttribute(t,r){this.data[t].__mergedData[r].splice(0,1,r)}_updateMergedAttribute(t,r,n,s){let i=this.data[t].__mergedAttrMap[n];this.data[t].__mergedData[r].splice(i,1,s)}async _getFetchAttributeValues(){if(tt.isEmptyOrZeroLength(Object.keys(this.columns)))return[];this._addFetchColumns(this.columns.joins);let t=null;try{t=this.statement.where?this.statement.where.toString():""}catch{throw new Error("Could not generate proper where clause")}this.columns.where&&this._addFetchColumns(this.columns.where);let r=this._isSimpleSelect();if(r?this._addFetchColumns(this.columns.columns):(!this.columns.where&&this.fetch_attributes.length===0)|t.indexOf(are)>-1&&this.tables.forEach(s=>{let i={columnid:dF()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=Vm.uniqBy(this.fetch_attributes,s=>[s.table.databaseid,s.table.as?s.table.as:s.table.tableid,s.attribute].join()),r)return await this._simpleSQLQuery();let n=this.fetch_attributes.reduce((s,i)=>{let a=`${i.table.databaseid}_${i.table.as?i.table.as:i.table.tableid}`,c=this.data[a].__hashName;return s[a]||(s[a]=[],s[a].push(null),this._addColumnToMergedAttributes(a,c)),i.attribute!==c&&(s[a].push(null),this._addColumnToMergedAttributes(a,i.attribute)),s},{});for(let s of this.fetch_attributes){let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`,a=this.data[i].__hashName,c={schema:s.table.databaseid,table:s.table.tableid,get_attributes:[s.attribute]},l=!1,u=[s.table.databaseid,s.table.tableid,s.attribute].join("/");if(s.attribute===a&&(l=!0),!tt.isEmpty(this.exact_search_values[u])&&!this.exact_search_values[u].ignore&&!tt.isEmptyOrZeroLength(this.exact_search_values[u].values))if(l)try{c.hash_values=Array.from(this.exact_search_values[u].values);let d=await Gu.getDataByHash(c);for(let f of c.hash_values)d.get(f)&&!this.data[i].__mergedData[f]&&(this.data[i].__mergedData[f]=[...n[i]],this._setMergedHashAttribute(i,f))}catch(d){throw ke.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),ke.error(d),new Error(si)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[u].values).map(async d=>{let f={...c};f.search_value=d;let m=await Gu.getDataByValue(f);for(let[h,p]of m)this.data[i].__mergedData[h]?this._updateMergedAttribute(i,h,s.attribute,p[s.attribute]):(this.data[i].__mergedData[h]=[...n[i]],this._updateMergedAttribute(i,h,s.attribute,p[s.attribute]),this._setMergedHashAttribute(i,h))}))}catch(d){throw ke.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),ke.error(d),new Error(si)}else if(!tt.isEmpty(this.comparator_search_values[u])&&!this.comparator_search_values[u].ignore&&!tt.isEmptyOrZeroLength(this.comparator_search_values[u].comparators))try{let d=this.comparator_search_values[u].comparators;for(let f=0,m=d.length;f<m;f++){let h=d[f];c.search_attribute=h.attribute,c.search_value=h.search_value;let p=await Gu.getDataByValue(c,h.operation);if(l)for(let[E]of p)this.data[i].__mergedData[E]||(this.data[i].__mergedData[E]=[...n[i]],this._setMergedHashAttribute(i,E));else for(let[E,g]of p)this.data[i].__mergedData[E]?this._updateMergedAttribute(i,E,s.attribute,g[s.attribute]):(this.data[i].__mergedData[E]=[...n[i]],this._updateMergedAttribute(i,E,s.attribute,g[s.attribute]),this._setMergedHashAttribute(i,E))}}catch(d){throw ke.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),ke.error(d),new Error(si)}else try{c.search_attribute=s.attribute,c.search_value="*";let d=await Gu.getDataByValue(c);if(l)for(let[f]of d)this.data[i].__mergedData[f]||(this.data[i].__mergedData[f]=[...n[i]],this._setMergedHashAttribute(i,f));else for(let[f,m]of d)this.data[i].__mergedData[f]?this._updateMergedAttribute(i,f,s.attribute,m[s.attribute]):(this.data[i].__mergedData[f]=[...n[i]],this._updateMergedAttribute(i,f,s.attribute,m[s.attribute]),this._setMergedHashAttribute(i,f))}catch(d){throw ke.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),ke.error(d),new Error(si)}}}_isSimpleSelect(){let t=!0;return Object.keys(this.statement).length!==2||!this.statement.columns||!this.statement.from||this.statement.from.length!==1?(t=!1,t):(this.statement.columns.forEach(r=>{r instanceof Dn.yy.Column||(t=!1)}),t)}_updateOrderByToAliases(){this.statement.order.forEach(t=>{if(t.expression.aggregatorid){t.is_aggregator=!0;return}if(t.expression.value){t.is_ordinal=!0,this.has_ordinal=!0;return}else t.is_ordinal=!1;let r=this.statement.columns.filter(s=>{let i=s.aggregatorid?s.expression:s,a=s.aggregatorid?s.as_orig:i.as_orig;return t.expression.tableid?i.columnid_orig===t.expression.columnid_orig&&i.tableid_orig===t.expression.tableid_orig:i.columnid_orig===t.expression.columnid_orig||t.expression.columnid_orig===a});r[0]||r.push(this._findColumn(t.expression));let n=r[0];if(t.is_func=!!n.funcid,t.is_aggregator=!!n.aggregatorid,n.as)if(n.as&&!t.expression.tableid)t.expression.columnid=n.as,t.expression.columnid_orig=n.as_orig;else{let s=new Dn.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new Dn.yy.Column,t.expression),t.initial_select_column.as=`[${t.expression.columnid_orig}]`,t.expression.columnid=t.initial_select_column.as;return}if(!t.is_aggregator){let s=t.is_func?new Dn.yy.FuncValue:new Dn.yy.Column;t.initial_select_column=Object.assign(s,n)}})}_addNonAggregatorsToFetchColumns(){let r=this.statement.order.filter(n=>!n.is_aggregator&&!n.is_ordinal).map(n=>n.is_func?{columnid:n.initial_select_column.args.filter(i=>!!i.columnid_orig)[0].columnid_orig}:{columnid:n.expression.columnid_orig});this._addFetchColumns(r)}async _processJoins(){let t=[],r=[],n=this.statement.from[0],s=[n],i=["? "+(n.as?" AS "+n.as:n.tableid)];t.push(Object.values(this.data[`${n.databaseid_orig}_${n.as?n.as_orig:n.tableid_orig}`].__mergedData)),this.statement.joins&&this.statement.joins.forEach(h=>{h.joinmode&&h.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(h.table);let p=h.joinmode+" JOIN ? AS "+(h.as?h.as:h.table.tableid);h.on&&(p+=" ON "+h.on.toString()),i.push(p),t.push(Object.values(this.data[`${h.table.databaseid_orig}_${h.table.as?h.table.as_orig:h.table.tableid_orig}`].__mergedData))});let a=[],c={};s.forEach(h=>{let p=this.data[`${h.databaseid_orig}_${h.as?h.as_orig:h.tableid_orig}`].__hashName,E=h.as?h.as_orig:h.tableid_orig;a.push({key:`'${E}.${p}'`,schema:h.databaseid_orig,table:h.as?h.as_orig:h.tableid_orig,keys:new Set}),r.push(`${h.as?h.as:h.tableid}.\`${p}\` AS "${E}.${p}"`),c[h.as?h.as_orig:h.tableid_orig]=this.data[`${h.databaseid_orig}_${h.as?h.as_orig:h.tableid_orig}`].__mergedAttributes});let l=this.statement.where?"WHERE "+this.statement.where:"";l=l.replace(/NOT\(NULL\)/g,"NOT NULL");let u="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(u="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(h=>{h.is_func?r.push(h.initial_select_column.toString()):h.initial_select_column.tableid?r.push(`${h.initial_select_column.tableid}.${h.initial_select_column.columnid} AS ${h.expression.columnid}`):r.push(`${h.initial_select_column.columnid} AS ${h.expression.columnid}`)}));let d="",f="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(d=this.statement.limit?"LIMIT "+this.statement.limit:"",f=this.statement.offset?"OFFSET "+this.statement.offset:"");let m=[];try{let h=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${l} ${u} ${d} ${f}`,p=this._convertColumnsToIndexes(h,s);m=await Dn.promise(p,t),t=null}catch(h){throw ke.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),ke.error(h),new Error("There was a problem processing the data.")}if(m&&m.length>0){for(let h=0,p=m.length;h<p;h++){let E=m[h];a.forEach(g=>{E[g.key]!==null&&E[g.key]!==void 0&&g.keys.add(E[g.key])})}a.forEach(h=>{let p=Object.keys(this.data[`${h.schema}_${h.table}`].__mergedData),E=Vm.difference(p,[...h.keys].map(g=>g.toString()));for(let g=0,y=E.length;g<y;g++){let T=E[g];delete this.data[`${h.schema}_${h.table}`].__mergedData[T]}})}return{existing_attributes:c,joined_length:m?m.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new tg(this.columns);for(let{node:i}of s)if(i&&i.columnid){let a=this._findColumn(i);if(a){let c=a.table.as?a.table.as:a.table.tableid;(!t[c]||t[c].indexOf(a.attribute)<0)&&n.push(a)}}n=Vm.uniqBy(n,i=>[i.table.databaseid,i.table.as?i.table.as:i.table.tableid,i.attribute].join());try{await this._getData(n)}catch(i){throw ke.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),ke.error(i),new Error(si)}}async _getData(t){try{let r=t.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]?n[i].columns.push(s.attribute):n[i]={schema:s.table.databaseid,table:s.table.tableid,columns:[s.attribute]},n},{});for(let n in r){let s=r[n],i=this.data[n].__mergedData,a=[];for(let d in i)a.push(i[d][0]);this.data[n].__mergedAttributes.push(...s.columns);let c={schema:s.schema,table:s.table,hash_values:a,get_attributes:s.columns},l=await Gu.getDataByHash(c),u=s.columns.length;for(let d=0,f=a.length;d<f;d++){let m=a[d],h=l.get(m);for(let p=0;p<u;p++){let E=s.columns[p],g=h[E]===void 0?null:h[E];this.data[n].__mergedData[m].push(g)}}}}catch(r){throw ke.error("Error thrown from getDataByHash function in SQLSearch class method getData."),ke.error(r),r}}async _finalSQL(){let t=[],r=this.statement.from[0];t.push(Object.values(this.data[`${r.databaseid_orig}_${r.as?r.as_orig:r.tableid_orig}`].__mergedData)),r.as=r.as?r.as:r.tableid,r.databaseid="",r.tableid="?",this.statement.joins&&this.statement.joins.forEach(s=>{s.as=s.as?s.as:s.table.tableid,t.push(Object.values(this.data[`${s.table.databaseid_orig}_${s.table.as?s.table.as_orig:s.table.tableid_orig}`].__mergedData)),s.table.databaseid="",s.table.tableid="?"}),this.statement.order&&this.statement.order.forEach(s=>{if(s.is_ordinal)return;this.statement.columns.filter(a=>{let c=a.aggregatorid?a.expression:a,l=a.aggregatorid?a.as_orig:c.as_orig;return s.expression.tableid?c.columnid_orig===s.expression.columnid_orig&&c.tableid_orig===s.expression.tableid_orig:c.columnid_orig===s.expression.columnid_orig||s.expression.columnid_orig===l}).length===0&&(s.expression.columnid=s.initial_select_column.columnid)}),!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&this.statement.limit&&!this.statement.joins&&(delete this.statement.limit,delete this.statement.offset);let n;try{let s=this._buildSQL();ke.trace(`Final SQL: ${s}`),n=await Dn.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),ke.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw ke.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),ke.error(s),new Error("There was a problem running the generated sql.")}return n}_translateUndefinedValues(t){try{let r=[];for(let n of t){let s=Object.create(null);Object.keys(n).forEach(i=>{n[i]===void 0?s[i]=null:s[i]=n[i]}),r.push(s)}return r}catch(r){return ke.error(ore.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),ke.trace(r.stack),t}}_buildSQL(t=!0){let r=this.statement.toString();return r=r.replace(/NOT\(NULL\)/g,"NOT NULL"),this.statement.columns.forEach(n=>{if(n.funcid&&n.as){let s=n.toString().replace(" AS "+n.as,"");r=r.replace(n.toString(),s)}}),t===!0?this._convertColumnsToIndexes(r,this.tables):r}_convertColumnsToIndexes(t,r){let n=t,s={};r.forEach(i=>{i.databaseid_orig?s[`${i.databaseid_orig}_${i.as?i.as_orig:i.tableid_orig}`]=i.as?i.as:i.tableid:s[`${i.databaseid}_${i.as?i.as:i.tableid}`]=`\`${i.as?i.as:i.tableid}\``});for(let i in this.data)this.data[i].__mergedAttributes.forEach((a,c)=>{let l=s[i],u=new RegExp(`${l}.\`${a}\``,"g"),d=`${l}.[${c}]`;n=n.replace(u,d)});for(let i in this.data)this.data[i].__mergedAttributes.forEach((a,c)=>{let l=new RegExp(`\`${a}\``,"g"),u=`[${c}]`;n=n.replace(l,u)});return n}async _simpleSQLQuery(){let t=this.statement.columns.reduce((n,s)=>(s.as_orig&&s.as_orig!=s.columnid_orig?n[s.columnid_orig]=s.as_orig:n[s.columnid_orig]||(n[s.columnid_orig]=s.columnid_orig),n),{}),r=this.fetch_attributes.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]||(n[i]={}),n[i][t[s.attribute]]=null,n},{});for(let n of this.fetch_attributes){let s=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`,i={schema:n.table.databaseid,table:n.table.tableid,get_attributes:[n.attribute]};try{i.search_attribute=n.attribute,i.search_value="*";let a=await Gu.getDataByValue(i);for(let[c,l]of a)this.data[s].__mergedData[c]||(l[n.attribute]===void 0&&(l[n.attribute]=null),this.data[s].__mergedData[c]={...r[s]}),this.data[s].__mergedData[c][t[n.attribute]]=l[n.attribute]??null}catch(a){throw ke.error("There was an error when processing this SQL operation. Check your logs"),ke.error(a),new Error(si)}}return Object.values(Object.values(this.data)[0].__mergedData)}};fF.exports=pI});var on=M((oPe,hF)=>{"use strict";var cre=c0();hF.exports={searchByConditions:ure,searchByHash:dre,searchByValue:fre,search:mre};var _I=jn(),{transformReq:EI}=ie(),lre=mF();async function ure(e){return EI(e),_I.searchByConditions(e)}o(ure,"searchByConditions");async function dre(e){EI(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of _I.searchByHash(e))r&&t.push(r);return t}o(dre,"searchByHash");async function fre(e){EI(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of _I.searchByValue(e))t.push(r);return t}o(fre,"searchByValue");function mre(e,t){try{let r=new cre(e);r.validate(),new lre(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}o(mre,"search")});var Bi=M((cPe,gF)=>{"use strict";var Km=require("crypto"),hre=ce(),{CONFIG_PARAMS:pre}=(k(),v(K)),_F="aes-256-cbc",_re=32,Ere=16,gI=64,EF=32,gre=gI+EF,pF=new Map;gF.exports={encrypt:Sre,decrypt:Tre,createNatsTableStreamName:Rre};function Sre(e){let t=Km.randomBytes(_re),r=Km.randomBytes(Ere),n=Km.createCipheriv(_F,Buffer.from(t),r),s=n.update(e);s=Buffer.concat([s,n.final()]);let i=t.toString("hex"),a=r.toString("hex"),c=s.toString("hex");return i+a+c}o(Sre,"encrypt");function Tre(e){let t=e.substr(0,gI),r=e.substr(gI,EF),n=e.substr(gre,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),a=Km.createDecipheriv(_F,Buffer.from(t,"hex"),s),c=a.update(i);return c=Buffer.concat([c,a.final()]),c.toString()}o(Tre,"decrypt");function Rre(e,t){let r=hre.get(pre.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=pF.get(r);return n||(n=Km.createHash("md5").update(r).digest("hex"),pF.set(r,n)),n}o(Rre,"createNatsTableStreamName")});var La=M((dPe,yF)=>{"use strict";var uPe=on(),Ym=z(),{validateBySchema:SF}=at(),al=require("joi"),yre=Bi(),rg=ie(),{handleHDBError:ng,hdbErrors:Are,ClientError:TF}=_e(),{HDB_ERROR_MSGS:sg,HTTP_STATUS_CODES:SI}=Are,RF=ce();RF.initSync();var{getDatabases:TI}=(Le(),v(ft)),bre=require("fs-extra"),Ire=(k(),v(K));yF.exports={describeAll:Nre,describeTable:ig,describeSchema:wre};async function Nre(e={}){try{let t=rg.isEmptyOrZeroLength(e),r=!!e.bypass_auth,n,s;!t&&!r&&(n=e.hdb_user?.role?.permission,s=n?.super_user||n?.cluster_user);let i=TI(),a={},c={},l=[],u=e?.exact_count;for(let f in i){a[f]=!0,!t&&!s&&!r&&(c[f]=e.hdb_user?.role?.permission[f]?.describe);let m=i[f];for(let h in m)try{let p;if(t||s||r)p=await ig({schema:f,table:h,exactCount:u});else if(n&&n[f].describe&&n[f].tables[h].describe){let E=n[f].tables[h].attribute_permissions;p=await ig({schema:f,table:h,exactCount:u},E)}p&&l.push(p)}catch(p){Ym.error(p)}}let d={};for(let f in l)t||s||r?(d[l[f].schema]==null&&(d[l[f].schema]={}),d[l[f].schema][l[f].name]=l[f],a[l[f].schema]&&delete a[l[f].schema]):c[l[f].schema]&&(d[l[f].schema]==null&&(d[l[f].schema]={}),d[l[f].schema][l[f].name]=l[f],a[l[f].schema]&&delete a[l[f].schema]);for(let f in a)t||s||r?d[f]={}:c[f]&&(d[f]={});return d}catch(t){return Ym.error("Got an error in describeAll"),Ym.error(t),ng(new Error,sg.DESCRIBE_ALL_ERR)}}o(Nre,"describeAll");async function ig(e,t){rg.transformReq(e);let{schema:r,table:n}=e;r=r?.toString(),n=n?.toString();let s=t;e.hdb_user&&!e.hdb_user?.role?.permission?.super_user&&(s=e.hdb_user?.role?.permission[r]?.tables[n]?.attribute_permissions);let i=SF(e,al.object({database:al.string(),table:al.string().required(),exact_count:al.boolean().strict()}));if(i)throw new TF(i.message);let c=TI()[r];if(!c)throw ng(new Error,sg.SCHEMA_NOT_FOUND(e.schema),SI.NOT_FOUND);let l=c[n];if(!l)throw ng(new Error,sg.TABLE_NOT_FOUND(e.schema,e.table),SI.NOT_FOUND);function u(h){d.push({attribute:h.attribute,type:h.type,elements:h.elements?.type,indexed:h.indexed,is_primary_key:h.isPrimaryKey,assigned_created_time:h.assignCreatedTime,assigned_updated_time:h.assignUpdatedTime,nullable:h.nullable,properties:h.properties?h.properties.map(p=>({type:p.type,name:p.name})):void 0})}o(u,"pushAtt");let d=[];if(s){let h={};s.forEach(p=>{p.describe&&(h[p.attribute_name]=!0)}),l.attributes.forEach(p=>{h[p.name]&&u(p)})}else l.attributes?.forEach(h=>u(h));let f;try{f=(await bre.stat(l.primaryStore.env.path)).size}catch(h){Ym.warn("unable to get database size",h)}let m={schema:r,name:l.tableName,hash_attribute:l.attributes.find(h=>h.isPrimaryKey||h.is_hash_attribute)?.name,audit:l.audit,schema_defined:l.schemaDefined,attributes:d,db_size:f};l.replicate!==void 0&&(m.replicate=l.replicate),l.expirationMS!==void 0&&(m.expiration=l.expirationMS/1e3+"s"),l.sealed!==void 0&&(m.sealed=l.sealed),l.sources?.length>0&&(m.sources=l.sources.map(h=>h.name).filter(h=>h&&h!=="NATSReplicator"&&h!=="Replicator")),RF.get(Ire.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(m.clustering_stream_name=yre.createNatsTableStreamName(m.schema,m.name));try{let h=await l.getRecordCount({exactCount:!!e.exact_count});m.record_count=h.recordCount,m.table_size=l.getSize(),m.db_audit_size=l.getAuditSize(),m.estimated_record_range=h.estimatedRange;let p=l.auditStore;if(p)for(let E of p.getKeys({reverse:!0,limit:1}))m.last_updated_record=E[0];if(!m.last_updated_record&&l.indices.__updatedtime__)for(let E of l.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))m.last_updated_record=E}catch(h){Ym.warn(`unable to stat table dbi due to ${h}`)}return m}o(ig,"descTable");async function wre(e){rg.transformReq(e);let t=SF(e,al.object({database:al.string(),exact_count:al.boolean().strict()}));if(t)throw new TF(t.message);let r;e.hdb_user&&!e.hdb_user?.role?.permission?.super_user&&(r=e.hdb_user?.role?.permission[e.schema]);let n=e.schema.toString(),i=TI()[n];if(!i)throw ng(new Error,sg.SCHEMA_NOT_FOUND(e.schema),SI.NOT_FOUND);let a={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),rg.isEmpty(l)||l.describe){let u=await ig({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);u&&(a[u.name]=u)}}return a}o(wre,"describeSchema")});var Mn=M((mPe,NF)=>{"use strict";var ag=Ab(),$r=ie(),Ore=require("util"),cg=jn(),Cre=Ns(),AF=z(),{handleHDBError:cl,hdbErrors:Pre}=_e(),{HTTP_STATUS_CODES:ll}=Pre,Lre=Ore.promisify(Cre.getTableSchema),Dre="updated",bF="inserted",IF="upserted";NF.exports={insert:vre,update:Ure,upsert:xre,validation:Mre,flush:Bre};async function Mre(e){if($r.isEmpty(e))throw new Error("invalid update parameters defined.");if($r.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if($r.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await Lre(e.schema,e.table),r=ag(e);if(r)throw r;if(!Array.isArray(e.records))throw new Error("records must be an array");let n=t.hash_attribute,s=new Set,i={},a=!1;return e.operation==="update"&&(a=!0),e.records.forEach(c=>{if(a&&$r.isEmptyOrZeroLength(c[n]))throw AF.error("a valid hash attribute must be provided with update record:",c),new Error("a valid hash attribute must be provided with update record");if(!$r.isEmptyOrZeroLength(c[n])&&(c[n]==="null"||c[n]==="undefined"))throw AF.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[n]}" is not a valid hash attribute value`);!$r.isEmpty(c[n])&&c[n]!==""&&s.has($r.autoCast(c[n]))&&(c.skip=!0),s.add($r.autoCast(c[n]));for(let l in c)i[l]=1}),i[n]=1,{schema_table:t,hashes:Array.from(s),attributes:Object.keys(i)}}o(Mre,"validation");async function vre(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=ag(e);if(t)throw cl(new Error,t.message,ll.BAD_REQUEST);$r.transformReq(e);let r=$r.checkSchemaTableExist(e.schema,e.table);if(r)throw cl(new Error,r,ll.BAD_REQUEST);let n=await cg.createRecords(e);return og(bF,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}o(vre,"insertData");async function Ure(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=ag(e);if(t)throw cl(new Error,t.message,ll.BAD_REQUEST);$r.transformReq(e);let r=$r.checkSchemaTableExist(e.schema,e.table);if(r)throw cl(new Error,r,ll.BAD_REQUEST);let n=await cg.updateRecords(e);return $r.isEmpty(n.existing_rows)?og(Dre,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):og(n.update_action,[],e,n.hashes,void 0,n.txn_time)}o(Ure,"updateData");async function xre(e){if(e.operation!=="upsert")throw cl(new Error,"invalid operation, must be upsert",ll.INTERNAL_SERVER_ERROR);let t=ag(e);if(t)throw cl(new Error,t.message,ll.BAD_REQUEST);$r.transformReq(e);let r=$r.checkSchemaTableExist(e.schema,e.table);if(r)throw cl(new Error,r,ll.BAD_REQUEST);let n=await cg.upsertRecords(e);return og(IF,n.written_hashes,e,[],n.new_attributes,n.txn_time)}o(xre,"upsertData");function og(e,t,r,n,s,i){let a={message:`${e} ${t.length} of ${t.length+n.length} records`,new_attributes:s,txn_time:i};return e===bF?(a.inserted_hashes=t,a.skipped_hashes=n,a):e===IF?(a.upserted_hashes=t,a):(a.update_hashes=t,a.skipped_hashes=n,a)}o(og,"returnObject");function Bre(e){return $r.transformReq(e),cg.flush(e.schema,e.table)}o(Bre,"flush")});var yI=M((pPe,CF)=>{var Fre=at(),RI=require("joi"),{hdbTable:Hre,hdbDatabase:wF}=Mi(),OF={schema:wF,database:wF,table:Hre},kre={date:RI.date().iso().required()},Gre={timestamp:RI.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};CF.exports=function(e,t){let r=t==="timestamp"?{...OF,...Gre}:{...OF,...kre},n=RI.object(r);return Fre.validateBySchema(e,n)}});var DF=M((_Pe,LF)=>{var qre=at(),AI=require("joi"),{hdbTable:$re,hdbDatabase:PF}=Mi(),Vre=AI.object({schema:PF,database:PF,table:$re,hash_values:AI.array().required(),ids:AI.array()});LF.exports=function(e){return qre.validateBySchema(e,Vre)}});var wI=M((EPe,MF)=>{"use strict";var bI=class{static{o(this,"InsertObject")}constructor(t,r,n,s,i){this.operation=t,this.schema=r,this.table=n,this.hash_attribute=s,this.records=i}},II=class{static{o(this,"NoSQLSeachObject")}constructor(t,r,n,s,i,a){this.schema=t,this.table=r,this.search_attribute=n,this.hash_attribute=s,this.get_attributes=i,this.search_value=a}},NI=class{static{o(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};MF.exports={InsertObject:bI,NoSQLSeachObject:II,DeleteResponseObject:NI}});var fl=M((SPe,FF)=>{"use strict";var UF=yI(),Kre=DF(),ul=ie(),vF=require("moment"),xF=z(),{promisify:Yre,callbackify:Wre}=require("util"),dl=(k(),v(K)),zre=Ns(),OI=Yre(zre.getTableSchema),CI=jn(),{DeleteResponseObject:jre}=wI(),{handleHDBError:Da,hdbErrors:Qre}=_e(),{HDB_ERROR_MSGS:lg,HTTP_STATUS_CODES:Ma}=Qre,Jre="records successfully deleted",Xre=Wre(BF);FF.exports={delete:Xre,deleteRecord:BF,deleteFilesBefore:Zre,deleteAuditLogsBefore:ene};async function Zre(e){let t=UF(e,"date");if(t)throw Da(t,t.message,Ma.BAD_REQUEST,void 0,void 0,!0);if(ul.transformReq(e),!vF(e.date,vF.ISO_8601).isValid())throw Da(new Error,lg.INVALID_DATE,Ma.BAD_REQUEST,dl.LOG_LEVELS.ERROR,lg.INVALID_DATE,!0);let n=ul.checkSchemaTableExist(e.schema,e.table);if(n)throw Da(new Error,n,Ma.NOT_FOUND,dl.LOG_LEVELS.ERROR,n,!0);let s=await CI.deleteRecordsBefore(e);if(await OI(e.schema,e.table),xF.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}o(Zre,"deleteFilesBefore");async function ene(e){let t=UF(e,"timestamp");if(t)throw Da(t,t.message,Ma.BAD_REQUEST,void 0,void 0,!0);if(ul.transformReq(e),isNaN(e.timestamp))throw Da(new Error,lg.INVALID_VALUE("Timestamp"),Ma.BAD_REQUEST,dl.LOG_LEVELS.ERROR,lg.INVALID_VALUE("Timestamp"),!0);let r=ul.checkSchemaTableExist(e.schema,e.table);if(r)throw Da(new Error,r,Ma.NOT_FOUND,dl.LOG_LEVELS.ERROR,r,!0);let n=await CI.deleteAuditLogsBefore(e);return await OI(e.schema,e.table),xF.info(`Finished deleting audit logs before ${e.timestamp}`),n}o(ene,"deleteAuditLogsBefore");async function BF(e){e.ids&&(e.hash_values=e.ids);let t=Kre(e);if(t)throw Da(t,t.message,Ma.BAD_REQUEST,void 0,void 0,!0);ul.transformReq(e);let r=ul.checkSchemaTableExist(e.schema,e.table);if(r)throw Da(new Error,r,Ma.NOT_FOUND,dl.LOG_LEVELS.ERROR,r,!0);try{await OI(e.schema,e.table);let n=await CI.deleteRecords(e);return ul.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${Jre}`),n}catch(n){if(n.message===dl.SEARCH_NOT_FOUND_MESSAGE){let s=new jre;return s.message=dl.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}o(BF,"deleteRecord")});var ug={};Ce(ug,{HASH_FUNCTION:()=>Mr,hash:()=>DI,validate:()=>MI});function PI(e=zm){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ";return Array.from(Wm.randomBytes(e)).map(r=>t[r%t.length]).join("")}function DI(e,t=Mr[kF?.toUpperCase()]??Mr.SHA256){return LI[t](e)}function MI(e,t,r=Mr[kF?.toUpperCase()]??Mr.SHA256){return e?tne[r](e,t):!1}var Wm,qu,HF,kF,zm,GF,Mr,LI,tne,dg=fe(()=>{Wm=w(require("node:crypto")),qu=w(require("argon2")),HF=w(ce());k();kF=(0,HF.get)(U.AUTHENTICATION_HASHFUNCTION)?.toLowerCase(),zm=16,GF=9,Mr={MD5:"md5",SHA256:"sha256",ARGON2ID:"argon2id"};o(PI,"generateSalt");LI={[Mr.MD5]:(e,t=void 0)=>{t=t??PI(GF);let r=Wm.createHash(Mr.MD5).update(e+t).digest("hex");return t+r},[Mr.SHA256]:(e,t=void 0)=>{t=t??PI(zm);let r=Wm.createHash(Mr.SHA256).update(e+t).digest("hex");return t+r},[Mr.ARGON2ID]:async e=>{let t=PI(zm),r=await qu.hash(e,{type:qu.argon2id,salt:Buffer.from(t)});return t+r}},tne={[Mr.MD5]:(e,t)=>{let r=e.slice(0,GF);return e===LI[Mr.MD5](t,r)},[Mr.SHA256]:(e,t)=>{let r=e.slice(0,zm);return e===LI[Mr.SHA256](t,r)},[Mr.ARGON2ID]:async(e,t)=>await qu.verify(e.slice(zm),t)};o(DI,"hash");o(MI,"validate")});var $F=M((APe,qF)=>{var vI=at(),an={username:{presence:!0,exclusion:{within:["system"],message:"You cannot create tables within the system schema"}},password:{presence:!0},role:{presence:!0,format:"[\\w\\-\\_]+"},active:{presence:!0,inclusion:{within:[!0,!1],message:"must be a boolean"}}};function rne(e){return an.password.presence=!0,an.username.presence=!0,an.role.presence=!0,an.active.presence=!0,vI.validateObject(e,an)}o(rne,"addUserValidation");function nne(e){return an.password.presence=!1,an.username.presence=!0,an.role.presence=!1,an.active.presence=!1,vI.validateObject(e,an)}o(nne,"alterUserValidation");function sne(e){return an.password.presence=!1,an.username.presence=!0,an.role.presence=!1,an.active.presence=!1,vI.validateObject(e,an)}o(sne,"dropUserValidation");qF.exports={addUserValidation:rne,alterUserValidation:nne,dropUserValidation:sne}});var It=M((NPe,KF)=>{"use strict";var{platform:IPe}=require("os"),ine="nats-server.zip",UI="nats-server",one=process.platform==="win32"?`${UI}.exe`:UI,ane=/^[^\s.,*>]+$/,VF="__request__",cne=o(e=>`${e}.${VF}`,"REQUEST_SUBJECT"),lne={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},une={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},dne={HUB:"hub.pid",LEAF:"leaf.pid"},fne={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},mne={SUCCESS:"success",ERROR:"error"},hne={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},pne={TXN:"txn",MSGID:"msgid"},$u={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},_ne={[$u.ERR]:1,[$u.WRN]:2,[$u.INF]:3,[$u.DBG]:4,[$u.TRC]:5},Ene={debug:"-D",trace:"-DVV"};KF.exports={NATS_SERVER_ZIP:ine,NATS_SERVER_NAME:UI,NATS_BINARY_NAME:one,PID_FILES:dne,NATS_CONFIG_FILES:une,SERVER_SUFFIX:fne,NATS_TERM_CONSTRAINTS_RX:ane,REQUEST_SUFFIX:VF,UPDATE_REMOTE_RESPONSE_STATUSES:mne,CLUSTER_STATUS_STATUSES:hne,REQUEST_SUBJECT:cne,SUBJECT_PREFIXES:pne,MSG_HEADERS:lne,LOG_LEVELS:$u,LOG_LEVEL_FLAGS:Ene,LOG_LEVEL_HIERARCHY:_ne}});var Jn=M((OPe,vr)=>{"use strict";var zF="username is required",jF="nothing to update, must supply active, role or password to update",QF="password cannot be an empty string",JF="If role is specified, it cannot be empty.",XF="active must be true or false";vr.exports.addUser=Nne;vr.exports.alterUser=wne;vr.exports.dropUser=Cne;vr.exports.getSuperUser=vne;vr.exports.userInfo=Pne;vr.exports.listUsers=mg;vr.exports.listUsersExternal=Lne;vr.exports.setUsersWithRolesCache=ml;vr.exports.findAndValidateUser=VI;vr.exports.getClusterUser=Une;vr.exports.getUsersWithRolesCache=Mne;vr.exports.USERNAME_REQUIRED=zF;vr.exports.ALTERUSER_NOTHING_TO_UPDATE=jF;vr.exports.EMPTY_PASSWORD=QF;vr.exports.EMPTY_ROLE=JF;vr.exports.ACTIVE_BOOLEAN=XF;var ZF=Mn(),gne=fl(),jm=(dg(),v(ug)),eH=$F(),Qm=on(),kI=No(),Fi=ie(),tH=require("validate.js"),GI=z(),{promisify:Sne}=require("util"),qI=Bi(),BI=(k(),v(K)),YF=It(),Tne=yt(),Rne=ce(),yne=Ao(),{hdbErrors:Ane,ClientError:ii}=_e(),{HTTP_STATUS_CODES:Po,AUTHENTICATION_ERROR_MSGS:xI,HDB_ERROR_MSGS:Vu}=Ane,{UserEventMsg:$I}=ti(),FI=require("lodash"),{server:fg}=(Pr(),v(Ff)),bne=z();fg.getUser=(e,t)=>VI(e,t,t!=null);fg.authenticateUser=(e,t)=>VI(e,t);var rH={username:!0,active:!0,role:!0,password:!0},WF=new Map,Ine=Sne(gne.delete),HI=Rne.get(BI.CONFIG_PARAMS.AUTHENTICATION_HASHFUNCTION)??jm.HASH_FUNCTION.SHA256,Hi;async function Nne(e){let t=tH.cleanAttributes(e,rH),r=eH.addUserValidation(t);if(r)throw new ii(r.message);let n=await Qm.searchByValue({schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["id","permission","role"]});if(!n||n.length<1)throw new ii(Vu.ROLE_NAME_NOT_FOUND(t.role),Po.NOT_FOUND);if(n.length>1)throw new ii(Vu.DUP_ROLES_FOUND(t.role),Po.CONFLICT);n[0].permission.cluster_user===!0&&(t.hash=qI.encrypt(t.password)),t.password=await jm.hash(t.password,HI),t.hash_function=HI,t.role=n[0].id;let s=await ZF.insert({operation:"insert",schema:"system",table:"hdb_user",records:[t]});if(GI.debug(s),await ml(),s.skipped_hashes.length===1)throw new ii(Vu.USER_ALREADY_EXISTS(t.username),Po.CONFLICT);return kI.signalUserChange(new $I(process.pid)),`${t.username} successfully added`}o(Nne,"addUser");async function wne(e){let t=tH.cleanAttributes(e,rH);if(Fi.isEmptyOrZeroLength(t.username))throw new Error(zF);if(Fi.isEmptyOrZeroLength(t.password)&&Fi.isEmptyOrZeroLength(t.role)&&Fi.isEmptyOrZeroLength(t.active))throw new Error(jF);if(!Fi.isEmpty(t.password)&&Fi.isEmptyOrZeroLength(t.password.trim()))throw new Error(QF);if(!Fi.isEmpty(t.active)&&!Fi.isBoolean(t.active))throw new Error(XF);if(!Fi.isEmpty(t.password)&&!Fi.isEmptyOrZeroLength(t.password.trim())&&(One(t.username)&&(t.hash=qI.encrypt(t.password)),t.password=await jm.hash(t.password,HI)),t.role==="")throw new Error(JF);if(t.role){let n=await Qm.searchByValue({schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]});if(!n||n.length===0)throw new ii(Vu.ALTER_USER_ROLE_NOT_FOUND(t.role),Po.NOT_FOUND);if(n.length>1)throw new ii(Vu.DUP_ROLES_FOUND(t.role),Po.CONFLICT);t.role=n[0].id}let r=await ZF.update({operation:"update",schema:"system",table:"hdb_user",records:[t]});return await ml(),kI.signalUserChange(new $I(process.pid)),r}o(wne,"alterUser");function One(e){let t=!1,r=Hi.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}o(One,"isClusterUser");async function Cne(e){let t=eH.dropUserValidation(e);if(t)throw new ii(t.message);if(Hi.get(e.username)===void 0)throw new ii(Vu.USER_NOT_EXIST(e.username),Po.NOT_FOUND);let r=await Ine({table:"hdb_user",schema:"system",hash_values:[e.username]});return GI.debug(r),await ml(),kI.signalUserChange(new $I(process.pid)),`${e.username} successfully deleted`}o(Cne,"dropUser");async function Pne(e){let t={};if(!e||!e.hdb_user)return"There was no user info in the body";t=FI.cloneDeep(e.hdb_user);let r=await Qm.searchByHash({schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]});return t.role=r[0],delete t.password,delete t.refresh_token,delete t.hash,delete t.hash_function,t}o(Pne,"userInfo");async function Lne(){let e=await mg();return e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token,delete t.hash_function}),[...e.values()]}o(Lne,"listUsersExternal");async function mg(){let e=await Qm.searchByValue({schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]}),t={};for(let s of e)t[s.id]=FI.cloneDeep(s);if(Object.keys(t).length===0)return null;let r=await Qm.searchByValue({schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]}),n=new Map;for(let s of r)s=FI.cloneDeep(s),s.role=t[s.role],Dne(s.role),n.set(s.username,s);return n}o(mg,"listUsers");function Dne(e){if(!e){GI.error("invalid user role found.");return}e.permission.system||(e.permission.system={}),e.permission.system.tables||(e.permission.system.tables={});for(let t of Object.keys(yne)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}o(Dne,"appendSystemTablesToRole");async function ml(e=void 0){e?Hi=e:Hi=await mg()}o(ml,"setUsersWithRolesCache");async function Mne(){return Hi||await ml(),Hi}o(Mne,"getUsersWithRolesCache");async function VI(e,t,r=!0){Hi||await ml();let n=Hi.get(e);if(!n){if(!r)return{username:e};throw new ii(xI.GENERIC_AUTH_FAIL,Po.UNAUTHORIZED)}if(n&&!n.active)throw new ii(xI.USER_INACTIVE,Po.UNAUTHORIZED);let s={active:n.active,username:n.username};if(n.refresh_token&&(s.refresh_token=n.refresh_token),n.role&&(s.role=n.role),r===!0){if(WF.get(t)===n.password)return s;{let i=jm.validate(n.password,t,n.hash_function||jm.HASH_FUNCTION.MD5);if(i?.then&&(i=await i),i===!0)WF.set(t,n.password);else throw new ii(xI.GENERIC_AUTH_FAIL,Po.UNAUTHORIZED)}}return s}o(VI,"findAndValidateUser");async function vne(){Hi||await ml();for(let[,e]of Hi)if(e.role.role==="super_user")return e}o(vne,"getSuperUser");async function Une(){let e=await mg(),t=Tne.getConfigFromFile(BI.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!(r==null||r?.role?.role!==BI.ROLE_TYPES_ENUM.CLUSTER_USER))return r.decrypt_hash=qI.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+YF.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+YF.SERVER_SUFFIX.ADMIN,r}o(Une,"getClusterUser");var nH=[];fg.invalidateUser=function(e){for(let t of nH)try{t(e)}catch(r){bne.error("Error invalidating user",r)}};fg.onInvalidatedUser=function(e){nH.push(e)}});var Xm=M((DPe,aH)=>{"use strict";var hl=z(),Xn=(k(),v(K)),xne=YU(),PPe=Ns(),LPe=La(),Bne=Jn(),{validateEvent:sH}=ti(),Jm=jn(),Fne=require("process"),{resetDatabases:Hne}=(Le(),v(ft)),kne={[Xn.ITC_EVENT_TYPES.SCHEMA]:Gne,[Xn.ITC_EVENT_TYPES.USER]:oH};async function Gne(e){let t=sH(e);if(t){hl.error(t);return}hl.trace("ITC schemaHandler received schema event:",e),await xne(e.message),await qne(e.message)}o(Gne,"schemaHandler");async function qne(e){try{Jm.resetReadTxn(Xn.SYSTEM_SCHEMA_NAME,Xn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),Jm.resetReadTxn(Xn.SYSTEM_SCHEMA_NAME,Xn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),Jm.resetReadTxn(Xn.SYSTEM_SCHEMA_NAME,Xn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=Hne();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){hl.error(t)}}o(qne,"syncSchemaMetadata");var iH=[];async function oH(e){try{try{Jm.resetReadTxn(Xn.SYSTEM_SCHEMA_NAME,Xn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),Jm.resetReadTxn(Xn.SYSTEM_SCHEMA_NAME,Xn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){hl.warn(r)}let t=sH(e);if(t){hl.error(t);return}hl.trace(`ITC userHandler ${Xn.HDB_ITC_CLIENT_PREFIX}${Fne.pid} received user event:`,e),await Bne.setUsersWithRolesCache();for(let r of iH)r()}catch(t){hl.error(t)}}o(oH,"userHandler");oH.addListener=function(e){iH.push(e)};aH.exports=kne});var ti=M((FPe,lH)=>{"use strict";var vPe=z(),KI=ie(),$ne=(k(),v(K)),{ITC_ERRORS:Zm}=tn(),{parentPort:UPe,threadId:Vne,isMainThread:Kne,workerData:xPe}=require("worker_threads"),{onMessageFromWorkers:Yne,broadcast:BPe,broadcastWithAcknowledgement:Wne}=st();lH.exports={sendItcEvent:zne,validateEvent:cH,SchemaEventMsg:jne,UserEventMsg:Qne};var hg;Yne(async(e,t)=>{hg=hg||Xm(),cH(e),hg[e.type]&&await hg[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function zne(e){return!Kne&&e.message&&(e.message.originator=Vne),Wne(e)}o(zne,"sendItcEvent");function cH(e){if(typeof e!="object")return Zm.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||KI.isEmpty(e.type))return Zm.MISSING_TYPE;if(!e.hasOwnProperty("message")||KI.isEmpty(e.message))return Zm.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||KI.isEmpty(e.message.originator))return Zm.MISSING_ORIGIN;if($ne.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return Zm.INVALID_EVENT(e.type)}o(cH,"validateEvent");function jne(e,t,r,n=void 0,s=void 0){this.originator=e,this.operation=t,this.schema=r,this.table=n,this.attribute=s}o(jne,"SchemaEventMsg");function Qne(e){this.originator=e}o(Qne,"UserEventMsg")});var No=M((GPe,mH)=>{"use strict";var uH=(k(),v(K)),kPe=ie(),pg=z(),dH=OU(),Ku,{sendItcEvent:fH}=ti();function Jne(e){try{pg.info("signalSchemaChange called with message:",e),Ku=Ku||Xm();let t=new dH(uH.ITC_EVENT_TYPES.SCHEMA,e);return Ku.schema(t),fH(t)}catch(t){pg.error(t)}}o(Jne,"signalSchemaChange");function Xne(e){try{pg.trace("signalUserChange called with message:",e),Ku=Ku||Xm();let t=new dH(uH.ITC_EVENT_TYPES.USER,e);return Ku.user(t),fH(t)}catch(t){pg.error(t)}}o(Xne,"signalUserChange");mH.exports={signalSchemaChange:Jne,signalUserChange:Xne}});function _g(){return YI||(YI=et({table:"hdb_analytics_hostname",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"hostname"}]})),YI}function ese(e){return e=e.replace(Zne,t=>{let[r,n,s,i]=t.split(".").map(a=>parseInt(a));return(r<<8|n).toString(16)+":"+(s<<8|i).toString(16)}),e=e.replace("::",":".repeat(10-e.split(":").length)),e.toLowerCase().split(":").map(t=>t.padStart(4,"0")).join(":")}function tse(e){if(e.length!==4)throw new Error(`nodeHash must be exactly 4 bytes (32 bits); got ${e.length} bytes`);return e[0]<<24|e[1]<<16|e[2]<<8|e[3]}function zI(e){let t=hH.default.createHash("shake128",{outputLength:4}),r;return(0,pH.isIPv6)(e)?r=ese(e):r=e.toLowerCase(),tse(Uint8Array.from(t.update(r).digest()))}var hH,pH,WI,YI,Zne,jI=fe(()=>{Le();hH=w(require("crypto")),pH=require("node:net"),WI=new Map;o(_g,"getAnalyticsHostnameTable");Zne=/(\d{1,3}\.){3}\d{1,3}$/;o(ese,"normalizeIPv6");o(tse,"nodeHashToNumber");o(zI,"stableNodeId")});var Lo,QI=fe(()=>{Lo={TABLE_SIZE:"table-size",DATABASE_SIZE:"database-size",STORAGE_VOLUME:"storage-volume",MAIN_THREAD_UTILIZATION:"main-thread-utilization",RESOURCE_USAGE:"resource-usage",UTILIZATION:"utilization"}});var Rg={};Ce(Rg,{addAnalyticsListener:()=>rh,calculateCPUUtilization:()=>DH,diffResourceUsage:()=>MH,recordAction:()=>gt,recordActionBinary:()=>Kr,recordHostname:()=>ZI,setAnalyticsEnabled:()=>rse});function rse(e){wH=e}function nse(e,t){if(typeof e=="number"){let r=t.values,n=r.index++;if(n>=r.length){let s=r;t.values=r=new Float32Array(n*2),r.set(s),r.index=n+1}r[n]=e,t.total+=e}else if(typeof e=="boolean")e&&t.total++,t.count++;else if(typeof e=="function")t.count++;else throw new TypeError("Invalid metric value type "+typeof e)}function sse(e,t,r,n,s,i){let a={};if(typeof t=="number")a.total=t,a.values=new Float32Array(4),a.values.index=1,a.values[0]=t,a.total=t;else if(typeof t=="boolean")a.total=t?1:0,a.count=1;else if(typeof t=="function")a.count=1,a.callback=t;else throw new TypeError("Invalid metric value type "+typeof t);a.description={metric:r,path:n,method:s,type:i},Sg.set(e,a)}function gt(e,t,r,n,s){if(!wH)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let a=Sg.get(i);a?nse(e,a):sse(i,e,t,r,n,s),gg||ise()}function Kr(e,t,r,n,s){gt(!!e,t,r,n,s)}function rh(e){PH.push(e)}function ise(){gg=performance.now(),setTimeout(async()=>{let e=performance.now()-gg;gg=0;let t=[],r={time:Date.now(),period:e,threadId:pl.threadId,metrics:t};for(let[s,i]of Sg){if(i.values){let a=i.values.subarray(0,i.values.index);a.sort();let c=a.length,l=0,u=[],d;for(let f of LH){let m=Math.floor(c*f),h=a[m-1];if(m>l){let p=m-l;if(h===d){let E=u[u.length-1];typeof E=="number"?u[u.length-1]={value:E,count:1+p}:E.count+=p}else u.push(p>1?{value:h,count:p}:h),d=h;l=m}}t.push(Object.assign(i.description,{mean:i.total/c,distribution:u,count:c}))}else i.callback?t.push(Object.assign(i.description,i.callback(i))):t.push(Object.assign(i.description,{total:i.total,count:i.count}));await vH()}let n=process.memoryUsage();t.push({metric:"memory",threadId:pl.threadId,byThread:!0,...n});for(let s of PH)s(t);Sg=new Map,pl.parentPort?pl.parentPort.postMessage({type:CH,report:r}):BH({report:r})},OH).unref()}async function ZI(){let e=ve.hostname;Vr.trace?.("recordHostname server.hostname:",e);let t=zI(e);Vr.trace?.("recordHostname nodeId:",t);let r=_g();if(!await r.get(t)){let s={id:t,hostname:e};Vr.trace?.(`recordHostname storing hostname: ${JSON.stringify(s)}`),r.put(s.id,s)}}function Yu(e,t){let r=ve.hostname,n=WI.get(r);n?Vr.trace?.("storeMetric cached nodeId:",n):(n=zI(r),Vr.trace?.("storeMetric new nodeId:",n),WI.set(r,n));let s={id:[(0,XI.getNextMonotonicTime)(),n],...t};Vr.trace?.(`storing metric ${JSON.stringify(s)}`),e.put(s.id,s)}function DH(e,t){let r=e.userCPUTime+e.systemCPUTime;return Vr.trace?.(`calculateCPUUtilization cpuTime: ${r} period: ${t}`),Math.round(r/t*100)/100}function MH(e,t){return{userCPUTime:t.userCPUTime-(e?.userCPUTime??0),systemCPUTime:t.systemCPUTime-(e?.systemCPUTime??0),minorPageFault:t.minorPageFault-(e?.minorPageFault??0),majorPageFault:t.majorPageFault-(e?.majorPageFault??0),fsRead:t.fsRead-(e?.fsRead??0),fsWrite:t.fsWrite-(e?.fsWrite??0),voluntaryContextSwitches:t.voluntaryContextSwitches-(e?.voluntaryContextSwitches??0),involuntaryContextSwitches:t.involuntaryContextSwitches-(e?.involuntaryContextSwitches??0)}}function ose(e,t,r){let n=0;for(let[s,i]of Object.entries(r)){let a=`${t}.${s}`,c=i.getSize(),l={metric:Lo.TABLE_SIZE,database:t,table:s,size:c};Vr.trace?.(`table ${a} size metric: ${JSON.stringify(l)}`),Yu(e,l),n+=c}return n}function _H(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s?.getAuditSize();if(!i)return;let a=NH.statSync(s.primaryStore.env.path).size,c=ose(e,r,n),l=a-c,u={metric:Lo.DATABASE_SIZE,database:r,size:a,used:c,free:l,audit:i};Yu(e,u),Vr.trace?.(`database ${r} size metric: ${JSON.stringify(u)}`)}catch(s){Vr.warn?.("Error getting DB size metrics",s)}}function EH(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s?.getStorageStats();if(!i)return;let a={metric:Lo.STORAGE_VOLUME,database:r,...i};Yu(e,a),Vr.trace?.(`db ${r} storage volume metrics: ${JSON.stringify(a)}`)}catch(s){Vr.warn?.("Error getting DB volume metrics",s)}}async function ase(e,t=6e4){let r=eN(),n=UH(),s=new Promise(R=>{let I=performance.now();setImmediate(()=>{let P=performance.now();P-I>5e3&&Vr.warn?.("Unusually high event queue latency on the main thread of "+Math.round(P-I)+"ms"),I=performance.now()}),n.primaryStore.prefetch([1],()=>{let P=performance.now();P-I>5e3&&Vr.warn?.("Unusually high task queue latency on the main thread of "+Math.round(P-I)+"ms"),R(P-I)})}),i;for(let R of n.primaryStore.getRange({start:1/0,end:!1,reverse:!0}))if(R.value?.time){i=R.value.time;break}if(Date.now()-t<i)return;let a,c=new Map,l=new Map,u=[],d;for(let{key:R,value:I}of r.primaryStore.getRange({start:i||!1,exclusiveStart:!0,end:1/0})){if(!I)continue;if(a){if(R>a+t)break}else a=R;d=R;let{metrics:P,threadId:Y}=I;for(let te of P||[]){let{path:x,method:$,type:j,metric:V,count:le,total:re,distribution:se,threads:Ee,...Ne}=te;le||(le=1);let Fe=V+(x?"-"+x:"");$!==void 0&&(Fe+="-"+$),j!==void 0&&(Fe+="-"+j);let He=c.get(Fe);if(He){if(He.threads){let pt=He.threads[Y];if(pt)He=pt;else{He.threads[Y]={...Ne};continue}}He.count||(He.count=1);let Er=He.count;for(let pt in Ne){let gr=Ne[pt];typeof gr=="number"&&(He[pt]=(He[pt]*Er+gr*le)/(Er+le))}He.count+=le,re>=0&&(He.total+=re,He.ratio=He.total/He.count)}else He={period:t,...te},delete He.distribution,c.set(Fe,He),He.byThread&&(He.threads=[],He.threads[Y]={...Ne},u.push(He));if(se){se=se.map(pt=>typeof pt=="number"?{value:pt,count:1}:pt);let Er=l.get(Fe);Er?Er.push(...se):l.set(Fe,se)}}await vH()}for(let R of u){let{path:I,method:P,type:Y,metric:te,count:x,total:$,distribution:j,threads:V,...le}=R;V=V.filter(re=>re);for(let re in le){if(typeof R[re]!="number")continue;let se=0;for(let Ee of V){let Ne=Ee[re];typeof Ne=="number"&&(se+=Ne)}R[re]=se}R.count=V.length,delete R.threads,delete R.byThread}for(let[R,I]of l){let P=c.get(R);I.sort((pt,gr)=>pt.value>gr.value?1:-1);let Y=P.count-1,te=[],x=0,$=0,j;for(let pt of LH){let gr=Y*pt;for(;x<gr;)j=I[$++],x+=j.count,$===1&&x--;let wr=I[$>1?$-2:0];j||(j=I[0]),te.push(j.value-(j.value-wr.value)*(x-gr)/j.count)}let[V,le,re,se,Ee,Ne,Fe,He,Er]=te;Object.assign(P,{p1:V,p10:le,p25:re,median:se,p75:Ee,p90:Ne,p95:Fe,p99:He,p999:Er})}let f;for(let[,R]of c)R.time=d,Yu(n,R),f=!0;let m=Date.now(),{idle:h,active:p}=performance.eventLoopUtilization();if(f||p*10>h){let R={metric:Lo.MAIN_THREAD_UTILIZATION,idle:h-gH,active:p-SH,taskQueueLatency:await s,time:m,...process.memoryUsage()};Yu(n,R)}gH=h,SH=p;let E=process.resourceUsage();E.time=m,E.userCPUTime=E.userCPUTime/1e3,E.systemCPUTime=E.systemCPUTime/1e3,Vr.trace?.(`process.resourceUsage: ${JSON.stringify(E)}`);let g=MH(Eg,E);Vr.trace?.(`diffed resourceUsage: ${JSON.stringify(g)}`),g.time=m,g.period=Eg.time?m-Eg.time:t,g.cpuUtilization=DH(g,g.period);let y={metric:Lo.RESOURCE_USAGE,...g};Yu(n,y),Eg=E;let T=it();_H(n,T),_H(n,{system:T.system}),EH(n,T),EH(n,{system:T.system})}async function TH(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function eN(){return RH||(RH=et({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function UH(){return yH||(yH=et({table:"hdb_analytics",database:"system",audit:!0,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function use(){xH=!0;let e=(0,th.get)(U.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await ase(OH,e),await TH(eN(),cse),await TH(UH(),lse)},Math.min(e/2,2147483647)).unref()}function BH(e,t){let r=e.report;r.threadId=t?.threadId||pl.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(AH+=n.mean*n.count);r.totalBytesProcessed=AH,t&&(r.metrics.push({metric:Lo.UTILIZATION,...t.performance.eventLoopUtilization(bH.get(t))}),bH.set(t,t.performance.eventLoopUtilization())),r.id=(0,XI.getNextMonotonicTime)(),eN().primaryStore.put(r.id,r),xH||use(),dse&&(FH=mse(r))}async function mse(e){if(await FH,!va){let r=(0,eh.dirname)((0,Tg.getLogFilePath)());try{va=await(0,JI.open)((0,eh.join)(r,"analytics.log"),"r+")}catch{va=await(0,JI.open)((0,eh.join)(r,"analytics.log"),"w+")}}let t=(await va.stat()).size;if(t>fse){let r=Buffer.alloc(t);await va.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await va.write(r,{position:0}),await va.truncate(r.length),t=r.length}await va.write(JSON.stringify(e)+`
|
|
13
|
+
`},"serialize"),compressible:!1,q:.8});nn.set("application/x-www-form-urlencoded",{deserialize(e){let t=Buffer.isBuffer(e)?e.toString("utf8"):e,r={};for(let[n,s]of new URLSearchParams(t))if(r.hasOwnProperty(n)){let i=r[n];Array.isArray(i)?i.push(s):r.key=[i,s]}else r[n]=s;return r},serialize(e){let t=new URLSearchParams;for(let r in e)t.set(r,e);return t.toString()}});wv={type:"application/json",serializeStream:Zf,serialize:em,deserialize:QZ,q:.5};nn.set("*/*",wv);nn.set("",wv);o(QZ,"tryJSONParse");o(rm,"registerContentHandlers");JZ=(0,Iv.default)(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:a,type:c}=j_(n.raw);s.type(c),s.serializer(function(l){let u;if(typeof l=="object"&&l&&(l[Symbol.iterator]||l[Symbol.asyncIterator])&&a.serializeStream){if(l.mapError){let d=l.getColumns;l=l.mapError(f=>(f.toJSON=()=>({error:f.name,message:f.message,...f.partialObject}),f)),l.getColumns=d}u=a.serializeStream}else u=a.serialize;return u(l,{headers:{set:o((d,f)=>{s.header(d,f)},"set")}})})}),r()},{name:"content-type-negotiation"});o(j_,"findBestSerializer");Tv=uA.default.get(U.HTTP_COMPRESSIONTHRESHOLD);o(nm,"serialize");o(Sa,"serializeMessage");o(hA,"asyncSerialization");o(pA,"hasAsyncSerialization");o(XZ,"streamToBuffer");ZZ=["ascii","utf8","utf-8","utf16le","utf-16le","ucs2","ucs-2","base64","base64url","latin1","binary","hex"];o(e6,"isBufferEncoding");o(t6,"parseContentType");o(_o,"getDeserializer");o(r6,"deserializerUnknownType");o(n6,"transformIterable");o(z_,"toCsvStream")});var TA={};Ce(TA,{Blob:()=>Ss,blobsWereEncoded:()=>Gc,databasePaths:()=>EA,decodeBlobsWithWrites:()=>sE,decodeFromDatabase:()=>qc,decodeWithBlobCallback:()=>iE,deleteBlob:()=>tE,deleteBlobsInObject:()=>Ta,deleteRootBlobPathsForDB:()=>SA,encodeBlobsAsBuffers:()=>m6,encodeBlobsWithFilePath:()=>nE,findBlobsInObject:()=>gu,getFileId:()=>rE,getFilePathForBlob:()=>Fv,getRootBlobPathsForDB:()=>am,setDeletionDelay:()=>a6});function Uv(){}function tE(e){let t=Fv(e);t&&setTimeout(()=>{(0,Ze.unlink)(t,r=>{r&&go.default.debug?.("Error trying to remove blob file",r)})},xv)}function a6(e){xv=e}function Bv(e){let t=bn.get(e);if(!t)t={storageIndex:0,fileId:null,store:In},bn.set(e,t);else{if(t.saving)return t;t.store=In}return l6(t),t.source?_A(e,t.source,t):t.contentBuffer?c6(e,t):_A(e,im.Readable.from(e.stream()),t),t}function _A(e,t,r){let{filePath:n,fileId:s,store:i,compress:a,flush:c}=r;return r.saving=new Promise((l,u)=>{let d=s+":blob";if(!i.attemptLock(d,0))throw new Error(`Unable to get lock for blob file ${s}`);let f=(0,Ze.createWriteStream)(n,{autoClose:!1,flags:"w"});if(t.errored){let g=Buffer.from(t.errored.toString());f.end(Buffer.concat([p(BigInt(g.length)+0xff000000000000n),g]));return}let m=!1;e.size!==void 0&&(f.write(p(e.size)),m=!0);let h;a?(m||f.write(i6),h=(0,Z_.createDeflate)(),t.pipe(h).pipe(f)):(m||f.write(s6),t.pipe(f)),t.on("error",E);function p(g){let y=BigInt(g),T=new Uint8Array(Rr),R=new DataView(T.buffer);return y|=BigInt(a?gA:vv)<<48n,R.setBigInt64(0,y),T}o(p,"createHeader");function E(g){i.unlock(d,0);let y=f.fd;g?(y&&(0,Ze.close)(y),u(g)):c?(0,Ze.fdatasync)(y,T=>{T&&u(T),l(),(0,Ze.close)(y)}):(l(),(0,Ze.close)(y))}o(E,"finished"),f.on("error",E).on("finish",()=>{if(m)E();else{let g=h?h.bytesWritten:f.bytesWritten-Rr;e.size=g,(0,Ze.write)(f.fd,p(g),0,Rr,0,E)}})}),e}function rE(e){return bn.get(e)?.fileId}function Fv(e){let t=bn.get(e);return t?.fileId&&om(t)}function am(e){if(!e)throw new Error("No store specified, can not determine blob storage path");let t=EA.get(e);if(!t){if(!e.databaseName)return go.default.warn?.("No database name specified, can not determine blob storage path"),[];let r=(0,eE.get)(U.STORAGE_BLOBPATHS);r?t=r.map(n=>(0,To.join)(n,e.databaseName)):t=[(0,To.join)((0,eE.getHdbBasePath)(),"blobs",e.databaseName)],EA.set(e,t)}return t}async function SA(e){let t=am(e);t&&await Promise.all(t.map(r=>Hv(r)))}async function Hv(e){if((0,Ze.existsSync)(e)){for(let t of await(0,Qs.readdir)(e,{withFileTypes:!0}))if(t.isDirectory())await Hv((0,To.join)(e,t.name));else try{await(0,Qs.unlink)((0,To.join)(e,t.name))}catch(r){go.default.warn?.("Error deleting file",r)}try{await(0,Qs.rmdir)(e)}catch(t){go.default.warn?.("Error deleting directory",t)}}}function om({storageIndex:e,fileId:t,store:r}){let n=am(r);return(0,To.join)(n[e],t.slice(-9,-6)||"0",t.slice(-6,-3)||"0",t.length<=9?t.slice(-3):t.slice(0,-9)+t.slice(-3))}function c6(e,t){let r=t.contentBuffer,n=r.length;if(!(n<Mv))return e.size=n,_A(e,im.Readable.from([r]),t)}function l6(e){let t=am(e.store),r=u6(),n=t?.length>1?d6(t,r):0,s=r.toString(16);e.storageIndex=n,e.fileId=s;let i=om(e),a=(0,To.dirname)(i);(0,Ze.existsSync)(a)||(0,Dv.ensureDirSync)(a),e.filePath=i}function u6(){let e=Lv.get(In);if(!e){let t=0,r=am(In);for(let n of r){let s=0;for(let i=0;i<3;i++){s=s*4096;let a=0;if((0,Ze.existsSync)(n))for(let c of(0,Ze.readdirSync)(n)){let l=parseInt(c,16);i===2&&c.length>3&&(l=parseInt(c.slice(-3),16),l+=parseInt(c.slice(0,-3),16)*68719476736),l>a&&(a=l)}s+=a,n=(0,To.join)(n,a.toString(16))}t=Math.max(t,s)}e=new BigInt64Array([BigInt(t)+1n]),e=new BigInt64Array(In.getUserSharedBuffer("blob-file-id",e.buffer)),Lv.set(In,e)}return Number(Atomics.add(e,0,1n))}function d6(e,t){let r=Date.now();if(!e.frequencyTable){e.lastUpdated=0;let s=new Array(X_);for(let i=0;i<s.length;i++)s[i]=i%e.length;e.frequencyTable=s}return(e.lastUpdated??0)+6e4<r&&(e.lastUpdated=r,f6(e)),e.frequencyTable[t%X_]}async function f6(e){if(!Qs.statfs)return;let t=await Promise.all(e.map(async(s,i)=>{let a=await(0,Qs.statfs)(s),c=a.bavail*a.bsize;return Math.pow(c,.8)})),r=new Array(X_),n=t.map(s=>1/s);for(let s=0;s<X_;s++){let i=1/0,a=0;for(let c=0;c<n.length;c++)n[c]<i&&(a=c,i=n[c]);n[a]+=1/t[a],r[s]=a}e.frequencyTable=r}function nE(e,t,r){Eu=t,In=r,Gc=!1;try{return e()}finally{Eu=void 0,In=void 0}}function m6(e){Gr=[];let t;try{t=e()}catch(n){throw Gr=void 0,n}let r=Gr.length<2?Gr[0]:Promise.all(Gr);return Gr=void 0,r?r.then(()=>e()):t}function sE(e,t){try{Gr=[],kc=t,e()}catch(n){throw kc=void 0,Gr=void 0,n}kc=void 0;let r=Gr.length<2?Gr[0]:Promise.all(Gr);return Gr=void 0,r}function iE(e,t,r){In=r;try{return kc=t,e()}finally{kc=void 0}}function qc(e,t){return In=t,e()}function Ta(e){gu(e,t=>{tE(t)})}function gu(e,t){if(e instanceof Ss)t(e);else if(Array.isArray(e))for(let r of e)typeof r=="object"&&r&&gu(r,t);else if(e&&typeof e=="object"&&!e[Symbol.iterator])for(let r in e){let n=e[r];typeof n=="object"&&n&&gu(e[r],t)}}function h6(){return class{static{o(this,"Blob")}content;constructor(t){this.content=t[0]}stream(){return new ReadableStream({start(t){t.enqueue(this.content),t.close()}})}text(){return Promise.resolve(this.content.toString())}arrayBuffer(){return Promise.resolve(this.content.buffer)}get size(){return this.content.length}slice(){throw new Error("Not implemented")}bytes(){return Promise.resolve(this.content)}get type(){return""}}}var So,Qs,Ze,Z_,im,Dv,eE,To,go,Mv,Rr,vv,gA,Cv,s6,i6,Pv,bn,kc,Ss,Eu,Gr,In,Gc,sm,Q_,o6,J_,xv,EA,Lv,X_,Ts=fe(()=>{So=require("msgpackr"),Qs=require("node:fs/promises"),Ze=require("node:fs"),Z_=require("node:zlib"),im=require("node:stream"),Dv=require("fs-extra"),eE=w(ce());k();To=require("path"),go=w(wi());Eo();Mv=8192,Rr=8,vv=0,gA=1,Cv=255,s6=new Uint8Array([0,vv,255,255,255,255,255,255]),i6=new Uint8Array([0,gA,255,255,255,255,255,255]),Pv=0xffffffffffff,bn=new WeakMap,Ss=global.Blob||h6(),Gc=!1,sm=new Uint8Array(8),Q_=new DataView(sm.buffer),o6=6e4;o(Uv,"InstanceOfBlobWithNoConstructor");Uv.prototype=Ss.prototype;J_=class e extends Uv{static{o(this,"FileBackedBlob")}type="";size;#e;#t;constructor(t){super(),t?.type&&(this.type=t.type),t?.size!=null&&(this.size=t.size)}on(t,r){if(t==="error")this.#e??=[],this.#e.push(r);else if(t==="size")this.#t??=[],this.#t.push(r);else throw new Error("Only 'error' and 'size' events are supported")}toJSON(){if(this.type?.startsWith("text")){let t=bn.get(this),{start:r,end:n,contentBuffer:s,asString:i}=t;return i||(s&&(n!==void 0||r!==void 0)&&(s=s.subarray(r??0,n??t.contentBuffer.length)),s?(t.asString=s.toString(),t.asString):(pA()&&hA(this.bytes().then(a=>t.contentBuffer=a)),`[blob: ${this.type}, ${this.size} bytes]`))}return{description:"Blobs that are not of type text/* can not be directly serialized as JSON, use as the body of a response or convert to another type"}}async text(){return(await this.bytes()).toString()}bytes(){let t=bn.get(this),{start:r,end:n,contentBuffer:s}=t;if(s)return(n!==void 0||r!==void 0)&&(s=s.subarray(r??0,n??t.contentBuffer.length)),Promise.resolve(s);let i=om(t),a,c=o(async()=>{let l,u=Rr;try{if(l=await(0,Qs.readFile)(i),l.length>=Rr){l.copy(sm,0,0,Rr);let f=Q_.getBigUint64(0);if(Number(f>>48n)===Cv)throw new Error("Error in blob: "+buffer.subarray(Rr));if(u=Number(f&0xffffffffffffn),u<n&&(u=n),u<Pv&&(this.size=u,this.#t))for(let m of this.#t)m(u)}}catch(f){if(f.code!=="ENOENT")throw f;l=Buffer.alloc(0)}function d(f){if(u>f.length){let m=t.store,h=t.fileId+":blob";if(a)throw new Error("Incomplete blob");return new Promise((p,E)=>{if(m.attemptLock(h,0,()=>(a=!0,m.unlock(h,0),p(c()))))return a=!0,m.unlock(h,0),p(c())})}return(n!=null||r!=null)&&(f=f.subarray(r??0,n??f.length)),f}return o(d,"checkCompletion"),l[1]===gA?new Promise((f,m)=>{(0,Z_.deflate)(l.subarray(Rr),(h,p)=>{h?m(h):f(d(p))})}):d(l.subarray(Rr))},"readContents");return c()}async arrayBuffer(){let t=await this.bytes(),r=new ArrayBuffer(t.length);return new Uint8Array(r).set(t),r}stream(){let t=bn.get(this),{contentBuffer:r,start:n,end:s}=t;if(r)return(s!=null||n!=null)&&(r=r.subarray(n??0,s??t.contentBuffer.length)),new ReadableStream({pull(E){E.enqueue(r),E.close()}});let i=om(t),a,c=0,l=0,u,d,f,m=!1,h=this;return new ReadableStream({start(){let E=1e3,g=o((y,T)=>{(0,Ze.open)(i,"r",(R,I)=>{if(R){if(R.code==="ENOENT"&&f!==!1&&(go.default.debug?.("File does not exist yet, waiting for it to be created",i,E),E-- >0))return setTimeout(()=>{p(),g(y,T)},20).unref();T(R),h.#e?.forEach(P=>P(R))}else a=I,y(I)})},"openFile");return new Promise(g)},pull:o(E=>{let g=0,y=100;return new Promise(o(function T(R,I){function P(te){(0,Ze.close)(a),clearTimeout(d),u&&u.close(),I(te),h.#e?.forEach(x=>x(te))}o(P,"onError");let Y=Buffer.allocUnsafe(262144);(0,Ze.read)(a,Y,0,Y.length,c,(te,x,$)=>{if(l+=x,te)return P(te);if(c===0){if(x<Rr){y-- >0&&f!==!1?(p(),go.default.debug?.("File was empty, waiting for data to be written",i,y),setTimeout(()=>T(R,I),20).unref()):(go.default.debug?.("File was empty, throwing error",i,y),I(new Error(`Blob ${t.fileId} was empty`)));return}$.copy(sm,0,0,Rr);let j=Q_.getBigUint64(0);if(Number(j>>48n)===Cv)return P(new Error("Error in blob: "+$.subarray(Rr)));if(g=Number(j&0xffffffffffffn),g<Pv&&h.size!==g&&(h.size=g,h.#t))for(let V of h.#t)V(g);$=$.subarray(Rr,x),l-=Rr}else if(x===0){let j=Buffer.allocUnsafe(8);return(0,Ze.read)(a,j,0,Rr,0,V=>{if(V)return P(V);if(sm.set(j),g=Number(Q_.getBigUint64(0)&0xffffffffffffn),g>l){p()?u?d=setTimeout(()=>{P(new Error("File read timed out"))},o6).unref():(u=(0,Ze.watch)(i,{persistent:!1},()=>{u.close(),u=null,d&&(clearTimeout(d),d=null,T(R,I))}),T(R,I)):m?P(new Error("Blob is incomplete")):(m=!0,T(R,I));return}(0,Ze.close)(a),E.close(),R()})}else $=$.subarray(0,x);if(n!==void 0||s!==void 0){if(n&&l<n)return c+=x,T(R,I);s&&l>=s&&(l>s&&($=$.subarray(0,s-c)),l=g=s),n&&n>c&&($=$.subarray(n-c))}c+=x;try{E.enqueue($)}catch(j){return go.default.debug?.("Error enqueuing chunk",j),R()}l===g&&((0,Ze.close)(a),E.close()),R()})},"readMore"))},"pull"),cancel(){(0,Ze.close)(a),clearTimeout(d),u&&u.close()}});function p(){if(f===void 0){let E=t.store,g=t.fileId+":blob";f=!E.attemptLock(g,0,()=>{f=!1,E.unlock(g,0)}),f||E.unlock(g,0)}return f}}slice(t,r,n){let s=bn.get(this),i=new e(n&&{type:n});if(s?.fileId){let a={...s,start:t,end:r};bn.set(i,a),this.size!=null&&(i.size=(r==null?this.size:Math.min(r,this.size))-(t??0))}else if(s?.contentBuffer&&!s.storageBuffer){let a={...s,contentBuffer:s.contentBuffer.subarray(t,r)};bn.set(i,a),i.size=(r??this.size)-t}else throw new Error("Can not slice a streaming blob that is not backed by a file");return i}save(t){if(In=t?.primaryStore?.rootStore,!In)throw new Error("No target table specified");return Bv(this).saving??Promise.resolve()}},xv=500;o(tE,"deleteBlob");o(a6,"setDeletionDelay");global.createBlob=function(e,t){let r=new J_(t),n={storageIndex:0,fileId:null,flush:t?.flush,compress:t?.compress};if(bn.set(r,n),e instanceof Uint8Array)r.size=e.length,n.contentBuffer=e;else if(e instanceof im.Readable)n.source=e;else if(typeof e=="string")n.contentBuffer=Buffer.from(e);else if(e?.[Symbol.asyncIterator]||e?.[Symbol.iterator])n.source=im.Readable.from(e);else throw new Error("Invalid source type");return r};o(Bv,"saveBlob");o(_A,"writeBlobWithStream");o(rE,"getFileId");o(Fv,"getFilePathForBlob");EA=new Map;o(am,"getRootBlobPathsForDB");o(SA,"deleteRootBlobPathsForDB");o(Hv,"rimrafSteadily");o(om,"getFilePath");o(c6,"writeBlobWithBuffer");o(l6,"generateFilePath");Lv=new Map;o(u6,"getNextFileId");X_=128;o(d6,"getNextStorageIndex");o(f6,"createFrequencyTableForStoragePaths");o(nE,"encodeBlobsWithFilePath");o(m6,"encodeBlobsAsBuffers");o(sE,"decodeBlobsWithWrites");o(iE,"decodeWithBlobCallback");o(qc,"decodeFromDatabase");o(Ta,"deleteBlobsInObject");o(gu,"findBlobsInObject");(0,So.addExtension)({Class:Ss,type:11,unpack:o(function(e){let t=(0,So.unpack)(e),r=new J_;if(Object.assign(r,t[0]),typeof t[1]!="object"){if(bn.set(r,{storageIndex:t[1],fileId:t[2],store:In}),kc)return kc(r)??r;if(!In)throw new Error("No store specified, cannot load blob from storage")}else bn.set(r,{storageIndex:0,fileId:null,storageBuffer:e,contentBuffer:t[1]}),r.size=t[1]?.length;return r},"unpack"),pack:o(function(e){let t=bn.get(e);if(Eu!==void 0&&(Gc=!0,t?.recordId!==void 0&&t.recordId!==Eu))throw new Error("Cannot use the same blob in two different records");let r={...e};if(e.type&&(r.type=e.type),e.size!==void 0&&(r.size=e.size),t){if(t.storageBuffer)return t.storageBuffer;if(t.contentBuffer?.length<Mv)return r.size=t.contentBuffer.length,(0,So.pack)([r,t.contentBuffer])}if(Eu!==void 0){if(t=Bv(e),!t.fileId)throw new Error("Unable to save blob without file id");return t.recordId=Eu,(0,So.pack)([r,t.storageIndex,t.fileId])}if(t)try{let n=(0,Ze.readFileSync)(om(t));if(n.length>=Rr&&(n.copy(sm,0,0,Rr),Number(Q_.getBigUint64(0)&0xffffffffffffn)===n.length-Rr))return Buffer.concat([(0,So.pack)([r]),n]);if(Gr)Gr.push(e.bytes());else throw new Error("Incomplete blob");return Buffer.alloc(0)}catch(n){if(n.code==="ENOENT"&&Gr)return Gr.push(e.bytes()),Buffer.alloc(0);throw n}else throw new Error("Blob has no storage info or buffer attached to it")},"pack")});(0,So.addExtension)({Class:Promise,type:12,pack(){throw new Error("Cannot encode a promise")}});o(h6,"polyfillBlob")});var Vv={};Ce(Vv,{onStorageReclamation:()=>cm,runReclamationHandlers:()=>bA,setAvailableSpaceRatioGetter:()=>_6});function cm(e,t,r){(r||(0,aE.getWorkerIndex)()===(0,aE.getWorkerCount)()-1)&&(oE.has(e)||oE.set(e,[]),oE.get(e).push({priority:0,handler:t}),AA||(AA=setTimeout(bA,Gv).unref()))}async function bA(){for(let[e,t]of oE)try{let r=await $v(e),n=p6/r;for(let s of t){let{priority:i,handler:a}=s;if(s.priority=n,n>1||i>1){let c=a(n>1?n:0);c&&(yA.default.info?.(`Running storage reclamation handler for ${e} with priority ${n}`),await c)}}}catch(r){yA.default.error?.("Error running storage reclamation handlers",r)}AA=setTimeout(bA,Gv).unref()}function _6(e){$v=e??qv}var RA,aE,yA,cE,kv,oE,p6,Gv,AA,qv,$v,lE=fe(()=>{RA=require("node:fs/promises"),aE=w(st()),yA=w(wi());k();cE=w(ce()),kv=w(ie());cE.default.initSync();oE=new Map,p6=cE.default.get(U.STORAGE_RECLAMATION_THRESHOLD)??.4,Gv=(0,kv.convertToMS)(cE.default.get(U.STORAGE_RECLAMATION_INTERVAL))||36e5;o(cm,"onStorageReclamation");qv=o(async e=>{if(RA.statfs){let t=await(0,RA.statfs)(e);return t.bavail/t.blocks}else return new Promise((t,r)=>{import("hdd-space").then(n=>{n.default(s=>{for(let i of s.parts)if(e.startsWith(i.place))return t(i.free/i.size);return t(1)})})})},"defaultGetAvailableSpaceRatio"),$v=qv;o(bA,"runReclamationHandlers");o(_6,"setAvailableSpaceRatioGetter")});var nU={};Ce(nU,{ACTION_32_BIT:()=>hE,ACTION_64_BIT:()=>S6,AUDIT_STORE_OPTIONS:()=>dm,Decoder:()=>Vc,HAS_BLOBS:()=>Nn,HAS_CURRENT_RESIDENCY_ID:()=>Kc,HAS_EXPIRATION_EXTENDED_TYPE:()=>hm,HAS_ORIGINATING_OPERATION:()=>mm,HAS_PREVIOUS_RESIDENCY_ID:()=>Yc,REMOTE_SEQUENCE_UPDATE:()=>pE,createAuditEntry:()=>Tu,getLastRemoved:()=>PA,openAuditStore:()=>fE,readAuditEntry:()=>Ut,removeAuditEntry:()=>mE,setAuditRetention:()=>g6,transactionKeyEncoder:()=>Zv});function fE(e){let t=e.auditStore=e.openDB(IA.AUDIT_STORE_NAME,{create:!1,...dm});t||(t=e.auditStore=e.openDB(IA.AUDIT_STORE_NAME,dm),Yv(t,1)),t.rootStore=e,t.tableStores=[];let r=[];t.addDeleteRemovalCallback=function(l,u,d){return r[l]=d,t.tableStores[l]=u,t.deleteCallbacks=r,{remove(){delete r[l]}}};let n=null,s,i=0,a=wA;cm(t.env.path,l=>{if(i=l,l)return c(100)});function c(l){l&&(a=l),clearTimeout(n);let u=new Promise(d=>{n=setTimeout(async()=>{if(await s,s=u,t.rootStore.status==="closed"||t.rootStore.status==="closing")return;let f=0,m,h;try{for(let{key:p,value:E}of t.getRange({start:1,snapshot:!1,end:Date.now()-NA/(1+i*i)})){try{m=mE(t,p,E)}catch(g){Su.warn("Error removing audit entry",g)}if(h=p,await new Promise(setImmediate),++f>=E6){a=10;break}}await m}finally{f===0?a=Math.min(a<<1,NA/10):(Yv(t,h),a>100&&(a=a>>1)),d(void 0),c()}},a).unref()});return u}if(o(c,"scheduleAuditCleanup"),t.scheduleAuditCleanup=c,(0,um.getWorkerIndex)()===(0,um.getWorkerCount)()-1&&c(),(0,um.getWorkerIndex)()===0&&!Kv)for(let l of t.getKeys({reverse:!0,limit:1}))l>Date.now()&&(Kv=!0,Su.error("The current time is before the last recorded entry in the audit log. Time reversal can undermine the integrity of data tracking and certificate validation and the time must be corrected."));return t}function mE(e,t,r){let n=T6(r),s;if(n&Nn){s=Ut(r);let i=e.tableStores[s.tableId],a=i?.getEntry(s.recordId);(!a||a.version!==s.version||!a.value)&&qc(()=>Ta(s.getValue(i)),i.rootStore)}if((n&15)===OA){s=s||Ut(r);let i=s.tableId;e.tableStores[s.tableId]?.getEntry(s.recordId)?.version===s.version&&e.deleteCallbacks?.[i]?.(s.recordId,s.version)}return e.remove(t)}function Yv(e,t){CA[0]=t,e.put(Symbol.for("last-removed"),eU)}function PA(e){let t=e.get(Symbol.for("last-removed"));if(t)return eU.set(t),CA[0]}function g6(e,t=wA){NA=e,wA=t}function Tu(e,t,r,n,s,i,a,c,l,u,d,f,m){let h=tU[a];if(!h)throw new Error(`Invalid audit entry type ${a}`);let p=1;if(n&&(n>1?Ra.setFloat64(0,n):Rs.set(LA),p=9),l){if(l&255)throw new Error("Illegal extended type");p+=3}y(s),y(t),g(r),Ra.setFloat64(p,e),p+=8,l&Kc&&y(u),l&Yc&&y(d),l&hm&&(Ra.setFloat64(p,f),p+=8),l&mm&&y(rU[m]),i?g(i):Rs[p++]=0,l?Ra.setUint32(n?8:0,h|l|3221225472):Rs[n?8:0]=h;let E=Rs.subarray(0,p);if(c)return Buffer.concat([E,c]);return E;function g(T){let R=p;p+=1,p=(0,$c.writeKey)(T,Rs,p);let I=p-R-1;I>127?I>16383?(Su.error("Key or username was too large for audit entry",T),p=R+1,Rs[R]=0):(Rs.copyWithin(R+2,R+1,p),Ra.setUint16(R,I|32768),p++):Rs[R]=I}function y(T){T<128?Rs[p++]=T:T<16384?(Ra.setUint16(p,T|32768),p+=2):T<1056964608?(Ra.setUint32(p,T|3221225472),p+=4):(Rs[p]=255,Ra.setUint32(p+1,T),p+=5)}}function T6(e){let t=0;e[0]==66&&(t=8);let r=e[t];if(r<128)return r;let n=e.dataView||(e.dataView=new Vc(e.buffer,e.byteOffset,e.byteLength));return n.position=t,n.readInt()}function Ut(e,t=0,r=void 0){try{let n=e.dataView||(e.dataView=new Vc(e.buffer,e.byteOffset,e.byteLength));n.position=t;let s;e[n.position]==66&&(s=n.readFloat64());let i=n.readInt(),a=n.readInt(),c=n.readInt(),l=n.readInt(),u=n.position,d=n.position+=l,f=n.readFloat64(),m,h,p,E;if(i&Kc&&(m=n.readInt()),i&Yc&&(h=n.readInt()),i&hm&&(p=n.readFloat64()),i&mm){let R=n.readInt();E=rU[R]}l=n.readInt();let g=n.position,y=n.position+=l,T;return{type:tU[i&7],tableId:c,nodeId:a,get recordId(){return(0,$c.readKey)(e,u,d)},getBinaryRecordId(){return e.subarray(u,d)},version:f,previousLocalTime:s,get user(){return y>g?(0,$c.readKey)(e,g,y):void 0},get encoded(){return t?e.subarray(t,r):e},getValue(R,I,P){if(i&uE||i&lm&&!I)return T||(T=qc(()=>R.decoder.decode(e.subarray(n.position,r)),R.rootStore)),T;if(i&lm&&P)return sA(R.getEntry(this.recordId),P,R)},getBinaryValue(){return i&(uE|lm)?e.subarray(n.position,r):void 0},extendedType:i,residencyId:m,previousResidencyId:h,expiresAt:p,originatingOperation:E}}catch(n){return Su.error("Reading audit entry error",n,e),{}}}var $c,dE,IA,um,Xv,Su,Rs,Ra,Zv,dm,NA,E6,CA,eU,wA,Kv,uE,lm,Wv,OA,zv,jv,Qv,Jv,hE,S6,pE,Kc,Yc,mm,hm,Nn,tU,rU,Vc,mo=fe(()=>{$c=require("ordered-binary"),dE=w(ce()),IA=w(kt());k();um=w(st()),Xv=w(ie());Wc();Su=w(z());K_();Ts();lE();(0,dE.initSync)();Rs=Buffer.alloc(2816),Ra=new DataView(Rs.buffer,Rs.byteOffset,2816),Zv={writeKey(e,t,r){return e===fm?(t.set(fm,r),r+8):typeof e=="number"?((t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).setFloat64(r,e),r+8):(0,$c.writeKey)(e,t,r)},readKey(e,t,r){return e[t]===66?(e.dataView||(e.dataView=new DataView(e.buffer,e.byteOffset,e.byteLength))).getFloat64(t):(0,$c.readKey)(e,t,r)}},dm={encoding:"binary",keyEncoder:Zv},NA=(0,Xv.convertToMS)((0,dE.get)(U.LOGGING_AUDITRETENTION))||86400*3,E6=1e3,CA=new Float64Array(1),eU=new Uint8Array(CA.buffer),wA=1e4,Kv=!1;o(fE,"openAuditStore");o(mE,"removeAuditEntry");o(Yv,"updateLastRemoved");o(PA,"getLastRemoved");o(g6,"setAuditRetention");uE=16,lm=32,Wv=1,OA=2,zv=3,jv=4,Qv=5,Jv=6,hE=14,S6=15,pE=11,Kc=512,Yc=1024,mm=2048,hm=4096,Nn=8192,tU={put:Wv|uE,[Wv]:"put",delete:OA,[OA]:"delete",message:zv|uE,[zv]:"message",invalidate:jv|lm,[jv]:"invalidate",patch:Qv|lm,[Qv]:"patch",relocate:Jv,[Jv]:"relocate"},rU={insert:1,update:2,upsert:3,1:"insert",2:"update",3:"upsert"};o(Tu,"createAuditEntry");o(T6,"readAction");o(Ut,"readAuditEntry");Vc=class extends DataView{static{o(this,"Decoder")}position=0;readInt(){let t;return t=this.getUint8(this.position++),t>=128?t>=192?t===255?(t=this.getUint32(this.position),this.position+=4,t):(t=this.getUint32(this.position-1)&1073741823,this.position+=3,t):(t=this.getUint16(this.position-1)&32767,this.position++,t):t}readFloat64(){try{let t=this.getFloat64(this.position);return this.position+=8,t}catch(t){throw t.message=`Error reading float64: ${t.message} at position ${this.position}`,t}}}});var cU={};Ce(cU,{ENTRY:()=>y6,HAS_EXPIRATION:()=>gE,HAS_RESIDENCY_ID:()=>BA,HAS_STRUCTURE_UPDATE:()=>SE,LAST_TIMESTAMP_PLACEHOLDER:()=>fm,LOCAL_TIMESTAMP:()=>R6,METADATA:()=>yu,NEW_TIMESTAMP_PLACEHOLDER:()=>iU,NO_TIMESTAMP:()=>DA,PENDING_LOCAL_TIME:()=>FA,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>LA,RecordEncoder:()=>xA,TIMESTAMP_ASSIGN_LAST:()=>b6,TIMESTAMP_ASSIGN_NEW:()=>oU,TIMESTAMP_ASSIGN_PREVIOUS:()=>aU,TIMESTAMP_PLACEHOLDER:()=>_E,TIMESTAMP_RECORD_PREVIOUS:()=>MA,entryMap:()=>ya,handleLocalTimeForGets:()=>TE,lastMetadata:()=>ct,recordUpdater:()=>HA,removeEntry:()=>jc});function N6(){return Em[0]=Em[0]^64,A6.getFloat64(0)}function TE(e,t){let r=e.getEntry;e.readCount=0,e.cachePuts=!1,e.rootStore=t,e.encoder.rootStore=t,e.getEntry=function(a,c){e.readCount++,ct=null;let l=r.call(this,a,c);return l&&(ct&&(l.metadataFlags=ct[yu],l.localTime=ct.localTime,l.residencyId=ct.residencyId,ct.expiresAt>=0&&(l.expiresAt=ct.expiresAt),ct=null),l.value&&ya.set(l.value,l),l.key=a),l};let n=e.get;e.get=function(a,c){ct=null;let l=n.call(this,a,c);return ct&&l&&(ya.set(l,ct),ct=null),l};let s=e.getRange;e.getRange=function(a){let c=s.call(this,a);return a.valuesForKey?c.map(l=>l?.value):a.values===!1||a.onlyCount?c:c.map(l=>(ct&&(l.metadataFlags=ct[yu],l.localTime=ct.localTime,l.residencyId=ct.residencyId,ct.expiresAt>=0&&(l.expiresAt=ct.expiresAt),ct=null),l))};let i=e.useReadTransaction();if(i.done(),!i.done.isTracked){let a=i.constructor,c=i.use,l=i.done;a.prototype.use=function(){this.timerTracked||(this.timerTracked=!0,zc.push(new WeakRef(this))),c.call(this)},a.prototype.done=function(){if(l.call(this),this.isDone)for(let u=0;u<zc.length;u++){let d=zc[u].deref();(!d||d.isDone||d.isCommitted)&&zc.splice(u--,1)}},a.prototype.done.isTracked=!0}return e}function HA(e,t,r){return function(n,s,i,a,c=-1,l,u,d="put",f,m){f||l==null?Ru=i?.localTime?MA|aU:DA:Ru=l?i?.localTime?MA|16384:oU|16384:DA;let h=u?.expiresAt;if(h>=0&&(c|=gE),_m=c,vA=h,i?.version===a&&l===!1)throw new Error("Must retain local time if version is not changed");let p={version:a,instructedWrite:Ru>0},E,g=0;try{let y=i?.residencyId,T=u?.residencyId;T&&(UA=T,_m|=BA,g|=Kc),y!==T&&(g|=Yc,y||(y=0)),c&gE&&(g|=hm),u?.originatingOperation&&(g|=mm),f&&(p.ifVersion=E=i?.version??null),i&&i.value&&i.metadataFlags&Nn&&(r.getBinaryFast(i.localTime)||Ta(i.value));let R;if(s!==void 0&&(R=nE(()=>e.put(n,s,p),n,e.rootStore),Gc&&(g|=Nn)),l){let I=u?.user?.username;if(m&&(nE(()=>e.encoder.encode(m),n,e.rootStore),Gc&&(g|=Nn)),e.encoder.hasStructureUpdate&&(g|=SE,e.encoder.hasStructureUpdate=!1),f&&i?.localTime){let P=i?.localTime,Y=r.get(P);if(Y){let te=Ut(Y).previousLocalTime;return R=r.put(P,Tu(a,t,n,te,u?.nodeId??server.replication.getThisNodeId(r)??0,I,d,pm,g,T,y,h),{ifVersion:E}),R}}R=r.put(s===void 0?iU:fm,Tu(a,t,n,i?.localTime?1:0,u?.nodeId??server.replication?.getThisNodeId(r)??0,I,d,pm,g,T,y,h,u?.originatingOperation),{append:d!=="invalidate",instructedWrite:!0,ifVersion:E})}return R}catch(y){throw y.message+=" id: "+n+" options: "+p,y}}}function jc(e,t,r){if(t)return t.value&&t.metadataFlags&Nn&&!e.auditStore.getBinaryFast(t.localTime)&&Ta(t.value),e.remove(t.key,r)}var sU,EE,_E,fm,LA,iU,R6,yu,y6,Em,A6,DA,oU,b6,aU,MA,gE,BA,FA,SE,ya,I6,pm,Ru,_m,vA,UA,ct,xA,zc,Wc=fe(()=>{sU=require("msgpackr");mo();EE=w(z());Ts();Ts();_E=new Uint8Array([1,1,1,1,4,64,0,0]),fm=new Uint8Array([1,1,1,1,1,0,0,0]),LA=new Uint8Array([1,1,1,1,3,64,0,0]),iU=new Uint8Array([1,1,1,1,0,64,0,0]),R6=Symbol("local-timestamp"),yu=Symbol("metadata"),y6=Symbol("entry"),Em=new Uint8Array(8),A6=new DataView(Em.buffer,0,8),DA=0,oU=0,b6=1,aU=3,MA=4,gE=16,BA=32,FA=1,SE=256,ya=new WeakMap,Ru=0,_m=-1,vA=-1,UA=0,ct=null,xA=class extends sU.Encoder{static{o(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0;class r{static{o(this,"RecordObject")}getUpdatedTime(){return ya.get(this)?.version}getExpiresAt(){return ya.get(this)?.expiresAt}}t.structPrototype=r.prototype,super(t);let n=this.encode;this.encode=function(i,a){if(Ru||_m>=0){let c=0,l=Ru;l&&(c+=8,Ru=0);let u=_m,d=vA,f=UA;u>=0&&(c+=4,_m=-1,d>=0&&(c+=8,vA=-1),f&&(c+=4,UA=0));let m=I6=n.call(this,i,a|2048|c);pm=m.subarray((m.start||0)+c,m.end);let h=m.start||0;return l&&(_E[4]=l,_E[5]=l>>8,m.set(_E,h),h+=8),Gc&&(u|=Nn),u>=0&&((m.dataView||(m.dataView=new DataView(m.buffer,m.byteOffset,m.byteLength))).setUint32(h,u|hE<<24),h+=4,d>=0&&((m.dataView||(m.dataView=new DataView(m.buffer,m.byteOffset,m.byteLength))).setFloat64(h,d),h+=8),f&&(m.dataView||(m.dataView=new DataView(m.buffer,m.byteOffset,m.byteLength))).setUint32(h,f)),m}else return pm=n.call(this,i,a),pm};let s=this.saveStructures;this.saveStructures=function(i,a){let c=s.call(this,i,a);return this.hasStructureUpdate=!0,c}}decode(t,r){ct=null;let n=r?.start||0,s=r>-1?r:r?.end||t.length,i=t[n],a=0;try{if(i<32&&s>2){let c=n,l;if(i===2){if(t.copy)t.copy(Em,0,c),c+=8;else for(let m=0;m<8;m++)Em[m]=t[c++];l=N6(),i=t[c]}let u,d;i<32&&(i===hE?(a=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4):(a=i|t[c+1]<<5,c+=2),a&gE&&(u=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8),a&BA&&(d=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4));let f=qc(()=>r?.valueAsBuffer?t.subarray(c,s):super.decode(t.subarray(c,s),s-c),this.rootStore);return ct={localTime:l,[yu]:a,expiresAt:u,residencyId:d},f}return r?.valueAsBuffer?t:qc(()=>super.decode(t,r),this.rootStore)}catch(c){return EE.error("Error decoding record",c,"data: "+t.slice(0,40).toString("hex")),null}}};o(N6,"getTimestamp");o(TE,"handleLocalTimeForGets");zc=[];setInterval(()=>{for(let e=0;e<zc.length;e++){let t=zc[e].deref();!t||t.isDone||t.isCommitted?zc.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(EE.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):EE.error("Read transaction detected that has been open too long (over one minute), make sure read transactions are quickly closed",t)),t.openTimer++):t.openTimer=1)}},15e3).unref();o(HA,"recordUpdater");o(jc,"removeEntry")});function qA(e,t,r,n,s,i,a,c){let l=e[0];if(t==="or"){let f=u(l);for(let h=1;h<e.length;h++){let p=e[h],E=u(p);f=f.concat(E)}let m=new Set;return f.filter(h=>{let p=h.key??h;return m.has(p)?!1:(m.add(p),!0)})}else{let f=u(l),m=d(e.slice(1),!0,l.estimated_count);return m.length>0?a(f,m):f}function u(f){return f.conditions?qA(f.conditions,f.operator,r,n,s,i,a,c):Nu(f,n,f.descending||s.reverse===!0,r,s.allowFullScan,c,i)}o(u,"executeCondition");function d(f,m,h){return f.map((p,E)=>{if(p.conditions){let T=p.operator==="or",R=d(p.conditions,!T,h);return T?(I,P)=>R.some(Y=>Y(I,P)):(I,P)=>R.every(Y=>Y(I,P))}let g=(p.attribute||p[0])===r.primaryKey,y=Sm(p,r,i,c,g,h);return m&&E<f.length-1&&h&&(h=U6(r.primaryStore,p.estimated_count,h)),y}).filter(Boolean)}o(d,"mapConditionsToFilters")}function Nu(e,t,r,n,s,i,a){let c=e[0]??e.attribute,l=e[1]??e.value,u=e.comparator;if(l===void 0&&u!=="sort")throw new qr.ClientError(`Search condition for ${c} must have a value`);if(Array.isArray(c)){let R=c[0],I=Pi(n.attributes,R);if(I.relationship){if(c.length<2)throw new qr.ClientError("Can not directly query a relational attribute, must query an attribute within the target table");let P=I.definition?.tableClass||I.elements?.definition?.tableClass,Y=new Map,te=Nu({attribute:c.length>2?c.slice(1):c[1],value:l,comparator:u},t,r,P,s,Y);if(I.relationship.to){i[c[0]]=Y;let x=!!Pi(P.attributes,I.relationship.to)?.elements;te=L6(te,I,P.primaryStore,x,Y)}if(I.relationship.from){let x=o($=>($?.key!==void 0&&($=$.key),Nu({attribute:I.relationship.from,value:$},t,r,n,s,Y)),"searchEntry");I.elements?(i[c[0]]=Y,te=D6(te,I,P.primaryStore,Y,x)):te=te.flatMap(x)}return te}else if(c.length===1)c=c[0];else throw new qr.ClientError("Unable to query by attribute "+JSON.stringify(c))}let d=c===n.primaryKey||c==null,f=d?n.primaryStore:n.indices[c],m,h,p,E;l instanceof Date&&(l=l.getTime());let g;switch($A[u]||u){case"lt":m=!0,h=l;break;case"le":m=!0,h=l,p=!0;break;case"gt":m=l,E=!0;break;case"ge":m=l;break;case"prefix":Array.isArray(l)?l[l.length-1]!=null&&(l=l.concat(null)):l=[l,null],m=l,h=l.slice(0),h[h.length-1]=Ci.MAXIMUM_KEY;break;case"starts_with":m=l.toString(),h=l+"\uFFFF";break;case"between":case"gele":case"gelt":case"gtlt":case"gtle":m=l[0],m instanceof Date&&(m=m.getTime()),h=l[1],h instanceof Date&&(h=h.getTime()),p=u==="gele"||u==="gtle"||u==="between",E=u==="gtlt"||u==="gtle";break;case"equals":case void 0:m=l,h=l,p=!0;break;case"ne":if(l===null){m=l,E=!0;break}case"sort":case"contains":case"ends_with":m=!0,g=!0;break;default:throw new qr.ClientError(`Unknown query comparator "${u}"`)}let y;if(typeof m=="string"&&m.length>ys.MAX_SEARCH_KEY_LENGTH&&(m=m.slice(0,ys.MAX_SEARCH_KEY_LENGTH)+ys.OVERFLOW_MARKER,E=!1,y=Sm(e,n,null,i,d)),typeof h=="string"&&h.length>ys.MAX_SEARCH_KEY_LENGTH&&(h=h.slice(0,ys.MAX_SEARCH_KEY_LENGTH)+ys.OVERFLOW_MARKER,p=!0,y=y??Sm(e,n,null,i,d)),r){let R=m;m=h,h=R,R=!E,E=!p,p=R}if(!f||f.isIndexing||g||l===null&&!f.indexNulls){if(s===!1&&!f)throw new qr.ClientError(`"${c}" is not indexed, can not search for this attribute`,404);if(s===!1&&g)throw new qr.ClientError(`Can not use ${u||"equal"} operator without combining with a condition that uses an index, can not search for attribute ${c}`,403);if(f?.isIndexing)throw new qr.ServerError(`"${c}" is not indexed yet, can not search for this attribute`,503);if(l===null&&f&&!f.indexNulls)throw new qr.ClientError(`"${c}" is not indexed for nulls, index needs to be rebuilt to search for nulls, can not search for this attribute`,400);if(y=y??Sm(e,n,null,i,d),!y)throw new qr.ClientError(`Unknown search operator ${e.comparator}`)}let T={start:m,end:h,inclusiveEnd:p,exclusiveStart:E,values:!0,versions:d,transaction:t,reverse:r};if(d){let R=f.getRange(T).map(y?function({key:I,value:P}){return this?.isSync?P&&y(P)?I:Aa.SKIP:new Promise((Y,te)=>setImmediate(()=>{try{Y(P&&y(P)?I:Aa.SKIP)}catch(x){te(x)}}))}:I=>I.value==null&&!(I.metadataFlags&(wn|ba))?Aa.SKIP:I);return R.hasEntries=!0,R}else return f?f.customIndex?f.customIndex.search(e,a).map(R=>{if(typeof R=="object"&&R){let{key:I,...P}=R,Y=n.primaryStore.getEntry(I);return{...P,...Y}}return R}):f.getRange(T).map(y?function({key:R,value:I}){let P;return typeof R=="string"&&R.length>ys.MAX_SEARCH_KEY_LENGTH?P=n.primaryStore.get(I):P={[c]:R},this.isSync?y(P)?I:Aa.SKIP:new Promise((Y,te)=>setImmediate(()=>{try{Y(y(P)?I:Aa.SKIP)}catch(x){te(x)}}))}:({value:R})=>R):n.primaryStore.getRange(r?{end:!0,transaction:t,reverse:!0}:{start:!0,transaction:t}).map(function({key:R,value:I}){return this.isSync?I&&y(I)?R:Aa.SKIP:new Promise((P,Y)=>setImmediate(()=>{try{P(I&&y(I)?R:Aa.SKIP)}catch(te){Y(te)}}))})}function Pi(e,t){if(Array.isArray(t))if(t.length>1){let r=Pi(e,t[0]),n=(r?.definition?.tableClass||r?.elements?.definition?.tableClass)?.attributes??r?.properties;return n?Pi(n,t.slice(1)):void 0}else t=t.toString();else typeof t!="string"&&(t=t.toString());return e.find(r=>r.name===t)}function L6(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i;return s.hasMappings=!0,{next(){if(!i){let c=t.relationship.to,l=o((u,d)=>{let f=s.get(u);f?f.push(d):s.set(u,f=[d])},"addEntry");for(let u of e){let d=u.value??r.get(u.key??u),f=d?.[c];if(f!=null&&!s.filters?.some(m=>!m(d)))if(n)for(let m=0;m<f.length;m++)l(f[m],u);else l(f,u)}return i=s.keys()[Symbol.iterator](),this.next()}let a=i.next();return a.done?a:{value:a.value}},return(){if(i?.return)return i.return()}}}})}function D6(e,t,r,n,s){return new e.constructor({[Symbol.iterator](){let i,a,c=new Set;return{next(){let l;if(a)for(;l=a.next(),!l.done;){let u=l.value;if(!c.has(u))return c.add(u),l}if(!i){let u=new Set;n.fromRecord=d=>d[t.relationship.from]?.filter?.(f=>u.has(f));for(let d of e){if(n.filters){let f=r.get(d);if(n.filters.some(m=>!m(f)))continue}u.add(d)}return i=u[Symbol.iterator](),this.next()}do{let u=i.next();return u.done?u:(a=s(u.value)[Symbol.iterator](),this.next())}while(!0)},return(){return a?.return?.()},throw(){return a?.throw?.()}}}})}function Sm(e,t,r,n,s,i){let a=e.comparator,c=e[0]??e.attribute,l=e[1]??e.value;if(Array.isArray(c)){if(c.length===0)return()=>!0;if(c.length===1)c=c[0];else if(c.length>1){let d=c[0],f=Pi(t.attributes,d),m=f.definition?.tableClass||f.elements.definition?.tableClass,h=n?.[d],p=Sm({attribute:c.length>2?c.slice(1):c[1],value:l,comparator:a},m,r,h?.[d]?.joined,c[1]===m.primaryKey,i);if(!p)return;if(h){h.filters||(h.filters=[]),h.filters.push(p);return}let E=t.propertyResolvers?.[d];E.to&&(p.to=E.to);let g,y=o((R,I)=>{let P,Y;return E?E.returnDirect?(P=E(R,r,I),Y=ct):(Y=E(R,r,I,!0),Array.isArray(Y)?(P=Y.map(te=>te.value),Y=null):P=Y?.value):P=R[d],{subObject:P,subEntry:Y}},"getSubObject"),T=o((R,I)=>{if(E&&p.idFilter){if(!g)if(p.idFilter.idSet?.size===1){for(let $ of p.idFilter.idSet)e={attribute:E.from??t.primaryKey,value:$};g=u(E.from??t.primaryKey,p.idFilter,!0,!0)}else g=u(E.from??t.primaryKey,p.idFilter,!1,!0);let x=g(R);return g.idFilter&&(T.idFilter=g.idFilter),x}let{subObject:P,subEntry:Y}=y(R,I);return P?Array.isArray(P)?(!n?.[d]&&n&&(n[d]={fromRecord(x){let $=y(x).subObject;return Array.isArray($)?$.filter(p).map(j=>j[m.primaryKey]):$}}),P.some(p)):p(P,Y):!1},"recordFilter");return T}}switch(l instanceof Date&&(l=l.getTime()),$A[a]||a){case ys.SEARCH_TYPES.EQUALS:case void 0:return u(c,d=>d===l,!0);case"contains":return u(c,d=>d?.toString().includes(l));case"ends_with":return u(c,d=>d?.toString().endsWith(l));case"starts_with":return u(c,d=>typeof d=="string"&&d.startsWith(l),!0);case"prefix":return Array.isArray(l)?l[l.length-1]==null&&(l=l.slice(0,-1)):l=[l],u(c,d=>{if(!Array.isArray(d))return!1;for(let f=0,m=l.length;f<m;f++)if(d[f]!==l[f])return!1;return!0},!0);case"between":return l[0]instanceof Date&&(l[0]=l[0].getTime()),l[1]instanceof Date&&(l[1]=l[1].getTime()),u(c,d=>(0,Ci.compareKeys)(d,l[0])>=0&&(0,Ci.compareKeys)(d,l[1])<=0,!0);case"gt":return u(c,d=>(0,Ci.compareKeys)(d,l)>0);case"ge":return u(c,d=>(0,Ci.compareKeys)(d,l)>=0);case"lt":return u(c,d=>(0,Ci.compareKeys)(d,l)<0);case"le":return u(c,d=>(0,Ci.compareKeys)(d,l)<=0);case"ne":return u(c,d=>(0,Ci.compareKeys)(d,l)!==0,!1,!0);case"sort":return()=>!0;default:throw new qr.ClientError(`Unknown query comparator "${a}"`)}function u(d,f,m,h){let p;m=m&&!s&&t?.indices[d]&&i>3,m&&(e.estimated_count==null&&yE(t)(e),p=e.estimated_count>>4,(isNaN(p)||p>=i)&&(m=!1));let E=0,g=3;function y(T){let R=T[d],I;if(typeof R!="object"||!R||h?I=f(R):Array.isArray(R)?I=R.some(f):R instanceof Date&&(I=f(R.getTime())),m&&(g++,!I&&!y.idFilter&&++E/g*i>p)){let P=Nu(e,r.transaction.getReadTxn(),!1,t),Y;y.to?Y=P.flatMap(x=>t.primaryStore.get(x)[y.to]):Y=P.map(wu);let te=new Set(Y);y.idFilter=x=>te.has(wu(x)),y.idFilter.idSet=te}return I}return o(y,"recordFilter"),s&&(y.idFilter=f),y}o(u,"attributeComparator")}function yE(e){function t(r){if(r.estimated_count===void 0){if(r.conditions){let s;if(r.operator==="or"){s=0;for(let i of r.conditions)t(i),s+=i.estimated_count}else{s=1/0;for(let i of r.conditions)t(i),s=isFinite(s)?s*i.estimated_count/Ro(e.primaryStore):i.estimated_count}return r.estimated_count=s,r.estimated_count}let n=r.comparator||r.search_type;if(n=$A[n]||n,n===ys.SEARCH_TYPES.EQUALS||!n){let s=r[0]??r.attribute;if(s==null||s===e.primaryKey)r.estimated_count=1;else if(Array.isArray(s)&&s.length>1){let i=Pi(e.attributes,s[0]),a=i.definition?.tableClass||i.elements.definition?.tableClass,c=yE(a)({value:r.value,attribute:s.length>2?s.slice(1):s[1],comparator:"equals"}),l=e.indices[i.relationship.from];r.estimated_count=c+(l?c*Ro(e.indices[i.relationship.from])/(Ro(a.primaryStore)||1):c)}else{let i=e.indices[s];r.estimated_count=i?i.getValuesCount(r[1]??r.value):1/0}}else if(n==="contains"||n==="ends_with"||n==="ne"){let s=r[0]??r.attribute,i=e.indices[s];r.value===null&&n==="ne"?r.estimated_count=Ro(e.primaryStore)-(i?i.getValuesCount(null):0):r.estimated_count=1/0}else if(n==="starts_with"||n==="prefix")r.estimated_count=C6*Ro(e.primaryStore)+1;else if(n==="between")r.estimated_count=O6*Ro(e.primaryStore)+1;else if(n==="sort"){let s=r[0]??r.attribute,i=e.indices[s];i?.customIndex?.estimateCountAsSort?r.estimated_count=i.customIndex.estimateCountAsSort(r):r.estimated_count=Ro(e.primaryStore)+1}else{let s=r[0]??r.attribute,i=e.indices[s];i?.customIndex?.estimateCount?r.estimated_count=i.customIndex.estimateCount(r.value):r.estimated_count=w6*Ro(e.primaryStore)+1}typeof r.descending=="boolean"&&(r.estimated_count/=2)}return r.estimated_count}return o(t,"estimateConditionForTable"),t}function AE(e,t){if(e)if(yo=e,Au.lastIndex=0,M6.test(e))try{if(t&&(t.conditions=[]),Js=t??new Iu,gm(Js,""),Lr!==yo.length&&Gt("Unable to parse query, unexpected end of query"),Js.parseErrorMessage&&(Js.parseError=new kA(t.parseErrorMessage),!t))throw Js.parseError;return Js}catch(r){if(r.statusCode=400,r.message=`Unable to parse query, ${r.message} at position ${Lr} in '${yo}'`,Js.parseErrorMessage&&(r.message+=", "+Js.parseErrorMessage),t)t.parseError=r;else throw r}else return t??new URLSearchParams(e)}function Gt(e){let t=`${e} at position ${Lr}`;Js.parseErrorMessage=Js.parseErrorMessage?Js.parseErrorMessage+", "+t:t}function gm(e,t){let r=Au,n,s,i,a,c,l=decodeURIComponent,u;for(;n=r.exec(yo);){Lr=r.lastIndex;let[,d,f]=n;a?(d&&Gt(`expected operator, but encountered '${d}'`),a=!1,c=!1):c=!0;let m;switch(f){case"=":s!=null?(d.length<=2?i=d:Gt(`invalid FIQL operator ${d}`),l=lU):(l=decodeURIComponent,i="equals",d||Gt("attribute must be specified before equality comparator"),s=bu(d));break;case"==":case"!=":case"<":case"<=":case">":case">=":case"===":case"!==":i=P6[f],l=GA[i]?lU:decodeURIComponent,d||Gt(`attribute must be specified before comparator ${f}`),s=bu(d);break;case"&=":case"|=":case"|":case"&":case"":case void 0:if(s==null)s===void 0&&(t&&Gt(`expected '${t}', but encountered ${f[0]?"'"+f[0]+"'":"end of string"}}`),Gt(`no comparison specified before ${f?"'"+f+"'":"end of string"}`));else{e.conditions||Gt("conditions/comparisons are not allowed in a property list");let p={comparator:i,attribute:s||null,value:l(d)};if(i==="eq"&&uU(p,d),s===""){let E=e.conditions[e.conditions.length-1];E.chainedConditions=E.chainedConditions||[],E.chainedConditions.push(p),E.operator=u}else RE(e,u),e.conditions.push(p)}f==="&"?(u="and",s=void 0):f==="|"?(u="or",s=void 0):f==="&="?(u="and",s=""):f==="|="&&(u="or",s="");break;case",":e.conditions?Gt("conditions/comparisons are not allowed in a property list"):e.push(bu(d)),s=void 0;break;case"(":Au.lastIndex=Lr;let h=gm(d?[]:new Iu,")");switch(d){case"":RE(e,u),e.conditions.push(h);break;case"limit":switch(h.length){case 1:e.limit=+h[0];break;case 2:e.offset=+h[0],e.limit=h[1]-e.offset;break;default:Gt("limit must have 1 or 2 arguments")}break;case"select":Array.isArray(h[0])&&h.length===1&&!h[0].name?(e.select=h[0],e.select.asArray=!0):h.length===1?e.select=h[0]:h.length===2&&h[1]===""?e.select=h.slice(0,1):e.select=h;break;case"group-by":Gt("group by is not implemented yet");case"sort":e.sort=dU(h);break;default:Gt(`unknown query function call ${d}`)}yo[Lr]===","?r.lastIndex=++Lr:a=!0,s=null;break;case"{":e.conditions&&Gt("property sets are not allowed in a queries"),d||Gt("property sets must have a defined parent property name"),Au.lastIndex=Lr,m=gm([],"}"),m.name=d,e.push(m),yo[Lr]===","?r.lastIndex=++Lr:a=!0;break;case"[":if(Au.lastIndex=Lr,d?(m=gm(new Iu,"]"),m.name=d):m=gm(e.conditions?new Iu:[],"]"),e.conditions)if(RE(e,u),yo[Lr]==="="){l=decodeURIComponent,i="equals",s=bu(d),r.lastIndex=++Lr;break}else e.conditions.push(m),s=null;else e.push(m);yo[Lr]===","?r.lastIndex=++Lr:a=!0;break;case")":case"]":case"}":if(t===f[0]){if(e.conditions)if(s){let p={comparator:i||"equals",attribute:s,value:l(d)};i==="eq"&&uU(p,d),RE(e,u),e.conditions.push(p)}else d&&Gt("no attribute or comparison specified");else(d||e.length>0&&c)&&e.push(bu(d));return e}else Gt(t?`expected '${t}', but encountered '${f[0]}'`:`unexpected token '${f[0]}'`);default:Gt(`unexpected operator '${f}'`)}if(t!==")"&&(r=s?v6:Au,r.lastIndex=Lr),Lr===yo.length)return e}t&&Gt(`expected '${t}', but encountered end of string`)}function RE(e,t){e.conditions.length>0&&(e.operator?e.operator!==t&&Gt("Can not mix operators within a condition grouping"):e.operator=t)}function bu(e){return e.indexOf(".")>-1?e.split(".").map(bu):decodeURIComponent(e)}function lU(e){if(e==="null")return null;if(e.indexOf(":")>-1){let[t,r]=e.split(":");if(t==="number")return r[0]==="$"?parseInt(r.slice(1),36):+r;if(t==="boolean")return r==="true";if(t==="date")return new Date(isNaN(r)?decodeURIComponent(r):+r);if(t==="string")return decodeURIComponent(r);throw new qr.ClientError(`Unknown type ${t}`)}return decodeURIComponent(e)}function uU(e,t){if(t.indexOf("*")>-1)if(t.endsWith("*"))e.comparator="starts_with",e.value=decodeURIComponent(t.slice(0,-1));else throw new qr.ClientError("wildcard can only be used at the end of a string")}function dU(e){let t=fU(e[0]);return e.length>1&&(t.next=dU(e.slice(1))),t}function fU(e){if(Array.isArray(e)){let t=fU(e[0]);return e[0]=t.attribute,t.attribute=e,t}if(typeof e=="string")switch(e[0]){case"-":return{attribute:e.slice(1),descending:!0};case"+":return{attribute:e.slice(1),descending:!1};default:return{attribute:e,descending:!1}}Gt(`Unknown sort type ${e}`)}function wu(e){return Array.isArray(e)?e.join("\0"):e}function Ro(e){let t=Date.now();return(e.estimatedEntryCountExpires||0)<t&&(e.estimatedEntryCount=e.getStats().entryCount,e.estimatedEntryCountExpires=t+1e4),e.estimatedEntryCount}function U6(e,t,r){return t*r/Ro(e)}var qr,ys,Ci,Aa,w6,O6,C6,P6,GA,$A,kA,M6,Au,v6,Lr,Js,yo,Iu,bE=fe(()=>{qr=w(_e()),ys=w(kt()),Ci=require("ordered-binary"),Aa=require("lmdb");Tm();Wc();w6=.3,O6=.1,C6=.05,P6={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},GA={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};o(qA,"executeConditions");o(Nu,"searchByIndex");o(Pi,"findAttribute");o(L6,"joinTo");o(D6,"joinFrom");$A={eq:"equals",greater_than:"gt",greaterThan:"gt",greater_than_equal:"ge",greaterThanEqual:"ge",less_than:"lt",lessThan:"lt",less_than_equal:"le",lessThanEqual:"le",not_equal:"ne",notEqual:"ne",equal:"equals",sw:"starts_with",startsWith:"starts_with",ew:"ends_with",endsWith:"ends_with",ct:"contains",">":"gt",">=":"ge","<":"lt","<=":"le","...":"between"};o(Sm,"filterByType");o(yE,"estimateCondition");kA=class extends qr.Violation{static{o(this,"SyntaxViolation")}},M6=/[()[\]|!<>.]|(=\w*=)/,Au=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,v6=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/g;o(AE,"parseQuery");o(Gt,"recordError");o(gm,"parseBlock");o(RE,"assignOperator");o(bu,"decodeProperty");o(lU,"typedDecoding");o(uU,"wildcardDecoding");o(dU,"toSortObject");o(fU,"toSortEntry");Iu=class{static{o(this,"Query")}constructor(){this.conditions=[]}[Symbol.iterator](){return this.conditions[Symbol.iterator]()}get(t){for(let r=0;r<this.conditions.length;r++){let n=this.conditions[r];if(n.attribute===t)return n.value}}getAll(){let t=[];for(let r=0,n=this.conditions.length;r<n;r++){let s=this.conditions[r];s.attribute&&t.push(s.value)}return t}};o(wu,"flattenKey");o(Ro,"estimatedEntryCount");o(U6,"intersectionEstimate")});var mU,Xs,IE=fe(()=>{mU=w(zs());Ia();Xs=class extends URLSearchParams{static{o(this,"RequestTarget")}#e;pathname;search;id;isCollection;constructor(t){let r,n;if(t&&(r=t.indexOf("?"))>-1){n=t.slice(0,r);let s=t.slice(r+1);super(s),this.search=s}else super(),n=t;this.pathname=n??"",this.#e=t}toString(){return this.#e?this.#e:this.size>0?this.pathname+"?"+super.toString():this.pathname}get url(){return this.toString()}delete(t){super.delete(t),this.conditions&&(this.conditions=this.conditions.filter(r=>r.attribute!==t)),this.#e=void 0}set(t,r){this.delete(t),super.set(t,r),this.conditions?.push({attribute:t,value:r})}append(t,r){super.append(t,r),this.#e=void 0,this.conditions?.push({attribute:t,value:r})}};(0,mU._assignPackageExport)("Resource",Dr)});var gU={};Ce(gU,{MultiPartId:()=>NE,Resource:()=>Dr,contextStorage:()=>Cu,snakeCase:()=>B6,transformForSelect:()=>wE});function B6(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function hU(e,t){if(Qc=!1,e==="")return null;if(e=e.slice(1),t.splitSegments){if(e.indexOf("/")===-1)return e===""?(Qc=!0,null):t.coerceId(decodeURIComponent(e));let r=e.split("/"),n=new NE;for(let s=0;s<r.length;s++){let i=r[s];if(!i&&s===r.length-1){Qc=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}else{if(e==="")return Qc=!0,null;e[e.length-1]==="/"&&(Qc=!0)}return t.coerceId(decodeURIComponent(e))}function On(e,t){n.reliesOnPrototype=!0;let r=t.hasContent;return n;function n(s,i,a){let c,l,u,d;if(r){if(a)d=i,a=a.getContext?.()||a;else if(i)typeof s=="object"&&s&&(!Array.isArray(s)||typeof s[0]=="object")?(d=s,c=d[this.primaryKey]??null,a=i.getContext?.()||i):i?.transaction instanceof fo?a=i:d=i;else if(s&&typeof s=="object")d=s,s=void 0,c=d.getId?.()??d[this.primaryKey];else throw new Ou.ClientError(`Invalid argument for data, must be an object, but got ${s}`);c===null&&(u=!0)}else i?a=i.getContext?.()||i:s&&typeof s=="object"&&!Array.isArray(s)&&(a=s);if(c===void 0)if(typeof s=="object"&&s){if(l=s,c=s instanceof URLSearchParams?s.toString():s.url,s.conditions)c=s.id;else if(typeof c=="string")if(this.directURLMapping)c=c.slice(1),l.id=c;else{let E=c.indexOf("?");E>-1&&(l=this.parseQuery(c.slice(E+1),s),c=c.slice(0,E),c===""&&(u=!0));let g=this.parsePath(c,a,l);g?.id!==void 0?(g.query&&(l?l=Object.assign(g.query,l):l=g.query),u=g.isCollection,c=g.id):c=g,c&&(l.id=c)}else if(s[Symbol.iterator]){c=[],u=!0;for(let E of s){if(typeof E=="object"&&E)break;c.push(E)}c.length===0?c=null:(c.length===1&&(c=c[0]),l.slice&&(l=l.slice(c.length,l.length),l.length===0&&(l=new Xs,l.id=c,u=!1)))}c===void 0&&(c=s.id??null,c==null&&(u=!0))}else c=s,l=new Xs,l.id=c,c==null&&(u=!0);l||(l=new Xs,l.id=c),u&&(l.isCollection=!0);let f;a||(a=Cu.getStore()??{}),l.ensureLoaded!=null||l.async||u?(f={...t},l.ensureLoaded!=null&&(f.ensureLoaded=l.ensureLoaded),l.async&&(f.async=l.async),u&&(f.isCollection=!0)):f=t;let m=this.loadAsInstance,h=p;if((m===!1?!this.explicitContext:this.explicitContext===!1)&&(h=o(E=>Cu.run(a,()=>p(E)),"runAction")),a?.transaction){let E=this.getResource(c,a,f);return E.then?E.then(h):h(E)}else return vt(a,()=>{let E=this.getResource(c,a,f);return E.then?E.then(h):h(E)},f);function p(E){if(m!==!1&&a.authorize){a.authorize=!1;let g=t.type==="read"?E.allowRead(a.user,l,a):t.type==="update"?E.doesExist?.()===!1?E.allowCreate(a.user,d,a):E.allowUpdate(a.user,d,a):t.type==="create"?E.allowCreate(a.user,d,a):E.allowDelete(a.user,l,a);if(g?.then)return g.then(y=>{if(!y)throw new Ou.AccessViolation(a.user);return typeof d?.then=="function"?d.then(T=>e(E,l,a,T)):e(E,l,a,d)});if(!g)throw new Ou.AccessViolation(a.user)}return typeof d?.then=="function"?d.then(g=>e(E,l,a,g)):e(E,l,a,d)}o(p,"authorizeActionOnResource")}}function Vn(e,t){let r=new Ou.ClientError(`The ${e.constructor.name} does not have a ${t} method implemented`,405);r.allow=[],r.method=t;for(let n of["get","put","post","delete","query","move","copy"])typeof e[n]=="function"&&r.allow.push(n);throw r}function VA(e,t,r){let n=e.getRecord?.();if(n){let s=e.getChanges?.();return i=>{let a,c;return e.hasOwnProperty(i)&&typeof(a=e[i])!="function"?a:s&&i in s?s[i]:(c=t?.[i])?c(e,r):n[i]}}else return t?s=>{let i=t[s];return i?i(e,r):e[s]}:s=>e[s]}function wE(e,t){let r=t.propertyResolvers,n=t.getContext?.(),s;if(typeof e=="string")return o(function a(c){return c.then?c.then(a):Array.isArray(c)?c.map(a):VA(c,r,n)(e)},"transform");if(typeof e=="object"){if(e.asArray)return o(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(c);let u=[],d=i(VA(l,r,n));for(let f of e)u.push(d(f));return u},"transform");let a=e.forceNulls;return o(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(m=>m&&typeof m=="object"?c(m):m);let u={},d=i(VA(l,r,n)),f;for(let m of e){let h=d(m);h===void 0&&a&&(h=null),h?.then?(f||(f=[]),f.push(h.then(p=>u[m.name||m]=p))):u[m.name||m]=h}return f?Promise.all(f).then(()=>u):u},"transform")}else throw new Error("Invalid select argument type "+typeof e);function i(a){return c=>{if(typeof c=="string")return a(c);if(typeof c=="object")if(c.name){s||(s={});let l=s[c.name];if(!l){let d=r[c.name]?.definition?.tableClass;l=s[c.name]=wE(c.select||c,d)}let u=a(c.name);return l(u)}else return a(c);else return c}}o(i,"handleProperty")}var pU,_U,Ou,EU,Cu,x6,Dr,Qc,NE,Ia=fe(()=>{pU=require("crypto");Jf();_u();_U=w(zs()),Ou=w(_e());xc();bE();EU=require("async_hooks");IE();Cu=new EU.AsyncLocalStorage,x6={json:"application/json",cbor:"application/cbor",msgpack:"application/x-msgpack",csv:"text/csv"},Dr=class{static{o(this,"Resource")}#e;#t;#r;static transactions;static directURLMapping=!1;static loadAsInstance;constructor(t,r){this.#e=t;let n=r?.getContext?r.getContext()??null:void 0;this.#t=n!==void 0?n:r||null}static get=On(function(t,r,n,s){let i=t.get?.(r);if(i?.then)return i.then(a);return a(i);function a(c){let l;if((l=r?.select)&&c!=null&&!c.selectApplied){let u=wE(l,t.constructor);return typeof c?.map=="function"?c.map(u):u(c)}return c}},{type:"read",letItLinger:!0,ensureLoaded:!0,async:!0});static put=On(function(t,r,n,s){if(Array.isArray(s)&&t.#r&&t.constructor.loadAsInstance!==!1){let i=[];for(let a of s){let c=t.constructor,l=a[c.primaryKey],u=c.getResource(l,n,{async:!0});u.then?i.push(u.then(d=>d.put(a,n))):i.push(u.put(a,n))}return Promise.all(i)}return t.put?t.constructor.loadAsInstance===!1?t.put(r,s):t.put(s,r):Vn(t,"put")},{hasContent:!0,type:"update"});static patch=On(function(t,r,n,s){return t.patch?t.constructor.loadAsInstance===!1?t.patch(r,s):t.patch(s,r):Vn(t,"patch")},{hasContent:!0,type:"update"});static delete=On(function(t,r,n,s){return t.delete?t.delete(r):Vn(t,"delete")},{hasContent:!1,type:"delete"});static getNewId(){return(0,pU.randomUUID)()}static create(t,r,n){n?n.getContext&&(n=n.getContext()):n=Cu.getStore()??{};let s;return this.loadAsInstance===!1?s=t:t==null?s=r?.[this.primaryKey]??this.getNewId():Array.isArray(t)&&typeof t[0]!="object"?s=r?.[this.primaryKey]??[...t,this.getNewId()]:typeof t!="object"?s=r?.[this.primaryKey]??[t,this.getNewId()]:(s=t?.[this.primaryKey]??this.getNewId(),n=r||{},r=t),vt(n,async()=>{let i=new this(s,n),a=await i.create?i.create(s,r):Vn(i,"create");return n.newLocation=s??a?.[this.primaryKey],n.createdResource=!0,this.loadAsInstance===!1?a:i})}static invalidate=On(function(t,r,n,s){return t.invalidate?t.invalidate(r):Vn(t,"delete")},{hasContent:!1,type:"update"});static post=On(function(t,r,n,s){return t.#e!=null&&t.update?.(),t.constructor.loadAsInstance===!1?t.post(r,s):t.post(s,r)},{hasContent:!0,type:"create"});static update=On(function(t,r,n,s){return t.update(r,s)},{hasContent:!0,type:"create"});static connect=On(function(t,r,n,s){return t.connect?t.constructor.loadAsInstance===!1?t.connect(r,s):t.connect(s,r):Vn(t,"connect")},{hasContent:!0,type:"read"});static subscribe=On(function(t,r,n,s){return t.subscribe?t.subscribe(r):Vn(t,"subscribe")},{type:"read"});static publish=On(function(t,r,n,s){return t.#e!=null&&t.update?.(),t.publish?t.constructor.loadAsInstance===!1?t.publish(r,s):t.publish(s,r):Vn(t,"publish")},{hasContent:!0,type:"create"});static search=On(function(t,r,n){let s=t.search?t.search(r):Vn(t,"search"),i=n.select;if(i&&n.hasOwnProperty("select")&&s!=null&&!s.selectApplied){let a=wE(i,t.constructor);return s.map(a)}return s},{type:"read"});static query=On(function(t,r,n,s){return t.search?t.constructor.loadAsInstance===!1?t.search(r,s):t.search(s,r):Vn(t,"search")},{hasContent:!0,type:"read"});static copy=On(function(t,r,n,s){return t.copy?t.constructor.loadAsInstance===!1?t.copy(r,s):t.copy(s,r):Vn(t,"copy")},{hasContent:!0,type:"create"});static move=On(function(t,r,n,s){return t.move?t.constructor.loadAsInstance===!1?t.move(r,s):t.move(s,r):Vn(t,"move")},{hasContent:!0,type:"delete"});async post(t){if(this.#r)return(await this.constructor.create(this.#e,t,this.#t)).#e;Vn(this,"post")}static isCollection(t){return t&&t.#r}get isCollection(){return this.#r}static coerceId(t){return t}static parseQuery(t,r){return AE(t,r)}static parsePath(t,r,n){let s=t.indexOf(".");if(s>-1){let a=t.slice(s+1),c=r?.headers&&x6[a];if(c)r.requestedContentType=c,t=t.slice(0,s);else if(this.attributes?.find(l=>l.name===a))if(t=t.slice(0,s),n)n.property=a;else return{query:{property:a},id:hU(t,this),isCollection:Qc}}let i=hU(t,this);return Qc?{id:i,isCollection:!0}:i}static getResource(t,r,n){let s,i=r.getContext?.(),a;typeof r.isCollection=="boolean"&&r.hasOwnProperty("isCollection")?a=r.isCollection:a=n?.isCollection;let c=a&&this.Collection||this;if(i||(i=i===void 0?r:{}),i.transaction){let l;if(i.resourceCache?l=i.resourceCache:l=i.resourceCache=[],l.asMap){let u=l.asMap.get(t);if(s=u?.find(d=>d.constructor===c),s)return s;u||l.asMap.set(t,u=[]),u.push(s=new c(t,i))}else{if(s=l.find(u=>u.#e===t&&u.constructor===c),s)return s;if(l.push(s=new c(t,i)),l.length>10){let u=new Map;for(let d of l){let f=d.#e,m=u.get(f);m?m.push(d):u.set(f,[d])}i.resourceCache.length=0,i.resourceCache.asMap=u}}}else s=new c(t,i);return a&&(s.#r=!0),s}subscribe(t){return new $n}connect(t,r){return r?.subscribe!==!1?this.subscribe?.(r):new $n}allowRead(t,r){return t?.role.permission.super_user}allowUpdate(t,r,n){return t?.role.permission.super_user}allowCreate(t,r,n){return t?.role.permission.super_user}allowDelete(t,r){return t?.role.permission.super_user}getId(){return this.#e}getContext(){return this.#t}};(0,_U._assignPackageExport)("Resource",Dr);o(B6,"snakeCase");o(hU,"pathToId");NE=class extends Array{static{o(this,"MultiPartId")}toString(){return this.join("/")}};o(On,"transactional");o(Vn,"missingMethod");o(VA,"selectFromObject");o(wE,"transformForSelect")});var Jc,KA=fe(()=>{Jc=class{static{o(this,"ErrorResource")}error;constructor(t){this.error=t}isError=!0;allowRead(){throw this.error}allowUpdate(){throw this.error}allowCreate(){throw this.error}allowDelete(){throw this.error}getId(){throw this.error}getContext(){throw this.error}get(){throw this.error}post(){throw this.error}put(){throw this.error}delete(){throw this.error}connect(){throw this.error}getResource(){return this}publish(){throw this.error}subscribe(){throw this.error}}});var RU={};Ce(RU,{Resources:()=>OE,keyArrayToString:()=>Pu,resetResources:()=>F6,resources:()=>As});function F6(){return As=new OE,ve.resources=As,As}function Pu(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var SU,TU,OE,As,Lu=fe(()=>{xc();KA();SU=w(z()),TU=w(_e());Pr();OE=class extends Map{static{o(this,"Resources")}isWorker=!0;loginPath;set(t,r,n,s){if(!r)throw new Error("Must provide a resource");t.startsWith("/")&&(t=t.replace(/^\/+/,""));let i={Resource:r,path:t,exportTypes:n,hasSubPaths:!1,relativeURL:""},a=super.get(t);if(a&&(a.Resource.databaseName!==r.databaseName||a.Resource.tableName!==r.tableName)&&!s){let c=new TU.ServerError(`Conflicting paths for ${t}`);SU.default.error(c),i.Resource=new Jc(c)}super.set(t,i);for(let[c,l]of this){let u=2;for(;(u=c.indexOf("/",u))>-1;){let d=this.get(c.slice(0,u));d&&(d.hasSubPaths=!0),u+=2}}}getMatch(t,r){let n=2,s=0,i,a=t.length;for(;n<a;){s=n,n=t.indexOf("/",n),n===-1&&(n=a);let u=n===a?t:t.slice(0,n),d=this.get(u),f=-1;if(!d&&n===a&&(f=u.indexOf("?",s),f!==-1)){let m=u.slice(0,f);d=this.get(m)}if(d&&(!r||d.exportTypes?.[r]!==!1)){if(d.relativeURL=t.slice(f!==-1?f:n),!d.hasSubPaths)return d;i=d}n+=2}if(i)return i;let c=t.indexOf("?"),l=c>-1?t.slice(0,c):t;return i=this.get(l),!i&&l.indexOf(".")>-1&&(i=this.get(l.split(".")[0])),i&&(!r||i.exportTypes?.[r]!==!1)?i.relativeURL=c>-1?t.slice(c):"":i||(i=this.get(""),i&&(!r||i.exportTypes?.[r]!==!1)&&(t.charAt(0)!=="/"&&(t="/"+t),i.relativeURL=t)),i}getResource(t,r){let n=this.getMatch(t);if(n)return t=n.relativeURL,n.Resource.getResource(this.pathToId(t,n.Resource),r)}call(t,r,n){return vt(r,async()=>{let s=this.getMatch(t);if(s)return t=s.relativeURL,n(s.Resource,s.path,t)})}setRepresentation(t,r,n){}};o(F6,"resetResources");o(Pu,"keyArrayToString")});function zA(e,t,r,n,s){let i=e.primaryStore.env.path,a=e.primaryStore.tableId,c;s?.crossThreads===!1?(c=AU,H6(e.primaryStore,e.auditStore)):(c=yU,e.primaryStore.env.hasSubscriptionCommitListener||(e.primaryStore.env.hasSubscriptionCommitListener=!0,e.primaryStore.on("committed",()=>{bU(yU[i])})));let l=c[i]||(c[i]=[]);if(l.auditStore=e.auditStore,l.lastTxnTime==null&&(l.lastTxnTime=Date.now()),s?.scope==="full-database")return;let u=l[a];u||(u=l[a]=new Map,u.envs=l,u.tableId=a,u.store=e.primaryStore),t=Pu(t);let d=new WA(r);d.startTime=n;let f=u.get(t);return f?f.push(d):(u.set(t,f=[d]),f.tables=u,f.key=t),d.subscriptions=f,d}function bU(e){if(!e)return;let t=e.auditStore;t.resetReadTxn(),IU(e.auditStore);let r;for(let{key:n,value:s}of t.getRange({start:e.lastTxnTime,exclusiveStart:!0})){e.lastTxnTime=n;let i=Ut(s),a=e[i.tableId];if(!a)continue;let c=i.recordId,l=Pu(c),u=0;do{let d=a.get(l);if(d){for(let m of d)if(!(u>0&&!(m.includeDescendants&&!(m.onlyChildren&&u>1)))){if(m.startTime>=n){(0,YA.info)("omitting",c,m.startTime,n);continue}try{let h;m.supportsTransactions&&m.txnInProgress!==i.version&&(h=!0,m.txnInProgress||(r?r.push(m):r=[m]),m.txnInProgress=i.version),m.listener(c,i,n,h)}catch(h){console.error(h),(0,YA.info)(h)}}}if(l==null)break;let f=l.lastIndexOf?.("/",l.length-2);f!==l.length-1&&u++,f>-1?l=l.slice(0,f+1):l=null}while(!0)}if(r)for(let n of r)n.txnInProgress=null,n.listener(null,{type:"end_txn"},e.lastTxnTime,!0)}function H6(e,t){let r=t||e,n=r.env;if(!n.hasAfterCommitListener){n.hasAfterCommitListener=!0;let s=n.path;r.on("aftercommit",({next:i,last:a,txnId:c})=>{let l=AU[s];if(!l)return;let u=o(()=>{r.threadLocalWrites||(r.threadLocalWrites=new Float64Array(r.getUserSharedBuffer("last-thread-local-write",new ArrayBuffer(8)))),l.txnTime=r.threadLocalWrites[0]||Date.now();try{bU(l)}finally{r.threadLocalWrites[0]=l.lastTxnTime,r.unlock("thread-local-writes")}},"acquiredLock");r.attemptLock("thread-local-writes",u)&&u()})}}function IU(e){e.nextTransaction?.resolve();let t;e.nextTransaction=new Promise(r=>{t=r}),e.nextTransaction.resolve=t}function NU(e){return e.nextTransaction||(zA({primaryStore:e,auditStore:e},null,null,0,{scope:"full-database"}),IU(e)),e.nextTransaction}var YA,yU,AU,WA,jA=fe(()=>{YA=w(z());_u();Lu();mo();yU=Object.create(null),AU=Object.create(null);o(zA,"addSubscription");WA=class extends $n{static{o(this,"Subscription")}listener;subscriptions;startTime;includeDescendants;supportsTransactions;onlyChildren;constructor(t){super(),this.listener=t,this.on("close",()=>this.end())}end(){if(this.subscriptions){if(this.subscriptions.splice(this.subscriptions.indexOf(this),1),this.subscriptions.length===0){let t=this.subscriptions.tables;if(t){let r=this.subscriptions.key;if(t.delete(r),t.size===0){let n=t.envs,s=t.dbi;delete n[s]}}}this.subscriptions=null}}toJSON(){return{name:"subscription"}}};o(bU,"notifyFromTransactionData");o(H6,"listenToCommits");o(IU,"nextTransaction");o(NU,"whenNextTransaction")});var OU=M((VNe,wU)=>{"use strict";var QA=class{static{o(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};wU.exports=QA});var PU=M((YNe,CU)=>{"use strict";var JA=class{static{o(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};CU.exports=JA});var Rm=M((zNe,DU)=>{"use strict";var LU=ce(),k6=(k(),v(K)),{RecordEncoder:G6}=(Wc(),v(cU));LU.initSync();var q6=LU.get(k6.CONFIG_PARAMS.STORAGE_CACHING)!==!1,XA=class{static{o(this,"OpenDBIObject")}constructor(t,r=!1){this.dupSort=t===!0,this.encoding=t?"ordered-binary":"msgpack",this.useVersions=r,this.sharedStructuresKey=Symbol.for("structures"),r&&(this.cache=q6&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:G6})}};DU.exports=XA});var ym=M((QNe,MU)=>{"use strict";var Kn=ce(),bs=(k(),v(K));Kn.initSync();var CE=class{static{o(this,"OpenEnvironmentObject")}constructor(t,r=!1){this.path=t,this.mapSize=1073741824,this.maxDbs=1e4,this.maxReaders=2048,this.sharedStructuresKey=Symbol.for("structures"),this.readOnly=r,this.trackMetrics=!0,this.eventTurnBatching=!1,this.noSync=Kn.get(bs.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Kn.get(bs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Kn.get(bs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Kn.get(bs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Kn.get(bs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Kn.get(bs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Kn.get(bs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Kn.get(bs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Kn.get(bs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Kn.get(bs.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Kn.get(bs.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Kn.get(bs.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};MU.exports=CE;CE.MAX_DBS=1e4});var Et=M((XNe,$U)=>{"use strict";var eb=require("lmdb"),Zs=require("fs-extra"),Yn=require("path"),PE=An(),xU=z(),Cn=tn().LMDB_ERRORS_ENUM,LE=PU(),tb=Rm(),BU=ym(),Na=kt(),vU=(k(),v(K)),{table:$6,resetDatabases:V6}=(Le(),v(ft)),UU=ce(),ei=Na.INTERNAL_DBIS_NAME,FU=Na.DBI_DEFINITION_NAME,K6="data.mdb",Y6="lock.mdb",Am=".mdb",W6="-lock",ZA=class{static{o(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=Is(t,r),this.key_type=this.dbi[Na.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[Na.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new eb.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function DE(e,t){if(e===void 0)throw new Error(Cn.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(Cn.ENV_NAME_REQUIRED)}o(DE,"pathEnvNameValidation");async function rb(e,t,r=!0){try{await Zs.access(e)}catch(n){throw n.code==="ENOENT"?new Error(Cn.INVALID_BASE_PATH):n}try{let n=Yn.join(e,t+Am);return await Zs.access(n,Zs.constants.R_OK|Zs.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await Zs.access(Yn.join(e,t,K6),Zs.constants.R_OK|Zs.constants.F_OK),Yn.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(Cn.INVALID_ENVIRONMENT)}else throw new Error(Cn.INVALID_ENVIRONMENT);throw n}}o(rb,"validateEnvironmentPath");function ME(e,t){if(PE.validateEnv(e),t===void 0)throw new Error(Cn.DBI_NAME_REQUIRED)}o(ME,"validateEnvDBIName");async function z6(e,t,r=!1,n=!1){DE(e,t);let s=Yn.basename(e);t=t.toString();let i=UU.get(vU.CONFIG_PARAMS.DATABASES);i||UU.setProperty(vU.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await rb(e,t,n),HU(e,t,r)}catch(a){if(a.message===Cn.INVALID_ENVIRONMENT){let c=Yn.join(e,t);await Zs.mkdirp(n?c:e);let l=new BU(n?c:c+Am,!1),u=eb.open(l);u.dbis=Object.create(null);let d=new tb(!1);u.openDB(ei,d),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let f=nb(e,t,r);return u[Na.ENVIRONMENT_NAME_KEY]=f,global.lmdb_map[f]=u,u}throw a}}o(z6,"createEnvironment");async function j6(e,t,r,n=!0){DE(e,t),t=t.toString();let s=Yn.join(e,t);return $6({table:t,database:Yn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}o(j6,"copyEnvironment");async function HU(e,t,r=!1){DE(e,t),t=t.toString();let n=nb(e,t,r);if(global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null)),global.lmdb_map[n]!==void 0)return global.lmdb_map[n];let s=await rb(e,t),i=Yn.join(e,t+Am),a=s!=i,c=new BU(s,a),l=eb.open(c);l.dbis=Object.create(null);let u=GU(l);for(let d=0;d<u.length;d++)Is(l,u[d]);return l[Na.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}o(HU,"openEnvironment");async function Q6(e,t,r=!1){DE(e,t),t=t.toString();let n=Yn.join(e,t+Am),s=await rb(e,t);if(global.lmdb_map!==void 0){let i=nb(e,t,r);if(global.lmdb_map[i]){let a=global.lmdb_map[i];await kU(a),delete global.lmdb_map[i]}}await Zs.remove(s),await Zs.remove(s===n?s+W6:Yn.join(Yn.dirname(s),Y6))}o(Q6,"deleteEnvironment");async function kU(e){PE.validateEnv(e);let t=e[Na.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}o(kU,"closeEnvironment");function nb(e,t,r=!1){let s=`${Yn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}o(nb,"getCachedEnvironmentName");function J6(e){PE.validateEnv(e);let t=Object.create(null),r=Is(e,ei);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==ei)try{t[n]=Object.assign(new LE,s)}catch{xU.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}o(J6,"listDBIDefinitions");function GU(e){PE.validateEnv(e);let t=[],r=Is(e,ei);for(let{key:n}of r.getRange({start:!1}))n!==ei&&t.push(n);return t}o(GU,"listDBIs");function X6(e,t){let n=Is(e,ei).getEntry(t),s=new LE;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{xU.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}o(X6,"getDBIDefinition");function qU(e,t,r,n=!r){if(ME(e,t),t=t.toString(),t===ei)throw new Error(Cn.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return Is(e,t)}catch(s){if(s.message===Cn.DBI_DOES_NOT_EXIST){let i=new tb(r,n===!0),a=e.openDB(t,i),c=new LE(r===!0,n);return a[FU]=c,Is(e,ei).putSync(t,c),e.dbis[t]=a,a}throw s}}o(qU,"createDBI");function Is(e,t){if(ME(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==ei?r=X6(e,t):r=new LE,r===void 0)throw new Error(Cn.DBI_DOES_NOT_EXIST);let n;try{let s=new tb(r.dup_sort,r.useVersions);if(n=e.openDB(t,s),n.db===void 0)throw new Error("MDB_NOTFOUND")}catch(s){throw s.message.includes("MDB_NOTFOUND")===!0?new Error(Cn.DBI_DOES_NOT_EXIST):s}return n[FU]=r,e.dbis[t]=n,n}o(Is,"openDBI");function Z6(e,t){ME(e,t),t=t.toString();let r=Is(e,t),n=r.getStats();return r[Na.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}o(Z6,"statDBI");async function e8(e,t){try{let r=Yn.join(e,t+Am);return(await Zs.stat(r)).size}catch{throw new Error(Cn.INVALID_ENVIRONMENT)}}o(e8,"environmentDataSize");function t8(e,t){if(ME(e,t),t=t.toString(),t===ei)throw new Error(Cn.CANNOT_DROP_INTERNAL_DBIS_NAME);Is(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],Is(e,ei).removeSync(t)}o(t8,"dropDBI");function r8(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{Is(e,i)}catch(a){if(a.message===Cn.DBI_DOES_NOT_EXIST)qU(e,i,i!==t,i===t),n=!0;else throw a}}n&&V6()}o(r8,"initializeDBIs");$U.exports={openDBI:Is,openEnvironment:HU,createEnvironment:z6,listDBIs:GU,listDBIDefinitions:J6,createDBI:qU,dropDBI:t8,statDBI:Z6,deleteEnvironment:Q6,initializeDBIs:r8,TransactionCursor:ZA,environmentDataSize:e8,copyEnvironment:j6,closeEnvironment:kU}});var YU=M((ewe,KU)=>{"use strict";var sb=Et(),n8=z(),VU=tn().LMDB_ERRORS_ENUM;KU.exports=s8;async function s8(e){try{if(global.lmdb_map!==void 0&&e.operation!==void 0){let t=Object.keys(global.lmdb_map),r;switch(e.operation){case"drop_schema":for(let i=0;i<t.length;i++){let a=t[i];if(a.startsWith(`${e.schema}.`)||a.startsWith(`txn.${e.schema}.`))try{await sb.closeEnvironment(global.lmdb_map[a])}catch(c){if(c.message!==VU.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await sb.closeEnvironment(global.lmdb_map[n]),await sb.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==VU.ENV_REQUIRED)throw i}break;case"drop_attribute":r=global.lmdb_map[`${e.schema}.${e.table}`],r!==void 0&&typeof r.dbis=="object"&&r.dbis[`${e.attribute}`]!==void 0&&delete r.dbis[`${e.attribute}`];break;default:break}}}catch(t){n8.error(t)}}o(s8,"cleanLMDBMap")});var Ao=M((rwe,i8)=>{i8.exports={hdb_user:{hash_attribute:"username",name:"hdb_user",schema:"system",residence:["*"],attributes:[{attribute:"username"},{attribute:"password"},{attribute:"role"},{attribute:"active"},{attribute:"hash"},{attribute:"refresh_token"},{attribute:"hash_function"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_role:{hash_attribute:"id",name:"hdb_role",schema:"system",attributes:[{attribute:"id"},{attribute:"role"},{attribute:"permission"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}],residence:["*"]},hdb_job:{hash_attribute:"id",name:"hdb_job",schema:"system",attributes:[{attribute:"id"},{attribute:"user"},{attribute:"type"},{attribute:"status"},{attribute:"start_datetime"},{attribute:"end_datetime"},{attribute:"message"},{attribute:"created_datetime"},{attribute:"request"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_license:{hash_attribute:"license_key",name:"hdb_license",schema:"system",attributes:[{attribute:"license_key"},{attribute:"company"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_info:{hash_attribute:"info_id",name:"hdb_info",schema:"system",attributes:[{attribute:"info_id"},{attribute:"data_version_num"},{attribute:"hdb_version_num"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_nodes:{hash_attribute:"name",name:"hdb_nodes",schema:"system",attributes:[{attribute:"name"},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"},{attribute:"revoked_certificates"},{attribute:"shard"}]},hdb_certificate:{hash_attribute:"name",name:"hdb_certificate",schema:"system",attributes:[{attribute:"name"},{attribute:"uses"},{attribute:"certificate"},{attribute:"is_authority"},{attribute:"private_key_name"},{attribute:"details"},{attribute:"is_self_signed"},{attribute:"__updatedtime__"}]},hdb_analytics_hostname:{hash_attribute:"id",name:"hdb_analytics_hostname",schema:"system",attributes:[{attribute:"id"},{attribute:"hostname"}]},hdb_analytics:{hash_attribute:"id",name:"hdb_analytics",schema:"system",attributes:[{attribute:"id"},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]},hdb_raw_analytics:{hash_attribute:"id",name:"hdb_raw_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{attribute:"time"},{attribute:"metrics"}]},hdb_temp:{hash_attribute:"id",name:"hdb_temp",schema:"system",attributes:[{attribute:"id"}]},hdb_durable_session:{hash_attribute:"id",name:"hdb_durable_session",schema:"system",attributes:[{attribute:"id"}]},hdb_session_will:{hash_attribute:"id",name:"hdb_session_will",schema:"system",attributes:[{attribute:"id"}]}}});var Ns=M((nwe,jU)=>{var o8=Ao(),{promisify:a8}=require("util"),{getDatabases:zU}=(Le(),v(ft));jU.exports={setSchemaDataToGlobal:WU,getTableSchema:c8,getSystemSchema:l8,setSchemaDataToGlobalAsync:a8(WU)};function WU(e){global.hdb_schema=zU(),e&&e()}o(WU,"setSchemaDataToGlobal");function c8(e,t,r){let n=zU()[e];if(!n)return r(`schema ${e} does not exist`);let s=n[t];return s?r(null,{schema:e,name:t,hash_attribute:s.primaryKey}):r(`table ${e}.${t} does not exist`)}o(c8,"getTableSchema");function l8(){return o8}o(l8,"getSystemSchema")});var c0=M((owe,a0)=>{"use strict";var ib=require("recursive-iterator"),u8=require("alasql"),ob=require("clone"),QU=ie(),{handleHDBError:JU,hdbErrors:d8}=_e(),{HDB_ERROR_MSGS:XU,HTTP_STATUS_CODES:ZU}=d8,{getDatabases:f8}=(Le(),v(ft)),m8=["DISTINCT_ARRAY"],e0=Symbol("validateTables"),ab=Symbol("validateTable"),iwe=Symbol("getAllColumns"),t0=Symbol("validateAllColumns"),vE=Symbol("findColumn"),r0=Symbol("validateOrderBy"),bm=Symbol("validateSegment"),cb=Symbol("validateColumn"),n0=Symbol("setColumnsForTable"),s0=Symbol("checkColumnsForAsterisk"),i0=Symbol("validateGroupBy"),o0=Symbol("hasColumns"),lb=class{static{o(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[e0](),this[s0](),this[t0]()}[e0](){if(this[o0]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[ab](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[ab](t.table)})}}[o0](){let t=!1,r=new ib(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[ab](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=f8();if(!r[t.databaseid])throw JU(new Error,XU.SCHEMA_NOT_FOUND(t.databaseid),ZU.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw JU(new Error,XU.TABLE_NOT_FOUND(t.databaseid,t.tableid),ZU.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=ob(s);i.table=ob(t),this.attributes.push(i)})}[vE](t){return this.attributes.filter(r=>t.tableid?(r.table.as===t.tableid||r.table.tableid===t.tableid)&&r.attribute===t.columnid:r.attribute===t.columnid)}[s0](){let t=new ib(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[n0](r.tableid)}[n0](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new u8.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[t0](){this[bm](this.statement.columns,!1),this[bm](this.statement.joins,!1),this[bm](this.statement.where,!1),this[i0](this.statement.group,!1),this[bm](this.statement.order,!0)}[bm](t,r){if(!t)return;let n=new ib(t),s=[];for(let{node:i,path:a}of n)!QU.isEmpty(i)&&!QU.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[r0](i):s.push(this[cb](i)));return s}[i0](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&m8.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=ob(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[vE](n)[0];s&&r.push(s)}}}),this.statement.group.forEach(n=>{let s=null;if(!n.columnid)r.forEach((i,a)=>{if(i.toString()===n.toString()){s=i,r.splice(a,1);return}});else{let i=this[vE](n);if(!i||i.length===0)throw`unknown column '${group_column.toString()}' in group by`;if(i.length>1)throw`ambiguously defined column '${group_column.toString()}' in group by`;r.forEach((a,c)=>{if(a.attribute===i[0].attribute&&a.table.tableid===i[0].table.tableid){s=a,r.splice(c,1);return}})}if(!s)throw`group by column '${group_column.toString()}' must be in select`}),r.length>0)throw`select column '${r[0].attribute?r[0].attribute:r[0].toString()}' must be in group by`}[r0](t){let r=this.statement.columns.filter(n=>n.as===t.columnid);if(r.length>1)throw`ambiguous column reference ${(t.tableid?t.tableid+".":"")+t.columnid} in order by`;r.length===0&&this[cb](t)}[cb](t){let r=this[vE](t),n=(t.tableid?t.tableid+".":"")+t.columnid;if(r.length===0)throw`unknown column ${n}`;if(r.length>1)throw`ambiguous column reference ${n}`;return r[0]}};a0.exports=lb});var u0=M((cwe,l0)=>{"use strict";var ub=class{static{o(this,"BridgeMethods")}createSchema(){throw new Error("createSchema bridge method is not defined")}dropSchema(){throw new Error("dropSchema bridge method is not defined")}createTable(){throw new Error("createTable bridge method is not defined")}dropTable(){throw new Error("dropTable bridge method is not defined")}createRecords(){throw new Error("createRecords bridge method is not defined")}updateRecords(){throw new Error("updateRecords bridge method is not defined")}async upsertRecords(){throw new Error("upsertRecords bridge method is not defined")}deleteRecords(){throw new Error("deleteRecords bridge method is not defined")}createAttribute(){throw new Error("createAttribute bridge method is not defined")}dropAttribute(){throw new Error("dropAttribute bridge method is not defined")}searchByConditions(){throw new Error("searchByConditions bridge method is not defined")}searchByHash(){throw new Error("searchByHash bridge method is not defined")}searchByValue(){throw new Error("searchByValue bridge method is not defined")}getDataByHash(){throw new Error("getDataByHash bridge method is not defined")}getDataByValue(){throw new Error("getDataByValue bridge method is not defined")}deleteRecordsBefore(){throw new Error("deleteRecordsBefore bridge method is not defined")}deleteAuditLogsBefore(){throw new Error("deleteAuditLogsBefore bridge method is not defined")}async readAuditLog(){throw new Error("readAuditLog bridge method is not defined")}};l0.exports=ub});var f0=M((uwe,d0)=>{"use strict";var db=class{static{o(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};d0.exports=db});var h0=M((fwe,m0)=>{"use strict";var fb=class{static{o(this,"UpdateRecordsResponseObject")}constructor(t=[],r=[],n=void 0,s=[]){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n,this.original_records=s}};m0.exports=fb});var _0=M((hwe,p0)=>{"use strict";var mb=class{static{o(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};p0.exports=mb});var Zc=M((Swe,S0)=>{"use strict";var h8=Et(),p8=f0(),_8=h0(),E8=_0(),Li=An(),Im=tn().LMDB_ERRORS_ENUM,g8=kt(),bo=(k(),v(K)),S8=ie(),T8=require("uuid"),_we=require("lmdb"),{handleHDBError:R8,hdbErrors:y8}=_e(),{OVERFLOW_MARKER:Ewe,MAX_SEARCH_KEY_LENGTH:gwe}=g8,E0=ce();E0.initSync();var UE=E0.get(bo.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),hb=bo.TIME_STAMP_NAMES_ENUM.CREATED_TIME,Xc=bo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function A8(e,t,r,n,s=Li.getNextMonotonicTime()){gb(e,t,r,n),pb(e,t,r);let i=new p8,a=[],c=[];for(let l=0;l<n.length;l++){let u=n[l];g0(u,!0,s);let d=b8(e,t,r,u),f=u[t];a.push(d),c.push(f)}return _b(a,c,n,i,s)}o(A8,"insertRecords");function b8(e,t,r,n){let s=n[t];return e.dbis[t].ifNoExists(s,()=>{for(let i=0;i<r.length;i++){let a=r[i];if(a===t||n.hasOwnProperty(a)===!1)continue;let c=n[a];if(typeof c=="function"){let d=c([[{}]]);Array.isArray(d)&&(c=d[0][bo.FUNC_VAL],n[a]=c)}let l=Li.getIndexedValues(c),u=e.dbis[a];if(l){UE&&u.prefetch(l.map(d=>({key:d,value:s})),xE);for(let d=0,f=l.length;d<f;d++)u.put(l[d],s)}}UE&&e.dbis[t].prefetch([s],xE),e.dbis[t].put(s,n,n[Xc])})}o(b8,"insertRecord");function I8(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}o(I8,"removeSkippedRecords");function g0(e,t,r){let n=r>0;(n||!Number.isInteger(e[Xc]))&&(e[Xc]=r||(r=Li.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[hb]))&&(e[hb]=r||Li.getNextMonotonicTime()):delete e[hb]}o(g0,"setTimestamps");function pb(e,t,r){r.indexOf(bo.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(bo.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(bo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(bo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),h8.initializeDBIs(e,t,r)}o(pb,"initializeTransaction");async function N8(e,t,r,n,s=Li.getNextMonotonicTime()){gb(e,t,r,n),pb(e,t,r);let i=new _8,a=[],c=[],l=[];for(let u=0;u<n.length;u++){let d=n[u],f=d[t],m;try{m=Eb(e,t,d,f,i,!0,s)}catch{i.skipped_hashes.push(f),a.push(u);continue}c.push(m),l.push(f)}return _b(c,l,n,i,s,a)}o(N8,"updateRecords");async function w8(e,t,r,n,s=Li.getNextMonotonicTime()){try{gb(e,t,r,n)}catch(l){throw R8(l,l.message,y8.HTTP_STATUS_CODES.BAD_REQUEST)}pb(e,t,r);let i=new E8,a=[],c=[];for(let l=0;l<n.length;l++){let u=n[l],d;S8.isEmpty(u[t])?(d=T8.v4(),u[t]=d):d=u[t];let f=Eb(e,t,u,d,i,!1,s);a.push(f),c.push(d)}return _b(a,c,n,i,s)}o(w8,"upsertRecords");async function _b(e,t,r,n,s,i=[]){let a=await Promise.all(e);for(let c=0,l=a.length;c<l;c++)a[c]===!0?n.written_hashes.push(t[c]):(n.skipped_hashes.push(t[c]),i.push(c));return n.txn_time=s||Li.getNextMonotonicTime(),I8(r,i),n}o(_b,"finalizeWrite");function Eb(e,t,r,n,s,i=!1,a){let c=e.dbis[t],l=c.getEntry(n),u=l?.value,d=u;if(!u){if(i)return!1;u={}}if(g0(r,!d,a),Number.isInteger(r[Xc])&&u[Xc]>r[Xc])return!1;d&&s.original_records.push(u);let f,m=o(()=>{for(let p in r){if(!r.hasOwnProperty(p)||p===t)continue;let E=r[p],g=e.dbis[p];if(g===void 0)continue;let y=u[p];if(typeof E=="function"){let R=E([[u]]);Array.isArray(R)&&(E=R[0][bo.FUNC_VAL],r[p]=E)}if(E===y)continue;let T=Li.getIndexedValues(y);if(T){UE&&g.prefetch(T.map(R=>({key:R,value:n})),xE);for(let R=0,I=T.length;R<I;R++)g.remove(T[R],n)}if(T=Li.getIndexedValues(E),T){UE&&g.prefetch(T.map(R=>({key:R,value:n})),xE);for(let R=0,I=T.length;R<I;R++)g.put(T[R],n)}}let h={...u,...r};c.put(n,h,h[Xc])},"doPut");return l?f=c.ifVersion(n,l.version,m):f=c.ifNoExists(n,m),f.then(h=>h?!0:Eb(e,t,r,n,s,i,a))}o(Eb,"updateUpsertRecord");function O8(e,t,r){if(Li.validateEnv(e),t===void 0)throw new Error(Im.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(Im.WRITE_ATTRIBUTES_REQUIRED):new Error(Im.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}o(O8,"validateBasic");function gb(e,t,r,n){if(O8(e,t,r),!Array.isArray(n))throw n===void 0?new Error(Im.RECORDS_REQUIRED):new Error(Im.RECORDS_MUST_BE_ARRAY)}o(gb,"validateWrite");function xE(){}o(xE,"noop");S0.exports={insertRecords:A8,updateRecords:N8,upsertRecords:w8}});var R0=M((Rwe,T0)=>{"use strict";var C8=require("uuid"),Sb=class{static{o(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||C8.v4(),this.schema_table=`${this.schema}.${this.table}`}};T0.exports=Sb});var BE=M((Awe,y0)=>{"use strict";var P8=R0(),Tb=class extends P8{static{o(this,"LMDBCreateAttributeObject")}constructor(t,r,n,s,i=!0,a=!1){super(t,r,n,s),this.dup_sort=i,this.is_hash_attribute=a}};y0.exports=Tb});var b0=M((Iwe,A0)=>{"use strict";A0.exports=D8;var L8="inserted";function D8(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===L8?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}o(D8,"returnObject")});var FE=M((Owe,N0)=>{"use strict";var M8=(k(),v(K)),Rb=Et(),v8=Zc(),{getSystemSchemaPath:U8,getSchemaPath:x8}=At(),wwe=Ao(),{validateBySchema:B8}=at(),Nm=require("joi"),F8=BE(),H8=b0(),{handleHDBError:k8,hdbErrors:G8,ClientError:q8}=_e(),I0=ie(),{HTTP_STATUS_CODES:$8}=G8,V8="inserted";N0.exports=K8;async function K8(e){let t=B8(e,Nm.object({database:Nm.string(),schema:Nm.string(),table:Nm.string().required(),attribute:Nm.string().required()}));if(t)throw new q8(t.message);let r=!e.skip_table_check&&I0.checkGlobalSchemaTable(e.schema,e.table);if(r)throw k8(new Error,r,$8.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=I0.isEmpty(e.dup_sort)||e.dup_sort=="true";let n=[];if(global.hdb_schema[e.schema]&&global.hdb_schema[e.schema][e.table]&&(n=global.hdb_schema[e.schema][e.table].attributes),Array.isArray(n)&&n.length>0){for(let i of n)if(i.attribute===e.attribute)throw new Error(`attribute '${i.attribute}' already exists in ${e.schema}.${e.table}`)}let s=new F8(e.schema,e.table,e.attribute,e.id);try{let i=await Rb.openEnvironment(x8(e.schema,e.table),e.table);if(i.dbis[e.attribute]!==void 0)throw new Error(`attribute '${create_attribute_obj.attribute}' already exists in ${e.schema}.${e.table}`);Rb.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let a=await Rb.openEnvironment(U8(),M8.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await v8.insertRecords(a,HDB_TABLE_INFO.hash_attribute,hdbAttributeAttributes,[s]);return H8(V8,c,{records:[s]},l)}catch(i){throw i}}o(K8,"lmdbCreateAttribute")});var Mi=M((Pwe,O0)=>{"use strict";var w0=ie(),Y8=(k(),v(K)),Du=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Di=require("joi"),wa={schema_format:{pattern:Du,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},W8=Di.alternatives(Di.string().min(1).max(wa.schema_length.maximum).pattern(Du).messages({"string.pattern.base":"{:#label} "+wa.schema_format.message}),Di.number(),Di.array()).required(),z8=Di.alternatives(Di.string().min(1).max(wa.schema_length.maximum).pattern(Du).messages({"string.pattern.base":"{:#label} "+wa.schema_format.message}),Di.number()),j8=Di.alternatives(Di.string().min(1).max(wa.schema_length.maximum).pattern(Du).messages({"string.pattern.base":"{:#label} "+wa.schema_format.message}),Di.number()).required();function Q8(e,t){return t?typeof t!="string"?`'${property_name}' must be a string`:t.length?t.length>wa.schema_length.maximum?`'${property_name}' maximum of 250 characters`:Du.test(t)?"":`'${property_name}' has illegal characters`:`'${property_name}' must be at least one character`:`'${property_name}' is required`}o(Q8,"checkValidTable");function J8(e,t){return w0.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}o(J8,"validateSchemaExists");function X8(e,t){let r=t.state.ancestors[0].schema;return w0.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}o(X8,"validateTableExists");function Z8(e,t){return e.toLowerCase()===Y8.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${hdb_terms.SYSTEM_SCHEMA_NAME}' name is reserved`):e}o(Z8,"validateSchemaName");O0.exports={commonValidators:wa,schemaRegex:Du,hdbSchemaTable:W8,validateSchemaExists:J8,validateTableExists:X8,validateSchemaName:Z8,checkValidTable:Q8,hdbDatabase:z8,hdbTable:j8}});var Ab=M((Dwe,P0)=>{var{hdbTable:e5,hdbDatabase:C0}=Mi(),t5=at(),yb=require("joi"),r5={undefined:"undefined",null:"null"},n5=o((e,t)=>{let r=Object.keys(e),n=r.length,s;for(let i=0;i<n;i++){let a=r[i];(!a||a.length===0||r5[a]!==void 0)&&(s===void 0?s=`Invalid attribute name: '${a}'`:s+=`. Invalid attribute name: '${a}'`)}return s?t.message(s):e},"customRecordsVal"),s5=yb.object({database:C0,schema:C0,table:e5,records:yb.array().items(yb.object().custom(n5)).required()});P0.exports=function(e){return t5.validateBySchema(e,s5)}});var wm=M((Uwe,D0)=>{"use strict";var Io=ie(),L0=z(),vwe=Ab(),{getDatabases:i5}=(Le(),v(ft)),{ClientError:el}=_e();D0.exports=o5;function o5(e){if(Io.isEmpty(e))throw new el("invalid update parameters defined.");if(Io.isEmptyOrZeroLength(e.schema))throw new el("invalid schema specified.");if(Io.isEmptyOrZeroLength(e.table))throw new el("invalid table specified.");if(!Array.isArray(e.records))throw new el("records must be an array");let t=i5()[e.schema]?.[e.table];if(Io.isEmpty(t))throw new el(`could not retrieve schema:${e.schema} and table ${e.table}`);let r=t.primaryKey,n=new Set,s={},i=!1;return e.operation==="update"&&(i=!0),e.records.forEach(a=>{if(i&&Io.isEmptyOrZeroLength(a[r]))throw L0.error("a valid hash attribute must be provided with update record:",a),new el("a valid hash attribute must be provided with update record, check log for more info");if(!Io.isEmptyOrZeroLength(a[r])&&(a[r]==="null"||a[r]==="undefined"))throw L0.error(`a valid hash value must be provided with ${e.operation} record:`,a),new el(`Invalid hash value: '${a[r]}' is not a valid hash attribute value, check log for more info`);!Io.isEmpty(a[r])&&a[r]!==""&&n.has(Io.autoCast(a[r]))&&(a.skip=!0),n.add(Io.autoCast(a[r]));for(let c in a)s[c]=1}),s[r]=1,{schema_table:t,hashes:Array.from(n),attributes:Object.keys(s)}}o(o5,"insertUpdateValidate")});var HE=M((Bwe,v0)=>{"use strict";var M0=ie(),a5=(k(),v(K)),c5=z(),l5=FE(),u5=BE(),d5=No(),{SchemaEventMsg:f5}=ti(),m5="already exists in";v0.exports=h5;async function h5(e,t,r){if(M0.isEmptyOrZeroLength(r))return r;let n=[];M0.isEmptyOrZeroLength(t.attributes)||t.attributes.forEach(i=>{n.push(i.attribute)});let s=r.filter(i=>n.indexOf(i)<0);return s.length===0||await Promise.all(s.map(async i=>{await p5(e,t.schema,t.name,i)})),s}o(h5,"lmdbCheckForNewAttributes");async function p5(e,t,r,n){let s=new u5(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await _5(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(m5))c5.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}o(p5,"createNewAttribute");async function _5(e){let t;return t=await l5(e),d5.signalSchemaChange(new f5(process.pid,a5.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}o(_5,"createAttribute")});var Mu=M((Hwe,U0)=>{"use strict";var bb=class{static{o(this,"LMDBTransactionObject")}constructor(t,r,n,s,i=void 0){this.operation=t,this.user_name=r,this.timestamp=n,this.hash_values=s,this.origin=i}};U0.exports=bb});var B0=M((Gwe,x0)=>{"use strict";var E5=Mu(),g5=(k(),v(K)).OPERATIONS_ENUM,Ib=class extends E5{static{o(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(g5.INSERT,r,n,s,i),this.records=t}};x0.exports=Ib});var H0=M(($we,F0)=>{"use strict";var S5=Mu(),T5=(k(),v(K)).OPERATIONS_ENUM,Nb=class extends S5{static{o(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,a=void 0){super(T5.UPDATE,n,s,i,a),this.records=t,this.original_records=r}};F0.exports=Nb});var G0=M((Kwe,k0)=>{"use strict";var R5=Mu(),y5=(k(),v(K)).OPERATIONS_ENUM,wb=class extends R5{static{o(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,a=void 0){super(y5.UPSERT,n,s,i,a),this.records=t,this.original_records=r}};k0.exports=wb});var $0=M((Wwe,q0)=>{"use strict";var A5=Mu(),b5=(k(),v(K)).OPERATIONS_ENUM,Ob=class extends A5{static{o(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(b5.DELETE,n,s,t,i),this.original_records=r}};q0.exports=Ob});var Om=M((Qwe,W0)=>{"use strict";var jwe=require("path"),V0=Et(),I5=B0(),N5=H0(),w5=G0(),O5=$0(),vu=kt(),K0=ie(),{CONFIG_PARAMS:C5}=(k(),v(K)),Y0=ce();Y0.initSync();var kE=(k(),v(K)).OPERATIONS_ENUM,{getTransactionAuditStorePath:P5}=At();W0.exports=L5;async function L5(e,t){if(Y0.get(C5.LOGGING_AUDITLOG)===!1)return;let r=P5(e.schema,e.table),n=await V0.openEnvironment(r,e.table,!0),s=D5(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){V0.initializeDBIs(n,vu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,vu.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[vu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[vu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),K0.isEmpty(s.user_name)||n.dbis[vu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let a=0;a<s.hash_values.length;a++)n.dbis[vu.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[a],i)})}}o(L5,"writeTransaction");function D5(e,t){let r=K0.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===kE.INSERT)return new I5(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===kE.UPDATE)return new N5(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===kE.UPSERT)return new w5(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===kE.DELETE)return new O5(t.deleted,t.original_records,r,t.txn_time,e.__origin)}o(D5,"createTransactionObject")});var Cb=M((Zwe,z0)=>{"use strict";var M5=wm(),Xwe=zf(),Cm=(k(),v(K)),v5=jf(),U5=Zc().insertRecords,x5=Et(),B5=z(),F5=HE(),{getSchemaPath:H5}=At(),k5=Om();z0.exports=G5;async function G5(e){try{let{schemaTable:t,attributes:r}=M5(e);v5(e,r,t.hash_attribute),e.schema!==Cm.SYSTEM_SCHEMA_NAME&&(r.includes(Cm.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(Cm.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(Cm.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(Cm.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await F5(e.hdb_auth_header,t,r),s=H5(e.schema,e.table),i=await x5.openEnvironment(s,e.table),a=await U5(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await k5(e,a)}catch(c){B5.error(`unable to write transaction due to ${c.message}`)}return{written_hashes:a.written_hashes,skipped_hashes:a.skipped_hashes,schemaTable:t,new_attributes:n,txn_time:a.txn_time}}catch(t){throw t}}o(G5,"lmdbCreateRecords")});var J0=M((tOe,Q0)=>{"use strict";var j0=(k(),v(K)),q5=Cb(),$5=zf(),V5=require("fs-extra"),{getSchemaPath:K5}=At();Q0.exports=Y5;async function Y5(e){let t=[{name:e.schema,createddate:Date.now()}],r=new $5(j0.SYSTEM_SCHEMA_NAME,j0.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await q5(r),await V5.mkdirp(K5(e.schema))}o(Y5,"lmdbCreateSchema")});var Z0=M((nOe,X0)=>{"use strict";var Pb=class{static{o(this,"DeleteRecordsResponseObject")}constructor(t=[],r=[],n=void 0,s=[]){this.deleted=t,this.skipped=r,this.txn_time=n,this.original_records=s}};X0.exports=Pb});var nx=M((cOe,rx)=>{"use strict";var ex=Et(),Lb=An(),Db=tn().LMDB_ERRORS_ENUM,W5=kt(),tx=z(),iOe=ie(),z5=require("lmdb"),j5=Z0(),Q5=(k(),v(K)),{OVERFLOW_MARKER:oOe,MAX_SEARCH_KEY_LENGTH:aOe}=W5,J5=Q5.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function X5(e,t,r,n){if(Lb.validateEnv(e),t===void 0)throw new Error(Db.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(Db.IDS_REQUIRED):new Error(Db.IDS_MUST_BE_ITERABLE);try{let s=ex.listDBIs(e);ex.initializeDBIs(e,t,s);let i=new j5,a,c=[],l=[];for(let m=0,h=r.length;m<h;m++)try{a=r[m];let p=e.dbis[t].get(a);if(!p||n&&p[J5]>n){i.skipped.push(a);continue}let E=e.dbis[t].ifVersion(a,z5.IF_EXISTS,()=>{e.dbis[t].remove(a);for(let g=0;g<s.length;g++){let y=s[g];if(!p.hasOwnProperty(y)||y===t)continue;let T=e.dbis[y],R=p[y];if(R!=null)try{let I=Lb.getIndexedValues(R);if(I)for(let P=0,Y=I.length;P<Y;P++)T.remove(I[P],a)}catch{tx.warn(`cannot delete from attribute: ${y}, ${R}:${a}`)}}});c.push(E),l.push(a),i.original_records.push(p)}catch(p){tx.warn(p),i.skipped.push(a)}let u=[],d=await Promise.all(c);for(let m=0,h=d.length;m<h;m++)d[m]===!0?i.deleted.push(l[m]):(i.skipped.push(l[m]),u.push(m));let f=0;for(let m=0;m<u.length;m++){let h=u[m];i.original_records.splice(h-f,1),f++}return i.txn_time=Lb.getNextMonotonicTime(),i}catch(s){throw s}}o(X5,"deleteRecords");rx.exports={deleteRecords:X5}});var Pm=M((uOe,ix)=>{"use strict";var Uu=ie(),Z5=nx(),e9=Et(),{getSchemaPath:t9}=At(),r9=Om(),n9=z();ix.exports=s9;async function s9(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(Uu.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(Uu.isEmptyOrZeroLength(e.hash_values)&&!Uu.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];Uu.isEmpty(l)||e.hash_values.push(l)}}if(Uu.isEmptyOrZeroLength(e.hash_values))return sx([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(Uu.isEmptyOrZeroLength(e.records)){e.records=[];for(let c=0;c<e.hash_values.length;c++)e.records[c]={[n]:e.hash_values[c]}}let s=t9(e.schema,e.table),i=await e9.openEnvironment(s,e.table),a=await Z5.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await r9(e,a)}catch(c){n9.error(`unable to write transaction due to ${c.message}`)}return sx(a.deleted,a.skipped,a.txn_time)}catch(s){throw s}}o(s9,"lmdbDeleteRecords");function sx(e,t,r){let n=e.length+t.length,s=n===1?"record":"records";return{message:`${e.length} of ${n} ${s} successfully deleted`,deleted_hashes:e,skipped_hashes:t,txn_time:r}}o(sx,"createDeleteResponse")});var vb=M((mOe,ox)=>{"use strict";var i9=(k(),v(K)),fOe=An();function Mb(e,t){let r=Object.create(null);if(t.length===1&&i9.SEARCH_WILDCARDS.indexOf(t[0])>=0)Object.assign(r,e);else for(let n=0;n<t.length;n++){let s=t[n],i=e[s];r[s]=i===void 0?null:i}return r}o(Mb,"parseRow");function o9(e,t,r,n){let s=Mb(r,e);n.push(s)}o(o9,"searchAll");function a9(e,t,r,n){let s=Mb(r,e);n[t]=s}o(a9,"searchAllToMap");function c9(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}o(c9,"iterateDBI");function tl(e,t,r,n,s){let i=Object.create(null);i[s]=e;let a;n===s?a=e:(a=t,n!==void 0&&(i[n]=a)),r[0].push(a),r[1].push(i)}o(tl,"pushResults");function l9(e,t,r,n,s,i){t.toString().endsWith(e)&&tl(t,r,n,s,i)}o(l9,"endsWith");function u9(e,t,r,n,s,i){t.toString().includes(e)&&tl(t,r,n,s,i)}o(u9,"contains");function d9(e,t,r,n,s,i){t>e&&tl(t,r,n,s,i)}o(d9,"greaterThanCompare");function f9(e,t,r,n,s,i){t>=e&&tl(t,r,n,s,i)}o(f9,"greaterThanEqualCompare");function m9(e,t,r,n,s,i){t<e&&tl(t,r,n,s,i)}o(m9,"lessThanCompare");function h9(e,t,r,n,s,i){t<=e&&tl(t,r,n,s,i)}o(h9,"lessThanEqualCompare");ox.exports={parseRow:Mb,searchAll:o9,searchAllToMap:a9,iterateDBI:c9,endsWith:l9,contains:u9,greaterThanCompare:d9,greaterThanEqualCompare:f9,lessThanCompare:m9,lessThanEqualCompare:h9,pushResults:tl}});var xu=M((gOe,mx)=>{"use strict";var Oa=Et(),pOe=z(),Wn=An(),GE=kt(),Jt=tn().LMDB_ERRORS_ENUM,_Oe=ie(),p9=(k(),v(K)),qE=vb(),{parseRow:_9}=qE,EOe=require("lmdb"),{OVERFLOW_MARKER:ax,MAX_SEARCH_KEY_LENGTH:E9}=GE;function cx(e,t,r,n=!1,s=void 0,i=void 0){return rl(e,t,r,(a,c)=>c.getRange({transaction:a,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}))}o(cx,"iterateFullIndex");function Lm(e,t,r,n,s,i=!1,a=void 0,c=void 0,l=!1,u=!1){return rl(e,t,r,(d,f,m,h)=>{let T={transaction:d,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:a,offset:c,inclusiveEnd:i===!0?!l:!u,exclusiveStart:i===!0?u:l};return h===r?(T.values=!1,f.getRange(T).map(R=>({value:R}))):f.getRange(T)})}o(Lm,"iterateRangeBetween");function rl(e,t,r,n){let s=e.database||e,i=Oa.openDBI(s,r);i[GE.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&Oa.openDBI(s,t);let a;e.database?a=e:(a=e.useReadTransaction(),a.database=e);let c=n(a,i,s,t);return c.transaction=a,e.database||(c.onDone=()=>{a.done()}),c}o(rl,"setupTransaction");function lx(e,t,r,n){let s;return function(i,a){if(typeof i=="string"&&i.endsWith(ax)){if(!s)if(r)s=Oa.openDBI(e,r);else{let l=Oa.listDBIs(e);for(let u=0,d=l.length;u<d&&(s=Oa.openDBI(e,l[u]),!s[GE.DBI_DEFINITION_NAME].is_hash_attribute);u++);}i=s.get(a,{transaction:t,lazy:!0})[n]}return i}}o(lx,"getOverflowCheck");function g9(e,t,r,n=!1,s=void 0,i=void 0){if(Wn.validateEnv(e),t===void 0)throw new Error(Jt.HASH_ATTRIBUTE_REQUIRED);return rl(e,t,t,(a,c,l)=>($E(r),r=Dm(l,r),c.getRange({transaction:a,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(u=>_9(u.value,r))))}o(g9,"searchAll");function S9(e,t,r,n=!1,s=void 0,i=void 0){if(Wn.validateEnv(e),t===void 0)throw new Error(Jt.HASH_ATTRIBUTE_REQUIRED);$E(r),r=Dm(e.database||e,r);let a=new Map;for(let{key:c,value:l}of cx(e,t,t,n,s,i))a.set(c,qE.parseRow(l,r));return a}o(S9,"searchAllToMap");function T9(e,t,r=!1,n=void 0,s=void 0){if(Wn.validateEnv(e),t===void 0)throw new Error(Jt.ATTRIBUTE_REQUIRED);let i=Object.create(null),a=cx(e,void 0,t,r,n,s),c=a.transaction,l=lx(c.database,c,void 0,t);for(let{key:u,value:d}of a){let f=l(u,d);i[f]===void 0&&(i[f]=[]),i[f].push(d)}return i}o(T9,"iterateDBI");function R9(e,t){if(Wn.validateEnv(e),t===void 0)throw new Error(Jt.HASH_ATTRIBUTE_REQUIRED);return Oa.statDBI(e,t).entryCount}o(R9,"countAll");function y9(e,t,r,n,s=!1,i=void 0,a=void 0){return Ca(e,r,n),rl(e,t,r,(c,l,u,d)=>(n=Wn.convertKeyValueToWrite(n),d===r?l.get(n,{transaction:c,lazy:!0})===void 0?[]:[{key:n,value:n}]:l.getValues(n,{transaction:c,reverse:s,limit:i,offset:a}).map(f=>({key:n,value:f}))))}o(y9,"equals");function A9(e,t,r){return Ca(e,t,r),Oa.openDBI(e,t).getValuesCount(r)}o(A9,"count");function b9(e,t,r,n,s=!1,i=void 0,a=void 0){return Ca(e,r,n),rl(e,null,r,(c,l)=>{n=Wn.convertKeyValueToWrite(n);let u=!0;typeof n=="number"&&(u=!1);let d;if(s===!0){let f;for(let m of l.getKeys({transaction:c,start:n}))if(!m.startsWith(n)){f=m;break}return f!==void 0&&(Number.isInteger(a)?a++:i++),d=l.getRange({transaction:c,start:f,end:void 0,reverse:s,limit:i,offset:a}).map(m=>{let{key:h}=m;if(h!==f){if(h.toString().startsWith(n))return m;if(u===!0)return d.DONE}}),d.filter(m=>m)}else return d=l.getRange({transaction:c,start:n,reverse:s,limit:i,offset:a}).map(f=>{if(f.key.toString().startsWith(n))return f;if(u===!0)return d.DONE}),u?d:d.filter(f=>f)})}o(b9,"startsWith");function I9(e,t,r,n,s=!1,i=void 0,a=void 0){return ux(e,t,r,n,s,i,a,!0)}o(I9,"endsWith");function ux(e,t,r,n,s=!1,i=void 0,a=void 0,c=!1){return Ca(e,r,n),rl(e,null,r,(l,u,d,f)=>{let m=lx(d,l,f,r);return a=Number.isInteger(a)?a:0,u.getKeys({transaction:l,end:s?!1:void 0,reverse:s}).flatMap(h=>{let p=h.toString();return p.endsWith(ax)?u.getValues(h,{transaction:l}).map(E=>{let g=m(h,E);if(c?g.endsWith(n):g.includes(n))return{key:g,value:E}}).filter(E=>E):(c?p.endsWith(n):p.includes(n))?u[GE.DBI_DEFINITION_NAME].is_hash_attribute?{key:h,value:h}:u.getValues(h,{transaction:l}).map(E=>({key:h,value:E})):[]}).slice(a,i===void 0?void 0:i+(a||0))})}o(ux,"contains");function N9(e,t,r,n,s=!1,i=void 0,a=void 0){Ca(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),Lm(e,t,r,n,l,s,i,a,!0,!1)}o(N9,"greaterThan");function w9(e,t,r,n,s=!1,i=void 0,a=void 0){Ca(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),Lm(e,t,r,n,l,s,i,a,!1,!1)}o(w9,"greaterThanEqual");function O9(e,t,r,n,s=!1,i=void 0,a=void 0){Ca(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),Lm(e,t,r,l,n,s,i,a,!1,!0)}o(O9,"lessThan");function C9(e,t,r,n,s=!1,i=void 0,a=void 0){Ca(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),Lm(e,t,r,l,n,s,i,a,!1,!1)}o(C9,"lessThanEqual");function P9(e,t,r,n,s,i=!1,a=void 0,c=void 0){if(Wn.validateEnv(e),r===void 0)throw new Error(Jt.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(Jt.START_VALUE_REQUIRED);if(s===void 0)throw new Error(Jt.END_VALUE_REQUIRED);if(n=Wn.convertKeyValueToWrite(n),s=Wn.convertKeyValueToWrite(s),n>s)throw new Error(Jt.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return Lm(e,t,r,n,s,i,a,c)}o(P9,"between");function L9(e,t,r,n){Wn.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(Jt.HASH_ATTRIBUTE_REQUIRED);if($E(r),r=Dm(s,r),n===void 0)throw new Error(Jt.ID_REQUIRED);let a=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(a=qE.parseRow(c,r)),a}o(L9,"searchByHash");function D9(e,t,r){Wn.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(Jt.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Jt.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}o(D9,"checkHashExists");function M9(e,t,r,n,s=[]){return fx(e,t,r,n,s),dx(e,t,r,n,s).map(i=>i[1])}o(M9,"batchSearchByHash");function v9(e,t,r,n,s=[]){fx(e,t,r,n,s);let i=new Map;for(let[a,c]of dx(e,t,r,n,s))i.set(a,c);return i}o(v9,"batchSearchByHashToMap");function dx(e,t,r,n,s=[]){return rl(e,t,t,(i,a,c)=>{r=Dm(c,r);let l=r.length<3;return n.map(u=>{let d=c.dbis[t].get(u,{transaction:i,lazy:l});if(d)return[u,qE.parseRow(d,r)];s.push(u)}).filter(u=>u)})}o(dx,"batchHashSearch");function fx(e,t,r,n,s){if(Wn.validateEnv(e),t===void 0)throw new Error(Jt.HASH_ATTRIBUTE_REQUIRED);if($E(r),n==null)throw new Error(Jt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(Jt.IDS_MUST_BE_ITERABLE)}o(fx,"initializeBatchSearchByHash");function $E(e){if(!Array.isArray(e))throw e===void 0?new Error(Jt.FETCH_ATTRIBUTES_REQUIRED):new Error(Jt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}o($E,"validateFetchAttributes");function Ca(e,t,r){if(Wn.validateEnv(e),t===void 0)throw new Error(Jt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Jt.SEARCH_VALUE_REQUIRED);if(r?.length>E9)throw new Error(Jt.SEARCH_VALUE_TOO_LARGE)}o(Ca,"validateComparisonFunctions");function Dm(e,t){return t.length===1&&p9.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=Oa.listDBIs(e)),t}o(Dm,"setGetWholeRowAttributes");mx.exports={searchAll:g9,searchAllToMap:S9,count:A9,countAll:R9,equals:y9,startsWith:b9,endsWith:I9,contains:ux,searchByHash:L9,setGetWholeRowAttributes:Dm,batchSearchByHash:M9,batchSearchByHashToMap:v9,checkHashExists:D9,iterateDBI:T9,greaterThan:N9,greaterThanEqual:w9,lessThan:O9,lessThanEqual:C9,between:P9}});var Bu=M((TOe,gx)=>{var hx=require("lodash"),px=at(),$e=require("joi"),U9=ie(),{hdbSchemaTable:Mm,checkValidTable:_x,hdbTable:Ex,hdbDatabase:VE}=Mi(),{handleHDBError:x9,hdbErrors:B9}=_e(),{getDatabases:F9}=(Le(),v(ft)),{HTTP_STATUS_CODES:H9}=B9,k9=$e.object({database:VE,schema:VE,table:Ex,search_attribute:Mm,search_value:$e.any().required(),get_attributes:$e.array().min(1).items($e.alternatives(Mm,$e.object())).optional(),desc:$e.bool(),limit:$e.number().integer().min(1),offset:$e.number().integer().min(0)}),G9=$e.object({database:VE,schema:VE,table:Ex,operator:$e.string().valid("and","or").default("and").lowercase(),offset:$e.number().integer().min(0),limit:$e.number().integer().min(1),get_attributes:$e.array().min(1).items($e.alternatives(Mm,$e.object())).optional(),sort:$e.object({attribute:$e.alternatives(Mm,$e.array().min(1)),descending:$e.bool().optional()}).optional(),conditions:$e.array().min(1).items($e.alternatives($e.object({operator:$e.string().valid("and","or").default("and").lowercase(),conditions:$e.array()}),$e.object({search_attribute:$e.alternatives(Mm,$e.array().min(1)),search_type:$e.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:$e.when("search_type",{switch:[{is:"equals",then:$e.any()},{is:"between",then:$e.array().items($e.alternatives([$e.string(),$e.number()])).length(2)}],otherwise:$e.alternatives($e.string(),$e.number())}).required()}))).required()});gx.exports=function(e,t){let r=null;switch(t){case"value":r=px.validateBySchema(e,k9);break;case"hashes":let i=function(a){s?s+=". "+a:s=a};var n=i;o(i,"addError");let s;i(_x("database",e.schema)),i(_x("table",e.table)),e.hash_values?Array.isArray(e.hash_values)?e.hash_values.every(a=>typeof a=="string"||typeof a=="number")||i("'hash_values' must be strings or numbers"):i("'hash_values' must be an array"):i("'hash_values' is required"),e.get_attributes?Array.isArray(e.get_attributes)?e.get_attributes.length===0?i("'get_attributes' must contain at least 1 item"):e.get_attributes.every(a=>typeof a=="string"||typeof a=="number")||i("'get_attributes' must be strings or numbers"):i("'get_attributes' must be an array"):i("'get_attributes' is required"),s&&(r=new Error(s.trim()));break;case"conditions":r=px.validateBySchema(e,G9);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=U9.checkGlobalSchemaTable(e.schema,e.table);if(s)return x9(new Error,s,H9.NOT_FOUND);let a=F9()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let l=o(d=>{for(let f=0,m=d.conditions.length;f<m;f++){let h=d.conditions[f];h.conditions?l(h):c.push(h.search_attribute)}},"addConditions");t==="conditions"&&l(e);let u=hx.filter(c,d=>d!=="*"&&!d.startsWith?.("$")&&d.attribute!=="*"&&!Array.isArray(d)&&!d.name&&!hx.some(a,f=>f===d||f.attribute===d||f.attribute===d.attribute));if(u&&u.length>0){let d=u.join(", ");return d=d.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${d}'`)}}return r}});var Ub=M((yOe,Sx)=>{"use strict";var q9=Et(),$9=Bu(),{getSchemaPath:V9}=At();Sx.exports=K9;function K9(e){let t=$9(e,"hashes");if(t)throw t;let r=V9(e.schema,e.table);return q9.openEnvironment(r,e.table)}o(K9,"initialize")});var xb=M((bOe,Tx)=>{"use strict";var Y9=xu(),W9=Ub();Tx.exports=z9;async function z9(e){let t=await W9(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return Y9.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}o(z9,"lmdbGetDataByHash")});var Fu=M((NOe,Rx)=>{"use strict";var Bb=class{static{o(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};Rx.exports=Bb});var Ax=M((COe,yx)=>{"use strict";var OOe=Fu(),j9=xu(),Q9=Ub();yx.exports=J9;async function J9(e){let t=await Q9(e),r=global.hdb_schema[e.schema][e.table];return j9.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}o(J9,"lmdbSearchByHash")});var ri=M((LOe,bx)=>{"use strict";var Fb=class{static{o(this,"SearchObject")}constructor(t,r,n,s,i,a,c,l=!1,u=void 0,d=void 0){this.schema=t,this.table=r,this.search_attribute=n,this.search_value=s,this.hash_attribute=i,this.get_attributes=a,this.end_value=c,this.reverse=l,this.limit=u,this.offset=d}};bx.exports=Fb});var KE=M((MOe,Px)=>{"use strict";var sn=xu(),X9=Et(),Z9=ie(),Ve=kt(),nl=(k(),v(K)),e7=Ao(),Ix=tn().LMDB_ERRORS_ENUM,{getSchemaPath:t7}=At(),wo=nl.SEARCH_WILDCARDS;async function r7(e,t,r){let n;e.schema===nl.SYSTEM_SCHEMA_NAME?n=e7[e.table]:n=global.hdb_schema[e.schema][e.table];let s=Cx(e,n.hash_attribute,r,t);return wx(e,s,n.hash_attribute,r)}o(r7,"prepSearch");async function wx(e,t,r,n){let s=t7(e.schema,e.table),i=await X9.openEnvironment(s,e.table),a=Ox(i,e,t,r),c=a.transaction||i;if([Ve.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,Ve.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,Ve.SEARCH_TYPES.SEARCH_ALL,Ve.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return a;if(n7(e,r)===!1){let d=e.search_attribute;if(d===r)return n?Nx(a,()=>!0):a.map(m=>({[r]:m.key}));let f=o(m=>({[r]:m.value,[d]:m.key}),"toObject");return n?Nx(a,f):a.map(f)}let u=e.search_attribute===r?a.map(d=>d.key):a.map(d=>d.value);return n===!0?sn.batchSearchByHashToMap(c,r,e.get_attributes,u):sn.batchSearchByHash(c,r,e.get_attributes,u)}o(wx,"executeSearch");function Ox(e,t,r,n){let s,i=n;t.get_attributes.indexOf(n)<0&&(i=void 0);let{reverse:a,limit:c,offset:l}=t;switch(a=typeof a=="boolean"?a:!1,c=Number.isInteger(c)?c:void 0,l=Number.isInteger(l)?l:void 0,r){case Ve.SEARCH_TYPES.EQUALS:s=sn.equals(e,i,t.search_attribute,t.search_value,a,c,l);break;case Ve.SEARCH_TYPES.CONTAINS:s=sn.contains(e,i,t.search_attribute,t.search_value,a,c,l);break;case Ve.SEARCH_TYPES.ENDS_WITH:case Ve.SEARCH_TYPES._ENDS_WITH:s=sn.endsWith(e,i,t.search_attribute,t.search_value,a,c,l);break;case Ve.SEARCH_TYPES.STARTS_WITH:case Ve.SEARCH_TYPES._STARTS_WITH:s=sn.startsWith(e,i,t.search_attribute,t.search_value,a,c,l);break;case Ve.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return sn.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case Ve.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return sn.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case Ve.SEARCH_TYPES.SEARCH_ALL:return sn.searchAll(e,n,t.get_attributes,a,c,l);case Ve.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return sn.searchAllToMap(e,n,t.get_attributes,a,c,l);case Ve.SEARCH_TYPES.BETWEEN:s=sn.between(e,i,t.search_attribute,t.search_value,t.end_value,a,c,l);break;case Ve.SEARCH_TYPES.GREATER_THAN:case Ve.SEARCH_TYPES._GREATER_THAN:s=sn.greaterThan(e,i,t.search_attribute,t.search_value,a,c,l);break;case Ve.SEARCH_TYPES.GREATER_THAN_EQUAL:case Ve.SEARCH_TYPES._GREATER_THAN_EQUAL:s=sn.greaterThanEqual(e,i,t.search_attribute,t.search_value,a,c,l);break;case Ve.SEARCH_TYPES.LESS_THAN:case Ve.SEARCH_TYPES._LESS_THAN:s=sn.lessThan(e,i,t.search_attribute,t.search_value,a,c,l);break;case Ve.SEARCH_TYPES.LESS_THAN_EQUAL:case Ve.SEARCH_TYPES._LESS_THAN_EQUAL:s=sn.lessThanEqual(e,i,t.search_attribute,t.search_value,a,c,l);break;default:return Object.create(null)}return s}o(Ox,"searchByType");function Nx(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}o(Nx,"createMapFromIterable");function n7(e,t){if(e.get_attributes.length===1&&e.get_attributes[0]==="*")return!0;let r=[e.search_attribute];e.get_attributes.indexOf(t)>=0&&r.push(t);let n=!1;for(let s=0;s<e.get_attributes.length;s++)if(r.indexOf(e.get_attributes[s])<0){n=!0;break}return n}o(n7,"checkToFetchMore");function Cx(e,t,r,n){if(Z9.isEmpty(n)){let s=e.search_value;typeof s=="object"?s=JSON.stringify(s):s=s.toString();let i=s.charAt(0),a=s.charAt(s.length-1),c=!1;if(e.search_attribute===t&&(c=!0),wo.indexOf(s)>-1)return r===!0?Ve.SEARCH_TYPES.SEARCH_ALL_TO_MAP:Ve.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(wo[0])<0&&s.indexOf(wo[1])<0)return c===!0?r===!0?Ve.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:Ve.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:Ve.SEARCH_TYPES.EQUALS;if(wo.indexOf(i)>=0&&wo.indexOf(a)>=0)return e.search_value=e.search_value.slice(1,-1),Ve.SEARCH_TYPES.CONTAINS;if(wo.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),Ve.SEARCH_TYPES.ENDS_WITH;if(wo.indexOf(a)>=0)return e.search_value=e.search_value.slice(0,-1),Ve.SEARCH_TYPES.STARTS_WITH;if(s.includes(wo[0])||s.includes(wo[1]))return Ve.SEARCH_TYPES.EQUALS;throw new Error(Ix.UNKNOWN_SEARCH_TYPE)}else switch(n){case nl.VALUE_SEARCH_COMPARATORS.BETWEEN:return Ve.SEARCH_TYPES.BETWEEN;case nl.VALUE_SEARCH_COMPARATORS.GREATER:return Ve.SEARCH_TYPES.GREATER_THAN;case nl.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return Ve.SEARCH_TYPES.GREATER_THAN_EQUAL;case nl.VALUE_SEARCH_COMPARATORS.LESS:return Ve.SEARCH_TYPES.LESS_THAN;case nl.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return Ve.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(Ix.UNKNOWN_SEARCH_TYPE)}}o(Cx,"createSearchTypeFromSearchObject");Px.exports={executeSearch:wx,createSearchTypeFromSearchObject:Cx,prepSearch:r7,searchByType:Ox}});var Dx=M((xOe,Lx)=>{"use strict";var UOe=ri(),s7=Bu(),i7=ie(),o7=(k(),v(K)),a7=KE();Lx.exports=c7;function c7(e,t){if(!i7.isEmpty(t)&&o7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=s7(e,"value");if(n)throw n;return a7.prepSearch(e,t,!0)}o(c7,"lmdbGetDataByValue")});var vm=M((HOe,Mx)=>{"use strict";var FOe=ri(),l7=Bu(),u7=ie(),d7=(k(),v(K)),f7=KE();Mx.exports=m7;async function m7(e,t){if(!u7.isEmpty(t)&&d7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=l7(e,"value");if(n)throw n;return f7.prepSearch(e,t,!1)}o(m7,"lmdbSearchByValue")});var Ux=M((qOe,vx)=>{"use strict";var GOe=kt(),Hb=class{static{o(this,"SearchByConditionsObject")}constructor(t,r,n,s,i=void 0,a=void 0,c="and"){this.schema=t,this.table=r,this.get_attributes=n,this.limit=i,this.offset=a,this.conditions=s,this.operator=c}},kb=class{static{o(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},Gb=class{static{o(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};vx.exports={SearchByConditionsObject:Hb,SearchCondition:kb,SortAttribute:Gb}});var kx=M((YOe,Hx)=>{"use strict";var VOe=Ux().SearchByConditionsObject,h7=ri(),p7=Bu(),qb=xu(),YE=kt(),{Resource:KOe}=(Ia(),v(gU)),Fx=KE(),_7=vb(),E7=require("lodash"),{getSchemaPath:g7}=At(),xx=Et(),{handleHDBError:S7,hdbErrors:T7}=_e(),{HTTP_STATUS_CODES:R7}=T7,y7=1e8;Hx.exports=A7;async function A7(e){let t=p7(e,"conditions");if(t)throw S7(t,t.message,R7.BAD_REQUEST,void 0,void 0,!0);e.operator=e.operator?e.operator.toLowerCase():void 0,e.offset=Number.isInteger(e.offset)?e.offset:0;let r=g7(e.schema,e.table),n=await xx.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let u of e.conditions)xx.openDBI(n,u.search_attribute);let i=E7.sortBy(e.conditions,u=>{if(u.estimated_count===void 0){let d=u.search_type;d===YE.SEARCH_TYPES.EQUALS?u.estimated_count=qb.count(n,u.search_attribute,u.search_value):d===YE.SEARCH_TYPES.CONTAINS||d===YE.SEARCH_TYPES.ENDS_WITH?u.estimated_count=1/0:u.estimated_count=y7}return u.estimated_count}),a=n.useReadTransaction();a.database=n;let c=await Bx(a,e,i[0],s.hash_attribute),l;if(!e.operator||e.operator.toLowerCase()==="and"){let u=n.dbis[s.hash_attribute],d=i.slice(1).map(Fx.filterByType),f=d.length,m=qb.setGetWholeRowAttributes(n,e.get_attributes);l=c.map(h=>u.get(h,{transaction:a,lazy:!0})),f>0&&(l=l.filter(h=>{for(let p=0;p<f;p++)if(!d[p](h))return!1;return!0})),(e.offset||e.limit!==void 0)&&(l=l.slice(e.offset,e.limit!==void 0?(e.offset||0)+e.limit:void 0)),l=l.map(h=>_7.parseRow(h,m))}else{for(let f=1;f<i.length;f++){let m=i[f],h=await Bx(a,e,m,s.hash_attribute);c=c.concat(h)}let u=new Set,d=e.offset||0;c=c.filter(f=>u.has(f)?!1:(u.add(f),!0)).slice(d,e.limit&&e.limit+d),l=qb.batchSearchByHash(a,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{a.done()},l}o(A7,"lmdbSearchByConditions");async function Bx(e,t,r,n){let s=new h7(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===YE.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,Fx.searchByType(e,s,i,n).map(a=>a.value)}o(Bx,"executeConditionSearch")});var Um=M((zOe,Gx)=>{"use strict";var b7=(k(),v(K)).OPERATIONS_ENUM,$b=class{static{o(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=b7.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};Gx.exports=$b});var Vb=M((QOe,jx)=>{"use strict";var Kx=ri(),Yx=Um(),Wx=vm(),zx=Pm(),Pn=(k(),v(K)),qx=ie(),$x=Et(),{getTransactionAuditStorePath:I7,getSchemaPath:N7}=At(),Vx=z();jx.exports=w7;async function w7(e){try{if(qx.isEmpty(global.hdb_schema[e.schema])||qx.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await O7(e),await C7(e);let t=N7(e.schema,e.table);try{await $x.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")Vx.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=I7(e.schema,e.table);await $x.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")Vx.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}o(w7,"lmdbDropTable");async function O7(e){let t=new Kx(Pn.SYSTEM_SCHEMA_NAME,Pn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Pn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Pn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await Wx(t)),n=[];for(let i=0;i<r.length;i++){let a=r[i];n.push(a.id)}if(n.length===0)return;let s=new Yx(Pn.SYSTEM_SCHEMA_NAME,Pn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await zx(s)}o(O7,"deleteAttributesFromSystem");async function C7(e){let t=new Kx(Pn.SYSTEM_SCHEMA_NAME,Pn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Pn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[Pn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,Pn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,Pn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await Wx(t))}catch(i){throw i}for(let i=0;i<r.length;i++){let a=r[i];a.name===e.table&&a.schema===e.schema&&(n=a)}if(!n)throw new Error(`${e.schema}.${e.table} was not found`);let s=new Yx(Pn.SYSTEM_SCHEMA_NAME,Pn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await zx(s)}catch(i){throw i}}o(C7,"dropTableFromSystem")});var Jx=M((XOe,Qx)=>{"use strict";var P7=require("fs-extra"),L7=ri(),D7=Fu(),M7=Um(),v7=Vb(),U7=Pm(),x7=xb(),B7=vm(),Oo=(k(),v(K)),{getSchemaPath:F7}=At(),{handleHDBError:H7,hdbErrors:k7}=_e(),{HDB_ERROR_MSGS:G7,HTTP_STATUS_CODES:q7}=k7;Qx.exports=$7;async function $7(e){let t;try{t=await V7(e.schema);let r=new L7(Oo.SYSTEM_SCHEMA_NAME,Oo.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Oo.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[Oo.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await B7(r));for(let a=0;a<n.length;a++){let c={schema:t,table:n[a].name};try{await v7(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new M7(Oo.SYSTEM_SCHEMA_NAME,Oo.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await U7(s);let i=F7(t);await P7.remove(i)}catch(r){throw r}}o($7,"lmdbDropSchema");async function V7(e){let t=new D7(Oo.SYSTEM_SCHEMA_NAME,Oo.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[Oo.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await x7(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw H7(new Error,G7.SCHEMA_NOT_FOUND(e),q7.NOT_FOUND,void 0,void 0,!0);return n}o(V7,"validateDropSchema")});var xm=M((eCe,Xx)=>{"use strict";var Kb=class{static{o(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};Xx.exports=Kb});var Wb=M((nCe,Zx)=>{"use strict";var K7=require("fs-extra"),WE=Et(),{getTransactionAuditStorePath:Y7}=At(),Yb=kt(),rCe=xm();Zx.exports=W7;async function W7(e){let t;try{let r=Y7(e.schema,e.table);await K7.mkdirp(r),t=await WE.createEnvironment(r,e.table,!0)}catch(r){throw r.message=`unable to create transactions audit environment for ${e.schema}.${e.table} due to: ${r.message}`,r}try{WE.createDBI(t,Yb.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),WE.createDBI(t,Yb.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),WE.createDBI(t,Yb.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME,!0,!1)}catch(r){throw r.message=`unable to create dbi for ${e.schema}.${e.table} due to: ${r.message}`,r}return t}o(W7,"createTransactionsAuditEnvironment")});var rB=M((oCe,tB)=>{"use strict";var zb=(k(),v(K)),eB=Et(),z7=Zc(),{getSystemSchemaPath:j7,getSchemaPath:Q7}=At(),iCe=Ao(),J7=FE(),jb=BE(),X7=z(),Z7=Wb();tB.exports=eee;async function eee(e,t){let r=Q7(t.schema,t.table),n=new jb(t.schema,t.table,zb.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new jb(t.schema,t.table,zb.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new jb(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await eB.createEnvironment(r,t.table),e!==void 0){let a=await eB.openEnvironment(j7(),zb.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await z7.insertRecords(a,HDB_TABLE_INFO.hash_attribute,hdbTableAttributes,[e]),n.skip_table_check=!0,s.skip_table_check=!0,i.skip_table_check=!0,await Qb(n),await Qb(s),await Qb(i)}await Z7(t)}catch(a){throw a}}o(eee,"lmdbCreateTable");async function Qb(e){try{await J7(e)}catch(t){X7.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}o(Qb,"createAttribute")});var sB=M((cCe,nB)=>{"use strict";var tee=wm(),ree=jf(),nee=HE(),Bm=(k(),v(K)),see=Zc().updateRecords,iee=Et(),{getSchemaPath:oee}=At(),aee=Om(),cee=z();nB.exports=lee;async function lee(e){try{let{schemaTable:t,attributes:r}=tee(e);ree(e,r,t.hash_attribute),e.schema!==Bm.SYSTEM_SCHEMA_NAME&&(r.includes(Bm.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(Bm.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(Bm.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(Bm.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await nee(e.hdb_auth_header,t,r),s=oee(e.schema,e.table),i=await iee.openEnvironment(s,e.table),a=await see(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await aee(e,a)}catch(c){cee.error(`unable to write transaction due to ${c.message}`)}return{written_hashes:a.written_hashes,skipped_hashes:a.skipped_hashes,schemaTable:t,new_attributes:n,txn_time:a.txn_time}}catch(t){throw t}}o(lee,"lmdbUpdateRecords")});var oB=M((uCe,iB)=>{"use strict";var uee=(k(),v(K)).OPERATIONS_ENUM,Jb=class{static{o(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=uee.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};iB.exports=Jb});var cB=M((mCe,aB)=>{"use strict";var fCe=oB(),dee=wm(),fee=jf(),mee=HE(),Fm=(k(),v(K)),hee=Zc().upsertRecords,pee=Et(),{getSchemaPath:_ee}=At(),Eee=Om(),gee=z(),{handleHDBError:See,hdbErrors:Tee}=_e();aB.exports=Ree;async function Ree(e){let t;try{t=dee(e)}catch(l){throw See(l,l.message,Tee.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schemaTable:r,attributes:n}=t;fee(e,n,r.hash_attribute),e.schema!==Fm.SYSTEM_SCHEMA_NAME&&(n.includes(Fm.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(Fm.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(Fm.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(Fm.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await mee(e.hdb_auth_header,r,n),i=_ee(e.schema,e.table),a=await pee.openEnvironment(i,e.table),c=await hee(a,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await Eee(e,c)}catch(l){gee.error(`unable to write transaction due to ${l.message}`)}return{written_hashes:c.written_hashes,schemaTable:r,new_attributes:s,txn_time:c.txn_time}}o(Ree,"lmdbUpsertRecords")});var uB=M((pCe,lB)=>{"use strict";var Xb=class{static{o(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};lB.exports=Xb});var fB=M((ECe,dB)=>{"use strict";var Zb=class{static{o(this,"DeleteAuditLogsBeforeResults")}constructor(t=void 0,r=void 0,n=0){this.start_timestamp=t,this.end_timestamp=r,this.transactions_deleted=n}};dB.exports=Zb});var pB=M((TCe,hB)=>{"use strict";var eI=Et(),{getTransactionAuditStorePath:yee}=At(),SCe=uB(),Hm=kt(),Aee=ie(),mB=fB(),bee=require("util").promisify,Iee=bee(setTimeout),Nee=1e4,wee=100;hB.exports=Oee;async function Oee(e){let t=yee(e.schema,e.table),r=await eI.openEnvironment(t,e.table,!0),n=eI.listDBIs(r);eI.initializeDBIs(r,Hm.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new mB;do s=await Cee(r,e.timestamp),i.start_timestamp===void 0&&(i.start_timestamp=s.start_timestamp),s.end_timestamp!==void 0&&(i.end_timestamp=s.end_timestamp),i.transactions_deleted+=s.transactions_deleted,await Iee(wee);while(s.transactions_deleted>0);return i}o(Oee,"deleteAuditLogsBefore");async function Cee(e,t){let r=new mB;try{let n=e.dbis[Hm.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],s;for(let{key:i,value:a}of n.getRange({start:!1})){if(i>=t)break;r.start_timestamp===void 0&&(r.start_timestamp=i),s=n.remove(i);let c=a[Hm.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];Aee.isEmpty(c)||(s=e.dbis[Hm.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<a.hash_values.length;l++)s=e.dbis[Hm.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(a.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>Nee)break}return await s,r}catch(n){throw n}}o(Cee,"deleteTransactions")});var EB=M((yCe,_B)=>{"use strict";var tI=class{static{o(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};_B.exports=tI});var SB=M((ICe,gB)=>{"use strict";var Pee=ri(),Lee=Um(),bCe=EB(),vi=(k(),v(K)),Dee=ie(),rI=Et(),Mee=Ao(),vee=vm(),Uee=Pm(),{getSchemaPath:xee}=At();gB.exports=Bee;async function Bee(e,t=!0){let r;e.schema===vi.SYSTEM_SCHEMA_NAME?r=Mee[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await Hee(e),s=xee(e.schema,e.table),i=await rI.openEnvironment(s,e.table);return t===!0&&await Fee(e,i,r.hash_attribute),rI.dropDBI(i,e.attribute),n}o(Bee,"lmdbDropAttribute");async function Fee(e,t,r){let n=rI.openDBI(t,r),s,i=e.attribute;for(let{key:a,value:c,version:l}of n.getRange({start:!1,versions:!0})){let u={};for(let d in c)d!==i&&(u[d]=c[d]);s=t.dbis[r].put(a,u,l)}await s}o(Fee,"removeAttributeFromAllObjects");async function Hee(e){let t=new Pee(vi.SYSTEM_SCHEMA_NAME,vi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,vi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[vi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,vi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await vee(t)).filter(a=>a[vi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(Dee.isEmptyOrZeroLength(n))throw new Error(`Attribute '${drop_attribute_obj.attribute}' was not found in '${drop_attribute_obj.schema}.${drop_attribute_obj.table}'`);let s=n.map(a=>a[vi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new Lee(vi.SYSTEM_SCHEMA_NAME,vi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return Uee(i)}o(Hee,"dropAttributeFromSystem")});var IB=M((OCe,bB)=>{"use strict";var nI=Et(),Hu=kt(),wCe=An(),sI=(k(),v(K)),TB=ie(),{getTransactionAuditStorePath:kee}=At(),Gee=xu(),zE=Mu(),qee=z();bB.exports=$ee;async function $ee(e){let t=kee(e.schema,e.table),r=await nI.openEnvironment(t,e.table,!0),n=nI.listDBIs(r);nI.initializeDBIs(r,Hu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case sI.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return RB(r,e.search_values);case sI.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,Kee(r,e.search_values,s);case sI.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return Vee(r,e.search_values);default:return RB(r)}}o($ee,"readAuditLog");function RB(e,t=[0,Date.now()]){TB.isEmpty(t[0])&&(t[0]=0),TB.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[Hu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],n;for(let s of r.getKeys({start:t[1]}))if(s!==t[1]){n=s;break}return r.getRange({start:t[0],end:n}).map(({value:s})=>Object.assign(new zE,s))}o(RB,"searchTransactionsByTimestamp");function Vee(e,t=[]){let r=new Map;for(let n=0;n<t.length;n++){let s=t[n],i=[];for(let a of e.dbis[Hu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(a);r.set(s,AB(e,i))}return Object.fromEntries(r)}o(Vee,"searchTransactionsByUsername");function Kee(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let u=t[c],d=Gee.equals(e,Hu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Hu.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,u);for(let{value:f}of d){let m=Number(f);n.has(m)?n.get(m).push(u.toString()):n.set(m,[u.toString()])}}let s=Array.from(n.keys()),i=AB(e,s),a=new Map;for(let c=0;c<i.length;c++){let l=i[c],u=l.timestamp,d=n.get(u);yB(l,"records",r,d,a),yB(l,"original_records",r,d,a)}return Object.fromEntries(a)}o(Kee,"searchTransactionsByHashValues");function yB(e,t,r,n,s){let i=e.timestamp;if(e[t])for(let a=0;a<e[t].length;a++){let c=e[t][a],l=c[r].toString();if(n.indexOf(l)>=0)if(s.has(l)){let u=s.get(l),d=u[u.length-1];if(d.timestamp===i)d[t]=[c];else{let f=new zE(e.operation,e.user_name,i,void 0);f[t]=[c],u.push(f)}}else{let u=new zE(e.operation,e.user_name,i,void 0);u[t]=[c],s.set(l,[u])}}}o(yB,"loopRecords");function AB(e,t){let r=[];try{let n=e.dbis[Hu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP];for(let s=0;s<t.length;s++)try{let i=n.get(t[s]);if(i){let a=Object.assign(new zE,i);r.push(a)}}catch(i){qee.warn(i)}return r}catch(n){throw n}}o(AB,"batchSearchTransactions")});var wB=M((DCe,NB)=>{"use strict";var{getSchemaPath:PCe}=At(),LCe=Et(),{database:Yee}=(Le(),v(ft));NB.exports={writeTransaction:Wee};async function Wee(e,t,r){return Yee({database:e,table:t}).transaction(r)}o(Wee,"writeTransaction")});var LB=M((vCe,PB)=>{"use strict";var{getSchemaPath:OB}=At(),CB=Et();PB.exports={flush:zee,resetReadTxn:jee};async function zee(e,t){return(await CB.openEnvironment(OB(e,t),t.toString())).flushed}o(zee,"flush");async function jee(e,t){try{(await CB.openEnvironment(OB(e,t),t.toString())).resetReadTxn()}catch{}}o(jee,"resetReadTxn")});var UB=M((xCe,vB)=>{"use strict";var{Readable:Qee}=require("stream"),{getDatabases:Jee}=(Le(),v(ft)),{readSync:Xee,openSync:Zee,createReadStream:DB}=require("fs"),{open:ete}=require("lmdb"),MB=Rm(),tte=ym(),{AUDIT_STORE_OPTIONS:rte}=(mo(),v(nU)),{INTERNAL_DBIS_NAME:nte,AUDIT_STORE_NAME:ste}=kt();vB.exports=ote;var iI=32768,ite=100;async function ote(e){let t=e.database||e.schema||"data",r=Jee()[t],n=new Date().toISOString(),s=e.tables||e.table&&[e.table];if(s){let u=r[s[0]];if(!u)throw new Error(`Can not find table ${s[0]}`);let d=u.dbisDB,f=ete({noSync:!0,maxDbs:tte.MAX_DBS}),m,h=f.openDB(nte,new MB(!1)),p=d.useReadTransaction(),E=0,g=o(async function(T,R){R.encoding="binary",R.encoder=void 0;let I=f.openDB(T,R),P=d.openDB(T,R);for(let{key:Y,version:te,value:x}of P.getRange({start:null,transaction:p,versions:P.useVersions}))m=I.put(Y,x,te),E++%ite===0&&(await new Promise($=>setTimeout($,20)),p.openTimer&&(p.openTimer=0))},"copyDatabase");for(let{key:T,value:R}of d.getRange({transaction:p,start:!1}))if(s.some(I=>T.startsWith?.(I+"/"))){h.put(T,R);let[,I]=T.split("/"),P=!I,Y=new MB(!P,P);await g(T,Y)}e.include_audit&&await g(ste,{...rte}),await m;let y=DB(f.path);return y.headers=l(),y.on("close",()=>{p.done(),f.close()}),y}let a=r[Object.keys(r)[0]].primaryStore,c=Zee(a.path);return a.transaction(()=>{let u=Buffer.alloc(iI);Xee(c,u,0,iI),a.resetReadTxn();let d=a.useReadTransaction();d.renew();let f=DB(null,{fd:c,start:iI}),m=new Qee.from(async function*(){yield u;for await(let h of f)d.openTimer&&(d.openTimer=0),yield h;d.done()}());return m.headers=l(),m});function l(){let u=new Map;return u.set("content-type","application/octet-stream"),u.set("content-disposition",`attachment; filename="${t}"`),u.set("date",n),u}}o(ote,"getBackup")});var FB=M((FCe,BB)=>{"use strict";var ate=z(),{handleHDBError:cte}=_e(),lte=u0(),ute=FE(),dte=Cb(),fte=J0(),mte=Pm(),hte=xb(),pte=Ax(),_te=Dx(),Ete=vm(),gte=kx(),Ste=Jx(),Tte=rB(),Rte=sB(),yte=cB(),Ate=pB(),bte=Vb(),Ite=SB(),Nte=IB(),wte=wB(),xB=LB(),Ote=UB(),oI=class extends lte{static{o(this,"LMDBBridge")}async searchByConditions(t){return gte(t)}async getDataByHash(t){return await hte(t)}async searchByHash(t){return await pte(t)}async getDataByValue(t,r){return await _te(t,r)}async searchByValue(t){return await Ete(t)}async createSchema(t){return await fte(t)}async dropSchema(t){return await Ste(t)}async createTable(t,r){return await Tte(t,r)}async dropTable(t){return await bte(t)}async createAttribute(t){return await ute(t)}async createRecords(t){return await dte(t)}async updateRecords(t){return await Rte(t)}async upsertRecords(t){try{return await yte(t)}catch(r){throw cte(r,null,null,ate.ERR,r)}}async deleteRecords(t){return await mte(t)}async dropAttribute(t){return await Ite(t)}async deleteAuditLogsBefore(t){return await Ate(t)}async readAuditLog(t){return await Nte(t)}writeTransaction(t,r,n){return wte.writeTransaction(t,r,n)}flush(t,r){return xB.flush(t,r)}resetReadTxn(t,r){return xB.resetReadTxn(t,r)}getBackup(t){return Ote(t)}};BB.exports=oI});function Ln(e){let t=e.getChanges();return t||(t=Object.create(null),e._setChanges(t)),t}function Gm(e,t,r=!1){let n=e.prototype,s={},i=t.attributes||t.properties||[];for(let l of i){let u=l.name,d,f;if(l.resolve)f={get(){return l.resolve(this,this.getContext?.())},set(m){return l.set(this,m)},configurable:!0};else{switch(l.type){case"String":d=o(function(m){if(!(typeof m=="string"||m==null&&l.nullable!==!1))throw new zn.ClientError(`${u} must be a string, attempt to assign ${m}`);Ln(this)[u]=m},"set");break;case"ID":d=o(function(m){if(!(typeof m=="string"||m?.length>0&&m.every?.(h=>typeof h=="string")||m==null&&l.nullable!==!1))throw new zn.ClientError(`${u} must be a string, attempt to assign ${m}`);Ln(this)[u]=m},"set");break;case"Float":case"Number":d=o(function(m){let h=m?.__op__?m.value:m;if(!(typeof h=="number"||m==null&&l.nullable!==!1))throw new zn.ClientError(`${u} must be a number, attempt to assign ${h}`);Ln(this)[u]=m},"set");break;case"Int":d=o(function(m){let h=m?.__op__?m.value:m;if(!(h>>0===h||m==null&&l.nullable!==!1))if(typeof h=="number"&&Math.abs((h>>0)-h)<=1)h=Math.round(h),m?.__op__?m.value=h:m=h;else throw new zn.ClientError(`${u} must be an integer between -2147483648 and 2147483647, attempt to assign ${m}`);Ln(this)[u]=m},"set");break;case"Long":d=o(function(m){let h=m?.__op__?m.value:m;if(!(Math.round(h)===m&&Math.abs(h)<=9007199254740992||m==null&&l.nullable!==!1))if(typeof h=="number"&&Math.abs(h)<=9007199254740992)h=Math.round(h),m?.__op__?m.value=h:m=h;else throw new zn.ClientError(`${u} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${m}`);Ln(this)[u]=m},"set");break;case"BigInt":d=o(function(m){let h=m?.__op__?m.value:m;if(!(typeof h=="bigint"||m==null&&l.nullable!==!1))if(typeof h=="string"||typeof h=="number")h=BigInt(h),m?.__op__?m.value=h:m=h;else throw new zn.ClientError(`${u} must be a number, attempt to assign ${m}`);Ln(this)[u]=m},"set");break;case"Boolean":d=o(function(m){if(!(typeof m=="boolean"||m==null&&l.nullable!==!1))throw new zn.ClientError(`${u} must be a boolean, attempt to assign ${m}`);Ln(this)[u]=m},"set");break;case"Date":d=o(function(m){if(!(m instanceof Date||m==null&&l.nullable!==!1))if(typeof m=="string"||typeof m=="number")m=new Date(m);else throw new zn.ClientError(`${u} must be a Date, attempt to assign ${m}`);Ln(this)[u]=m},"set");break;case"Bytes":d=o(function(m){if(!(m instanceof Uint8Array||m==null&&l.nullable!==!1))throw new zn.ClientError(`${u} must be a Buffer or Uint8Array, attempt to assign ${m}`);Ln(this)[u]=m},"set");break;case"Blob":d=o(function(m){if(!(m instanceof Ss||m==null&&l.nullable!==!1))throw new zn.ClientError(`${u} must be a Blob, attempt to assign ${m}`);Ln(this)[u]=m},"set");break;case"Any":case void 0:d=o(function(m){Ln(this)[u]=m},"set");break;default:d=o(function(m){if(!(typeof m=="object"||m==null&&l.nullable!==!1))throw new zn.ClientError(`${u} must be an object, attempt to assign ${m}`);Ln(this)[u]=m},"set")}f={get(){let m=this.getChanges?.();if(m&&u in m){let p=m[u];if(p?.__op__){let E=this.getRecord()?.[u];return p.update(E)}return p}let h=this.getRecord()?.[u];if(h&&typeof h=="object"){let p=aI(h,l);if(p)return m||this._setChanges(m=Object.create(null)),m[u]=p}return h},set:d,enumerable:!0,configurable:!0}}f.get.isAttribute=!0,s[u]=f,(!(u in n)||Object.getOwnPropertyDescriptor(n,u)?.get?.isAttribute)&&Object.defineProperty(n,u,f)}a("getProperty",function(l){let u=s[l];if(u)return u.get.call(this);let d=this.getChanges();return d?.[l]!==void 0?d[l]:this.getRecord()?.[l]}),a("set",function(l,u){let d=s[l];if(d)return d.set.call(this,u);if(t.sealed)throw new zn.ClientError("Can not add a property to a sealed table schema");Ln(this)[l]=u}),a("deleteProperty",function(l){Ln(this)[l]=void 0}),a("toJSON",function(){let l=this.getChanges?.(),u;for(let f in l){u||(u={...this.getRecord()});let m=l[f];if(m?.__op__){let h=u[f];m=m.update(h)}u[f]=m}return Object.keys(this).length>0&&(u||(u={...this.getRecord()}),Object.assign(u,this)),u||this.getRecord()}),n.get||a("get",n.getProperty),n.delete||a("delete",n.deleteProperty),n.then||a("then",null);function a(l,u){Object.defineProperty(n,l,{value:u,configurable:!0})}o(a,"setMethod");let c=n;do{let l=Object.getPrototypeOf(c);if(l===Object.prototype){Object.setPrototypeOf(c,r?GB:kB);break}c=l}while(c&&c!==kB&&c!==GB)}function qB(e,t,r){if(typeof t=="string"){if(t==="then"||t==="getRecord"||t==="getChanges")return;if(HB[t])return HB[t];let n=r.getChanges?.();if(n&&t in n)return n[t];let s=r.getRecord?.()?.[t];if(s&&typeof s=="object"){let i=aI(s);if(i)return n||(n=Object.create(null),r._setChanges(n)),n[t]=i,i}return s}}function Cte(e,t,r,n){if(typeof t=="string"){let s=n.getChanges?.();s||(s={},n._setChanges(s)),s[t]=r}else Object.defineProperty(n,t,{value:r,configurable:!0,writable:!0});return!0}function aI(e,t){let r;switch(e.constructor){case Object:return t?(r=t.TrackedObject,r||(t.TrackedObject=r=class extends il{static{o(this,"TrackedObject")}},Gm(r,t)),new r(e)):new il(e);case Array:let n=new QE(e.length,e);for(let s=0,i=e.length;s<i;s++){let a=e[s];a&&typeof a=="object"&&(a=aI(a,t?.elements)),n[s]=a}return n;default:return e}}function JE(e){let t=e.getChanges?.(),r;for(let s in t){r||(r=e.getRecord?{...e.getRecord()}:{});let i=t[s];if(i&&typeof i=="object")if(i.__op__){let a=r[s];i=i.update(a)}else i=JE(i);r[s]=i}return Object.keys(e).length>0&&(r||(r=e.getRecord?{...e.getRecord()}:{}),Object.assign(r,e)),r||e.getRecord?.()||e}function Pa(e,t=e.getChanges?.()){let r;if(!e)return t;if(e.getRecord&&e.constructor===Array&&!Object.isFrozen(e)){r=e;for(let n=0,s=e.length;n<s;n++){let i=e[n];if(i&&typeof i=="object"){let a=Pa(i);a!==i&&r===e&&(r=e.slice(0)),i=a}r[n]=i}return Object.freeze(r)}for(let n in t){r||(r={...e.getRecord?e.getRecord():e});let s=t[n];if(s&&typeof s=="object")if(s.__op__){let i=iA[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=Pa(s);r[n]=s}if(!Array.isArray(e)&&e.getRecord)for(let n in e)Pte.call(e,n)&&(r||(r={...e.getRecord()}),r[n]=e[n]);return r?Object.freeze(r):e.getRecord?e.getRecord():e}function jE(e){let t=e.getRecord?.();if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[sl]||e.length!==t.length)return!0;for(let r=0,n=e.length;r<n;r++){let s=t[r],i=e[r];if(s&&i?.getRecord?.()===s){if(jE(i))return!0}else return!0}}else{let r=e.getChanges?.();if(r&&!t)return!0;for(let n in r){let s=r[n];if(s&&typeof s=="object"){let i=t[n];if(i&&s.getRecord?.()===i){if(jE(s))return!0}else return!0}else return!0}}return!1}var zn,HB,kB,GB,il,Pte,sl,QE,km,cI=fe(()=>{zn=w(_e());K_();Ts();o(Ln,"getChanges");o(Gm,"assignTrackedAccessors");HB=Object.prototype,kB=new Proxy({},{get:qB}),GB=new Proxy({},{get:qB,set:Cte});o(qB,"getProxiedProperty");o(Cte,"setProxiedProperty");o(aI,"trackObject");il=class{static{o(this,"GenericTrackedObject")}#e;#t;constructor(t){if(t?.getRecord)throw new Error("Can not track an already tracked object, check for circular references");this.#e=t}getRecord(){return this.#e}setRecord(t){this.#e=t}getChanges(){return this.#t}_setChanges(t){this.#t=t}};Gm(il,{},!0);o(JE,"collapseData");Pte=Object.prototype.hasOwnProperty;o(Pa,"updateAndFreeze");o(jE,"hasChanges");sl=Symbol.for("has-array-changes"),QE=class extends Array{static{o(this,"TrackedArray")}#e;[sl];constructor(t,r){super(t),this.#e=r}getRecord(){return this.#e}splice(...t){return this[sl]=!0,super.splice(...t)}push(...t){return this[sl]=!0,super.push(...t)}pop(){return this[sl]=!0,super.pop()}unshift(...t){return this[sl]=!0,super.unshift(...t)}shift(){return this[sl]=!0,super.shift()}};QE.prototype.constructor=Array;km=class{static{o(this,"Addition")}__op__="add";value;constructor(t){this.value=t}update(t){return(+t||0)+this.value}}});var QB={};Ce(QB,{ResourceBridge:()=>dI});function fI({get_attributes:e},t){if(e){if(e[0]==="*"){if(t.schemaDefined)return;e=t.attributes.map(r=>r.name)}return e.forceNulls=!0,e}}function $B(e,t){let r=Ui(e),n=fI(e,r);if(!r)throw new ni.ClientError(`Table ${e.table} not found`);let s;n&&r.attributes.length-n.length>2&&n.length<5&&(s=!0);let i={user:e.hdb_user,onlyIfCached:e.onlyIfCached,noCacheStore:e.noCacheStore,noCache:e.noCache,replicateFrom:e.replicateFrom},a;vt(i,()=>new Promise(u=>a=u));let c=e.ids||e.hash_values,l=0;return{[Symbol.asyncIterator](){return{async next(){if(l<c.length){let u=c[l++],d;try{d=await r.get({id:u,lazy:s,select:n},i),d=d&&JE(d)}catch(f){d={message:(0,jB.errorToString)(f)}}return t?{value:{key:u,value:d}}:{value:d}}else return a(),{done:!0}},return(u){return a(),{value:u,done:!0}},throw(u){return a(),{done:!0}}}}}}function Ui(e){let t=e.database||e.schema||Dte,r=it()[t];if(!r)throw(0,ni.handleHDBError)(new Error,Lte.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function VB(e,t,r){let n=e.length+t.length,s=n===1?"record":"records";return{message:`${e.length} of ${n} ${s} successfully deleted`,deleted_hashes:e,skipped_hashes:t,txn_time:r}}async function*KB(e,t,r,n){let s,i=0;for await(let a of e.getHistory(t,r)){let c=a.operation??a.type;c==="put"&&(c="upsert");let{id:l,version:u,value:d}=a;if(s?.timestamp===u)s.hash_values.push(l),s.records.push(d);else{if(s&&(yield s,i++,n&&n<=i)){s=void 0;break}s={operation:c,user_name:a.user,timestamp:u,hash_values:[l],records:[d]}}}s&&(yield s)}var YB,XE,ni,WB,lI,uI,zB,jB,Lte,Dte,Mte,vte,dI,JB=fe(()=>{YB=w(FB()),XE=w(Bu()),ni=w(_e());Le();WB=w(wm());k();lI=w(No()),uI=w(ti()),zB=w(ie());xc();cI();jB=w(z()),{HDB_ERROR_MSGS:Lte}=ni.hdbErrors,Dte="data",Mte=1e4,vte=10,dI=class extends YB.default{static{o(this,"ResourceBridge")}async searchByConditions(t){t.select!==void 0&&(t.get_attributes=t.select);for(let a of t.conditions||[])a?.attribute!==void 0&&(a.search_attribute=a.attribute),a?.comparator!==void 0&&(a.search_type=a.comparator),a?.value!==void 0&&(a.search_value=a.value);let r=(0,XE.default)(t,"conditions");if(r)throw(0,ni.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=Ui(t);if(!n)throw new ni.ClientError(`Table ${t.table} not found`);let s=t.conditions.map(i);function i(a){if("conditions"in a&&a.conditions)return a.conditions=a.conditions.map(i),a;{let c=a;return{attribute:c.search_attribute??c.attribute,comparator:c.search_type??c.comparator,value:c.search_value!==void 0?c.search_value:c.value}}}return o(i,"mapCondition"),n.search({conditions:s,operator:t.operator?t.operator.toLowerCase():void 0,limit:t.limit,offset:t.offset,reverse:t.reverse,select:fI(t,n),sort:t.sort,allowFullScan:!0},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async createTable(t,r){let n=r.attributes,s=!!n,i=r.primary_key||r.hash_attribute;if(n)for(let a of n)a.is_primary_key?(a.isPrimaryKey=!0,delete a.is_primary_key):a.name===i&&i&&(a.isPrimaryKey=!0);else{if(!i)throw new ni.ClientError("A primary key must be specified with a `primary_key` property or with `attributes`");n=[{name:i,isPrimaryKey:!0},{name:"__createdtime__",indexed:!0},{name:"__updatedtime__",indexed:!0}]}et({database:r.database??r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration,audit:r.audit})}async createAttribute(t){return await Ui(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=Ui(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=o((a,c,l)=>(c={...c},delete c[n],r.primaryStore.ifVersion(a,l,()=>r.primaryStore.put(a,c,l)).then(u=>{if(!u){let{value:d,version:f}=r.primaryStore.getEntry(a);return i(a,d,f)}})),"deleteRecord");for(let{key:a,value:c,version:l}of r.primaryStore.getRange({start:!0,versions:!0}))s=i(a,c,l),await new Promise(u=>setImmediate(u));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){return Ui(t).dropTable()}createSchema(t){return ku({database:t.schema,table:null}),lI.signalSchemaChange(new uI.SchemaEventMsg(process.pid,G.CREATE_SCHEMA,t.schema))}async dropSchema(t){await mI(t.schema),lI.signalSchemaChange(new uI.SchemaEventMsg(process.pid,G.DROP_SCHEMA,t.schema))}async updateRecords(t){return t.requires_existing=!0,this.upsertRecords(t)}async createRecords(t){return t.requires_no_existing=!0,this.upsertRecords(t)}async upsertRecords(t){let{schemaTable:r,attributes:n}=(0,WB.default)(t),s,i=it()[t.schema][t.table],a={user:t.hdb_user,expiresAt:t.expiresAt,originatingOperation:t.operation};return t.replicateTo&&(a.replicateTo=t.replicateTo),t.replicatedConfirmation&&(a.replicatedConfirmation=t.replicatedConfirmation),vt(a,async c=>{if(!i.schemaDefined){s=[];for(let d of n)i.attributes.find(m=>m.name==d)||s.push(d);s.length>0&&await i.addAttributes(s.map(d=>({name:d,indexed:!0})))}let l=[],u=[];for(let d of t.records){let f=d[i.primaryKey],m=f!=null&&await i.get(f,a);if(t.requires_existing&&!m||t.requires_no_existing&&m){u.push(d[i.primaryKey]);continue}m&&(m=JE(m));for(let h in d)if(Object.prototype.hasOwnProperty.call(d,h)){let p=d[h];if(typeof p=="function")try{let E=p([[m]]);Array.isArray(E)&&(p=E[0].func_val,d[h]=p)}catch(E){throw E.message+="Trying to set key "+h+" on object"+JSON.stringify(d),E}}if(m)for(let h in m)Object.prototype.hasOwnProperty.call(d,h)||(d[h]=m[h]);await(f==null?i.create(d,a):i.put(d,a)),l.push(d[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:l,new_attributes:s,skipped_hashes:u}})}async deleteRecords(t){let r=it()[t.schema][t.table],n={user:t.hdb_user};return t.replicateTo&&(n.replicateTo=t.replicateTo),t.replicatedConfirmation&&(n.replicatedConfirmation=t.replicatedConfirmation),vt(n,async s=>{let i=t.hash_values||t.records.map(l=>l[r.primaryKey]),a=[],c=[];for(let l of i)await r.delete(l,n)?a.push(l):c.push(l);return VB(a,c,s.timestamp)})}async deleteRecordsBefore(t){let r=it()[t.schema][t.table];if(!r.createdTimeProperty)throw new ni.ClientError("Table must have a '__createdtime__' attribute or @createdTime timestamp defined to perform this operation");let n=await r.search({conditions:[{attribute:r.createdTimeProperty.name,value:Date.parse(t.date),comparator:N_.LESS}]}),s=!1,i=[],a=[],c=0,l=[],u=o(async()=>{let d=await this.deleteRecords({schema:t.schema,table:t.table,hash_values:l});i.push(...d.deleted_hashes),a.push(...d.skipped_hashes),await(0,zB.asyncSetTimeout)(vte),l=[],s=!0},"chunkDelete");for await(let d of n)l.push(d[r.primaryKey]),c++,c%Mte===0&&await u();return l.length>0&&await u(),s?VB(i,a,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,XE.default)(t,"hashes");if(r)throw r;return $B(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of $B(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&By[r]===void 0)throw new Error(`Value search comparator - ${r} - is not valid`);t.select!==void 0&&(t.get_attributes=t.select),t.attribute!==void 0&&(t.search_attribute=t.attribute),t.value!==void 0&&(t.search_value=t.value);let n=(0,XE.default)(t,"value");if(n)throw n;let s=Ui(t);if(!s)throw new ni.ClientError(`Table ${t.table} not found`);let i=t.search_value;i.includes?.("*")&&(i.startsWith("*")?i.endsWith("*")?i!=="*"&&(r="contains",i=i.slice(1,-1)):(r="ends_with",i=i.slice(1)):i.endsWith("*")&&(r="starts_with",i=i.slice(0,-1))),r===N_.BETWEEN&&(i=[i,t.end_value]);let a=i==="*"?[]:[{attribute:t.search_attribute,value:i,comparator:r}];return s.search({conditions:a,allowFullScan:!0,limit:t.limit,offset:t.offset,reverse:t.reverse,sort:t.sort,select:fI(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async getDataByValue(t,r){let n=new Map,s=Ui(t);t.get_attributes&&!t.get_attributes.includes(s.primaryKey)&&t.get_attributes[0]!=="*"&&t.get_attributes.push(s.primaryKey);for await(let i of this.searchByValue(t,r))n.set(i[s.primaryKey],i);return n}resetReadTxn(t,r){Ui({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return Ui(t).deleteHistory(t.timestamp,t.cleanup_deleted_records)}async readAuditLog(t){let r=Ui(t),n={};switch(t.search_type){case w_.HASH_VALUE:for(let s of t.search_values)n[s]=(await r.getHistoryOfRecord(s)).map(i=>{let a=i.operation??i.type;return a==="put"&&(a="upsert"),{operation:a,timestamp:i.version,user_name:i.user,hash_values:[s],records:[i.value]}});return n;case w_.USERNAME:{let s=t.search_values;for await(let i of KB(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n}default:return KB(r,t.search_values?.[0],t.search_values?.[1],t.limit)}}};o(fI,"getSelect");o($B,"getRecords");o(Ui,"getTable");o(VB,"createDeleteResponse");o(KB,"groupRecordsInHistory")});var jn=M((jCe,XB)=>{"use strict";var{ResourceBridge:Ute}=(JB(),v(QB)),xte=ce();xte.initSync();var ZE;function Bte(){return ZE||(ZE=new Ute,ZE)}o(Bte,"getBridge");XB.exports=Bte()});var rF=M((JCe,tF)=>{"use strict";var ZB=require("lodash"),qm=require("mathjs"),Fte=require("jsonata"),eF=ie();tF.exports={distinct_array:o(e=>Array.isArray(e)&&e.length>1?ZB.uniqWith(e,ZB.isEqual):e,"distinct_array"),searchJSON:Hte,mad:$m.bind(null,qm.mad),mean:$m.bind(null,qm.mean),mode:$m.bind(null,qm.mode),prod:$m.bind(null,qm.prod),median:$m.bind(null,qm.median)};function $m(e,t,r,n){return n===1?t==null?[]:[t]:n===2?(t!=null&&r.push(t),r):r!=null&&r.length>0?e(r):null}o($m,"aggregateFunction");function Hte(e,t){if(typeof e!="string"||e.length===0)throw new Error("search json expression must be a non-empty string");let r="__"+e+"__";if(eF.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),eF.isEmpty(this.__ala__.res[r])){let n=Fte(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}o(Hte,"searchJSON")});var sF=M((ZCe,nF)=>{"use strict";var ar=require("moment"),hI="YYYY-MM-DDTHH:mm:ss.SSSZZ";ar.suppressDeprecationWarnings=!0;nF.exports={current_date:o(()=>ar().utc().format("YYYY-MM-DD"),"current_date"),current_time:o(()=>ar().utc().format("HH:mm:ss.SSS"),"current_time"),extract:o((e,t)=>{switch(t.toLowerCase()){case"year":return ar(e).utc().format("YYYY");case"month":return ar(e).utc().format("MM");case"day":return ar(e).utc().format("DD");case"hour":return ar(e).utc().format("HH");case"minute":return ar(e).utc().format("mm");case"second":return ar(e).utc().format("ss");case"millisecond":return ar(e).utc().format("SSS");default:break}},"extract"),date:o(e=>ar(e).utc().format(hI),"date"),date_format:o((e,t)=>ar(e).utc().format(t),"date_format"),date_add:o((e,t,r)=>ar(e).utc().add(t,r).valueOf(),"date_add"),date_sub:o((e,t,r)=>ar(e).utc().subtract(t,r).valueOf(),"date_sub"),date_diff:o((e,t,r)=>{let n=ar(e).utc(),s=ar(t).utc();return r?n.diff(s,r,!0):n.diff(s)},"date_diff"),now:o(()=>ar().utc().valueOf(),"now"),get_server_time:o(()=>ar().format(hI),"get_server_time"),offset_utc:o((e,t)=>ar(e).utc().utcOffset(t).format(hI),"offset_utc")}});var cF=M((tPe,aF)=>{"use strict";var kte=require("@turf/area"),Gte=require("@turf/length"),qte=require("@turf/circle"),$te=require("@turf/difference"),Vte=require("@turf/distance"),Kte=require("@turf/boolean-contains"),Yte=require("@turf/boolean-equal"),Wte=require("@turf/boolean-disjoint"),zte=require("@turf/helpers"),iF=(k(),v(K)),Ye=ie(),Co=z();aF.exports={geoArea:jte,geoLength:Qte,geoCircle:Jte,geoDifference:Xte,geoDistance:oF,geoNear:Zte,geoContains:ere,geoEqual:tre,geoCrosses:rre,geoConvert:nre};function jte(e){if(Ye.isEmpty(e))return NaN;typeof e=="string"&&(e=Ye.autoCastJSON(e));try{return kte.default(e)}catch(t){return Co.trace(t,e),NaN}}o(jte,"geoArea");function Qte(e,t){if(Ye.isEmpty(e))return NaN;typeof e=="string"&&(e=Ye.autoCastJSON(e));try{return Gte.default(e,{units:t||"kilometers"})}catch(r){return Co.trace(r,e),NaN}}o(Qte,"geoLength");function Jte(e,t,r){if(Ye.isEmpty(e))return NaN;if(Ye.isEmpty(t))return NaN;typeof e=="string"&&(e=Ye.autoCastJSON(e));try{return qte.default(e,t,{units:r||"kilometers"})}catch(n){return Co.trace(n,e,t),NaN}}o(Jte,"geoCircle");function Xte(e,t){if(Ye.isEmpty(e))return NaN;if(Ye.isEmpty(t))return NaN;typeof e=="string"&&(e=Ye.autoCastJSON(e)),typeof t=="string"&&(t=Ye.autoCastJSON(t));try{return $te(e,t)}catch(r){return Co.trace(r,e,t),NaN}}o(Xte,"geoDifference");function oF(e,t,r){if(Ye.isEmpty(e))return NaN;if(Ye.isEmpty(t))return NaN;typeof e=="string"&&(e=Ye.autoCastJSON(e)),typeof t=="string"&&(t=Ye.autoCastJSON(t));try{return Vte.default(e,t,{units:r||"kilometers"})}catch(n){return Co.trace(n,e,t),NaN}}o(oF,"geoDistance");function Zte(e,t,r,n){if(Ye.isEmpty(e)||Ye.isEmpty(t))return!1;if(Ye.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=Ye.autoCastJSON(e)),typeof t=="string"&&(t=Ye.autoCastJSON(t)),isNaN(r))throw new Error("distance must be a number");try{return oF(e,t,n)<=r}catch(s){return Co.trace(s,e,t),!1}}o(Zte,"geoNear");function ere(e,t){if(Ye.isEmpty(e)||Ye.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Ye.autoCastJSON(e)),typeof t=="string"&&(t=Ye.autoCastJSON(t));try{return Kte.default(e,t)}catch(r){return Co.trace(r,e,t),!1}}o(ere,"geoContains");function tre(e,t){if(Ye.isEmpty(e)||Ye.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Ye.autoCastJSON(e)),typeof t=="string"&&(t=Ye.autoCastJSON(t));try{return Yte.default(e,t)}catch(r){return Co.trace(r,e,t),!1}}o(tre,"geoEqual");function rre(e,t){if(Ye.isEmpty(e)||Ye.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Ye.autoCastJSON(e)),typeof t=="string"&&(t=Ye.autoCastJSON(t));try{return!Wte.default(e,t)}catch(r){return Co.trace(r,e,t),!1}}o(rre,"geoCrosses");function nre(e,t,r){if(Ye.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if(Ye.isEmpty(t))throw new Error("geo_type is required");if(Ye.isEmpty(iF.GEO_CONVERSION_ENUM[t]))throw new Error(`geoType of ${t} is invalid please use one of the following types: ${Object.keys(iF.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Ye.autoCastJSON(e)),zte[t](e,r)}o(nre,"geoConvert")});var eg=M((nPe,lF)=>{var ol=rF(),Qn=sF(),xi=cF();lF.exports=e=>{e.aggr.mad=e.aggr.MAD=ol.mad,e.aggr.mean=e.aggr.MEAN=ol.mean,e.aggr.mode=e.aggr.MODE=ol.mode,e.aggr.prod=e.aggr.PROD=ol.prod,e.aggr.median=e.aggr.MEDIAN=ol.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=ol.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=ol.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=Qn.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Qn.current_time,e.fn.extract=e.fn.EXTRACT=Qn.extract,e.fn.date=e.fn.DATE=Qn.date,e.fn.date_format=e.fn.DATE_FORMAT=Qn.date_format,e.fn.date_add=e.fn.DATE_ADD=Qn.date_add,e.fn.date_sub=e.fn.DATE_SUB=Qn.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Qn.date_diff,e.fn.now=e.fn.NOW=Qn.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Qn.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Qn.get_server_time,e.fn.getdate=e.fn.GETDATE=Qn.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Qn.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=xi.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=xi.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=xi.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=xi.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=xi.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=xi.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=xi.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=xi.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=xi.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=xi.geoNear}});var mF=M((sPe,fF)=>{"use strict";var Vm=require("lodash"),Dn=require("alasql");Dn.options.cache=!1;var sre=eg(),uF=require("clone"),tg=require("recursive-iterator"),ke=z(),tt=ie(),Gu=jn(),ire=(k(),v(K)),{hdbErrors:ore}=_e(),{getDatabases:dF}=(Le(),v(ft)),are="IS NULL",si="There was a problem performing this search. Please check the logs and try again.";sre(Dn);var pI=class{static{o(this,"SQLSearch")}constructor(t,r){if(tt.isEmpty(t))throw ke.error("AST statement for SQL select process cannot be empty"),"statement cannot be null";this.statement=t,this.columns={},this.all_table_attributes=r,this.fetch_attributes=[],this.exact_search_values={},this.comparator_search_values={},this.tables=[],this.data={},this.has_aggregator=!1,this.has_ordinal=!1,this.has_outer_join=!1,this._getColumns(),this._getTables(),this._conditionsToFetchAttributeValues(),this._setAliasesForColumns(),tt.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!tt.isEmptyOrZeroLength(n))return ke.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw ke.error("Error thrown from checkEmptySQL in SQLSearch class method search."),ke.error(n),new Error(si)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw ke.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),ke.error(n),new Error(si)}if(Object.keys(this.data).length===0)return ke.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw ke.error("Error thrown from processJoins in SQLSearch class method search."),ke.error(n),new Error(si)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw ke.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),ke.error(n),new Error(si)}try{return t=await this._finalSQL(),t}catch(n){throw ke.error("Error thrown from finalSQL in SQLSearch class method search."),ke.error(n),new Error(si)}}_getColumns(){let t=new tg(this.statement);for(let{node:r,path:n}of t)r&&r.columnid&&(this.columns[n[0]]||(this.columns[n[0]]=[]),this.columns[n[0]].push(uF(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=Vm.uniqBy(t,r=>[r.databaseid,r.tableid,r.as].join()),this.tables.forEach(r=>{let n=`${r.databaseid}_${r.as?r.as:r.tableid}`;this.data[n]={},this.data[n].__hashName=dF()[r.databaseid][r.tableid].primaryKey,this.data[n].__mergedData={},this.data[n].__mergedAttributes=[],this.data[n].__mergedAttrMap={}})}_conditionsToFetchAttributeValues(){if(tt.isEmpty(this.statement.where)){ke.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new tg(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!tt.isEmpty(r)&&r.right)if(tt.isNotEmptyAndHasValue(r.right.value)){let n=tt.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new Dn.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=tt.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new Dn.yy.LogicValue({value:i}):n instanceof Dn.yy.StringValue&&tt.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new Dn.yy.NumValue({value:i}))});if(t){ke.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new tg(this.statement.where))if(r&&r.left&&r.right&&(r.left.columnid||r.right.value)&&r.op){let n=new Set,s=r.left.columnid?r.left:r.right,i=this._findColumn(s);if(!i)continue;let a=[i.table.databaseid,i.table.tableid,i.attribute].join("/");if(!tt.isEmpty(ire.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(tt.isEmpty(this.comparator_search_values[a])&&(this.comparator_search_values[a]={ignore:!1,comparators:[]}),!this.comparator_search_values[a].ignore){if(tt.isEmptyOrZeroLength(r.left.columnid)||tt.isEmptyOrZeroLength(r.right.value)){this.comparator_search_values[a].ignore=!0,this.comparator_search_values[a].comparators=[];continue}this.comparator_search_values[a].comparators.push({attribute:r.left.columnid,operation:r.op,search_value:r.right.value})}continue}if(tt.isEmpty(this.exact_search_values[a])&&(this.exact_search_values[a]={ignore:!1,values:new Set}),!this.exact_search_values[a].ignore){let c=!1;switch(r.op){case"=":!tt.isEmpty(r.right.value)||!tt.isEmpty(r.left.value)?n.add(tt.isEmpty(r.right.value)?r.left.value:r.right.value):c=!0;break;case"IN":let l=Array.isArray(r.right)?r.right:r.left;for(let u=0;u<l.length;u++)if(l[u].value)n.add(l[u].value);else{c=!0;break}break;default:c=!0;break}this.exact_search_values[a].ignore=c,c?this.exact_search_values[a].values=new Set:this.exact_search_values[a].values=new Set([...this.exact_search_values[a].values,...n])}}}_setAliasesForColumns(){if(tt.isEmptyOrZeroLength(this.all_table_attributes)&&tt.isEmptyOrZeroLength(this.statement.from)&&tt.isEmptyOrZeroLength(this.columns.columns))return;let t=[],r={};this.statement.columns.forEach((n,s)=>{if(n.columnid==="*"){t.push(s);return}if(n.aggregatorid&&(this.has_aggregator=!0),!n.aggregatorid&&!n.funcid)if(n.as_orig=n.as?n.as:n.columnid,this.statement.joins)if(r[n.as_orig]>=0){let i=r[n.as_orig]+1;n.as=`[${n.as_orig+i}]`,r[n.as_orig]=i}else n.as=`[${n.as_orig}]`,r[n.as_orig]=0;else n.as=`[${n.as_orig}]`;!n.aggregatorid&&n.funcid&&n.args&&(n.as_orig=n.as?n.as:n.toString().replace(/'/g,'"'),n.as=`[${n.as_orig}]`),n.aggregatorid&&n.expression.columnid!=="*"&&(n.as_orig=n.as?n.as:n.expression.tableid?`${n.aggregatorid}(${n.expression.tableid}.${n.expression.columnid})`:`${n.aggregatorid}(${n.expression.columnid})`,n.as=`[${n.as_orig}]`)}),this.statement.columns.length>1&&t.length>0&&Vm.pullAt(this.statement.columns,t)}_findColumn(t){let r=this.all_table_attributes.filter(n=>{if(t.columnid_orig&&t.tableid_orig)return(n.table.as===t.tableid_orig||n.table.tableid===t.tableid_orig)&&n.attribute===t.columnid_orig;if(t.tableid)return(n.table.as===t.tableid||n.table.tableid===t.tableid)&&n.attribute===t.columnid;let s=t.columnid_orig?t.columnid_orig:t.columnid;return n.attribute===s});if(tt.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);tt.isEmptyOrZeroLength(n)||(r=this.all_table_attributes.filter(s=>s.attribute===n[0].columnid&&n[0].tableid&&n[0].tableid===(s.table.as?s.table.as:s.table.tableid)))}return r[0]}async _checkEmptySQL(){let t=[];if(tt.isEmptyOrZeroLength(this.all_table_attributes)&&!tt.isEmptyOrZeroLength(this.columns.columns))return t;if(tt.isEmptyOrZeroLength(this.all_table_attributes)&&tt.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await Dn.promise(r)}catch(r){throw ke.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),ke.error(r),new Error("There was a problem with the SQL statement")}return t}_addFetchColumns(t){t&&t.length>0&&t.forEach(r=>{let n=this._findColumn(r);n&&this.fetch_attributes.push(uF(n))})}_addColumnToMergedAttributes(t,r){this.data[t].__mergedAttributes.push(r),this.data[t].__mergedAttrMap[r]=this.data[t].__mergedAttributes.length-1}_setMergedHashAttribute(t,r){this.data[t].__mergedData[r].splice(0,1,r)}_updateMergedAttribute(t,r,n,s){let i=this.data[t].__mergedAttrMap[n];this.data[t].__mergedData[r].splice(i,1,s)}async _getFetchAttributeValues(){if(tt.isEmptyOrZeroLength(Object.keys(this.columns)))return[];this._addFetchColumns(this.columns.joins);let t=null;try{t=this.statement.where?this.statement.where.toString():""}catch{throw new Error("Could not generate proper where clause")}this.columns.where&&this._addFetchColumns(this.columns.where);let r=this._isSimpleSelect();if(r?this._addFetchColumns(this.columns.columns):(!this.columns.where&&this.fetch_attributes.length===0)|t.indexOf(are)>-1&&this.tables.forEach(s=>{let i={columnid:dF()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=Vm.uniqBy(this.fetch_attributes,s=>[s.table.databaseid,s.table.as?s.table.as:s.table.tableid,s.attribute].join()),r)return await this._simpleSQLQuery();let n=this.fetch_attributes.reduce((s,i)=>{let a=`${i.table.databaseid}_${i.table.as?i.table.as:i.table.tableid}`,c=this.data[a].__hashName;return s[a]||(s[a]=[],s[a].push(null),this._addColumnToMergedAttributes(a,c)),i.attribute!==c&&(s[a].push(null),this._addColumnToMergedAttributes(a,i.attribute)),s},{});for(let s of this.fetch_attributes){let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`,a=this.data[i].__hashName,c={schema:s.table.databaseid,table:s.table.tableid,get_attributes:[s.attribute]},l=!1,u=[s.table.databaseid,s.table.tableid,s.attribute].join("/");if(s.attribute===a&&(l=!0),!tt.isEmpty(this.exact_search_values[u])&&!this.exact_search_values[u].ignore&&!tt.isEmptyOrZeroLength(this.exact_search_values[u].values))if(l)try{c.hash_values=Array.from(this.exact_search_values[u].values);let d=await Gu.getDataByHash(c);for(let f of c.hash_values)d.get(f)&&!this.data[i].__mergedData[f]&&(this.data[i].__mergedData[f]=[...n[i]],this._setMergedHashAttribute(i,f))}catch(d){throw ke.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),ke.error(d),new Error(si)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[u].values).map(async d=>{let f={...c};f.search_value=d;let m=await Gu.getDataByValue(f);for(let[h,p]of m)this.data[i].__mergedData[h]?this._updateMergedAttribute(i,h,s.attribute,p[s.attribute]):(this.data[i].__mergedData[h]=[...n[i]],this._updateMergedAttribute(i,h,s.attribute,p[s.attribute]),this._setMergedHashAttribute(i,h))}))}catch(d){throw ke.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),ke.error(d),new Error(si)}else if(!tt.isEmpty(this.comparator_search_values[u])&&!this.comparator_search_values[u].ignore&&!tt.isEmptyOrZeroLength(this.comparator_search_values[u].comparators))try{let d=this.comparator_search_values[u].comparators;for(let f=0,m=d.length;f<m;f++){let h=d[f];c.search_attribute=h.attribute,c.search_value=h.search_value;let p=await Gu.getDataByValue(c,h.operation);if(l)for(let[E]of p)this.data[i].__mergedData[E]||(this.data[i].__mergedData[E]=[...n[i]],this._setMergedHashAttribute(i,E));else for(let[E,g]of p)this.data[i].__mergedData[E]?this._updateMergedAttribute(i,E,s.attribute,g[s.attribute]):(this.data[i].__mergedData[E]=[...n[i]],this._updateMergedAttribute(i,E,s.attribute,g[s.attribute]),this._setMergedHashAttribute(i,E))}}catch(d){throw ke.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),ke.error(d),new Error(si)}else try{c.search_attribute=s.attribute,c.search_value="*";let d=await Gu.getDataByValue(c);if(l)for(let[f]of d)this.data[i].__mergedData[f]||(this.data[i].__mergedData[f]=[...n[i]],this._setMergedHashAttribute(i,f));else for(let[f,m]of d)this.data[i].__mergedData[f]?this._updateMergedAttribute(i,f,s.attribute,m[s.attribute]):(this.data[i].__mergedData[f]=[...n[i]],this._updateMergedAttribute(i,f,s.attribute,m[s.attribute]),this._setMergedHashAttribute(i,f))}catch(d){throw ke.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),ke.error(d),new Error(si)}}}_isSimpleSelect(){let t=!0;return Object.keys(this.statement).length!==2||!this.statement.columns||!this.statement.from||this.statement.from.length!==1?(t=!1,t):(this.statement.columns.forEach(r=>{r instanceof Dn.yy.Column||(t=!1)}),t)}_updateOrderByToAliases(){this.statement.order.forEach(t=>{if(t.expression.aggregatorid){t.is_aggregator=!0;return}if(t.expression.value){t.is_ordinal=!0,this.has_ordinal=!0;return}else t.is_ordinal=!1;let r=this.statement.columns.filter(s=>{let i=s.aggregatorid?s.expression:s,a=s.aggregatorid?s.as_orig:i.as_orig;return t.expression.tableid?i.columnid_orig===t.expression.columnid_orig&&i.tableid_orig===t.expression.tableid_orig:i.columnid_orig===t.expression.columnid_orig||t.expression.columnid_orig===a});r[0]||r.push(this._findColumn(t.expression));let n=r[0];if(t.is_func=!!n.funcid,t.is_aggregator=!!n.aggregatorid,n.as)if(n.as&&!t.expression.tableid)t.expression.columnid=n.as,t.expression.columnid_orig=n.as_orig;else{let s=new Dn.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new Dn.yy.Column,t.expression),t.initial_select_column.as=`[${t.expression.columnid_orig}]`,t.expression.columnid=t.initial_select_column.as;return}if(!t.is_aggregator){let s=t.is_func?new Dn.yy.FuncValue:new Dn.yy.Column;t.initial_select_column=Object.assign(s,n)}})}_addNonAggregatorsToFetchColumns(){let r=this.statement.order.filter(n=>!n.is_aggregator&&!n.is_ordinal).map(n=>n.is_func?{columnid:n.initial_select_column.args.filter(i=>!!i.columnid_orig)[0].columnid_orig}:{columnid:n.expression.columnid_orig});this._addFetchColumns(r)}async _processJoins(){let t=[],r=[],n=this.statement.from[0],s=[n],i=["? "+(n.as?" AS "+n.as:n.tableid)];t.push(Object.values(this.data[`${n.databaseid_orig}_${n.as?n.as_orig:n.tableid_orig}`].__mergedData)),this.statement.joins&&this.statement.joins.forEach(h=>{h.joinmode&&h.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(h.table);let p=h.joinmode+" JOIN ? AS "+(h.as?h.as:h.table.tableid);h.on&&(p+=" ON "+h.on.toString()),i.push(p),t.push(Object.values(this.data[`${h.table.databaseid_orig}_${h.table.as?h.table.as_orig:h.table.tableid_orig}`].__mergedData))});let a=[],c={};s.forEach(h=>{let p=this.data[`${h.databaseid_orig}_${h.as?h.as_orig:h.tableid_orig}`].__hashName,E=h.as?h.as_orig:h.tableid_orig;a.push({key:`'${E}.${p}'`,schema:h.databaseid_orig,table:h.as?h.as_orig:h.tableid_orig,keys:new Set}),r.push(`${h.as?h.as:h.tableid}.\`${p}\` AS "${E}.${p}"`),c[h.as?h.as_orig:h.tableid_orig]=this.data[`${h.databaseid_orig}_${h.as?h.as_orig:h.tableid_orig}`].__mergedAttributes});let l=this.statement.where?"WHERE "+this.statement.where:"";l=l.replace(/NOT\(NULL\)/g,"NOT NULL");let u="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(u="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(h=>{h.is_func?r.push(h.initial_select_column.toString()):h.initial_select_column.tableid?r.push(`${h.initial_select_column.tableid}.${h.initial_select_column.columnid} AS ${h.expression.columnid}`):r.push(`${h.initial_select_column.columnid} AS ${h.expression.columnid}`)}));let d="",f="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(d=this.statement.limit?"LIMIT "+this.statement.limit:"",f=this.statement.offset?"OFFSET "+this.statement.offset:"");let m=[];try{let h=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${l} ${u} ${d} ${f}`,p=this._convertColumnsToIndexes(h,s);m=await Dn.promise(p,t),t=null}catch(h){throw ke.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),ke.error(h),new Error("There was a problem processing the data.")}if(m&&m.length>0){for(let h=0,p=m.length;h<p;h++){let E=m[h];a.forEach(g=>{E[g.key]!==null&&E[g.key]!==void 0&&g.keys.add(E[g.key])})}a.forEach(h=>{let p=Object.keys(this.data[`${h.schema}_${h.table}`].__mergedData),E=Vm.difference(p,[...h.keys].map(g=>g.toString()));for(let g=0,y=E.length;g<y;g++){let T=E[g];delete this.data[`${h.schema}_${h.table}`].__mergedData[T]}})}return{existing_attributes:c,joined_length:m?m.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new tg(this.columns);for(let{node:i}of s)if(i&&i.columnid){let a=this._findColumn(i);if(a){let c=a.table.as?a.table.as:a.table.tableid;(!t[c]||t[c].indexOf(a.attribute)<0)&&n.push(a)}}n=Vm.uniqBy(n,i=>[i.table.databaseid,i.table.as?i.table.as:i.table.tableid,i.attribute].join());try{await this._getData(n)}catch(i){throw ke.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),ke.error(i),new Error(si)}}async _getData(t){try{let r=t.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]?n[i].columns.push(s.attribute):n[i]={schema:s.table.databaseid,table:s.table.tableid,columns:[s.attribute]},n},{});for(let n in r){let s=r[n],i=this.data[n].__mergedData,a=[];for(let d in i)a.push(i[d][0]);this.data[n].__mergedAttributes.push(...s.columns);let c={schema:s.schema,table:s.table,hash_values:a,get_attributes:s.columns},l=await Gu.getDataByHash(c),u=s.columns.length;for(let d=0,f=a.length;d<f;d++){let m=a[d],h=l.get(m);for(let p=0;p<u;p++){let E=s.columns[p],g=h[E]===void 0?null:h[E];this.data[n].__mergedData[m].push(g)}}}}catch(r){throw ke.error("Error thrown from getDataByHash function in SQLSearch class method getData."),ke.error(r),r}}async _finalSQL(){let t=[],r=this.statement.from[0];t.push(Object.values(this.data[`${r.databaseid_orig}_${r.as?r.as_orig:r.tableid_orig}`].__mergedData)),r.as=r.as?r.as:r.tableid,r.databaseid="",r.tableid="?",this.statement.joins&&this.statement.joins.forEach(s=>{s.as=s.as?s.as:s.table.tableid,t.push(Object.values(this.data[`${s.table.databaseid_orig}_${s.table.as?s.table.as_orig:s.table.tableid_orig}`].__mergedData)),s.table.databaseid="",s.table.tableid="?"}),this.statement.order&&this.statement.order.forEach(s=>{if(s.is_ordinal)return;this.statement.columns.filter(a=>{let c=a.aggregatorid?a.expression:a,l=a.aggregatorid?a.as_orig:c.as_orig;return s.expression.tableid?c.columnid_orig===s.expression.columnid_orig&&c.tableid_orig===s.expression.tableid_orig:c.columnid_orig===s.expression.columnid_orig||s.expression.columnid_orig===l}).length===0&&(s.expression.columnid=s.initial_select_column.columnid)}),!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&this.statement.limit&&!this.statement.joins&&(delete this.statement.limit,delete this.statement.offset);let n;try{let s=this._buildSQL();ke.trace(`Final SQL: ${s}`),n=await Dn.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),ke.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw ke.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),ke.error(s),new Error("There was a problem running the generated sql.")}return n}_translateUndefinedValues(t){try{let r=[];for(let n of t){let s=Object.create(null);Object.keys(n).forEach(i=>{n[i]===void 0?s[i]=null:s[i]=n[i]}),r.push(s)}return r}catch(r){return ke.error(ore.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),ke.trace(r.stack),t}}_buildSQL(t=!0){let r=this.statement.toString();return r=r.replace(/NOT\(NULL\)/g,"NOT NULL"),this.statement.columns.forEach(n=>{if(n.funcid&&n.as){let s=n.toString().replace(" AS "+n.as,"");r=r.replace(n.toString(),s)}}),t===!0?this._convertColumnsToIndexes(r,this.tables):r}_convertColumnsToIndexes(t,r){let n=t,s={};r.forEach(i=>{i.databaseid_orig?s[`${i.databaseid_orig}_${i.as?i.as_orig:i.tableid_orig}`]=i.as?i.as:i.tableid:s[`${i.databaseid}_${i.as?i.as:i.tableid}`]=`\`${i.as?i.as:i.tableid}\``});for(let i in this.data)this.data[i].__mergedAttributes.forEach((a,c)=>{let l=s[i],u=new RegExp(`${l}.\`${a}\``,"g"),d=`${l}.[${c}]`;n=n.replace(u,d)});for(let i in this.data)this.data[i].__mergedAttributes.forEach((a,c)=>{let l=new RegExp(`\`${a}\``,"g"),u=`[${c}]`;n=n.replace(l,u)});return n}async _simpleSQLQuery(){let t=this.statement.columns.reduce((n,s)=>(s.as_orig&&s.as_orig!=s.columnid_orig?n[s.columnid_orig]=s.as_orig:n[s.columnid_orig]||(n[s.columnid_orig]=s.columnid_orig),n),{}),r=this.fetch_attributes.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]||(n[i]={}),n[i][t[s.attribute]]=null,n},{});for(let n of this.fetch_attributes){let s=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`,i={schema:n.table.databaseid,table:n.table.tableid,get_attributes:[n.attribute]};try{i.search_attribute=n.attribute,i.search_value="*";let a=await Gu.getDataByValue(i);for(let[c,l]of a)this.data[s].__mergedData[c]||(l[n.attribute]===void 0&&(l[n.attribute]=null),this.data[s].__mergedData[c]={...r[s]}),this.data[s].__mergedData[c][t[n.attribute]]=l[n.attribute]??null}catch(a){throw ke.error("There was an error when processing this SQL operation. Check your logs"),ke.error(a),new Error(si)}}return Object.values(Object.values(this.data)[0].__mergedData)}};fF.exports=pI});var on=M((oPe,hF)=>{"use strict";var cre=c0();hF.exports={searchByConditions:ure,searchByHash:dre,searchByValue:fre,search:mre};var _I=jn(),{transformReq:EI}=ie(),lre=mF();async function ure(e){return EI(e),_I.searchByConditions(e)}o(ure,"searchByConditions");async function dre(e){EI(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of _I.searchByHash(e))r&&t.push(r);return t}o(dre,"searchByHash");async function fre(e){EI(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of _I.searchByValue(e))t.push(r);return t}o(fre,"searchByValue");function mre(e,t){try{let r=new cre(e);r.validate(),new lre(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}o(mre,"search")});var Bi=M((cPe,gF)=>{"use strict";var Km=require("crypto"),hre=ce(),{CONFIG_PARAMS:pre}=(k(),v(K)),_F="aes-256-cbc",_re=32,Ere=16,gI=64,EF=32,gre=gI+EF,pF=new Map;gF.exports={encrypt:Sre,decrypt:Tre,createNatsTableStreamName:Rre};function Sre(e){let t=Km.randomBytes(_re),r=Km.randomBytes(Ere),n=Km.createCipheriv(_F,Buffer.from(t),r),s=n.update(e);s=Buffer.concat([s,n.final()]);let i=t.toString("hex"),a=r.toString("hex"),c=s.toString("hex");return i+a+c}o(Sre,"encrypt");function Tre(e){let t=e.substr(0,gI),r=e.substr(gI,EF),n=e.substr(gre,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),a=Km.createDecipheriv(_F,Buffer.from(t,"hex"),s),c=a.update(i);return c=Buffer.concat([c,a.final()]),c.toString()}o(Tre,"decrypt");function Rre(e,t){let r=hre.get(pre.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=pF.get(r);return n||(n=Km.createHash("md5").update(r).digest("hex"),pF.set(r,n)),n}o(Rre,"createNatsTableStreamName")});var La=M((dPe,yF)=>{"use strict";var uPe=on(),Ym=z(),{validateBySchema:SF}=at(),al=require("joi"),yre=Bi(),rg=ie(),{handleHDBError:ng,hdbErrors:Are,ClientError:TF}=_e(),{HDB_ERROR_MSGS:sg,HTTP_STATUS_CODES:SI}=Are,RF=ce();RF.initSync();var{getDatabases:TI}=(Le(),v(ft)),bre=require("fs-extra"),Ire=(k(),v(K));yF.exports={describeAll:Nre,describeTable:ig,describeSchema:wre};async function Nre(e={}){try{let t=rg.isEmptyOrZeroLength(e),r=!!e.bypass_auth,n,s;!t&&!r&&(n=e.hdb_user?.role?.permission,s=n?.super_user||n?.cluster_user);let i=TI(),a={},c={},l=[],u=e?.exact_count;for(let f in i){a[f]=!0,!t&&!s&&!r&&(c[f]=e.hdb_user?.role?.permission[f]?.describe);let m=i[f];for(let h in m)try{let p;if(t||s||r)p=await ig({schema:f,table:h,exactCount:u});else if(n&&n[f].describe&&n[f].tables[h].describe){let E=n[f].tables[h].attribute_permissions;p=await ig({schema:f,table:h,exactCount:u},E)}p&&l.push(p)}catch(p){Ym.error(p)}}let d={};for(let f in l)t||s||r?(d[l[f].schema]==null&&(d[l[f].schema]={}),d[l[f].schema][l[f].name]=l[f],a[l[f].schema]&&delete a[l[f].schema]):c[l[f].schema]&&(d[l[f].schema]==null&&(d[l[f].schema]={}),d[l[f].schema][l[f].name]=l[f],a[l[f].schema]&&delete a[l[f].schema]);for(let f in a)t||s||r?d[f]={}:c[f]&&(d[f]={});return d}catch(t){return Ym.error("Got an error in describeAll"),Ym.error(t),ng(new Error,sg.DESCRIBE_ALL_ERR)}}o(Nre,"describeAll");async function ig(e,t){rg.transformReq(e);let{schema:r,table:n}=e;r=r?.toString(),n=n?.toString();let s=t;e.hdb_user&&!e.hdb_user?.role?.permission?.super_user&&(s=e.hdb_user?.role?.permission[r]?.tables[n]?.attribute_permissions);let i=SF(e,al.object({database:al.string(),table:al.string().required(),exact_count:al.boolean().strict()}));if(i)throw new TF(i.message);let c=TI()[r];if(!c)throw ng(new Error,sg.SCHEMA_NOT_FOUND(e.schema),SI.NOT_FOUND);let l=c[n];if(!l)throw ng(new Error,sg.TABLE_NOT_FOUND(e.schema,e.table),SI.NOT_FOUND);function u(h){d.push({attribute:h.attribute,type:h.type,elements:h.elements?.type,indexed:h.indexed,is_primary_key:h.isPrimaryKey,assigned_created_time:h.assignCreatedTime,assigned_updated_time:h.assignUpdatedTime,nullable:h.nullable,properties:h.properties?h.properties.map(p=>({type:p.type,name:p.name})):void 0})}o(u,"pushAtt");let d=[];if(s){let h={};s.forEach(p=>{p.describe&&(h[p.attribute_name]=!0)}),l.attributes.forEach(p=>{h[p.name]&&u(p)})}else l.attributes?.forEach(h=>u(h));let f;try{f=(await bre.stat(l.primaryStore.env.path)).size}catch(h){Ym.warn("unable to get database size",h)}let m={schema:r,name:l.tableName,hash_attribute:l.attributes.find(h=>h.isPrimaryKey||h.is_hash_attribute)?.name,audit:l.audit,schema_defined:l.schemaDefined,attributes:d,db_size:f};l.replicate!==void 0&&(m.replicate=l.replicate),l.expirationMS!==void 0&&(m.expiration=l.expirationMS/1e3+"s"),l.sealed!==void 0&&(m.sealed=l.sealed),l.sources?.length>0&&(m.sources=l.sources.map(h=>h.name).filter(h=>h&&h!=="NATSReplicator"&&h!=="Replicator")),RF.get(Ire.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(m.clustering_stream_name=yre.createNatsTableStreamName(m.schema,m.name));try{let h=await l.getRecordCount({exactCount:!!e.exact_count});m.record_count=h.recordCount,m.table_size=l.getSize(),m.db_audit_size=l.getAuditSize(),m.estimated_record_range=h.estimatedRange;let p=l.auditStore;if(p)for(let E of p.getKeys({reverse:!0,limit:1}))m.last_updated_record=E[0];if(!m.last_updated_record&&l.indices.__updatedtime__)for(let E of l.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))m.last_updated_record=E}catch(h){Ym.warn(`unable to stat table dbi due to ${h}`)}return m}o(ig,"descTable");async function wre(e){rg.transformReq(e);let t=SF(e,al.object({database:al.string(),exact_count:al.boolean().strict()}));if(t)throw new TF(t.message);let r;e.hdb_user&&!e.hdb_user?.role?.permission?.super_user&&(r=e.hdb_user?.role?.permission[e.schema]);let n=e.schema.toString(),i=TI()[n];if(!i)throw ng(new Error,sg.SCHEMA_NOT_FOUND(e.schema),SI.NOT_FOUND);let a={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),rg.isEmpty(l)||l.describe){let u=await ig({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);u&&(a[u.name]=u)}}return a}o(wre,"describeSchema")});var Mn=M((mPe,NF)=>{"use strict";var ag=Ab(),$r=ie(),Ore=require("util"),cg=jn(),Cre=Ns(),AF=z(),{handleHDBError:cl,hdbErrors:Pre}=_e(),{HTTP_STATUS_CODES:ll}=Pre,Lre=Ore.promisify(Cre.getTableSchema),Dre="updated",bF="inserted",IF="upserted";NF.exports={insert:vre,update:Ure,upsert:xre,validation:Mre,flush:Bre};async function Mre(e){if($r.isEmpty(e))throw new Error("invalid update parameters defined.");if($r.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if($r.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await Lre(e.schema,e.table),r=ag(e);if(r)throw r;if(!Array.isArray(e.records))throw new Error("records must be an array");let n=t.hash_attribute,s=new Set,i={},a=!1;return e.operation==="update"&&(a=!0),e.records.forEach(c=>{if(a&&$r.isEmptyOrZeroLength(c[n]))throw AF.error("a valid hash attribute must be provided with update record:",c),new Error("a valid hash attribute must be provided with update record");if(!$r.isEmptyOrZeroLength(c[n])&&(c[n]==="null"||c[n]==="undefined"))throw AF.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[n]}" is not a valid hash attribute value`);!$r.isEmpty(c[n])&&c[n]!==""&&s.has($r.autoCast(c[n]))&&(c.skip=!0),s.add($r.autoCast(c[n]));for(let l in c)i[l]=1}),i[n]=1,{schema_table:t,hashes:Array.from(s),attributes:Object.keys(i)}}o(Mre,"validation");async function vre(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=ag(e);if(t)throw cl(new Error,t.message,ll.BAD_REQUEST);$r.transformReq(e);let r=$r.checkSchemaTableExist(e.schema,e.table);if(r)throw cl(new Error,r,ll.BAD_REQUEST);let n=await cg.createRecords(e);return og(bF,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}o(vre,"insertData");async function Ure(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=ag(e);if(t)throw cl(new Error,t.message,ll.BAD_REQUEST);$r.transformReq(e);let r=$r.checkSchemaTableExist(e.schema,e.table);if(r)throw cl(new Error,r,ll.BAD_REQUEST);let n=await cg.updateRecords(e);return $r.isEmpty(n.existing_rows)?og(Dre,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):og(n.update_action,[],e,n.hashes,void 0,n.txn_time)}o(Ure,"updateData");async function xre(e){if(e.operation!=="upsert")throw cl(new Error,"invalid operation, must be upsert",ll.INTERNAL_SERVER_ERROR);let t=ag(e);if(t)throw cl(new Error,t.message,ll.BAD_REQUEST);$r.transformReq(e);let r=$r.checkSchemaTableExist(e.schema,e.table);if(r)throw cl(new Error,r,ll.BAD_REQUEST);let n=await cg.upsertRecords(e);return og(IF,n.written_hashes,e,[],n.new_attributes,n.txn_time)}o(xre,"upsertData");function og(e,t,r,n,s,i){let a={message:`${e} ${t.length} of ${t.length+n.length} records`,new_attributes:s,txn_time:i};return e===bF?(a.inserted_hashes=t,a.skipped_hashes=n,a):e===IF?(a.upserted_hashes=t,a):(a.update_hashes=t,a.skipped_hashes=n,a)}o(og,"returnObject");function Bre(e){return $r.transformReq(e),cg.flush(e.schema,e.table)}o(Bre,"flush")});var yI=M((pPe,CF)=>{var Fre=at(),RI=require("joi"),{hdbTable:Hre,hdbDatabase:wF}=Mi(),OF={schema:wF,database:wF,table:Hre},kre={date:RI.date().iso().required()},Gre={timestamp:RI.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};CF.exports=function(e,t){let r=t==="timestamp"?{...OF,...Gre}:{...OF,...kre},n=RI.object(r);return Fre.validateBySchema(e,n)}});var DF=M((_Pe,LF)=>{var qre=at(),AI=require("joi"),{hdbTable:$re,hdbDatabase:PF}=Mi(),Vre=AI.object({schema:PF,database:PF,table:$re,hash_values:AI.array().required(),ids:AI.array()});LF.exports=function(e){return qre.validateBySchema(e,Vre)}});var wI=M((EPe,MF)=>{"use strict";var bI=class{static{o(this,"InsertObject")}constructor(t,r,n,s,i){this.operation=t,this.schema=r,this.table=n,this.hash_attribute=s,this.records=i}},II=class{static{o(this,"NoSQLSeachObject")}constructor(t,r,n,s,i,a){this.schema=t,this.table=r,this.search_attribute=n,this.hash_attribute=s,this.get_attributes=i,this.search_value=a}},NI=class{static{o(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};MF.exports={InsertObject:bI,NoSQLSeachObject:II,DeleteResponseObject:NI}});var fl=M((SPe,FF)=>{"use strict";var UF=yI(),Kre=DF(),ul=ie(),vF=require("moment"),xF=z(),{promisify:Yre,callbackify:Wre}=require("util"),dl=(k(),v(K)),zre=Ns(),OI=Yre(zre.getTableSchema),CI=jn(),{DeleteResponseObject:jre}=wI(),{handleHDBError:Da,hdbErrors:Qre}=_e(),{HDB_ERROR_MSGS:lg,HTTP_STATUS_CODES:Ma}=Qre,Jre="records successfully deleted",Xre=Wre(BF);FF.exports={delete:Xre,deleteRecord:BF,deleteFilesBefore:Zre,deleteAuditLogsBefore:ene};async function Zre(e){let t=UF(e,"date");if(t)throw Da(t,t.message,Ma.BAD_REQUEST,void 0,void 0,!0);if(ul.transformReq(e),!vF(e.date,vF.ISO_8601).isValid())throw Da(new Error,lg.INVALID_DATE,Ma.BAD_REQUEST,dl.LOG_LEVELS.ERROR,lg.INVALID_DATE,!0);let n=ul.checkSchemaTableExist(e.schema,e.table);if(n)throw Da(new Error,n,Ma.NOT_FOUND,dl.LOG_LEVELS.ERROR,n,!0);let s=await CI.deleteRecordsBefore(e);if(await OI(e.schema,e.table),xF.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}o(Zre,"deleteFilesBefore");async function ene(e){let t=UF(e,"timestamp");if(t)throw Da(t,t.message,Ma.BAD_REQUEST,void 0,void 0,!0);if(ul.transformReq(e),isNaN(e.timestamp))throw Da(new Error,lg.INVALID_VALUE("Timestamp"),Ma.BAD_REQUEST,dl.LOG_LEVELS.ERROR,lg.INVALID_VALUE("Timestamp"),!0);let r=ul.checkSchemaTableExist(e.schema,e.table);if(r)throw Da(new Error,r,Ma.NOT_FOUND,dl.LOG_LEVELS.ERROR,r,!0);let n=await CI.deleteAuditLogsBefore(e);return await OI(e.schema,e.table),xF.info(`Finished deleting audit logs before ${e.timestamp}`),n}o(ene,"deleteAuditLogsBefore");async function BF(e){e.ids&&(e.hash_values=e.ids);let t=Kre(e);if(t)throw Da(t,t.message,Ma.BAD_REQUEST,void 0,void 0,!0);ul.transformReq(e);let r=ul.checkSchemaTableExist(e.schema,e.table);if(r)throw Da(new Error,r,Ma.NOT_FOUND,dl.LOG_LEVELS.ERROR,r,!0);try{await OI(e.schema,e.table);let n=await CI.deleteRecords(e);return ul.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${Jre}`),n}catch(n){if(n.message===dl.SEARCH_NOT_FOUND_MESSAGE){let s=new jre;return s.message=dl.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}o(BF,"deleteRecord")});var ug={};Ce(ug,{HASH_FUNCTION:()=>Mr,hash:()=>DI,validate:()=>MI});function PI(e=zm){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ";return Array.from(Wm.randomBytes(e)).map(r=>t[r%t.length]).join("")}function DI(e,t=Mr[kF?.toUpperCase()]??Mr.SHA256){return LI[t](e)}function MI(e,t,r=Mr[kF?.toUpperCase()]??Mr.SHA256){return e?tne[r](e,t):!1}var Wm,qu,HF,kF,zm,GF,Mr,LI,tne,dg=fe(()=>{Wm=w(require("node:crypto")),qu=w(require("argon2")),HF=w(ce());k();kF=(0,HF.get)(U.AUTHENTICATION_HASHFUNCTION)?.toLowerCase(),zm=16,GF=9,Mr={MD5:"md5",SHA256:"sha256",ARGON2ID:"argon2id"};o(PI,"generateSalt");LI={[Mr.MD5]:(e,t=void 0)=>{t=t??PI(GF);let r=Wm.createHash(Mr.MD5).update(e+t).digest("hex");return t+r},[Mr.SHA256]:(e,t=void 0)=>{t=t??PI(zm);let r=Wm.createHash(Mr.SHA256).update(e+t).digest("hex");return t+r},[Mr.ARGON2ID]:async e=>{let t=PI(zm),r=await qu.hash(e,{type:qu.argon2id,salt:Buffer.from(t)});return t+r}},tne={[Mr.MD5]:(e,t)=>{let r=e.slice(0,GF);return e===LI[Mr.MD5](t,r)},[Mr.SHA256]:(e,t)=>{let r=e.slice(0,zm);return e===LI[Mr.SHA256](t,r)},[Mr.ARGON2ID]:async(e,t)=>await qu.verify(e.slice(zm),t)};o(DI,"hash");o(MI,"validate")});var $F=M((APe,qF)=>{var vI=at(),an={username:{presence:!0,exclusion:{within:["system"],message:"You cannot create tables within the system schema"}},password:{presence:!0},role:{presence:!0,format:"[\\w\\-\\_]+"},active:{presence:!0,inclusion:{within:[!0,!1],message:"must be a boolean"}}};function rne(e){return an.password.presence=!0,an.username.presence=!0,an.role.presence=!0,an.active.presence=!0,vI.validateObject(e,an)}o(rne,"addUserValidation");function nne(e){return an.password.presence=!1,an.username.presence=!0,an.role.presence=!1,an.active.presence=!1,vI.validateObject(e,an)}o(nne,"alterUserValidation");function sne(e){return an.password.presence=!1,an.username.presence=!0,an.role.presence=!1,an.active.presence=!1,vI.validateObject(e,an)}o(sne,"dropUserValidation");qF.exports={addUserValidation:rne,alterUserValidation:nne,dropUserValidation:sne}});var It=M((NPe,KF)=>{"use strict";var{platform:IPe}=require("os"),ine="nats-server.zip",UI="nats-server",one=process.platform==="win32"?`${UI}.exe`:UI,ane=/^[^\s.,*>]+$/,VF="__request__",cne=o(e=>`${e}.${VF}`,"REQUEST_SUBJECT"),lne={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},une={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},dne={HUB:"hub.pid",LEAF:"leaf.pid"},fne={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},mne={SUCCESS:"success",ERROR:"error"},hne={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},pne={TXN:"txn",MSGID:"msgid"},$u={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},_ne={[$u.ERR]:1,[$u.WRN]:2,[$u.INF]:3,[$u.DBG]:4,[$u.TRC]:5},Ene={debug:"-D",trace:"-DVV"};KF.exports={NATS_SERVER_ZIP:ine,NATS_SERVER_NAME:UI,NATS_BINARY_NAME:one,PID_FILES:dne,NATS_CONFIG_FILES:une,SERVER_SUFFIX:fne,NATS_TERM_CONSTRAINTS_RX:ane,REQUEST_SUFFIX:VF,UPDATE_REMOTE_RESPONSE_STATUSES:mne,CLUSTER_STATUS_STATUSES:hne,REQUEST_SUBJECT:cne,SUBJECT_PREFIXES:pne,MSG_HEADERS:lne,LOG_LEVELS:$u,LOG_LEVEL_FLAGS:Ene,LOG_LEVEL_HIERARCHY:_ne}});var Jn=M((OPe,vr)=>{"use strict";var zF="username is required",jF="nothing to update, must supply active, role or password to update",QF="password cannot be an empty string",JF="If role is specified, it cannot be empty.",XF="active must be true or false";vr.exports.addUser=Nne;vr.exports.alterUser=wne;vr.exports.dropUser=Cne;vr.exports.getSuperUser=vne;vr.exports.userInfo=Pne;vr.exports.listUsers=mg;vr.exports.listUsersExternal=Lne;vr.exports.setUsersWithRolesCache=ml;vr.exports.findAndValidateUser=VI;vr.exports.getClusterUser=Une;vr.exports.getUsersWithRolesCache=Mne;vr.exports.USERNAME_REQUIRED=zF;vr.exports.ALTERUSER_NOTHING_TO_UPDATE=jF;vr.exports.EMPTY_PASSWORD=QF;vr.exports.EMPTY_ROLE=JF;vr.exports.ACTIVE_BOOLEAN=XF;var ZF=Mn(),gne=fl(),jm=(dg(),v(ug)),eH=$F(),Qm=on(),kI=No(),Fi=ie(),tH=require("validate.js"),GI=z(),{promisify:Sne}=require("util"),qI=Bi(),BI=(k(),v(K)),YF=It(),Tne=yt(),Rne=ce(),yne=Ao(),{hdbErrors:Ane,ClientError:ii}=_e(),{HTTP_STATUS_CODES:Po,AUTHENTICATION_ERROR_MSGS:xI,HDB_ERROR_MSGS:Vu}=Ane,{UserEventMsg:$I}=ti(),FI=require("lodash"),{server:fg}=(Pr(),v(Ff)),bne=z();fg.getUser=(e,t)=>VI(e,t,t!=null);fg.authenticateUser=(e,t)=>VI(e,t);var rH={username:!0,active:!0,role:!0,password:!0},WF=new Map,Ine=Sne(gne.delete),HI=Rne.get(BI.CONFIG_PARAMS.AUTHENTICATION_HASHFUNCTION)??jm.HASH_FUNCTION.SHA256,Hi;async function Nne(e){let t=tH.cleanAttributes(e,rH),r=eH.addUserValidation(t);if(r)throw new ii(r.message);let n=await Qm.searchByValue({schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["id","permission","role"]});if(!n||n.length<1)throw new ii(Vu.ROLE_NAME_NOT_FOUND(t.role),Po.NOT_FOUND);if(n.length>1)throw new ii(Vu.DUP_ROLES_FOUND(t.role),Po.CONFLICT);n[0].permission.cluster_user===!0&&(t.hash=qI.encrypt(t.password)),t.password=await jm.hash(t.password,HI),t.hash_function=HI,t.role=n[0].id;let s=await ZF.insert({operation:"insert",schema:"system",table:"hdb_user",records:[t]});if(GI.debug(s),await ml(),s.skipped_hashes.length===1)throw new ii(Vu.USER_ALREADY_EXISTS(t.username),Po.CONFLICT);return kI.signalUserChange(new $I(process.pid)),`${t.username} successfully added`}o(Nne,"addUser");async function wne(e){let t=tH.cleanAttributes(e,rH);if(Fi.isEmptyOrZeroLength(t.username))throw new Error(zF);if(Fi.isEmptyOrZeroLength(t.password)&&Fi.isEmptyOrZeroLength(t.role)&&Fi.isEmptyOrZeroLength(t.active))throw new Error(jF);if(!Fi.isEmpty(t.password)&&Fi.isEmptyOrZeroLength(t.password.trim()))throw new Error(QF);if(!Fi.isEmpty(t.active)&&!Fi.isBoolean(t.active))throw new Error(XF);if(!Fi.isEmpty(t.password)&&!Fi.isEmptyOrZeroLength(t.password.trim())&&(One(t.username)&&(t.hash=qI.encrypt(t.password)),t.password=await jm.hash(t.password,HI)),t.role==="")throw new Error(JF);if(t.role){let n=await Qm.searchByValue({schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]});if(!n||n.length===0)throw new ii(Vu.ALTER_USER_ROLE_NOT_FOUND(t.role),Po.NOT_FOUND);if(n.length>1)throw new ii(Vu.DUP_ROLES_FOUND(t.role),Po.CONFLICT);t.role=n[0].id}let r=await ZF.update({operation:"update",schema:"system",table:"hdb_user",records:[t]});return await ml(),kI.signalUserChange(new $I(process.pid)),r}o(wne,"alterUser");function One(e){let t=!1,r=Hi.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}o(One,"isClusterUser");async function Cne(e){let t=eH.dropUserValidation(e);if(t)throw new ii(t.message);if(Hi.get(e.username)===void 0)throw new ii(Vu.USER_NOT_EXIST(e.username),Po.NOT_FOUND);let r=await Ine({table:"hdb_user",schema:"system",hash_values:[e.username]});return GI.debug(r),await ml(),kI.signalUserChange(new $I(process.pid)),`${e.username} successfully deleted`}o(Cne,"dropUser");async function Pne(e){let t={};if(!e||!e.hdb_user)return"There was no user info in the body";t=FI.cloneDeep(e.hdb_user);let r=await Qm.searchByHash({schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]});return t.role=r[0],delete t.password,delete t.refresh_token,delete t.hash,delete t.hash_function,t}o(Pne,"userInfo");async function Lne(){let e=await mg();return e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token,delete t.hash_function}),[...e.values()]}o(Lne,"listUsersExternal");async function mg(){let e=await Qm.searchByValue({schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]}),t={};for(let s of e)t[s.id]=FI.cloneDeep(s);if(Object.keys(t).length===0)return null;let r=await Qm.searchByValue({schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]}),n=new Map;for(let s of r)s=FI.cloneDeep(s),s.role=t[s.role],Dne(s.role),n.set(s.username,s);return n}o(mg,"listUsers");function Dne(e){if(!e){GI.error("invalid user role found.");return}e.permission.system||(e.permission.system={}),e.permission.system.tables||(e.permission.system.tables={});for(let t of Object.keys(yne)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}o(Dne,"appendSystemTablesToRole");async function ml(e=void 0){e?Hi=e:Hi=await mg()}o(ml,"setUsersWithRolesCache");async function Mne(){return Hi||await ml(),Hi}o(Mne,"getUsersWithRolesCache");async function VI(e,t,r=!0){Hi||await ml();let n=Hi.get(e);if(!n){if(!r)return{username:e};throw new ii(xI.GENERIC_AUTH_FAIL,Po.UNAUTHORIZED)}if(n&&!n.active)throw new ii(xI.USER_INACTIVE,Po.UNAUTHORIZED);let s={active:n.active,username:n.username};if(n.refresh_token&&(s.refresh_token=n.refresh_token),n.role&&(s.role=n.role),r===!0){if(WF.get(t)===n.password)return s;{let i=jm.validate(n.password,t,n.hash_function||jm.HASH_FUNCTION.MD5);if(i?.then&&(i=await i),i===!0)WF.set(t,n.password);else throw new ii(xI.GENERIC_AUTH_FAIL,Po.UNAUTHORIZED)}}return s}o(VI,"findAndValidateUser");async function vne(){Hi||await ml();for(let[,e]of Hi)if(e.role.role==="super_user")return e}o(vne,"getSuperUser");async function Une(){let e=await mg(),t=Tne.getConfigFromFile(BI.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!(r==null||r?.role?.role!==BI.ROLE_TYPES_ENUM.CLUSTER_USER))return r.decrypt_hash=qI.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+YF.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+YF.SERVER_SUFFIX.ADMIN,r}o(Une,"getClusterUser");var nH=[];fg.invalidateUser=function(e){for(let t of nH)try{t(e)}catch(r){bne.error("Error invalidating user",r)}};fg.onInvalidatedUser=function(e){nH.push(e)}});var Xm=M((DPe,aH)=>{"use strict";var hl=z(),Xn=(k(),v(K)),xne=YU(),PPe=Ns(),LPe=La(),Bne=Jn(),{validateEvent:sH}=ti(),Jm=jn(),Fne=require("process"),{resetDatabases:Hne}=(Le(),v(ft)),kne={[Xn.ITC_EVENT_TYPES.SCHEMA]:Gne,[Xn.ITC_EVENT_TYPES.USER]:oH};async function Gne(e){let t=sH(e);if(t){hl.error(t);return}hl.trace("ITC schemaHandler received schema event:",e),await xne(e.message),await qne(e.message)}o(Gne,"schemaHandler");async function qne(e){try{Jm.resetReadTxn(Xn.SYSTEM_SCHEMA_NAME,Xn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),Jm.resetReadTxn(Xn.SYSTEM_SCHEMA_NAME,Xn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),Jm.resetReadTxn(Xn.SYSTEM_SCHEMA_NAME,Xn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=Hne();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){hl.error(t)}}o(qne,"syncSchemaMetadata");var iH=[];async function oH(e){try{try{Jm.resetReadTxn(Xn.SYSTEM_SCHEMA_NAME,Xn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),Jm.resetReadTxn(Xn.SYSTEM_SCHEMA_NAME,Xn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){hl.warn(r)}let t=sH(e);if(t){hl.error(t);return}hl.trace(`ITC userHandler ${Xn.HDB_ITC_CLIENT_PREFIX}${Fne.pid} received user event:`,e),await Bne.setUsersWithRolesCache();for(let r of iH)r()}catch(t){hl.error(t)}}o(oH,"userHandler");oH.addListener=function(e){iH.push(e)};aH.exports=kne});var ti=M((FPe,lH)=>{"use strict";var vPe=z(),KI=ie(),$ne=(k(),v(K)),{ITC_ERRORS:Zm}=tn(),{parentPort:UPe,threadId:Vne,isMainThread:Kne,workerData:xPe}=require("worker_threads"),{onMessageFromWorkers:Yne,broadcast:BPe,broadcastWithAcknowledgement:Wne}=st();lH.exports={sendItcEvent:zne,validateEvent:cH,SchemaEventMsg:jne,UserEventMsg:Qne};var hg;Yne(async(e,t)=>{hg=hg||Xm(),cH(e),hg[e.type]&&await hg[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function zne(e){return!Kne&&e.message&&(e.message.originator=Vne),Wne(e)}o(zne,"sendItcEvent");function cH(e){if(typeof e!="object")return Zm.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||KI.isEmpty(e.type))return Zm.MISSING_TYPE;if(!e.hasOwnProperty("message")||KI.isEmpty(e.message))return Zm.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||KI.isEmpty(e.message.originator))return Zm.MISSING_ORIGIN;if($ne.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return Zm.INVALID_EVENT(e.type)}o(cH,"validateEvent");function jne(e,t,r,n=void 0,s=void 0){this.originator=e,this.operation=t,this.schema=r,this.table=n,this.attribute=s}o(jne,"SchemaEventMsg");function Qne(e){this.originator=e}o(Qne,"UserEventMsg")});var No=M((GPe,mH)=>{"use strict";var uH=(k(),v(K)),kPe=ie(),pg=z(),dH=OU(),Ku,{sendItcEvent:fH}=ti();function Jne(e){try{pg.info("signalSchemaChange called with message:",e),Ku=Ku||Xm();let t=new dH(uH.ITC_EVENT_TYPES.SCHEMA,e);return Ku.schema(t),fH(t)}catch(t){pg.error(t)}}o(Jne,"signalSchemaChange");function Xne(e){try{pg.trace("signalUserChange called with message:",e),Ku=Ku||Xm();let t=new dH(uH.ITC_EVENT_TYPES.USER,e);return Ku.user(t),fH(t)}catch(t){pg.error(t)}}o(Xne,"signalUserChange");mH.exports={signalSchemaChange:Jne,signalUserChange:Xne}});function _g(){return YI||(YI=et({table:"hdb_analytics_hostname",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"hostname"}]})),YI}function ese(e){return e=e.replace(Zne,t=>{let[r,n,s,i]=t.split(".").map(a=>parseInt(a));return(r<<8|n).toString(16)+":"+(s<<8|i).toString(16)}),e=e.replace("::",":".repeat(10-e.split(":").length)),e.toLowerCase().split(":").map(t=>t.padStart(4,"0")).join(":")}function tse(e){if(e.length!==4)throw new Error(`nodeHash must be exactly 4 bytes (32 bits); got ${e.length} bytes`);return e[0]<<24|e[1]<<16|e[2]<<8|e[3]}function zI(e){let t=hH.default.createHash("shake128",{outputLength:4}),r;return(0,pH.isIPv6)(e)?r=ese(e):r=e.toLowerCase(),tse(Uint8Array.from(t.update(r).digest()))}var hH,pH,WI,YI,Zne,jI=fe(()=>{Le();hH=w(require("crypto")),pH=require("node:net"),WI=new Map;o(_g,"getAnalyticsHostnameTable");Zne=/(\d{1,3}\.){3}\d{1,3}$/;o(ese,"normalizeIPv6");o(tse,"nodeHashToNumber");o(zI,"stableNodeId")});var Lo,QI=fe(()=>{Lo={TABLE_SIZE:"table-size",DATABASE_SIZE:"database-size",STORAGE_VOLUME:"storage-volume",MAIN_THREAD_UTILIZATION:"main-thread-utilization",RESOURCE_USAGE:"resource-usage",UTILIZATION:"utilization"}});var Rg={};Ce(Rg,{addAnalyticsListener:()=>rh,calculateCPUUtilization:()=>DH,diffResourceUsage:()=>MH,recordAction:()=>gt,recordActionBinary:()=>Kr,recordHostname:()=>ZI,setAnalyticsEnabled:()=>rse});function rse(e){wH=e}function nse(e,t){if(typeof e=="number"){let r=t.values,n=r.index++;if(n>=r.length){let s=r;t.values=r=new Float32Array(n*2),r.set(s),r.index=n+1}r[n]=e,t.total+=e}else if(typeof e=="boolean")e&&t.total++,t.count++;else if(typeof e=="function")t.count++;else throw new TypeError("Invalid metric value type "+typeof e)}function sse(e,t,r,n,s,i){let a={};if(typeof t=="number")a.total=t,a.values=new Float32Array(4),a.values.index=1,a.values[0]=t,a.total=t;else if(typeof t=="boolean")a.total=t?1:0,a.count=1;else if(typeof t=="function")a.count=1,a.callback=t;else throw new TypeError("Invalid metric value type "+typeof t);a.description={metric:r,path:n,method:s,type:i},Sg.set(e,a)}function gt(e,t,r,n,s){if(!wH)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let a=Sg.get(i);a?nse(e,a):sse(i,e,t,r,n,s),gg||ise()}function Kr(e,t,r,n,s){gt(!!e,t,r,n,s)}function rh(e){PH.push(e)}function ise(){gg=performance.now(),setTimeout(async()=>{let e=performance.now()-gg;gg=0;let t=[],r={time:Date.now(),period:e,threadId:pl.threadId,metrics:t};for(let[s,i]of Sg){if(i.values){let a=i.values.subarray(0,i.values.index);a.sort();let c=a.length,l=0,u=[],d;for(let f of LH){let m=Math.floor(c*f),h=a[m-1];if(m>l){let p=m-l;if(h===d){let E=u[u.length-1];typeof E=="number"?u[u.length-1]={value:E,count:1+p}:E.count+=p}else u.push(p>1?{value:h,count:p}:h),d=h;l=m}}t.push(Object.assign(i.description,{mean:i.total/c,distribution:u,count:c}))}else i.callback?t.push(Object.assign(i.description,i.callback(i))):t.push(Object.assign(i.description,{total:i.total,count:i.count}));await vH()}let n=process.memoryUsage();t.push({metric:"memory",threadId:pl.threadId,byThread:!0,...n});for(let s of PH)s(t);Sg=new Map,pl.parentPort?pl.parentPort.postMessage({type:CH,report:r}):BH({report:r})},OH).unref()}async function ZI(){let e=ve.hostname;Vr.trace?.("recordHostname server.hostname:",e);let t=zI(e);Vr.trace?.("recordHostname nodeId:",t);let r=_g();if(!await r.get(t)){let s={id:t,hostname:e};Vr.trace?.(`recordHostname storing hostname: ${JSON.stringify(s)}`),r.put(s.id,s)}}function Yu(e,t){let r=ve.hostname,n=WI.get(r);n?Vr.trace?.("storeMetric cached nodeId:",n):(n=zI(r),Vr.trace?.("storeMetric new nodeId:",n),WI.set(r,n));let s={id:[(0,XI.getNextMonotonicTime)(),n],...t};Vr.trace?.(`storing metric ${JSON.stringify(s)}`),e.put(s.id,s)}function DH(e,t){let r=e.userCPUTime+e.systemCPUTime;return Vr.trace?.(`calculateCPUUtilization cpuTime: ${r} period: ${t}`),Math.round(r/t*100)/100}function MH(e,t){return{userCPUTime:t.userCPUTime-(e?.userCPUTime??0),systemCPUTime:t.systemCPUTime-(e?.systemCPUTime??0),minorPageFault:t.minorPageFault-(e?.minorPageFault??0),majorPageFault:t.majorPageFault-(e?.majorPageFault??0),fsRead:t.fsRead-(e?.fsRead??0),fsWrite:t.fsWrite-(e?.fsWrite??0),voluntaryContextSwitches:t.voluntaryContextSwitches-(e?.voluntaryContextSwitches??0),involuntaryContextSwitches:t.involuntaryContextSwitches-(e?.involuntaryContextSwitches??0)}}function ose(e,t,r){let n=0;for(let[s,i]of Object.entries(r)){let a=`${t}.${s}`,c=i.getSize(),l={metric:Lo.TABLE_SIZE,database:t,table:s,size:c};Vr.trace?.(`table ${a} size metric: ${JSON.stringify(l)}`),Yu(e,l),n+=c}return n}function _H(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s?.getAuditSize();if(!i)return;let a=NH.statSync(s.primaryStore.env.path).size,c=ose(e,r,n),l=a-c,u={metric:Lo.DATABASE_SIZE,database:r,size:a,used:c,free:l,audit:i};Yu(e,u),Vr.trace?.(`database ${r} size metric: ${JSON.stringify(u)}`)}catch(s){Vr.warn?.("Error getting DB size metrics",s)}}function EH(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s?.getStorageStats();if(!i)return;let a={metric:Lo.STORAGE_VOLUME,database:r,...i};Yu(e,a),Vr.trace?.(`db ${r} storage volume metrics: ${JSON.stringify(a)}`)}catch(s){Vr.warn?.("Error getting DB volume metrics",s)}}async function ase(e,t=6e4){let r=eN(),n=UH(),s=new Promise(R=>{let I=performance.now();setImmediate(()=>{let P=performance.now();P-I>5e3&&Vr.warn?.("Unusually high event queue latency on the main thread of "+Math.round(P-I)+"ms"),I=performance.now()}),n.primaryStore.prefetch([1],()=>{let P=performance.now();P-I>5e3&&Vr.warn?.("Unusually high task queue latency on the main thread of "+Math.round(P-I)+"ms"),R(P-I)})}),i;for(let R of n.primaryStore.getRange({start:1/0,end:!1,reverse:!0}))if(R.value?.time){i=R.value.time;break}if(Date.now()-t<i)return;let a,c=new Map,l=new Map,u=[],d;for(let{key:R,value:I}of r.primaryStore.getRange({start:i||!1,exclusiveStart:!0,end:1/0})){if(!I)continue;if(a){if(R>a+t)break}else a=R;d=R;let{metrics:P,threadId:Y}=I;for(let te of P||[]){let{path:x,method:$,type:j,metric:V,count:le,total:re,distribution:se,threads:Ee,...Ne}=te;le||(le=1);let Fe=V+(x?"-"+x:"");$!==void 0&&(Fe+="-"+$),j!==void 0&&(Fe+="-"+j);let He=c.get(Fe);if(He){if(He.threads){let pt=He.threads[Y];if(pt)He=pt;else{He.threads[Y]={...Ne};continue}}He.count||(He.count=1);let Er=He.count;for(let pt in Ne){let gr=Ne[pt];typeof gr=="number"&&(He[pt]=(He[pt]*Er+gr*le)/(Er+le))}He.count+=le,re>=0&&(He.total+=re,He.ratio=He.total/He.count)}else He={period:t,...te},delete He.distribution,c.set(Fe,He),He.byThread&&(He.threads=[],He.threads[Y]={...Ne},u.push(He));if(se){se=se.map(pt=>typeof pt=="number"?{value:pt,count:1}:pt);let Er=l.get(Fe);Er?Er.push(...se):l.set(Fe,se)}}await vH()}for(let R of u){let{path:I,method:P,type:Y,metric:te,count:x,total:$,distribution:j,threads:V,...le}=R;V=V.filter(re=>re);for(let re in le){if(typeof R[re]!="number")continue;let se=0;for(let Ee of V){let Ne=Ee[re];typeof Ne=="number"&&(se+=Ne)}R[re]=se}R.count=V.length,delete R.threads,delete R.byThread}for(let[R,I]of l){let P=c.get(R);I.sort((pt,gr)=>pt.value>gr.value?1:-1);let Y=P.count-1,te=[],x=0,$=0,j;for(let pt of LH){let gr=Y*pt;for(;x<gr;)j=I[$++],x+=j.count,$===1&&x--;let wr=I[$>1?$-2:0];j||(j=I[0]),te.push(j.value-(j.value-wr.value)*(x-gr)/j.count)}let[V,le,re,se,Ee,Ne,Fe,He,Er]=te;Object.assign(P,{p1:V,p10:le,p25:re,median:se,p75:Ee,p90:Ne,p95:Fe,p99:He,p999:Er})}let f;for(let[,R]of c)R.time=d,Yu(n,R),f=!0;let m=Date.now(),{idle:h,active:p}=performance.eventLoopUtilization();if(f||p*10>h){let R={metric:Lo.MAIN_THREAD_UTILIZATION,idle:h-gH,active:p-SH,taskQueueLatency:await s,time:m,...process.memoryUsage()};Yu(n,R)}gH=h,SH=p;let E=process.resourceUsage();E.time=m,E.userCPUTime=E.userCPUTime/1e3,E.systemCPUTime=E.systemCPUTime/1e3,Vr.trace?.(`process.resourceUsage: ${JSON.stringify(E)}`);let g=MH(Eg,E);Vr.trace?.(`diffed resourceUsage: ${JSON.stringify(g)}`),g.time=m,g.period=Eg.time?m-Eg.time:t,g.cpuUtilization=DH(g,g.period);let y={metric:Lo.RESOURCE_USAGE,...g};Yu(n,y),Eg=E;let T=it();_H(n,T),_H(n,{system:T.system}),EH(n,T),EH(n,{system:T.system})}async function TH(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function eN(){return RH||(RH=et({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function UH(){return yH||(yH=et({table:"hdb_analytics",database:"system",audit:!0,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function use(){xH=!0;let e=(0,th.get)(U.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await ase(OH,e),await TH(eN(),cse),await TH(UH(),lse)},Math.min(e/2,2147483647)).unref()}function BH(e,t){let r=e.report;r.threadId=t?.threadId||pl.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(AH+=n.mean*n.count);r.totalBytesProcessed=AH,t&&(r.metrics.push({metric:Lo.UTILIZATION,...t.performance.eventLoopUtilization(bH.get(t))}),bH.set(t,t.performance.eventLoopUtilization())),r.id=(0,XI.getNextMonotonicTime)(),eN().primaryStore.put(r.id,r),xH||use(),dse&&(FH=mse(r))}async function mse(e){if(await FH,!va){let r=(0,eh.dirname)((0,Tg.getLogFilePath)());try{va=await(0,JI.open)((0,eh.join)(r,"analytics.log"),"r+")}catch{va=await(0,JI.open)((0,eh.join)(r,"analytics.log"),"w+")}}let t=(await va.stat()).size;if(t>fse){let r=Buffer.alloc(t);await va.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await va.write(r,{position:0}),await va.truncate(r.length),t=r.length}await va.write(JSON.stringify(e)+`
|
|
14
14
|
`,t)}var pl,IH,Tg,eh,JI,XI,th,NH,Vr,Sg,wH,gg,OH,CH,PH,LH,gH,SH,Eg,vH,cse,lse,RH,yH,xH,AH,bH,dse,FH,va,fse,ki=fe(()=>{pl=require("worker_threads"),IH=w(st());Le();Tg=w(z()),eh=require("path"),JI=require("fs/promises"),XI=w(An()),th=w(ce());k();Pr();NH=w(require("node:fs"));jI();QI();Vr=(0,Tg.forComponent)("analytics").conditional;(0,th.initSync)();Sg=new Map,wH=(0,th.get)(U.ANALYTICS_AGGREGATEPERIOD)>-1;o(rse,"setAnalyticsEnabled");o(nse,"recordExistingAction");o(sse,"recordNewAction");o(gt,"recordAction");ve.recordAnalytics=gt;o(Kr,"recordActionBinary");gg=0,OH=1e3,CH="analytics-report",PH=[];o(rh,"addAnalyticsListener");LH=[.01,.1,.25,.5,.75,.9,.95,.99,.999,1];o(ise,"sendAnalytics");o(ZI,"recordHostname");o(Yu,"storeMetric");o(DH,"calculateCPUUtilization");o(MH,"diffResourceUsage");o(ose,"storeTableSizeMetrics");o(_H,"storeDBSizeMetrics");o(EH,"storeVolumeMetrics");o(ase,"aggregation");gH=0,SH=0,Eg={userCPUTime:0,systemCPUTime:0},vH=o(()=>new Promise(setImmediate),"rest");o(TH,"cleanup");cse=36e5,lse=31536e6;o(eN,"getRawAnalyticsTable");o(UH,"getAnalyticsTable");(0,IH.setChildListenerByType)(CH,BH);o(use,"startScheduledTasks");AH=0,bH=new Map,dse=!1;o(BH,"recordAnalytics");fse=1e6;o(mse,"logAnalytics")});function nh(e,t,r,n){if(e.append)e.append(t,r,n);else if(e.set){let s=e.get(t);if(s)if(n)r=(typeof s=="string"?s:s.join(", "))+", "+r;else if(typeof s=="string")r=[s,r];else{s.push(r);return}return e.set(t,r)}else e[t]=(e[t]?e[t]+", ":"")+r}function HH(e,t){(typeof e.set!="function"||typeof e.has!="function")&&(e=new ws(e));for(let[r,n]of t)e.has(r)?r.toLowerCase()==="set-cookie"&&e.append?.(r,n,!0):e.set(r,n);return e}var ws,sh=fe(()=>{ws=class extends Map{static{o(this,"Headers")}constructor(t){if(t)if(t[Symbol.iterator])super(t);else{super();for(let r in t)this.set(r,t[r])}else super()}set(t,r){return typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r),super.set(t.toLowerCase(),[t,r])}get(t){return typeof t!="string"&&(t=""+t),super.get(t.toLowerCase())?.[1]}has(t){return typeof t!="string"&&(t=""+t),super.has(t.toLowerCase())}setIfNone(t,r){typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r);let n=t.toLowerCase();if(!super.has(n))return super.set(n,[t,r])}append(t,r,n){typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r);let s=t.toLowerCase(),i=super.get(s);if(i){let a=i[1];if(n)r=(typeof a=="string"?a:a.join(", "))+", "+r;else if(typeof a=="string")r=[a,r];else{a.push(r);return}}return super.set(s,[t,r])}[Symbol.iterator](){return super.values()[Symbol.iterator]()}};o(nh,"appendHeader");o(HH,"mergeHeaders")});var QH={};Ce(QH,{EVICTED:()=>ba,INVALIDATED:()=>wn,coerceType:()=>Ag,makeTable:()=>Ig,setServerUtilities:()=>nN});function Ig(e){let{primaryKey:t,indices:r,tableId:n,tableName:s,primaryStore:i,databasePath:a,databaseName:c,auditStore:l,schemaDefined:u,dbisDB:d,sealed:f,splitSegments:m,replicate:h}=e,{expirationMS:p,evictionMS:E,audit:g,trackDeletes:y}=e;E??=0;let{attributes:T}=e;T||(T=[]);let R=HA(i,n,l),I,P,Y={},te=Promise.resolve(),x,$,j;for(let q of T)(q.assignCreatedTime||q.name==="__createdtime__")&&(x=q),(q.assignUpdatedTime||q.name==="__updatedtime__")&&($=q),q.expiresAt&&(j=q),q.isPrimaryKey&&(Y=q);let V,le=[],re=[],se=1,Ee=2,Ne={},Fe={},He=864e5,Er=0,pt,gr,wr,au=!1,cu,Ft,wf,Of=El.get(U.REPLICATION_DATABASES);if(Array.isArray(Of)){for(let q of Of)if(q.name===c&&q.replicateTo>=0){wf=q.replicateTo;break}}let E_=i.getRange({start:!1,end:!1}).constructor,yy=10,g_=6;g&&wc(),cm(i.env.path,q=>{if(P)return fa(q)});class lu extends il{static{o(this,"Updatable")}getUpdatedTime(){return ya.get(this.getRecord())?.version}getExpiresAt(){return ya.get(this.getRecord())?.expiresAt}addTo(_,S){if(typeof S=="number"||typeof S=="bigint")this.set(_,new km(S));else throw new Error("Can not add or subtract a non-numeric value")}subtractFrom(_,S){return this.addTo(_,-S)}}class Me extends Dr{#e;#t;#r;#n;#s;#i;static name=s;static primaryStore=i;static auditStore=l;static primaryKey=t;static tableName=s;static tableId=n;static indices=r;static audit=g;static databasePath=a;static databaseName=c;static attributes=T;static replicate=h;static sealed=f;static splitSegments=m??!0;static createdTimeProperty=x;static updatedTimeProperty=$;static propertyResolvers;static userResolvers={};static sources=[];static getResidencyById;static get expirationMS(){return p}static dbisDB=d;static schemaDefined=u;static sourcedFrom(_,S){if(S&&(this.sourceOptions=S,(S.expiration||S.eviction||S.scanInterval)&&this.setTTLExpiration(S)),S?.intermediateSource)_.intermediateSource=!0,this.sources.unshift(_);else{if(this.sources.some(O=>!O.intermediateSource)){if(this.sources.some(O=>O.name===_.name))return;throw new Error("Can not have multiple canonical (non-intermediate) sources")}this.sources.push(_)}P=P||_.get&&(!_.get.reliesOnPrototype||_.prototype.get),I=I||_.load;let A=o(O=>{let D=this.sources;if(D=D.filter(F=>F.intermediateSource&&F[O]&&(!F[O].reliesOnPrototype||F.prototype[O])),D.length>0)if(D.length===1){let F=D[0];return(L,H,W)=>{if(L?.source!==F)return F[O](H,W,L)}}else return(F,L,H)=>{let W=[];for(let ee of D){if(F?.source===ee)break;W.push(ee[O](L,H,F))}return Promise.all(W)}},"getApplyToIntermediateSource"),N=this.sources[this.sources.length-1];N.intermediateSource&&(N={});let b=o(O=>{if(N[O]&&(!N[O].reliesOnPrototype||N.prototype[O]))return(D,F,L)=>{if(!D?.source)return N[O](F,L,D)}},"getApplyToCanonicalSource");Ne={put:b("put"),patch:b("patch"),delete:b("delete"),publish:b("publish")},Fe={put:A("put"),patch:A("patch"),delete:A("delete"),publish:A("publish"),invalidate:A("invalidate")};let C=N.shouldRevalidateEvents;return(async()=>{let O=!1,D,F=o(async(L,H)=>{let W=L.value,ee=L.table?Ge[c][L.table]:Me;if(c===Uf&&(L.table===du.ROLE_TABLE_NAME||L.table===du.USER_TABLE_NAME)&&(O=!0),L.id===void 0&&(L.id=W[ee.primaryKey],L.id===void 0))throw new Error("Replication message without an id "+JSON.stringify(L));L.source=_;let oe={residencyId:ma(L.residencyList),isNotification:!0,ensureLoaded:!1,nodeId:L.nodeId},B=L.id,ue=await ee.getResource(B,H,oe);switch(L.finished&&await L.finished,L.type){case"put":return C?ue._writeInvalidate(B,W,oe):ue._writeUpdate(B,W,!0,oe);case"patch":return C?ue._writeInvalidate(B,W,oe):ue._writeUpdate(B,W,!1,oe);case"delete":return ue._writeDelete(B,oe);case"publish":case"message":return ue._writePublish(B,W,oe);case"invalidate":return ue._writeInvalidate(B,W,oe);case"relocate":return ue._writeRelocate(B,oe);default:xe.default.error?.("Unknown operation",L.type,L.id)}},"writeUpdate");try{let L=_.subscribe;L&&y==null&&(y=!0);let H={crossThreads:!1,inTransactionUpdates:!0,supportsTransactions:!0,omitCurrent:!0},W=_.subscribeOnThisThread?_.subscribeOnThisThread((0,_l.getWorkerIndex)(),H):(0,_l.getWorkerIndex)()===0,ee=L&&W&&await _.subscribe?.(H);if(ee){let oe;for await(let B of ee)try{if(!(B.type==="transaction"?B.writes[0]:B)){xe.default.error?.("Bad subscription event",B);continue}if(B.source=_,B.type==="end_txn"){if(oe?.resolve(),B.localTime&&D!==B.localTime){if(B.remoteNodeIds?.length>0){let ge=[Symbol.for("seq"),B.remoteNodeIds[0]],X=d.get(ge),de=X?.nodes;de||(de=[]);for(let he of B.remoteNodeIds.slice(1)){let Ae=de.find(Oe=>Oe.id===he);de=de.filter(Oe=>Oe.id!==he||Oe===Ae),Ae||(Ae={id:he,seqId:0},de.push(Ae)),Ae.seqId=Math.max(X?.seqId??1,B.localTime),he===oe?.nodeId&&(Ae.lastTxnTime=B.timestamp)}let ne=Math.max(X?.seqId??1,B.localTime);xe.default.trace?.("Received txn",c,new Date(ne),new Date(B.localTime),B.remoteNodeIds),d.put(ge,{seqId:ne,nodes:de})}D=B.localTime}B.onCommit&&oe?.committed.then(B.onCommit);continue}if(oe)if(B.beginTxn)oe.resolve();else{oe.write_promises.push(F(B,oe));continue}!B.timestamp&&B.version&&(B.timestamp=B.version);let ae=vt(B,()=>{if(B.type==="transaction"){let ge=[];for(let X of B.writes)try{ge.push(F(X,B))}catch(de){throw de.message+=" writing "+JSON.stringify(X)+" of event "+JSON.stringify(B),de}return Promise.all(ge)}else if(B.type==="define_schema"){let ge=this.attributes.slice(0),X=!1;for(let de of B.attributes)ge.find(ne=>ne.name===de.name)||(ge.push(de),X=!0);X&&(et({table:s,database:c,attributes:ge,origin:"cluster"}),oh.signalSchemaChange(new ah.SchemaEventMsg(process.pid,G.CREATE_TABLE,c,s)))}else return B.beginTxn?(oe=B,oe.write_promises=[F(B,B)],new Promise(ge=>{oe.resolve=()=>ge(Promise.all(oe.write_promises))})):F(B,B)});oe&&(oe.committed=ae),O&&ae&&!ae?.waitingForUserChange&&(ae.then(()=>oh.signalUserChange(new ah.UserEventMsg(process.pid))),ae.waitingForUserChange=!0),B.onCommit&&(ae?ae.then(B.onCommit):B.onCommit())}catch(ue){xe.default.error?.("error in subscription handler",ue)}}}catch(L){xe.default.error?.(L)}})(),this}static get isCaching(){return P}static get shouldRevalidateEvents(){return this.prototype.get!==Me.prototype.get}static getResource(_,S,A){let N=super.getResource(_,S,A);if(_!=null&&this.loadAsInstance!==!1){Or(_);try{if(N.getRecord?.())return N;if(typeof _=="object"&&_&&!Array.isArray(_))throw new Error(`Invalid id ${JSON.stringify(_)}`);let b=!A?.async||i.cache?.get?.(_),C=Cr(S),O=C.getReadTxn();if(O?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");return Rc(_,S,{transaction:O,ensureLoaded:A?.ensureLoaded},b,D=>{if(D?Me._updateResource(N,D):N.#e=null,S.onlyIfCached){if(!N.doesExist())throw new lt.ServerError("Entry is not cached",504)}else if(A?.ensureLoaded){let F=Ac(_,D,S,N);if(F)return C?.disregardReadTxn(),N.#i=!0,S.loadedFromSource=!0,oi(F,L=>(Me._updateResource(N,L),N))}return N})}catch(b){throw b.message.includes("Unable to serialize object")&&(b.message+=": "+JSON.stringify(_)),b}}return N}static _updateResource(_,S){_.#n=S,_.#e=S?.value??null,_.#r=S?.version}ensureLoaded(){let _=Ac(this.getId(),this.#n,this.getContext());if(_)return this.#i=!0,this.getContext().loadedFromSource=!0,oi(_,S=>{this.#n=S,this.#e=S.value,this.#r=S.version})}static getNewId(){let _=Y?.type;if(_==="String"||_==="ID")return super.getNewId();if(!Ft){let b=i.getEntry(Symbol.for("id_allocation")),C=b?.value,O;if(C&&C.nodeName===server.hostname&&(!bse(i)||C.pid===process.pid)){let D=C.start,F=C.end;O=D;for(let L of i.getKeys({start:F,end:D,limit:1,reverse:!0}))O=L}else C=N(b?.version??null),O=C.start;Ft=new BigInt64Array([BigInt(O)+1n]),Ft=new BigInt64Array(i.getUserSharedBuffer("id",Ft.buffer)),Ft.maxSafeId=C.end}let S=Number(Atomics.add(Ft,0,1n)),A=_==="Int"?512:1048576;if(S+A>=Ft.maxSafeId){let b=o(C=>{Ft.maxSafeId=S+(_==="Int"?1023:4194303);let O=(_==="Int"?Math.pow(2,31):Math.pow(2,49))-1,D=C?void 0:i.useReadTransaction(),F=Number(Ft[0]);for(let W of i.getKeys({start:F+1,end:O,limit:1,transaction:D}))O=W;D?.done();let{value:L,version:H}=i.getEntry(Symbol.for("id_allocation"));if(Ft.maxSafeId<O){if(L.end>Ft.maxSafeId-100)return;xe.default.info?.("New id allocation",S,Ft.maxSafeId,H),i.put(Symbol.for("id_allocation"),{start:L.start,end:Ft.maxSafeId,nodeName:server.hostname,pid:process.pid},Date.now(),H)}else{xe.default.warn?.(`Id conflict detected, starting new id allocation range, attempting to allocate to ${Ft.maxSafeId}, but id of ${O} detected`);let W=N(H);W.alreadyUpdated||Atomics.store(Ft,0,BigInt(W.start+1)),Ft.maxSafeId=W.end}},"updateEnd");S+A===Ft.maxSafeId?setImmediate(b):S+100>=Ft.maxSafeId&&(xe.default.warn?.(`Synchronous id allocation required on table ${s}${_=="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`),i.transactionSync(()=>b(!0)))}return S;function N(b){let C=(_==="Int"?Math.pow(2,31):Math.pow(2,49))-1,O=C/4,D,F,L=!1,H,W;do{H=Math.floor(Math.random()*C),W={start:H,end:H+(_==="Int"?1024:4194304),nodeName:server.hostname,pid:process.pid},D=0;for(let ee of i.getKeys({start:H,limit:1,reverse:!0}))D=ee;F=C;for(let ee of i.getKeys({start:H+1,end:C,limit:1}))F=ee;O*=.875,O<1e3&&!L&&(L=!0,xe.default.error?.(`Id allocation in table ${s} is very dense, limited safe range of numbers to allocate ids in${_==="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`,H,D,F,O))}while(!(O<F-H&&(O<H-D||D===0)));return i.transactionSync(()=>{let ee=i.getEntry(Symbol.for("id_allocation"));return(ee?.version??null)==b?(xe.default.info?.("Allocated new id range",W),i.put(Symbol.for("id_allocation"),W,Date.now()),W):(xe.default.debug?.("Looks like ids were already allocated"),{alreadyUpdated:!0,...ee.value})})}}static setTTLExpiration(_){if(typeof _=="number")p=_*1e3,E||(E=0);else if(_&&typeof _=="object")p=_.expiration*1e3,E=(_.eviction||0)*1e3,He=_.scanInterval*1e3;else throw new Error("Invalid expiration value type");if(p<0)throw new Error("Expiration can not be negative");He=He||(p+E)/4,fa()}static getResidencyRecord(_){return d.get([Symbol.for("residency_by_id"),_])}static setResidency(_){Me.getResidency=_&&((S,A)=>{try{return _(S,A)}catch(N){throw N.message+=` in residency function for table ${s}`,N}})}static setResidencyById(_){Me.getResidencyById=_&&(S=>{try{return _(S)}catch(A){throw A.message+=` in residency function for table ${s}`,A}})}static getResidency(_,S){if(Me.getResidencyById)return Me.getResidencyById(_[t]);let A=wf;if(S.replicateTo!=null){if(Array.isArray(S.replicateTo))return S.replicateTo.includes(server.hostname)?S.replicateTo:[server.hostname,...S.replicateTo];S.replicateTo>=0&&(A=S.replicateTo)}if(A>=0&&server.nodes){let N=[server.hostname];if(S.previousResidency)N.push(...S.previousResidency.slice(0,A));else{let b=server.nodes.map(D=>D.name),C=Math.floor(b.length*Math.random());N.push(...b.slice(C,C+A));let O=C+A-b.length;O>0&&N.push(...b.slice(0,O))}return N}}static enableAuditing(_=!0){g=_,_&&wc(),Me.audit=_}static coerceId(_){return _===""?null:Ag(_,Y)}static async dropTable(){delete Ge[c][s];for(let _ of i.getRange({versions:!0,snapshot:!1,lazy:!0}))_.metadataFlags&Nn&&_.value&&Ta(_.value);if(c===a){for(let _ of T)d.remove(Me.tableName+"/"+_.name),r[_.name]?.drop();d.remove(Me.tableName+"/"),i.drop(),await d.committed}else console.log("legacy dropTable"),await i.close(),rN.default.unlinkSync(i.env.path);oh.signalSchemaChange(new ah.SchemaEventMsg(process.pid,G.DROP_TABLE,c,s))}get(_){let S=this.constructor;if(typeof _=="string"&&S.loadAsInstance!==!1)return this.getProperty(_);if(Pf(_))return this.search(_);if(_&&_.id===void 0&&!_.toString()){let A={records:"./",name:s,database:c,auditSize:l?.getStats().entryCount,attributes:T,recordCount:void 0,estimatedRecordRange:void 0};return this.getContext()?.includeExpensiveRecordCountEstimates?Me.getRecordCount().then(N=>(A.recordCount=N.recordCount,A.estimatedRecordRange=N.estimatedRange,A)):A}if(_!==void 0&&S.loadAsInstance===!1){let A=this.getContext(),N=Cr(A),b=N.getReadTxn();if(b?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");let C=Sr(_);Or(C);let O=!0;return _.checkPermission&&(O=this.allowRead(A.user,_)),oi(O,D=>{if(!D)throw new lt.AccessViolation(A.user);let F=!0;return Rc(C,A,{transaction:b,ensureLoaded:F},!1,L=>{if(A.onlyIfCached){if(!L?.value)throw new lt.ServerError("Entry is not cached",504)}else if(F){let H=Ac(C,L,A);if(H)return N?.disregardReadTxn(),A.loadedFromSource=!0,H.then(W=>W?.value)}return L?.value})})}if(_?.property)return this.getProperty(_.property);if(this.doesExist()||_?.ensureLoaded===!1||this.getContext()?.returnNonexistent)return this}allowRead(_,S){let A=yc(_,S);if(A?.read){if(A.isSuperUser)return!0;let N=A.attribute_permissions,b=S?.select;if(N?.length>0||au&&b){if(S||(S={}),b){let C=N?.length>0&&tN(N,"read");S.select=b.map(O=>{let D=O.name||O;if(!C||C[D]){let F=wr[D]?.definition?.tableClass;if(F){if(O.name||(O={name:O}),!O.checkPermission&&S.checkPermission&&(O.checkPermission=S.checkPermission),!F.prototype.allowRead.call(null,_,O))return!1;if(!O.select)return O.name}return O}}).filter(Boolean)}else S.select=N.filter(C=>C.read&&!wr[C.attribute_name]).map(C=>C.attribute_name);return S}else return!0}}allowUpdate(_,S,A){let N=yc(_,A);if(N?.update){let b=N.attribute_permissions;if(b?.length>0){let C=tN(b,"update");for(let O in S)if(!C[O])return!1;for(let O of b){let D=O.attribute_name;!O.update&&!(D in S)&&(S[D]=this.getProperty(D))}}return Nc(this.getContext())}}allowCreate(_,S,A){if(this.isCollection){let N=yc(_,A);if(N?.insert){let b=N.attribute_permissions;if(b?.length>0){let C=tN(b,"insert");for(let O in S)if(!C[O])return!1;return Nc(this.getContext())}else return Nc(this.getContext())}}else return this.allowUpdate(_,{})}allowDelete(_,S){return yc(_,S)?.delete&&Nc(this.getContext())}update(_,S){let A,N=typeof S=="boolean"||S===void 0&&(_==null||typeof _=="object"&&!(_ instanceof URLSearchParams)),b=!1;N?(b=S,S=_,A=this.getId()):A=Sr(_);let C=this.getContext();if(!Cr(C))throw new Error("Can not update a table resource outside of a transaction");if(S===!1)return this;if(typeof S=="object"&&S)if(b)Object.isFrozen(S)&&(S={...S}),this.#e={},this.#t=S;else if(N){let D=this.#t;D&&(S=Object.assign(D,S)),this.#t=S}else{let D=!0;if(_==null)throw new TypeError("Can not put a record without a target");return _.checkPermission&&(D=this.allowUpdate(C.user,S,_)),oi(D,F=>{if(!F)throw new lt.AccessViolation(C.user);return oi(i.get(Sr(_)),L=>{let H=new lu(L);return H._setChanges(S),this._writeUpdate(A,H.getChanges(),!1),H})})}return this._writeUpdate(A,this.#t,b),this}addTo(_,S){if(typeof S=="number"||typeof S=="bigint")this.#s===GH?this.set(_,(+this.getProperty(_)||0)+S):(this.#s||this.update(),this.set(_,new km(S)));else throw new Error("Can not add a non-numeric value")}subtractFrom(_,S){if(typeof S=="number")return this.addTo(_,-S);throw new Error("Can not subtract a non-numeric value")}getMetadata(){return this.#n}getRecord(){return this.#e}getChanges(){return this.#t}_setChanges(_){this.#t=_}setRecord(_){this.#e=_}invalidate(_){let S=!0,A=this.getContext();return _?.checkPermission&&(S=this.allowDelete(A.user,_,A)),oi(S,N=>{if(!N)throw new lt.AccessViolation(A.user);this._writeInvalidate(_?Sr(_):this.getId())})}_writeInvalidate(_,S,A){let N=this.getContext();Or(_),Cr(this.getContext()).addWrite({key:_,store:i,invalidated:!0,entry:this.#n,before:Ne.invalidate?.bind(this,N,_),beforeIntermediate:Fe.invalidate?.bind(this,N,_),commit:o((C,O)=>{if(!(Ic(C,O,A?.nodeId)<=0)){S??=null;for(let D in r)S||(S={}),S[D]===void 0&&(S[D]=this.getProperty(D));xe.default.trace?.(`Invalidating entry in ${s} id: ${_}, timestamp: ${new Date(C).toISOString()}`),R(_,S,O,C,wn,g,{user:N?.user,residencyId:A?.residencyId,nodeId:A?.nodeId},"invalidate")}},"commit")})}_writeRelocate(_,S){let A=this.getContext();Or(_),Cr(this.getContext()).addWrite({key:_,store:i,invalidated:!0,entry:this.#n,before:Ne.relocate?.bind(this,A,_),beforeIntermediate:Fe.relocate?.bind(this,A,_),commit:o((b,C)=>{if(Ic(b,C,S?.nodeId)<=0)return;let O=Me.getResidencyRecord(S.residencyId),D=0,F=null,L=C?.value;if(O&&!O.includes(server.hostname)){for(let H in r)F||(F={}),F[H]=L(H);D=wn}else F=L;xe.default.trace?.(`Relocating entry id: ${_}, timestamp: ${new Date(b).toISOString()}`),R(_,F,C,b,D,g,{user:A.user,residencyId:S.residencyId,nodeId:S.nodeId,expiresAt:S.expiresAt},"relocate",!1,null)},"commit")})}static _recordRelocate(_,S){let A={previousResidency:this.getResidencyRecord(_.residencyId),isRelocation:!0},N=Oc(this.getResidency(S.value,A)),b;if(N){if(!N.includes(server.hostname))return!1;b=ma(N)}let O=R(_.key,S.value,_,_.version,0,!0,{residencyId:b,expiresAt:S.expiresAt},"relocate",!1,null);return!0}static evict(_,S,A){let N=this.Source,b;if(!((P||g)&&(!S||(b=i.getEntry(_),!b||!S)||b.version!==A))){if(P){if(i.hasLock(_,b.version))return;let C;for(let O in r)C||(C={}),C[O]=S[O];if(C)return R(_,C,b,A,ba,null,null,null,!0)}if(i.ifVersion(_,A,()=>{co(_,S,null)}),g)return R(_,null,b,A,ba,null,null,null,!0);jc(i,b??i.getEntry(_),A)}}lock(){throw new Error("Not yet implemented")}static operation(_,S){return _.table||=s,_.schema||=c,jH.operation(_,S)}put(_,S){if(S===void 0||S instanceof URLSearchParams)this.update(_,!0);else{let A=!0;if(_==null)throw new TypeError("Can not put a record without a target");let N=this.getContext();return _.checkPermission&&(A=this.allowUpdate(N.user,S,_)),oi(A,b=>{if(!b)throw new lt.AccessViolation(N.user);if(Array.isArray(S))for(let C of S){let O=C[t];this._writeUpdate(O,C,!0)}else{let C=Sr(_);this._writeUpdate(C,S,!0)}})}}create(_,S){let A=!0,N=this.getContext();if(!S&&!(_ instanceof URLSearchParams)&&(S=_,_=void 0),!S||typeof S!="object"||Array.isArray(S))throw new TypeError("Can not create a record without an object");return _?.checkPermission&&(A=this.allowCreate(N.user,S,_)),oi(A,b=>{if(!b)throw new lt.AccessViolation(N.user);let C=Sr(_)??S[t];if(C===void 0)C=this.constructor.getNewId();else if(i.get(C))throw new lt.ClientError("Record already exists",409);return this._writeUpdate(C,S,!0),S})}patch(_,S){if(S===void 0||S instanceof URLSearchParams)this.update(_,!1);else{let A=this.update(_,S);if(A?.then)return A.then(()=>{})}}_writeUpdate(_,S,A,N){let b=this.getContext(),C=Cr(b);Or(_);let O=this.#n??i.getEntry(_);this.#s=A?GH:Tse;let D={key:_,store:i,entry:O,nodeName:b?.nodeName,validate:o(F=>{S||(S=this.#t),A||S&&jE(this.#t===S?this:S)?b?.source||(C.checkOverloaded(),this.validate(S,!A),$&&(S[$.name]=$.type==="Date"?new Date(F):$.type==="String"?new Date(F).toISOString():F),A&&(t&&S[t]!==_&&(S[t]=_),x&&(O?.value?S[x.name]=O?.value[x.name]:S[x.name]=x.type==="Date"?new Date(F):x.type==="String"?new Date(F).toISOString():F),S=Pa(S))):C.removeWrite(D)},"validate"),before:A?Ne.put?()=>Ne.put(b,_,S):null:Ne.patch?()=>Ne.patch(b,_,S):Ne.put?()=>Ne.put(b,_,Pa(this)):null,beforeIntermediate:A?Fe.put?()=>Fe.put(b,_,S):null:Fe.patch?()=>Fe.patch(b,_,S):Fe.put?()=>Fe.put(b,_,Pa(this)):null,commit:o((F,L,H)=>{if(H){if(b&&L?.version>(b.lastModified||0)&&(b.lastModified=L.version),this.#n=L,L?.value&&L.value.getRecord)throw new Error("Can not assign a record to a record, check for circular references");A||(this.#e=L?.value??null)}this.#t=void 0,this.#r=F;let W=L?.value,ee=S;this.#s=0;let oe=!1,B=Ic(F,L,N?.nodeId),ue;if(B<=0){if(g){let ne=L.localTime,he=L.version;xe.default.trace?.("Applying CRDT update to record with id: ",_,"txn time",new Date(F),"applying later update from:",new Date(he),"local recorded time",new Date(ne));let Ae=[];for(;ne>F||he>=F&&ne>0;){let Oe=l.get(ne);if(!Oe)break;let ze=Ut(Oe);if(he=ze.version,he>=F){if(he===F){if(B=Ic(F,{version:he,localTime:ne},N?.nodeId),B===0)return;if(B>0)continue}if(ze.type==="patch")Ae.push(ze),ue=S;else if(ze.type==="put"||ze.type==="delete")return}ne=ze.previousLocalTime}if(!ne){xe.default.debug?.("No further audit history, must drop update",_,"existing version preserved",L);return}Ae.sort((Oe,ze)=>Oe.version-ze.version);for(let Oe of Ae){let ze=Oe.getValue(i);if(xe.default.debug?.("Rebuilding update with future patch:",new Date(Oe.version),ze,Oe),ee=V_(ee,ze,A),!ee)return}}else{if(A)return;ee=V_(ee,W,A),xe.default.debug?.("Rebuilding update without audit:",ee)}xe.default.trace?.("Rebuilt record to save:",ee," is full update:",A)}let ae;if(A?ae=ee:this.constructor.loadAsInstance===!1?ae=Pa(W,ee):(this.#e=W,ae=Pa(this,ee)),this.#e=ae,ae&&ae.getRecord)throw new Error("Can not assign a record to a record, check for circular references");let ge;if(N?.residencyId!=null)ge=N.residencyId;else{O?.residencyId&&(b.previousResidency=Me.getResidencyRecord(O.residencyId));let ne=Oc(Me.getResidency(ae,b));if(ne&&!ne.includes(server.hostname))if(ue??=ae,oe=!0,Me.getResidencyById)ae=void 0;else{ae=null;for(let he in r)ae||(ae={}),ae[he]=ue[he]}ge=ma(ne)}A||(ue=S);let X=b?.expiresAt??(p?p+Date.now():-1);xe.default.trace?.(`Saving record with id: ${_}, timestamp: ${new Date(F).toISOString()}${X?", expires at: "+new Date(X).toISOString():""}${L?", replaces entry from: "+new Date(L.version).toISOString():", new entry"}`,(()=>{try{return JSON.stringify(ae).slice(0,100)}catch{return""}})()),co(_,W,ae);let de=A?"put":"patch";R(_,ae,L,F,oe?wn:0,g,{omitLocalRecord:oe,user:b?.user,residencyId:ge,expiresAt:X,nodeId:N?.nodeId,originatingOperation:b?.originatingOperation},de,!1,ue),b.expiresAt&&fa()},"commit")};C.addWrite(D)}async delete(_){if(Pf(_)){_.select=["$id"];for await(let S of this.search(_))this._writeDelete(S.$id);return!0}if(_){let S=!0,A=this.getContext();return _.checkPermission&&(S=this.allowDelete(A.user,_,A)),oi(S,N=>{if(!N)throw new lt.AccessViolation(A.user);let b=Sr(_);return this._writeDelete(b),!0})}return this._writeDelete(this.getId()),!!this.#e}_writeDelete(_,S){let A=Cr(this.getContext());Or(_);let N=this.getContext();return A.addWrite({key:_,store:i,entry:this.#n,nodeName:N?.nodeName,before:Ne.delete?.bind(this,N,_),beforeIntermediate:Fe.delete?.bind(this,N,_),commit:o((b,C,O)=>{let D=C?.value;O&&(N&&C?.version>(N.lastModified||0)&&(N.lastModified=C.version),Me._updateResource(this,C)),!(Ic(b,C,S?.nodeId)<=0)&&(co(this.getId(),D),xe.default.trace?.(`Deleting record with id: ${_}, txn timestamp: ${new Date(b).toISOString()}`),g||y?(R(_,null,C,b,0,g,{user:N?.user,nodeId:S?.nodeId},"delete"),g||fa()):jc(i,C))},"commit")}),!0}search(_){let S=this.getContext(),A=Cr(S);if(!_)throw new Error("No query provided");if(_.parseError)throw _.parseError;if(_.checkPermission&&!this.allowRead(S.user,_))throw new lt.AccessViolation(S.user);let N=_.conditions;N?N.length===void 0&&(N=N[Symbol.iterator]?Array.from(N):[N]):N=Array.isArray(_)?_:_[Symbol.iterator]?Array.from(_):[];let b=_.id??this.getId();b&&(N=[{attribute:null,comparator:Array.isArray(b)?"prefix":"starts_with",value:b}].concat(N));let C,O={};function D(ne,he){let Ae;switch(he){case"and":case void 0:if(ne.length<1)throw new Error('An "and" operator requires at least one condition');Ae=!0;break;case"or":if(ne.length<2)throw new Error('An "or" operator requires at least two conditions');break;default:throw new Error("Invalid operator "+he)}for(let Oe of ne){if(Oe.conditions){Oe.conditions=D(Oe.conditions,Oe.operator);continue}let ze=Oe[0]??Oe.attribute,kr=ze==null?Y:Pi(T,ze);if(kr)(kr.type||GA[Oe.comparator])&&(Oe[1]===void 0?Oe.value=L(Oe.value,kr):Oe[1]=L(Oe[1],kr));else if(ze!=null)throw(0,lt.handleHDBError)(new Error,`${ze} is not a defined attribute`,404);if(Oe.chainedConditions)if(Oe.chainedConditions.length===1&&(!Oe.operator||Oe.operator=="and")){let ye=Oe.chainedConditions[0],We,Xe;if(ye.comparator==="gt"||ye.comparator==="greater_than"||ye.comparator==="ge"||ye.comparator==="greater_than_equal"?(We=Oe,Xe=ye):(We=ye,Xe=Oe),We.comparator!=="lt"&&We.comparator!=="less_than"&&We.comparator!=="le"&&We.comparator!=="less_than_equal")throw new Error("Invalid chained condition, only less than and greater than conditions can be chained together");let jt=Xe.comparator==="ge"||Xe.comparator==="greater_than_equal",Dt=We.comparator==="le"||We.comparator==="less_than_equal";Oe.comparator=(jt?"ge":"gt")+(Dt?"le":"lt"),Oe.value=[Xe.value,We.value]}else throw new Error("Multiple chained conditions are not currently supported")}return ne}o(D,"prepareConditions");function F(ne,he){if(_.enforceExecutionOrder)return ne;for(let Ae of ne)Ae.conditions&&(Ae.conditions=F(Ae.conditions,Ae.operator));return ne.length>1&&he!=="or"?hse(ne,yE(Me)):ne}o(F,"orderConditions");function L(ne,he){return Array.isArray(ne)?ne.map(Ae=>Ag(Ae,he)):Ag(ne,he)}o(L,"coerceTypedValues");let H=_.operator;(N.length>0||H)&&(N=D(N,H));let W=typeof _.sort=="object"&&_.sort,ee;if(W&&H!=="or"){let ne=W.attribute;if(ne==null)throw new lt.ClientError("Sort requires an attribute");if(C=N.find(he=>wu(he.attribute)===wu(ne)),!C){let he=Pi(T,ne);if(!he)throw(0,lt.handleHDBError)(new Error,`${Array.isArray(ne)?ne.join("."):ne} is not a defined attribute`,404);if(he.indexed)C={...W,comparator:"sort"},N.push(C);else if(N.length===0&&!_.allowFullScan)throw(0,lt.handleHDBError)(new Error,`${Array.isArray(ne)?ne.join("."):ne} is not indexed and not combined with any other conditions`,404)}C&&(C.descending=!!W.descending)}N=F(N,H),W&&(C&&N[0]===C?W.next&&(ee={dbOrderedAttribute:W.attribute,attribute:W.next.attribute,descending:W.next.descending,next:W.next.next}):(C&&N.splice(N.indexOf(C),1),ee=W));let oe=_.select;if(N.length===0&&(N=[{attribute:t,comparator:"greater_than",value:!0}]),_.explain)return{conditions:N,operator:H,postOrdering:ee,selectApplied:!!oe};let B=A.useReadTxn(),ue=qA(N,H,Me,B,_,S,(ne,he)=>Lf(ne,oe,S,B,he),O),ae=_.ensureLoaded!==!1;ee||(ue=de(ue));let ge=Me.transformEntryForSelect(oe,S,B,O,ae,!0),X=Me.transformToOrderedSelect(ue,oe,ee,S,B,ge);function de(ne){return _.offset||_.limit!==void 0?ne.slice(_.offset,_.limit!==void 0?(_.offset||0)+_.limit:void 0):ne}return o(de,"applyOffset"),ee&&(X=de(X)),X.onDone=()=>{X.onDone=null,A.doneReadTxn()},X.selectApplied=!0,X.getColumns=()=>{if(oe){let ne=[];for(let he of oe)he==="*"?ne.push(...T.map(Ae=>Ae.name)):ne.push(he.name||he);return ne}return T.filter(ne=>!ne.computed&&!ne.relationship).map(ne=>ne.name)},X}static transformToOrderedSelect(_,S,A,N,b,C){let O=new E_;if(A){_=Lf(_,S,N,b,null);let D;O.iterate=function(){let L,H=_[Symbol.asyncIterator]?_[Symbol.asyncIterator]():_[Symbol.iterator](),W,ee=A.dbOrderedAttribute,oe,B,ue=!0;function ae(X){let de=X.next&&ae(X.next),ne=X.descending;return N.sort=X,(he,Ae)=>{let Oe=bc(he,X.attribute,N),ze=bc(Ae,X.attribute,N),kr=ne?(0,gl.compareKeys)(ze,Oe):(0,gl.compareKeys)(Oe,ze);return kr===0?de?.(he,Ae)||0:kr}}o(ae,"createComparator");let ge=ae(A);return{async next(){let X;if(L)if(X=L.next(),X.done){if(W)return O.onDone&&O.onDone(),X}else return{value:await C.call(this,X.value)};D=[],oe&&D.push(oe);do if(X=await H.next(),X.done){if(W=!0,D.length)break;return O.onDone&&O.onDone(),X}else{let de=X.value;if(de?.then&&(de=await de),ee){let ne=bc(de,ee,N);if(ue)ue=!1,B=ne;else if(ne!==B){B=ne,oe=de;break}}D.push(de)}while(!0);return A.isGrouped,D.sort(ge),L=D[Symbol.iterator](),X=L.next(),X.done?(O.onDone&&O.onDone(),X):{value:await C.call(this,X.value)}},return(){O.onDone&&O.onDone(),H.return()},throw(){O.onDone&&O.onDone(),H.throw()}}};let F=o(L=>{if(typeof S=="object"&&Array.isArray(L.attribute))for(let H=0;H<S.length;H++){let W=S[H],ee;if(W.name===L.attribute[0]){for(ee=W.sort||(W.sort={});ee.next;)ee=ee.next;ee.attribute=L.attribute.slice(1),ee.descending=L.descending}else W===L.attribute[0]&&(S[H]=ee={name:W,sort:{attribute:L.attribute.slice(1),descending:L.descending}})}L.next&&F(L.next)},"applySortingOnSelect");F(A)}else O.iterate=(_[Symbol.asyncIterator]||_[Symbol.iterator]).bind(_),O=O.map(function(D){try{let F=C.call(this,D);return typeof F?.catch=="function"?F.catch(L=>{throw L.partialObject={[t]:D.key},L}):F}catch(F){throw F.partialObject={[t]:D.key},F}});return O}static transformEntryForSelect(_,S,A,N,b,C){let O;b&&P&&!(typeof _=="string"?[_]:_)?.every(L=>{let H;return typeof L=="object"?H=L.name:H=L,r[H]||H===t})&&(O=!0);let D,F=o(function(L){let H;if(S?.transaction?.stale&&(S.transaction.stale=!1),L!=null){if(H=L.deref?L.deref():L.value,!H&&(L.key===void 0||L.deref)||L.metadataFlags&wn){if(L.metadataFlags&wn&&S.replicateFrom===!1&&C&&L.residencyId)return xa.SKIP;if(L=Rc(L.key??L,S,{transaction:A,lazy:_?.length<4,ensureLoaded:b},this?.isSync,W=>W),L?.then)return L.then(F.bind(this));H=L?.value}if(O&&L?.metadataFlags&(wn|ba)||L?.expiresAt!=null&&L?.expiresAt<Date.now()){if(S.onlyIfCached)return{[t]:L.key,message:"This entry has expired"};let W=Ac(L.key??L,L,S);if(W?.then)return W.then(F)}}if(H==null)return C?xa.SKIP:H;if(_&&!(_[0]==="*"&&_.length===1)){let W,ee=o((B,ue)=>{let ae;typeof B=="object"?ae=B.name:ae=B;let ge=wr?.[ae],X;if(ge){let de=N?.[ae];if(de)if(de.hasMappings){let he=ge.from?H[ge.from]:wu(L.key);X=de.get(he),X||(X=[])}else X=de.fromRecord?.(H);else X=ge(H,S,L,!0);let ne=o(he=>{if(ge.directReturn)return ue(he,ae);if(he&&typeof he=="object"){let Ae=ge.definition?.tableClass||Me;D||(D={});let Oe=D[ae]||(D[ae]=Ae.transformEntryForSelect(ae===B?null:B.select||(Array.isArray(B)?B:null),S,A,de,b));if(Array.isArray(he)){let ze=[],kr=Ae.transformToOrderedSelect(he,B.select,typeof B.sort=="object"&&B.sort,S,A,Oe)[this.isSync?Symbol.iterator:Symbol.asyncIterator](),ye=o(Xe=>{for(;!Xe.done;){if(Xe?.then)return Xe.then(ye);ze.push(Xe.value),Xe=kr.next()}ue(ze,ae)},"nextValue"),We=ye(kr.next());We&&(W||(W=[]),W.push(We));return}else if(he=Oe.call(this,he),he?.then){W||(W=[]),W.push(he.then(ze=>ue(ze,ae)));return}}ue(he,ae)},"handleResolvedValue");X?.then?(W||(W=[]),W.push(X.then(ne))):ne(X);return}else X=H[ae],X&&typeof X=="object"&&ae!==B&&(X=Me.transformEntryForSelect(B.select||B,S,A,null)({value:X}));ue(X,ae)},"selectAttribute"),oe;if(typeof _=="string")ee(_,B=>{oe=B});else if(Array.isArray(_))if(_.asArray)oe=[],_.forEach((B,ue)=>{B==="*"?_[ue]=H:ee(B,ae=>oe[ue]=ae)});else{oe={};let B=_.forceNulls;for(let ue of _)if(ue==="*")for(let ae in H)oe[ae]=H[ae];else ee(ue,(ae,ge)=>{ae===void 0&&B&&(ae=null),oe[ge]=ae})}else throw new lt.ClientError("Invalid select"+_);return W?Promise.all(W).then(()=>oe):oe}return H},"transform");return F}async subscribe(_){if(!l)throw new Error("Can not subscribe to a table without an audit log");g||et({table:s,database:c,schemaDefined:u,attributes:T,audit:!0}),_||(_={});let S=!_.rawEvents,A=[],N=this,b=zA(Me,this.getId()??null,function(O,D,F,L){try{let H=D.getValue?.(i,S),W=D.type;if(!H&&W==="patch"&&S){let oe=i.getEntry(O);oe?.version===D.version?H=oe.value:H=D.getValue?.(i,!0,F),W="put"}let ee={id:O,localTime:F,value:H,version:D.version,type:W,beginTxn:L};A?A.push(ee):this.send(ee)}catch(H){xe.default.error?.(H)}},_.startTime||0,_),C=(async()=>{this.isCollection&&(b.includeDescendants=!0,_.onlyChildren&&(b.onlyChildren=!0)),_.supportsTransactions&&(b.supportsTransactions=!0);let O=this.getId(),D=_.previousCount;D>1e3&&(D=1e3);let F=_.startTime;if(this.isCollection){if(F){if(D)throw new lt.ClientError("startTime and previousCount can not be combined for a table level subscription");for(let{key:L,value:H}of l.getRange({start:F,exclusiveStart:!0,snapshot:!1})){let W=Ut(H);if(W.tableId!==n)continue;let ee=W.recordId;if(O==null||KH(O,ee)){let oe=W.getValue(i,S,L);if(b.send({id:ee,localTime:L,value:oe,version:W.version,type:W.type}),b.queue?.length>$H&&await b.waitForDrain()===!1)return}b.startTime=L}}else if(D){let L=[];for(let{key:H,value:W}of l.getRange({start:"z",end:!1,reverse:!0}))try{let ee=Ut(W);if(ee.tableId!==n)continue;let oe=ee.recordId;if(O==null||KH(O,oe)){let B=ee.getValue(i,S,H);if(L.push({id:oe,localTime:H,value:B,version:ee.version,type:ee.type}),--D<=0)break}}catch(ee){xe.default.error("Error getting history entry",H,ee)}for(let H=L.length;H>0;)b.send(L[--H]);L[0]&&(b.startTime=L[0].localTime)}else if(!_.omitCurrent){for(let{key:L,value:H,version:W,localTime:ee}of i.getRange({start:O??!1,end:O==null?void 0:[O,gl.MAXIMUM_KEY],versions:!0,snapshot:!1}))if(H&&(b.send({id:L,localTime:ee,value:H,version:W,type:"put"}),b.queue?.length>$H&&await b.waitForDrain()===!1))return}}else{D&&!F&&(F=0);let L=this.#n?.localTime;if(L===FA&&(i.cache?.delete(O),this.#n=i.getEntry(O),xe.default.trace?.("re-retrieved record",L,this.#n?.localTime),L=this.#n?.localTime),xe.default.trace?.("Subscription from",F,"from",O,L),F<L){let H=[],W=L;do{let ee=l.get(W);if(ee){_.omitCurrent=!0;let oe=Ut(ee),B=oe.getValue(i,S,W);S&&(oe.type="put"),H.push({id:O,value:B,localTime:W,...oe}),W=oe.previousLocalTime}else break;D&&D--}while(W>F&&D!==0);for(let ee=H.length;ee>0;)b.send(H[--ee]);b.startTime=L}!_.omitCurrent&&this.doesExist()&&b.send({id:O,localTime:L,value:this.#e,version:this.#r,type:"put"})}for(let L of A)b.send(L);A=null})();return _.listener&&b.on("data",_.listener),b}static subscribeOnThisThread(_,S){return _===0||S?.crossThreads===!1}doesExist(){return!!(this.#e||this.#s)}publish(_,S,A){if(S===void 0||S instanceof URLSearchParams)this._writePublish(this.getId(),_,S);else{let N=!0,b=this.getContext();return _.checkPermission&&(N=this.allowCreate(b.user,_,b)),oi(N,C=>{if(!C)throw new lt.AccessViolation(b.user);let O=Sr(_);this._writePublish(O,S,A)})}}_writePublish(_,S,A){let N=Cr(this.getContext());_??=null,_!==null&&Or(_);let b=this.getContext();N.addWrite({key:_,store:i,entry:this.#n,nodeName:b?.nodeName,validate:o(()=>{b?.source||(N.checkOverloaded(),this.validate(S))},"validate"),before:Ne.publish?.bind(this,b,_,S),beforeIntermediate:Fe.publish?.bind(this,b,_,S),commit:o((C,O,D)=>{O===void 0&&y&&!g&&fa(),xe.default.trace?.(`Publishing message to id: ${_}, timestamp: ${new Date(C).toISOString()}`),R(_,O?.value??null,O,O?.version||C,0,!0,{user:b?.user,residencyId:A?.residencyId,expiresAt:b?.expiresAt,nodeId:A?.nodeId},"message",!1,S)},"commit")})}validate(_,S){let A,N=o((b,C,O)=>{if(C.type&&b!=null)if(S&&b.__op__&&(b=b.value),C.properties){typeof b!="object"&&(A||(A=[])).push(`Value ${Os(b)} in property ${O} must be an object${C.type?" ("+C.type+")":""}`);let D=C.properties;for(let F=0,L=D.length;F<L;F++){let H=D[F];if(H.relationship||H.computed){_.hasOwnProperty(H.name)&&(A||(A=[])).push(`Computed property ${O}.${H.name} may not be directly assigned a value`);continue}let W=N(b[H.name],H,O+"."+H.name);W&&(b[H.name]=W)}if(C.sealed&&b!=null&&typeof b=="object")for(let F in b)D.find(L=>L.name===F)||(A||(A=[])).push(`Property ${F} is not allowed within object in property ${O}`)}else switch(C.type){case"Int":(typeof b!="number"||b>>0!==b)&&(A||(A=[])).push(`Value ${Os(b)} in property ${O} must be an integer (from -2147483648 to 2147483647)`);break;case"Long":(typeof b!="number"||!(Math.floor(b)===b&&Math.abs(b)<=9007199254740992))&&(A||(A=[])).push(`Value ${Os(b)} in property ${O} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof b!="number"&&(A||(A=[])).push(`Value ${Os(b)} in property ${O} must be a number`);break;case"ID":typeof b=="string"||b?.length>0&&b.every?.(D=>typeof D=="string")||(A||(A=[])).push(`Value ${Os(b)} in property ${O} must be a string, or an array of strings`);break;case"String":typeof b!="string"&&(A||(A=[])).push(`Value ${Os(b)} in property ${O} must be a string`);break;case"Boolean":typeof b!="boolean"&&(A||(A=[])).push(`Value ${Os(b)} in property ${O} must be a boolean`);break;case"Date":if(!(b instanceof Date)){if(typeof b=="string"||typeof b=="number")return new Date(b);(A||(A=[])).push(`Value ${Os(b)} in property ${O} must be a Date`)}break;case"BigInt":if(typeof b!="bigint"){if(typeof b=="string"||typeof b=="number")return BigInt(b);(A||(A=[])).push(`Value ${Os(b)} in property ${O} must be a bigint`)}break;case"Bytes":if(!(b instanceof Uint8Array)){if(typeof b=="string")return Buffer.from(b);(A||(A=[])).push(`Value ${Os(b)} in property ${O} must be a Buffer or Uint8Array`)}break;case"Blob":if(!(b instanceof Ss)){if(typeof b=="string"&&(b=Buffer.from(b)),b instanceof Buffer)return createBlob(b,{type:"text/plain"});(A||(A=[])).push(`Value ${Os(b)} in property ${O} must be a Blob`)}break;case"array":if(Array.isArray(b)){if(C.elements)for(let D=0,F=b.length;D<F;D++){let L=b[D],H=N(L,C.elements,O+"[*]");H&&(b[D]=H)}}else(A||(A=[])).push(`Value ${Os(b)} in property ${O} must be an Array`);break}C.nullable===!1&&b==null&&(A||(A=[])).push(`Property ${O} is required (and not does not allow null values)`)},"validateValue");for(let b=0,C=T.length;b<C;b++){let O=T[b];if(O.relationship||O.computed){Object.hasOwn(_,O.name)&&(A||(A=[])).push(`Computed property ${O.name} may not be directly assigned a value`);continue}if(!S||O.name in _){let D=N(_[O.name],O,O.name);D!==void 0&&(_[O.name]=D)}}if(f)for(let b in _)T.find(C=>C.name===b)||(A||(A=[])).push(`Property ${b} is not allowed`);if(A)throw new lt.ClientError(A.join(". "))}getUpdatedTime(){return this.#r}wasLoadedFromSource(){return P?!!this.#i:void 0}static async addAttributes(_){let S=T.slice(0);for(let A of _){if(!A.name)throw new lt.ClientError("Attribute name is required");if(A.name.match(/[`/]/))throw new lt.ClientError("Attribute names cannot include backticks or forward slashes");pse(A.name),S.push(A)}return et({table:s,database:c,schemaDefined:u,attributes:S}),Me.indexingOperation}static async removeAttributes(_){let S=T.filter(A=>!_.includes(A.name));return et({table:s,database:c,schemaDefined:u,attributes:S}),Me.indexingOperation}static getSize(){let _=i.getStats();return(_.treeBranchPageCount+_.treeLeafPageCount+_.overflowPages)*_.pageSize}static getAuditSize(){let _=l?.getStats();return _&&(_.treeBranchPageCount+_.treeLeafPageCount+_.overflowPages)*_.pageSize}static getStorageStats(){let _=i.env.path,S=rN.default.statfsSync?.(_)??{};return{available:S.bavail*S.bsize,free:S.bfree*S.bsize,size:S.blocks*S.bsize}}static async getRecordCount(_){let S=i.getStats().entryCount,A=1e3/2,N=performance.now(),b=Math.floor(S/2),C=_?.exactCount,O=0,D=0,F;for(let{value:L}of i.getRange({start:!0,lazy:!0,snapshot:!1}))if(L!=null&&O++,D++,await Ua(),!C&&D<b&&performance.now()-N>A){F=D;break}if(F){let L=O;O=0;for(let{value:X}of i.getRange({start:"\uFFFF",reverse:!0,lazy:!0,limit:F,snapshot:!1}))X!=null&&O++,await Ua();let H=F*2,W=(O+L)/H,ee=Math.pow((O-L+1)/F/2,2)+W*(1-W)/H,oe=Math.max(Math.sqrt(ee)*S,1),B=Math.round(W*S),ue=Math.max(B-1.96*oe,O+L),ae=Math.min(B+1.96*oe,S),ge=Math.pow(10,Math.round(Math.log10(oe)));return ge>B&&(ge=ge/10),O=Math.round(B/ge)*ge,{recordCount:O,estimatedRange:[Math.round(ue),Math.round(ae)]}}return{recordCount:O}}static updatedAttributes(){wr=this.propertyResolvers={$id:o((_,S,A)=>({value:A.key}),"$id"),$updatedtime:o((_,S,A)=>A.version,"$updatedtime"),$updatedTime:o((_,S,A)=>A.version,"$updatedTime"),$expiresAt:o((_,S,A)=>A.expiresAt,"$expiresAt"),$record:o((_,S,A)=>A?{value:_}:_,"$record"),$distance:o((_,S,A)=>A&&(A.distance??S?.vectorDistances?.get(A)),"$distance")};for(let _ of this.attributes){_.isPrimaryKey&&(Y=_),_.resolve=null;let S=_.relationship,A=_.computed;if(S)if(_.indexed&&console.error("A relationship property can not be directly indexed, (but you may want to index the foreign key attribute)"),A&&console.error("A relationship property is already computed and can not be combined with a computed function (the relationship will be given precedence)"),au=!0,S.to)_.elements?.definition?(wr[_.name]=_.resolve=(N,b,C,O)=>{let D=N[S.from?S.from:t],F=_.elements.definition.tableClass;return O?Nu({attribute:S.to,value:D},Cr(b).getReadTxn(),!1,F,!1).map(L=>L&&L.key!==void 0?L:F.primaryStore.getEntry(L,{transaction:Cr(b).getReadTxn()})).asArray:F.search([{attribute:S.to,value:D}],b).asArray},_.set=()=>{},_.resolve.definition=_.elements.definition,_.resolve.to=S.to,S.from&&(_.resolve.from=S.from)):console.error(`The one-to-many/many-to-many relationship property "${_.name}" in table "${s}" must have an array type referencing a table as the elements`);else if(S.from){let N=_.definition||_.elements?.definition;N?(wr[_.name]=_.resolve=(b,C,O,D)=>{let F=b[S.from];if(F!==void 0){if(_.elements){let L,H=F?.map(W=>{let ee=N.tableClass.primaryStore[D?"getEntry":"get"](W,{transaction:Cr(C).getReadTxn()});return ee?.then&&(L=!0),ee});return S.filterMissing?L?Promise.all(H).then(W=>W.filter(YH)):H.filter(YH):L?Promise.all(H):H}return N.tableClass.primaryStore[D?"getEntry":"get"](F,{transaction:Cr(C).getReadTxn()})}},_.set=(b,C)=>{if(Array.isArray(C)){let O=C.map(D=>D.getId?.()||D[N.tableClass.primaryKey]);b[S.from]=O}else{let O=C.getId?.()||C[N.tableClass.primaryKey];b[S.from]=O}},_.resolve.definition=_.definition||_.elements?.definition,_.resolve.from=S.from):console.error(`The relationship property "${_.name}" in table "${s}" must be a type that references a table`)}else console.error(`The relationship directive on "${_.name}" in table "${s}" must use either "from" or "to" arguments`);else if(A)typeof A.from=="function"&&this.setComputedAttribute(_.name,A.from),wr[_.name]=_.resolve=(N,b,C)=>{let O=typeof A.from=="string"?N[A.from]:N,D=this.userResolvers[_.name];if(D)return D(O,b,C);xe.default.warn(`Computed attribute "${_.name}" does not have a function assigned to it. Please use setComputedAttribute('${_.name}', resolver) to assign a resolver function.`),this.userResolvers[_.name]=()=>{}},_.resolve.directReturn=!0;else if(r[_.name]?.customIndex?.propertyResolver){let N=r[_.name].customIndex;wr[_.name]=(b,C,O)=>{let D=b[_.name];return N.propertyResolver(D,C,O)},wr[_.name].directReturn=!0}}Gm(this,this),Gm(lu,this,!0);for(let _ of T){let S=_.name;_.resolve&&Object.defineProperty(i.encoder.structPrototype,S,{get(){return _.resolve(this,Cu.getStore())},set(A){return _.set(this,A)},configurable:!0})}}static setComputedAttribute(_,S){let A=Pi(T,_);if(!A){console.error(`The attribute "${_}" does not exist in the table "${s}"`);return}if(!A.computed){console.error(`The attribute "${_}" is not defined as computed in the table "${s}"`);return}this.userResolvers[_]=S}static async deleteHistory(_=0,S=!1){let A;for(let{key:N,value:b}of l.getRange({start:0,end:_}))await Ua(),Ut(b).tableId===n&&(A=mE(l,N,b));if(S)for(let N of i.getRange({start:0,versions:!0})){let{key:b,value:C,localTime:O}=N;await Ua(),C===null&&O<_&&(A=jc(i,N))}await A}static async*getHistory(_=0,S=1/0){for(let{key:A,value:N}of l.getRange({start:_||1,end:S})){await Ua();let b=Ut(N);b.tableId===n&&(yield{id:b.recordId,localTime:A,version:b.version,type:b.type,value:b.getValue(i,!0,A),user:b.user,operation:b.originatingOperation})}}static async getHistoryOfRecord(_){let S=[];if(_==null)throw new Error("An id is required");let A=i.getEntry(_);if(!A)return S;let N=A.localTime;if(!N)throw new Error("The entry does not have a local audit time");let b=0;do{await Ua();let C=l.get(N);if(C){let O=Ut(C);S.push({id:O.recordId,localTime:N,version:O.version,type:O.type,value:O.getValue(i,!0,N),user:O.user}),N=O.previousLocalTime}else break}while(b<1e3&&N);return S.reverse()}static cleanup(){V?.remove()}}Me.updatedAttributes();let Cf=Me.prototype;return p&&Me.setTTLExpiration(p/1e3),j&&S_(),Me;function co(q,_,S){let A;for(let N in r){let b=r[N],C=b.isIndexing,O=wr[N],D=S&&(O?O(S):S[N]),F=_&&(O?O(_):_[N]);if(D===F&&!C)continue;if(b.customIndex){b.customIndex.index(q,D,F);continue}A=!0;let L=b.indexNulls,H=(0,ih.getIndexedValues)(D,L),W=(0,ih.getIndexedValues)(F,L);if(W?.length>0){let ee=new Set(W);if(H=H?H.filter(oe=>{if(ee.has(oe))ee.delete(oe);else return!0}):[],W=Array.from(ee),(W.length>0||H.length>0)&&kH){let oe=W.concat(H).map(B=>({key:B,value:q}));b.prefetch(oe,VH)}for(let oe=0,B=W.length;oe<B;oe++)b.remove(W[oe],q)}else H?.length>0&&kH&&b.prefetch(H.map(ee=>({key:ee,value:q})),VH);if(H)for(let ee=0,oe=H.length;ee<oe;ee++)b.put(H[ee],q)}return A}o(co,"updateIndices");function Or(q){switch(typeof q){case"number":return!0;case"string":if(q.length<659)return!0;if(q.length>qH)throw new Error("Primary key size is too large: "+q.length);break;case"object":if(q===null)throw new Error("Invalid primary key of null");break;case"bigint":if(q<2n**64n&&q>-(2n**64n))return!0;break;default:throw new Error("Invalid primary key type: "+typeof q)}if((0,gl.writeKey)(q,Rse,0)>qH)throw new Error("Primary key size is too large: "+q.length);return!0}o(Or,"checkValidId");function Sr(q){return typeof q=="object"&&q?q.id:q}o(Sr,"requestTargetToId");function Pf(q){return typeof q=="object"&&q&&q.isCollection}o(Pf,"isSearchTarget");function _s(q){}o(_s,"isRequestTarget");function Rc(q,_,S,A,N){if(Me.getResidencyById&&S.ensureLoaded&&_?.replicateFrom!==!1){let C=Oc(Me.getResidencyById(q));if(C&&!C.includes(server.hostname)&&I)return I({key:q,residency:C}).then(N)}let b=o(()=>{if(_?.transaction?.stale&&(_.transaction.stale=!1),S.transaction?.isDone)return N(null,q);let C=i.getEntry(q,S);return C?.residencyId&&C.metadataFlags&wn&&I&&S.ensureLoaded&&_?.replicateFrom!==!1?I(C).then(O=>N(O,q),O=>(xe.default.error?.("Error loading remote record",q,C,S,O),N(null,q))):(C&&_&&(C?.version>(_.lastModified||0)&&(_.lastModified=C.version),C?.localTime&&!_.lastRefreshed&&(_.lastRefreshed=C.localTime)),N(C,q))},"whenPrefetched");return A?b():se>0?(se--,b()):new Promise((C,O)=>{se===0?(se--,i.prefetch([q],()=>{D(),F()})):(le.push(q),re.push(F),le.length>g_&&(se--,D()));function D(){if(le.length>0){let L=re;i.prefetch(le,()=>{se===-1?D():se++;for(let H of L)H()}),le=[],re=[],Ee>2&&Ee--}else se=Ee,Ee<yy&&Ee++}o(D,"prefetch");function F(){try{C(b())}catch(L){O(L)}}o(F,"load")})}o(Rc,"loadLocalRecord");function yc(q,_){let S=_?.checkPermission;if(typeof S!="object"){if(!q?.role)return;S=q.role.permission}if(S.super_user)return yse;let A=S[c],N,b=A?.tables;if(b)return b[s];if(c==="data"&&(N=S[s])&&!N.tables)return N}o(yc,"getTablePermissions");function Ac(q,_,S,A){if(P){let N=!1;if(S.noCache?N=!0:(_?(!_.value||_.metadataFlags&(wn|ba)||_.expiresAt!=null&&_.expiresAt<Date.now())&&(N=!0):N=!0,Kr(!N,"cache-hit",s)),N){let b=uu(q,_,S).then(C=>(C?.value&&C?.value.getRecord?.()&&xe.default.error?.("Can not assign a record that is already a resource"),S&&(C?.version>(S.lastModified||0)&&(S.lastModified=C.version),S.lastRefreshed=Date.now()),C));if(S?.onlyIfCached||_?.value&&A?.allowStaleWhileRevalidate?.(_,q)){if(b.catch(C=>xe.default.warn?.(C)),S?.onlyIfCached&&!A.doesExist())throw new lt.ServerError("Entry is not cached",504);return}else return b}}else if(_?.value&&_.expiresAt!=null&&_.expiresAt<Date.now())return Me.evict(_.key,_.value,_.version),_.value=null,{then(N){return N(_)}}}o(Ac,"ensureLoadedFromSource");function Cr(q){let _=q?.transaction;if(_){if(!_.lmdbDb)return _.lmdbDb=i,_;do{if(_.lmdbDb?.path===i.path)return _;let S=_.next;if(!S)return _=_.next=new fo,_.lmdbDb=i,_;_=S}while(!0)}else return new q_}o(Cr,"txnForContext");function bc(q,_,S){if(!q)return;let A=(q.deref?q.deref():q.value)??i.getEntry(q.key)?.value;if(typeof _=="object"){let b=wr,C=A;for(let O=0,D=_.length;O<D;O++){let F=_[O],L=b?.[F];C=L&&C?L(C,S,q):C?.[F],q=null,b=L?.definition?.tableClass?.propertyResolvers}return C}let N=wr[_];return N?N(A,S,q):A[_]}o(bc,"getAttributeValue");function Lf(q,_,S,A,N){let b=N?.length,C={transaction:A,lazy:b>0||typeof _=="string"||_?.length<4,alwaysPrefetch:!0},O;function D(F,L){let H=F?.value;if(!H)return xa.SKIP;for(let W=0;W<b;W++)if(!O?.includes(W)&&!N[W](H,F))return xa.SKIP;return L!==void 0&&(F.key=L),F}if(o(D,"processEntry"),b>0||!q.hasEntries){let F=q.map(L=>{if(O=null,typeof L=="object"&&L?.key!==void 0)return b>0?D(L):L;if(L==null)return xa.SKIP;for(let H=0;H<b;H++){let ee=N[H].idFilter;if(ee){if(!ee(L))return xa.SKIP;O||(O=[]),O.push(H)}}return Rc(L,S,C,!1,D)});return Array.isArray(q)&&(F=F.filter(L=>L!==xa.SKIP)),F.hasEntries=!0,F}return q}o(Lf,"transformToEntries");function Ic(q,_,S=server.replication?.getThisNodeId(l)){if(q<=_?.version){if(_?.version===q&&S!==void 0){let A=server.replication?.exportIdMapping(l),N=_.localTime,b=N&&l.get(N);if(b){let C,O,D=Ut(b);for(let F in A)A[F]===S&&(C=F),A[F]===D.nodeId&&(O=F);if(C>O)return 1;if(C===O)return 0}}return-1}return 1}o(Ic,"precedesExistingVersion");async function uu(q,_,S){let A=_?.metadataFlags,N=_?.version,b,C;if(!i.attemptLock(q,N,()=>{clearTimeout(C);let L=i.getEntry(q);!L||!L.value||L.metadataFlags&(wn|ba)?b(uu(q,i.getEntry(q),S)):b(L)}))return new Promise(L=>{b=L,C=setTimeout(()=>{i.unlock(q,N)},Sse)});let O=_?.value,D={requestContext:S,replacingRecord:O,replacingEntry:_,replacingVersion:N,noCacheStore:!1,source:null,resourceCache:S?.resourceCache,transaction:void 0,expiresAt:void 0,lastModified:void 0},F=S?.responseHeaders;return new Promise((L,H)=>{let W;oi(vt(D,async ee=>{let oe=performance.now(),B,ue,ae;try{for(let ne of Me.sources)if(ne.get&&(!ne.get.reliesOnPrototype||ne.prototype.get)){if(ne.available?.(_)===!1)continue;if(D.source=ne,B=await ne.get(q,D),B)break}ae=A&wn;let X=D.lastModified||ae&&N;ue=ae||X>N||!O,X||(X=(0,ih.getNextMonotonicTime)());let de=performance.now()-oe;if(gt(de,"cache-resolution",s,null,"success"),F&&nh(F,"Server-Timing",`cache-resolve;dur=${de.toFixed(2)}`,!0),ee.timestamp=X,p&&D.expiresAt==null&&(D.expiresAt=Date.now()+p),B){if(typeof B!="object")throw new Error("Only objects can be cached and stored in tables");if(B.status>0&&B.headers)if(B.status>=300)if(B.status===304)B=O,X=N;else throw new lt.ServerError(B.body||"Error from source",B.status);else B=B.body;typeof B.toJSON=="function"&&(B=B.toJSON()),t&&B[t]!==q&&(B[t]=q)}W=!0,L({key:q,version:X,value:B})}catch(X){X.message+=` while resolving record ${q} for ${s}`,O&&((X.code==="ECONNRESET"||X.code==="ECONNREFUSED"||X.code==="EAI_AGAIN")&&!S?.mustRevalidate||S?.staleIfError&&(X.statusCode===500||X.statusCode===502||X.statusCode===503||X.statusCode===504))?(L({key:q,version:N,value:O}),xe.default.trace?.(X.message,"(returned stale record)")):H(X);let de=performance.now()-oe;gt(de,"cache-resolution",s,null,"fail"),F&&nh(F,"Server-Timing",`cache-resolve;dur=${de.toFixed(2)}`,!0),D.transaction.abort();return}if(S?.noCacheStore||D.noCacheStore){D.transaction.abort();return}Cr(D).addWrite({key:q,store:i,entry:_,nodeName:"source",commit:o((X,de)=>{if(de?.version!==N)return;let ne=co(q,O,B);if(B){Fe.put?.(D,q,B),de&&(S.previousResidency=Me.getResidencyRecord(de.residencyId));let he,Ae=!1,Oe,ze=Oc(Me.getResidency(B,S));if(ze){if(!ze.includes(server.hostname))if(he=B,Ae=!0,Me.getResidencyById)B=void 0;else{B=null;for(let kr in r)B||(B={}),B[kr]=he[kr]}Oe=ma(ze)}xe.default.trace?.(`Writing resolved record from source with id: ${q}, timestamp: ${new Date(X).toISOString()}`),R(q,B,de,X,Ae?wn:0,g&&(ue||Ae)||null,{user:D?.user,expiresAt:D.expiresAt,residencyId:Oe},"put",!!ae,he)}else de&&(Fe.delete?.(D,q),xe.default.trace?.(`Deleting resolved record from source with id: ${q}, timestamp: ${new Date(X).toISOString()}`),g||y?R(q,null,de,X,0,g&&ue||null,{user:D?.user},"delete",!!ae):jc(i,de,N))},"commit")})}),()=>{i.unlock(q,N)},ee=>{i.unlock(q,N),W&&xe.default.error?.("Error committing cache update",ee)})})}o(uu,"getFromSource");function Nc(q){if(!q||q.user?.role?.permission?.super_user)return!0;if(q.replicateTo)throw new lt.ClientError("Can not specify replication parameters without super user permissions",403);if(q.replicatedConfirmation)throw new lt.ClientError("Can not specify replication confirmation without super user permissions",403);return!0}o(Nc,"checkContextPermissions");function fa(q){let _=!1;if(q&&(q-Er>1&&(_=!0),Er=q),!(He===pt&&!_)&&(pt=He,(0,_l.getWorkerIndex)()===(0,_l.getWorkerCount)()-1))return gr&&clearTimeout(gr),He?new Promise(S=>{let A=new Date;A.setMonth(0),A.setDate(1),A.setHours(0),A.setMinutes(0),A.setSeconds(0);let N=He/(1+Er),b=_?Date.now():Math.ceil((Date.now()-A.getTime())/N)*N+A.getTime(),C=o(O=>{xe.default.trace?.(`Scheduled next cleanup scan at ${new Date(O)}`),gr=setTimeout(()=>te=te.then(async()=>{if(C(Math.max(O+He,Date.now())),i.rootStore.status!=="open"){clearTimeout(gr);return}let D=50,F=new Array(D),L=0,H=Math.pow(Er,8)*(El.get(U.STORAGE_RECLAMATION_EVICTIONFACTOR)??1e5),W=E/Math.pow(Math.max(Er,1),4);xe.default.info?.(`Starting cleanup scan for ${s}, evict threshold ${H}, adjusted eviction ${W}ms`);function ee(oe,B,ue,ae){let ge=oe+W-Date.now();if(ge<0)return!0;if(Er){let X=i.lastSize;return ue&Nn&&gu(ae,de=>{de.size&&(X+=de.size)}),xe.default.trace?.(`shouldEvict adjusted ${ge} ${X}, ${ge*(oe-B)/X} < ${H}`),ge*(oe-B)/X<H}return!1}o(ee,"shouldEvict");try{let oe=0;for(let B of i.getRange({start:!1,snapshot:!1,versions:!0,lazy:!0})){let{key:ue,value:ae,version:ge,expiresAt:X,metadataFlags:de}=B,ne;ae===null&&!g&&ge+gse<Date.now()?ne=jc(i,B,ge):X!=null&&ee(X,ge,de,ae)&&(ne=Me.evict(ue,ae,ge),oe++),ne&&(await F[L],F[L]=ne.catch(he=>{xe.default.error?.("Cleanup error",he)}),++L>=D&&(L=0)),await Ua()}xe.default.info?.(`Finished cleanup scan for ${s}, evicted ${oe} entries`)}catch(oe){xe.default.warn?.(`Error in cleanup scan for ${s}:`,oe)}S(void 0),Er=0}),Math.min(O-Date.now(),2147483647)).unref()},"startNextTimer");C(b)}):void 0}o(fa,"scheduleCleanup");function wc(){V=l?.addDeleteRemovalCallback(n,i,(q,_)=>{i.remove(q,_)})}o(wc,"addDeleteRemoval");function S_(){(0,_l.getWorkerIndex)()===0&&setInterval(async()=>{if(!cu){cu=!0;try{let q=j.name,_=r[q];if(!_)throw new Error(`expiresAt attribute ${j} must be indexed`);for(let S of _.getRange({start:!0,values:!1,end:Date.now(),snapshot:!1})){for(let A of _.getValues(S)){let N=i.getEntry(A);N?.value?N.value[q]<Date.now()&&Me.evict(A,N.value,N.version):i.ifVersion(A,N?.version,()=>_.remove(S,A))}await Ua()}}catch(q){xe.default.error?.("Error in evicting old records",q)}finally{cu=!1}}},Ese).unref()}o(S_,"runRecordExpirationEviction");function Oc(q){if(q!=null){if(Array.isArray(q))return q;if(typeof q=="number"){if(q>=65536)throw new Error(`Shard id ${q} must be below 65536`);let _=server.shards?.get?.(q);if(_)return xe.default.trace?.(`Shard ${q} mapped to ${_.map(S=>S.name).join(", ")}`),_.map(S=>S.name);throw new Error(`Shard ${q} is not defined`)}throw new Error(`Shard or residency list ${q} is not a valid type, must be a shard number or residency list of node hostnames`)}}o(Oc,"residencyFromFunction");function ma(q){if(q){let _=q.join(","),S=d.get([Symbol.for("residency_by_set"),_]);return S||(d.put([Symbol.for("residency_by_set"),_],S=Math.floor(Math.random()*2147418112)+65535),d.put([Symbol.for("residency_by_id"),S],q),S)}}o(ma,"getResidencyId")}function tN(e,t){let r=e.attr_object||(e.attr_object={}),n=r[t];if(n)return n;n=r[t]=Object.create(null);for(let s of e)n[s.attribute_name]=s[t];return n}function VH(){}function nN(e){jH=e}function Ag(e,t){let r=t?.type;if(e===null)return e;if(e===""&&r&&r!=="String"&&r!=="Any")return null;try{switch(r){case"Int":case"Long":if(e[0]==="$")return yg(parseInt(e.slice(1),36));if(e==="null")return null;if(!/^-?[0-9]+$/.test(e)&&!(e instanceof Date))throw new SyntaxError;return yg(+e);case"Float":return e==="null"?null:yg(+e);case"BigInt":return e==="null"?null:BigInt(e);case"Boolean":return e==="true"?!0:e==="false"?!1:e;case"Date":if(isNaN(e)){if(e==="null")return null;Ase.test(e)||(e+="Z");let n=new Date(e);return yg(n.getTime()),n}return new Date(+e);case void 0:case"Any":return(0,bg.autoCast)(e);default:return e}}catch(n){throw n.message=`Invalid value for attribute ${t.name}: "${e}", expecting ${r}`,n.statusCode=400,n}}function yg(e){if(isNaN(e))throw new SyntaxError;return e}function KH(e,t){if(e==null)return!0;if(!Array.isArray(t))return e===t||t.startsWith?.(e);if(Array.isArray(e)){let r=e.length;if(e[r-1]===null&&r--,t.length>=r){for(let n=0;n<r;n++)if(t[n]!==e[n])return!1;return!0}return!1}else if(t[0]===e)return!0}function oi(e,t,r){return e?.then?e.then(t,r):t(e)}function YH(e){return e!=null}function Os(e){try{return JSON.stringify(e)}catch{return e}}function bse(e){let t=process.pid;return e.env.readerList().slice(1).some(r=>+r.match(/\d+/)?.[0]!=t)}var xa,ih,WH,zH,El,lt,oh,ah,xe,gl,_l,bg,rN,hse,pse,_se,jH,Ese,gse,kH,Sse,GH,Tse,wn,ba,Rse,qH,$H,yse,ELe,Ase,Ua,Tm=fe(()=>{k();xa=require("lmdb"),ih=w(An()),WH=w(require("lodash")),zH=w(jf());Ia();Jf();El=w(ce());jA();lt=w(_e()),oh=w(No()),ah=w(ti());Le();bE();xe=w(wi());cI();xc();gl=require("ordered-binary"),_l=w(st());mo();bg=w(ie());Wc();ki();K_();sh();rN=w(require("node:fs"));Ts();lE();({sortBy:hse}=WH.default),{validateAttribute:pse}=zH.default,_se=new Uint8Array(9);_se[8]=192;Ese=6e4,gse=864e5;El.initSync();kH=El.get(U.STORAGE_PREFETCHWRITES),Sse=1e4,GH=1,Tse=2,wn=1,ba=8,Rse=Buffer.allocUnsafeSlow(8192),qH=1978,$H=100,yse={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},ELe=(0,bg.convertToMS)(El.get(U.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;o(Ig,"makeTable");o(tN,"attributesAsObject");o(VH,"noop");o(nN,"setServerUtilities");Ase=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;o(Ag,"coerceType");o(yg,"rejectNaN");o(KH,"isDescendantId");Ua=o(()=>new Promise(setImmediate),"rest");o(oi,"when");o(YH,"exists");o(Os,"stringify");o(bse,"hasOtherProcesses")});function Ng(e,t){if(!Array.isArray(e)||!Array.isArray(t))throw new Error("Euclidean distance comparison requires an array");let r=0,n=Math.max(e.length,t.length);for(let s=0;s<n;s++){let i=e[s]||0,a=t[s]||0,c=i-a;r+=c*c}return r}function wg(e,t){if(!Array.isArray(e)||!Array.isArray(t))throw new Error("Cosine distance comparison requires an array");let r=0,n=0,s=0,i=Math.max(e.length,t.length);for(let a=0;a<i;a++){let c=e[a]||0,l=t[a]||0;r+=c*l,n+=c*c,s+=l*l}return n=Math.sqrt(n),s=Math.sqrt(s),1-r/(n*s||1)}var JH=fe(()=>{o(Ng,"euclideanDistance");o(wg,"cosineDistance")});var XH,ZH,zu,Gi,Wu,Ise,Nse,Og,ek=fe(()=>{JH();XH=require("msgpackr"),ZH=w(wi()),zu=w(_e()),Gi=(0,ZH.loggerWithTag)("HNSW"),Wu=Symbol.for("entryPoint"),Ise=Symbol.for("key"),Nse=10,Og=class{static{o(this,"HierarchicalNavigableSmallWorld")}static useObjectStore=!0;indexStore;M=16;efConstruction=100;efConstructionSearch=50;mL=1/Math.log(this.M);optimizeRouting=.5;nodesVisitedCount=0;idIncrementer;distance;constructor(t,r){this.indexStore=t,t&&(this.indexStore.encoder.useFloat32=XH.FLOAT32_OPTIONS.ALWAYS),this.distance=r?.distance==="euclidean"?Ng:wg,r&&(r.M!==void 0&&(this.M=r.M,this.mL=1/Math.log(this.M)),r.efConstruction!==void 0&&(this.efConstruction=this.efConstructionSearch=r.efConstruction),r.efConstructionSearch!==void 0&&(this.efConstructionSearch=r.efConstructionSearch),r.mL!==void 0&&(this.mL=r.mL),r.optimizeRouting!==void 0&&(this.optimizeRouting=r.optimizeRouting))}index(t,r,n){let s=typeof t=="number"?[Ise,t]:t,i=this.indexStore.get(s);if(!i){if(!r)return;if(!this.idIncrementer){let f=0;for(let m of this.indexStore.getKeys({reverse:!0,limit:1,start:1/0,end:0}))typeof m=="number"&&(f=m);this.idIncrementer=new BigInt64Array([BigInt(f)+1n]),this.idIncrementer=new BigInt64Array(this.indexStore.getUserSharedBuffer("next-id",this.idIncrementer.buffer))}i=Number(Atomics.add(this.idIncrementer,0,1n)),this.indexStore.put(s,i)}let a=new Map,c,l=this.indexStore.get(Wu);if(n?c={...this.indexStore.get(i)}:c={},r){let f=l&&this.indexStore.get(l);if(f===void 0){let E=Math.floor(-Math.log(Math.random())*this.mL),g={vector:r,level:E,primaryKey:t};for(let y=0;y<=E;y++)g[y]=[];if(this.indexStore.put(i,g),typeof i!="number")throw new Error("Invalid nodeId: "+i);Gi.debug?.("setting entry point to",i),this.indexStore.put(Wu,i);return}let m=c.level??Math.min(Math.floor(-Math.log(Math.random())*this.mL),Nse),h=f.level;if(m>=h){if(typeof i!="number")throw new Error("Invalid nodeId: "+i);Gi.debug?.("setting entry point to",i),this.indexStore.put(Wu,i)}for(;h>m;){let E=this.searchLayer(r,l,f,this.efConstruction,h);E.length>0&&(l=E[0].id,f=E[0].node),h--}let p=new Array(m+1);for(let E=0;E<=m;E++)p[E]=[];for(let E=Math.min(m,h);E>=0;E--){let g=this.searchLayer(r,l,f,this.efConstruction,E);g=g.slice(0,this.M<<1),g.length===0&&E===0&&Gi.info?.("should not have zero connections for",l);let y=p[E];for(let T=0;T<g.length;T++){let{id:R,distance:I,node:P}=g[T];if(R===i)continue;let Y=[];if(this.optimizeRouting){let $=!1,j=P[E],V=1+this.optimizeRouting*(1+.5*T/this.M);for(let le=0;le<j.length;le++){let{id:re,distance:se}=j[le],Ee=1+this.optimizeRouting*(1+.5*le/this.M);for(let Ne=0;Ne<y.length;Ne++){let{id:Fe,distance:He}=y[Ne];if(Fe===re){I*V>He+se?$=!0:se*Ee>I+He&&(Y.push({fromId:Fe,toId:R}),Y.push({fromId:R,toId:Fe}));break}}if($)break}if($)continue}else if(T>=(E>0?this.M:this.M<<1))continue;y.push({id:R,distance:I});for(let{fromId:$,toId:j}of Y){let V=d($);V||(V=d($,this.indexStore.get($)));for(let le=0;le<V[E].length;le++)if(V[E][le].id===j){Object.isFrozen(V[E])&&(V[E]=V[E].slice()),V[E].splice(le,1);break}}let te=c[E],x=te?.find(({id:$})=>$===R);if(x){let $=te?.indexOf(x);te.copied||(te=[...te],te.copied=!0,c[E]=te),te.splice($,1)}else this.addConnection(R,d(R,P),i,E,I,d)}}this.indexStore.put(i,{vector:r,level:m,primaryKey:t,...p})}else{if(l===i){let f=c.level??0;for(let m=f;m>=0&&(l=c[m][0]?.id,l===void 0);m--);if(l===void 0){let m=-1;for(let{key:h,value:p}of this.indexStore.getRange({start:0,end:1/0}))if(p.level>m){if(l=h,p.level===f)break;m=p.level}}if(l===void 0)this.indexStore.remove(Wu);else{if(typeof l!="number")throw new Error("Invalid nodeId: "+l);Gi.debug?.("setting entry point to",l),this.indexStore.put(Wu,l)}}this.indexStore.remove(i)}let u=new Map;if(c.level!==void 0)for(let f=0;f<=c.level;f++){let m=c[f];for(let{id:h}of m){let p=d(h,this.indexStore.get(h));for(let E=0;E<=f;E++)p[E]=p[E]?.filter(({id:g})=>g!==i),p[E].length===0&&(Gi.info?.("node was left orphaned, will reindex",h),u.set(p.primaryKey,p.vector))}}function d(f,m){let h=a.get(f);return!h&&m&&(h={...m},a.set(f,h)),h}o(d,"updateNode");for(let[f,m]of a)this.indexStore.put(f,m);for(let[f,m]of u)this.index(f,m,m);this.checkSymmetry(i,this.indexStore.get(i))}getEntryPoint(){let t=this.indexStore.get(Wu);if(t===void 0)return;let r=this.indexStore.get(t);return{id:t,...r}}searchLayer(t,r,n,s,i,a=this.distance){let c=new Set([r]),l=[{id:r,distance:this.distance(t,n.vector),node:n}],u=[...l];for(;l.length>0;){l.sort((h,p)=>h.distance-p.distance);let d=l.shift(),f=u[u.length-1].distance;if(d.distance>f)break;let m=d.node;for(let{id:h}of m[i]||[]){if(c.has(h)||h===void 0)continue;c.add(h);let p=this.indexStore.get(h);if(!p)continue;this.nodesVisitedCount++;let E=a(t,p.vector);if(E<f||u.length<s){let g={id:h,distance:E,node:p};l.push(g),u.push(g)}}u.sort((h,p)=>h.distance-p.distance),u.length>s&&u.splice(s,u.length-s)}return u.visited=c.size,u}search({target:t,value:r,descending:n,distance:s,comparator:i}){let a=0;switch(i){case"lt":case"le":a=r;case"sort":break;default:throw new zu.ClientError(`Can not use "${i}" comparator with HNSW`)}if(n)throw new zu.ClientError("Can not use descending sort order with HNSW");let c;if(s==="cosine")c=wg;else if(s==="euclidean")c=Ng;else{if(s)throw new zu.ClientError("Unknown distance function");c=this.distance}if(!t)throw new zu.ClientError("A target vector must be provided for an HNSW query");if(!Array.isArray(t))throw new zu.ClientError("The target vector must be an array");let l=this.getEntryPoint();if(!l)return[];let u=l.id,d=[];for(let f=l.level;f>=0;f--)if(d=this.searchLayer(t,u,l,this.efConstructionSearch,f,c),d.length>0){let m=d[0];l=m.node,u=m.id}return a&&(d=d.filter(f=>f.distance<a)),d.map(f=>({key:f.node.primaryKey,distance:f.distance}))}checkSymmetry(t,r){if(!r)return;let n=0,s;for(;(s=r[n])&&s.length!==0;){for(let{id:i}of s){let a=this.indexStore.get(i);if(!a){Gi.info?.("could not find neighbor node",a);continue}a[n]?.find(({id:l})=>l==t)||Gi.info?.("asymmetry detected",a[n])}n++}}addConnection(t,r,n,s,i,a){r[s]||(r[s]=[]);let c=s===0?this.M<<1:this.M;if(this.optimizeRouting&&(c<<=2),r[s].length>=c+(c>>2)){Gi.warn?.("maxConnections reached, removing some connections",c);let l=[...r[s]];l.sort((f,m)=>f.distance-m.distance);let u=l.slice(0,c),d=l.slice(c);r[s]=u;for(let f of d){let m=a(f.id)??this.indexStore.get(f.id);m&&m[s]&&(m=a(f.id,m),m[s]=m[s].filter(({id:h})=>h!==t),s===0&&m[s].length===0&&Gi.info?.("should not remove last connection",t,n))}}r[s].find(({id:l})=>l===n)?Gi.debug?.("already connected",t,n):r[s]=[...r[s],{id:n,distance:i}]}validateConnectivity(t=0){let r=this.getEntryPoint(),n=new Set,s=[r.id];n.add(r.id);let i=0;for(;s.length>0;){let a=s.shift(),c=this.indexStore.get(a);for(let l=t;l<=c.level;l++)for(let{id:u}of c[l]||[])i++,n.has(u)||(n.add(u),s.push(u))}return n.size!==this.totalNodes&&console.log("visited",n.size,"total",this.totalNodes),{isFullyConnected:n.size===this.totalNodes,averageConnections:i/n.size}}get totalNodes(){return Array.from(this.indexStore.getKeys({start:0,end:1/0})).length}estimateCountAsSort(){return Math.sqrt(this.indexStore.getStats().entryCount*this.efConstructionSearch)}propertyResolver(t,r,n){let s=r?.sort;if(s){let i=s.vectorDistances;if(i){let l=i.get(n);if(l)return l}else i=r.vectorDistances=s.vectorDistances=new Map;let a=this.distance;s.type&&(a=s.distance==="euclidean"?Ng:wg);let c=a(s.target,t);return i.set(n,c),c}return t}}});var sN,tk=fe(()=>{ek();sN={HNSW:Og}});var ft={};Ce(ft,{database:()=>ku,databaseEnvs:()=>Do,databases:()=>Ge,dropDatabase:()=>mI,dropTableMeta:()=>Lse,getDatabases:()=>it,getDefaultCompression:()=>vg,getTables:()=>wse,onRemovedDB:()=>mh,onUpdatedTable:()=>Sl,readMetaDb:()=>ch,resetDatabases:()=>ed,table:()=>et,tables:()=>cn});function wse(){return Dg||it(),cn||{}}function it(){if(Dg)return Ge;Dg=!0,Ju=new Map;let e=(0,qt.getHdbBasePath)()&&(0,xt.join)((0,qt.getHdbBasePath)(),Lc),t=(0,qt.get)(U.DATABASES)||{};if(process.env.SCHEMAS_DATA_PATH&&(t.data={path:process.env.SCHEMAS_DATA_PATH}),e=process.env.STORAGE_PATH||(0,qt.get)(U.STORAGE_PATH)||e&&((0,Zn.existsSync)(e)?e:(0,xt.join)((0,qt.getHdbBasePath)(),I_)),!e)return;if((0,Zn.existsSync)(e))for(let n of(0,Zn.readdirSync)(e,{withFileTypes:!0})){let s=(0,xt.basename)(n.name,".mdb");n.isFile()&&(0,xt.extname)(n.name).toLowerCase()===".mdb"&&!t[s]?.path&&ch((0,xt.join)(e,n.name),null,s)}if((0,Zn.existsSync)((0,Qu.getBaseSchemaPath)())){for(let n of(0,Zn.readdirSync)((0,Qu.getBaseSchemaPath)(),{withFileTypes:!0}))if(!n.isFile()){let s=(0,xt.join)((0,Qu.getBaseSchemaPath)(),n.name),i=(0,xt.join)((0,Qu.getTransactionAuditStoreBasePath)(),n.name);for(let a of(0,Zn.readdirSync)(s,{withFileTypes:!0}))if(a.isFile()&&(0,xt.extname)(a.name).toLowerCase()===".mdb"){let c=(0,xt.join)(i,a.name);ch((0,xt.join)(s,a.name),(0,xt.basename)(a.name,".mdb"),n.name,c,!0)}}}if(t)for(let n in t){let s=t[n],i=s.path;if((0,Zn.existsSync)(i))for(let c of(0,Zn.readdirSync)(i,{withFileTypes:!0}))c.isFile()&&(0,xt.extname)(c.name).toLowerCase()===".mdb"&&ch((0,xt.join)(i,c.name),(0,xt.basename)(c.name,".mdb"),n);let a=s.tables;if(a)for(let c in a){let l=a[c],u=(0,xt.join)(l.path,(0,xt.basename)(c+".mdb"));(0,Zn.existsSync)(u)&&ch(u,c,n,null,!0)}}for(let n in Ge){let s=Ju.get(n);if(s){let i=Ge[n];n.includes("delete")&&yr.trace(`defined tables ${Array.from(s.keys())}`);for(let a in i)s.has(a)||(yr.trace(`delete table class ${a}`),delete i[a])}else if(delete Ge[n],n==="data"){for(let i in cn)delete cn[i];delete cn[Mg]}}let r=["hdb_temp","hdb_certificate","hdb_raw_analytics","hdb_session_will","hdb_job","hdb_license","hdb_info"];if((0,qt.get)(U.ANALYTICS_REPLICATE)===!1?r.push("hdb_analytics"):(Ge.system?.hdb_analytics?.enableAuditing(),Ge.system?.hdb_analytics_hostname?.enableAuditing()),Ge.system)for(let n of r)Ge.system[n]&&(Ge.system[n].replicate=!1);return Ju=null,Ge}function ed(){Dg=!1;for(let[,e]of Do)e.needsDeletion=!0;it();for(let[e,t]of Do)if(t.needsDeletion&&!e.endsWith("system.mdb")){t.close(),Do.delete(e);let r=Ge[t.databaseName];for(let n in r)if(r[n].primaryStore.path===e){delete Ge[t.databaseName],uh.forEach(i=>i(t.databaseName));break}}return Ge}function ch(e,t,r=aN,n,s){let i=new iN.default(e,!1);try{let a=Do.get(e);a?a.needsDeletion=!1:(a=(0,Xu.open)(i),Do.set(e,a));let c=new Zu.default(!1),l=a.dbisDb||(a.dbisDb=a.openDB(Cg.INTERNAL_DBIS_NAME,c)),u=a.auditStore;u||(n?(0,Zn.existsSync)(n)&&(i.path=n,u=(0,Xu.open)(i),u.isLegacy=!0):u=fE(a));let d=ok(r),f=d[Mg],m=new Map;for(let{key:h,value:p}of l.getRange({start:!1})){let[E,g]=h.toString().split("/");g===""?g=p.name:g||(g=E,E=t,p.name||(p.name=g,p.indexed=!p.is_hash_attribute)),f?.add(E);let y=m.get(E);y||m.set(E,y={attributes:[]}),(g==null||p.is_hash_attribute)&&(y.primary=p),g!=null&&y.attributes.push(p),Object.defineProperty(p,"key",{value:h,configurable:!0})}for(let[h,p]of m){let{attributes:E,primary:g}=p;if(!g){for(let se of E)if(se.is_hash_attribute||se.isPrimaryKey){g=se;break}if(!g){yr.warn(`Unable to find a primary key attribute on table ${h}, with attributes: ${JSON.stringify(E)}`);continue}}let y=d[h],T={},R=[],I,P,Y=typeof g.audit=="boolean"?g.audit:(0,qt.get)(U.LOGGING_AUDITLOG),te=g.trackDeletes,x=g.expiration,$=g.eviction,j=g.sealed,V=g.splitSegments,le=g.replicate;if(y)T=y.indices,R=y.attributes,y.schemaVersion++;else{I=g.tableId,I?I>=(l.get(ju)||0)&&(l.putSync(ju,I+1),yr.info(`Updating next table id (it was out of sync) to ${I+1} for ${h}`)):(g.tableId=I=l.get(ju),I||(I=1),yr.debug("Table {tableName} missing an id, assigning {tableId}"),l.putSync(ju,I+1),l.putSync(g.key,g));let se=new Zu.default(!g.is_hash_attribute,g.is_hash_attribute);if(se.compression=g.compression,se.compression){let Ee=(0,qt.get)(U.STORAGE_COMPRESSION_THRESHOLD)||ik;se.compression.threshold=Ee}P=TE(a.openDB(g.key,se),a),a.databaseName=r,P.tableId=I}let re;for(let se of E){se.attribute=se.name;try{if(!se.is_hash_attribute&&(se.indexed||se.attribute&&!se.name)){if(!T[se.name]){let Ne=ck(se.key,a,se);T[se.name]=Ne,T[se.name].indexNulls=se.indexNulls}let Ee=R.find(Ne=>Ne.name===se.name);Ee?R.splice(R.indexOf(Ee),1,se):R.push(se),re=!0}}catch(Ee){yr.error("Error trying to update attribute",se,R,T,Ee)}}for(let se of R)if(!E.find(Ne=>Ne.name===se.name)){if(se.is_hash_attribute){yr.error("Unable to remove existing primary key attribute",se);continue}se.indexed&&(R.splice(R.indexOf(se),1),re=!0)}if(y)re&&(y.schemaVersion++,y.updatedAttributes());else{y=ak(d,h,Ig({primaryStore:P,auditStore:u,audit:Y,sealed:j,splitSegments:V,replicate:le,expirationMS:x&&x*1e3,evictionMS:$&&$*1e3,trackDeletes:te,tableName:h,tableId:I,primaryKey:g.name,databasePath:s?r+"/"+h:r,databaseName:r,indices:T,attributes:E,schemaDefined:g.schemaDefined,dbisDB:l})),y.schemaVersion=1;for(let se of lh)se(y)}}return a}catch(a){throw a.message+=` opening database ${e}`,a}}function ok(e){let t=Ge[e];if(t||(e==="data"?t=Ge[e]=cn:e==="system"?Object.defineProperty(Ge,"system",{value:t=Object.create(null),configurable:!0}):t=Ge[e]=Object.create(null)),Ju&&!Ju.has(e)){let r=new Set;t[Mg]=r,Ju.set(e,r)}return t}function ak(e,t,r){return e[t]=r,r}function ku({database:e,table:t}){e||(e=aN),it();let r=ok(e),n=(0,xt.join)((0,qt.getHdbBasePath)(),Lc),s=(0,qt.get)(U.DATABASES)||{};process.env.SCHEMAS_DATA_PATH&&(s.data={path:process.env.SCHEMAS_DATA_PATH});let i=t&&s[e]?.tables?.[t]?.path;n=i||s[e]?.path||process.env.STORAGE_PATH||(0,qt.get)(U.STORAGE_PATH)||((0,Zn.existsSync)(n)?n:(0,xt.join)((0,qt.getHdbBasePath)(),I_));let a=(0,xt.join)(n,(i?t:e)+".mdb"),c=Do.get(a);if(!c||c.status==="closed"){let l=new iN.default(a,!1);c=(0,Xu.open)(l),Do.set(a,c)}return c.auditStore||(c.auditStore=fE(c)),c}async function mI(e){if(!Ge[e])throw new Error("Schema does not exist");let t=Ge[e],r;for(let n in t)r=t[n].primaryStore.rootStore,Do.delete(r.path),r.status==="open"&&(await r.close(),await dh.remove(r.path));if(r||(r=ku({database:e,table:null}),r.status==="open"&&(await r.close(),await dh.remove(r.path))),e==="data"){for(let n in cn)delete cn[n];delete cn[Mg]}delete Ge[e],uh.forEach(n=>n(e)),await SA(r)}function ck(e,t,r){let n=r.is_hash_attribute||r.indexed.type&&sN[r.indexed.type]?.useObjectStore,s=new Zu.default(!n,n),i=t.openDB(e,s);if(r.indexed.type){let a=sN[r.indexed.type];a?i.customIndex=new a(i,r.indexed):yr.error(`The indexing type '${r.indexed.type}' is unknown`)}return i}function et(e){let{table:t,database:r,expiration:n,eviction:s,scanInterval:i,attributes:a,audit:c,sealed:l,splitSegments:u,replicate:d,trackDeletes:f,schemaDefined:m,origin:h}=e;r||(r=aN);let p=ku({database:r,table:t}),E=Ge[r];yr.trace(`Defining ${t} in ${r}`);let g=E?.[t];if(p.status==="closed")throw new Error(`Can not use a closed data store for ${t}`);let y,T,R;m==null&&(m=!0);let I=new Zu.default(!1);for(let V of a)V.attribute&&!V.name?(V.name=V.attribute,V.indexed=!0):V.attribute=V.name,V.expiresAt&&(V.indexed=!0);let P,Y;if(g){if(y=g.primaryKey,g.primaryStore.rootStore.status==="closed")throw new Error(`Can not use a closed data store from ${t} class`);u==null&&(u=g.splitSegments),g.attributes.splice(0,g.attributes.length,...a)}else{let V=p.auditStore;T=a.find(Ee=>Ee.isPrimaryKey)||{},y=T.name,T.is_hash_attribute=T.isPrimaryKey=!0,T.schemaDefined=m,T.compression=vg(),f&&(T.trackDeletes=!0),c=T.audit=typeof c=="boolean"?c:(0,qt.get)(U.LOGGING_AUDITLOG),n&&(T.expiration=n),s&&(T.eviction=s),u??=!1,T.splitSegments=u,typeof l=="boolean"&&(T.sealed=l),typeof d=="boolean"&&(T.replicate=d),h&&(T.origins?T.origins.includes(h)||T.origins.push(h):T.origins=[h]),yr.trace(`${t} table loading, opening primary store`);let le=new Zu.default(!1,!0);le.compression=T.compression;let re=t+"/";if(R=p.dbisDb=p.openDB(Cg.INTERNAL_DBIS_NAME,I),j(),R.get(re))return Y&&Y(),ed(),et(e);let se=TE(p.openDB(re,le),p);p.databaseName=r,se.tableId=R.get(ju),yr.trace(`Assigning new table id ${se.tableId} for ${t}`),se.tableId||(se.tableId=1),R.put(ju,se.tableId+1),T.tableId=se.tableId,g=ak(E,t,Ig({primaryStore:se,auditStore:V,audit:c,sealed:l,splitSegments:u,replicate:d,trackDeletes:f,expirationMS:n&&n*1e3,evictionMS:s&&s*1e3,primaryKey:y,tableName:t,tableId:se.tableId,databasePath:r,databaseName:r,indices:{},attributes:a,schemaDefined:m,dbisDB:R})),g.schemaVersion=1,P=!0,R.put(re,T)}let te=g.indices;R=R||(p.dbisDb=p.openDB(Cg.INTERNAL_DBIS_NAME,I)),g.dbisDB=R;let x=[];for(let{key:V,value:le}of R.getRange({start:!0})){let[re,se]=V.toString().split("/");if(se===""&&(se=le.name),se){if(re!==t)continue}else continue;let Ee=a.find(Fe=>Fe.name===se),Ne=!Ee?.indexed&&le.indexed&&!le.isPrimaryKey;if((!Ee||Ne)&&(j(),P=!0,Ee||R.remove(V),Ne)){let Fe=g.indices[re];Fe&&x.push(Fe)}}let $=[];try{for(let V of a||[]){if((V.relationship||V.computed)&&(P=!0,V.relationship))continue;let le=t+"/"+(V.name||"");Object.defineProperty(V,"key",{value:le,configurable:!0});let re=R.get(le);if(V.isPrimaryKey){if(re=re||R.get(le=t+"/")||{},c!==void 0&&c!==g.audit||l!==void 0&&l!==g.sealed||d!==void 0&&d!==g.replicate||(+n||void 0)!==(+re.expiration||void 0)||(+s||void 0)!==(+re.eviction||void 0)||V.type!==re.type){let Ee={...re};typeof c=="boolean"&&(c&&g.enableAuditing(c),Ee.audit=c),n&&(Ee.expiration=+n),s&&(Ee.eviction=+s),l!==void 0&&(Ee.sealed=l),d!==void 0&&(Ee.replicate=d),V.type&&(Ee.type=V.type),P=!0,j(),R.put(le,Ee)}continue}re?.attribute&&!re.name&&(re.indexed=!0);let se=!re||re.type!==V.type||JSON.stringify(re.indexed)!==JSON.stringify(V.indexed)||re.nullable!==V.nullable||re.version!==V.version||JSON.stringify(re.properties)!==JSON.stringify(V.properties)||JSON.stringify(re.elements)!==JSON.stringify(V.elements);if(V.indexed){let Ee=ck(le,p,V);(se||re.indexingPID&&re.indexingPID!==process.pid||re.restartNumber<fh.workerData?.restartNumber)&&(P=!0,j(),re=R.get(le),(se||re.indexingPID&&re.indexingPID!==process.pid||re.restartNumber<fh.workerData?.restartNumber)&&(P=!0,V.indexNulls===void 0&&(V.indexNulls=!0),g.primaryStore.getStats().entryCount>0&&(V.lastIndexedKey=re?.lastIndexedKey??void 0,V.indexingPID=process.pid,Ee.isIndexing=!0,Object.defineProperty(V,"dbi",{value:Ee}),$.push(V))),R.put(le,V)),re?.indexNulls&&V.indexNulls===void 0&&(V.indexNulls=!0),Ee.indexNulls=V.indexNulls,te[V.name]=Ee}else se&&(P=!0,j(),R.put(le,V))}}finally{Y&&Y()}if(P&&(g.schemaVersion++,g.updatedAttributes()),yr.trace(`${t} table loading, running index`),$.length>0||x.length>0?g.indexingOperation=Pse(g,$,x):P&&Pg.signalSchemaChange(new Lg.SchemaEventMsg(process.pid,"schema-change",g.databaseName,g.tableName)),g.origin=h,P)for(let V of lh)V(g,h!=="cluster");return(n||s||i)&&g.setTTLExpiration({expiration:n,eviction:s,scanInterval:i}),yr.trace(`${t} table loaded`),g;function j(){Y||p.transactionSync(()=>({then(V){Y=V}}))}o(j,"startTxn")}async function Pse(e,t,r){try{yr.info(`Indexing ${e.tableName} attributes`,t);let n=e.schemaVersion;await Pg.signalSchemaChange(new Lg.SchemaEventMsg(process.pid,"schema-change",e.databaseName,e.tableName));let s;for(let u of r)s=u.drop();let i,a={},c=0,l=t.length;if(await new Promise(u=>setImmediate(u)),l>0){let u;for(let f of t)(0,Xu.compareKeys)(f.lastIndexedKey,u)<0&&(u=f.lastIndexedKey),f.lastIndexedKey==null&&f.dbi.clearAsync();let d=0;for(let{key:f,value:m,version:h}of e.primaryStore.getRange({start:u,lazy:l<4,versions:!0,snapshot:!1}))if(m){if(d++,s=e.primaryStore.ifVersion(f,h,()=>{for(let p=0;p<l;p++){let E=t[p],g=E.name,y=E.dbi;try{let T=E.resolve,R=m&&(T?T(m):m[g]);if(y.customIndex){y.customIndex.index(f,R);continue}let I=(0,rk.getIndexedValues)(R);if(I)for(let P=0,Y=I.length;P<Y;P++)y.put(I[P],f)}catch(T){a[g]||(a[g]=!0,yr.error(`Error indexing attribute ${g}`,T))}}}),s.then(()=>d--,p=>{d--,yr.error(p)}),fh.workerData&&fh.workerData.restartNumber!==sk.restartNumber&&(i=!0),++c%100===0||i){for(let p of t)p.lastIndexedKey=f,e.dbisDB.put(p.key,p);if(i)return}d>Ose?await s:d>Cse&&await new Promise(p=>setImmediate(p))}for(let f of t)delete f.lastIndexedKey,delete f.indexingPID,f.dbi.isIndexing=!1,s=e.dbisDB.put(f.key,f)}await s,await Pg.signalSchemaChange(new Lg.SchemaEventMsg(process.pid,"indexing-finished",e.databaseName,e.tableName)),yr.info(`Finished indexing ${e.tableName} attributes`,t)}catch(n){yr.error("Error in indexing",n)}}function Lse({table:e,database:t}){let r=ku({database:t,table:e}),n=[],s=r.dbisDb;for(let i of s.getKeys({start:e+"/",end:e+"0"}))n.push(s.remove(i));return Promise.all(n)}function Sl(e){return lh.push(e),{remove(){let t=lh.indexOf(e);t>-1&&lh.splice(t,1)}}}function mh(e){return uh.push(e),{remove(){let t=uh.indexOf(e);t>-1&&uh.splice(t,1)}}}function vg(){let e=(0,qt.get)(U.STORAGE_COMPRESSION),t=(0,qt.get)(U.STORAGE_COMPRESSION_DICTIONARY),r=(0,qt.get)(U.STORAGE_COMPRESSION_THRESHOLD)||ik,n={startingOffset:32};return t&&(n.dictionary=dh.readFileSync(t)),r&&(n.threshold=r),e&&n}var qt,Cg,Xu,xt,Zn,Qu,Zu,iN,dh,oN,rk,Pg,Lg,fh,nk,sk,yr,aN,Mg,ik,cn,Ge,ju,lh,uh,Dg,Do,Ju,Ose,Cse,Le=fe(()=>{qt=w(ce()),Cg=w(kt()),Xu=require("lmdb"),xt=require("path"),Zn=require("fs"),Qu=w(At());Tm();Zu=w(Rm()),iN=w(ym());k();dh=w(require("fs-extra")),oN=w(zs()),rk=w(An()),Pg=w(No()),Lg=w(ti()),fh=require("worker_threads"),nk=w(z()),sk=w(st());mo();Wc();Ts();tk();yr=(0,nk.forComponent)("storage"),aN="data",Mg=Symbol("defined-tables"),ik=((0,qt.get)(U.STORAGE_PAGESIZE)||4096)-60;(0,qt.initSync)();cn=Object.create(null),Ge=Object.create(null);(0,oN._assignPackageExport)("databases",Ge);(0,oN._assignPackageExport)("tables",cn);ju=Symbol.for("next-table-id"),lh=[],uh=[],Do=new Map;o(wse,"getTables");o(it,"getDatabases");o(ed,"resetDatabases");o(ch,"readMetaDb");o(ok,"ensureDB");o(ak,"setTable");o(ku,"database");o(mI,"dropDatabase");o(ck,"openIndex");o(et,"table");Ose=1e3,Cse=10;o(Pse,"runIndexing");o(Lse,"dropTableMeta");o(Sl,"onUpdatedTable");o(mh,"onRemovedDB");o(vg,"getDefaultCompression")});var uN={};Ce(uN,{loadGQLSchema:()=>vse,start:()=>lN,startOnMainThread:()=>Mse});function lN({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r,n,s,i){let{parse:a,Source:c,Kind:l,NamedTypeNode:u,StringValueNode:d}=await import("graphql"),f=a(new c(r.toString(),s)),m=new Map,h=[],p;for(let y of f.definitions)switch(y.kind){case l.OBJECT_TYPE_DEFINITION:let Y=function(x){if(x.kind==="NonNullType"){let V=Y(x.type);return V.nullable=!1,V}if(x.kind==="ListType")return{type:"array",elements:Y(x.type)};let j={type:x.name?.value};return Object.defineProperty(j,"location",{value:x.loc.startToken}),j};o(Y,"getProperty");let T=y.name.value,R=[],I={table:null,database:null,properties:R};m.set(T,I);for(let x of y.directives){if(x.name.value==="table"){for(let j of x.arguments)I[j.name.value]=j.value.value;I.schema&&(I.database=I.schema),I.table||(I.table=T),I.audit&&(I.audit=I.audit!=="false"),I.attributes=I.properties,h.push(I)}if(x.name.value==="sealed"&&(I.sealed=!0),x.name.value==="splitSegments"&&(I.splitSegments=!0),x.name.value==="replicate"&&(I.replicate=!0),x.name.value==="export"){I.export=!0;for(let j of x.arguments)typeof I.export!="object"&&(I.export={}),I.export[j.name.value]=j.value.value}}let P=!1,te={};for(let x of y.fields){let $=Y(x.type);$.name=x.name.value,R.push($),te[$.name]=void 0;for(let j of x.directives){let V=j.name.value;if(V==="primaryKey")P?console.warn("Can not define two attributes as a primary key at",j.loc):($.isPrimaryKey=!0,P=!0);else if(V==="indexed"){let le={};for(let re of j.arguments||[])le[re.name.value]=re.value.value;$.indexed=le}else if(V==="computed"){for(let le of j.arguments||[])if(le.name.value==="from"){let re=le.value.value;$.computed={from:g(re,le,te)},$.version==null&&($.version=re)}else le.name.value==="version"&&($.version=le.value.value);$.computed=$.computed||!0}else if(V==="relationship"){let le={};for(let re of j.arguments)le[re.name.value]=re.value.value;$.relationship=le}else if(V==="createdTime")$.assignCreatedTime=!0;else if(V==="updatedTime")$.assignUpdatedTime=!0;else if(V==="expiresAt")$.expiresAt=!0;else if(V==="allow"){let le=$.authorizedRoles=[];for(let re of j.arguments)re.name.value==="role"&&le.push(re.value.value)}else server.knownGraphQLDirectives.includes(V)&&console.warn(`@${V} is an unknown directive, at`,j.loc)}}I.type=T,T==="Query"&&(p=I)}function E(y){let T=m.get(y.type);T?(Object.defineProperty(y,"properties",{value:T.properties}),Object.defineProperty(y,"definition",{value:T})):y.type==="array"?E(y.elements):Dse.includes(y.type)||(0,uk.getWorkerIndex)()===0&&console.error(`The type ${y.type} is unknown at line ${y.location.line}, column ${y.location.column}, in ${s}`)}o(E,"connectPropertyType");for(let y of m.values())for(let T of y.properties)E(T);for(let y of h)y.tableClass=e(y),y.export&&(y.export.name===""?i.set((0,cN.dirname)(n),y.tableClass):i.set((0,cN.dirname)(n)+"/"+(y.export.name||y.type),y.tableClass,y.export));function g(y,T,R){return new lk.Script(`function computed(attributes) { return function(record) { with(attributes) { with (record) { return ${y}; } } } } computed;`,{filename:s,lineOffset:T.loc.startToken.line-1,columnOffset:T.loc.startToken.column}).runInThisContext()(R)}o(g,"createComputedFrom")}}var cN,lk,uk,Dse,Mse,vse,dk=fe(()=>{cN=require("path"),lk=require("node:vm");Le();uk=w(st()),Dse=["ID","Int","Float","Long","String","Boolean","Date","Bytes","Any","BigInt","Blob"];server.knownGraphQLDirectives&&(server.knownGraphQLDirectives=["table","sealed","export","primaryKey","indexed","computed","relationship","createdTime","updatedTime","expiresAt","allow"]);o(lN,"start");Mse=lN,vse=lN({ensureTable:et}).handleFile});var fN={};Ce(fN,{start:()=>$se});function Use(e){if(e.kind!==Be.Kind.OPERATION_DEFINITION&&e.kind!==Be.Kind.FRAGMENT_DEFINITION)throw new Ur(`Unexpected non-executable definition type ${e.kind}.`)}function fk(e){if(typeof e!="object"||e===null)throw new qi("Request body must be an object.");if(!("query"in e))throw new qi("Request body must contain a `query` field.");if(typeof e.query!="string")throw new qi("Request body `query` field must be a string.");if("variables"in e&&(typeof e.variables!="object"||e.variables===null))throw new qi("Request body `variables` field must be an object.");if("operationName"in e&&typeof e.operationName!="string")throw new qi("Request body `operationName` field must be a string.")}function dN(e){return parseInt(e.value,10)}function hk(e){return parseFloat(e.value)}function pk(e,t,r){let n=r.get(e.name.value);return _k(n)?Ek(n,t):{attribute:t,value:n}}function _k(e){return typeof e=="object"&&e!=null&&!Array.isArray(e)}function Ek(e,t){return t=typeof t=="string"?[t]:t,Object.entries(e).flatMap(([r,n])=>(t=[...t,r],_k(n)?Ek(n,t):{attribute:t,value:n}))}function xse(e,t,r){switch(t=[...t,e.name.value],e.value.kind){case Be.Kind.NULL:return{attribute:t,value:null};case Be.Kind.INT:return{attribute:t,value:dN(e.value)};case Be.Kind.FLOAT:return{attribute:t,value:hk(e.value)};case Be.Kind.BOOLEAN:case Be.Kind.STRING:return{attribute:t,value:e.value.value};case Be.Kind.VARIABLE:return pk(e.value,t,r);case Be.Kind.OBJECT:return gk(e.value,t,r);case Be.Kind.LIST:case Be.Kind.ENUM:default:throw new Ur(`Value type, ${e.value.kind}, is not supported.`)}}function gk(e,t,r){return e.fields.flatMap(n=>xse(n,t,r))}function Bse(e,t){switch(e.value.kind){case Be.Kind.NULL:return{attribute:e.name.value,value:null};case Be.Kind.INT:return{attribute:e.name.value,value:dN(e.value)};case Be.Kind.FLOAT:return{attribute:e.name.value,value:hk(e.value)};case Be.Kind.BOOLEAN:case Be.Kind.STRING:return{attribute:e.name.value,value:e.value.value};case Be.Kind.VARIABLE:return pk(e.value,e.name.value,t);case Be.Kind.OBJECT:return gk(e.value,[e.name.value],t);case Be.Kind.LIST:case Be.Kind.ENUM:default:throw new Ur(`Argument type, ${e.value.kind}, is not supported.`)}}function Fse(e,t){return e.flatMap(r=>Bse(r,t))}function Ug(e,t){return e.selections.flatMap(r=>{switch(r.kind){case Be.Kind.FIELD:return r;case Be.Kind.FRAGMENT_SPREAD:{let n=r.name.value,s=t.get(n);if(s==null)throw new Ur(`Fragment \`${n}\` not found.`);return Ug(s.selectionSet,t)}case Be.Kind.INLINE_FRAGMENT:return Ug(r.selectionSet,t)}})}function Sk(e,t){return Ug(e,t).map(r=>r.selectionSet?.selections.length>0?{name:r.name.value,select:Sk(r.selectionSet,t)}:r.name.value)}async function Hse(e,t,r,n){let s=As.getMatch(e.name.value,"graphql");if(s===void 0)throw new Ur(`Resource \`${e.name.value}\` not found.`);let i=s.Resource,a={select:Sk(e.selectionSet,r),conditions:Fse(e.arguments,t)},c=[];n.authorize=!0;for await(let l of i.search(a,n))c.push(l);return[e.name.value,c]}function Tk(e){switch(e.kind){case Be.Kind.NULL:return null;case Be.Kind.INT:return dN(e);case Be.Kind.FLOAT:return parseFloat(e.value);case Be.Kind.STRING:case Be.Kind.BOOLEAN:return e.value;case Be.Kind.OBJECT:return e.fields.reduce((t,r)=>({[r.name.value]:Tk(r.value),...t}),{});case Be.Kind.LIST:case Be.Kind.ENUM:default:throw new Ur(`Value type, ${e.kind}, is not supported.`)}}function kse(e,t){let r=new Map;for(let n of e){let s=n.variable.name.value,i=t?.[s];if(i===void 0&&n.defaultValue!==void 0&&(i=Tk(n.defaultValue)),n.type.kind===Be.Kind.NON_NULL_TYPE&&!(s in t)&&i===void 0)throw new Ur(`Variable $${s} is required, but not provided.`);r.set(n.variable.name.value,i??null)}return r}async function Gse(e,t,r,n){if(e.operation===Be.OperationTypeNode.SUBSCRIPTION)throw new Ur("Subscriptions are not supported.");if(e.operation===Be.OperationTypeNode.MUTATION)throw new Ur("Mutations are not supported yet.");let s=kse(e.variableDefinitions,t),i=await Promise.all(Ug(e.selectionSet,r).map(c=>Hse(c,s,r,n))),a={data:{}};for(let[c,l]of i)a.data[c]=l;return a}async function mk({query:e,variables:t={},operationName:r},n){let s=Be.parse(e),i=new Map,a=new Map;for(let u of s.definitions)if(Use(u),u.kind===Be.Kind.FRAGMENT_DEFINITION)a.set(u.name.value,u);else{if(u.name===void 0&&s.definitions.length>1)throw new Ur("Unnamed operations are only allowed when there is a single operation in the document.");let d=u.name?.value??"Unnamed Query";if(i.has(d))throw new Ur(`Duplicate operation definition: ${d}`);i.set(d,u)}let c;if(r==null)if(i.size===1)c=i.entries().next().value[1];else throw new Ur("Operation name is required when there are multiple operations in the document.");else if(c=i.get(r),c==null)throw new Ur(`Operation \`${r}\` not found.`);let l=await Gse(c,t,a,n);return{status:200,headers:{"Content-Type":"application/graphql-response+json; charset=utf-8"},body:JSON.stringify(l)}}async function qse(e){switch(e.method){case"GET":{let t=new URLSearchParams(e.url.split("?")[1]),r={};for(let[n,s]of t)r[n]=n==="variables"||n==="extensions"?JSON.parse(s):s;return fk(r),mk(r,e)}case"POST":{let r=await _o(e.headers.get("content-type"),!0)(e._nodeRequest);return fk(r),mk(r,e)}default:throw new qi("Method Not Allowed",405,{Allow:"GET, POST"})}}function $se(e){e.server.http(async(t,r)=>{if(!t.url.startsWith("/graphql"))return r(t);try{return await qse(t)}catch(n){logger.error(n);let s=t.headers.get("accept")??"application/graphql-response+json";switch(s){case"application/json":{if(n instanceof qi)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json",...n.headers}};if(n instanceof Be.GraphQLError)return{status:200,body:JSON.stringify({errors:[n]}),headers:{"Content-Type":"application/json"}};if(n instanceof Ur)return{status:200,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json"}};if(n instanceof Error)return{status:500,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json"}};break}default:logger.info(`Unsupported accept header, ${s}, defaulting to application/graphql-response+json`);case"application/graphql-response+json":{if(n instanceof qi)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json",...n.headers}};if(n instanceof Be.GraphQLError)return{status:400,body:JSON.stringify({errors:[n]}),headers:{"Content-Type":"application/graphql-response+json"}};if(n instanceof Ur)return{status:400,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json"}};if(n instanceof Error)return{status:500,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json"}};break}}throw n}},{port:e.port,securePort:e.securePort})}var Be,Ur,qi,Rk=fe(()=>{Be=w(require("graphql"));Eo();Lu();o(Use,"assertExecutableDefinitionNode");o(fk,"assertRequestParams");o(dN,"processIntValueNode");o(hk,"processFloatValueNode");o(pk,"processVariableNode");o(_k,"isObject");o(Ek,"transformObjectIntoQueryCondition");o(xse,"processObjectFieldNode");o(gk,"processObjectValueNode");o(Bse,"processArgumentNode");o(Fse,"buildConditionsQuery");o(Ug,"fillInFragments");o(Sk,"buildSelectQuery");o(Hse,"processFieldNode");o(Tk,"processConstValueNode");o(kse,"resolveVariables");o(Gse,"executeOperation");o(mk,"resolver");Ur=class extends Error{static{o(this,"GraphQLQueryingError")}},qi=class extends Error{static{o(this,"HTTPError")}statusCode;headers;constructor(t,r=400,n={}){super(t),this.statusCode=r,this.headers=n}};o(qse,"graphqlQueryingHandler");o($se,"start")});var wk=M((kLe,Nk)=>{var td=require("validate.js"),Ak=at(),rd=(k(),v(K)),{handleHDBError:Vse,hdbErrors:Kse}=_e(),{HDB_ERROR_MSGS:Xt,HTTP_STATUS_CODES:Yse}=Kse,mN=o(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),Wse={STRUCTURE_USER:"structure_user"},yk=Object.values(rd.ROLE_TYPES_ENUM),zse="attribute_permissions",jse="attribute_name",{PERMS_CRUD_ENUM:nd}=rd,Qse=[zse,...Object.values(nd)],bk=[nd.READ,nd.INSERT,nd.UPDATE],Jse=[jse,...bk];function Xse(e){let t=mN();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,Ik(e,t)}o(Xse,"addRoleValidation");function Zse(e){let t=mN();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,Ik(e,t)}o(Zse,"alterRoleValidation");function eie(e){let t=mN();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,Ak.validateObject(e,t)}o(eie,"dropRoleValidation");var tie=["operation","role","id","permission","hdb_user","access"];function Ik(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let a=0,c=n.length;a<c;a++)tie.includes(n[a])||s.push(n[a]);s.length>0&&cr(Xt.INVALID_ROLE_JSON_KEYS(s),r);let i=Ak.validateObject(e,t);if(i&&i.message.split(",").forEach(a=>{cr(a,r)}),e.permission){let a=rie(e);a&&cr(a,r),yk.forEach(c=>{e.permission[c]&&!td.isBoolean(e.permission[c])&&cr(Xt.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let a in e.permission)if(yk.indexOf(a)<0){if(a===Wse.STRUCTURE_USER){let l=e.permission[a];if(typeof l=="boolean")continue;if(Array.isArray(l)){for(let u=0,d=l.length;u<d;u++){let f=l[u];global.hdb_schema[f]||cr(Xt.SCHEMA_NOT_FOUND(f),r)}continue}cr(Xt.STRUCTURE_USER_ROLE_TYPE_ERROR(a),r);continue}let c=e.permission[a];if(!a||!global.hdb_schema[a]){cr(Xt.SCHEMA_NOT_FOUND(a),r);continue}if(c.tables)for(let l in c.tables){let u=c.tables[l];if(!l||!global.hdb_schema[a][l]){cr(Xt.TABLE_NOT_FOUND(a,l),r);continue}if(Object.keys(u).forEach(d=>{Qse.includes(d)||cr(Xt.INVALID_PERM_KEY(d),r,a,l)}),Object.values(nd).forEach(d=>{td.isDefined(u[d])?td.isBoolean(u[d])||cr(Xt.TABLE_PERM_NOT_BOOLEAN(d),r,a,l):cr(Xt.TABLE_PERM_MISSING(d),r,a,l)}),u.attribute_permissions===void 0){cr(Xt.ATTR_PERMS_ARRAY_MISSING,r,a,l);continue}else if(!(Array.isArray(u.attribute_permissions)||u.attribute_permissions===null)){cr(Xt.ATTR_PERMS_NOT_ARRAY,r,a,l);continue}if(u.attribute_permissions){let d=global.hdb_schema[a][l].attributes.map(({attribute:m})=>m),f={read:!1,insert:!1,update:!1};for(let m in u.attribute_permissions){let h=u.attribute_permissions[m];if(Object.keys(h).forEach(E=>{!Jse.includes(E)&&E!==nd.DELETE&&cr(Xt.INVALID_ATTR_PERM_KEY(E),r,a,l)}),!td.isDefined(h.attribute_name)){cr(Xt.ATTR_PERM_MISSING_NAME,r,a,l);continue}let p=h.attribute_name;if(!d.includes(p)){cr(Xt.INVALID_ATTRIBUTE_IN_PERMS(p),r,a,l);continue}bk.forEach(E=>{td.isDefined(h[E])?td.isBoolean(h[E])||cr(Xt.ATTR_PERM_NOT_BOOLEAN(E,p),r,a,l):cr(Xt.ATTR_PERM_MISSING(E,p),r,a,l)}),!f.read&&h.read===!0&&(f.read=!0),!f.insert&&h.insert===!0&&(f.insert=!0),!f.update&&h.update===!0&&(f.update=!0)}if(u.read===!1&&f.read===!0||u.insert===!1&&f.insert===!0||u.update===!1&&f.update===!0){let m=`${a}.${l}`;cr(Xt.MISMATCHED_TABLE_ATTR_PERMS(m),r,a,l)}}}}return nie(r)}o(Ik,"customValidate");Nk.exports={addRoleValidation:Xse,alterRoleValidation:Zse,dropRoleValidation:eie};function rie(e){let{operation:t,permission:r}=e;if(t===rd.OPERATIONS_ENUM.ADD_ROLE||t===rd.OPERATIONS_ENUM.ALTER_ROLE){let n=r.super_user===!0,s=r.cluster_user===!0;if(Object.keys(r).length>1&&(n||s)){if(s&&n)return Xt.SU_CU_ROLE_COMBINED_ERROR;{let a=r.super_user?rd.ROLE_TYPES_ENUM.SUPER_USER:rd.ROLE_TYPES_ENUM.CLUSTER_USER;return Xt.SU_CU_ROLE_NO_PERMS_ALLOWED(a)}}}return null}o(rie,"validateNoSUPerms");function nie(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:Xt.ROLE_PERMS_ERROR,...e};return Vse(new Error,n,Yse.BAD_REQUEST)}else return null}o(nie,"generateRolePermResponse");function cr(e,t,r,n){if(!r)t.main_permissions.push(e);else{let s=n?r+"_"+n:r;t.schema_permissions[s]?t.schema_permissions[s].push(e):t.schema_permissions[s]=[e]}}o(cr,"addPermError")});var ph=M(($Le,Lk)=>{"use strict";var Ok=Mn(),Ck=on(),sie=fl(),pN=wk(),_N=No(),qLe=require("uuid").v4,iie=require("util"),xg=(k(),v(K)),oie=ie(),EN=Ck.searchByValue,aie=Ck.searchByHash,cie=iie.promisify(sie.delete),lie=ri(),uie=Fu(),{hdbErrors:die,handleHDBError:Tl}=_e(),{HDB_ERROR_MSGS:Pk,HTTP_STATUS_CODES:hh}=die,{UserEventMsg:gN}=ti();Lk.exports={addRole:fie,alterRole:mie,dropRole:hie,listRoles:pie};function hN(e){try{e.hdb_auth_header&&delete e.hdb_auth_header,e.HDB_INTERNAL_PATH&&delete e.HDB_INTERNAL_PATH,e.operation&&delete e.operation,e.hdb_user&&delete e.hdb_user}catch{}return e}o(hN,"scrubRoleDetails");async function fie(e){let t=pN.addRoleValidation(e);if(t)throw t;e=hN(e);let r={schema:"system",table:"hdb_role",search_attribute:"role",search_value:e.role,hash_attribute:"id",get_attributes:["*"]},n;try{n=Array.from(await EN(r)||[])}catch(i){throw Tl(i)}if(n&&n.length>0)throw Tl(new Error,Pk.ROLE_ALREADY_EXISTS(e.role),hh.CONFLICT,void 0,void 0,!0);e.id||(e.id=e.role);let s={operation:"insert",schema:"system",table:"hdb_role",hash_attribute:"id",records:[e]};return await Ok.insert(s),_N.signalUserChange(new gN(process.pid)),e=hN(e),e}o(fie,"addRole");async function mie(e){let t=pN.alterRoleValidation(e);if(t)throw t;e=hN(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await Ok.update(r)}catch(s){throw Tl(s)}if(n&&n?.message==="updated 0 of 1 records")throw Tl(new Error,"Invalid role id",hh.BAD_REQUEST,void 0,void 0,!0);return await _N.signalUserChange(new gN(process.pid)),e}o(mie,"alterRole");async function hie(e){let t=pN.dropRoleValidation(e);if(t)throw Tl(new Error,t,hh.BAD_REQUEST,void 0,void 0,!0);let r=new uie(xg.SYSTEM_SCHEMA_NAME,xg.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await aie(r));if(n.length===0)throw Tl(new Error,Pk.ROLE_NOT_FOUND,hh.NOT_FOUND,void 0,void 0,!0);let s=new lie(xg.SYSTEM_SCHEMA_NAME,xg.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await EN(s)),a=!1;if(oie.isEmptyOrZeroLength(i)===!1){for(let l=0;l<i.length;l++)if(i[l].active===!0){a=!0;break}}if(a===!0)throw Tl(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,hh.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await cie(c),_N.signalUserChange(new gN(process.pid)),`${n[0].role} successfully deleted`}o(hie,"dropRole");async function pie(){return EN({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}o(pie,"listRoles")});var SN={};Ce(SN,{start:()=>vk,startOnMainThread:()=>gie});function vk({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r){let n=(0,Dk.parseDocument)(r.toString(),{simpleKeys:!0}).toJSON();for(let s in n){let i=n[s];i.permission||(i={permission:i},i.permission.access&&(i.access=i.permission.access,delete i.permission.access));for(let a in i.permission){if(_ie.includes(a))continue;let c=i.permission[a];c.tables||(i.permission[a]=c={tables:c});for(let l in c.tables){let u=c.tables[l];if(u.read=!!u.read,u.insert=!!u.insert,u.update=!!u.update,u.delete=!!u.delete,u.attributes){let d=[];for(let f in u.attributes){let m=u.attributes[f];m.attribute_name=f,d.push(m)}u.attribute_permissions=d,delete u.attributes}if(u.attribute_permissions){if(!Array.isArray(u.attribute_permissions))throw new Error("attribute_permissions must be an array if defined");for(let d of u.attribute_permissions)d.read=!!d.read,d.insert=!!d.insert,d.update=!!d.update}else u.attribute_permissions=null}}i.role=i.id=s,await Eie(i)}}}async function Eie(e){let t=it().system.hdb_role;for await(let r of t.search([{attribute:"role",value:e.role}])){let{__createdtime__:n,__updatedtime__:s,...i}=r;return(0,Mk.isEqual)(i,e)?void 0:(e.id=r.id,(0,Bg.alterRole)(e))}return(0,Bg.addRole)(e)}var Bg,Dk,Mk,_ie,gie,Uk=fe(()=>{Le();Bg=w(ph()),Dk=require("yaml"),Mk=require("lodash"),_ie=["super_user","cluster_user","structure_user"];o(vk,"start");o(Eie,"ensureRole");gie=vk});async function Fg(e){let t=(0,Fk.pathToFileURL)(e).toString();if(Sie)return _h||(_h=Tie(yie)),(await(await _h).import(t)).namespace;try{return await import(t)}catch(r){try{(await import("internal/util")).default.decorateErrorStack(r)}catch{}throw r}}async function Tie(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),_h=new Compartment({console,Math,Date,fetch:Rie,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,Bk.extname)(r)||(r+=".js"),r)},importHook:o(async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){s.Resource=Dr,s.tables=cn,s.databases=Ge}};let n=await(0,xk.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)},"importHook")}),_h}function Rie(e,t){let r=typeof e=="string"||e.url;if(new URL(r).protocol!="https")throw new Error("Only https is allowed in fetch");return fetch(e,t)}function yie(){return{Resource:Dr,tables:cn}}var xk,Bk,Fk,Sie,_h,TN=fe(()=>{Ia();Le();xk=require("fs/promises"),Bk=require("path"),Fk=require("url"),Sie=!1;o(Fg,"secureImport");o(Tie,"getCompartment");o(Rie,"secureOnlyFetch");o(yie,"getGlobalVars")});var RN={};Ce(RN,{handleApplication:()=>Aie,suppressHandleApplicationWarning:()=>bie});function Hk(e){return typeof e=="function"&&("get"in e||"put"in e||"post"in e||"delete"in e)}async function Aie(e){e.handleEntry(t=>{if(t.entryType!=="file"){e.logger.warn(`jsResource plugin cannot handle entry type ${t.entryType}. Modify the 'files' option in ${e.configFilePath} to only include files.`);return}if(t.eventType!=="add"){e.requestRestart();return}Fg(t.absolutePath).then(r=>{let n=(0,Hg.dirname)(t.urlPath);Hk(r.default)&&(e.resources.set(n,r.default),e.logger.debug(`Registered root resource: ${n}`)),kk(e,r,n)}).catch(r=>{e.logger.error(`Failed to load resource module ${t.absolutePath}: ${r}`),e.requestRestart()})})}function kk(e,t,r){for(let n in t){let s=t[n],i=(0,Hg.join)(r,n);Hk(s)?(e.resources.set(i,s),e.logger.debug(`Registered resource: ${i}`)):typeof s=="object"&&kk(e,s,i)}}var Hg,bie,Gk=fe(()=>{TN();Hg=require("path");o(Hk,"isResource");o(Aie,"handleApplication");o(kk,"recurseForResources");bie=!0});var AN={};Ce(AN,{start:()=>Iie});function Iie({resources:e}){e.set("login",yN),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var yN,qk=fe(()=>{Ia();o(Iie,"start");yN=class extends Dr{static{o(this,"Login")}static async get(t,r,n){}static async post(t,r,n){let{username:s,password:i,redirect:a}=r;return{data:await n.login(s,i)}}}});function Wk(e){let t={openapi:Nie,info:{title:"HarperDB HTTP REST interface",version:Yk.packageJson.version},paths:{},components:{schemas:{},securitySchemes:{basicAuth:{type:"http",scheme:"basic"},bearerAuth:{type:"http",scheme:"bearer",bearerFormat:"JWT"}}}},r=[{basicAuth:[],bearerAuth:[]}];for(let[,n]of e){if(!n.path||n.Resource.isError)continue;let{path:s}=n,i=s.split("/").slice(-1),{attributes:a,primaryKey:c,prototype:l}=n.Resource;if(c=c??"id",!c)continue;let u={},d=[];if(a)for(let{type:R,name:I,elements:P,relationship:Y,definition:te}of a){if(Y)R==="array"?u[I]={type:"array",items:{$ref:Ba+P.type}}:u[I]={$ref:Ba+R};else{let x=te??P?.definition;if(x){if(!t.components.schemas[x.type]){let $={};x.properties.forEach(j=>{$[j.name]=new wN(bN[j.type],j.type)}),t.components.schemas[x.type]=new Kk($)}R==="array"?u[I]={type:"array",items:{$ref:Ba+x.type}}:u[I]={$ref:Ba+x.type}}else R==="array"?P.type==="Any"||P.type=="ID"?u[I]={type:"array",items:{format:P.type}}:u[I]={type:"array",items:new wN(bN[P.type],P.type)}:R==="Any"||R=="ID"?u[I]={format:R}:u[I]=new wN(bN[R],R)}d.push(new ON(I,"query",u[I]))}let f=Object.keys(u),m=new ON(c,"path",{format:"ID"});m.required=!0,m.description="primary key of record";let h=new ON("property","path",{enum:f});h.required=!0,t.components.schemas[i]=new Kk(u);let p=l.post!==Resource.prototype.post||l.update,E=typeof l.put=="function",g=typeof l.get=="function",y=typeof l.delete=="function",T="/"+s+"/";p&&(t.paths[T]={},t.paths[T].post=new wie(i,r,"create a new record auto-assigning a primary key")),g&&(t.paths[T]||(t.paths[T]={}),t.paths[T].get=new IN(d,r,{200:new NN({$ref:Ba+i})},"search for records by the specified property name and value pairs")),y&&(t.paths[T]||(t.paths[T]={}),t.paths[T].delete=new Vk(d,r,"delete all the records that match the provided query",{204:new $k})),T="/"+s+"/{"+c+"}",g&&(t.paths[T]={},t.paths[T].get=new IN([m],r,{200:new NN({$ref:Ba+i})},"retrieve a record by its primary key")),E&&(t.paths[T]||(t.paths[T]={}),t.paths[T].put=new Oie([m],r,i,"create or update the record with the URL path that maps to the record's primary key")),y&&(t.paths[T]||(t.paths[T]={}),t.paths[T].delete=new Vk([m],r,"delete a record with the given primary key",{204:new $k})),g&&h.schema.enum.length>0&&(T="/"+s+"/{"+c+"}.{property}",t.paths[T]={},t.paths[T].get=new IN([m,h],r,{200:new NN({enum:f})},"used to retrieve the specified property of the specified record"))}return t}function wie(e,t,r){this.description=r,this.requestBody={content:{"application/json":{schema:{$ref:Ba+e}}}},this.security=t,this.responses={200:{description:CN,headers:{Location:{description:"primary key of new record",schema:{type:"string",format:"ID"}}},content:{"application/json":{schema:{type:"string",format:"ID"}}}}}}function IN(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.responses=r}function NN(e){this.description=CN,this.content={"application/json":{schema:e}}}function $k(){this.description="successfully processed request, no content returned to client"}function Oie(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.requestBody={content:{"application/json":{schema:{$ref:Ba+r}}}},this.responses={200:{description:CN}}}function Vk(e,t,r,n){this.description=r,this.parameters=e,this.security=t,this.responses=n}function Kk(e){this.type="object",this.properties=e}function wN(e,t){this.type=e,this.format=t}function ON(e,t,r){this.name=e,this.in=t,this.schema=r}var Yk,Nie,bN,Ba,CN,zk=fe(()=>{Yk=w(Rt()),Nie="3.0.3",bN={Int:"integer",Float:"number",Long:"integer",String:"string",Boolean:"boolean",Date:"string",Bytes:"string",BigInt:"integer",array:"array"},Ba="#/components/schemas/",CN="successful operation";o(Wk,"generateJsonApi");o(wie,"Post");o(IN,"Get");o(NN,"Response200");o($k,"Response204");o(Oie,"Put");o(Vk,"Delete");o(Kk,"ResourceSchema");o(wN,"Type");o(ON,"Parameter")});var Qk={};Ce(Qk,{Request:()=>Fa,createReuseportFd:()=>kg});var jk,Fa,PN,LN,kg,Eh=fe(()=>{jk=require("os"),Fa=class{static{o(this,"Request")}#e;constructor(t,r){this.method=t.method;let n=t.url;this._nodeRequest=t,this._nodeResponse=r,this.url=n,this.headers=new LN(t.headers)}get absoluteURL(){return this.protocol+"://"+this.host+this.url}get pathname(){let t=this.url.indexOf("?");return t>-1?this.url.slice(0,t):this.url}set pathname(t){let r=this.url.indexOf("?");r>-1?this.url=t+this.url.slice(r):this.url=t}get protocol(){return this._nodeRequest.socket.encrypted?"https":"http"}get ip(){return this._nodeRequest.socket.remoteAddress}get authorized(){return this._nodeRequest.socket.authorized}get peerCertificate(){return this._nodeRequest.socket.getPeerCertificate()}get mtlsConfig(){return this._nodeRequest.socket.server.mtlsConfig}get body(){return this.#e||(this.#e=new PN(this._nodeRequest))}get host(){return this._nodeRequest.authority||this._nodeRequest.headers.host}get httpVersion(){return this._nodeRequest.httpVersion}get isAborted(){return!1}sendEarlyHints(t,r={}){r.link=t,this._nodeResponse.writeEarlyHints(r)}},PN=class{static{o(this,"RequestBody")}#e;constructor(t){this.#e=t}on(t,r){return this.#e.on(t,r),this}pipe(t,r){return this.#e.pipe(t,r)}},LN=class{constructor(t){this.asObject=t}static{o(this,"Headers")}set(t,r){this.asObject[t.toLowerCase()]=r}get(t){return this.asObject[t.toLowerCase()]}has(t){return this.asObject.hasOwnProperty(t.toLowerCase())}[Symbol.iterator](){return Object.entries(this.asObject)[Symbol.iterator]()}keys(){return Object.keys(this.asObject)}values(){return Object.values(this.asObject)}delete(t){delete this.asObject[t.toLowerCase()]}forEach(t){for(let[r,n]of this)t(n,r,this)}};(0,jk.platform)()!="win32"&&(kg=require("node-unix-socket").createReuseportFd)});var qg={};Ce(qg,{parseHeaderValue:()=>MN,start:()=>Lie});async function Pie(e,t){let r=e.headers.asObject,n=r.accept==="text/event-stream",s=n?"CONNECT":e.method;e.search&&AE(e);let i=new ws;try{e.responseHeaders=i;let a=e.url.slice(1),c,l;if(a!==Jk){let g=Gg.getMatch(a,n?"sse":"rest");if(!g)return t(e);e.handlerPath=g.path,c=new Xs(g.relativeURL),c.async=!0,l=g.Resource}if(l?.isCaching){let g=r["cache-control"];if(g){let y=MN(g);for(let T of y)switch(T.name){case"max-age":e.expiresAt=T.value*1e3+Date.now();break;case"only-if-cached":e.onlyIfCached=!0;break;case"no-cache":e.noCache=!0;break;case"no-store":e.noCacheStore=!0;break;case"stale-if-error":e.staleIfError=!0;break;case"must-revalidate":e.mustRevalidate=!0;break}}}let u=r["x-replicate-to"];if(u){let g=MN(u).map(y=>(y.next?.name==="confirm"&&y.next.value>=0&&(e.replicatedConfirmation=+y.next.value),y.name));e.replicateTo=g.length===1&&+g[0]>=0?+g[0]:g[0]==="*"?void 0:g}r["x-replicate-from"]==="none"&&(e.replicateFrom=!1);let f=await vt(e,()=>{if(r["content-length"]||r["transfer-encoding"])try{e.data=_o(r["content-type"],!0)(e.body,e.headers)}catch(g){throw new sd.ClientError(g,400)}if(e.authorize=!0,a===Jk&&s==="GET"){if(e?.user?.role?.permission?.super_user)return Wk(Gg);throw new sd.ServerError("Forbidden",403)}switch(c.checkPermission=e.user?.role?.permission??{},s){case"GET":case"HEAD":return l.get(c,e);case"POST":return l.post(c,e.data,e);case"PUT":return l.put(c,e.data,e);case"DELETE":return l.delete(c,e);case"PATCH":return l.patch(c,e.data,e);case"OPTIONS":i.setIfNone("Allow","GET, HEAD, POST, PUT, DELETE, PATCH, OPTIONS, TRACE, QUERY, COPY, MOVE");return;case"CONNECT":return l.connect(c,null,e);case"TRACE":return"HarperDB is the terminating server";case"QUERY":return l.query(c,e.data,e);case"COPY":return l.copy(c,r.destination,e);case"MOVE":return l.move(c,r.destination,e);case"BREW":throw new sd.ClientError("HarperDB is short and stout and can't brew coffee",418);default:throw new sd.ServerError(`Method ${s} is not recognized`,501)}}),m=200,h;if(f==null)m=s==="GET"||s==="HEAD"?404:204,DN.lastModified&&e.lastModified&&i.setIfNone("Last-Modified",new Date(e.lastModified).toUTCString());else if(f.status>0&&f.headers){let g=HH(f.headers,i);return f.headers!==g&&(f.headers=g),f.data!==void 0&&(f.body=nm(f.data,e,f)),f}else if(h=e.lastModified){Cie[0]=h;let g=String.fromCharCode(34,(Yr[0]&63)+62,(Yr[0]>>6)+(Yr[1]<<2&63)+62,(Yr[1]>>4)+(Yr[2]<<4&63)+62,(Yr[2]>>2)+62,(Yr[3]&63)+62,(Yr[3]>>6)+(Yr[4]<<2&63)+62,(Yr[4]>>4)+(Yr[5]<<4&63)+62,(Yr[5]>>2)+62,(Yr[6]&63)+62,(Yr[6]>>6)+(Yr[7]<<2&63)+62,34),y=r["if-none-match"];y&&g==y?(f?.onDone&&f.onDone(),m=304,f=void 0):i.setIfNone("ETag",g),DN.lastModified&&i.setIfNone("Last-Modified",new Date(h).toUTCString())}e.createdResource&&(m=201),e.newLocation&&i.setIfNone("Location",e.newLocation);let p={status:m,headers:i,body:void 0},E=e.loadedFromSource??f?.wasLoadedFromSource?.();return E!==void 0&&(p.wasCacheMiss=E,!E&&h&&i.setIfNone("Age",Math.round((Date.now()-(e.lastRefreshed||h))/1e3))),f!==void 0&&(p.body=nm(f,e,p),s==="HEAD"&&(p.body=void 0)),p}catch(a){a.statusCode?a.statusCode===500?ai.warn(a):ai.info(a):ai.error(a),a.statusCode===405&&(a.method&&(a.message+=` to handle HTTP method ${a.method.toUpperCase()||""}`),a.allow&&(a.allow.push("trace","head","options"),i.setIfNone("Allow",a.allow.map(l=>l.toUpperCase()).join(", "))));let c={status:a.statusCode||500,headers:i,body:void 0};return c.body=nm(a.contentType?a:eG(a),e,c),c}}function Lie(e){DN=e,!Xk&&(Xk=!0,e.includeExpensiveRecordCountEstimates&&(Fa.prototype.includeExpensiveRecordCountEstimates=!0),Gg=e.resources,e.server.http(async(t,r)=>{if(!t.isWebSocket)return Pie(t,r)},e),e.webSocket!==!1&&e.server.ws(async(t,r,n)=>{gh++;let s=new $n;Zk||(Zk=!0,rh(l=>{gh>0&&l.push({metric:"ws-connections",connections:gh,byThread:!0})}));let i;t.on("error",l=>{i=!0,ai.warn(l)});let a;t.on("message",o(function(u){a||(a=_o(r.requestedContentType??r.headers.asObject["content-type"],!1));let d=a(u);gt(u.length,"bytes-received",r.handlerPath,"message","ws"),s.push(d)},"message"));let c;t.on("close",()=>{gh--,Kr(!i,"connection","ws","disconnect"),s.emit("close"),c&&c.return()});try{await n;let l=r.url.slice(1),u=Gg.getMatch(l,"ws");if(Kr(!!u,"connection","ws","connect"),u){r.handlerPath=u.path,gt(p=>({count:p.count,total:gh}),"connections",r.handlerPath,"connect","ws"),r.authorize=!0;let d=new Xs(u.relativeURL);d.checkPermission=r.user?.role?.permission??{};let f=u.Resource;c=(await vt(r,()=>f.connect(d,s,r)))[Symbol.asyncIterator]();let h;for(;!(h=await c.next()).done;){let p=await Sa(h.value,r);t.send(p),gt(p.length,"bytes-sent",r.handlerPath,"message","ws"),t._socket.writableNeedDrain&&await new Promise(E=>t._socket.once("drain",E))}}else return t.close(1011,`No resource was found to handle ${r.pathname}`)}catch(l){l.statusCode?l.statusCode===500?ai.warn(l):ai.info(l):ai.error(l),t.close(Die[l.statusCode]||1011,eG(l))}t.close()},e))}function MN(e){return e.trim().split(",").map(t=>{let r,n=t.trim().split(";"),s;for(;s=n.pop();)if(s.includes("=")){let[i,a]=s.trim().split("=");i=i.trim(),a&&(a=a.trim()),r={name:i.toLowerCase(),value:a,next:r}}else r={name:s.toLowerCase(),next:r};return r})}var ai,sd,eG,Yr,Cie,DN,Jk,Xk,Gg,Zk,gh,Die,tG=fe(()=>{Eo();ki();ai=w(z()),sd=w(_e());bE();_u();xc();sh();zk();Eh();IE();({errorToString:eG}=ai),Yr=new Uint8Array(8),Cie=new Float64Array(Yr.buffer,0,1),DN={},Jk="openapi";o(Pie,"http");gh=0;o(Lie,"start");Die={401:3e3,403:3003};o(MN,"parseHeaderValue")});var vN=M((pDe,nG)=>{var{recordAction:$g,recordActionBinary:rG}=(ki(),v(Rg)),Mie=require("fastify-plugin"),vie=200;nG.exports=Mie(function(e,t,r){e.addHook("onResponse",async(n,s)=>{let i=s.elapsedTime}),e.addHook("onSend",async(n,s,i)=>{let a=s.elapsedTime,c=performance.now(),l=s.request.routeOptions,u,d,f;l.config?.isOperation?(u=n.body?.operation,d="operation"):(u=l.url,d="fastify-route",f=l.method),$g(a,"duration",u,f,d),rG(s.raw.statusCode<400,"success",u,f,d),rG(1,"response_"+s.raw.statusCode,u,f,d);let m=vie;i?.pipe?(i.on("data",g=>{m+=g.length}),i.on("end",()=>{$g(performance.now()-c,"transfer",u,f,d),$g(m,"bytes-sent",u,f,d)})):(m+=i?.length||0,$g(m,"bytes-sent",u,f,d));let h=a.toFixed(3),p=s.getHeader("Server-Timing"),E=`db;dur=${h}`;s.header("Server-Timing",p?`${p}, ${E}`:E)}),r()},{name:"hdb-request-time"})});var iG=M((_De,sG)=>{var Uie=at(),xie={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};sG.exports=function(e){return Uie.validateObject(e,xie)}});var Vg=M((EDe,oG)=>{"use strict";var Bie=(k(),v(K)).OPERATIONS_ENUM,UN=class{static{o(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=Bie.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};oG.exports=UN});var Rh={};Ce(Rh,{createTokens:()=>FN,getJWTRSAKeys:()=>jg,refreshOperationToken:()=>HN,validateOperationToken:()=>kN,validateRefreshToken:()=>Qg});async function jg(){if(Kg)return Kg;try{let e=Sh.default.join(Th.default.getHdbBasePath(),My),t=await Yg.default.readFile(Sh.default.join(e,xf.JWT_PASSPHRASE_NAME),"utf8"),r=await Yg.default.readFile(Sh.default.join(e,xf.JWT_PRIVATE_KEY_NAME),"utf8");return Kg={publicKey:await Yg.default.readFile(Sh.default.join(e,xf.JWT_PUBLIC_KEY_NAME),"utf8"),privateKey:r,passphrase:t},Kg}catch(e){throw zg.default.error(e),new ci.ClientError(od.NO_ENCRYPTION_KEYS,id.INTERNAL_SERVER_ERROR)}}async function FN(e){let t=(0,xN.validateBySchema)(e,$i.default.object({username:$i.default.string().optional(),password:$i.default.string().optional(),role:$i.default.string().optional(),expires_in:$i.default.alternatives($i.default.string(),$i.default.number()).optional()}));if(t)throw new ci.ClientError(t.message);let r;try{let f=e.bypass_auth!==!0;!e.username&&!e.password&&(e.username=e.hdb_user?.username,f=!1),r=await(0,BN.findAndValidateUser)(e.username,e.password,f)}catch(f){throw zg.default.error(f),new ci.ClientError(od.INVALID_CREDENTIALS,id.UNAUTHORIZED)}if(!r)throw new ci.ClientError(od.INVALID_CREDENTIALS,id.UNAUTHORIZED);let n=!1,s=!1;r.role?.permission&&(n=r.role.permission.super_user===!0,s=r.role.permission.cluster_user===!0);let i={username:e.username,super_user:n,cluster_user:s};e.role&&(i.role=e.role);let a=await jg(),c=await ad.default.sign(i,{key:a.privateKey,passphrase:a.passphrase},{expiresIn:e.expires_in??dG,algorithm:Wg,subject:cd.OPERATION}),l=await ad.default.sign(i,{key:a.privateKey,passphrase:a.passphrase},{expiresIn:Fie,algorithm:Wg,subject:cd.REFRESH}),u=DI(l,Mr.SHA256);if((await(0,aG.update)(new cG.default(Uf,du.USER_TABLE_NAME,[{username:e.username,refresh_token:u}]))).skipped_hashes.length>0)throw new ci.ClientError(od.REFRESH_TOKEN_SAVE_FAILED,id.INTERNAL_SERVER_ERROR);return lG.default.signalUserChange(new uG.UserEventMsg(process.pid)),{operation_token:c,refresh_token:l}}async function HN(e){let t=(0,xN.validateBySchema)(e,$i.default.object({refresh_token:$i.default.string().required()}).required());if(t)throw new ci.ClientError(t.message);let{refresh_token:r}=e;await Qg(r);let n=await jg(),s=await ad.default.decode(r);return{operation_token:await ad.default.sign({username:s.username,super_user:s.super_user,cluster_user:s.cluster_user},{key:n.privateKey,passphrase:n.passphrase},{expiresIn:dG,algorithm:Wg,subject:cd.OPERATION})}}async function kN(e){return fG(e,cd.OPERATION)}async function Qg(e){return fG(e,cd.REFRESH)}async function fG(e,t){try{let r=await jg(),n=await ad.default.verify(e,r.publicKey,{algorithms:Wg,subject:t});if(n.role)throw new Error("Invalid token");let s=await(0,BN.findAndValidateUser)(n.username,void 0,!1);if(t===cd.REFRESH&&!MI(s.refresh_token,e))throw new Error("Invalid token");return s}catch(r){throw zg.default.warn(r),r?.name==="TokenExpiredError"?new ci.ClientError(od.TOKEN_EXPIRED,id.FORBIDDEN):new ci.ClientError(od.INVALID_TOKEN,id.UNAUTHORIZED)}}var ad,Yg,Sh,$i,xN,ci,zg,BN,aG,cG,lG,uG,Th,id,od,dG,Fie,Wg,cd,Kg,ld=fe(()=>{ad=w(require("jsonwebtoken")),Yg=w(require("fs-extra")),Sh=w(require("node:path")),$i=w(require("joi")),xN=w(at());k();ci=w(_e()),zg=w(z());dg();BN=w(Jn()),aG=w(Mn()),cG=w(Vg()),lG=w(No()),uG=w(ti()),Th=w(ce()),{HTTP_STATUS_CODES:id,AUTHENTICATION_ERROR_MSGS:od}=ci.hdbErrors;Th.default.initSync();dG=Th.default.get(U.AUTHENTICATION_OPERATIONTOKENTIMEOUT)||"1d",Fie=Th.default.get(U.AUTHENTICATION_REFRESHTOKENTIMEOUT)||"30d",Wg="RS256",cd={OPERATION:"operation",REFRESH:"refresh"};o(jg,"getJWTRSAKeys");o(FN,"createTokens");o(HN,"refreshOperationToken");o(kN,"validateOperationToken");o(Qg,"validateRefreshToken");o(fG,"validateToken")});var GN=M((yDe,pG)=>{"use strict";var Hie=iG(),ud=require("passport"),kie=require("passport-local").Strategy,Gie=require("passport-http").BasicStrategy,qie=require("util"),$ie=Jn(),hG=qie.callbackify($ie.findAndValidateUser),RDe=tn(),Vie=(k(),v(K)),mG=(ld(),v(Rh));ud.use(new kie(function(e,t,r){hG(e,t,r)}));ud.use(new Gie(function(e,t,r){hG(e,t,r)}));ud.serializeUser(function(e,t){t(null,e)});ud.deserializeUser(function(e,t){t(null,e)});function Kie(e,t,r){if(e.raw?.user!==void 0)return r(null,e.raw.user);let n,s;if(e.headers?.authorization){let a=e.headers.authorization.split(" ");n=a[0],s=a[1]}function i(a,c){return a?r(a):c?r(null,c):r("Must login")}switch(o(i,"handleResponse"),n){case"Basic":ud.authenticate("basic",{session:!1},(a,c)=>{i(a,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===Vie.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?mG.validateRefreshToken(s).then(a=>{e.body.refresh_token=s,r(null,a)}).catch(a=>{r(a)}):mG.validateOperationToken(s).then(a=>{r(null,a)}).catch(a=>{r(a)});break;default:ud.authenticate("local",{session:!1},function(a,c){i(a,c)})(e,t,r);break}}o(Kie,"authorize");function Yie(e,t){let r=Hie(e);if(r){t(r);return}let n={authorized:!0,messages:[]},s=e.user.role;if(!s?.permission)return t("Invalid role");let i=JSON.parse(s.permission);if(i.super_user)return t(null,n);if(!i[e.schema])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.schema} schema`),t(null,n);if(!i[e.schema].tables[e.table])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.table} table`),t(null,n);if(!i[e.schema].tables[e.table][e.operation])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.operation} on ${e.table} table`),t(null,n);if(i[e.schema].tables[e.table].attribute_permissions&&!e.attributes)return n.authorized=!1,n.messages.push(`${e.schema}.${e.table} has attribute permissions. Missing attributes to validate`),t(null,n);if(i[e.schema].tables[e.table].attribute_permissions&&e.attributes){let a=i[e.schema].tables[e.table].attribute_permissions;for(let c in a)e.attributes.indexOf(a[c].attribute_name)>-1&&!a[c][e.operation]&&(n.authorized=!1,n.messages.push(`Not authorized to ${e.operation} ${a[c].attribute_name} `))}return t(null,n)}o(Yie,"checkPermissions");pG.exports={authorize:Kie,checkPermissions:Yie}});var Jg=M((bDe,_G)=>{"use strict";var Wie=jn();_G.exports={writeTransaction:zie};function zie(e,t,r){return Wie.writeTransaction(e,t,r)}o(zie,"writeTransaction")});var TG=M((wDe,SG)=>{"use strict";var jie=on(),Qie=Ns(),EG=z(),Jie=Mn(),NDe=Jg(),Xie=require("clone"),$N=require("alasql"),Zie=eg(),gG=require("util"),eoe=gG.promisify(Qie.getTableSchema),toe=gG.promisify(jie.search),roe=(k(),v(K)),qN=ie();Zie($N);SG.exports={update:soe};var noe="There was a problem performing this update. Please check the logs and try again.";async function soe({statement:e,hdb_user:t}){let r=await eoe(e.table.databaseid,e.table.tableid),n=ioe(e.columns);qN.backtickASTSchemaItems(e);let{table:s,where:i}=e,a=Xie(s),c=qN.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,u=$N.parse(l).statements[0],d=await toe(u),f=ooe(n,d);return aoe(a,f,t)}o(soe,"update");function ioe(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=$N.compile(`SELECT ${r.expression.toString()} AS [${roe.FUNC_VAL}] FROM ?`)}),t}catch(t){throw EG.error(t),new Error(noe)}}o(ioe,"createUpdateRecord");function ooe(e,t){return qN.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}o(ooe,"buildUpdateRecords");async function aoe(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await Jie.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){EG.error(`Error delete new_attributes from update response: ${i}`)}return s}o(aoe,"updateRecords")});var yG=M((LDe,RG)=>{var coe=require("alasql"),loe=on(),uoe=z(),doe=jn(),KN=require("util"),VN=ie(),foe=(k(),v(K)),moe=Ns(),CDe=Jg(),PDe=Mn(),hoe="record",poe="successfully deleted",_oe=KN.callbackify(Toe),Eoe=KN.promisify(loe.search),goe=KN.promisify(moe.getTableSchema);RG.exports={convertDelete:_oe};function Soe(e){return`${e.deleted_hashes.length} ${hoe}${e.deleted_hashes.length===1?"":"s"} ${poe}`}o(Soe,"generateReturnMessage");async function Toe({statement:e,hdb_user:t}){let r=await goe(e.table.databaseid,e.table.tableid);VN.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=VN.isEmpty(s)?"":` WHERE ${s.toString()}`,a=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=coe.parse(a).statements[0],l={operation:foe.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await Eoe(c);let u=await doe.deleteRecords(l);return VN.isEmptyOrZeroLength(u.message)&&(u.message=Soe(u)),delete u.txn_time,u}catch(u){throw uoe.error(u),u.hdb_code?u.message:u}}o(Toe,"convertDelete")});var wG=M((MDe,NG)=>{"use strict";var Roe=La(),{hdbErrors:AG}=_e(),{getDatabases:bG}=(Le(),v(ft));NG.exports={checkSchemaExists:IG,checkSchemaTableExists:yoe,schemaDescribe:Roe};async function IG(e){if(!bG()[e])return AG.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}o(IG,"checkSchemaExists");async function yoe(e,t){let r=await IG(e);if(r)return r;if(!bG()[e][t])return AG.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}o(yoe,"checkSchemaTableExists")});var QN=M((FDe,HG)=>{"use strict";var{decode:Aoe}=require("msgpackr"),{isMainThread:UDe,parentPort:xDe,threadId:BDe}=require("worker_threads"),eS=lr(),dd=It(),zN=(k(),v(K)),ln=z(),WN=ce(),boe=(k(),v(K)),{onMessageByType:Ioe}=st(),LG=Bi(),{recordAction:OG,recordActionBinary:Noe}=(ki(),v(Rg)),{publishToStream:woe}=eS,{ConsumerEvents:CG}=require("nats"),Ooe=on(),{promisify:Coe}=require("util"),{decodeBlobsWithWrites:Poe}=(Ts(),v(TA)),DG=Coe(setTimeout),tS=1e4,rS,Zg,Loe,Doe,MG,yh=new Map,fd=new Map;HG.exports={initialize:vG,ingestConsumer:jN,setSubscription:Moe,setIgnoreOrigin:xoe,getDatabaseSubscriptions:Uoe,updateConsumer:UG};async function vG(){Ioe(zN.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,async n=>{await UG(n)}),MG=!0,ln.notify("Initializing clustering ingest service.");let{connection:e,jsm:t,js:r}=await eS.getNATSReferences();rS=e,Zg=e.info.server_name,Loe=t,Doe=r}o(vG,"initialize");async function UG(e){if(e.status==="start"){let{js:t,jsm:r}=await xG(e.node_domain_name);jN(e.stream_name,t,r,e.node_domain_name)}else if(e.status==="stop"){let t=yh.get(e.stream_name+e.node_domain_name);t&&(ln.notify("Closing ingest consumer for node:",e.node_domain_name,"stream:",e.stream_name),await t.close?.(),yh.set(e.stream_name+e.node_domain_name,"close")),fd.get(e.node_domain_name)==="failed"&&fd.set(e.node_domain_name,"close")}}o(UG,"updateConsumer");var nS=new Map;function Moe(e,t,r){let n=nS.get(e);n||nS.set(e,n=new Map),n.set(t,r),MG||vG().then(voe)}o(Moe,"setSubscription");async function voe(){let e=await Ooe.searchByValue({database:"system",table:"hdb_nodes",search_attribute:"name",search_value:"*"});for await(let t of e){let r=t.name+dd.SERVER_SUFFIX.LEAF,n,s;for(let i of t.subscriptions||[])if(i.subscribe===!0){if(!n&&({js:n,jsm:s}=await xG(r),!n))break;let{schema:a,table:c}=i,l=LG.createNatsTableStreamName(a,c);jN(l,n,s,r)}}}o(voe,"accessConsumers");async function xG(e){let t,r,n=1;for(;!r;)try{t=await rS.jetstream({domain:e}),r=await rS.jetstreamManager({domain:e,checkAPI:!1})}catch(s){if(fd.get(e)==="close")break;fd.set(e,"failed"),n%10===1&&ln.warn("Nats ingest attempting to connect to:",e,"Nats error:",s.message);let i=n++*100<tS?n++*100:tS;await DG(i)}return{js:t,jsm:r}}o(xG,"connectToRemoteJS");function Uoe(){return nS}o(Uoe,"getDatabaseSubscriptions");var BG;function xoe(e){BG=e}o(xoe,"setIgnoreOrigin");var FG=100,PG=new Array(FG),Xg=0;async function jN(e,t,r,n){let{connection:s}=await eS.getNATSReferences();rS=s,Zg=s.info.server_name;let i,a=1;for(;!i;)try{i=await t.consumers.get(e,Zg),ln.notify("Initializing ingest consumer for node:",n,"stream:",e)}catch(u){if(fd.get(n)==="close")break;a%10===1&&ln.warn("Nats ingest error getting consumer:",n,"stream:",e,"Nats error:",u.message),u.code==="404"&&(ln.notify("Nats ingest creating consumer for node:",n,"stream:",e),i=await eS.createConsumer(r,e,Zg,new Date(Date.now()).toISOString()));let d=a++*100<tS?a++*100:tS;await DG(d)}let c=!1,l;for(;!c;){if(yh.get(e+n)==="close"||fd.get(n)==="close"){yh.delete(e+n),c=!0;continue}l=await i.consume({max_messages:WN.get(zN.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS)??100,bind:!0}),yh.set(e+n,l);let u=!1;(async()=>{for await(let d of await l.status())if(d.type===CG.ConsumerDeleted&&(await l.close(),c=!0),d.type===CG.HeartbeatsMissed){let f=d.data;ln.trace(`${f} clustering ingest consumer heartbeats missed, node: ${n} stream: ${l.consumer.stream}`),f===100&&(ln.warn(`Restarting clustering ingest consumer due to missed heartbeat threshold being met, node: ${n} stream: ${l.consumer.stream}`),l.stop(),u=!0)}})();try{for await(let d of l)await PG[Xg],PG[Xg]=Boe(d).catch(f=>{ln.error(f)}),++Xg>=FG&&(Xg=0)}catch(d){d.message==="consumer deleted"?(ln.notify("Nats consumer deleted, closing messages for node:",n,"stream:",l.consumer.stream),await l.close(),c=!0):ln.error("Error consuming clustering ingest, restarting consumer",d)}}}o(jN,"ingestConsumer");async function Boe(e){let t;await Poe(()=>{t=Aoe(e.data)}),OG(e.data.length,"bytes-received",e.subject,t.operation,"ingest"),ln.trace("Nats message processor message size:",e?.msg?._msg?.size,"bytes");let r=e.headers,n=!1,s=WN.get(zN.CONFIG_PARAMS.CLUSTERING_NODENAME);r.has(dd.MSG_HEADERS.TRANSACTED_NODES)&&r.values(dd.MSG_HEADERS.TRANSACTED_NODES).indexOf(s)>-1&&(n=!0);let i=r.get(dd.MSG_HEADERS.ORIGIN);if(n||(n=i===s&&!BG),Noe(n,"echo",e.subject,t.operation,"ingest"),n){e.ack();return}r.append(dd.MSG_HEADERS.TRANSACTED_NODES,s);try{let{operation:a,schema:c,next:l,table:u,records:d,hash_values:f,__origin:m,expiresAt:h}=t;ln.trace("processing message:",a,c,u,(d?"records: "+d.map(P=>P?.id):"")+(f?"ids: "+f:""),"with sequence:",e.seq),ln.trace(`messageProcessor nats msg id: ${e.headers.get(dd.MSG_HEADERS.NATS_MSG_ID)}`);let p;d||(d=f);let E=new Promise(P=>p=P),{timestamp:g,user:y,node_name:T}=m||{},R=nS.get(c)?.get(u);if(!R)throw new Error(`Missing table for replication message: ${u}`);if(a==="define_schema")t.type=a,t.onCommit=p,R.send(t);else if(d.length===1&&!l)R.send({type:YN(a),value:d[0],id:f?.[0],expiresAt:h,timestamp:g,table:u,onCommit:p,user:y,nodeName:T});else{let P=d.map((Y,te)=>({type:YN(a),value:Y,expiresAt:h,id:f?.[te],table:u}));for(;l;)P.push({type:YN(l.operation),value:l.record,expiresAt:l.expiresAt,id:l.id,table:l.table}),l=l.next;R.send({type:"transaction",writes:P,table:u,timestamp:g,onCommit:p,user:y,nodeName:T})}WN.get(boe.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&woe(e.subject.split(".").slice(0,-1).join("."),LG.createNatsTableStreamName(c,u),e.headers,e.data),await E;let I=Date.now()-g;g&&OG(I,"replication-latency",e.subject,a,"ingest")}catch(a){ln.error(a)}e.ack()}o(Boe,"messageProcessor");function YN(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}o(YN,"convertOperation")});var lr=M((KDe,rq)=>{"use strict";var xr=ce();xr.initSync();var Foe=require("fs-extra"),Hoe=require("semver"),Ih=require("path"),{monotonicFactory:koe}=require("ulidx"),GG=koe(),Goe=require("util"),qG=require("child_process"),qoe=Goe.promisify(qG.exec),$oe=qG.spawn,Wr=It(),Qe=(k(),v(K)),{packageJson:Voe,PACKAGE_ROOT:Koe}=Rt(),sS=ie(),li=z(),iS=Bi(),Yoe=Jg(),Ah=yt(),{broadcast:Woe,onMessageByType:zoe,getWorkerIndex:joe}=st(),{isMainThread:$G}=require("worker_threads"),{Encoder:Qoe,decode:ew}=require("msgpackr"),VG=new Qoe,{isEmpty:bl}=sS,KG=Jn(),kDe=48*36e11;$G&&zoe(Qe.ITC_EVENT_TYPES.RESTART,()=>{un=void 0,Al=void 0});var{connect:Joe,StorageType:Xoe,RetentionPolicy:Zoe,AckPolicy:tw,DeliverPolicy:rw,DiscardPolicy:eae,NatsConnection:GDe,JetStreamManager:qDe,JetStreamClient:$De,StringCodec:VDe,JSONCodec:tae,createInbox:nw,headers:rae,ErrorCode:kG}=require("nats"),{recordAction:nae}=(ki(),v(Rg)),{encodeBlobsAsBuffers:sae}=(Ts(),v(TA)),YG=tae(),iae="clustering",oae=Voe.engines[Wr.NATS_SERVER_NAME],aae=Ih.join(Koe,"dependencies"),ZN=Ih.join(aae,`${process.platform}-${process.arch}`,Wr.NATS_BINARY_NAME),JN,XN,bh,Rl,yl;rq.exports={runCommand:WG,checkNATSServerInstalled:cae,createConnection:sw,getConnection:Nh,getJetStreamManager:wh,getJetStream:jG,getNATSReferences:Vi,getServerList:uae,createLocalStream:iw,listStreams:QG,deleteLocalStream:dae,getServerConfig:md,listRemoteStreams:fae,viewStream:mae,viewStreamIterator:hae,publishToStream:pae,request:gae,reloadNATS:ow,reloadNATSHub:Sae,reloadNATSLeaf:Tae,extractServerName:Eae,requestErrorHandler:Rae,createLocalTableStream:eq,createTableStreams:bae,purgeTableStream:tq,purgeSchemaTableStreams:Iae,getStreamInfo:Nae,updateLocalStreams:Oae,closeConnection:lae,getJsmServerName:oS,addNatsMsgHeader:JG,clearClientCache:zG,updateRemoteConsumer:yae,createConsumer:XG,updateConsumerIterator:Aae};async function WG(e,t=void 0){let{stdout:r,stderr:n}=await qoe(e,{cwd:t});if(n)throw new Error(n.replace(`
|
|
15
15
|
`,""));return r.replace(`
|
|
16
16
|
`,"")}o(WG,"runCommand");async function cae(){try{await Foe.access(ZN)}catch{return!1}let e=await WG(`${ZN} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return Hoe.eq(t,oae)}o(cae,"checkNATSServerInstalled");async function sw(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let a=await KG.getClusterUser();if(bl(a))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=a.username,r=a.decrypt_hash}li.trace("create nats connection called");let i=await Joe({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:xr.get(Qe.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:xr.get(Qe.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:xr.get(Qe.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),li.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(a=>{a&&li.error("Error with Nats client connection, connection closed",a),i===un&&zG()}),i}o(sw,"createConnection");function zG(){un=void 0,Rl=void 0,yl=void 0,Al=void 0}o(zG,"clearClientCache");async function lae(){un&&(await un.drain(),un=void 0,Rl=void 0,yl=void 0,Al=void 0)}o(lae,"closeConnection");var un,Al;async function Nh(){return Al||(Al=sw(xr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),un=await Al),un||Al}o(Nh,"getConnection");async function wh(){if(Rl)return Rl;bl(un)&&await Nh();let{domain:e}=md(Qe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(bl(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return Rl=await un.jetstreamManager({domain:e,timeout:6e4}),Rl}o(wh,"getJetStreamManager");async function jG(){if(yl)return yl;bl(un)&&await Nh();let{domain:e}=md(Qe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(bl(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return yl=un.jetstream({domain:e,timeout:6e4}),yl}o(jG,"getJetStream");async function Vi(){let e=un||await Nh(),t=Rl||await wh(),r=yl||await jG();return{connection:e,jsm:t,js:r}}o(Vi,"getNATSReferences");async function uae(e){let t=xr.get(Qe.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await KG.getClusterUser(),s=await sw(t,r,n),i=nw(),a=s.subscribe(i),c=[],l,u=(async()=>{for await(let d of a){let f=YG.decode(d.data);f.response_time=Date.now()-l,c.push(f)}})();return l=Date.now(),await s.publish("$SYS.REQ.SERVER.PING.VARZ",void 0,{reply:i}),await s.publish("$SYS.REQ.SERVER.PING",void 0,{reply:i}),await s.flush(),await sS.asyncSetTimeout(e),await a.drain(),await s.close(),await u,c}o(uae,"getServerList");async function iw(e,t){let{jsm:r}=await Vi(),n=xr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=xr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=xr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:Xoe.File,retention:Zoe.Limits,subjects:t,discard:eae.Old,maxMsgs:s,maxBytes:i,maxAge:n})}o(iw,"createLocalStream");async function QG(){let{jsm:e}=await Vi(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}o(QG,"listStreams");async function dae(e){let{jsm:t}=await Vi();await t.streams.delete(e)}o(dae,"deleteLocalStream");async function fae(e){let{connection:t}=await Vi(),r=[],n=nw(),s=t.subscribe(n),i=(async()=>{for await(let a of s)r.push(YG.decode(a.data))})();return await t.publish(`$JS.${e}.API.STREAM.LIST`,void 0,{reply:n}),await t.flush(),await s.drain(),await i,r}o(fae,"listRemoteStreams");async function mae(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Vi(),i=GG(),a={durable_name:i,ack_policy:tw.Explicit};t&&(a.deliver_policy=rw.StartTime,a.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,a);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];let u=[];for await(let d of l){let f=ew(d.data),m={nats_timestamp:d.info.timestampNanos,nats_sequence:d.info.streamSequence,entry:f};if(d.headers&&(m.origin=d.headers.get(Wr.MSG_HEADERS.ORIGIN)),u.push(m),d.ack(),d.info.pending===0)break}return await c.delete(),u}o(mae,"viewStream");async function*hae(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Vi(),i=GG(),a={durable_name:i,ack_policy:tw.Explicit};t&&(a.deliver_policy=rw.StartTime,a.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,a);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];for await(let u of l){let d=ew(u.data);d[0]||(d=[d]);for(let f of d){let m={nats_timestamp:u.info.timestampNanos,nats_sequence:u.info.streamSequence,entry:f};u.headers&&(m.origin=u.headers.get(Wr.MSG_HEADERS.ORIGIN)),yield m}if(u.ack(),u.info.pending===0)break}await c.delete()}o(hae,"viewStreamIterator");async function pae(e,t,r,n){li.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=JG(n,r);let{js:s}=await Vi(),i=await oS(),a=`${e}.${i}`,c=await sae(()=>n instanceof Uint8Array?n:VG.encode(n));try{li.trace(`publishToStream publishing to subject: ${a}`),nae(c.length,"bytes-sent",e,n.operation,"replication"),await s.publish(a,c,{headers:r})}catch(l){if(l.code&&l.code.toString()==="503")return ZG(async()=>{try{await s.publish(a,c,{headers:r})}catch{if(l.code&&l.code.toString()==="503"){li.trace(`publishToStream creating stream: ${t}`);let d=a.split(".");d[2]="*",await iw(t,[a]),await s.publish(a,c,{headers:r})}else throw l}});throw l}}o(pae,"publishToStream");function JG(e,t){t===void 0&&(t=rae());let r=xr.get(Qe.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(Wr.MSG_HEADERS.ORIGIN)&&r&&t.append(Wr.MSG_HEADERS.ORIGIN,r),t}o(JG,"addNatsMsgHeader");function md(e){e=e.toLowerCase();let t=Ih.join(xr.get(Qe.CONFIG_PARAMS.ROOTPATH),iae);if(e===Qe.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return bl(XN)&&(XN={port:Ah.getConfigFromFile(Qe.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:Ah.getConfigFromFile(Qe.CONFIG_PARAMS.CLUSTERING_NODENAME)+Wr.SERVER_SUFFIX.HUB,config_file:Wr.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:Ih.join(t,Wr.PID_FILES.HUB),hdbNatsPath:t}),XN;if(e===Qe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return bl(JN)&&(JN={port:Ah.getConfigFromFile(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:Ah.getConfigFromFile(Qe.CONFIG_PARAMS.CLUSTERING_NODENAME)+Wr.SERVER_SUFFIX.LEAF,config_file:Wr.NATS_CONFIG_FILES.LEAF_SERVER,domain:Ah.getConfigFromFile(Qe.CONFIG_PARAMS.CLUSTERING_NODENAME)+Wr.SERVER_SUFFIX.LEAF,pid_file_path:Ih.join(t,Wr.PID_FILES.LEAF),hdbNatsPath:t}),JN;li.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}o(md,"getServerConfig");async function XG(e,t,r,n){try{await e.consumers.add(t,{ack_policy:tw.Explicit,durable_name:r,deliver_policy:rw.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}o(XG,"createConsumer");async function _ae(e,t,r){await e.consumers.delete(t,r)}o(_ae,"removeConsumer");function Eae(e){return e.split(".")[1]}o(Eae,"extractServerName");async function gae(e,t,r=6e4,n=nw()){if(!sS.isObject(t))throw new Error("data param must be an object");let s=VG.encode(t),{connection:i}=await Vi(),a={timeout:r};n&&(a.reply=n,a.noMux=!0);let c=await i.request(e,s,a);return ew(c.data)}o(gae,"request");function ow(e){return new Promise(async(t,r)=>{let n=$oe(ZN,["--signal",`reload=${e}`],{cwd:__dirname}),s,i;n.on("error",a=>{r(a)}),n.stdout.on("data",a=>{i+=a.toString()}),n.stderr.on("data",a=>{s+=a.toString()}),n.stderr.on("close",a=>{s&&r(s),t(i)})})}o(ow,"reloadNATS");async function Sae(){let{pid_file_path:e}=md(Qe.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await ow(e)}o(Sae,"reloadNATSHub");async function Tae(){let{pid_file_path:e}=md(Qe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await ow(e)}o(Tae,"reloadNATSLeaf");function Rae(e,t,r){let n;switch(e.code){case kG.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case kG.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}o(Rae,"requestErrorHandler");async function yae(e,t){let r=t+Wr.SERVER_SUFFIX.LEAF,{connection:n}=await Vi(),{jsm:s}=await Pae(r),{schema:i,table:a}=e,c=iS.createNatsTableStreamName(i,a),l=e.start_time?e.start_time:new Date(Date.now()).toISOString();await ZG(async()=>{if(e.subscribe===!0)await XG(s,c,n.info.server_name,l);else try{await _ae(s,c,n.info.server_name)}catch(u){li.trace(u)}})}o(yae,"updateRemoteConsumer");async function Aae(e,t,r,n){let s=iS.createNatsTableStreamName(e,t),i=r+Wr.SERVER_SUFFIX.LEAF,a={type:Qe.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!$G&&joe()<xr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=QN();await c(a)}await Woe(a),n==="stop"&&await sS.asyncSetTimeout(1e3)}o(Aae,"updateConsumerIterator");function ZG(e){return Yoe.writeTransaction(Qe.SYSTEM_SCHEMA_NAME,Qe.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}o(ZG,"exclusiveLock");async function eq(e,t){let r=iS.createNatsTableStreamName(e,t),n=await oS(),s=wae(e,t,n);await iw(r,[s])}o(eq,"createLocalTableStream");async function bae(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await eq(n,s)}}o(bae,"createTableStreams");async function tq(e,t,r=void 0){if(xr.get(Qe.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=iS.createNatsTableStreamName(e,t),{domain:s}=md(Qe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await Nh()).jetstreamManager({domain:s,timeout:24e4})).streams.purge(n,r)}catch(n){if(n.message==="stream not found")li.warn(n);else throw n}}o(tq,"purgeTableStream");async function Iae(e,t){if(xr.get(Qe.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await tq(e,t[r])}o(Iae,"purgeSchemaTableStreams");async function Nae(e){return(await wh()).streams.info(e)}o(Nae,"getStreamInfo");function wae(e,t,r){return`${Wr.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}o(wae,"createSubjectName");async function oS(){if(bh)return bh;if(bh=(await wh())?.nc?.info?.server_name,bh===void 0)throw new Error("Unable to get jetstream manager server name");return bh}o(oS,"getJsmServerName");async function Oae(){let e=await wh(),t=await oS(),r=await QG();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let a=Cae(n),c=i.split(".");if(c[c.length-1]===t&&!a||s.name==="__HARPERDB_WORK_QUEUE__")continue;let u=i.split(".");u[u.length-1]=t;let d=u.join(".");li.trace(`Updating stream subject name from: ${i} to: ${d}`),s.subjects[0]=d,await e.streams.update(s.name,s)}}o(Oae,"updateLocalStreams");function Cae(e){let{config:t}=e,r=!1,n=xr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=xr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=xr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);return i=i===null?-1:i,n!==t.max_age&&(t.max_age=n,r=!0),s!==t.max_bytes&&(t.max_bytes=s,r=!0),i!==t.max_msgs&&(t.max_msgs=i,r=!0),r}o(Cae,"updateStreamLimits");async function Pae(e){let t,r;try{t=await un.jetstream({domain:e}),r=await un.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw li.error("Unable to connect to:",e),n}return{js:t,jsm:r}}o(Pae,"connectToRemoteJS")});function aw(e){let t=e.get(aS),r=t?(0,hd.unpack)(t):null;r||(r={remoteNameToId:{}});let n=rt(),s=!1;r.nodeName=rt();let i=r.remoteNameToId;if(i[n]!==0){let a=0,c;for(let l in i){let u=i[l];u===0?c=l:u>a&&(a=u)}if(c){a++,i[c]=a;let l=[Symbol.for("seq"),a];e.rootStore.dbisDb.transactionSync(()=>{e.rootStore.dbisDb.get(l)||e.rootStore.dbisDb.putSync(l,{seqId:Ch(e)??1,nodes:[]})})}i[n]=0,e.putSync(aS,(0,hd.pack)(r))}return r}function Oh(e){return aw(e).remoteNameToId}function sq(e,t){let r=aw(t),n=r.remoteNameToId,s=new Map,i=!1;for(let a in e){let c=e[a],l=n[a];if(l==null){let u=0;for(let d in n){let f=n[d];f>u&&(u=f)}l=u+1,n[a]=l,i=!0}s.set(c,l)}return i&&t.putSync(aS,(0,hd.pack)(r)),s}function cS(e,t){let r=aw(t),n=r.remoteNameToId,s=n[e];if(s==null){let i=0;for(let a in n){let c=n[a];c>i&&(i=c)}s=i+1,n[e]=s,t.putSync(aS,(0,hd.pack)(r))}return nq.trace?.("The remote node name map",e,n,s),s}var nq,hd,aS,cw=fe(()=>{nq=w(wi());es();hd=require("msgpackr"),aS=Symbol.for("remote-ids");o(aw,"getIdMappingRecord");o(Oh,"exportIdMapping");o(sq,"remoteToLocalNodeId");o(cS,"getIdOfRemoteNode")});var lw={};Ce(lw,{commitsAwaitingReplication:()=>_d,getHDBNodeTable:()=>$t,getReplicationSharedStatus:()=>Ed,iterateRoutes:()=>Lh,shouldReplicateToNode:()=>Ph,subscribeToNodeUpdates:()=>gd});function $t(){return iq||(iq=et({table:"hdb_nodes",database:"system",attributes:[{name:"name",isPrimaryKey:!0},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"},{attribute:"ca"},{attribute:"ca_info"},{attribute:"replicates"},{attribute:"revoked_certificates"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]}))}function Ed(e,t,r,n){return new Float64Array(e.getUserSharedBuffer(["replicated",t,r],new ArrayBuffer(48),n&&{callback:n}))}function gd(e){$t().subscribe({}).then(async t=>{for await(let r of t){let n=r?.value?.name;lq.debug?.("adding node",n,"on node",rt()," on process",process.pid),server.nodes=server.nodes.filter(i=>i.name!==n),r.type==="put"&&n!==rt()&&(r.value?server.nodes.push(r.value):console.error("Invalid node update event",r));let s=new Map;for await(let i of $t().search({}))if(i.shard!=null){let a=s.get(i.shard);a||s.set(i.shard,a=[]),a.push(i)}server.shards=s,(r.type==="put"||r.type==="delete")&&e(r.value,r.id)}})}function Ph(e,t){return(e.replicates===!0||e.replicates?.sends)&&databases[t]&&$t().primaryStore.get(rt())?.replicates||e.subscriptions?.some(r=>(r.database||r.schema)===t&&r.subscribe)}function Lae(){gd(e=>{Ha({},(t,r)=>{let n=e.name,s=oq.get(n);if(s||oq.set(n,s=new Map),s.has(r))return;let i;for(let a in t)if(i=t[a].auditStore,i)break;if(i){let a=Ed(i,r,n,()=>{let c=a[0],l=a.lastTime;for(let{txnTime:u,onConfirm:d}of _d.get(r)||[])u>l&&u<=c&&d();a.lastTime=c});a.lastTime=0,s.set(r,a)}})})}function*Lh(e){for(let t of e.routes||[]){let r=t.url,n;if(typeof t=="string"?t.includes("://")?r=t:n=t:n=t.hostname??t.host,n&&!r){let s=pd.default.get(U.REPLICATION_SECUREPORT)??(!pd.default.get(U.REPLICATION_PORT)&&pd.default.get(U.OPERATIONSAPI_NETWORK_SECUREPORT)),i;(i=n.match(/:(\d+)$/)?.[1])?n=n.slice(0,-i[0].length-1):t.port?i=t.port:i=s||pd.default.get(U.REPLICATION_PORT)||pd.default.get(U.OPERATIONSAPI_NETWORK_PORT);let a=i?.lastIndexOf?.(":");a>0&&(i=+i.slice(a+1).replace(/[\[\]]/g,"")),r=(s?"wss://":"ws://")+n+":"+i}if(!r){aq.isMainThread&&console.error("Invalid route, must specify a url or host (with port)");continue}yield{replicates:!t.subscriptions,url:r,subscription:t.subscriptions,routes:t.routes,startTime:t.startTime,revoked_certificates:t.revokedCertificates}}}var aq,cq,pd,lq,iq,oq,_d,Il=fe(()=>{Le();es();Jf();aq=require("worker_threads"),cq=w(_e()),pd=w(ce());k();lq=w(wi());server.nodes=[];o($t,"getHDBNodeTable");o(Ed,"getReplicationSharedStatus");o(gd,"subscribeToNodeUpdates");o(Ph,"shouldReplicateToNode");oq=new Map;av((e,t,r)=>{if(r>server.nodes.length)throw new cq.ClientError(`Cannot confirm replication to more nodes (${r}) than are in the network (${server.nodes.length})`);_d||(_d=new Map,Lae());let n=_d.get(e);return n||(n=[],_d.set(e,n)),new Promise(s=>{let i=0;n.push({txnTime:t,onConfirm:o(()=>{++i===r&&s()},"onConfirm")})})});o(Lae,"startSubscriptionToReplications");o(Lh,"iterateRoutes")});var mq={};Ce(mq,{connectedToNode:()=>Nl,disconnectedFromNode:()=>Rd,ensureNode:()=>vo,requestClusterStatus:()=>fq,startOnMainThread:()=>dw});async function dw(e){let t=0,r=it();for(let i of Object.getOwnPropertyNames(r)){let a=r[i];for(let c in a){let l=a[c];if(l.auditStore){lS.set(i,Ch(l.auditStore));break}}}Ki.whenThreadsStarted.then(async()=>{let i=[];for await(let l of r.system.hdb_nodes?.search([])||[])i.push(l);let a=rt();function c(){let l=$t().primaryStore.get(a);if(l!==null){let u=e.url??ka();if(l===void 0||l.url!==u||l.shard!==e.shard)return vo(a,{name:a,url:u,shard:e.shard,replicates:!0})}}o(c,"ensureThisNode"),$t().primaryStore.get(a)&&c();for(let l of Lh(e))try{let u=!l.subscriptions;if(u&&await c(),u&&l.replicates==null&&(l.replicates=!0),i.find(d=>d.url===l.url))continue;s(l)}catch(u){console.error(u)}gd(s)});let n;function s(i,a=i?.name){let c=rt()&&a===rt()||ka()&&i?.url===ka();if(c){let f=!!i?.replicates;if(n!==void 0&&n!==f)for(let m of $t().search([]))m.replicates&&m.name!==a&&s(m,m.name);n=f}if(ut.trace("Setting up node replication for",i),!i){for(let[f,m]of Mo){let h;for(let[p,{worker:E,nodes:g}]of m){let y=g[0];if(y&&y.name==a){h=!0;for(let[T,{worker:R}]of m)m.delete(T),ut.warn("Node was deleted, unsubscribing from node",a,T,f),R?.postMessage({type:"unsubscribe-from-node",node:a,database:T,url:f});break}}if(h){Mo.get(f).iterator.remove(),Mo.delete(f);return}}return}if(c)return;if(!i.url){ut.info(`Node ${i.name} is missing url`);return}let l=Mo.get(i.url);if(l&&l.iterator.remove(),!(i.replicates===!0||i.replicates?.sends)&&!i.subscriptions?.length&&!l)return;if(ut.info(`Added node ${i.name} at ${i.url} for process ${rt()}`),i.replicates&&i.subscriptions&&(i={...i,subscriptions:null}),i.name){for(let[f,m]of Sd)if(i.url===m.url){Sd.delete(f);break}Sd.set(i.name,i)}let u=it();if(l||(l=new Map,Mo.set(i.url,l)),l.iterator=Ha(e,(f,m,h)=>{h?d(m,!0):d(m,!1)}),i.subscriptions)for(let f of i.subscriptions){let m=f.database||f.schema;u[m]||(ut.warn(`Database ${m} not found for node ${i.name}, making a subscription anyway`),d(m,!1))}function d(f,m){ut.trace("Setting up replication for database",f,"on node",i.name);let h=l.get(f),p,E=[{replicateByDefault:m,...i}];lS.has(f)&&(E.push({replicateByDefault:m,name:rt(),startTime:lS.get(f),endTime:Date.now(),replicates:!0}),lS.delete(f));let g=Ph(i,f),y=Ki.workers.filter(T=>T.name==="http");if(h?(p=h.worker,h.nodes=E):g&&(t=t%y.length,p=y[t++],l.set(f,{worker:p,nodes:E,url:i.url}),p?.on("exit",()=>{l.get(f)?.worker===p&&(l.delete(f),d(f,m))})),g)setTimeout(()=>{let T={type:"subscribe-to-node",database:f,nodes:E};p?p.postMessage(T):Td(T)},Dae);else{ut.info("Node no longer should be used, unsubscribing from node",{replicates:i.replicates,databaseName:f,node:i,subscriptions:i.subscriptions,hasDatabase:!!u[f],thisReplicates:$t().primaryStore.get(rt())?.replicates}),$t().primaryStore.get(rt())?.replicates||(n=!1,ut.info("Disabling replication, this node name",rt(),$t().primaryStore.get(rt()),f));let T={type:"unsubscribe-from-node",database:f,url:i.url,name:i.name};p?p.postMessage(T):dS(T)}}o(d,"onDatabase")}o(s,"onNodeUpdate"),Rd=o(function(i){try{ut.info("Disconnected from node",i.name,i.url,"finished",!!i.finished);let a=Array.from(Sd.keys()),c=a.sort(),l=c.indexOf(i.name||ui(i.url));if(l===-1){ut.warn("Disconnected node not found in node map",i.name,a);return}let u=Mo.get(i.url),d=u?.get(i.database);if(!d){ut.warn("Disconnected node not found in replication map",i.database,u);return}if(d.connected=!1,i.finished)return;let f=d.nodes[0];if(!(f.replicates===!0||f.replicates?.sends||f.subscriptions?.length))return;let m=(l+1)%c.length;for(;l!==m;){let h=c[m],p=Sd.get(h);u=Mo.get(p.url);let E=u?.get(i.database);if(!E){m=(m+1)%c.length;continue}let{worker:g,nodes:y}=E,T=!1;for(let R of d.nodes){if(y.some(I=>I.name===R.name)){ut.info(`Disconnected node is already failing over to ${h} for ${i.database}`);continue}y.push(R),T=!0}if(!T){ut.info(`Disconnected node ${i.name} has no nodes to fail over to ${h}`);return}d.redirectingTo=E,ut.info(`Failing over ${i.database} from ${i.name} to ${h}`),g?g.postMessage({type:"subscribe-to-node",database:i.database,nodes:y}):Td({database:i.database,nodes:y});return}ut.warn("Unable to find any other node to fail over to",i.name,i.url)}catch(a){ut.error("Error failing over node",a)}},"disconnectedFromNode"),Nl=o(function(i){let a=Mo.get(i.url),c=a?.get(i.database);if(!c){ut.warn("Connected node not found in replication map, this may be because the node is being removed",i.database,a);return}if(c.connected=!0,c.latency=i.latency,c.redirectingTo){let{worker:l,nodes:u}=c.redirectingTo,d=u.find(f=>f.name===i.name);c.redirectingTo=null,d&&(u.splice(u.indexOf(d),1),l?l.postMessage({type:"subscribe-to-node",database:i.database,nodes:u}):Td({database:i.database,nodes:u}))}},"connectedToNode"),(0,Ki.onMessageByType)("disconnected-from-node",Rd),(0,Ki.onMessageByType)("connected-to-node",Nl),(0,Ki.onMessageByType)("request-cluster-status",fq)}function fq(e,t){let r=[];for(let[n,s]of Sd)try{let i=Mo.get(s.url);ut.info("Getting cluster status for",n,s.url,"has dbs",i?.size);let a=[];if(i){for(let[l,{worker:u,connected:d,nodes:f,latency:m}]of i)a.push({database:l,connected:d,latency:m,threadId:u?.threadId,nodes:f.map(h=>h.name)});let c=(0,uw.cloneDeep)(s);c.database_sockets=a,delete c.ca,delete c.node_name,delete c.__updatedtime__,delete c.__createdtime__,r.push(c)}}catch(i){ut.warn("Error getting cluster status for",s?.url,i)}return t?.postMessage({type:"cluster-status",connections:r}),{connections:r}}async function vo(e,t){let r=$t();e=e??ui(t.url),t.name=e;try{if(t.ca){let s=new dq.X509Certificate(t.ca);t.ca_info={issuer:s.issuer.replace(/\n/g," "),subject:s.subject.replace(/\n/g," "),subjectAltName:s.subjectAltName,serialNumber:s.serialNumber,validFrom:s.validFrom,validTo:s.validTo}}}catch(s){ut.error("Error parsing replication CA info for hdb_nodes table",s.message)}let n=r.primaryStore.get(e);if(ut.debug(`Ensuring node ${e} at ${t.url}, existing record:`,n,"new record:",t),!n)await r.patch(t);else{t.replicates&&!uq.default.get(U.CLUSTERING_ENABLED)&&(t.subscriptions=null);for(let s in t)if(n[s]!==t[s]&&s==="subscriptions"&&t[s]&&n[s]){let i=[],a=(0,uw.cloneDeep)(n[s]);for(let c of t[s]){let l=!1;for(let u of a)if((c.database??c.schema)===(u.database??u.schema)&&c.table===u.table){u.publish=c.publish,u.subscribe=c.subscribe,l=!0;break}l||i.push(c)}t.subscriptions=[...a,...i];break}if(Array.isArray(t.revoked_certificates)){let s=n.revoked_certificates||[];t.revoked_certificates=[...new Set([...s,...t.revoked_certificates])]}ut.info(`Updating node ${e} at ${t.url}`),await r.patch(t)}}var Ki,uS,ut,uw,uq,dq,Dae,Mo,Rd,Nl,Sd,lS,Dh=fe(()=>{Le();Ki=w(st());es();uS=require("worker_threads");Il();ut=w(z()),uw=require("lodash"),uq=w(ce());k();dq=require("crypto"),Dae=200,Mo=new Map,Sd=new Map,lS=new Map;o(dw,"startOnMainThread");o(fq,"requestClusterStatus");uS.parentPort&&(Rd=o(e=>{uS.parentPort.postMessage({type:"disconnected-from-node",...e})},"disconnectedFromNode"),Nl=o(e=>{uS.parentPort.postMessage({type:"connected-to-node",...e})},"connectedToNode"),(0,Ki.onMessageByType)("subscribe-to-node",e=>{Td(e)}),(0,Ki.onMessageByType)("unsubscribe-from-node",e=>{dS(e)}));o(vo,"ensureNode")});var rs=M(Vt=>{"use strict";var ur=require("path"),{watch:Mae}=require("chokidar"),vn=require("fs-extra"),yd=require("node-forge"),Sq=require("net"),{generateKeyPair:fw,X509Certificate:Uo,createPrivateKey:Tq}=require("crypto"),vae=require("util");fw=vae.promisify(fw);var Nt=yd.pki,di=require("joi"),{v4:Rq}=require("uuid"),{validateBySchema:_w}=at(),{forComponent:Uae}=z(),ts=ce(),Cs=(k(),v(K)),{CONFIG_PARAMS:Ol}=Cs,fi=ky(),{ClientError:qa}=_e(),mS=require("node:tls"),{relative:yq,join:xae}=require("node:path"),{CERT_PREFERENCE_APP:cMe,CERTIFICATE_VALUES:hq}=fi,Bae=Dc(),mw=yt(),{table:Fae,getDatabases:Hae,databases:fS}=(Le(),v(ft)),{getJWTRSAKeys:pq}=(ld(),v(Rh)),mt=Uae("tls");Vt.generateKeys=Sw;Vt.updateConfigCert=Pq;Vt.createCsr=Yae;Vt.signCertificate=Wae;Vt.setCertTable=Ad;Vt.loadCertificates=wq;Vt.reviewSelfSignedCert=Rw;Vt.createTLSSelector=Dq;Vt.listCertificates=vq;Vt.addCertificate=Zae;Vt.removeCertificate=tce;Vt.createNatsCerts=Qae;Vt.generateCertsKeys=jae;Vt.getReplicationCert=vh;Vt.getReplicationCertAuth=Kae;Vt.renewSelfSigned=Jae;Vt.hostnamesFromCert=Aw;Vt.getKey=rce;Vt.getHostnamesFromCertificate=nce;Vt.getPrimaryHostName=yw;var{urlToNodeName:Aq,getThisNodeUrl:kae,getThisNodeName:pS,clearThisNodeName:Gae}=(es(),v(xo)),{readFileSync:qae,statSync:bq}=require("node:fs"),lMe=ce(),{getTicketKeys:$ae,onMessageFromWorkers:Vae}=st(),Ga=z(),{isMainThread:Iq}=require("worker_threads"),{TLSSocket:Nq,createSecureContext:uMe}=require("node:tls"),Ew=3650,Mh=["127.0.0.1","localhost","::1"],gw=[{name:"countryName",value:"USA"},{name:"stateOrProvinceName",value:"Colorado"},{name:"localityName",value:"Denver"},{name:"organizationName",value:"HarperDB, Inc."}];Vae(async e=>{e.type===Cs.ITC_EVENT_TYPES.RESTART&&(ts.initSync(!0),await Rw())});var zr;function Va(){return zr||(zr=Hae().system.hdb_certificate,zr||(zr=Fae({table:"hdb_certificate",database:"system",attributes:[{name:"name",isPrimaryKey:!0},{attribute:"uses"},{attribute:"certificate"},{attribute:"is_authority"},{attribute:"private_key_name"},{attribute:"details"},{attribute:"is_self_signed"},{attribute:"__updatedtime__"}]}))),zr}o(Va,"getCertTable");async function vh(){let e=Dq("operations-api"),t={secureContexts:null,setSecureContext:o(s=>{},"setSecureContext")};await e.initialize(t);let r=t.secureContexts.get(pS());if(!r)return;let n=new Uo(r.options.cert);return r.cert_parsed=n,r.issuer=n.issuer,r}o(vh,"getReplicationCert");async function Kae(){Va();let e=(await vh()).options.cert,r=new Uo(e).issuer.match(/CN=(.*)/)?.[1];return zr.get(r)}o(Kae,"getReplicationCertAuth");var _q,$a=new Map;function wq(){if(_q)return;_q=!0;let e=[{configKey:Ol.TLS},{configKey:Ol.OPERATIONSAPI_TLS}];Va();let t=ur.dirname(mw.getConfigFilePath()),r;for(let{configKey:n}of e){let s=mw.getConfigFromFile(n);if(s){Array.isArray(s)||(s=[s]);for(let i of s){let a=i.privateKey,c=a&&yq(xae(t,"keys"),a);c&&Eq(a,l=>{$a.set(c,l)},"private key");for(let l of[!1,!0]){let u=i[l?"certificateAuthority":"certificate"];if(u&&Iq){let d;Eq(u,f=>{if(hq.cert===f)return;let m=i.hostname??i.hostnames??i.host??i.hosts;m&&!Array.isArray(m)&&(m=[m]);let h=Lq(u),p=new Uo(h),E;try{E=yw(p)}catch(R){mt.error("error extracting host name from certificate",R);return}if(E==null){mt.error("No host name found on certificate");return}if(p.checkIssued(new Uo(hq.cert)))return;let g=zr.primaryStore.get(E),y=bq(u).mtimeMs,T=!g||g.is_self_signed?1:g.file_timestamp??g.__updatedtime__;if(g&&y<=T){y<T&&mt.info(`Certificate ${E} at ${u} is older (${new Date(y)}) than the certificate in the database (${T>1?new Date(T):"only self signed certificate available"})`);return}r=zr.put({name:E,uses:["https",...n.includes("operations")?["operations"]:[]],ciphers:i.ciphers,certificate:h,private_key_name:c,is_authority:l,hostnames:m,fileTimestamp:y,details:{issuer:p.issuer.replace(/\n/g," "),subject:p.subject.replace(/\n/g," "),subject_alt_name:p.subjectAltName,serial_number:p.serialNumber,valid_from:p.validFrom,valid_to:p.validTo}})},l?"certificate authority":"certificate")}}}}}return r}o(wq,"loadCertificates");function Eq(e,t,r){let n,s=o((i,a)=>{try{let c=a.mtimeMs;c&&c!==n&&(n&&Iq&&mt.warn(`Reloading ${r}:`,i),n=c,t(Lq(i)))}catch(c){mt.error(`Error loading ${r}:`,i,c)}},"loadFile");vn.existsSync(e)?s(e,bq(e)):mt.error(`${r} file not found:`,e),Mae(e,{persistent:!1}).on("change",s)}o(Eq,"loadAndWatch");function hw(){let e=kae();if(e==null){let t=Mh[0];return mt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return Aq(e)}o(hw,"getHost");function hS(){let e=pS();if(e==null){let t=Mh[0];return mt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return e}o(hS,"getCommonName");async function Yae(){let e=await vh(),t=Nt.certificateFromPem(e.options.cert),r=Nt.privateKeyFromPem(e.options.key);mt.info("Creating CSR with cert named:",e.name);let n=Nt.createCertificationRequest();n.publicKey=t.publicKey;let s=[{name:"commonName",value:hS()},...gw];mt.info("Creating CSR with subject",s),n.setSubject(s);let i=[{name:"unstructuredName",value:"HarperDB, Inc."},{name:"extensionRequest",extensions:Oq()}];return mt.info("Creating CSR with attributes",i),n.setAttributes(i),n.sign(r),yd.pki.certificationRequestToPem(n)}o(Yae,"createCsr");function Oq(){let e=Mh.includes(hS())?Mh:[...Mh,hS()];return e.includes(hw())||e.push(hw()),[{name:"basicConstraints",cA:!1,critical:!0},{name:"keyUsage",digitalSignature:!0,keyEncipherment:!0,critical:!0},{name:"extKeyUsage",serverAuth:!0,clientAuth:!0},{name:"nsCertType",client:!0,server:!0},{name:"subjectAltName",altNames:e.map(t=>Sq.isIP(t)?{type:7,ip:t}:{type:2,value:t})}]}o(Oq,"certExtensions");async function Wae(e){let t={},r=ur.join(ts.getHdbBasePath(),Cs.LICENSE_KEY_DIR_NAME);if(e.csr){let n,s;Va();for await(let d of zr.search([]))if(d.is_authority&&!d.details.issuer.includes("HarperDB-Certificate-Authority")){if($a.has(d.private_key_name)){n=$a.get(d.private_key_name),s=d;break}else if(d.private_key_name&&await vn.exists(ur.join(r,d.private_key_name))){n=vn.readFile(ur.join(r,d.private_key_name)),s=d;break}}if(!n){let d=await pw();s=d.ca,n=d.private_key}n=Nt.privateKeyFromPem(n),t.signingCA=s.certificate;let i=Nt.certificateFromPem(s.certificate);mt.info("Signing CSR with cert named",s.name);let a=Nt.certificationRequestFromPem(e.csr);try{a.verify()}catch(d){return mt.error(d),new Error("Error verifying CSR: "+d.message)}let c=yd.pki.createCertificate();c.serialNumber="0"+Math.random().toString().slice(2,9),c.validity.notBefore=new Date;let l=new Date;c.validity.notAfter=l,c.validity.notAfter.setDate(l.getDate()+Ew),mt.info("sign cert setting validity:",c.validity),mt.info("sign cert setting subject from CSR:",a.subject.attributes),c.setSubject(a.subject.attributes),mt.info("sign cert setting issuer:",i.subject.attributes),c.setIssuer(i.subject.attributes);let u=a.getAttribute({name:"extensionRequest"}).extensions;mt.info("sign cert adding extensions from CSR:",u),c.setExtensions(u),c.publicKey=a.publicKey,c.sign(n,yd.md.sha256.create()),t.certificate=Nt.certificateToPem(c)}else mt.info("Sign cert did not receive a CSR from:",e.url,"only the CA will be returned");return t}o(Wae,"signCertificate");async function zae(e,t){await Ad({name:pS(),uses:["https","wss"],certificate:e,private_key_name:"privateKey.pem",is_authority:!1,is_self_signed:!0}),await Ad({name:t.subject.getField("CN").value,uses:["https","wss"],certificate:Nt.certificateToPem(t),private_key_name:"privateKey.pem",is_authority:!0,is_self_signed:!0})}o(zae,"createCertificateTable");async function Ad(e){let t=new Uo(e.certificate);e.details={issuer:t.issuer.replace(/\n/g," "),subject:t.subject.replace(/\n/g," "),subject_alt_name:t.subjectAltName,serial_number:t.serialNumber,valid_from:t.validFrom,valid_to:t.validTo},Va(),await zr.patch(e)}o(Ad,"setCertTable");async function Sw(){let e=await fw("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}});return{publicKey:Nt.publicKeyFromPem(e.publicKey),privateKey:Nt.privateKeyFromPem(e.privateKey)}}o(Sw,"generateKeys");async function Tw(e,t,r){let n=Nt.createCertificate();if(!t){let a=await vh();t=Nt.certificateFromPem(a.options.cert).publicKey}n.publicKey=t,n.serialNumber="0"+Math.random().toString().slice(2,9),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+Ew);let i=[{name:"commonName",value:hS()},...gw];return n.setSubject(i),n.setIssuer(r.subject.attributes),n.setExtensions(Oq()),n.sign(e,yd.md.sha256.create()),Nt.certificateToPem(n)}o(Tw,"generateCertificates");async function pw(){let e=await vq(),t;for(let r of e){if(!r.is_authority)continue;let n=await Mq(r.private_key_name);if(r.private_key_name&&n&&new Uo(r.certificate).checkPrivateKey(Tq(n))){mt.trace(`CA named: ${r.name} found with matching private key`),t={ca:r,private_key:n};break}}if(t)return t;mt.trace("No CA found with matching private key")}o(pw,"getCertAuthority");async function Cq(e,t,r=!0){let n=Nt.createCertificate();n.publicKey=t,n.serialNumber="0"+Math.random().toString().slice(2,9),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+Ew);let i=[{name:"commonName",value:`HarperDB-Certificate-Authority-${ts.get(Ol.REPLICATION_HOSTNAME)??Aq(ts.get(Ol.REPLICATION_URL))??Rq().split("-")[0]}`},...gw];n.setSubject(i),n.setIssuer(i),n.setExtensions([{name:"basicConstraints",cA:!0,critical:!0},{name:"keyUsage",keyCertSign:!0,critical:!0}]),n.sign(e,yd.md.sha256.create());let a=ur.join(ts.getHdbBasePath(),Cs.LICENSE_KEY_DIR_NAME),c=ur.join(a,fi.PRIVATEKEY_PEM_NAME);return r&&await vn.writeFile(c,Nt.privateKeyToPem(e)),n}o(Cq,"generateCertAuthority");async function jae(){let{privateKey:e,publicKey:t}=await Sw(),r=await Cq(e,t),n=await Tw(e,t,r);await zae(n,r),Pq()}o(jae,"generateCertsKeys");async function Qae(){let e=await Tw(Nt.privateKeyFromPem(fi.CERTIFICATE_VALUES.key),void 0,Nt.certificateFromPem(fi.CERTIFICATE_VALUES.cert)),t=ur.join(ts.getHdbBasePath(),Cs.LICENSE_KEY_DIR_NAME),r=ur.join(t,fi.NATS_CERTIFICATE_PEM_NAME);await vn.exists(r)||await vn.writeFile(r,e);let n=ur.join(t,fi.NATS_CA_PEM_NAME);await vn.exists(n)||await vn.writeFile(n,fi.CERTIFICATE_VALUES.cert)}o(Qae,"createNatsCerts");async function Jae(){Va();for await(let e of zr.search([{attribute:"is_self_signed",value:!0}]))await zr.delete(e.name);await Rw()}o(Jae,"renewSelfSigned");async function Rw(){Gae(),await wq(),Va();let e=await pw();if(!e){mt.notify("A matching Certificate Authority and key was not found. A new CA will be created in advance, so it's available if needed.");let r=o(u=>{try{return{key:Nt.privateKeyFromPem(vn.readFileSync(u)),keyPath:u}}catch(d){return mt.warn(`Failed to parse private key from ${u}:`,d.message),{key:null,keyPath:u}}},"tryToParseKey"),n=ts.get(Ol.TLS),s,i;if(Array.isArray(n)){for(let u of n)if(u.privateKey){let d=r(u.privateKey);if(s=d.key,i=d.keyPath,d.key)break}}else{let u=ts.get(Ol.TLS_PRIVATEKEY),d=r(u);s=d.key,i=d.keyPath}let a=ur.join(ts.getHdbBasePath(),Cs.LICENSE_KEY_DIR_NAME),c=yq(a,i);s||(mt.warn("Unable to parse the TLS key",i,"A new key will be generated and used to create Certificate Authority"),{privateKey:s}=await Sw(),vn.existsSync(ur.join(a,fi.PRIVATEKEY_PEM_NAME))&&(c=`privateKey${Rq().split("-")[0]}.pem`),await vn.writeFile(ur.join(a,c),Nt.privateKeyToPem(s)));let l=await Cq(s,Nt.setRsaPublicKey(s.n,s.e),!1);await Ad({name:l.subject.getField("CN").value,uses:["https"],certificate:Nt.certificateToPem(l),private_key_name:c,is_authority:!0,is_self_signed:!0})}if(!await vh()){let r=pS();mt.notify(`A suitable replication certificate was not found, creating new self singed cert named: ${r}`),e=e??await pw();let n=Nt.certificateFromPem(e.ca.certificate),s=n.publicKey,i=await Tw(Nt.privateKeyFromPem(e.private_key),s,n);await Ad({name:r,uses:["https","operations","wss"],certificate:i,is_authority:!1,private_key_name:e.ca.private_key_name,is_self_signed:!0})}}o(Rw,"reviewSelfSignedCert");function Pq(){let e=Bae(Object.keys(Cs.CONFIG_PARAM_MAP),!0),t=ur.join(ts.getHdbBasePath(),Cs.LICENSE_KEY_DIR_NAME),r=ur.join(t,fi.PRIVATEKEY_PEM_NAME),n=ur.join(t,fi.NATS_CERTIFICATE_PEM_NAME),s=ur.join(t,fi.NATS_CA_PEM_NAME),i=Cs.CONFIG_PARAMS,a={[i.TLS_PRIVATEKEY]:e[i.TLS_PRIVATEKEY.toLowerCase()]?e[i.TLS_PRIVATEKEY.toLowerCase()]:r};e[i.TLS_CERTIFICATE.toLowerCase()]&&(a[i.TLS_CERTIFICATE]=e[i.TLS_CERTIFICATE.toLowerCase()]),e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(a[i.TLS_CERTIFICATEAUTHORITY]=e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]&&(a[i.OPERATIONSAPI_TLS_CERTIFICATE]=e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]),e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]&&(a[i.OPERATIONSAPI_TLS_PRIVATEKEY]=e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(a[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY]=e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]),(e[i.CLUSTERING_ENABLED.toLowerCase()]||e.clustering)&&(a[i.CLUSTERING_TLS_CERTIFICATE]=e[i.CLUSTERING_TLS_CERTIFICATE.toLowerCase()]??n,a[i.CLUSTERING_TLS_CERT_AUTH]=e[i.CLUSTERING_TLS_CERT_AUTH.toLowerCase()]??s,a[i.CLUSTERING_TLS_PRIVATEKEY]=e[i.CLUSTERING_TLS_PRIVATEKEY.toLowerCase()]??r),mw.updateConfigValue(void 0,void 0,a,!1,!0)}o(Pq,"updateConfigCert");function Lq(e){return e.startsWith("-----BEGIN")?e:qae(e,"utf8")}o(Lq,"readPEM");var gq=mS.createSecureContext;mS.createSecureContext=function(e){if(!e.cert||!e.key)return gq(e);let t={...e};delete t.key,delete t.cert;let r=gq(t);return r.context.setCert(e.cert),r.context.setKey(e.key,void 0),r};var Xae=Nq.prototype._init;Nq.prototype._init=function(e,t){Xae.call(this,e,t);let r=this;this._handle.oncertcb=function(n){let s=n.servername;r._SNICallback(s,(i,a)=>{this.sni_context=a?.context||a,this.certCbDone()})}};var wl=new Map;function Dq(e,t){let r=new Map,n,s=!1;return i.initialize=a=>i.ready?i.ready:(a&&(a.secureContexts=r,a.secureContextsListeners=[]),i.ready=new Promise((c,l)=>{async function u(){try{r.clear(),wl.clear();let d=0;if(fS===void 0){c();return}for await(let f of fS.system.hdb_certificate.search([])){let m=f.certificate,h=new Uo(m);f.is_authority&&(h.asString=m,wl.set(h.subject,m))}for await(let f of fS.system.hdb_certificate.search([]))try{if(f.is_authority)continue;let m=e==="operations-api",h=f.is_self_signed?1:2;m&&f.uses?.includes?.("operations")&&(h+=1);let p=await Mq(f.private_key_name),E=f.certificate,g=new Uo(E);if(wl.has(g.issuer)&&(E+=`
|