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
package/bin/lite.js
CHANGED
|
@@ -8,7 +8,7 @@ var I4=Object.create;var Lf=Object.defineProperty;var N4=Object.getOwnPropertyDe
|
|
|
8
8
|
|
|
9
9
|
`:`data: ${e}
|
|
10
10
|
|
|
11
|
-
`},"serialize"),compressible:!1,q:.8});tn.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()}});sv={type:"application/json",serializeStream:Wf,serialize:zf,deserialize:kX,q:.5};tn.set("*/*",sv);tn.set("",sv);o(kX,"tryJSONParse");o(Qf,"registerContentHandlers");GX=(0,rv.default)(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:a,type:c}=GE(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(GE,"findBestSerializer");JM=rA.default.get(U.HTTP_COMPRESSIONTHRESHOLD);o(Jf,"serialize");o(Ea,"serializeMessage");o(oA,"asyncSerialization");o(aA,"hasAsyncSerialization");o(qX,"streamToBuffer");$X=["ascii","utf8","utf-8","utf16le","utf-16le","ucs2","ucs-2","base64","base64url","latin1","binary","hex"];o(VX,"isBufferEncoding");o(KX,"parseContentType");o(mo,"getDeserializer");o(YX,"deserializerUnknownType");o(WX,"transformIterable");o(kE,"toCsvStream")});var fA={};Ce(fA,{Blob:()=>gs,blobsWereEncoded:()=>Bc,databasePaths:()=>lA,decodeBlobsWithWrites:()=>QE,decodeFromDatabase:()=>Fc,decodeWithBlobCallback:()=>JE,deleteBlob:()=>WE,deleteBlobsInObject:()=>_a,deleteRootBlobPathsForDB:()=>dA,encodeBlobsAsBuffers:()=>nZ,encodeBlobsWithFilePath:()=>jE,findBlobsInObject:()=>pu,getFileId:()=>zE,getFilePathForBlob:()=>pv,getRootBlobPathsForDB:()=>tm,setDeletionDelay:()=>JX});function fv(){}function WE(e){let t=pv(e);t&&setTimeout(()=>{(0,Ze.unlink)(t,r=>{r&&po.default.debug?.("Error trying to remove blob file",r)})},mv)}function JX(e){mv=e}function hv(e){let t=yn.get(e);if(!t)t={storageIndex:0,fileId:null,store:An},yn.set(e,t);else{if(t.saving)return t;t.store=An}return ZX(t),t.source?cA(e,t.source,t):t.contentBuffer?XX(e,t):cA(e,Zf.Readable.from(e.stream()),t),t}function cA(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(jX),h=(0,KE.createDeflate)(),t.pipe(h).pipe(f)):(m||f.write(zX),t.pipe(f)),t.on("error",_);function p(g){let y=BigInt(g),T=new Uint8Array(Tr),R=new DataView(T.buffer);return y|=BigInt(a?uA:dv)<<48n,R.setBigInt64(0,y),T}o(p,"createHeader");function _(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(_,"finished"),f.on("error",_).on("finish",()=>{if(m)_();else{let g=h?h.bytesWritten:f.bytesWritten-Tr;e.size=g,(0,Ze.write)(f.fd,p(g),0,Tr,0,_)}})}),e}function zE(e){return yn.get(e)?.fileId}function pv(e){let t=yn.get(e);return t?.fileId&&em(t)}function tm(e){if(!e)throw new Error("No store specified, can not determine blob storage path");let t=lA.get(e);if(!t){if(!e.databaseName)return po.default.warn?.("No database name specified, can not determine blob storage path"),[];let r=(0,YE.get)(U.STORAGE_BLOBPATHS);r?t=r.map(n=>(0,_o.join)(n,e.databaseName)):t=[(0,_o.join)((0,YE.getHdbBasePath)(),"blobs",e.databaseName)],lA.set(e,t)}return t}async function dA(e){let t=tm(e);t&&await Promise.all(t.map(r=>Ev(r)))}async function Ev(e){if((0,Ze.existsSync)(e)){for(let t of await(0,zs.readdir)(e,{withFileTypes:!0}))if(t.isDirectory())await Ev((0,_o.join)(e,t.name));else try{await(0,zs.unlink)((0,_o.join)(e,t.name))}catch(r){po.default.warn?.("Error deleting file",r)}try{await(0,zs.rmdir)(e)}catch(t){po.default.warn?.("Error deleting directory",t)}}}function em({storageIndex:e,fileId:t,store:r}){let n=tm(r);return(0,_o.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 XX(e,t){let r=t.contentBuffer,n=r.length;if(!(n<uv))return e.size=n,cA(e,Zf.Readable.from([r]),t)}function ZX(e){let t=tm(e.store),r=eZ(),n=t?.length>1?tZ(t,r):0,s=r.toString(16);e.storageIndex=n,e.fileId=s;let i=em(e),a=(0,_o.dirname)(i);(0,Ze.existsSync)(a)||(0,lv.ensureDirSync)(a),e.filePath=i}function eZ(){let e=cv.get(An);if(!e){let t=0,r=tm(An);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,_o.join)(n,a.toString(16))}t=Math.max(t,s)}e=new BigInt64Array([BigInt(t)+1n]),e=new BigInt64Array(An.getUserSharedBuffer("blob-file-id",e.buffer)),cv.set(An,e)}return Number(Atomics.add(e,0,1n))}function tZ(e,t){let r=Date.now();if(!e.frequencyTable){e.lastUpdated=0;let s=new Array(VE);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,rZ(e)),e.frequencyTable[t%VE]}async function rZ(e){if(!zs.statfs)return;let t=await Promise.all(e.map(async(s,i)=>{let a=await(0,zs.statfs)(s),c=a.bavail*a.bsize;return Math.pow(c,.8)})),r=new Array(VE),n=t.map(s=>1/s);for(let s=0;s<VE;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 jE(e,t,r){hu=t,An=r,Bc=!1;try{return e()}finally{hu=void 0,An=void 0}}function nZ(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 QE(e,t){try{Gr=[],xc=t,e()}catch(n){throw xc=void 0,Gr=void 0,n}xc=void 0;let r=Gr.length<2?Gr[0]:Promise.all(Gr);return Gr=void 0,r}function JE(e,t,r){An=r;try{return xc=t,e()}finally{xc=void 0}}function Fc(e,t){return An=t,e()}function _a(e){pu(e,t=>{WE(t)})}function pu(e,t){if(e instanceof gs)t(e);else if(Array.isArray(e))for(let r of e)typeof r=="object"&&r&&pu(r,t);else if(e&&typeof e=="object"&&!e[Symbol.iterator])for(let r in e){let n=e[r];typeof n=="object"&&n&&pu(e[r],t)}}function sZ(){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 Eo,zs,Ze,KE,Zf,lv,YE,_o,po,uv,Tr,dv,uA,ov,zX,jX,av,yn,xc,gs,hu,Gr,An,Bc,Xf,qE,QX,$E,mv,lA,cv,VE,Ss=fe(()=>{Eo=require("msgpackr"),zs=require("node:fs/promises"),Ze=require("node:fs"),KE=require("node:zlib"),Zf=require("node:stream"),lv=require("fs-extra"),YE=w(ce());k();_o=require("path"),po=w(Ii());ho();uv=8192,Tr=8,dv=0,uA=1,ov=255,zX=new Uint8Array([0,dv,255,255,255,255,255,255]),jX=new Uint8Array([0,uA,255,255,255,255,255,255]),av=0xffffffffffff,yn=new WeakMap,gs=global.Blob||sZ(),Bc=!1,Xf=new Uint8Array(8),qE=new DataView(Xf.buffer),QX=6e4;o(fv,"InstanceOfBlobWithNoConstructor");fv.prototype=gs.prototype;$E=class e extends fv{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=yn.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):(aA()&&oA(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=yn.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=em(t),a,c=o(async()=>{let l,u=Tr;try{if(l=await(0,zs.readFile)(i),l.length>=Tr){l.copy(Xf,0,0,Tr);let f=qE.getBigUint64(0);if(Number(f>>48n)===ov)throw new Error("Error in blob: "+buffer.subarray(Tr));if(u=Number(f&0xffffffffffffn),u<n&&(u=n),u<av&&(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,_)=>{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]===uA?new Promise((f,m)=>{(0,KE.deflate)(l.subarray(Tr),(h,p)=>{h?m(h):f(d(p))})}):d(l.subarray(Tr))},"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=yn.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(_){_.enqueue(r),_.close()}});let i=em(t),a,c=0,l=0,u,d,f,m=!1,h=this;return new ReadableStream({start(){let _=1e3,g=o((y,T)=>{(0,Ze.open)(i,"r",(R,I)=>{if(R){if(R.code==="ENOENT"&&f!==!1&&(po.default.debug?.("File does not exist yet, waiting for it to be created",i,_),_-- >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(_=>{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<Tr){y-- >0&&f!==!1?(p(),po.default.debug?.("File was empty, waiting for data to be written",i,y),setTimeout(()=>T(R,I),20).unref()):(po.default.debug?.("File was empty, throwing error",i,y),I(new Error(`Blob ${t.fileId} was empty`)));return}$.copy(Xf,0,0,Tr);let j=qE.getBigUint64(0);if(Number(j>>48n)===ov)return P(new Error("Error in blob: "+$.subarray(Tr)));if(g=Number(j&0xffffffffffffn),g<av&&h.size!==g&&(h.size=g,h.#t))for(let V of h.#t)V(g);$=$.subarray(Tr,x),l-=Tr}else if(x===0){let j=Buffer.allocUnsafe(8);return(0,Ze.read)(a,j,0,Tr,0,V=>{if(V)return P(V);if(Xf.set(j),g=Number(qE.getBigUint64(0)&0xffffffffffffn),g>l){p()?u?d=setTimeout(()=>{P(new Error("File read timed out"))},QX).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),_.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{_.enqueue($)}catch(j){return po.default.debug?.("Error enqueuing chunk",j),R()}l===g&&((0,Ze.close)(a),_.close()),R()})},"readMore"))},"pull"),cancel(){(0,Ze.close)(a),clearTimeout(d),u&&u.close()}});function p(){if(f===void 0){let _=t.store,g=t.fileId+":blob";f=!_.attemptLock(g,0,()=>{f=!1,_.unlock(g,0)}),f||_.unlock(g,0)}return f}}slice(t,r,n){let s=yn.get(this),i=new e(n&&{type:n});if(s?.fileId){let a={...s,start:t,end:r};yn.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)};yn.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(An=t?.primaryStore?.rootStore,!An)throw new Error("No target table specified");return hv(this).saving??Promise.resolve()}},mv=500;o(WE,"deleteBlob");o(JX,"setDeletionDelay");global.createBlob=function(e,t){let r=new $E(t),n={storageIndex:0,fileId:null,flush:t?.flush,compress:t?.compress};if(yn.set(r,n),e instanceof Uint8Array)r.size=e.length,n.contentBuffer=e;else if(e instanceof Zf.Readable)n.source=e;else if(typeof e=="string")n.contentBuffer=Buffer.from(e);else if(e?.[Symbol.asyncIterator]||e?.[Symbol.iterator])n.source=Zf.Readable.from(e);else throw new Error("Invalid source type");return r};o(hv,"saveBlob");o(cA,"writeBlobWithStream");o(zE,"getFileId");o(pv,"getFilePathForBlob");lA=new Map;o(tm,"getRootBlobPathsForDB");o(dA,"deleteRootBlobPathsForDB");o(Ev,"rimrafSteadily");o(em,"getFilePath");o(XX,"writeBlobWithBuffer");o(ZX,"generateFilePath");cv=new Map;o(eZ,"getNextFileId");VE=128;o(tZ,"getNextStorageIndex");o(rZ,"createFrequencyTableForStoragePaths");o(jE,"encodeBlobsWithFilePath");o(nZ,"encodeBlobsAsBuffers");o(QE,"decodeBlobsWithWrites");o(JE,"decodeWithBlobCallback");o(Fc,"decodeFromDatabase");o(_a,"deleteBlobsInObject");o(pu,"findBlobsInObject");(0,Eo.addExtension)({Class:gs,type:11,unpack:o(function(e){let t=(0,Eo.unpack)(e),r=new $E;if(Object.assign(r,t[0]),typeof t[1]!="object"){if(yn.set(r,{storageIndex:t[1],fileId:t[2],store:An}),xc)return xc(r)??r;if(!An)throw new Error("No store specified, cannot load blob from storage")}else yn.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=yn.get(e);if(hu!==void 0&&(Bc=!0,t?.recordId!==void 0&&t.recordId!==hu))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<uv)return r.size=t.contentBuffer.length,(0,Eo.pack)([r,t.contentBuffer])}if(hu!==void 0){if(t=hv(e),!t.fileId)throw new Error("Unable to save blob without file id");return t.recordId=hu,(0,Eo.pack)([r,t.storageIndex,t.fileId])}if(t)try{let n=(0,Ze.readFileSync)(em(t));if(n.length>=Tr&&(n.copy(Xf,0,0,Tr),Number(qE.getBigUint64(0)&0xffffffffffffn)===n.length-Tr))return Buffer.concat([(0,Eo.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,Eo.addExtension)({Class:Promise,type:12,pack(){throw new Error("Cannot encode a promise")}});o(sZ,"polyfillBlob")});var Rv={};Ce(Rv,{onStorageReclamation:()=>rm,runReclamationHandlers:()=>EA,setAvailableSpaceRatioGetter:()=>oZ});function rm(e,t,r){(r||(0,ZE.getWorkerIndex)()===(0,ZE.getWorkerCount)()-1)&&(XE.has(e)||XE.set(e,[]),XE.get(e).push({priority:0,handler:t}),pA||(pA=setTimeout(EA,gv).unref()))}async function EA(){for(let[e,t]of XE)try{let r=await Tv(e),n=iZ/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&&(hA.default.info?.(`Running storage reclamation handler for ${e} with priority ${n}`),await c)}}}catch(r){hA.default.error?.("Error running storage reclamation handlers",r)}pA=setTimeout(EA,gv).unref()}function oZ(e){Tv=e??Sv}var mA,ZE,hA,e_,_v,XE,iZ,gv,pA,Sv,Tv,t_=fe(()=>{mA=require("node:fs/promises"),ZE=w(st()),hA=w(Ii());k();e_=w(ce()),_v=w(ie());e_.default.initSync();XE=new Map,iZ=e_.default.get(U.STORAGE_RECLAMATION_THRESHOLD)??.4,gv=(0,_v.convertToMS)(e_.default.get(U.STORAGE_RECLAMATION_INTERVAL))||36e5;o(rm,"onStorageReclamation");Sv=o(async e=>{if(mA.statfs){let t=await(0,mA.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"),Tv=Sv;o(EA,"runReclamationHandlers");o(oZ,"setAvailableSpaceRatioGetter")});var vv={};Ce(vv,{ACTION_32_BIT:()=>o_,ACTION_64_BIT:()=>lZ,AUDIT_STORE_OPTIONS:()=>im,Decoder:()=>kc,HAS_BLOBS:()=>bn,HAS_CURRENT_RESIDENCY_ID:()=>Gc,HAS_EXPIRATION_EXTENDED_TYPE:()=>cm,HAS_ORIGINATING_OPERATION:()=>am,HAS_PREVIOUS_RESIDENCY_ID:()=>qc,REMOTE_SEQUENCE_UPDATE:()=>a_,createAuditEntry:()=>_u,getLastRemoved:()=>yA,openAuditStore:()=>s_,readAuditEntry:()=>vt,removeAuditEntry:()=>i_,setAuditRetention:()=>cZ,transactionKeyEncoder:()=>Pv});function s_(e){let t=e.auditStore=e.openDB(_A.AUDIT_STORE_NAME,{create:!1,...im});t||(t=e.auditStore=e.openDB(_A.AUDIT_STORE_NAME,im),Av(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=SA;rm(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:_}of t.getRange({start:1,snapshot:!1,end:Date.now()-gA/(1+i*i)})){try{m=i_(t,p,_)}catch(g){Eu.warn("Error removing audit entry",g)}if(h=p,await new Promise(setImmediate),++f>=aZ){a=10;break}}await m}finally{f===0?a=Math.min(a<<1,gA/10):(Av(t,h),a>100&&(a=a>>1)),d(void 0),c()}},a).unref()});return u}if(o(c,"scheduleAuditCleanup"),t.scheduleAuditCleanup=c,(0,sm.getWorkerIndex)()===(0,sm.getWorkerCount)()-1&&c(),(0,sm.getWorkerIndex)()===0&&!yv)for(let l of t.getKeys({reverse:!0,limit:1}))l>Date.now()&&(yv=!0,Eu.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 i_(e,t,r){let n=uZ(r),s;if(n&bn){s=vt(r);let i=e.tableStores[s.tableId],a=i?.getEntry(s.recordId);(!a||a.version!==s.version||!a.value)&&Fc(()=>_a(s.getValue(i)),i.rootStore)}if((n&15)===TA){s=s||vt(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 Av(e,t){RA[0]=t,e.put(Symbol.for("last-removed"),Lv)}function yA(e){let t=e.get(Symbol.for("last-removed"));if(t)return Lv.set(t),RA[0]}function cZ(e,t=SA){gA=e,SA=t}function _u(e,t,r,n,s,i,a,c,l,u,d,f,m){let h=Dv[a];if(!h)throw new Error(`Invalid audit entry type ${a}`);let p=1;if(n&&(n>1?ga.setFloat64(0,n):Ts.set(AA),p=9),l){if(l&255)throw new Error("Illegal extended type");p+=3}y(s),y(t),g(r),ga.setFloat64(p,e),p+=8,l&Gc&&y(u),l&qc&&y(d),l&cm&&(ga.setFloat64(p,f),p+=8),l&am&&y(Mv[m]),i?g(i):Ts[p++]=0,l?ga.setUint32(n?8:0,h|l|3221225472):Ts[n?8:0]=h;let _=Ts.subarray(0,p);if(c)return Buffer.concat([_,c]);return _;function g(T){let R=p;p+=1,p=(0,Hc.writeKey)(T,Ts,p);let I=p-R-1;I>127?I>16383?(Eu.error("Key or username was too large for audit entry",T),p=R+1,Ts[R]=0):(Ts.copyWithin(R+2,R+1,p),ga.setUint16(R,I|32768),p++):Ts[R]=I}function y(T){T<128?Ts[p++]=T:T<16384?(ga.setUint16(p,T|32768),p+=2):T<1056964608?(ga.setUint32(p,T|3221225472),p+=4):(Ts[p]=255,ga.setUint32(p+1,T),p+=5)}}function uZ(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 kc(e.buffer,e.byteOffset,e.byteLength));return n.position=t,n.readInt()}function vt(e,t=0,r=void 0){try{let n=e.dataView||(e.dataView=new kc(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,_;if(i&Gc&&(m=n.readInt()),i&qc&&(h=n.readInt()),i&cm&&(p=n.readFloat64()),i&am){let R=n.readInt();_=Mv[R]}l=n.readInt();let g=n.position,y=n.position+=l,T;return{type:Dv[i&7],tableId:c,nodeId:a,get recordId(){return(0,Hc.readKey)(e,u,d)},getBinaryRecordId(){return e.subarray(u,d)},version:f,previousLocalTime:s,get user(){return y>g?(0,Hc.readKey)(e,g,y):void 0},get encoded(){return t?e.subarray(t,r):e},getValue(R,I,P){if(i&r_||i&nm&&!I)return T||(T=Fc(()=>R.decoder.decode(e.subarray(n.position,r)),R.rootStore)),T;if(i&nm&&P)return Qy(R.getEntry(this.recordId),P,R)},getBinaryValue(){return i&(r_|nm)?e.subarray(n.position,r):void 0},extendedType:i,residencyId:m,previousResidencyId:h,expiresAt:p,originatingOperation:_}}catch(n){return Eu.error("Reading audit entry error",n,e),{}}}var Hc,n_,_A,sm,Cv,Eu,Ts,ga,Pv,im,gA,aZ,RA,Lv,SA,yv,r_,nm,bv,TA,Iv,Nv,wv,Ov,o_,lZ,a_,Gc,qc,am,cm,bn,Dv,Mv,kc,lo=fe(()=>{Hc=require("ordered-binary"),n_=w(ce()),_A=w(kt());k();sm=w(st()),Cv=w(ie());$c();Eu=w(z());BE();Ss();t_();(0,n_.initSync)();Ts=Buffer.alloc(2816),ga=new DataView(Ts.buffer,Ts.byteOffset,2816),Pv={writeKey(e,t,r){return e===om?(t.set(om,r),r+8):typeof e=="number"?((t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).setFloat64(r,e),r+8):(0,Hc.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,Hc.readKey)(e,t,r)}},im={encoding:"binary",keyEncoder:Pv},gA=(0,Cv.convertToMS)((0,n_.get)(U.LOGGING_AUDITRETENTION))||86400*3,aZ=1e3,RA=new Float64Array(1),Lv=new Uint8Array(RA.buffer),SA=1e4,yv=!1;o(s_,"openAuditStore");o(i_,"removeAuditEntry");o(Av,"updateLastRemoved");o(yA,"getLastRemoved");o(cZ,"setAuditRetention");r_=16,nm=32,bv=1,TA=2,Iv=3,Nv=4,wv=5,Ov=6,o_=14,lZ=15,a_=11,Gc=512,qc=1024,am=2048,cm=4096,bn=8192,Dv={put:bv|r_,[bv]:"put",delete:TA,[TA]:"delete",message:Iv|r_,[Iv]:"message",invalidate:Nv|nm,[Nv]:"invalidate",patch:wv|nm,[wv]:"patch",relocate:Ov,[Ov]:"relocate"},Mv={insert:1,update:2,upsert:3,1:"insert",2:"update",3:"upsert"};o(_u,"createAuditEntry");o(uZ,"readAction");o(vt,"readAuditEntry");kc=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 Hv={};Ce(Hv,{ENTRY:()=>fZ,HAS_EXPIRATION:()=>u_,HAS_RESIDENCY_ID:()=>CA,HAS_STRUCTURE_UPDATE:()=>d_,LAST_TIMESTAMP_PLACEHOLDER:()=>om,LOCAL_TIMESTAMP:()=>dZ,METADATA:()=>Su,NEW_TIMESTAMP_PLACEHOLDER:()=>xv,NO_TIMESTAMP:()=>bA,PENDING_LOCAL_TIME:()=>PA,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>AA,RecordEncoder:()=>OA,TIMESTAMP_ASSIGN_LAST:()=>hZ,TIMESTAMP_ASSIGN_NEW:()=>Bv,TIMESTAMP_ASSIGN_PREVIOUS:()=>Fv,TIMESTAMP_PLACEHOLDER:()=>c_,TIMESTAMP_RECORD_PREVIOUS:()=>IA,entryMap:()=>Sa,handleLocalTimeForGets:()=>f_,lastMetadata:()=>at,recordUpdater:()=>LA,removeEntry:()=>Kc});function EZ(){return dm[0]=dm[0]^64,mZ.getFloat64(0)}function f_(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++,at=null;let l=r.call(this,a,c);return l&&(at&&(l.metadataFlags=at[Su],l.localTime=at.localTime,l.residencyId=at.residencyId,at.expiresAt>=0&&(l.expiresAt=at.expiresAt),at=null),l.value&&Sa.set(l.value,l),l.key=a),l};let n=e.get;e.get=function(a,c){at=null;let l=n.call(this,a,c);return at&&l&&(Sa.set(l,at),at=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=>(at&&(l.metadataFlags=at[Su],l.localTime=at.localTime,l.residencyId=at.residencyId,at.expiresAt>=0&&(l.expiresAt=at.expiresAt),at=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,Vc.push(new WeakRef(this))),c.call(this)},a.prototype.done=function(){if(l.call(this),this.isDone)for(let u=0;u<Vc.length;u++){let d=Vc[u].deref();(!d||d.isDone||d.isCommitted)&&Vc.splice(u--,1)}},a.prototype.done.isTracked=!0}return e}function LA(e,t,r){return function(n,s,i,a,c=-1,l,u,d="put",f,m){f||l==null?gu=i?.localTime?IA|Fv:bA:gu=l?i?.localTime?IA|16384:Bv|16384:bA;let h=u?.expiresAt;if(h>=0&&(c|=u_),um=c,NA=h,i?.version===a&&l===!1)throw new Error("Must retain local time if version is not changed");let p={version:a,instructedWrite:gu>0},_,g=0;try{let y=i?.residencyId,T=u?.residencyId;T&&(wA=T,um|=CA,g|=Gc),y!==T&&(g|=qc,y||(y=0)),c&u_&&(g|=cm),u?.originatingOperation&&(g|=am),f&&(p.ifVersion=_=i?.version??null),i&&i.value&&i.metadataFlags&bn&&(r.getBinaryFast(i.localTime)||_a(i.value));let R;if(s!==void 0&&(R=jE(()=>e.put(n,s,p),n,e.rootStore),Bc&&(g|=bn)),l){let I=u?.user?.username;if(m&&(jE(()=>e.encoder.encode(m),n,e.rootStore),Bc&&(g|=bn)),e.encoder.hasStructureUpdate&&(g|=d_,e.encoder.hasStructureUpdate=!1),f&&i?.localTime){let P=i?.localTime,Y=r.get(P);if(Y){let te=vt(Y).previousLocalTime;return R=r.put(P,_u(a,t,n,te,u?.nodeId??server.replication.getThisNodeId(r)??0,I,d,lm,g,T,y,h),{ifVersion:_}),R}}R=r.put(s===void 0?xv:om,_u(a,t,n,i?.localTime?1:0,u?.nodeId??server.replication?.getThisNodeId(r)??0,I,d,lm,g,T,y,h,u?.originatingOperation),{append:d!=="invalidate",instructedWrite:!0,ifVersion:_})}return R}catch(y){throw y.message+=" id: "+n+" options: "+p,y}}}function Kc(e,t,r){if(t)return t.value&&t.metadataFlags&bn&&!e.auditStore.getBinaryFast(t.localTime)&&_a(t.value),e.remove(t.key,r)}var Uv,l_,c_,om,AA,xv,dZ,Su,fZ,dm,mZ,bA,Bv,hZ,Fv,IA,u_,CA,PA,d_,Sa,pZ,lm,gu,um,NA,wA,at,OA,Vc,$c=fe(()=>{Uv=require("msgpackr");lo();l_=w(z());Ss();Ss();c_=new Uint8Array([1,1,1,1,4,64,0,0]),om=new Uint8Array([1,1,1,1,1,0,0,0]),AA=new Uint8Array([1,1,1,1,3,64,0,0]),xv=new Uint8Array([1,1,1,1,0,64,0,0]),dZ=Symbol("local-timestamp"),Su=Symbol("metadata"),fZ=Symbol("entry"),dm=new Uint8Array(8),mZ=new DataView(dm.buffer,0,8),bA=0,Bv=0,hZ=1,Fv=3,IA=4,u_=16,CA=32,PA=1,d_=256,Sa=new WeakMap,gu=0,um=-1,NA=-1,wA=0,at=null,OA=class extends Uv.Encoder{static{o(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0;class r{static{o(this,"RecordObject")}getUpdatedTime(){return Sa.get(this)?.version}getExpiresAt(){return Sa.get(this)?.expiresAt}}t.structPrototype=r.prototype,super(t);let n=this.encode;this.encode=function(i,a){if(gu||um>=0){let c=0,l=gu;l&&(c+=8,gu=0);let u=um,d=NA,f=wA;u>=0&&(c+=4,um=-1,d>=0&&(c+=8,NA=-1),f&&(c+=4,wA=0));let m=pZ=n.call(this,i,a|2048|c);lm=m.subarray((m.start||0)+c,m.end);let h=m.start||0;return l&&(c_[4]=l,c_[5]=l>>8,m.set(c_,h),h+=8),Bc&&(u|=bn),u>=0&&((m.dataView||(m.dataView=new DataView(m.buffer,m.byteOffset,m.byteLength))).setUint32(h,u|o_<<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 lm=n.call(this,i,a),lm};let s=this.saveStructures;this.saveStructures=function(i,a){let c=s.call(this,i,a);return this.hasStructureUpdate=!0,c}}decode(t,r){at=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(dm,0,c),c+=8;else for(let m=0;m<8;m++)dm[m]=t[c++];l=EZ(),i=t[c]}let u,d;i<32&&(i===o_?(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&u_&&(u=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8),a&CA&&(d=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4));let f=Fc(()=>r?.valueAsBuffer?t.subarray(c,s):super.decode(t.subarray(c,s),s-c),this.rootStore);return at={localTime:l,[Su]:a,expiresAt:u,residencyId:d},f}return r?.valueAsBuffer?t:Fc(()=>super.decode(t,r),this.rootStore)}catch(c){return l_.error("Error decoding record",c,"data: "+t.slice(0,40).toString("hex")),null}}};o(EZ,"getTimestamp");o(f_,"handleLocalTimeForGets");Vc=[];setInterval(()=>{for(let e=0;e<Vc.length;e++){let t=Vc[e].deref();!t||t.isDone||t.isCommitted?Vc.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(l_.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):l_.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(LA,"recordUpdater");o(Kc,"removeEntry")});function vA(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],_=u(p);f=f.concat(_)}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?vA(f.conditions,f.operator,r,n,s,i,a,c):Au(f,n,f.descending||s.reverse===!0,r,s.allowFullScan,c,i)}o(u,"executeCondition");function d(f,m,h){return f.map((p,_)=>{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=mm(p,r,i,c,g,h);return m&&_<f.length-1&&h&&(h=IZ(r.primaryStore,p.estimated_count,h)),y}).filter(Boolean)}o(d,"mapConditionsToFilters")}function Au(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=Oi(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=Au({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=!!Oi(P.attributes,I.relationship.to)?.elements;te=RZ(te,I,P.primaryStore,x,Y)}if(I.relationship.from){let x=o($=>($?.key!==void 0&&($=$.key),Au({attribute:I.relationship.from,value:$},t,r,n,s,Y)),"searchEntry");I.elements?(i[c[0]]=Y,te=yZ(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,_;l instanceof Date&&(l=l.getTime());let g;switch(UA[u]||u){case"lt":m=!0,h=l;break;case"le":m=!0,h=l,p=!0;break;case"gt":m=l,_=!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]=wi.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",_=u==="gtlt"||u==="gtle";break;case"equals":case void 0:m=l,h=l,p=!0;break;case"ne":if(l===null){m=l,_=!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>Rs.MAX_SEARCH_KEY_LENGTH&&(m=m.slice(0,Rs.MAX_SEARCH_KEY_LENGTH)+Rs.OVERFLOW_MARKER,_=!1,y=mm(e,n,null,i,d)),typeof h=="string"&&h.length>Rs.MAX_SEARCH_KEY_LENGTH&&(h=h.slice(0,Rs.MAX_SEARCH_KEY_LENGTH)+Rs.OVERFLOW_MARKER,p=!0,y=y??mm(e,n,null,i,d)),r){let R=m;m=h,h=R,R=!_,_=!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??mm(e,n,null,i,d),!y)throw new qr.ClientError(`Unknown search operator ${e.comparator}`)}let T={start:m,end:h,inclusiveEnd:p,exclusiveStart:_,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:Ta.SKIP:new Promise((Y,te)=>setImmediate(()=>{try{Y(P&&y(P)?I:Ta.SKIP)}catch(x){te(x)}}))}:I=>I.value==null&&!(I.metadataFlags&(In|Ra))?Ta.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>Rs.MAX_SEARCH_KEY_LENGTH?P=n.primaryStore.get(I):P={[c]:R},this.isSync?y(P)?I:Ta.SKIP:new Promise((Y,te)=>setImmediate(()=>{try{Y(y(P)?I:Ta.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:Ta.SKIP:new Promise((P,Y)=>setImmediate(()=>{try{P(I&&y(I)?R:Ta.SKIP)}catch(te){Y(te)}}))})}function Oi(e,t){if(Array.isArray(t))if(t.length>1){let r=Oi(e,t[0]),n=(r?.definition?.tableClass||r?.elements?.definition?.tableClass)?.attributes??r?.properties;return n?Oi(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 RZ(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 yZ(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 mm(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=Oi(t.attributes,d),m=f.definition?.tableClass||f.elements.definition?.tableClass,h=n?.[d],p=mm({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 _=t.propertyResolvers?.[d];_.to&&(p.to=_.to);let g,y=o((R,I)=>{let P,Y;return _?_.returnDirect?(P=_(R,r,I),Y=at):(Y=_(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(_&&p.idFilter){if(!g)if(p.idFilter.idSet?.size===1){for(let $ of p.idFilter.idSet)e={attribute:_.from??t.primaryKey,value:$};g=u(_.from??t.primaryKey,p.idFilter,!0,!0)}else g=u(_.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()),UA[a]||a){case Rs.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,wi.compareKeys)(d,l[0])>=0&&(0,wi.compareKeys)(d,l[1])<=0,!0);case"gt":return u(c,d=>(0,wi.compareKeys)(d,l)>0);case"ge":return u(c,d=>(0,wi.compareKeys)(d,l)>=0);case"lt":return u(c,d=>(0,wi.compareKeys)(d,l)<0);case"le":return u(c,d=>(0,wi.compareKeys)(d,l)<=0);case"ne":return u(c,d=>(0,wi.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&&h_(t)(e),p=e.estimated_count>>4,(isNaN(p)||p>=i)&&(m=!1));let _=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&&++_/g*i>p)){let P=Au(e,r.transaction.getReadTxn(),!1,t),Y;y.to?Y=P.flatMap(x=>t.primaryStore.get(x)[y.to]):Y=P.map(bu);let te=new Set(Y);y.idFilter=x=>te.has(bu(x)),y.idFilter.idSet=te}return I}return o(y,"recordFilter"),s&&(y.idFilter=f),y}o(u,"attributeComparator")}function h_(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/go(e.primaryStore):i.estimated_count}return r.estimated_count=s,r.estimated_count}let n=r.comparator||r.search_type;if(n=UA[n]||n,n===Rs.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=Oi(e.attributes,s[0]),a=i.definition?.tableClass||i.elements.definition?.tableClass,c=h_(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*go(e.indices[i.relationship.from])/(go(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=go(e.primaryStore)-(i?i.getValuesCount(null):0):r.estimated_count=1/0}else if(n==="starts_with"||n==="prefix")r.estimated_count=SZ*go(e.primaryStore)+1;else if(n==="between")r.estimated_count=gZ*go(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=go(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=_Z*go(e.primaryStore)+1}typeof r.descending=="boolean"&&(r.estimated_count/=2)}return r.estimated_count}return o(t,"estimateConditionForTable"),t}function p_(e,t){if(e)if(So=e,Tu.lastIndex=0,AZ.test(e))try{if(t&&(t.conditions=[]),js=t??new yu,fm(js,""),Lr!==So.length&&Gt("Unable to parse query, unexpected end of query"),js.parseErrorMessage&&(js.parseError=new DA(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 '${So}'`,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 fm(e,t){let r=Tu,n,s,i,a,c,l=decodeURIComponent,u;for(;n=r.exec(So);){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=kv):(l=decodeURIComponent,i="equals",d||Gt("attribute must be specified before equality comparator"),s=Ru(d));break;case"==":case"!=":case"<":case"<=":case">":case">=":case"===":case"!==":i=TZ[f],l=MA[i]?kv:decodeURIComponent,d||Gt(`attribute must be specified before comparator ${f}`),s=Ru(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"&&Gv(p,d),s===""){let _=e.conditions[e.conditions.length-1];_.chainedConditions=_.chainedConditions||[],_.chainedConditions.push(p),_.operator=u}else m_(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(Ru(d)),s=void 0;break;case"(":Tu.lastIndex=Lr;let h=fm(d?[]:new yu,")");switch(d){case"":m_(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=qv(h);break;default:Gt(`unknown query function call ${d}`)}So[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"),Tu.lastIndex=Lr,m=fm([],"}"),m.name=d,e.push(m),So[Lr]===","?r.lastIndex=++Lr:a=!0;break;case"[":if(Tu.lastIndex=Lr,d?(m=fm(new yu,"]"),m.name=d):m=fm(e.conditions?new yu:[],"]"),e.conditions)if(m_(e,u),So[Lr]==="="){l=decodeURIComponent,i="equals",s=Ru(d),r.lastIndex=++Lr;break}else e.conditions.push(m),s=null;else e.push(m);So[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"&&Gv(p,d),m_(e,u),e.conditions.push(p)}else d&&Gt("no attribute or comparison specified");else(d||e.length>0&&c)&&e.push(Ru(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?bZ:Tu,r.lastIndex=Lr),Lr===So.length)return e}t&&Gt(`expected '${t}', but encountered end of string`)}function m_(e,t){e.conditions.length>0&&(e.operator?e.operator!==t&&Gt("Can not mix operators within a condition grouping"):e.operator=t)}function Ru(e){return e.indexOf(".")>-1?e.split(".").map(Ru):decodeURIComponent(e)}function kv(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 Gv(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 qv(e){let t=$v(e[0]);return e.length>1&&(t.next=qv(e.slice(1))),t}function $v(e){if(Array.isArray(e)){let t=$v(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 bu(e){return Array.isArray(e)?e.join("\0"):e}function go(e){let t=Date.now();return(e.estimatedEntryCountExpires||0)<t&&(e.estimatedEntryCount=e.getStats().entryCount,e.estimatedEntryCountExpires=t+1e4),e.estimatedEntryCount}function IZ(e,t,r){return t*r/go(e)}var qr,Rs,wi,Ta,_Z,gZ,SZ,TZ,MA,UA,DA,AZ,Tu,bZ,Lr,js,So,yu,E_=fe(()=>{qr=w(Ee()),Rs=w(kt()),wi=require("ordered-binary"),Ta=require("lmdb");hm();$c();_Z=.3,gZ=.1,SZ=.05,TZ={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},MA={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};o(vA,"executeConditions");o(Au,"searchByIndex");o(Oi,"findAttribute");o(RZ,"joinTo");o(yZ,"joinFrom");UA={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(mm,"filterByType");o(h_,"estimateCondition");DA=class extends qr.Violation{static{o(this,"SyntaxViolation")}},AZ=/[()[\]|!<>.]|(=\w*=)/,Tu=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,bZ=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/g;o(p_,"parseQuery");o(Gt,"recordError");o(fm,"parseBlock");o(m_,"assignOperator");o(Ru,"decodeProperty");o(kv,"typedDecoding");o(Gv,"wildcardDecoding");o(qv,"toSortObject");o($v,"toSortEntry");yu=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(bu,"flattenKey");o(go,"estimatedEntryCount");o(IZ,"intersectionEstimate")});var Vv,Qs,__=fe(()=>{Vv=w(Ys());ya();Qs=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,Vv._assignPackageExport)("Resource",Dr)});var jv={};Ce(jv,{MultiPartId:()=>g_,Resource:()=>Dr,contextStorage:()=>Nu,snakeCase:()=>wZ,transformForSelect:()=>S_});function wZ(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function Kv(e,t){if(Yc=!1,e==="")return null;if(e=e.slice(1),t.splitSegments){if(e.indexOf("/")===-1)return e===""?(Yc=!0,null):t.coerceId(decodeURIComponent(e));let r=e.split("/"),n=new g_;for(let s=0;s<r.length;s++){let i=r[s];if(!i&&s===r.length-1){Yc=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}else{if(e==="")return Yc=!0,null;e[e.length-1]==="/"&&(Yc=!0)}return t.coerceId(decodeURIComponent(e))}function Nn(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 co?a=i:d=i;else if(s&&typeof s=="object")d=s,s=void 0,c=d.getId?.()??d[this.primaryKey];else throw new Iu.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 _=c.indexOf("?");_>-1&&(l=this.parseQuery(c.slice(_+1),s),c=c.slice(0,_),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 _ of s){if(typeof _=="object"&&_)break;c.push(_)}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 Qs,l.id=c,u=!1)))}c===void 0&&(c=s.id??null,c==null&&(u=!0))}else c=s,l=new Qs,l.id=c,c==null&&(u=!0);l||(l=new Qs,l.id=c),u&&(l.isCollection=!0);let f;a||(a=Nu.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(_=>Nu.run(a,()=>p(_)),"runAction")),a?.transaction){let _=this.getResource(c,a,f);return _.then?_.then(h):h(_)}else return Mt(a,()=>{let _=this.getResource(c,a,f);return _.then?_.then(h):h(_)},f);function p(_){if(m!==!1&&a.authorize){a.authorize=!1;let g=t.type==="read"?_.allowRead(a.user,l,a):t.type==="update"?_.doesExist?.()===!1?_.allowCreate(a.user,d,a):_.allowUpdate(a.user,d,a):t.type==="create"?_.allowCreate(a.user,d,a):_.allowDelete(a.user,l,a);if(g?.then)return g.then(y=>{if(!y)throw new Iu.AccessViolation(a.user);return typeof d?.then=="function"?d.then(T=>e(_,l,a,T)):e(_,l,a,d)});if(!g)throw new Iu.AccessViolation(a.user)}return typeof d?.then=="function"?d.then(g=>e(_,l,a,g)):e(_,l,a,d)}o(p,"authorizeActionOnResource")}}function qn(e,t){let r=new Iu.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 xA(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 S_(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):xA(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(xA(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(xA(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]=S_(c.select||c,d)}let u=a(c.name);return l(u)}else return a(c);else return c}}o(i,"handleProperty")}var Yv,Wv,Iu,zv,Nu,NZ,Dr,Yc,g_,ya=fe(()=>{Yv=require("crypto");Kf();mu();Wv=w(Ys()),Iu=w(Ee());Dc();E_();zv=require("async_hooks");__();Nu=new zv.AsyncLocalStorage,NZ={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=Nn(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=S_(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=Nn(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):qn(t,"put")},{hasContent:!0,type:"update"});static patch=Nn(function(t,r,n,s){return t.patch?t.constructor.loadAsInstance===!1?t.patch(r,s):t.patch(s,r):qn(t,"patch")},{hasContent:!0,type:"update"});static delete=Nn(function(t,r,n,s){return t.delete?t.delete(r):qn(t,"delete")},{hasContent:!1,type:"delete"});static getNewId(){return(0,Yv.randomUUID)()}static create(t,r,n){n?n.getContext&&(n=n.getContext()):n=Nu.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),Mt(n,async()=>{let i=new this(s,n),a=await i.create?i.create(s,r):qn(i,"create");return n.newLocation=s??a?.[this.primaryKey],n.createdResource=!0,this.loadAsInstance===!1?a:i})}static invalidate=Nn(function(t,r,n,s){return t.invalidate?t.invalidate(r):qn(t,"delete")},{hasContent:!1,type:"update"});static post=Nn(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=Nn(function(t,r,n,s){return t.update(r,s)},{hasContent:!0,type:"create"});static connect=Nn(function(t,r,n,s){return t.connect?t.constructor.loadAsInstance===!1?t.connect(r,s):t.connect(s,r):qn(t,"connect")},{hasContent:!0,type:"read"});static subscribe=Nn(function(t,r,n,s){return t.subscribe?t.subscribe(r):qn(t,"subscribe")},{type:"read"});static publish=Nn(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):qn(t,"publish")},{hasContent:!0,type:"create"});static search=Nn(function(t,r,n){let s=t.search?t.search(r):qn(t,"search"),i=n.select;if(i&&n.hasOwnProperty("select")&&s!=null&&!s.selectApplied){let a=S_(i,t.constructor);return s.map(a)}return s},{type:"read"});static query=Nn(function(t,r,n,s){return t.search?t.constructor.loadAsInstance===!1?t.search(r,s):t.search(s,r):qn(t,"search")},{hasContent:!0,type:"read"});static copy=Nn(function(t,r,n,s){return t.copy?t.constructor.loadAsInstance===!1?t.copy(r,s):t.copy(s,r):qn(t,"copy")},{hasContent:!0,type:"create"});static move=Nn(function(t,r,n,s){return t.move?t.constructor.loadAsInstance===!1?t.move(r,s):t.move(s,r):qn(t,"move")},{hasContent:!0,type:"delete"});async post(t){if(this.#r)return(await this.constructor.create(this.#e,t,this.#t)).#e;qn(this,"post")}static isCollection(t){return t&&t.#r}get isCollection(){return this.#r}static coerceId(t){return t}static parseQuery(t,r){return p_(t,r)}static parsePath(t,r,n){let s=t.indexOf(".");if(s>-1){let a=t.slice(s+1),c=r?.headers&&NZ[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:Kv(t,this),isCollection:Yc}}let i=Kv(t,this);return Yc?{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 Gn}connect(t,r){return r?.subscribe!==!1?this.subscribe?.(r):new Gn}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,Wv._assignPackageExport)("Resource",Dr);o(wZ,"snakeCase");o(Kv,"pathToId");g_=class extends Array{static{o(this,"MultiPartId")}toString(){return this.join("/")}};o(Nn,"transactional");o(qn,"missingMethod");o(xA,"selectFromObject");o(S_,"transformForSelect")});var Wc,BA=fe(()=>{Wc=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 Xv={};Ce(Xv,{Resources:()=>T_,keyArrayToString:()=>wu,resetResources:()=>OZ,resources:()=>ys});function OZ(){return ys=new T_,ve.resources=ys,ys}function wu(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var Qv,Jv,T_,ys,Ou=fe(()=>{Dc();BA();Qv=w(z()),Jv=w(Ee());Pr();T_=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 Jv.ServerError(`Conflicting paths for ${t}`);Qv.default.error(c),i.Resource=new Wc(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 Mt(r,async()=>{let s=this.getMatch(t);if(s)return t=s.relativeURL,n(s.Resource,s.path,t)})}setRepresentation(t,r,n){}};o(OZ,"resetResources");o(wu,"keyArrayToString")});function kA(e,t,r,n,s){let i=e.primaryStore.env.path,a=e.primaryStore.tableId,c;s?.crossThreads===!1?(c=eU,CZ(e.primaryStore,e.auditStore)):(c=Zv,e.primaryStore.env.hasSubscriptionCommitListener||(e.primaryStore.env.hasSubscriptionCommitListener=!0,e.primaryStore.on("committed",()=>{tU(Zv[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=wu(t);let d=new HA(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 tU(e){if(!e)return;let t=e.auditStore;t.resetReadTxn(),rU(e.auditStore);let r;for(let{key:n,value:s}of t.getRange({start:e.lastTxnTime,exclusiveStart:!0})){e.lastTxnTime=n;let i=vt(s),a=e[i.tableId];if(!a)continue;let c=i.recordId,l=wu(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,FA.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,FA.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 CZ(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=eU[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{tU(l)}finally{r.threadLocalWrites[0]=l.lastTxnTime,r.unlock("thread-local-writes")}},"acquiredLock");r.attemptLock("thread-local-writes",u)&&u()})}}function rU(e){e.nextTransaction?.resolve();let t;e.nextTransaction=new Promise(r=>{t=r}),e.nextTransaction.resolve=t}function nU(e){return e.nextTransaction||(kA({primaryStore:e,auditStore:e},null,null,0,{scope:"full-database"}),rU(e)),e.nextTransaction}var FA,Zv,eU,HA,GA=fe(()=>{FA=w(z());mu();Ou();lo();Zv=Object.create(null),eU=Object.create(null);o(kA,"addSubscription");HA=class extends Gn{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(tU,"notifyFromTransactionData");o(CZ,"listenToCommits");o(rU,"nextTransaction");o(nU,"whenNextTransaction")});var iU=M((ANe,sU)=>{"use strict";var qA=class{static{o(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};sU.exports=qA});var aU=M((INe,oU)=>{"use strict";var $A=class{static{o(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};oU.exports=$A});var pm=M((wNe,lU)=>{"use strict";var cU=ce(),PZ=(k(),v(K)),{RecordEncoder:LZ}=($c(),v(Hv));cU.initSync();var DZ=cU.get(PZ.CONFIG_PARAMS.STORAGE_CACHING)!==!1,VA=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=DZ&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:LZ})}};lU.exports=VA});var Em=M((CNe,uU)=>{"use strict";var $n=ce(),As=(k(),v(K));$n.initSync();var R_=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=$n.get(As.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||$n.get(As.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||$n.get(As.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",$n.get(As.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=$n.get(As.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),$n.get(As.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=$n.get(As.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),$n.get(As.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=$n.get(As.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),$n.get(As.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=$n.get(As.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=$n.get(As.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};uU.exports=R_;R_.MAX_DBS=1e4});var Et=M((LNe,TU)=>{"use strict";var YA=require("lmdb"),Js=require("fs-extra"),Vn=require("path"),y_=Rn(),mU=z(),wn=en().LMDB_ERRORS_ENUM,A_=aU(),WA=pm(),hU=Em(),Aa=kt(),dU=(k(),v(K)),{table:MZ,resetDatabases:vZ}=(Le(),v(ft)),fU=ce(),Xs=Aa.INTERNAL_DBIS_NAME,pU=Aa.DBI_DEFINITION_NAME,UZ="data.mdb",xZ="lock.mdb",_m=".mdb",BZ="-lock",KA=class{static{o(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=bs(t,r),this.key_type=this.dbi[Aa.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[Aa.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new YA.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function b_(e,t){if(e===void 0)throw new Error(wn.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(wn.ENV_NAME_REQUIRED)}o(b_,"pathEnvNameValidation");async function zA(e,t,r=!0){try{await Js.access(e)}catch(n){throw n.code==="ENOENT"?new Error(wn.INVALID_BASE_PATH):n}try{let n=Vn.join(e,t+_m);return await Js.access(n,Js.constants.R_OK|Js.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await Js.access(Vn.join(e,t,UZ),Js.constants.R_OK|Js.constants.F_OK),Vn.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(wn.INVALID_ENVIRONMENT)}else throw new Error(wn.INVALID_ENVIRONMENT);throw n}}o(zA,"validateEnvironmentPath");function I_(e,t){if(y_.validateEnv(e),t===void 0)throw new Error(wn.DBI_NAME_REQUIRED)}o(I_,"validateEnvDBIName");async function FZ(e,t,r=!1,n=!1){b_(e,t);let s=Vn.basename(e);t=t.toString();let i=fU.get(dU.CONFIG_PARAMS.DATABASES);i||fU.setProperty(dU.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await zA(e,t,n),EU(e,t,r)}catch(a){if(a.message===wn.INVALID_ENVIRONMENT){let c=Vn.join(e,t);await Js.mkdirp(n?c:e);let l=new hU(n?c:c+_m,!1),u=YA.open(l);u.dbis=Object.create(null);let d=new WA(!1);u.openDB(Xs,d),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let f=jA(e,t,r);return u[Aa.ENVIRONMENT_NAME_KEY]=f,global.lmdb_map[f]=u,u}throw a}}o(FZ,"createEnvironment");async function HZ(e,t,r,n=!0){b_(e,t),t=t.toString();let s=Vn.join(e,t);return MZ({table:t,database:Vn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}o(HZ,"copyEnvironment");async function EU(e,t,r=!1){b_(e,t),t=t.toString();let n=jA(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 zA(e,t),i=Vn.join(e,t+_m),a=s!=i,c=new hU(s,a),l=YA.open(c);l.dbis=Object.create(null);let u=gU(l);for(let d=0;d<u.length;d++)bs(l,u[d]);return l[Aa.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}o(EU,"openEnvironment");async function kZ(e,t,r=!1){b_(e,t),t=t.toString();let n=Vn.join(e,t+_m),s=await zA(e,t);if(global.lmdb_map!==void 0){let i=jA(e,t,r);if(global.lmdb_map[i]){let a=global.lmdb_map[i];await _U(a),delete global.lmdb_map[i]}}await Js.remove(s),await Js.remove(s===n?s+BZ:Vn.join(Vn.dirname(s),xZ))}o(kZ,"deleteEnvironment");async function _U(e){y_.validateEnv(e);let t=e[Aa.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}o(_U,"closeEnvironment");function jA(e,t,r=!1){let s=`${Vn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}o(jA,"getCachedEnvironmentName");function GZ(e){y_.validateEnv(e);let t=Object.create(null),r=bs(e,Xs);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==Xs)try{t[n]=Object.assign(new A_,s)}catch{mU.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}o(GZ,"listDBIDefinitions");function gU(e){y_.validateEnv(e);let t=[],r=bs(e,Xs);for(let{key:n}of r.getRange({start:!1}))n!==Xs&&t.push(n);return t}o(gU,"listDBIs");function qZ(e,t){let n=bs(e,Xs).getEntry(t),s=new A_;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{mU.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}o(qZ,"getDBIDefinition");function SU(e,t,r,n=!r){if(I_(e,t),t=t.toString(),t===Xs)throw new Error(wn.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return bs(e,t)}catch(s){if(s.message===wn.DBI_DOES_NOT_EXIST){let i=new WA(r,n===!0),a=e.openDB(t,i),c=new A_(r===!0,n);return a[pU]=c,bs(e,Xs).putSync(t,c),e.dbis[t]=a,a}throw s}}o(SU,"createDBI");function bs(e,t){if(I_(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==Xs?r=qZ(e,t):r=new A_,r===void 0)throw new Error(wn.DBI_DOES_NOT_EXIST);let n;try{let s=new WA(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(wn.DBI_DOES_NOT_EXIST):s}return n[pU]=r,e.dbis[t]=n,n}o(bs,"openDBI");function $Z(e,t){I_(e,t),t=t.toString();let r=bs(e,t),n=r.getStats();return r[Aa.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}o($Z,"statDBI");async function VZ(e,t){try{let r=Vn.join(e,t+_m);return(await Js.stat(r)).size}catch{throw new Error(wn.INVALID_ENVIRONMENT)}}o(VZ,"environmentDataSize");function KZ(e,t){if(I_(e,t),t=t.toString(),t===Xs)throw new Error(wn.CANNOT_DROP_INTERNAL_DBIS_NAME);bs(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],bs(e,Xs).removeSync(t)}o(KZ,"dropDBI");function YZ(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{bs(e,i)}catch(a){if(a.message===wn.DBI_DOES_NOT_EXIST)SU(e,i,i!==t,i===t),n=!0;else throw a}}n&&vZ()}o(YZ,"initializeDBIs");TU.exports={openDBI:bs,openEnvironment:EU,createEnvironment:FZ,listDBIs:gU,listDBIDefinitions:GZ,createDBI:SU,dropDBI:KZ,statDBI:$Z,deleteEnvironment:kZ,initializeDBIs:YZ,TransactionCursor:KA,environmentDataSize:VZ,copyEnvironment:HZ,closeEnvironment:_U}});var AU=M((MNe,yU)=>{"use strict";var QA=Et(),WZ=z(),RU=en().LMDB_ERRORS_ENUM;yU.exports=zZ;async function zZ(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 QA.closeEnvironment(global.lmdb_map[a])}catch(c){if(c.message!==RU.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await QA.closeEnvironment(global.lmdb_map[n]),await QA.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==RU.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){WZ.error(t)}}o(zZ,"cleanLMDBMap")});var To=M((UNe,jZ)=>{jZ.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 Zs=M((xNe,NU)=>{var QZ=To(),{promisify:JZ}=require("util"),{getDatabases:IU}=(Le(),v(ft));NU.exports={setSchemaDataToGlobal:bU,getTableSchema:XZ,getSystemSchema:ZZ,setSchemaDataToGlobalAsync:JZ(bU)};function bU(e){global.hdb_schema=IU(),e&&e()}o(bU,"setSchemaDataToGlobal");function XZ(e,t,r){let n=IU()[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(XZ,"getTableSchema");function ZZ(){return QZ}o(ZZ,"getSystemSchema")});var HU=M((HNe,FU)=>{"use strict";var JA=require("recursive-iterator"),e6=require("alasql"),XA=require("clone"),wU=ie(),{handleHDBError:OU,hdbErrors:t6}=Ee(),{HDB_ERROR_MSGS:CU,HTTP_STATUS_CODES:PU}=t6,{getDatabases:r6}=(Le(),v(ft)),n6=["DISTINCT_ARRAY"],LU=Symbol("validateTables"),ZA=Symbol("validateTable"),FNe=Symbol("getAllColumns"),DU=Symbol("validateAllColumns"),N_=Symbol("findColumn"),MU=Symbol("validateOrderBy"),gm=Symbol("validateSegment"),eb=Symbol("validateColumn"),vU=Symbol("setColumnsForTable"),UU=Symbol("checkColumnsForAsterisk"),xU=Symbol("validateGroupBy"),BU=Symbol("hasColumns"),tb=class{static{o(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[LU](),this[UU](),this[DU]()}[LU](){if(this[BU]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[ZA](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[ZA](t.table)})}}[BU](){let t=!1,r=new JA(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[ZA](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=r6();if(!r[t.databaseid])throw OU(new Error,CU.SCHEMA_NOT_FOUND(t.databaseid),PU.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw OU(new Error,CU.TABLE_NOT_FOUND(t.databaseid,t.tableid),PU.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=XA(s);i.table=XA(t),this.attributes.push(i)})}[N_](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)}[UU](){let t=new JA(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[vU](r.tableid)}[vU](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new e6.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[DU](){this[gm](this.statement.columns,!1),this[gm](this.statement.joins,!1),this[gm](this.statement.where,!1),this[xU](this.statement.group,!1),this[gm](this.statement.order,!0)}[gm](t,r){if(!t)return;let n=new JA(t),s=[];for(let{node:i,path:a}of n)!wU.isEmpty(i)&&!wU.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[MU](i):s.push(this[eb](i)));return s}[xU](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&n6.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=XA(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[N_](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[N_](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`}[MU](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[eb](t)}[eb](t){let r=this[N_](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]}};FU.exports=tb});var GU=M((GNe,kU)=>{"use strict";var rb=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")}};kU.exports=rb});var $U=M(($Ne,qU)=>{"use strict";var nb=class{static{o(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};qU.exports=nb});var KU=M((KNe,VU)=>{"use strict";var sb=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}};VU.exports=sb});var WU=M((WNe,YU)=>{"use strict";var ib=class{static{o(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};YU.exports=ib});var jc=M((XNe,QU)=>{"use strict";var s6=Et(),i6=$U(),o6=KU(),a6=WU(),Ci=Rn(),Sm=en().LMDB_ERRORS_ENUM,c6=kt(),Ro=(k(),v(K)),l6=ie(),u6=require("uuid"),jNe=require("lmdb"),{handleHDBError:d6,hdbErrors:f6}=Ee(),{OVERFLOW_MARKER:QNe,MAX_SEARCH_KEY_LENGTH:JNe}=c6,zU=ce();zU.initSync();var w_=zU.get(Ro.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),ob=Ro.TIME_STAMP_NAMES_ENUM.CREATED_TIME,zc=Ro.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function m6(e,t,r,n,s=Ci.getNextMonotonicTime()){ub(e,t,r,n),ab(e,t,r);let i=new i6,a=[],c=[];for(let l=0;l<n.length;l++){let u=n[l];jU(u,!0,s);let d=h6(e,t,r,u),f=u[t];a.push(d),c.push(f)}return cb(a,c,n,i,s)}o(m6,"insertRecords");function h6(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][Ro.FUNC_VAL],n[a]=c)}let l=Ci.getIndexedValues(c),u=e.dbis[a];if(l){w_&&u.prefetch(l.map(d=>({key:d,value:s})),O_);for(let d=0,f=l.length;d<f;d++)u.put(l[d],s)}}w_&&e.dbis[t].prefetch([s],O_),e.dbis[t].put(s,n,n[zc])})}o(h6,"insertRecord");function p6(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}o(p6,"removeSkippedRecords");function jU(e,t,r){let n=r>0;(n||!Number.isInteger(e[zc]))&&(e[zc]=r||(r=Ci.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[ob]))&&(e[ob]=r||Ci.getNextMonotonicTime()):delete e[ob]}o(jU,"setTimestamps");function ab(e,t,r){r.indexOf(Ro.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(Ro.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(Ro.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(Ro.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),s6.initializeDBIs(e,t,r)}o(ab,"initializeTransaction");async function E6(e,t,r,n,s=Ci.getNextMonotonicTime()){ub(e,t,r,n),ab(e,t,r);let i=new o6,a=[],c=[],l=[];for(let u=0;u<n.length;u++){let d=n[u],f=d[t],m;try{m=lb(e,t,d,f,i,!0,s)}catch{i.skipped_hashes.push(f),a.push(u);continue}c.push(m),l.push(f)}return cb(c,l,n,i,s,a)}o(E6,"updateRecords");async function _6(e,t,r,n,s=Ci.getNextMonotonicTime()){try{ub(e,t,r,n)}catch(l){throw d6(l,l.message,f6.HTTP_STATUS_CODES.BAD_REQUEST)}ab(e,t,r);let i=new a6,a=[],c=[];for(let l=0;l<n.length;l++){let u=n[l],d;l6.isEmpty(u[t])?(d=u6.v4(),u[t]=d):d=u[t];let f=lb(e,t,u,d,i,!1,s);a.push(f),c.push(d)}return cb(a,c,n,i,s)}o(_6,"upsertRecords");async function cb(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||Ci.getNextMonotonicTime(),p6(r,i),n}o(cb,"finalizeWrite");function lb(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(jU(r,!d,a),Number.isInteger(r[zc])&&u[zc]>r[zc])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 _=r[p],g=e.dbis[p];if(g===void 0)continue;let y=u[p];if(typeof _=="function"){let R=_([[u]]);Array.isArray(R)&&(_=R[0][Ro.FUNC_VAL],r[p]=_)}if(_===y)continue;let T=Ci.getIndexedValues(y);if(T){w_&&g.prefetch(T.map(R=>({key:R,value:n})),O_);for(let R=0,I=T.length;R<I;R++)g.remove(T[R],n)}if(T=Ci.getIndexedValues(_),T){w_&&g.prefetch(T.map(R=>({key:R,value:n})),O_);for(let R=0,I=T.length;R<I;R++)g.put(T[R],n)}}let h={...u,...r};c.put(n,h,h[zc])},"doPut");return l?f=c.ifVersion(n,l.version,m):f=c.ifNoExists(n,m),f.then(h=>h?!0:lb(e,t,r,n,s,i,a))}o(lb,"updateUpsertRecord");function g6(e,t,r){if(Ci.validateEnv(e),t===void 0)throw new Error(Sm.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(Sm.WRITE_ATTRIBUTES_REQUIRED):new Error(Sm.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}o(g6,"validateBasic");function ub(e,t,r,n){if(g6(e,t,r),!Array.isArray(n))throw n===void 0?new Error(Sm.RECORDS_REQUIRED):new Error(Sm.RECORDS_MUST_BE_ARRAY)}o(ub,"validateWrite");function O_(){}o(O_,"noop");QU.exports={insertRecords:m6,updateRecords:E6,upsertRecords:_6}});var ct=M((ewe,JU)=>{"use strict";var On=require("validate.js");On.validators.type=function(e,t,r,n){return e===null||typeof e>"u"||On.validators.type.checks[t](e)?null:` must be a '${t}' value`};On.validators.type.checks={Object:o(function(e){return On.isObject(e)&&!On.isArray(e)},"Object"),Array:On.isArray,Integer:On.isInteger,Number:On.isNumber,String:On.isString,Date:On.isDate,Boolean:o(function(e){return typeof e=="boolean"},"Boolean")};On.validators.hasValidFileExt=function(e,t){return On.isString(e)?e===""?"can't be blank":t.filter(r=>e.endsWith(r)).length>0?null:`must include one of the following valid file extensions - '${t.join("', '")}'`:null};JU.exports={validateObject:S6,validateObjectAsync:T6,validateBySchema:R6};function S6(e,t){if(!e||!t)return new Error("validateObject parameters were null");let r=On(e,t,{format:"flat"});return r?new Error(r):null}o(S6,"validateObject");async function T6(e,t){if(!e||!t)return new Error("validateObject parameters were null");try{await On.async(e,t,{format:"flat"})}catch(r){let n=r.join(",");return new Error(n)}return null}o(T6,"validateObjectAsync");function R6(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}o(R6,"validateBySchema")});var ZU=M((rwe,XU)=>{"use strict";var y6=require("uuid"),db=class{static{o(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||y6.v4(),this.schema_table=`${this.schema}.${this.table}`}};XU.exports=db});var C_=M((swe,ex)=>{"use strict";var A6=ZU(),fb=class extends A6{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}};ex.exports=fb});var rx=M((owe,tx)=>{"use strict";tx.exports=I6;var b6="inserted";function I6(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===b6?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}o(I6,"returnObject")});var P_=M((lwe,sx)=>{"use strict";var N6=(k(),v(K)),mb=Et(),w6=jc(),{getSystemSchemaPath:O6,getSchemaPath:C6}=yt(),cwe=To(),{validateBySchema:P6}=ct(),Tm=require("joi"),L6=C_(),D6=rx(),{handleHDBError:M6,hdbErrors:v6,ClientError:U6}=Ee(),nx=ie(),{HTTP_STATUS_CODES:x6}=v6,B6="inserted";sx.exports=F6;async function F6(e){let t=P6(e,Tm.object({database:Tm.string(),schema:Tm.string(),table:Tm.string().required(),attribute:Tm.string().required()}));if(t)throw new U6(t.message);let r=!e.skip_table_check&&nx.checkGlobalSchemaTable(e.schema,e.table);if(r)throw M6(new Error,r,x6.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=nx.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 L6(e.schema,e.table,e.attribute,e.id);try{let i=await mb.openEnvironment(C6(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}`);mb.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let a=await mb.openEnvironment(O6(),N6.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await w6.insertRecords(a,HDB_TABLE_INFO.hash_attribute,hdbAttributeAttributes,[s]);return D6(B6,c,{records:[s]},l)}catch(i){throw i}}o(F6,"lmdbCreateAttribute")});var Li=M((dwe,ox)=>{"use strict";var ix=ie(),H6=(k(),v(K)),Cu=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Pi=require("joi"),ba={schema_format:{pattern:Cu,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},k6=Pi.alternatives(Pi.string().min(1).max(ba.schema_length.maximum).pattern(Cu).messages({"string.pattern.base":"{:#label} "+ba.schema_format.message}),Pi.number(),Pi.array()).required(),G6=Pi.alternatives(Pi.string().min(1).max(ba.schema_length.maximum).pattern(Cu).messages({"string.pattern.base":"{:#label} "+ba.schema_format.message}),Pi.number()),q6=Pi.alternatives(Pi.string().min(1).max(ba.schema_length.maximum).pattern(Cu).messages({"string.pattern.base":"{:#label} "+ba.schema_format.message}),Pi.number()).required();function $6(e,t){return t?typeof t!="string"?`'${property_name}' must be a string`:t.length?t.length>ba.schema_length.maximum?`'${property_name}' maximum of 250 characters`:Cu.test(t)?"":`'${property_name}' has illegal characters`:`'${property_name}' must be at least one character`:`'${property_name}' is required`}o($6,"checkValidTable");function V6(e,t){return ix.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}o(V6,"validateSchemaExists");function K6(e,t){let r=t.state.ancestors[0].schema;return ix.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}o(K6,"validateTableExists");function Y6(e,t){return e.toLowerCase()===H6.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${hdb_terms.SYSTEM_SCHEMA_NAME}' name is reserved`):e}o(Y6,"validateSchemaName");ox.exports={commonValidators:ba,schemaRegex:Cu,hdbSchemaTable:k6,validateSchemaExists:V6,validateTableExists:K6,validateSchemaName:Y6,checkValidTable:$6,hdbDatabase:G6,hdbTable:q6}});var pb=M((mwe,cx)=>{var{hdbTable:W6,hdbDatabase:ax}=Li(),z6=ct(),hb=require("joi"),j6={undefined:"undefined",null:"null"},Q6=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||j6[a]!==void 0)&&(s===void 0?s=`Invalid attribute name: '${a}'`:s+=`. Invalid attribute name: '${a}'`)}return s?t.message(s):e},"customRecordsVal"),J6=hb.object({database:ax,schema:ax,table:W6,records:hb.array().items(hb.object().custom(Q6)).required()});cx.exports=function(e){return z6.validateBySchema(e,J6)}});var Rm=M((Ewe,ux)=>{"use strict";var yo=ie(),lx=z(),pwe=pb(),{getDatabases:X6}=(Le(),v(ft)),{ClientError:Qc}=Ee();ux.exports=Z6;function Z6(e){if(yo.isEmpty(e))throw new Qc("invalid update parameters defined.");if(yo.isEmptyOrZeroLength(e.schema))throw new Qc("invalid schema specified.");if(yo.isEmptyOrZeroLength(e.table))throw new Qc("invalid table specified.");if(!Array.isArray(e.records))throw new Qc("records must be an array");let t=X6()[e.schema]?.[e.table];if(yo.isEmpty(t))throw new Qc(`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&&yo.isEmptyOrZeroLength(a[r]))throw lx.error("a valid hash attribute must be provided with update record:",a),new Qc("a valid hash attribute must be provided with update record, check log for more info");if(!yo.isEmptyOrZeroLength(a[r])&&(a[r]==="null"||a[r]==="undefined"))throw lx.error(`a valid hash value must be provided with ${e.operation} record:`,a),new Qc(`Invalid hash value: '${a[r]}' is not a valid hash attribute value, check log for more info`);!yo.isEmpty(a[r])&&a[r]!==""&&n.has(yo.autoCast(a[r]))&&(a.skip=!0),n.add(yo.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(Z6,"insertUpdateValidate")});var L_=M((gwe,fx)=>{"use strict";var dx=ie(),e8=(k(),v(K)),t8=z(),r8=P_(),n8=C_(),s8=Ao(),{SchemaEventMsg:i8}=ei(),o8="already exists in";fx.exports=a8;async function a8(e,t,r){if(dx.isEmptyOrZeroLength(r))return r;let n=[];dx.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 c8(e,t.schema,t.name,i)})),s}o(a8,"lmdbCheckForNewAttributes");async function c8(e,t,r,n){let s=new n8(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await l8(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(o8))t8.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}o(c8,"createNewAttribute");async function l8(e){let t;return t=await r8(e),s8.signalSchemaChange(new i8(process.pid,e8.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}o(l8,"createAttribute")});var Pu=M((Twe,mx)=>{"use strict";var Eb=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}};mx.exports=Eb});var px=M((ywe,hx)=>{"use strict";var u8=Pu(),d8=(k(),v(K)).OPERATIONS_ENUM,_b=class extends u8{static{o(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(d8.INSERT,r,n,s,i),this.records=t}};hx.exports=_b});var _x=M((bwe,Ex)=>{"use strict";var f8=Pu(),m8=(k(),v(K)).OPERATIONS_ENUM,gb=class extends f8{static{o(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,a=void 0){super(m8.UPDATE,n,s,i,a),this.records=t,this.original_records=r}};Ex.exports=gb});var Sx=M((Nwe,gx)=>{"use strict";var h8=Pu(),p8=(k(),v(K)).OPERATIONS_ENUM,Sb=class extends h8{static{o(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,a=void 0){super(p8.UPSERT,n,s,i,a),this.records=t,this.original_records=r}};gx.exports=Sb});var Rx=M((Owe,Tx)=>{"use strict";var E8=Pu(),_8=(k(),v(K)).OPERATIONS_ENUM,Tb=class extends E8{static{o(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(_8.DELETE,n,s,t,i),this.original_records=r}};Tx.exports=Tb});var ym=M((Lwe,Ix)=>{"use strict";var Pwe=require("path"),yx=Et(),g8=px(),S8=_x(),T8=Sx(),R8=Rx(),Lu=kt(),Ax=ie(),{CONFIG_PARAMS:y8}=(k(),v(K)),bx=ce();bx.initSync();var D_=(k(),v(K)).OPERATIONS_ENUM,{getTransactionAuditStorePath:A8}=yt();Ix.exports=b8;async function b8(e,t){if(bx.get(y8.LOGGING_AUDITLOG)===!1)return;let r=A8(e.schema,e.table),n=await yx.openEnvironment(r,e.table,!0),s=I8(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){yx.initializeDBIs(n,Lu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Lu.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[Lu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[Lu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),Ax.isEmpty(s.user_name)||n.dbis[Lu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let a=0;a<s.hash_values.length;a++)n.dbis[Lu.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[a],i)})}}o(b8,"writeTransaction");function I8(e,t){let r=Ax.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===D_.INSERT)return new g8(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===D_.UPDATE)return new S8(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===D_.UPSERT)return new T8(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===D_.DELETE)return new R8(t.deleted,t.original_records,r,t.txn_time,e.__origin)}o(I8,"createTransactionObject")});var Rb=M((vwe,Nx)=>{"use strict";var N8=Rm(),Mwe=qf(),Am=(k(),v(K)),w8=$f(),O8=jc().insertRecords,C8=Et(),P8=z(),L8=L_(),{getSchemaPath:D8}=yt(),M8=ym();Nx.exports=v8;async function v8(e){try{let{schemaTable:t,attributes:r}=N8(e);w8(e,r,t.hash_attribute),e.schema!==Am.SYSTEM_SCHEMA_NAME&&(r.includes(Am.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(Am.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(Am.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(Am.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await L8(e.hdb_auth_header,t,r),s=D8(e.schema,e.table),i=await C8.openEnvironment(s,e.table),a=await O8(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await M8(e,a)}catch(c){P8.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(v8,"lmdbCreateRecords")});var Cx=M((xwe,Ox)=>{"use strict";var wx=(k(),v(K)),U8=Rb(),x8=qf(),B8=require("fs-extra"),{getSchemaPath:F8}=yt();Ox.exports=H8;async function H8(e){let t=[{name:e.schema,createddate:Date.now()}],r=new x8(wx.SYSTEM_SCHEMA_NAME,wx.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await U8(r),await B8.mkdirp(F8(e.schema))}o(H8,"lmdbCreateSchema")});var Lx=M((Fwe,Px)=>{"use strict";var yb=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}};Px.exports=yb});var Ux=M(($we,vx)=>{"use strict";var Dx=Et(),Ab=Rn(),bb=en().LMDB_ERRORS_ENUM,k8=kt(),Mx=z(),kwe=ie(),G8=require("lmdb"),q8=Lx(),$8=(k(),v(K)),{OVERFLOW_MARKER:Gwe,MAX_SEARCH_KEY_LENGTH:qwe}=k8,V8=$8.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function K8(e,t,r,n){if(Ab.validateEnv(e),t===void 0)throw new Error(bb.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(bb.IDS_REQUIRED):new Error(bb.IDS_MUST_BE_ITERABLE);try{let s=Dx.listDBIs(e);Dx.initializeDBIs(e,t,s);let i=new q8,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[V8]>n){i.skipped.push(a);continue}let _=e.dbis[t].ifVersion(a,G8.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=Ab.getIndexedValues(R);if(I)for(let P=0,Y=I.length;P<Y;P++)T.remove(I[P],a)}catch{Mx.warn(`cannot delete from attribute: ${y}, ${R}:${a}`)}}});c.push(_),l.push(a),i.original_records.push(p)}catch(p){Mx.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=Ab.getNextMonotonicTime(),i}catch(s){throw s}}o(K8,"deleteRecords");vx.exports={deleteRecords:K8}});var bm=M((Kwe,Bx)=>{"use strict";var Du=ie(),Y8=Ux(),W8=Et(),{getSchemaPath:z8}=yt(),j8=ym(),Q8=z();Bx.exports=J8;async function J8(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(Du.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(Du.isEmptyOrZeroLength(e.hash_values)&&!Du.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];Du.isEmpty(l)||e.hash_values.push(l)}}if(Du.isEmptyOrZeroLength(e.hash_values))return xx([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(Du.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=z8(e.schema,e.table),i=await W8.openEnvironment(s,e.table),a=await Y8.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await j8(e,a)}catch(c){Q8.error(`unable to write transaction due to ${c.message}`)}return xx(a.deleted,a.skipped,a.txn_time)}catch(s){throw s}}o(J8,"lmdbDeleteRecords");function xx(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(xx,"createDeleteResponse")});var Nb=M((zwe,Fx)=>{"use strict";var X8=(k(),v(K)),Wwe=Rn();function Ib(e,t){let r=Object.create(null);if(t.length===1&&X8.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(Ib,"parseRow");function Z8(e,t,r,n){let s=Ib(r,e);n.push(s)}o(Z8,"searchAll");function e5(e,t,r,n){let s=Ib(r,e);n[t]=s}o(e5,"searchAllToMap");function t5(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}o(t5,"iterateDBI");function Jc(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(Jc,"pushResults");function r5(e,t,r,n,s,i){t.toString().endsWith(e)&&Jc(t,r,n,s,i)}o(r5,"endsWith");function n5(e,t,r,n,s,i){t.toString().includes(e)&&Jc(t,r,n,s,i)}o(n5,"contains");function s5(e,t,r,n,s,i){t>e&&Jc(t,r,n,s,i)}o(s5,"greaterThanCompare");function i5(e,t,r,n,s,i){t>=e&&Jc(t,r,n,s,i)}o(i5,"greaterThanEqualCompare");function o5(e,t,r,n,s,i){t<e&&Jc(t,r,n,s,i)}o(o5,"lessThanCompare");function a5(e,t,r,n,s,i){t<=e&&Jc(t,r,n,s,i)}o(a5,"lessThanEqualCompare");Fx.exports={parseRow:Ib,searchAll:Z8,searchAllToMap:e5,iterateDBI:t5,endsWith:r5,contains:n5,greaterThanCompare:s5,greaterThanEqualCompare:i5,lessThanCompare:o5,lessThanEqualCompare:a5,pushResults:Jc}});var Mu=M((Zwe,Kx)=>{"use strict";var Ia=Et(),Qwe=z(),Kn=Rn(),M_=kt(),Qt=en().LMDB_ERRORS_ENUM,Jwe=ie(),c5=(k(),v(K)),v_=Nb(),{parseRow:l5}=v_,Xwe=require("lmdb"),{OVERFLOW_MARKER:Hx,MAX_SEARCH_KEY_LENGTH:u5}=M_;function kx(e,t,r,n=!1,s=void 0,i=void 0){return Xc(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(kx,"iterateFullIndex");function Im(e,t,r,n,s,i=!1,a=void 0,c=void 0,l=!1,u=!1){return Xc(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(Im,"iterateRangeBetween");function Xc(e,t,r,n){let s=e.database||e,i=Ia.openDBI(s,r);i[M_.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&Ia.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(Xc,"setupTransaction");function Gx(e,t,r,n){let s;return function(i,a){if(typeof i=="string"&&i.endsWith(Hx)){if(!s)if(r)s=Ia.openDBI(e,r);else{let l=Ia.listDBIs(e);for(let u=0,d=l.length;u<d&&(s=Ia.openDBI(e,l[u]),!s[M_.DBI_DEFINITION_NAME].is_hash_attribute);u++);}i=s.get(a,{transaction:t,lazy:!0})[n]}return i}}o(Gx,"getOverflowCheck");function d5(e,t,r,n=!1,s=void 0,i=void 0){if(Kn.validateEnv(e),t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);return Xc(e,t,t,(a,c,l)=>(U_(r),r=Nm(l,r),c.getRange({transaction:a,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(u=>l5(u.value,r))))}o(d5,"searchAll");function f5(e,t,r,n=!1,s=void 0,i=void 0){if(Kn.validateEnv(e),t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);U_(r),r=Nm(e.database||e,r);let a=new Map;for(let{key:c,value:l}of kx(e,t,t,n,s,i))a.set(c,v_.parseRow(l,r));return a}o(f5,"searchAllToMap");function m5(e,t,r=!1,n=void 0,s=void 0){if(Kn.validateEnv(e),t===void 0)throw new Error(Qt.ATTRIBUTE_REQUIRED);let i=Object.create(null),a=kx(e,void 0,t,r,n,s),c=a.transaction,l=Gx(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(m5,"iterateDBI");function h5(e,t){if(Kn.validateEnv(e),t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);return Ia.statDBI(e,t).entryCount}o(h5,"countAll");function p5(e,t,r,n,s=!1,i=void 0,a=void 0){return Na(e,r,n),Xc(e,t,r,(c,l,u,d)=>(n=Kn.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(p5,"equals");function E5(e,t,r){return Na(e,t,r),Ia.openDBI(e,t).getValuesCount(r)}o(E5,"count");function _5(e,t,r,n,s=!1,i=void 0,a=void 0){return Na(e,r,n),Xc(e,null,r,(c,l)=>{n=Kn.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(_5,"startsWith");function g5(e,t,r,n,s=!1,i=void 0,a=void 0){return qx(e,t,r,n,s,i,a,!0)}o(g5,"endsWith");function qx(e,t,r,n,s=!1,i=void 0,a=void 0,c=!1){return Na(e,r,n),Xc(e,null,r,(l,u,d,f)=>{let m=Gx(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(Hx)?u.getValues(h,{transaction:l}).map(_=>{let g=m(h,_);if(c?g.endsWith(n):g.includes(n))return{key:g,value:_}}).filter(_=>_):(c?p.endsWith(n):p.includes(n))?u[M_.DBI_DEFINITION_NAME].is_hash_attribute?{key:h,value:h}:u.getValues(h,{transaction:l}).map(_=>({key:h,value:_})):[]}).slice(a,i===void 0?void 0:i+(a||0))})}o(qx,"contains");function S5(e,t,r,n,s=!1,i=void 0,a=void 0){Na(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),Im(e,t,r,n,l,s,i,a,!0,!1)}o(S5,"greaterThan");function T5(e,t,r,n,s=!1,i=void 0,a=void 0){Na(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),Im(e,t,r,n,l,s,i,a,!1,!1)}o(T5,"greaterThanEqual");function R5(e,t,r,n,s=!1,i=void 0,a=void 0){Na(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),Im(e,t,r,l,n,s,i,a,!1,!0)}o(R5,"lessThan");function y5(e,t,r,n,s=!1,i=void 0,a=void 0){Na(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),Im(e,t,r,l,n,s,i,a,!1,!1)}o(y5,"lessThanEqual");function A5(e,t,r,n,s,i=!1,a=void 0,c=void 0){if(Kn.validateEnv(e),r===void 0)throw new Error(Qt.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(Qt.START_VALUE_REQUIRED);if(s===void 0)throw new Error(Qt.END_VALUE_REQUIRED);if(n=Kn.convertKeyValueToWrite(n),s=Kn.convertKeyValueToWrite(s),n>s)throw new Error(Qt.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return Im(e,t,r,n,s,i,a,c)}o(A5,"between");function b5(e,t,r,n){Kn.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);if(U_(r),r=Nm(s,r),n===void 0)throw new Error(Qt.ID_REQUIRED);let a=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(a=v_.parseRow(c,r)),a}o(b5,"searchByHash");function I5(e,t,r){Kn.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Qt.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}o(I5,"checkHashExists");function N5(e,t,r,n,s=[]){return Vx(e,t,r,n,s),$x(e,t,r,n,s).map(i=>i[1])}o(N5,"batchSearchByHash");function w5(e,t,r,n,s=[]){Vx(e,t,r,n,s);let i=new Map;for(let[a,c]of $x(e,t,r,n,s))i.set(a,c);return i}o(w5,"batchSearchByHashToMap");function $x(e,t,r,n,s=[]){return Xc(e,t,t,(i,a,c)=>{r=Nm(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,v_.parseRow(d,r)];s.push(u)}).filter(u=>u)})}o($x,"batchHashSearch");function Vx(e,t,r,n,s){if(Kn.validateEnv(e),t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);if(U_(r),n==null)throw new Error(Qt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(Qt.IDS_MUST_BE_ITERABLE)}o(Vx,"initializeBatchSearchByHash");function U_(e){if(!Array.isArray(e))throw e===void 0?new Error(Qt.FETCH_ATTRIBUTES_REQUIRED):new Error(Qt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}o(U_,"validateFetchAttributes");function Na(e,t,r){if(Kn.validateEnv(e),t===void 0)throw new Error(Qt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Qt.SEARCH_VALUE_REQUIRED);if(r?.length>u5)throw new Error(Qt.SEARCH_VALUE_TOO_LARGE)}o(Na,"validateComparisonFunctions");function Nm(e,t){return t.length===1&&c5.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=Ia.listDBIs(e)),t}o(Nm,"setGetWholeRowAttributes");Kx.exports={searchAll:d5,searchAllToMap:f5,count:E5,countAll:h5,equals:p5,startsWith:_5,endsWith:g5,contains:qx,searchByHash:b5,setGetWholeRowAttributes:Nm,batchSearchByHash:N5,batchSearchByHashToMap:w5,checkHashExists:I5,iterateDBI:m5,greaterThan:S5,greaterThanEqual:T5,lessThan:R5,lessThanEqual:y5,between:A5}});var vu=M((tOe,Qx)=>{var Yx=require("lodash"),Wx=ct(),$e=require("joi"),O5=ie(),{hdbSchemaTable:wm,checkValidTable:zx,hdbTable:jx,hdbDatabase:x_}=Li(),{handleHDBError:C5,hdbErrors:P5}=Ee(),{getDatabases:L5}=(Le(),v(ft)),{HTTP_STATUS_CODES:D5}=P5,M5=$e.object({database:x_,schema:x_,table:jx,search_attribute:wm,search_value:$e.any().required(),get_attributes:$e.array().min(1).items($e.alternatives(wm,$e.object())).optional(),desc:$e.bool(),limit:$e.number().integer().min(1),offset:$e.number().integer().min(0)}),v5=$e.object({database:x_,schema:x_,table:jx,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(wm,$e.object())).optional(),sort:$e.object({attribute:$e.alternatives(wm,$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(wm,$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()});Qx.exports=function(e,t){let r=null;switch(t){case"value":r=Wx.validateBySchema(e,M5);break;case"hashes":let i=function(a){s?s+=". "+a:s=a};var n=i;o(i,"addError");let s;i(zx("database",e.schema)),i(zx("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=Wx.validateBySchema(e,v5);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=O5.checkGlobalSchemaTable(e.schema,e.table);if(s)return C5(new Error,s,D5.NOT_FOUND);let a=L5()[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=Yx.filter(c,d=>d!=="*"&&!d.startsWith?.("$")&&d.attribute!=="*"&&!Array.isArray(d)&&!d.name&&!Yx.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 wb=M((nOe,Jx)=>{"use strict";var U5=Et(),x5=vu(),{getSchemaPath:B5}=yt();Jx.exports=F5;function F5(e){let t=x5(e,"hashes");if(t)throw t;let r=B5(e.schema,e.table);return U5.openEnvironment(r,e.table)}o(F5,"initialize")});var Ob=M((iOe,Xx)=>{"use strict";var H5=Mu(),k5=wb();Xx.exports=G5;async function G5(e){let t=await k5(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return H5.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}o(G5,"lmdbGetDataByHash")});var Uu=M((aOe,Zx)=>{"use strict";var Cb=class{static{o(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};Zx.exports=Cb});var t0=M((uOe,e0)=>{"use strict";var lOe=Uu(),q5=Mu(),$5=wb();e0.exports=V5;async function V5(e){let t=await $5(e),r=global.hdb_schema[e.schema][e.table];return q5.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}o(V5,"lmdbSearchByHash")});var ti=M((fOe,r0)=>{"use strict";var Pb=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}};r0.exports=Pb});var B_=M((hOe,c0)=>{"use strict";var rn=Mu(),K5=Et(),Y5=ie(),Ve=kt(),Zc=(k(),v(K)),W5=To(),n0=en().LMDB_ERRORS_ENUM,{getSchemaPath:z5}=yt(),bo=Zc.SEARCH_WILDCARDS;async function j5(e,t,r){let n;e.schema===Zc.SYSTEM_SCHEMA_NAME?n=W5[e.table]:n=global.hdb_schema[e.schema][e.table];let s=a0(e,n.hash_attribute,r,t);return i0(e,s,n.hash_attribute,r)}o(j5,"prepSearch");async function i0(e,t,r,n){let s=z5(e.schema,e.table),i=await K5.openEnvironment(s,e.table),a=o0(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(Q5(e,r)===!1){let d=e.search_attribute;if(d===r)return n?s0(a,()=>!0):a.map(m=>({[r]:m.key}));let f=o(m=>({[r]:m.value,[d]:m.key}),"toObject");return n?s0(a,f):a.map(f)}let u=e.search_attribute===r?a.map(d=>d.key):a.map(d=>d.value);return n===!0?rn.batchSearchByHashToMap(c,r,e.get_attributes,u):rn.batchSearchByHash(c,r,e.get_attributes,u)}o(i0,"executeSearch");function o0(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=rn.equals(e,i,t.search_attribute,t.search_value,a,c,l);break;case Ve.SEARCH_TYPES.CONTAINS:s=rn.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=rn.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=rn.startsWith(e,i,t.search_attribute,t.search_value,a,c,l);break;case Ve.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return rn.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case Ve.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return rn.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case Ve.SEARCH_TYPES.SEARCH_ALL:return rn.searchAll(e,n,t.get_attributes,a,c,l);case Ve.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return rn.searchAllToMap(e,n,t.get_attributes,a,c,l);case Ve.SEARCH_TYPES.BETWEEN:s=rn.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=rn.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=rn.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=rn.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=rn.lessThanEqual(e,i,t.search_attribute,t.search_value,a,c,l);break;default:return Object.create(null)}return s}o(o0,"searchByType");function s0(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}o(s0,"createMapFromIterable");function Q5(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(Q5,"checkToFetchMore");function a0(e,t,r,n){if(Y5.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),bo.indexOf(s)>-1)return r===!0?Ve.SEARCH_TYPES.SEARCH_ALL_TO_MAP:Ve.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(bo[0])<0&&s.indexOf(bo[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(bo.indexOf(i)>=0&&bo.indexOf(a)>=0)return e.search_value=e.search_value.slice(1,-1),Ve.SEARCH_TYPES.CONTAINS;if(bo.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),Ve.SEARCH_TYPES.ENDS_WITH;if(bo.indexOf(a)>=0)return e.search_value=e.search_value.slice(0,-1),Ve.SEARCH_TYPES.STARTS_WITH;if(s.includes(bo[0])||s.includes(bo[1]))return Ve.SEARCH_TYPES.EQUALS;throw new Error(n0.UNKNOWN_SEARCH_TYPE)}else switch(n){case Zc.VALUE_SEARCH_COMPARATORS.BETWEEN:return Ve.SEARCH_TYPES.BETWEEN;case Zc.VALUE_SEARCH_COMPARATORS.GREATER:return Ve.SEARCH_TYPES.GREATER_THAN;case Zc.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return Ve.SEARCH_TYPES.GREATER_THAN_EQUAL;case Zc.VALUE_SEARCH_COMPARATORS.LESS:return Ve.SEARCH_TYPES.LESS_THAN;case Zc.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return Ve.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(n0.UNKNOWN_SEARCH_TYPE)}}o(a0,"createSearchTypeFromSearchObject");c0.exports={executeSearch:i0,createSearchTypeFromSearchObject:a0,prepSearch:j5,searchByType:o0}});var u0=M((_Oe,l0)=>{"use strict";var EOe=ti(),J5=vu(),X5=ie(),Z5=(k(),v(K)),e9=B_();l0.exports=t9;function t9(e,t){if(!X5.isEmpty(t)&&Z5.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=J5(e,"value");if(n)throw n;return e9.prepSearch(e,t,!0)}o(t9,"lmdbGetDataByValue")});var Om=M((TOe,d0)=>{"use strict";var SOe=ti(),r9=vu(),n9=ie(),s9=(k(),v(K)),i9=B_();d0.exports=o9;async function o9(e,t){if(!n9.isEmpty(t)&&s9.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=r9(e,"value");if(n)throw n;return i9.prepSearch(e,t,!1)}o(o9,"lmdbSearchByValue")});var m0=M((AOe,f0)=>{"use strict";var yOe=kt(),Lb=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}},Db=class{static{o(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},Mb=class{static{o(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};f0.exports={SearchByConditionsObject:Lb,SearchCondition:Db,SortAttribute:Mb}});var g0=M((wOe,_0)=>{"use strict";var IOe=m0().SearchByConditionsObject,a9=ti(),c9=vu(),vb=Mu(),F_=kt(),{Resource:NOe}=(ya(),v(jv)),E0=B_(),l9=Nb(),u9=require("lodash"),{getSchemaPath:d9}=yt(),h0=Et(),{handleHDBError:f9,hdbErrors:m9}=Ee(),{HTTP_STATUS_CODES:h9}=m9,p9=1e8;_0.exports=E9;async function E9(e){let t=c9(e,"conditions");if(t)throw f9(t,t.message,h9.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=d9(e.schema,e.table),n=await h0.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let u of e.conditions)h0.openDBI(n,u.search_attribute);let i=u9.sortBy(e.conditions,u=>{if(u.estimated_count===void 0){let d=u.search_type;d===F_.SEARCH_TYPES.EQUALS?u.estimated_count=vb.count(n,u.search_attribute,u.search_value):d===F_.SEARCH_TYPES.CONTAINS||d===F_.SEARCH_TYPES.ENDS_WITH?u.estimated_count=1/0:u.estimated_count=p9}return u.estimated_count}),a=n.useReadTransaction();a.database=n;let c=await p0(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(E0.filterByType),f=d.length,m=vb.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=>l9.parseRow(h,m))}else{for(let f=1;f<i.length;f++){let m=i[f],h=await p0(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=vb.batchSearchByHash(a,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{a.done()},l}o(E9,"lmdbSearchByConditions");async function p0(e,t,r,n){let s=new a9(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===F_.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,E0.searchByType(e,s,i,n).map(a=>a.value)}o(p0,"executeConditionSearch")});var Cm=M((COe,S0)=>{"use strict";var _9=(k(),v(K)).OPERATIONS_ENUM,Ub=class{static{o(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=_9.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};S0.exports=Ub});var xb=M((LOe,w0)=>{"use strict";var A0=ti(),b0=Cm(),I0=Om(),N0=bm(),Cn=(k(),v(K)),T0=ie(),R0=Et(),{getTransactionAuditStorePath:g9,getSchemaPath:S9}=yt(),y0=z();w0.exports=T9;async function T9(e){try{if(T0.isEmpty(global.hdb_schema[e.schema])||T0.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await R9(e),await y9(e);let t=S9(e.schema,e.table);try{await R0.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")y0.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=g9(e.schema,e.table);await R0.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")y0.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}o(T9,"lmdbDropTable");async function R9(e){let t=new A0(Cn.SYSTEM_SCHEMA_NAME,Cn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Cn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Cn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await I0(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 b0(Cn.SYSTEM_SCHEMA_NAME,Cn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await N0(s)}o(R9,"deleteAttributesFromSystem");async function y9(e){let t=new A0(Cn.SYSTEM_SCHEMA_NAME,Cn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Cn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[Cn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,Cn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,Cn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await I0(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 b0(Cn.SYSTEM_SCHEMA_NAME,Cn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await N0(s)}catch(i){throw i}}o(y9,"dropTableFromSystem")});var C0=M((MOe,O0)=>{"use strict";var A9=require("fs-extra"),b9=ti(),I9=Uu(),N9=Cm(),w9=xb(),O9=bm(),C9=Ob(),P9=Om(),Io=(k(),v(K)),{getSchemaPath:L9}=yt(),{handleHDBError:D9,hdbErrors:M9}=Ee(),{HDB_ERROR_MSGS:v9,HTTP_STATUS_CODES:U9}=M9;O0.exports=x9;async function x9(e){let t;try{t=await B9(e.schema);let r=new b9(Io.SYSTEM_SCHEMA_NAME,Io.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Io.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[Io.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await P9(r));for(let a=0;a<n.length;a++){let c={schema:t,table:n[a].name};try{await w9(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new N9(Io.SYSTEM_SCHEMA_NAME,Io.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await O9(s);let i=L9(t);await A9.remove(i)}catch(r){throw r}}o(x9,"lmdbDropSchema");async function B9(e){let t=new I9(Io.SYSTEM_SCHEMA_NAME,Io.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[Io.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await C9(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw D9(new Error,v9.SCHEMA_NOT_FOUND(e),U9.NOT_FOUND,void 0,void 0,!0);return n}o(B9,"validateDropSchema")});var Pm=M((UOe,P0)=>{"use strict";var Bb=class{static{o(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};P0.exports=Bb});var Hb=M((FOe,L0)=>{"use strict";var F9=require("fs-extra"),H_=Et(),{getTransactionAuditStorePath:H9}=yt(),Fb=kt(),BOe=Pm();L0.exports=k9;async function k9(e){let t;try{let r=H9(e.schema,e.table);await F9.mkdirp(r),t=await H_.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{H_.createDBI(t,Fb.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),H_.createDBI(t,Fb.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),H_.createDBI(t,Fb.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(k9,"createTransactionsAuditEnvironment")});var v0=M((GOe,M0)=>{"use strict";var kb=(k(),v(K)),D0=Et(),G9=jc(),{getSystemSchemaPath:q9,getSchemaPath:$9}=yt(),kOe=To(),V9=P_(),Gb=C_(),K9=z(),Y9=Hb();M0.exports=W9;async function W9(e,t){let r=$9(t.schema,t.table),n=new Gb(t.schema,t.table,kb.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new Gb(t.schema,t.table,kb.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new Gb(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await D0.createEnvironment(r,t.table),e!==void 0){let a=await D0.openEnvironment(q9(),kb.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await G9.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 Y9(t)}catch(a){throw a}}o(W9,"lmdbCreateTable");async function qb(e){try{await V9(e)}catch(t){K9.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}o(qb,"createAttribute")});var x0=M(($Oe,U0)=>{"use strict";var z9=Rm(),j9=$f(),Q9=L_(),Lm=(k(),v(K)),J9=jc().updateRecords,X9=Et(),{getSchemaPath:Z9}=yt(),e7=ym(),t7=z();U0.exports=r7;async function r7(e){try{let{schemaTable:t,attributes:r}=z9(e);j9(e,r,t.hash_attribute),e.schema!==Lm.SYSTEM_SCHEMA_NAME&&(r.includes(Lm.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(Lm.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(Lm.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(Lm.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await Q9(e.hdb_auth_header,t,r),s=Z9(e.schema,e.table),i=await X9.openEnvironment(s,e.table),a=await J9(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await e7(e,a)}catch(c){t7.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(r7,"lmdbUpdateRecords")});var F0=M((KOe,B0)=>{"use strict";var n7=(k(),v(K)).OPERATIONS_ENUM,$b=class{static{o(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=n7.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};B0.exports=$b});var k0=M((zOe,H0)=>{"use strict";var WOe=F0(),s7=Rm(),i7=$f(),o7=L_(),Dm=(k(),v(K)),a7=jc().upsertRecords,c7=Et(),{getSchemaPath:l7}=yt(),u7=ym(),d7=z(),{handleHDBError:f7,hdbErrors:m7}=Ee();H0.exports=h7;async function h7(e){let t;try{t=s7(e)}catch(l){throw f7(l,l.message,m7.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schemaTable:r,attributes:n}=t;i7(e,n,r.hash_attribute),e.schema!==Dm.SYSTEM_SCHEMA_NAME&&(n.includes(Dm.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(Dm.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(Dm.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(Dm.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await o7(e.hdb_auth_header,r,n),i=l7(e.schema,e.table),a=await c7.openEnvironment(i,e.table),c=await a7(a,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await u7(e,c)}catch(l){d7.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(h7,"lmdbUpsertRecords")});var q0=M((QOe,G0)=>{"use strict";var Vb=class{static{o(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};G0.exports=Vb});var V0=M((XOe,$0)=>{"use strict";var Kb=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}};$0.exports=Kb});var W0=M((tCe,Y0)=>{"use strict";var Yb=Et(),{getTransactionAuditStorePath:p7}=yt(),eCe=q0(),Mm=kt(),E7=ie(),K0=V0(),_7=require("util").promisify,g7=_7(setTimeout),S7=1e4,T7=100;Y0.exports=R7;async function R7(e){let t=p7(e.schema,e.table),r=await Yb.openEnvironment(t,e.table,!0),n=Yb.listDBIs(r);Yb.initializeDBIs(r,Mm.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new K0;do s=await y7(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 g7(T7);while(s.transactions_deleted>0);return i}o(R7,"deleteAuditLogsBefore");async function y7(e,t){let r=new K0;try{let n=e.dbis[Mm.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[Mm.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];E7.isEmpty(c)||(s=e.dbis[Mm.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<a.hash_values.length;l++)s=e.dbis[Mm.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(a.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>S7)break}return await s,r}catch(n){throw n}}o(y7,"deleteTransactions")});var j0=M((nCe,z0)=>{"use strict";var Wb=class{static{o(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};z0.exports=Wb});var J0=M((oCe,Q0)=>{"use strict";var A7=ti(),b7=Cm(),iCe=j0(),Di=(k(),v(K)),I7=ie(),zb=Et(),N7=To(),w7=Om(),O7=bm(),{getSchemaPath:C7}=yt();Q0.exports=P7;async function P7(e,t=!0){let r;e.schema===Di.SYSTEM_SCHEMA_NAME?r=N7[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await D7(e),s=C7(e.schema,e.table),i=await zb.openEnvironment(s,e.table);return t===!0&&await L7(e,i,r.hash_attribute),zb.dropDBI(i,e.attribute),n}o(P7,"lmdbDropAttribute");async function L7(e,t,r){let n=zb.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(L7,"removeAttributeFromAllObjects");async function D7(e){let t=new A7(Di.SYSTEM_SCHEMA_NAME,Di.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Di.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Di.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,Di.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await w7(t)).filter(a=>a[Di.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(I7.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[Di.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new b7(Di.SYSTEM_SCHEMA_NAME,Di.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return O7(i)}o(D7,"dropAttributeFromSystem")});var nB=M((lCe,rB)=>{"use strict";var jb=Et(),xu=kt(),cCe=Rn(),Qb=(k(),v(K)),X0=ie(),{getTransactionAuditStorePath:M7}=yt(),v7=Mu(),k_=Pu(),U7=z();rB.exports=x7;async function x7(e){let t=M7(e.schema,e.table),r=await jb.openEnvironment(t,e.table,!0),n=jb.listDBIs(r);jb.initializeDBIs(r,xu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case Qb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return Z0(r,e.search_values);case Qb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,F7(r,e.search_values,s);case Qb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return B7(r,e.search_values);default:return Z0(r)}}o(x7,"readAuditLog");function Z0(e,t=[0,Date.now()]){X0.isEmpty(t[0])&&(t[0]=0),X0.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[xu.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 k_,s))}o(Z0,"searchTransactionsByTimestamp");function B7(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[xu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(a);r.set(s,tB(e,i))}return Object.fromEntries(r)}o(B7,"searchTransactionsByUsername");function F7(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let u=t[c],d=v7.equals(e,xu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,xu.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=tB(e,s),a=new Map;for(let c=0;c<i.length;c++){let l=i[c],u=l.timestamp,d=n.get(u);eB(l,"records",r,d,a),eB(l,"original_records",r,d,a)}return Object.fromEntries(a)}o(F7,"searchTransactionsByHashValues");function eB(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 k_(e.operation,e.user_name,i,void 0);f[t]=[c],u.push(f)}}else{let u=new k_(e.operation,e.user_name,i,void 0);u[t]=[c],s.set(l,[u])}}}o(eB,"loopRecords");function tB(e,t){let r=[];try{let n=e.dbis[xu.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 k_,i);r.push(a)}}catch(i){U7.warn(i)}return r}catch(n){throw n}}o(tB,"batchSearchTransactions")});var iB=M((mCe,sB)=>{"use strict";var{getSchemaPath:dCe}=yt(),fCe=Et(),{database:H7}=(Le(),v(ft));sB.exports={writeTransaction:k7};async function k7(e,t,r){return H7({database:e,table:t}).transaction(r)}o(k7,"writeTransaction")});var lB=M((pCe,cB)=>{"use strict";var{getSchemaPath:oB}=yt(),aB=Et();cB.exports={flush:G7,resetReadTxn:q7};async function G7(e,t){return(await aB.openEnvironment(oB(e,t),t.toString())).flushed}o(G7,"flush");async function q7(e,t){try{(await aB.openEnvironment(oB(e,t),t.toString())).resetReadTxn()}catch{}}o(q7,"resetReadTxn")});var mB=M((_Ce,fB)=>{"use strict";var{Readable:$7}=require("stream"),{getDatabases:V7}=(Le(),v(ft)),{readSync:K7,openSync:Y7,createReadStream:uB}=require("fs"),{open:W7}=require("lmdb"),dB=pm(),z7=Em(),{AUDIT_STORE_OPTIONS:j7}=(lo(),v(vv)),{INTERNAL_DBIS_NAME:Q7,AUDIT_STORE_NAME:J7}=kt();fB.exports=Z7;var Jb=32768,X7=100;async function Z7(e){let t=e.database||e.schema||"data",r=V7()[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=W7({noSync:!0,maxDbs:z7.MAX_DBS}),m,h=f.openDB(Q7,new dB(!1)),p=d.useReadTransaction(),_=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),_++%X7===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 dB(!P,P);await g(T,Y)}e.include_audit&&await g(J7,{...j7}),await m;let y=uB(f.path);return y.headers=l(),y.on("close",()=>{p.done(),f.close()}),y}let a=r[Object.keys(r)[0]].primaryStore,c=Y7(a.path);return a.transaction(()=>{let u=Buffer.alloc(Jb);K7(c,u,0,Jb),a.resetReadTxn();let d=a.useReadTransaction();d.renew();let f=uB(null,{fd:c,start:Jb}),m=new $7.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(Z7,"getBackup")});var EB=M((SCe,pB)=>{"use strict";var eee=z(),{handleHDBError:tee}=Ee(),ree=GU(),nee=P_(),see=Rb(),iee=Cx(),oee=bm(),aee=Ob(),cee=t0(),lee=u0(),uee=Om(),dee=g0(),fee=C0(),mee=v0(),hee=x0(),pee=k0(),Eee=W0(),_ee=xb(),gee=J0(),See=nB(),Tee=iB(),hB=lB(),Ree=mB(),Xb=class extends ree{static{o(this,"LMDBBridge")}async searchByConditions(t){return dee(t)}async getDataByHash(t){return await aee(t)}async searchByHash(t){return await cee(t)}async getDataByValue(t,r){return await lee(t,r)}async searchByValue(t){return await uee(t)}async createSchema(t){return await iee(t)}async dropSchema(t){return await fee(t)}async createTable(t,r){return await mee(t,r)}async dropTable(t){return await _ee(t)}async createAttribute(t){return await nee(t)}async createRecords(t){return await see(t)}async updateRecords(t){return await hee(t)}async upsertRecords(t){try{return await pee(t)}catch(r){throw tee(r,null,null,eee.ERR,r)}}async deleteRecords(t){return await oee(t)}async dropAttribute(t){return await gee(t)}async deleteAuditLogsBefore(t){return await Eee(t)}async readAuditLog(t){return await See(t)}writeTransaction(t,r,n){return Tee.writeTransaction(t,r,n)}flush(t,r){return hB.flush(t,r)}resetReadTxn(t,r){return hB.resetReadTxn(t,r)}getBackup(t){return Ree(t)}};pB.exports=Xb});function Pn(e){let t=e.getChanges();return t||(t=Object.create(null),e._setChanges(t)),t}function Um(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 Yn.ClientError(`${u} must be a string, attempt to assign ${m}`);Pn(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 Yn.ClientError(`${u} must be a string, attempt to assign ${m}`);Pn(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 Yn.ClientError(`${u} must be a number, attempt to assign ${h}`);Pn(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 Yn.ClientError(`${u} must be an integer between -2147483648 and 2147483647, attempt to assign ${m}`);Pn(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 Yn.ClientError(`${u} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${m}`);Pn(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 Yn.ClientError(`${u} must be a number, attempt to assign ${m}`);Pn(this)[u]=m},"set");break;case"Boolean":d=o(function(m){if(!(typeof m=="boolean"||m==null&&l.nullable!==!1))throw new Yn.ClientError(`${u} must be a boolean, attempt to assign ${m}`);Pn(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 Yn.ClientError(`${u} must be a Date, attempt to assign ${m}`);Pn(this)[u]=m},"set");break;case"Bytes":d=o(function(m){if(!(m instanceof Uint8Array||m==null&&l.nullable!==!1))throw new Yn.ClientError(`${u} must be a Buffer or Uint8Array, attempt to assign ${m}`);Pn(this)[u]=m},"set");break;case"Blob":d=o(function(m){if(!(m instanceof gs||m==null&&l.nullable!==!1))throw new Yn.ClientError(`${u} must be a Blob, attempt to assign ${m}`);Pn(this)[u]=m},"set");break;case"Any":case void 0:d=o(function(m){Pn(this)[u]=m},"set");break;default:d=o(function(m){if(!(typeof m=="object"||m==null&&l.nullable!==!1))throw new Yn.ClientError(`${u} must be an object, attempt to assign ${m}`);Pn(this)[u]=m},"set")}f={get(){let m=this.getChanges?.();if(m&&u in m){let p=m[u];if(p?.__op__){let _=this.getRecord()?.[u];return p.update(_)}return p}let h=this.getRecord()?.[u];if(h&&typeof h=="object"){let p=Zb(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 Yn.ClientError("Can not add a property to a sealed table schema");Pn(this)[l]=u}),a("deleteProperty",function(l){Pn(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?SB:gB);break}c=l}while(c&&c!==gB&&c!==SB)}function TB(e,t,r){if(typeof t=="string"){if(t==="then"||t==="getRecord"||t==="getChanges")return;if(_B[t])return _B[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=Zb(s);if(i)return n||(n=Object.create(null),r._setChanges(n)),n[t]=i,i}return s}}function yee(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 Zb(e,t){let r;switch(e.constructor){case Object:return t?(r=t.TrackedObject,r||(t.TrackedObject=r=class extends tl{static{o(this,"TrackedObject")}},Um(r,t)),new r(e)):new tl(e);case Array:let n=new q_(e.length,e);for(let s=0,i=e.length;s<i;s++){let a=e[s];a&&typeof a=="object"&&(a=Zb(a,t?.elements)),n[s]=a}return n;default:return e}}function $_(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=$_(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 wa(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=wa(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=Jy[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=wa(s);r[n]=s}if(!Array.isArray(e)&&e.getRecord)for(let n in e)Aee.call(e,n)&&(r||(r={...e.getRecord()}),r[n]=e[n]);return r?Object.freeze(r):e.getRecord?e.getRecord():e}function G_(e){let t=e.getRecord?.();if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[el]||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(G_(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(G_(s))return!0}else return!0}else return!0}}return!1}var Yn,_B,gB,SB,tl,Aee,el,q_,vm,eI=fe(()=>{Yn=w(Ee());BE();Ss();o(Pn,"getChanges");o(Um,"assignTrackedAccessors");_B=Object.prototype,gB=new Proxy({},{get:TB}),SB=new Proxy({},{get:TB,set:yee});o(TB,"getProxiedProperty");o(yee,"setProxiedProperty");o(Zb,"trackObject");tl=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}};Um(tl,{},!0);o($_,"collapseData");Aee=Object.prototype.hasOwnProperty;o(wa,"updateAndFreeze");o(G_,"hasChanges");el=Symbol.for("has-array-changes"),q_=class extends Array{static{o(this,"TrackedArray")}#e;[el];constructor(t,r){super(t),this.#e=r}getRecord(){return this.#e}splice(...t){return this[el]=!0,super.splice(...t)}push(...t){return this[el]=!0,super.push(...t)}pop(){return this[el]=!0,super.pop()}unshift(...t){return this[el]=!0,super.unshift(...t)}shift(){return this[el]=!0,super.shift()}};q_.prototype.constructor=Array;vm=class{static{o(this,"Addition")}__op__="add";value;constructor(t){this.value=t}update(t){return(+t||0)+this.value}}});var OB={};Ce(OB,{ResourceBridge:()=>nI});function sI({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 RB(e,t){let r=Mi(e),n=sI(e,r);if(!r)throw new ri.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;Mt(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&&$_(d)}catch(f){d={message:(0,wB.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 Mi(e){let t=e.database||e.schema||Iee,r=it()[t];if(!r)throw(0,ri.handleHDBError)(new Error,bee.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function yB(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*AB(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 bB,V_,ri,IB,tI,rI,NB,wB,bee,Iee,Nee,wee,nI,CB=fe(()=>{bB=w(EB()),V_=w(vu()),ri=w(Ee());Le();IB=w(Rm());k();tI=w(Ao()),rI=w(ei()),NB=w(ie());Dc();eI();wB=w(z()),{HDB_ERROR_MSGS:bee}=ri.hdbErrors,Iee="data",Nee=1e4,wee=10,nI=class extends bB.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,V_.default)(t,"conditions");if(r)throw(0,ri.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=Mi(t);if(!n)throw new ri.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:sI(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 ri.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 Mi(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=Mi(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 Mi(t).dropTable()}createSchema(t){return Bu({database:t.schema,table:null}),tI.signalSchemaChange(new rI.SchemaEventMsg(process.pid,G.CREATE_SCHEMA,t.schema))}async dropSchema(t){await iI(t.schema),tI.signalSchemaChange(new rI.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,IB.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),Mt(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=$_(m));for(let h in d)if(Object.prototype.hasOwnProperty.call(d,h)){let p=d[h];if(typeof p=="function")try{let _=p([[m]]);Array.isArray(_)&&(p=_[0].func_val,d[h]=p)}catch(_){throw _.message+="Trying to set key "+h+" on object"+JSON.stringify(d),_}}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),Mt(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 yB(a,c,s.timestamp)})}async deleteRecordsBefore(t){let r=it()[t.schema][t.table];if(!r.createdTimeProperty)throw new ri.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:bE.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,NB.asyncSetTimeout)(wee),l=[],s=!0},"chunkDelete");for await(let d of n)l.push(d[r.primaryKey]),c++,c%Nee===0&&await u();return l.length>0&&await u(),s?yB(i,a,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,V_.default)(t,"hashes");if(r)throw r;return RB(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of RB(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,V_.default)(t,"value");if(n)throw n;let s=Mi(t);if(!s)throw new ri.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===bE.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:sI(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async getDataByValue(t,r){let n=new Map,s=Mi(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){Mi({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return Mi(t).deleteHistory(t.timestamp,t.cleanup_deleted_records)}async readAuditLog(t){let r=Mi(t),n={};switch(t.search_type){case IE.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 IE.USERNAME:{let s=t.search_values;for await(let i of AB(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n}default:return AB(r,t.search_values?.[0],t.search_values?.[1],t.limit)}}};o(sI,"getSelect");o(RB,"getRecords");o(Mi,"getTable");o(yB,"createDeleteResponse");o(AB,"groupRecordsInHistory")});var Wn=M((PCe,PB)=>{"use strict";var{ResourceBridge:Oee}=(CB(),v(OB)),Cee=ce();Cee.initSync();var K_;function Pee(){return K_||(K_=new Oee,K_)}o(Pee,"getBridge");PB.exports=Pee()});var vB=M((DCe,MB)=>{"use strict";var LB=require("lodash"),xm=require("mathjs"),Lee=require("jsonata"),DB=ie();MB.exports={distinct_array:o(e=>Array.isArray(e)&&e.length>1?LB.uniqWith(e,LB.isEqual):e,"distinct_array"),searchJSON:Dee,mad:Bm.bind(null,xm.mad),mean:Bm.bind(null,xm.mean),mode:Bm.bind(null,xm.mode),prod:Bm.bind(null,xm.prod),median:Bm.bind(null,xm.median)};function Bm(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(Bm,"aggregateFunction");function Dee(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(DB.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),DB.isEmpty(this.__ala__.res[r])){let n=Lee(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}o(Dee,"searchJSON")});var xB=M((vCe,UB)=>{"use strict";var ir=require("moment"),oI="YYYY-MM-DDTHH:mm:ss.SSSZZ";ir.suppressDeprecationWarnings=!0;UB.exports={current_date:o(()=>ir().utc().format("YYYY-MM-DD"),"current_date"),current_time:o(()=>ir().utc().format("HH:mm:ss.SSS"),"current_time"),extract:o((e,t)=>{switch(t.toLowerCase()){case"year":return ir(e).utc().format("YYYY");case"month":return ir(e).utc().format("MM");case"day":return ir(e).utc().format("DD");case"hour":return ir(e).utc().format("HH");case"minute":return ir(e).utc().format("mm");case"second":return ir(e).utc().format("ss");case"millisecond":return ir(e).utc().format("SSS");default:break}},"extract"),date:o(e=>ir(e).utc().format(oI),"date"),date_format:o((e,t)=>ir(e).utc().format(t),"date_format"),date_add:o((e,t,r)=>ir(e).utc().add(t,r).valueOf(),"date_add"),date_sub:o((e,t,r)=>ir(e).utc().subtract(t,r).valueOf(),"date_sub"),date_diff:o((e,t,r)=>{let n=ir(e).utc(),s=ir(t).utc();return r?n.diff(s,r,!0):n.diff(s)},"date_diff"),now:o(()=>ir().utc().valueOf(),"now"),get_server_time:o(()=>ir().format(oI),"get_server_time"),offset_utc:o((e,t)=>ir(e).utc().utcOffset(t).format(oI),"offset_utc")}});var kB=M((xCe,HB)=>{"use strict";var Mee=require("@turf/area"),vee=require("@turf/length"),Uee=require("@turf/circle"),xee=require("@turf/difference"),Bee=require("@turf/distance"),Fee=require("@turf/boolean-contains"),Hee=require("@turf/boolean-equal"),kee=require("@turf/boolean-disjoint"),Gee=require("@turf/helpers"),BB=(k(),v(K)),Ye=ie(),No=z();HB.exports={geoArea:qee,geoLength:$ee,geoCircle:Vee,geoDifference:Kee,geoDistance:FB,geoNear:Yee,geoContains:Wee,geoEqual:zee,geoCrosses:jee,geoConvert:Qee};function qee(e){if(Ye.isEmpty(e))return NaN;typeof e=="string"&&(e=Ye.autoCastJSON(e));try{return Mee.default(e)}catch(t){return No.trace(t,e),NaN}}o(qee,"geoArea");function $ee(e,t){if(Ye.isEmpty(e))return NaN;typeof e=="string"&&(e=Ye.autoCastJSON(e));try{return vee.default(e,{units:t||"kilometers"})}catch(r){return No.trace(r,e),NaN}}o($ee,"geoLength");function Vee(e,t,r){if(Ye.isEmpty(e))return NaN;if(Ye.isEmpty(t))return NaN;typeof e=="string"&&(e=Ye.autoCastJSON(e));try{return Uee.default(e,t,{units:r||"kilometers"})}catch(n){return No.trace(n,e,t),NaN}}o(Vee,"geoCircle");function Kee(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 xee(e,t)}catch(r){return No.trace(r,e,t),NaN}}o(Kee,"geoDifference");function FB(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 Bee.default(e,t,{units:r||"kilometers"})}catch(n){return No.trace(n,e,t),NaN}}o(FB,"geoDistance");function Yee(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 FB(e,t,n)<=r}catch(s){return No.trace(s,e,t),!1}}o(Yee,"geoNear");function Wee(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 Fee.default(e,t)}catch(r){return No.trace(r,e,t),!1}}o(Wee,"geoContains");function zee(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 Hee.default(e,t)}catch(r){return No.trace(r,e,t),!1}}o(zee,"geoEqual");function jee(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!kee.default(e,t)}catch(r){return No.trace(r,e,t),!1}}o(jee,"geoCrosses");function Qee(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(BB.GEO_CONVERSION_ENUM[t]))throw new Error(`geoType of ${t} is invalid please use one of the following types: ${Object.keys(BB.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Ye.autoCastJSON(e)),Gee[t](e,r)}o(Qee,"geoConvert")});var Y_=M((FCe,GB)=>{var rl=vB(),zn=xB(),vi=kB();GB.exports=e=>{e.aggr.mad=e.aggr.MAD=rl.mad,e.aggr.mean=e.aggr.MEAN=rl.mean,e.aggr.mode=e.aggr.MODE=rl.mode,e.aggr.prod=e.aggr.PROD=rl.prod,e.aggr.median=e.aggr.MEDIAN=rl.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=rl.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=rl.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=zn.current_date,e.fn.current_time=e.fn.CURRENT_TIME=zn.current_time,e.fn.extract=e.fn.EXTRACT=zn.extract,e.fn.date=e.fn.DATE=zn.date,e.fn.date_format=e.fn.DATE_FORMAT=zn.date_format,e.fn.date_add=e.fn.DATE_ADD=zn.date_add,e.fn.date_sub=e.fn.DATE_SUB=zn.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=zn.date_diff,e.fn.now=e.fn.NOW=zn.now,e.fn.offset_utc=e.fn.OFFSET_UTC=zn.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=zn.get_server_time,e.fn.getdate=e.fn.GETDATE=zn.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=zn.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=vi.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=vi.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=vi.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=vi.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=vi.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=vi.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=vi.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=vi.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=vi.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=vi.geoNear}});var KB=M((HCe,VB)=>{"use strict";var Fm=require("lodash"),Ln=require("alasql");Ln.options.cache=!1;var Jee=Y_(),qB=require("clone"),W_=require("recursive-iterator"),ke=z(),tt=ie(),Fu=Wn(),Xee=(k(),v(K)),{hdbErrors:Zee}=Ee(),{getDatabases:$B}=(Le(),v(ft)),ete="IS NULL",ni="There was a problem performing this search. Please check the logs and try again.";Jee(Ln);var aI=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(ni)}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(ni)}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(ni)}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(ni)}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(ni)}}_getColumns(){let t=new W_(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(qB(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=Fm.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=$B()[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 W_(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 Ln.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 Ln.yy.LogicValue({value:i}):n instanceof Ln.yy.StringValue&&tt.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new Ln.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 W_(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(Xee.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&&Fm.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 Ln.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(qB(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(ete)>-1&&this.tables.forEach(s=>{let i={columnid:$B()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=Fm.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 Fu.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(ni)}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 Fu.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(ni)}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 Fu.getDataByValue(c,h.operation);if(l)for(let[_]of p)this.data[i].__mergedData[_]||(this.data[i].__mergedData[_]=[...n[i]],this._setMergedHashAttribute(i,_));else for(let[_,g]of p)this.data[i].__mergedData[_]?this._updateMergedAttribute(i,_,s.attribute,g[s.attribute]):(this.data[i].__mergedData[_]=[...n[i]],this._updateMergedAttribute(i,_,s.attribute,g[s.attribute]),this._setMergedHashAttribute(i,_))}}catch(d){throw ke.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),ke.error(d),new Error(ni)}else try{c.search_attribute=s.attribute,c.search_value="*";let d=await Fu.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(ni)}}}_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 Ln.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 Ln.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new Ln.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 Ln.yy.FuncValue:new Ln.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,_=h.as?h.as_orig:h.tableid_orig;a.push({key:`'${_}.${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 "${_}.${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 Ln.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 _=m[h];a.forEach(g=>{_[g.key]!==null&&_[g.key]!==void 0&&g.keys.add(_[g.key])})}a.forEach(h=>{let p=Object.keys(this.data[`${h.schema}_${h.table}`].__mergedData),_=Fm.difference(p,[...h.keys].map(g=>g.toString()));for(let g=0,y=_.length;g<y;g++){let T=_[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 W_(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=Fm.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(ni)}}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 Fu.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 _=s.columns[p],g=h[_]===void 0?null:h[_];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 Ln.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(Zee.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 Fu.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(ni)}}return Object.values(Object.values(this.data)[0].__mergedData)}};VB.exports=aI});var nn=M((GCe,YB)=>{"use strict";var tte=HU();YB.exports={searchByConditions:nte,searchByHash:ste,searchByValue:ite,search:ote};var cI=Wn(),{transformReq:lI}=ie(),rte=KB();async function nte(e){return lI(e),cI.searchByConditions(e)}o(nte,"searchByConditions");async function ste(e){lI(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of cI.searchByHash(e))r&&t.push(r);return t}o(ste,"searchByHash");async function ite(e){lI(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of cI.searchByValue(e))t.push(r);return t}o(ite,"searchByValue");function ote(e,t){try{let r=new tte(e);r.validate(),new rte(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}o(ote,"search")});var Ui=M(($Ce,QB)=>{"use strict";var Hm=require("crypto"),ate=ce(),{CONFIG_PARAMS:cte}=(k(),v(K)),zB="aes-256-cbc",lte=32,ute=16,uI=64,jB=32,dte=uI+jB,WB=new Map;QB.exports={encrypt:fte,decrypt:mte,createNatsTableStreamName:hte};function fte(e){let t=Hm.randomBytes(lte),r=Hm.randomBytes(ute),n=Hm.createCipheriv(zB,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(fte,"encrypt");function mte(e){let t=e.substr(0,uI),r=e.substr(uI,jB),n=e.substr(dte,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),a=Hm.createDecipheriv(zB,Buffer.from(t,"hex"),s),c=a.update(i);return c=Buffer.concat([c,a.final()]),c.toString()}o(mte,"decrypt");function hte(e,t){let r=ate.get(cte.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=WB.get(r);return n||(n=Hm.createHash("md5").update(r).digest("hex"),WB.set(r,n)),n}o(hte,"createNatsTableStreamName")});var Oa=M((YCe,eF)=>{"use strict";var KCe=nn(),km=z(),{validateBySchema:JB}=ct(),nl=require("joi"),pte=Ui(),z_=ie(),{handleHDBError:j_,hdbErrors:Ete,ClientError:XB}=Ee(),{HDB_ERROR_MSGS:Q_,HTTP_STATUS_CODES:dI}=Ete,ZB=ce();ZB.initSync();var{getDatabases:fI}=(Le(),v(ft)),_te=require("fs-extra"),gte=(k(),v(K));eF.exports={describeAll:Ste,describeTable:J_,describeSchema:Tte};async function Ste(e={}){try{let t=z_.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=fI(),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 J_({schema:f,table:h,exactCount:u});else if(n&&n[f].describe&&n[f].tables[h].describe){let _=n[f].tables[h].attribute_permissions;p=await J_({schema:f,table:h,exactCount:u},_)}p&&l.push(p)}catch(p){km.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 km.error("Got an error in describeAll"),km.error(t),j_(new Error,Q_.DESCRIBE_ALL_ERR)}}o(Ste,"describeAll");async function J_(e,t){z_.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=JB(e,nl.object({database:nl.string(),table:nl.string().required(),exact_count:nl.boolean().strict()}));if(i)throw new XB(i.message);let c=fI()[r];if(!c)throw j_(new Error,Q_.SCHEMA_NOT_FOUND(e.schema),dI.NOT_FOUND);let l=c[n];if(!l)throw j_(new Error,Q_.TABLE_NOT_FOUND(e.schema,e.table),dI.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 _te.stat(l.primaryStore.env.path)).size}catch(h){km.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")),ZB.get(gte.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(m.clustering_stream_name=pte.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 _ of p.getKeys({reverse:!0,limit:1}))m.last_updated_record=_[0];if(!m.last_updated_record&&l.indices.__updatedtime__)for(let _ of l.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))m.last_updated_record=_}catch(h){km.warn(`unable to stat table dbi due to ${h}`)}return m}o(J_,"descTable");async function Tte(e){z_.transformReq(e);let t=JB(e,nl.object({database:nl.string(),exact_count:nl.boolean().strict()}));if(t)throw new XB(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=fI()[n];if(!i)throw j_(new Error,Q_.SCHEMA_NOT_FOUND(e.schema),dI.NOT_FOUND);let a={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),z_.isEmpty(l)||l.describe){let u=await J_({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);u&&(a[u.name]=u)}}return a}o(Tte,"describeSchema")});var Dn=M((zCe,sF)=>{"use strict";var Z_=pb(),$r=ie(),Rte=require("util"),eg=Wn(),yte=Zs(),tF=z(),{handleHDBError:sl,hdbErrors:Ate}=Ee(),{HTTP_STATUS_CODES:il}=Ate,bte=Rte.promisify(yte.getTableSchema),Ite="updated",rF="inserted",nF="upserted";sF.exports={insert:wte,update:Ote,upsert:Cte,validation:Nte,flush:Pte};async function Nte(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 bte(e.schema,e.table),r=Z_(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 tF.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 tF.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(Nte,"validation");async function wte(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=Z_(e);if(t)throw sl(new Error,t.message,il.BAD_REQUEST);$r.transformReq(e);let r=$r.checkSchemaTableExist(e.schema,e.table);if(r)throw sl(new Error,r,il.BAD_REQUEST);let n=await eg.createRecords(e);return X_(rF,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}o(wte,"insertData");async function Ote(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=Z_(e);if(t)throw sl(new Error,t.message,il.BAD_REQUEST);$r.transformReq(e);let r=$r.checkSchemaTableExist(e.schema,e.table);if(r)throw sl(new Error,r,il.BAD_REQUEST);let n=await eg.updateRecords(e);return $r.isEmpty(n.existing_rows)?X_(Ite,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):X_(n.update_action,[],e,n.hashes,void 0,n.txn_time)}o(Ote,"updateData");async function Cte(e){if(e.operation!=="upsert")throw sl(new Error,"invalid operation, must be upsert",il.INTERNAL_SERVER_ERROR);let t=Z_(e);if(t)throw sl(new Error,t.message,il.BAD_REQUEST);$r.transformReq(e);let r=$r.checkSchemaTableExist(e.schema,e.table);if(r)throw sl(new Error,r,il.BAD_REQUEST);let n=await eg.upsertRecords(e);return X_(nF,n.written_hashes,e,[],n.new_attributes,n.txn_time)}o(Cte,"upsertData");function X_(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===rF?(a.inserted_hashes=t,a.skipped_hashes=n,a):e===nF?(a.upserted_hashes=t,a):(a.update_hashes=t,a.skipped_hashes=n,a)}o(X_,"returnObject");function Pte(e){return $r.transformReq(e),eg.flush(e.schema,e.table)}o(Pte,"flush")});var hI=M((QCe,aF)=>{var Lte=ct(),mI=require("joi"),{hdbTable:Dte,hdbDatabase:iF}=Li(),oF={schema:iF,database:iF,table:Dte},Mte={date:mI.date().iso().required()},vte={timestamp:mI.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};aF.exports=function(e,t){let r=t==="timestamp"?{...oF,...vte}:{...oF,...Mte},n=mI.object(r);return Lte.validateBySchema(e,n)}});var uF=M((JCe,lF)=>{var Ute=ct(),pI=require("joi"),{hdbTable:xte,hdbDatabase:cF}=Li(),Bte=pI.object({schema:cF,database:cF,table:xte,hash_values:pI.array().required(),ids:pI.array()});lF.exports=function(e){return Ute.validateBySchema(e,Bte)}});var SI=M((XCe,dF)=>{"use strict";var EI=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}},_I=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}},gI=class{static{o(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};dF.exports={InsertObject:EI,NoSQLSeachObject:_I,DeleteResponseObject:gI}});var cl=M((ePe,EF)=>{"use strict";var mF=hI(),Fte=uF(),ol=ie(),fF=require("moment"),hF=z(),{promisify:Hte,callbackify:kte}=require("util"),al=(k(),v(K)),Gte=Zs(),TI=Hte(Gte.getTableSchema),RI=Wn(),{DeleteResponseObject:qte}=SI(),{handleHDBError:Ca,hdbErrors:$te}=Ee(),{HDB_ERROR_MSGS:tg,HTTP_STATUS_CODES:Pa}=$te,Vte="records successfully deleted",Kte=kte(pF);EF.exports={delete:Kte,deleteRecord:pF,deleteFilesBefore:Yte,deleteAuditLogsBefore:Wte};async function Yte(e){let t=mF(e,"date");if(t)throw Ca(t,t.message,Pa.BAD_REQUEST,void 0,void 0,!0);if(ol.transformReq(e),!fF(e.date,fF.ISO_8601).isValid())throw Ca(new Error,tg.INVALID_DATE,Pa.BAD_REQUEST,al.LOG_LEVELS.ERROR,tg.INVALID_DATE,!0);let n=ol.checkSchemaTableExist(e.schema,e.table);if(n)throw Ca(new Error,n,Pa.NOT_FOUND,al.LOG_LEVELS.ERROR,n,!0);let s=await RI.deleteRecordsBefore(e);if(await TI(e.schema,e.table),hF.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}o(Yte,"deleteFilesBefore");async function Wte(e){let t=mF(e,"timestamp");if(t)throw Ca(t,t.message,Pa.BAD_REQUEST,void 0,void 0,!0);if(ol.transformReq(e),isNaN(e.timestamp))throw Ca(new Error,tg.INVALID_VALUE("Timestamp"),Pa.BAD_REQUEST,al.LOG_LEVELS.ERROR,tg.INVALID_VALUE("Timestamp"),!0);let r=ol.checkSchemaTableExist(e.schema,e.table);if(r)throw Ca(new Error,r,Pa.NOT_FOUND,al.LOG_LEVELS.ERROR,r,!0);let n=await RI.deleteAuditLogsBefore(e);return await TI(e.schema,e.table),hF.info(`Finished deleting audit logs before ${e.timestamp}`),n}o(Wte,"deleteAuditLogsBefore");async function pF(e){e.ids&&(e.hash_values=e.ids);let t=Fte(e);if(t)throw Ca(t,t.message,Pa.BAD_REQUEST,void 0,void 0,!0);ol.transformReq(e);let r=ol.checkSchemaTableExist(e.schema,e.table);if(r)throw Ca(new Error,r,Pa.NOT_FOUND,al.LOG_LEVELS.ERROR,r,!0);try{await TI(e.schema,e.table);let n=await RI.deleteRecords(e);return ol.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${Vte}`),n}catch(n){if(n.message===al.SEARCH_NOT_FOUND_MESSAGE){let s=new qte;return s.message=al.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}o(pF,"deleteRecord")});var rg={};Ce(rg,{HASH_FUNCTION:()=>Mr,hash:()=>bI,validate:()=>II});function yI(e=qm){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ";return Array.from(Gm.randomBytes(e)).map(r=>t[r%t.length]).join("")}function bI(e,t=Mr[gF?.toUpperCase()]??Mr.SHA256){return AI[t](e)}function II(e,t,r=Mr[gF?.toUpperCase()]??Mr.SHA256){return e?zte[r](e,t):!1}var Gm,Hu,_F,gF,qm,SF,Mr,AI,zte,ng=fe(()=>{Gm=w(require("node:crypto")),Hu=w(require("argon2")),_F=w(ce());k();gF=(0,_F.get)(U.AUTHENTICATION_HASHFUNCTION)?.toLowerCase(),qm=16,SF=9,Mr={MD5:"md5",SHA256:"sha256",ARGON2ID:"argon2id"};o(yI,"generateSalt");AI={[Mr.MD5]:(e,t=void 0)=>{t=t??yI(SF);let r=Gm.createHash(Mr.MD5).update(e+t).digest("hex");return t+r},[Mr.SHA256]:(e,t=void 0)=>{t=t??yI(qm);let r=Gm.createHash(Mr.SHA256).update(e+t).digest("hex");return t+r},[Mr.ARGON2ID]:async e=>{let t=yI(qm),r=await Hu.hash(e,{type:Hu.argon2id,salt:Buffer.from(t)});return t+r}},zte={[Mr.MD5]:(e,t)=>{let r=e.slice(0,SF);return e===AI[Mr.MD5](t,r)},[Mr.SHA256]:(e,t)=>{let r=e.slice(0,qm);return e===AI[Mr.SHA256](t,r)},[Mr.ARGON2ID]:async(e,t)=>await Hu.verify(e.slice(qm),t)};o(bI,"hash");o(II,"validate")});var RF=M((sPe,TF)=>{var NI=ct(),sn={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 jte(e){return sn.password.presence=!0,sn.username.presence=!0,sn.role.presence=!0,sn.active.presence=!0,NI.validateObject(e,sn)}o(jte,"addUserValidation");function Qte(e){return sn.password.presence=!1,sn.username.presence=!0,sn.role.presence=!1,sn.active.presence=!1,NI.validateObject(e,sn)}o(Qte,"alterUserValidation");function Jte(e){return sn.password.presence=!1,sn.username.presence=!0,sn.role.presence=!1,sn.active.presence=!1,NI.validateObject(e,sn)}o(Jte,"dropUserValidation");TF.exports={addUserValidation:jte,alterUserValidation:Qte,dropUserValidation:Jte}});var bt=M((aPe,AF)=>{"use strict";var{platform:oPe}=require("os"),Xte="nats-server.zip",wI="nats-server",Zte=process.platform==="win32"?`${wI}.exe`:wI,ere=/^[^\s.,*>]+$/,yF="__request__",tre=o(e=>`${e}.${yF}`,"REQUEST_SUBJECT"),rre={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},nre={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},sre={HUB:"hub.pid",LEAF:"leaf.pid"},ire={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},ore={SUCCESS:"success",ERROR:"error"},are={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},cre={TXN:"txn",MSGID:"msgid"},ku={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},lre={[ku.ERR]:1,[ku.WRN]:2,[ku.INF]:3,[ku.DBG]:4,[ku.TRC]:5},ure={debug:"-D",trace:"-DVV"};AF.exports={NATS_SERVER_ZIP:Xte,NATS_SERVER_NAME:wI,NATS_BINARY_NAME:Zte,PID_FILES:sre,NATS_CONFIG_FILES:nre,SERVER_SUFFIX:ire,NATS_TERM_CONSTRAINTS_RX:ere,REQUEST_SUFFIX:yF,UPDATE_REMOTE_RESPONSE_STATUSES:ore,CLUSTER_STATUS_STATUSES:are,REQUEST_SUBJECT:tre,SUBJECT_PREFIXES:cre,MSG_HEADERS:rre,LOG_LEVELS:ku,LOG_LEVEL_FLAGS:ure,LOG_LEVEL_HIERARCHY:lre}});var OI=M(on=>{"use strict";var dre={cert:"-----BEGIN CERTIFICATE-----\rMIIDXDCCAkSgAwIBAgIFNTE4MzQwDQYJKoZIhvcNAQELBQAwXTEXMBUGA1UEAxMO\rSGFycGVyREIsIEluYy4xCzAJBgNVBAYTAlVTMQswCQYDVQQIEwJDTzEPMA0GA1UE\rBxMGRGVudmVyMRcwFQYDVQQKEw5IYXJwZXJEQiwgSW5jLjAeFw0yMjAzMTEyMzAz\rNDlaFw0yNzAzMTAyMzAzNDlaMF0xFzAVBgNVBAMTDkhhcnBlckRCLCBJbmMuMQsw\rCQYDVQQGEwJVUzELMAkGA1UECBMCQ08xDzANBgNVBAcTBkRlbnZlcjEXMBUGA1UE\rChMOSGFycGVyREIsIEluYy4wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIB\rAQCsEUlBF8WImS78rCFXVKyntxfrW++4qZ3hGnoD2MHZAuDHyeP/5eGnaE9GQhKc\r4DwG4DGvh0wP2zIYnBfiQ3L2ZtnlDR9ZkKIQYGlVxTUn6T43krhK5nZKqDF43Yg3\rZEvO3cbJBjiKZx0eA2/toehdSsTAHHQx5gTDcggNe2tgoJHYPwi9YF/AxSBZrbgb\ryWlYgtYDmF32ytHP03GUCIdKOFuBPsHTGu4SkdEIdLIqO9oglW1YFH5qZ6NiwApW\rsP+GCuqOwDXXbdjr75iq9Tq/CDrjGFLaTPmvd2Q0qG/BtaCll0ghpG+yIHvt/iQs\rajS+LxEWAnVlGMaDdFErbDUtAgMBAAGjIzAhMA8GA1UdEwEB/wQFMAMBAf8wDgYD\rVR0PAQH/BAQDAgIEMA0GCSqGSIb3DQEBCwUAA4IBAQASR4YW/rPK7PNArHVe9zzM\rb0rKNX/2T9/0nybRhmE/+hdlSgliTAeebmwkUS2APckmekYt/q2ZY2NS65Fo/jjp\rG8TJrtcF4h+ylVqUp0ZXQLFtIsr7r2JZA7hJ6njW6G4DHSZ0gxtECLi4CBlTjzm5\rNmnmIDObvGRTuqmcdAZmXeObbta/He2XIzietukPAYX062pNM+G5XT5UM1eG/Vlp\rN86vjhpyI+ffKy+C60SJqxmKM3ydgN7oLscE7+2wLPN25XqN4W99OwGsp5dTdu/f\r5lPtFayXdJ55e/sNQKmGN+UGLrL05c2MWgjb8U/LFilnupUianceoeSERZmVjzKX\r-----END CERTIFICATE-----\r".replace(/\r/g,`\r
|
|
11
|
+
`},"serialize"),compressible:!1,q:.8});tn.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()}});sv={type:"application/json",serializeStream:Wf,serialize:zf,deserialize:kX,q:.5};tn.set("*/*",sv);tn.set("",sv);o(kX,"tryJSONParse");o(Qf,"registerContentHandlers");GX=(0,rv.default)(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:a,type:c}=GE(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(GE,"findBestSerializer");JM=rA.default.get(U.HTTP_COMPRESSIONTHRESHOLD);o(Jf,"serialize");o(Ea,"serializeMessage");o(oA,"asyncSerialization");o(aA,"hasAsyncSerialization");o(qX,"streamToBuffer");$X=["ascii","utf8","utf-8","utf16le","utf-16le","ucs2","ucs-2","base64","base64url","latin1","binary","hex"];o(VX,"isBufferEncoding");o(KX,"parseContentType");o(mo,"getDeserializer");o(YX,"deserializerUnknownType");o(WX,"transformIterable");o(kE,"toCsvStream")});var fA={};Ce(fA,{Blob:()=>gs,blobsWereEncoded:()=>Bc,databasePaths:()=>lA,decodeBlobsWithWrites:()=>QE,decodeFromDatabase:()=>Fc,decodeWithBlobCallback:()=>JE,deleteBlob:()=>WE,deleteBlobsInObject:()=>_a,deleteRootBlobPathsForDB:()=>dA,encodeBlobsAsBuffers:()=>nZ,encodeBlobsWithFilePath:()=>jE,findBlobsInObject:()=>pu,getFileId:()=>zE,getFilePathForBlob:()=>pv,getRootBlobPathsForDB:()=>tm,setDeletionDelay:()=>JX});function fv(){}function WE(e){let t=pv(e);t&&setTimeout(()=>{(0,Ze.unlink)(t,r=>{r&&po.default.debug?.("Error trying to remove blob file",r)})},mv)}function JX(e){mv=e}function hv(e){let t=yn.get(e);if(!t)t={storageIndex:0,fileId:null,store:An},yn.set(e,t);else{if(t.saving)return t;t.store=An}return ZX(t),t.source?cA(e,t.source,t):t.contentBuffer?XX(e,t):cA(e,Zf.Readable.from(e.stream()),t),t}function cA(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(jX),h=(0,KE.createDeflate)(),t.pipe(h).pipe(f)):(m||f.write(zX),t.pipe(f)),t.on("error",_);function p(g){let y=BigInt(g),T=new Uint8Array(Tr),R=new DataView(T.buffer);return y|=BigInt(a?uA:dv)<<48n,R.setBigInt64(0,y),T}o(p,"createHeader");function _(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(_,"finished"),f.on("error",_).on("finish",()=>{if(m)_();else{let g=h?h.bytesWritten:f.bytesWritten-Tr;e.size=g,(0,Ze.write)(f.fd,p(g),0,Tr,0,_)}})}),e}function zE(e){return yn.get(e)?.fileId}function pv(e){let t=yn.get(e);return t?.fileId&&em(t)}function tm(e){if(!e)throw new Error("No store specified, can not determine blob storage path");let t=lA.get(e);if(!t){if(!e.databaseName)return po.default.warn?.("No database name specified, can not determine blob storage path"),[];let r=(0,YE.get)(U.STORAGE_BLOBPATHS);r?t=r.map(n=>(0,_o.join)(n,e.databaseName)):t=[(0,_o.join)((0,YE.getHdbBasePath)(),"blobs",e.databaseName)],lA.set(e,t)}return t}async function dA(e){let t=tm(e);t&&await Promise.all(t.map(r=>Ev(r)))}async function Ev(e){if((0,Ze.existsSync)(e)){for(let t of await(0,zs.readdir)(e,{withFileTypes:!0}))if(t.isDirectory())await Ev((0,_o.join)(e,t.name));else try{await(0,zs.unlink)((0,_o.join)(e,t.name))}catch(r){po.default.warn?.("Error deleting file",r)}try{await(0,zs.rmdir)(e)}catch(t){po.default.warn?.("Error deleting directory",t)}}}function em({storageIndex:e,fileId:t,store:r}){let n=tm(r);return(0,_o.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 XX(e,t){let r=t.contentBuffer,n=r.length;if(!(n<uv))return e.size=n,cA(e,Zf.Readable.from([r]),t)}function ZX(e){let t=tm(e.store),r=eZ(),n=t?.length>1?tZ(t,r):0,s=r.toString(16);e.storageIndex=n,e.fileId=s;let i=em(e),a=(0,_o.dirname)(i);(0,Ze.existsSync)(a)||(0,lv.ensureDirSync)(a),e.filePath=i}function eZ(){let e=cv.get(An);if(!e){let t=0,r=tm(An);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,_o.join)(n,a.toString(16))}t=Math.max(t,s)}e=new BigInt64Array([BigInt(t)+1n]),e=new BigInt64Array(An.getUserSharedBuffer("blob-file-id",e.buffer)),cv.set(An,e)}return Number(Atomics.add(e,0,1n))}function tZ(e,t){let r=Date.now();if(!e.frequencyTable){e.lastUpdated=0;let s=new Array(VE);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,rZ(e)),e.frequencyTable[t%VE]}async function rZ(e){if(!zs.statfs)return;let t=await Promise.all(e.map(async(s,i)=>{let a=await(0,zs.statfs)(s),c=a.bavail*a.bsize;return Math.pow(c,.8)})),r=new Array(VE),n=t.map(s=>1/s);for(let s=0;s<VE;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 jE(e,t,r){hu=t,An=r,Bc=!1;try{return e()}finally{hu=void 0,An=void 0}}function nZ(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 QE(e,t){try{Gr=[],xc=t,e()}catch(n){throw xc=void 0,Gr=void 0,n}xc=void 0;let r=Gr.length<2?Gr[0]:Promise.all(Gr);return Gr=void 0,r}function JE(e,t,r){An=r;try{return xc=t,e()}finally{xc=void 0}}function Fc(e,t){return An=t,e()}function _a(e){pu(e,t=>{WE(t)})}function pu(e,t){if(e instanceof gs)t(e);else if(Array.isArray(e))for(let r of e)typeof r=="object"&&r&&pu(r,t);else if(e&&typeof e=="object"&&!e[Symbol.iterator])for(let r in e){let n=e[r];typeof n=="object"&&n&&pu(e[r],t)}}function sZ(){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 Eo,zs,Ze,KE,Zf,lv,YE,_o,po,uv,Tr,dv,uA,ov,zX,jX,av,yn,xc,gs,hu,Gr,An,Bc,Xf,qE,QX,$E,mv,lA,cv,VE,Ss=fe(()=>{Eo=require("msgpackr"),zs=require("node:fs/promises"),Ze=require("node:fs"),KE=require("node:zlib"),Zf=require("node:stream"),lv=require("fs-extra"),YE=w(ce());k();_o=require("path"),po=w(Ii());ho();uv=8192,Tr=8,dv=0,uA=1,ov=255,zX=new Uint8Array([0,dv,255,255,255,255,255,255]),jX=new Uint8Array([0,uA,255,255,255,255,255,255]),av=0xffffffffffff,yn=new WeakMap,gs=global.Blob||sZ(),Bc=!1,Xf=new Uint8Array(8),qE=new DataView(Xf.buffer),QX=6e4;o(fv,"InstanceOfBlobWithNoConstructor");fv.prototype=gs.prototype;$E=class e extends fv{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=yn.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):(aA()&&oA(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=yn.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=em(t),a,c=o(async()=>{let l,u=Tr;try{if(l=await(0,zs.readFile)(i),l.length>=Tr){l.copy(Xf,0,0,Tr);let f=qE.getBigUint64(0);if(Number(f>>48n)===ov)throw new Error("Error in blob: "+buffer.subarray(Tr));if(u=Number(f&0xffffffffffffn),u<n&&(u=n),u<av&&(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,_)=>{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]===uA?new Promise((f,m)=>{(0,KE.deflate)(l.subarray(Tr),(h,p)=>{h?m(h):f(d(p))})}):d(l.subarray(Tr))},"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=yn.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(_){_.enqueue(r),_.close()}});let i=em(t),a,c=0,l=0,u,d,f,m=!1,h=this;return new ReadableStream({start(){let _=1e3,g=o((y,T)=>{(0,Ze.open)(i,"r",(R,I)=>{if(R){if(R.code==="ENOENT"&&f!==!1&&(po.default.debug?.("File does not exist yet, waiting for it to be created",i,_),_-- >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(_=>{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<Tr){y-- >0&&f!==!1?(p(),po.default.debug?.("File was empty, waiting for data to be written",i,y),setTimeout(()=>T(R,I),20).unref()):(po.default.debug?.("File was empty, throwing error",i,y),I(new Error(`Blob ${t.fileId} was empty`)));return}$.copy(Xf,0,0,Tr);let j=qE.getBigUint64(0);if(Number(j>>48n)===ov)return P(new Error("Error in blob: "+$.subarray(Tr)));if(g=Number(j&0xffffffffffffn),g<av&&h.size!==g&&(h.size=g,h.#t))for(let V of h.#t)V(g);$=$.subarray(Tr,x),l-=Tr}else if(x===0){let j=Buffer.allocUnsafe(8);return(0,Ze.read)(a,j,0,Tr,0,V=>{if(V)return P(V);if(Xf.set(j),g=Number(qE.getBigUint64(0)&0xffffffffffffn),g>l){p()?u?d=setTimeout(()=>{P(new Error("File read timed out"))},QX).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),_.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{_.enqueue($)}catch(j){return po.default.debug?.("Error enqueuing chunk",j),R()}l===g&&((0,Ze.close)(a),_.close()),R()})},"readMore"))},"pull"),cancel(){(0,Ze.close)(a),clearTimeout(d),u&&u.close()}});function p(){if(f===void 0){let _=t.store,g=t.fileId+":blob";f=!_.attemptLock(g,0,()=>{f=!1,_.unlock(g,0)}),f||_.unlock(g,0)}return f}}slice(t,r,n){let s=yn.get(this),i=new e(n&&{type:n});if(s?.fileId){let a={...s,start:t,end:r};yn.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)};yn.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(An=t?.primaryStore?.rootStore,!An)throw new Error("No target table specified");return hv(this).saving??Promise.resolve()}},mv=500;o(WE,"deleteBlob");o(JX,"setDeletionDelay");global.createBlob=function(e,t){let r=new $E(t),n={storageIndex:0,fileId:null,flush:t?.flush,compress:t?.compress};if(yn.set(r,n),e instanceof Uint8Array)r.size=e.length,n.contentBuffer=e;else if(e instanceof Zf.Readable)n.source=e;else if(typeof e=="string")n.contentBuffer=Buffer.from(e);else if(e?.[Symbol.asyncIterator]||e?.[Symbol.iterator])n.source=Zf.Readable.from(e);else throw new Error("Invalid source type");return r};o(hv,"saveBlob");o(cA,"writeBlobWithStream");o(zE,"getFileId");o(pv,"getFilePathForBlob");lA=new Map;o(tm,"getRootBlobPathsForDB");o(dA,"deleteRootBlobPathsForDB");o(Ev,"rimrafSteadily");o(em,"getFilePath");o(XX,"writeBlobWithBuffer");o(ZX,"generateFilePath");cv=new Map;o(eZ,"getNextFileId");VE=128;o(tZ,"getNextStorageIndex");o(rZ,"createFrequencyTableForStoragePaths");o(jE,"encodeBlobsWithFilePath");o(nZ,"encodeBlobsAsBuffers");o(QE,"decodeBlobsWithWrites");o(JE,"decodeWithBlobCallback");o(Fc,"decodeFromDatabase");o(_a,"deleteBlobsInObject");o(pu,"findBlobsInObject");(0,Eo.addExtension)({Class:gs,type:11,unpack:o(function(e){let t=(0,Eo.unpack)(e),r=new $E;if(Object.assign(r,t[0]),typeof t[1]!="object"){if(yn.set(r,{storageIndex:t[1],fileId:t[2],store:An}),xc)return xc(r)??r;if(!An)throw new Error("No store specified, cannot load blob from storage")}else yn.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=yn.get(e);if(hu!==void 0&&(Bc=!0,t?.recordId!==void 0&&t.recordId!==hu))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<uv)return r.size=t.contentBuffer.length,(0,Eo.pack)([r,t.contentBuffer])}if(hu!==void 0){if(t=hv(e),!t.fileId)throw new Error("Unable to save blob without file id");return t.recordId=hu,(0,Eo.pack)([r,t.storageIndex,t.fileId])}if(t)try{let n=(0,Ze.readFileSync)(em(t));if(n.length>=Tr&&(n.copy(Xf,0,0,Tr),Number(qE.getBigUint64(0)&0xffffffffffffn)===n.length-Tr))return Buffer.concat([(0,Eo.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,Eo.addExtension)({Class:Promise,type:12,pack(){throw new Error("Cannot encode a promise")}});o(sZ,"polyfillBlob")});var Rv={};Ce(Rv,{onStorageReclamation:()=>rm,runReclamationHandlers:()=>EA,setAvailableSpaceRatioGetter:()=>oZ});function rm(e,t,r){(r||(0,ZE.getWorkerIndex)()===(0,ZE.getWorkerCount)()-1)&&(XE.has(e)||XE.set(e,[]),XE.get(e).push({priority:0,handler:t}),pA||(pA=setTimeout(EA,gv).unref()))}async function EA(){for(let[e,t]of XE)try{let r=await Tv(e),n=iZ/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&&(hA.default.info?.(`Running storage reclamation handler for ${e} with priority ${n}`),await c)}}}catch(r){hA.default.error?.("Error running storage reclamation handlers",r)}pA=setTimeout(EA,gv).unref()}function oZ(e){Tv=e??Sv}var mA,ZE,hA,e_,_v,XE,iZ,gv,pA,Sv,Tv,t_=fe(()=>{mA=require("node:fs/promises"),ZE=w(st()),hA=w(Ii());k();e_=w(ce()),_v=w(ie());e_.default.initSync();XE=new Map,iZ=e_.default.get(U.STORAGE_RECLAMATION_THRESHOLD)??.4,gv=(0,_v.convertToMS)(e_.default.get(U.STORAGE_RECLAMATION_INTERVAL))||36e5;o(rm,"onStorageReclamation");Sv=o(async e=>{if(mA.statfs){let t=await(0,mA.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"),Tv=Sv;o(EA,"runReclamationHandlers");o(oZ,"setAvailableSpaceRatioGetter")});var vv={};Ce(vv,{ACTION_32_BIT:()=>o_,ACTION_64_BIT:()=>lZ,AUDIT_STORE_OPTIONS:()=>im,Decoder:()=>kc,HAS_BLOBS:()=>bn,HAS_CURRENT_RESIDENCY_ID:()=>Gc,HAS_EXPIRATION_EXTENDED_TYPE:()=>cm,HAS_ORIGINATING_OPERATION:()=>am,HAS_PREVIOUS_RESIDENCY_ID:()=>qc,REMOTE_SEQUENCE_UPDATE:()=>a_,createAuditEntry:()=>_u,getLastRemoved:()=>yA,openAuditStore:()=>s_,readAuditEntry:()=>vt,removeAuditEntry:()=>i_,setAuditRetention:()=>cZ,transactionKeyEncoder:()=>Pv});function s_(e){let t=e.auditStore=e.openDB(_A.AUDIT_STORE_NAME,{create:!1,...im});t||(t=e.auditStore=e.openDB(_A.AUDIT_STORE_NAME,im),Av(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=SA;rm(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:_}of t.getRange({start:1,snapshot:!1,end:Date.now()-gA/(1+i*i)})){try{m=i_(t,p,_)}catch(g){Eu.warn("Error removing audit entry",g)}if(h=p,await new Promise(setImmediate),++f>=aZ){a=10;break}}await m}finally{f===0?a=Math.min(a<<1,gA/10):(Av(t,h),a>100&&(a=a>>1)),d(void 0),c()}},a).unref()});return u}if(o(c,"scheduleAuditCleanup"),t.scheduleAuditCleanup=c,(0,sm.getWorkerIndex)()===(0,sm.getWorkerCount)()-1&&c(),(0,sm.getWorkerIndex)()===0&&!yv)for(let l of t.getKeys({reverse:!0,limit:1}))l>Date.now()&&(yv=!0,Eu.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 i_(e,t,r){let n=uZ(r),s;if(n&bn){s=vt(r);let i=e.tableStores[s.tableId],a=i?.getEntry(s.recordId);(!a||a.version!==s.version||!a.value)&&Fc(()=>_a(s.getValue(i)),i.rootStore)}if((n&15)===TA){s=s||vt(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 Av(e,t){RA[0]=t,e.put(Symbol.for("last-removed"),Lv)}function yA(e){let t=e.get(Symbol.for("last-removed"));if(t)return Lv.set(t),RA[0]}function cZ(e,t=SA){gA=e,SA=t}function _u(e,t,r,n,s,i,a,c,l,u,d,f,m){let h=Dv[a];if(!h)throw new Error(`Invalid audit entry type ${a}`);let p=1;if(n&&(n>1?ga.setFloat64(0,n):Ts.set(AA),p=9),l){if(l&255)throw new Error("Illegal extended type");p+=3}y(s),y(t),g(r),ga.setFloat64(p,e),p+=8,l&Gc&&y(u),l&qc&&y(d),l&cm&&(ga.setFloat64(p,f),p+=8),l&am&&y(Mv[m]),i?g(i):Ts[p++]=0,l?ga.setUint32(n?8:0,h|l|3221225472):Ts[n?8:0]=h;let _=Ts.subarray(0,p);if(c)return Buffer.concat([_,c]);return _;function g(T){let R=p;p+=1,p=(0,Hc.writeKey)(T,Ts,p);let I=p-R-1;I>127?I>16383?(Eu.error("Key or username was too large for audit entry",T),p=R+1,Ts[R]=0):(Ts.copyWithin(R+2,R+1,p),ga.setUint16(R,I|32768),p++):Ts[R]=I}function y(T){T<128?Ts[p++]=T:T<16384?(ga.setUint16(p,T|32768),p+=2):T<1056964608?(ga.setUint32(p,T|3221225472),p+=4):(Ts[p]=255,ga.setUint32(p+1,T),p+=5)}}function uZ(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 kc(e.buffer,e.byteOffset,e.byteLength));return n.position=t,n.readInt()}function vt(e,t=0,r=void 0){try{let n=e.dataView||(e.dataView=new kc(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,_;if(i&Gc&&(m=n.readInt()),i&qc&&(h=n.readInt()),i&cm&&(p=n.readFloat64()),i&am){let R=n.readInt();_=Mv[R]}l=n.readInt();let g=n.position,y=n.position+=l,T;return{type:Dv[i&7],tableId:c,nodeId:a,get recordId(){return(0,Hc.readKey)(e,u,d)},getBinaryRecordId(){return e.subarray(u,d)},version:f,previousLocalTime:s,get user(){return y>g?(0,Hc.readKey)(e,g,y):void 0},get encoded(){return t?e.subarray(t,r):e},getValue(R,I,P){if(i&r_||i&nm&&!I)return T||(T=Fc(()=>R.decoder.decode(e.subarray(n.position,r)),R.rootStore)),T;if(i&nm&&P)return Qy(R.getEntry(this.recordId),P,R)},getBinaryValue(){return i&(r_|nm)?e.subarray(n.position,r):void 0},extendedType:i,residencyId:m,previousResidencyId:h,expiresAt:p,originatingOperation:_}}catch(n){return Eu.error("Reading audit entry error",n,e),{}}}var Hc,n_,_A,sm,Cv,Eu,Ts,ga,Pv,im,gA,aZ,RA,Lv,SA,yv,r_,nm,bv,TA,Iv,Nv,wv,Ov,o_,lZ,a_,Gc,qc,am,cm,bn,Dv,Mv,kc,lo=fe(()=>{Hc=require("ordered-binary"),n_=w(ce()),_A=w(kt());k();sm=w(st()),Cv=w(ie());$c();Eu=w(z());BE();Ss();t_();(0,n_.initSync)();Ts=Buffer.alloc(2816),ga=new DataView(Ts.buffer,Ts.byteOffset,2816),Pv={writeKey(e,t,r){return e===om?(t.set(om,r),r+8):typeof e=="number"?((t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).setFloat64(r,e),r+8):(0,Hc.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,Hc.readKey)(e,t,r)}},im={encoding:"binary",keyEncoder:Pv},gA=(0,Cv.convertToMS)((0,n_.get)(U.LOGGING_AUDITRETENTION))||86400*3,aZ=1e3,RA=new Float64Array(1),Lv=new Uint8Array(RA.buffer),SA=1e4,yv=!1;o(s_,"openAuditStore");o(i_,"removeAuditEntry");o(Av,"updateLastRemoved");o(yA,"getLastRemoved");o(cZ,"setAuditRetention");r_=16,nm=32,bv=1,TA=2,Iv=3,Nv=4,wv=5,Ov=6,o_=14,lZ=15,a_=11,Gc=512,qc=1024,am=2048,cm=4096,bn=8192,Dv={put:bv|r_,[bv]:"put",delete:TA,[TA]:"delete",message:Iv|r_,[Iv]:"message",invalidate:Nv|nm,[Nv]:"invalidate",patch:wv|nm,[wv]:"patch",relocate:Ov,[Ov]:"relocate"},Mv={insert:1,update:2,upsert:3,1:"insert",2:"update",3:"upsert"};o(_u,"createAuditEntry");o(uZ,"readAction");o(vt,"readAuditEntry");kc=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 Hv={};Ce(Hv,{ENTRY:()=>fZ,HAS_EXPIRATION:()=>u_,HAS_RESIDENCY_ID:()=>CA,HAS_STRUCTURE_UPDATE:()=>d_,LAST_TIMESTAMP_PLACEHOLDER:()=>om,LOCAL_TIMESTAMP:()=>dZ,METADATA:()=>Su,NEW_TIMESTAMP_PLACEHOLDER:()=>xv,NO_TIMESTAMP:()=>bA,PENDING_LOCAL_TIME:()=>PA,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>AA,RecordEncoder:()=>OA,TIMESTAMP_ASSIGN_LAST:()=>hZ,TIMESTAMP_ASSIGN_NEW:()=>Bv,TIMESTAMP_ASSIGN_PREVIOUS:()=>Fv,TIMESTAMP_PLACEHOLDER:()=>c_,TIMESTAMP_RECORD_PREVIOUS:()=>IA,entryMap:()=>Sa,handleLocalTimeForGets:()=>f_,lastMetadata:()=>at,recordUpdater:()=>LA,removeEntry:()=>Kc});function EZ(){return dm[0]=dm[0]^64,mZ.getFloat64(0)}function f_(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++,at=null;let l=r.call(this,a,c);return l&&(at&&(l.metadataFlags=at[Su],l.localTime=at.localTime,l.residencyId=at.residencyId,at.expiresAt>=0&&(l.expiresAt=at.expiresAt),at=null),l.value&&Sa.set(l.value,l),l.key=a),l};let n=e.get;e.get=function(a,c){at=null;let l=n.call(this,a,c);return at&&l&&(Sa.set(l,at),at=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=>(at&&(l.metadataFlags=at[Su],l.localTime=at.localTime,l.residencyId=at.residencyId,at.expiresAt>=0&&(l.expiresAt=at.expiresAt),at=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,Vc.push(new WeakRef(this))),c.call(this)},a.prototype.done=function(){if(l.call(this),this.isDone)for(let u=0;u<Vc.length;u++){let d=Vc[u].deref();(!d||d.isDone||d.isCommitted)&&Vc.splice(u--,1)}},a.prototype.done.isTracked=!0}return e}function LA(e,t,r){return function(n,s,i,a,c=-1,l,u,d="put",f,m){f||l==null?gu=i?.localTime?IA|Fv:bA:gu=l?i?.localTime?IA|16384:Bv|16384:bA;let h=u?.expiresAt;if(h>=0&&(c|=u_),um=c,NA=h,i?.version===a&&l===!1)throw new Error("Must retain local time if version is not changed");let p={version:a,instructedWrite:gu>0},_,g=0;try{let y=i?.residencyId,T=u?.residencyId;T&&(wA=T,um|=CA,g|=Gc),y!==T&&(g|=qc,y||(y=0)),c&u_&&(g|=cm),u?.originatingOperation&&(g|=am),f&&(p.ifVersion=_=i?.version??null),i&&i.value&&i.metadataFlags&bn&&(r.getBinaryFast(i.localTime)||_a(i.value));let R;if(s!==void 0&&(R=jE(()=>e.put(n,s,p),n,e.rootStore),Bc&&(g|=bn)),l){let I=u?.user?.username;if(m&&(jE(()=>e.encoder.encode(m),n,e.rootStore),Bc&&(g|=bn)),e.encoder.hasStructureUpdate&&(g|=d_,e.encoder.hasStructureUpdate=!1),f&&i?.localTime){let P=i?.localTime,Y=r.get(P);if(Y){let te=vt(Y).previousLocalTime;return R=r.put(P,_u(a,t,n,te,u?.nodeId??server.replication.getThisNodeId(r)??0,I,d,lm,g,T,y,h),{ifVersion:_}),R}}R=r.put(s===void 0?xv:om,_u(a,t,n,i?.localTime?1:0,u?.nodeId??server.replication?.getThisNodeId(r)??0,I,d,lm,g,T,y,h,u?.originatingOperation),{append:d!=="invalidate",instructedWrite:!0,ifVersion:_})}return R}catch(y){throw y.message+=" id: "+n+" options: "+p,y}}}function Kc(e,t,r){if(t)return t.value&&t.metadataFlags&bn&&!e.auditStore.getBinaryFast(t.localTime)&&_a(t.value),e.remove(t.key,r)}var Uv,l_,c_,om,AA,xv,dZ,Su,fZ,dm,mZ,bA,Bv,hZ,Fv,IA,u_,CA,PA,d_,Sa,pZ,lm,gu,um,NA,wA,at,OA,Vc,$c=fe(()=>{Uv=require("msgpackr");lo();l_=w(z());Ss();Ss();c_=new Uint8Array([1,1,1,1,4,64,0,0]),om=new Uint8Array([1,1,1,1,1,0,0,0]),AA=new Uint8Array([1,1,1,1,3,64,0,0]),xv=new Uint8Array([1,1,1,1,0,64,0,0]),dZ=Symbol("local-timestamp"),Su=Symbol("metadata"),fZ=Symbol("entry"),dm=new Uint8Array(8),mZ=new DataView(dm.buffer,0,8),bA=0,Bv=0,hZ=1,Fv=3,IA=4,u_=16,CA=32,PA=1,d_=256,Sa=new WeakMap,gu=0,um=-1,NA=-1,wA=0,at=null,OA=class extends Uv.Encoder{static{o(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0;class r{static{o(this,"RecordObject")}getUpdatedTime(){return Sa.get(this)?.version}getExpiresAt(){return Sa.get(this)?.expiresAt}}t.structPrototype=r.prototype,super(t);let n=this.encode;this.encode=function(i,a){if(gu||um>=0){let c=0,l=gu;l&&(c+=8,gu=0);let u=um,d=NA,f=wA;u>=0&&(c+=4,um=-1,d>=0&&(c+=8,NA=-1),f&&(c+=4,wA=0));let m=pZ=n.call(this,i,a|2048|c);lm=m.subarray((m.start||0)+c,m.end);let h=m.start||0;return l&&(c_[4]=l,c_[5]=l>>8,m.set(c_,h),h+=8),Bc&&(u|=bn),u>=0&&((m.dataView||(m.dataView=new DataView(m.buffer,m.byteOffset,m.byteLength))).setUint32(h,u|o_<<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 lm=n.call(this,i,a),lm};let s=this.saveStructures;this.saveStructures=function(i,a){let c=s.call(this,i,a);return this.hasStructureUpdate=!0,c}}decode(t,r){at=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(dm,0,c),c+=8;else for(let m=0;m<8;m++)dm[m]=t[c++];l=EZ(),i=t[c]}let u,d;i<32&&(i===o_?(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&u_&&(u=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8),a&CA&&(d=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4));let f=Fc(()=>r?.valueAsBuffer?t.subarray(c,s):super.decode(t.subarray(c,s),s-c),this.rootStore);return at={localTime:l,[Su]:a,expiresAt:u,residencyId:d},f}return r?.valueAsBuffer?t:Fc(()=>super.decode(t,r),this.rootStore)}catch(c){return l_.error("Error decoding record",c,"data: "+t.slice(0,40).toString("hex")),null}}};o(EZ,"getTimestamp");o(f_,"handleLocalTimeForGets");Vc=[];setInterval(()=>{for(let e=0;e<Vc.length;e++){let t=Vc[e].deref();!t||t.isDone||t.isCommitted?Vc.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(l_.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):l_.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(LA,"recordUpdater");o(Kc,"removeEntry")});function vA(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],_=u(p);f=f.concat(_)}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?vA(f.conditions,f.operator,r,n,s,i,a,c):Au(f,n,f.descending||s.reverse===!0,r,s.allowFullScan,c,i)}o(u,"executeCondition");function d(f,m,h){return f.map((p,_)=>{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=mm(p,r,i,c,g,h);return m&&_<f.length-1&&h&&(h=IZ(r.primaryStore,p.estimated_count,h)),y}).filter(Boolean)}o(d,"mapConditionsToFilters")}function Au(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=Oi(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=Au({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=!!Oi(P.attributes,I.relationship.to)?.elements;te=RZ(te,I,P.primaryStore,x,Y)}if(I.relationship.from){let x=o($=>($?.key!==void 0&&($=$.key),Au({attribute:I.relationship.from,value:$},t,r,n,s,Y)),"searchEntry");I.elements?(i[c[0]]=Y,te=yZ(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,_;l instanceof Date&&(l=l.getTime());let g;switch(UA[u]||u){case"lt":m=!0,h=l;break;case"le":m=!0,h=l,p=!0;break;case"gt":m=l,_=!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]=wi.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",_=u==="gtlt"||u==="gtle";break;case"equals":case void 0:m=l,h=l,p=!0;break;case"ne":if(l===null){m=l,_=!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>Rs.MAX_SEARCH_KEY_LENGTH&&(m=m.slice(0,Rs.MAX_SEARCH_KEY_LENGTH)+Rs.OVERFLOW_MARKER,_=!1,y=mm(e,n,null,i,d)),typeof h=="string"&&h.length>Rs.MAX_SEARCH_KEY_LENGTH&&(h=h.slice(0,Rs.MAX_SEARCH_KEY_LENGTH)+Rs.OVERFLOW_MARKER,p=!0,y=y??mm(e,n,null,i,d)),r){let R=m;m=h,h=R,R=!_,_=!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??mm(e,n,null,i,d),!y)throw new qr.ClientError(`Unknown search operator ${e.comparator}`)}let T={start:m,end:h,inclusiveEnd:p,exclusiveStart:_,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:Ta.SKIP:new Promise((Y,te)=>setImmediate(()=>{try{Y(P&&y(P)?I:Ta.SKIP)}catch(x){te(x)}}))}:I=>I.value==null&&!(I.metadataFlags&(In|Ra))?Ta.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>Rs.MAX_SEARCH_KEY_LENGTH?P=n.primaryStore.get(I):P={[c]:R},this.isSync?y(P)?I:Ta.SKIP:new Promise((Y,te)=>setImmediate(()=>{try{Y(y(P)?I:Ta.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:Ta.SKIP:new Promise((P,Y)=>setImmediate(()=>{try{P(I&&y(I)?R:Ta.SKIP)}catch(te){Y(te)}}))})}function Oi(e,t){if(Array.isArray(t))if(t.length>1){let r=Oi(e,t[0]),n=(r?.definition?.tableClass||r?.elements?.definition?.tableClass)?.attributes??r?.properties;return n?Oi(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 RZ(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 yZ(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 mm(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=Oi(t.attributes,d),m=f.definition?.tableClass||f.elements.definition?.tableClass,h=n?.[d],p=mm({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 _=t.propertyResolvers?.[d];_.to&&(p.to=_.to);let g,y=o((R,I)=>{let P,Y;return _?_.returnDirect?(P=_(R,r,I),Y=at):(Y=_(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(_&&p.idFilter){if(!g)if(p.idFilter.idSet?.size===1){for(let $ of p.idFilter.idSet)e={attribute:_.from??t.primaryKey,value:$};g=u(_.from??t.primaryKey,p.idFilter,!0,!0)}else g=u(_.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()),UA[a]||a){case Rs.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,wi.compareKeys)(d,l[0])>=0&&(0,wi.compareKeys)(d,l[1])<=0,!0);case"gt":return u(c,d=>(0,wi.compareKeys)(d,l)>0);case"ge":return u(c,d=>(0,wi.compareKeys)(d,l)>=0);case"lt":return u(c,d=>(0,wi.compareKeys)(d,l)<0);case"le":return u(c,d=>(0,wi.compareKeys)(d,l)<=0);case"ne":return u(c,d=>(0,wi.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&&h_(t)(e),p=e.estimated_count>>4,(isNaN(p)||p>=i)&&(m=!1));let _=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&&++_/g*i>p)){let P=Au(e,r.transaction.getReadTxn(),!1,t),Y;y.to?Y=P.flatMap(x=>t.primaryStore.get(x)[y.to]):Y=P.map(bu);let te=new Set(Y);y.idFilter=x=>te.has(bu(x)),y.idFilter.idSet=te}return I}return o(y,"recordFilter"),s&&(y.idFilter=f),y}o(u,"attributeComparator")}function h_(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/go(e.primaryStore):i.estimated_count}return r.estimated_count=s,r.estimated_count}let n=r.comparator||r.search_type;if(n=UA[n]||n,n===Rs.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=Oi(e.attributes,s[0]),a=i.definition?.tableClass||i.elements.definition?.tableClass,c=h_(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*go(e.indices[i.relationship.from])/(go(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=go(e.primaryStore)-(i?i.getValuesCount(null):0):r.estimated_count=1/0}else if(n==="starts_with"||n==="prefix")r.estimated_count=SZ*go(e.primaryStore)+1;else if(n==="between")r.estimated_count=gZ*go(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=go(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=_Z*go(e.primaryStore)+1}typeof r.descending=="boolean"&&(r.estimated_count/=2)}return r.estimated_count}return o(t,"estimateConditionForTable"),t}function p_(e,t){if(e)if(So=e,Tu.lastIndex=0,AZ.test(e))try{if(t&&(t.conditions=[]),js=t??new yu,fm(js,""),Lr!==So.length&&Gt("Unable to parse query, unexpected end of query"),js.parseErrorMessage&&(js.parseError=new DA(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 '${So}'`,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 fm(e,t){let r=Tu,n,s,i,a,c,l=decodeURIComponent,u;for(;n=r.exec(So);){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=kv):(l=decodeURIComponent,i="equals",d||Gt("attribute must be specified before equality comparator"),s=Ru(d));break;case"==":case"!=":case"<":case"<=":case">":case">=":case"===":case"!==":i=TZ[f],l=MA[i]?kv:decodeURIComponent,d||Gt(`attribute must be specified before comparator ${f}`),s=Ru(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"&&Gv(p,d),s===""){let _=e.conditions[e.conditions.length-1];_.chainedConditions=_.chainedConditions||[],_.chainedConditions.push(p),_.operator=u}else m_(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(Ru(d)),s=void 0;break;case"(":Tu.lastIndex=Lr;let h=fm(d?[]:new yu,")");switch(d){case"":m_(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=qv(h);break;default:Gt(`unknown query function call ${d}`)}So[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"),Tu.lastIndex=Lr,m=fm([],"}"),m.name=d,e.push(m),So[Lr]===","?r.lastIndex=++Lr:a=!0;break;case"[":if(Tu.lastIndex=Lr,d?(m=fm(new yu,"]"),m.name=d):m=fm(e.conditions?new yu:[],"]"),e.conditions)if(m_(e,u),So[Lr]==="="){l=decodeURIComponent,i="equals",s=Ru(d),r.lastIndex=++Lr;break}else e.conditions.push(m),s=null;else e.push(m);So[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"&&Gv(p,d),m_(e,u),e.conditions.push(p)}else d&&Gt("no attribute or comparison specified");else(d||e.length>0&&c)&&e.push(Ru(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?bZ:Tu,r.lastIndex=Lr),Lr===So.length)return e}t&&Gt(`expected '${t}', but encountered end of string`)}function m_(e,t){e.conditions.length>0&&(e.operator?e.operator!==t&&Gt("Can not mix operators within a condition grouping"):e.operator=t)}function Ru(e){return e.indexOf(".")>-1?e.split(".").map(Ru):decodeURIComponent(e)}function kv(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 Gv(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 qv(e){let t=$v(e[0]);return e.length>1&&(t.next=qv(e.slice(1))),t}function $v(e){if(Array.isArray(e)){let t=$v(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 bu(e){return Array.isArray(e)?e.join("\0"):e}function go(e){let t=Date.now();return(e.estimatedEntryCountExpires||0)<t&&(e.estimatedEntryCount=e.getStats().entryCount,e.estimatedEntryCountExpires=t+1e4),e.estimatedEntryCount}function IZ(e,t,r){return t*r/go(e)}var qr,Rs,wi,Ta,_Z,gZ,SZ,TZ,MA,UA,DA,AZ,Tu,bZ,Lr,js,So,yu,E_=fe(()=>{qr=w(Ee()),Rs=w(kt()),wi=require("ordered-binary"),Ta=require("lmdb");hm();$c();_Z=.3,gZ=.1,SZ=.05,TZ={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},MA={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};o(vA,"executeConditions");o(Au,"searchByIndex");o(Oi,"findAttribute");o(RZ,"joinTo");o(yZ,"joinFrom");UA={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(mm,"filterByType");o(h_,"estimateCondition");DA=class extends qr.Violation{static{o(this,"SyntaxViolation")}},AZ=/[()[\]|!<>.]|(=\w*=)/,Tu=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,bZ=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/g;o(p_,"parseQuery");o(Gt,"recordError");o(fm,"parseBlock");o(m_,"assignOperator");o(Ru,"decodeProperty");o(kv,"typedDecoding");o(Gv,"wildcardDecoding");o(qv,"toSortObject");o($v,"toSortEntry");yu=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(bu,"flattenKey");o(go,"estimatedEntryCount");o(IZ,"intersectionEstimate")});var Vv,Qs,__=fe(()=>{Vv=w(Ys());ya();Qs=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,Vv._assignPackageExport)("Resource",Dr)});var jv={};Ce(jv,{MultiPartId:()=>g_,Resource:()=>Dr,contextStorage:()=>Nu,snakeCase:()=>wZ,transformForSelect:()=>S_});function wZ(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function Kv(e,t){if(Yc=!1,e==="")return null;if(e=e.slice(1),t.splitSegments){if(e.indexOf("/")===-1)return e===""?(Yc=!0,null):t.coerceId(decodeURIComponent(e));let r=e.split("/"),n=new g_;for(let s=0;s<r.length;s++){let i=r[s];if(!i&&s===r.length-1){Yc=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}else{if(e==="")return Yc=!0,null;e[e.length-1]==="/"&&(Yc=!0)}return t.coerceId(decodeURIComponent(e))}function Nn(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 co?a=i:d=i;else if(s&&typeof s=="object")d=s,s=void 0,c=d.getId?.()??d[this.primaryKey];else throw new Iu.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 _=c.indexOf("?");_>-1&&(l=this.parseQuery(c.slice(_+1),s),c=c.slice(0,_),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 _ of s){if(typeof _=="object"&&_)break;c.push(_)}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 Qs,l.id=c,u=!1)))}c===void 0&&(c=s.id??null,c==null&&(u=!0))}else c=s,l=new Qs,l.id=c,c==null&&(u=!0);l||(l=new Qs,l.id=c),u&&(l.isCollection=!0);let f;a||(a=Nu.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(_=>Nu.run(a,()=>p(_)),"runAction")),a?.transaction){let _=this.getResource(c,a,f);return _.then?_.then(h):h(_)}else return Mt(a,()=>{let _=this.getResource(c,a,f);return _.then?_.then(h):h(_)},f);function p(_){if(m!==!1&&a.authorize){a.authorize=!1;let g=t.type==="read"?_.allowRead(a.user,l,a):t.type==="update"?_.doesExist?.()===!1?_.allowCreate(a.user,d,a):_.allowUpdate(a.user,d,a):t.type==="create"?_.allowCreate(a.user,d,a):_.allowDelete(a.user,l,a);if(g?.then)return g.then(y=>{if(!y)throw new Iu.AccessViolation(a.user);return typeof d?.then=="function"?d.then(T=>e(_,l,a,T)):e(_,l,a,d)});if(!g)throw new Iu.AccessViolation(a.user)}return typeof d?.then=="function"?d.then(g=>e(_,l,a,g)):e(_,l,a,d)}o(p,"authorizeActionOnResource")}}function qn(e,t){let r=new Iu.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 xA(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 S_(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):xA(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(xA(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(xA(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]=S_(c.select||c,d)}let u=a(c.name);return l(u)}else return a(c);else return c}}o(i,"handleProperty")}var Yv,Wv,Iu,zv,Nu,NZ,Dr,Yc,g_,ya=fe(()=>{Yv=require("crypto");Kf();mu();Wv=w(Ys()),Iu=w(Ee());Dc();E_();zv=require("async_hooks");__();Nu=new zv.AsyncLocalStorage,NZ={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=Nn(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=S_(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=Nn(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):qn(t,"put")},{hasContent:!0,type:"update"});static patch=Nn(function(t,r,n,s){return t.patch?t.constructor.loadAsInstance===!1?t.patch(r,s):t.patch(s,r):qn(t,"patch")},{hasContent:!0,type:"update"});static delete=Nn(function(t,r,n,s){return t.delete?t.delete(r):qn(t,"delete")},{hasContent:!1,type:"delete"});static getNewId(){return(0,Yv.randomUUID)()}static create(t,r,n){n?n.getContext&&(n=n.getContext()):n=Nu.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),Mt(n,async()=>{let i=new this(s,n),a=await i.create?i.create(s,r):qn(i,"create");return n.newLocation=s??a?.[this.primaryKey],n.createdResource=!0,this.loadAsInstance===!1?a:i})}static invalidate=Nn(function(t,r,n,s){return t.invalidate?t.invalidate(r):qn(t,"delete")},{hasContent:!1,type:"update"});static post=Nn(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=Nn(function(t,r,n,s){return t.update(r,s)},{hasContent:!0,type:"create"});static connect=Nn(function(t,r,n,s){return t.connect?t.constructor.loadAsInstance===!1?t.connect(r,s):t.connect(s,r):qn(t,"connect")},{hasContent:!0,type:"read"});static subscribe=Nn(function(t,r,n,s){return t.subscribe?t.subscribe(r):qn(t,"subscribe")},{type:"read"});static publish=Nn(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):qn(t,"publish")},{hasContent:!0,type:"create"});static search=Nn(function(t,r,n){let s=t.search?t.search(r):qn(t,"search"),i=n.select;if(i&&n.hasOwnProperty("select")&&s!=null&&!s.selectApplied){let a=S_(i,t.constructor);return s.map(a)}return s},{type:"read"});static query=Nn(function(t,r,n,s){return t.search?t.constructor.loadAsInstance===!1?t.search(r,s):t.search(s,r):qn(t,"search")},{hasContent:!0,type:"read"});static copy=Nn(function(t,r,n,s){return t.copy?t.constructor.loadAsInstance===!1?t.copy(r,s):t.copy(s,r):qn(t,"copy")},{hasContent:!0,type:"create"});static move=Nn(function(t,r,n,s){return t.move?t.constructor.loadAsInstance===!1?t.move(r,s):t.move(s,r):qn(t,"move")},{hasContent:!0,type:"delete"});async post(t){if(this.#r)return(await this.constructor.create(this.#e,t,this.#t)).#e;qn(this,"post")}static isCollection(t){return t&&t.#r}get isCollection(){return this.#r}static coerceId(t){return t}static parseQuery(t,r){return p_(t,r)}static parsePath(t,r,n){let s=t.indexOf(".");if(s>-1){let a=t.slice(s+1),c=r?.headers&&NZ[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:Kv(t,this),isCollection:Yc}}let i=Kv(t,this);return Yc?{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 Gn}connect(t,r){return r?.subscribe!==!1?this.subscribe?.(r):new Gn}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,Wv._assignPackageExport)("Resource",Dr);o(wZ,"snakeCase");o(Kv,"pathToId");g_=class extends Array{static{o(this,"MultiPartId")}toString(){return this.join("/")}};o(Nn,"transactional");o(qn,"missingMethod");o(xA,"selectFromObject");o(S_,"transformForSelect")});var Wc,BA=fe(()=>{Wc=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 Xv={};Ce(Xv,{Resources:()=>T_,keyArrayToString:()=>wu,resetResources:()=>OZ,resources:()=>ys});function OZ(){return ys=new T_,ve.resources=ys,ys}function wu(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var Qv,Jv,T_,ys,Ou=fe(()=>{Dc();BA();Qv=w(z()),Jv=w(Ee());Pr();T_=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 Jv.ServerError(`Conflicting paths for ${t}`);Qv.default.error(c),i.Resource=new Wc(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 Mt(r,async()=>{let s=this.getMatch(t);if(s)return t=s.relativeURL,n(s.Resource,s.path,t)})}setRepresentation(t,r,n){}};o(OZ,"resetResources");o(wu,"keyArrayToString")});function kA(e,t,r,n,s){let i=e.primaryStore.env.path,a=e.primaryStore.tableId,c;s?.crossThreads===!1?(c=eU,CZ(e.primaryStore,e.auditStore)):(c=Zv,e.primaryStore.env.hasSubscriptionCommitListener||(e.primaryStore.env.hasSubscriptionCommitListener=!0,e.primaryStore.on("committed",()=>{tU(Zv[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=wu(t);let d=new HA(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 tU(e){if(!e)return;let t=e.auditStore;t.resetReadTxn(),rU(e.auditStore);let r;for(let{key:n,value:s}of t.getRange({start:e.lastTxnTime,exclusiveStart:!0})){e.lastTxnTime=n;let i=vt(s),a=e[i.tableId];if(!a)continue;let c=i.recordId,l=wu(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,FA.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,FA.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 CZ(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=eU[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{tU(l)}finally{r.threadLocalWrites[0]=l.lastTxnTime,r.unlock("thread-local-writes")}},"acquiredLock");r.attemptLock("thread-local-writes",u)&&u()})}}function rU(e){e.nextTransaction?.resolve();let t;e.nextTransaction=new Promise(r=>{t=r}),e.nextTransaction.resolve=t}function nU(e){return e.nextTransaction||(kA({primaryStore:e,auditStore:e},null,null,0,{scope:"full-database"}),rU(e)),e.nextTransaction}var FA,Zv,eU,HA,GA=fe(()=>{FA=w(z());mu();Ou();lo();Zv=Object.create(null),eU=Object.create(null);o(kA,"addSubscription");HA=class extends Gn{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(tU,"notifyFromTransactionData");o(CZ,"listenToCommits");o(rU,"nextTransaction");o(nU,"whenNextTransaction")});var iU=M((ANe,sU)=>{"use strict";var qA=class{static{o(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};sU.exports=qA});var aU=M((INe,oU)=>{"use strict";var $A=class{static{o(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};oU.exports=$A});var pm=M((wNe,lU)=>{"use strict";var cU=ce(),PZ=(k(),v(K)),{RecordEncoder:LZ}=($c(),v(Hv));cU.initSync();var DZ=cU.get(PZ.CONFIG_PARAMS.STORAGE_CACHING)!==!1,VA=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=DZ&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:LZ})}};lU.exports=VA});var Em=M((CNe,uU)=>{"use strict";var $n=ce(),As=(k(),v(K));$n.initSync();var R_=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=$n.get(As.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||$n.get(As.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||$n.get(As.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",$n.get(As.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=$n.get(As.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),$n.get(As.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=$n.get(As.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),$n.get(As.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=$n.get(As.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),$n.get(As.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=$n.get(As.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=$n.get(As.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};uU.exports=R_;R_.MAX_DBS=1e4});var Et=M((LNe,TU)=>{"use strict";var YA=require("lmdb"),Js=require("fs-extra"),Vn=require("path"),y_=Rn(),mU=z(),wn=en().LMDB_ERRORS_ENUM,A_=aU(),WA=pm(),hU=Em(),Aa=kt(),dU=(k(),v(K)),{table:MZ,resetDatabases:vZ}=(Le(),v(ft)),fU=ce(),Xs=Aa.INTERNAL_DBIS_NAME,pU=Aa.DBI_DEFINITION_NAME,UZ="data.mdb",xZ="lock.mdb",_m=".mdb",BZ="-lock",KA=class{static{o(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=bs(t,r),this.key_type=this.dbi[Aa.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[Aa.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new YA.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function b_(e,t){if(e===void 0)throw new Error(wn.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(wn.ENV_NAME_REQUIRED)}o(b_,"pathEnvNameValidation");async function zA(e,t,r=!0){try{await Js.access(e)}catch(n){throw n.code==="ENOENT"?new Error(wn.INVALID_BASE_PATH):n}try{let n=Vn.join(e,t+_m);return await Js.access(n,Js.constants.R_OK|Js.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await Js.access(Vn.join(e,t,UZ),Js.constants.R_OK|Js.constants.F_OK),Vn.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(wn.INVALID_ENVIRONMENT)}else throw new Error(wn.INVALID_ENVIRONMENT);throw n}}o(zA,"validateEnvironmentPath");function I_(e,t){if(y_.validateEnv(e),t===void 0)throw new Error(wn.DBI_NAME_REQUIRED)}o(I_,"validateEnvDBIName");async function FZ(e,t,r=!1,n=!1){b_(e,t);let s=Vn.basename(e);t=t.toString();let i=fU.get(dU.CONFIG_PARAMS.DATABASES);i||fU.setProperty(dU.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await zA(e,t,n),EU(e,t,r)}catch(a){if(a.message===wn.INVALID_ENVIRONMENT){let c=Vn.join(e,t);await Js.mkdirp(n?c:e);let l=new hU(n?c:c+_m,!1),u=YA.open(l);u.dbis=Object.create(null);let d=new WA(!1);u.openDB(Xs,d),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let f=jA(e,t,r);return u[Aa.ENVIRONMENT_NAME_KEY]=f,global.lmdb_map[f]=u,u}throw a}}o(FZ,"createEnvironment");async function HZ(e,t,r,n=!0){b_(e,t),t=t.toString();let s=Vn.join(e,t);return MZ({table:t,database:Vn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}o(HZ,"copyEnvironment");async function EU(e,t,r=!1){b_(e,t),t=t.toString();let n=jA(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 zA(e,t),i=Vn.join(e,t+_m),a=s!=i,c=new hU(s,a),l=YA.open(c);l.dbis=Object.create(null);let u=gU(l);for(let d=0;d<u.length;d++)bs(l,u[d]);return l[Aa.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}o(EU,"openEnvironment");async function kZ(e,t,r=!1){b_(e,t),t=t.toString();let n=Vn.join(e,t+_m),s=await zA(e,t);if(global.lmdb_map!==void 0){let i=jA(e,t,r);if(global.lmdb_map[i]){let a=global.lmdb_map[i];await _U(a),delete global.lmdb_map[i]}}await Js.remove(s),await Js.remove(s===n?s+BZ:Vn.join(Vn.dirname(s),xZ))}o(kZ,"deleteEnvironment");async function _U(e){y_.validateEnv(e);let t=e[Aa.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}o(_U,"closeEnvironment");function jA(e,t,r=!1){let s=`${Vn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}o(jA,"getCachedEnvironmentName");function GZ(e){y_.validateEnv(e);let t=Object.create(null),r=bs(e,Xs);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==Xs)try{t[n]=Object.assign(new A_,s)}catch{mU.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}o(GZ,"listDBIDefinitions");function gU(e){y_.validateEnv(e);let t=[],r=bs(e,Xs);for(let{key:n}of r.getRange({start:!1}))n!==Xs&&t.push(n);return t}o(gU,"listDBIs");function qZ(e,t){let n=bs(e,Xs).getEntry(t),s=new A_;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{mU.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}o(qZ,"getDBIDefinition");function SU(e,t,r,n=!r){if(I_(e,t),t=t.toString(),t===Xs)throw new Error(wn.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return bs(e,t)}catch(s){if(s.message===wn.DBI_DOES_NOT_EXIST){let i=new WA(r,n===!0),a=e.openDB(t,i),c=new A_(r===!0,n);return a[pU]=c,bs(e,Xs).putSync(t,c),e.dbis[t]=a,a}throw s}}o(SU,"createDBI");function bs(e,t){if(I_(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==Xs?r=qZ(e,t):r=new A_,r===void 0)throw new Error(wn.DBI_DOES_NOT_EXIST);let n;try{let s=new WA(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(wn.DBI_DOES_NOT_EXIST):s}return n[pU]=r,e.dbis[t]=n,n}o(bs,"openDBI");function $Z(e,t){I_(e,t),t=t.toString();let r=bs(e,t),n=r.getStats();return r[Aa.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}o($Z,"statDBI");async function VZ(e,t){try{let r=Vn.join(e,t+_m);return(await Js.stat(r)).size}catch{throw new Error(wn.INVALID_ENVIRONMENT)}}o(VZ,"environmentDataSize");function KZ(e,t){if(I_(e,t),t=t.toString(),t===Xs)throw new Error(wn.CANNOT_DROP_INTERNAL_DBIS_NAME);bs(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],bs(e,Xs).removeSync(t)}o(KZ,"dropDBI");function YZ(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{bs(e,i)}catch(a){if(a.message===wn.DBI_DOES_NOT_EXIST)SU(e,i,i!==t,i===t),n=!0;else throw a}}n&&vZ()}o(YZ,"initializeDBIs");TU.exports={openDBI:bs,openEnvironment:EU,createEnvironment:FZ,listDBIs:gU,listDBIDefinitions:GZ,createDBI:SU,dropDBI:KZ,statDBI:$Z,deleteEnvironment:kZ,initializeDBIs:YZ,TransactionCursor:KA,environmentDataSize:VZ,copyEnvironment:HZ,closeEnvironment:_U}});var AU=M((MNe,yU)=>{"use strict";var QA=Et(),WZ=z(),RU=en().LMDB_ERRORS_ENUM;yU.exports=zZ;async function zZ(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 QA.closeEnvironment(global.lmdb_map[a])}catch(c){if(c.message!==RU.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await QA.closeEnvironment(global.lmdb_map[n]),await QA.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==RU.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){WZ.error(t)}}o(zZ,"cleanLMDBMap")});var To=M((UNe,jZ)=>{jZ.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 Zs=M((xNe,NU)=>{var QZ=To(),{promisify:JZ}=require("util"),{getDatabases:IU}=(Le(),v(ft));NU.exports={setSchemaDataToGlobal:bU,getTableSchema:XZ,getSystemSchema:ZZ,setSchemaDataToGlobalAsync:JZ(bU)};function bU(e){global.hdb_schema=IU(),e&&e()}o(bU,"setSchemaDataToGlobal");function XZ(e,t,r){let n=IU()[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(XZ,"getTableSchema");function ZZ(){return QZ}o(ZZ,"getSystemSchema")});var HU=M((HNe,FU)=>{"use strict";var JA=require("recursive-iterator"),e6=require("alasql"),XA=require("clone"),wU=ie(),{handleHDBError:OU,hdbErrors:t6}=Ee(),{HDB_ERROR_MSGS:CU,HTTP_STATUS_CODES:PU}=t6,{getDatabases:r6}=(Le(),v(ft)),n6=["DISTINCT_ARRAY"],LU=Symbol("validateTables"),ZA=Symbol("validateTable"),FNe=Symbol("getAllColumns"),DU=Symbol("validateAllColumns"),N_=Symbol("findColumn"),MU=Symbol("validateOrderBy"),gm=Symbol("validateSegment"),eb=Symbol("validateColumn"),vU=Symbol("setColumnsForTable"),UU=Symbol("checkColumnsForAsterisk"),xU=Symbol("validateGroupBy"),BU=Symbol("hasColumns"),tb=class{static{o(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[LU](),this[UU](),this[DU]()}[LU](){if(this[BU]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[ZA](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[ZA](t.table)})}}[BU](){let t=!1,r=new JA(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[ZA](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=r6();if(!r[t.databaseid])throw OU(new Error,CU.SCHEMA_NOT_FOUND(t.databaseid),PU.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw OU(new Error,CU.TABLE_NOT_FOUND(t.databaseid,t.tableid),PU.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=XA(s);i.table=XA(t),this.attributes.push(i)})}[N_](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)}[UU](){let t=new JA(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[vU](r.tableid)}[vU](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new e6.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[DU](){this[gm](this.statement.columns,!1),this[gm](this.statement.joins,!1),this[gm](this.statement.where,!1),this[xU](this.statement.group,!1),this[gm](this.statement.order,!0)}[gm](t,r){if(!t)return;let n=new JA(t),s=[];for(let{node:i,path:a}of n)!wU.isEmpty(i)&&!wU.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[MU](i):s.push(this[eb](i)));return s}[xU](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&n6.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=XA(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[N_](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[N_](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`}[MU](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[eb](t)}[eb](t){let r=this[N_](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]}};FU.exports=tb});var GU=M((GNe,kU)=>{"use strict";var rb=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")}};kU.exports=rb});var $U=M(($Ne,qU)=>{"use strict";var nb=class{static{o(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};qU.exports=nb});var KU=M((KNe,VU)=>{"use strict";var sb=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}};VU.exports=sb});var WU=M((WNe,YU)=>{"use strict";var ib=class{static{o(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};YU.exports=ib});var jc=M((XNe,QU)=>{"use strict";var s6=Et(),i6=$U(),o6=KU(),a6=WU(),Ci=Rn(),Sm=en().LMDB_ERRORS_ENUM,c6=kt(),Ro=(k(),v(K)),l6=ie(),u6=require("uuid"),jNe=require("lmdb"),{handleHDBError:d6,hdbErrors:f6}=Ee(),{OVERFLOW_MARKER:QNe,MAX_SEARCH_KEY_LENGTH:JNe}=c6,zU=ce();zU.initSync();var w_=zU.get(Ro.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),ob=Ro.TIME_STAMP_NAMES_ENUM.CREATED_TIME,zc=Ro.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function m6(e,t,r,n,s=Ci.getNextMonotonicTime()){ub(e,t,r,n),ab(e,t,r);let i=new i6,a=[],c=[];for(let l=0;l<n.length;l++){let u=n[l];jU(u,!0,s);let d=h6(e,t,r,u),f=u[t];a.push(d),c.push(f)}return cb(a,c,n,i,s)}o(m6,"insertRecords");function h6(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][Ro.FUNC_VAL],n[a]=c)}let l=Ci.getIndexedValues(c),u=e.dbis[a];if(l){w_&&u.prefetch(l.map(d=>({key:d,value:s})),O_);for(let d=0,f=l.length;d<f;d++)u.put(l[d],s)}}w_&&e.dbis[t].prefetch([s],O_),e.dbis[t].put(s,n,n[zc])})}o(h6,"insertRecord");function p6(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}o(p6,"removeSkippedRecords");function jU(e,t,r){let n=r>0;(n||!Number.isInteger(e[zc]))&&(e[zc]=r||(r=Ci.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[ob]))&&(e[ob]=r||Ci.getNextMonotonicTime()):delete e[ob]}o(jU,"setTimestamps");function ab(e,t,r){r.indexOf(Ro.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(Ro.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(Ro.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(Ro.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),s6.initializeDBIs(e,t,r)}o(ab,"initializeTransaction");async function E6(e,t,r,n,s=Ci.getNextMonotonicTime()){ub(e,t,r,n),ab(e,t,r);let i=new o6,a=[],c=[],l=[];for(let u=0;u<n.length;u++){let d=n[u],f=d[t],m;try{m=lb(e,t,d,f,i,!0,s)}catch{i.skipped_hashes.push(f),a.push(u);continue}c.push(m),l.push(f)}return cb(c,l,n,i,s,a)}o(E6,"updateRecords");async function _6(e,t,r,n,s=Ci.getNextMonotonicTime()){try{ub(e,t,r,n)}catch(l){throw d6(l,l.message,f6.HTTP_STATUS_CODES.BAD_REQUEST)}ab(e,t,r);let i=new a6,a=[],c=[];for(let l=0;l<n.length;l++){let u=n[l],d;l6.isEmpty(u[t])?(d=u6.v4(),u[t]=d):d=u[t];let f=lb(e,t,u,d,i,!1,s);a.push(f),c.push(d)}return cb(a,c,n,i,s)}o(_6,"upsertRecords");async function cb(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||Ci.getNextMonotonicTime(),p6(r,i),n}o(cb,"finalizeWrite");function lb(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(jU(r,!d,a),Number.isInteger(r[zc])&&u[zc]>r[zc])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 _=r[p],g=e.dbis[p];if(g===void 0)continue;let y=u[p];if(typeof _=="function"){let R=_([[u]]);Array.isArray(R)&&(_=R[0][Ro.FUNC_VAL],r[p]=_)}if(_===y)continue;let T=Ci.getIndexedValues(y);if(T){w_&&g.prefetch(T.map(R=>({key:R,value:n})),O_);for(let R=0,I=T.length;R<I;R++)g.remove(T[R],n)}if(T=Ci.getIndexedValues(_),T){w_&&g.prefetch(T.map(R=>({key:R,value:n})),O_);for(let R=0,I=T.length;R<I;R++)g.put(T[R],n)}}let h={...u,...r};c.put(n,h,h[zc])},"doPut");return l?f=c.ifVersion(n,l.version,m):f=c.ifNoExists(n,m),f.then(h=>h?!0:lb(e,t,r,n,s,i,a))}o(lb,"updateUpsertRecord");function g6(e,t,r){if(Ci.validateEnv(e),t===void 0)throw new Error(Sm.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(Sm.WRITE_ATTRIBUTES_REQUIRED):new Error(Sm.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}o(g6,"validateBasic");function ub(e,t,r,n){if(g6(e,t,r),!Array.isArray(n))throw n===void 0?new Error(Sm.RECORDS_REQUIRED):new Error(Sm.RECORDS_MUST_BE_ARRAY)}o(ub,"validateWrite");function O_(){}o(O_,"noop");QU.exports={insertRecords:m6,updateRecords:E6,upsertRecords:_6}});var ct=M((ewe,JU)=>{"use strict";var On=require("validate.js");On.validators.type=function(e,t,r,n){return e===null||typeof e>"u"||On.validators.type.checks[t](e)?null:` must be a '${t}' value`};On.validators.type.checks={Object:o(function(e){return On.isObject(e)&&!On.isArray(e)},"Object"),Array:On.isArray,Integer:On.isInteger,Number:On.isNumber,String:On.isString,Date:On.isDate,Boolean:o(function(e){return typeof e=="boolean"},"Boolean")};On.validators.hasValidFileExt=function(e,t){return On.isString(e)?e===""?"can't be blank":t.filter(r=>e.endsWith(r)).length>0?null:`must include one of the following valid file extensions - '${t.join("', '")}'`:null};JU.exports={validateObject:S6,validateObjectAsync:T6,validateBySchema:R6};function S6(e,t){if(!e||!t)return new Error("validateObject parameters were null");let r=On(e,t,{format:"flat"});return r?new Error(r):null}o(S6,"validateObject");async function T6(e,t){if(!e||!t)return new Error("validateObject parameters were null");try{await On.async(e,t,{format:"flat"})}catch(r){let n=r.join(",");return new Error(n)}return null}o(T6,"validateObjectAsync");function R6(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}o(R6,"validateBySchema")});var ZU=M((rwe,XU)=>{"use strict";var y6=require("uuid"),db=class{static{o(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||y6.v4(),this.schema_table=`${this.schema}.${this.table}`}};XU.exports=db});var C_=M((swe,ex)=>{"use strict";var A6=ZU(),fb=class extends A6{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}};ex.exports=fb});var rx=M((owe,tx)=>{"use strict";tx.exports=I6;var b6="inserted";function I6(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===b6?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}o(I6,"returnObject")});var P_=M((lwe,sx)=>{"use strict";var N6=(k(),v(K)),mb=Et(),w6=jc(),{getSystemSchemaPath:O6,getSchemaPath:C6}=yt(),cwe=To(),{validateBySchema:P6}=ct(),Tm=require("joi"),L6=C_(),D6=rx(),{handleHDBError:M6,hdbErrors:v6,ClientError:U6}=Ee(),nx=ie(),{HTTP_STATUS_CODES:x6}=v6,B6="inserted";sx.exports=F6;async function F6(e){let t=P6(e,Tm.object({database:Tm.string(),schema:Tm.string(),table:Tm.string().required(),attribute:Tm.string().required()}));if(t)throw new U6(t.message);let r=!e.skip_table_check&&nx.checkGlobalSchemaTable(e.schema,e.table);if(r)throw M6(new Error,r,x6.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=nx.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 L6(e.schema,e.table,e.attribute,e.id);try{let i=await mb.openEnvironment(C6(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}`);mb.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let a=await mb.openEnvironment(O6(),N6.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await w6.insertRecords(a,HDB_TABLE_INFO.hash_attribute,hdbAttributeAttributes,[s]);return D6(B6,c,{records:[s]},l)}catch(i){throw i}}o(F6,"lmdbCreateAttribute")});var Li=M((dwe,ox)=>{"use strict";var ix=ie(),H6=(k(),v(K)),Cu=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Pi=require("joi"),ba={schema_format:{pattern:Cu,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},k6=Pi.alternatives(Pi.string().min(1).max(ba.schema_length.maximum).pattern(Cu).messages({"string.pattern.base":"{:#label} "+ba.schema_format.message}),Pi.number(),Pi.array()).required(),G6=Pi.alternatives(Pi.string().min(1).max(ba.schema_length.maximum).pattern(Cu).messages({"string.pattern.base":"{:#label} "+ba.schema_format.message}),Pi.number()),q6=Pi.alternatives(Pi.string().min(1).max(ba.schema_length.maximum).pattern(Cu).messages({"string.pattern.base":"{:#label} "+ba.schema_format.message}),Pi.number()).required();function $6(e,t){return t?typeof t!="string"?`'${property_name}' must be a string`:t.length?t.length>ba.schema_length.maximum?`'${property_name}' maximum of 250 characters`:Cu.test(t)?"":`'${property_name}' has illegal characters`:`'${property_name}' must be at least one character`:`'${property_name}' is required`}o($6,"checkValidTable");function V6(e,t){return ix.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}o(V6,"validateSchemaExists");function K6(e,t){let r=t.state.ancestors[0].schema;return ix.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}o(K6,"validateTableExists");function Y6(e,t){return e.toLowerCase()===H6.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${hdb_terms.SYSTEM_SCHEMA_NAME}' name is reserved`):e}o(Y6,"validateSchemaName");ox.exports={commonValidators:ba,schemaRegex:Cu,hdbSchemaTable:k6,validateSchemaExists:V6,validateTableExists:K6,validateSchemaName:Y6,checkValidTable:$6,hdbDatabase:G6,hdbTable:q6}});var pb=M((mwe,cx)=>{var{hdbTable:W6,hdbDatabase:ax}=Li(),z6=ct(),hb=require("joi"),j6={undefined:"undefined",null:"null"},Q6=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||j6[a]!==void 0)&&(s===void 0?s=`Invalid attribute name: '${a}'`:s+=`. Invalid attribute name: '${a}'`)}return s?t.message(s):e},"customRecordsVal"),J6=hb.object({database:ax,schema:ax,table:W6,records:hb.array().items(hb.object().custom(Q6)).required()});cx.exports=function(e){return z6.validateBySchema(e,J6)}});var Rm=M((Ewe,ux)=>{"use strict";var yo=ie(),lx=z(),pwe=pb(),{getDatabases:X6}=(Le(),v(ft)),{ClientError:Qc}=Ee();ux.exports=Z6;function Z6(e){if(yo.isEmpty(e))throw new Qc("invalid update parameters defined.");if(yo.isEmptyOrZeroLength(e.schema))throw new Qc("invalid schema specified.");if(yo.isEmptyOrZeroLength(e.table))throw new Qc("invalid table specified.");if(!Array.isArray(e.records))throw new Qc("records must be an array");let t=X6()[e.schema]?.[e.table];if(yo.isEmpty(t))throw new Qc(`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&&yo.isEmptyOrZeroLength(a[r]))throw lx.error("a valid hash attribute must be provided with update record:",a),new Qc("a valid hash attribute must be provided with update record, check log for more info");if(!yo.isEmptyOrZeroLength(a[r])&&(a[r]==="null"||a[r]==="undefined"))throw lx.error(`a valid hash value must be provided with ${e.operation} record:`,a),new Qc(`Invalid hash value: '${a[r]}' is not a valid hash attribute value, check log for more info`);!yo.isEmpty(a[r])&&a[r]!==""&&n.has(yo.autoCast(a[r]))&&(a.skip=!0),n.add(yo.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(Z6,"insertUpdateValidate")});var L_=M((gwe,fx)=>{"use strict";var dx=ie(),e8=(k(),v(K)),t8=z(),r8=P_(),n8=C_(),s8=Ao(),{SchemaEventMsg:i8}=ei(),o8="already exists in";fx.exports=a8;async function a8(e,t,r){if(dx.isEmptyOrZeroLength(r))return r;let n=[];dx.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 c8(e,t.schema,t.name,i)})),s}o(a8,"lmdbCheckForNewAttributes");async function c8(e,t,r,n){let s=new n8(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await l8(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(o8))t8.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}o(c8,"createNewAttribute");async function l8(e){let t;return t=await r8(e),s8.signalSchemaChange(new i8(process.pid,e8.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}o(l8,"createAttribute")});var Pu=M((Twe,mx)=>{"use strict";var Eb=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}};mx.exports=Eb});var px=M((ywe,hx)=>{"use strict";var u8=Pu(),d8=(k(),v(K)).OPERATIONS_ENUM,_b=class extends u8{static{o(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(d8.INSERT,r,n,s,i),this.records=t}};hx.exports=_b});var _x=M((bwe,Ex)=>{"use strict";var f8=Pu(),m8=(k(),v(K)).OPERATIONS_ENUM,gb=class extends f8{static{o(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,a=void 0){super(m8.UPDATE,n,s,i,a),this.records=t,this.original_records=r}};Ex.exports=gb});var Sx=M((Nwe,gx)=>{"use strict";var h8=Pu(),p8=(k(),v(K)).OPERATIONS_ENUM,Sb=class extends h8{static{o(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,a=void 0){super(p8.UPSERT,n,s,i,a),this.records=t,this.original_records=r}};gx.exports=Sb});var Rx=M((Owe,Tx)=>{"use strict";var E8=Pu(),_8=(k(),v(K)).OPERATIONS_ENUM,Tb=class extends E8{static{o(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(_8.DELETE,n,s,t,i),this.original_records=r}};Tx.exports=Tb});var ym=M((Lwe,Ix)=>{"use strict";var Pwe=require("path"),yx=Et(),g8=px(),S8=_x(),T8=Sx(),R8=Rx(),Lu=kt(),Ax=ie(),{CONFIG_PARAMS:y8}=(k(),v(K)),bx=ce();bx.initSync();var D_=(k(),v(K)).OPERATIONS_ENUM,{getTransactionAuditStorePath:A8}=yt();Ix.exports=b8;async function b8(e,t){if(bx.get(y8.LOGGING_AUDITLOG)===!1)return;let r=A8(e.schema,e.table),n=await yx.openEnvironment(r,e.table,!0),s=I8(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){yx.initializeDBIs(n,Lu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Lu.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[Lu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[Lu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),Ax.isEmpty(s.user_name)||n.dbis[Lu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let a=0;a<s.hash_values.length;a++)n.dbis[Lu.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[a],i)})}}o(b8,"writeTransaction");function I8(e,t){let r=Ax.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===D_.INSERT)return new g8(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===D_.UPDATE)return new S8(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===D_.UPSERT)return new T8(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===D_.DELETE)return new R8(t.deleted,t.original_records,r,t.txn_time,e.__origin)}o(I8,"createTransactionObject")});var Rb=M((vwe,Nx)=>{"use strict";var N8=Rm(),Mwe=qf(),Am=(k(),v(K)),w8=$f(),O8=jc().insertRecords,C8=Et(),P8=z(),L8=L_(),{getSchemaPath:D8}=yt(),M8=ym();Nx.exports=v8;async function v8(e){try{let{schemaTable:t,attributes:r}=N8(e);w8(e,r,t.hash_attribute),e.schema!==Am.SYSTEM_SCHEMA_NAME&&(r.includes(Am.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(Am.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(Am.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(Am.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await L8(e.hdb_auth_header,t,r),s=D8(e.schema,e.table),i=await C8.openEnvironment(s,e.table),a=await O8(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await M8(e,a)}catch(c){P8.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(v8,"lmdbCreateRecords")});var Cx=M((xwe,Ox)=>{"use strict";var wx=(k(),v(K)),U8=Rb(),x8=qf(),B8=require("fs-extra"),{getSchemaPath:F8}=yt();Ox.exports=H8;async function H8(e){let t=[{name:e.schema,createddate:Date.now()}],r=new x8(wx.SYSTEM_SCHEMA_NAME,wx.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await U8(r),await B8.mkdirp(F8(e.schema))}o(H8,"lmdbCreateSchema")});var Lx=M((Fwe,Px)=>{"use strict";var yb=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}};Px.exports=yb});var Ux=M(($we,vx)=>{"use strict";var Dx=Et(),Ab=Rn(),bb=en().LMDB_ERRORS_ENUM,k8=kt(),Mx=z(),kwe=ie(),G8=require("lmdb"),q8=Lx(),$8=(k(),v(K)),{OVERFLOW_MARKER:Gwe,MAX_SEARCH_KEY_LENGTH:qwe}=k8,V8=$8.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function K8(e,t,r,n){if(Ab.validateEnv(e),t===void 0)throw new Error(bb.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(bb.IDS_REQUIRED):new Error(bb.IDS_MUST_BE_ITERABLE);try{let s=Dx.listDBIs(e);Dx.initializeDBIs(e,t,s);let i=new q8,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[V8]>n){i.skipped.push(a);continue}let _=e.dbis[t].ifVersion(a,G8.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=Ab.getIndexedValues(R);if(I)for(let P=0,Y=I.length;P<Y;P++)T.remove(I[P],a)}catch{Mx.warn(`cannot delete from attribute: ${y}, ${R}:${a}`)}}});c.push(_),l.push(a),i.original_records.push(p)}catch(p){Mx.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=Ab.getNextMonotonicTime(),i}catch(s){throw s}}o(K8,"deleteRecords");vx.exports={deleteRecords:K8}});var bm=M((Kwe,Bx)=>{"use strict";var Du=ie(),Y8=Ux(),W8=Et(),{getSchemaPath:z8}=yt(),j8=ym(),Q8=z();Bx.exports=J8;async function J8(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(Du.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(Du.isEmptyOrZeroLength(e.hash_values)&&!Du.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];Du.isEmpty(l)||e.hash_values.push(l)}}if(Du.isEmptyOrZeroLength(e.hash_values))return xx([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(Du.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=z8(e.schema,e.table),i=await W8.openEnvironment(s,e.table),a=await Y8.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await j8(e,a)}catch(c){Q8.error(`unable to write transaction due to ${c.message}`)}return xx(a.deleted,a.skipped,a.txn_time)}catch(s){throw s}}o(J8,"lmdbDeleteRecords");function xx(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(xx,"createDeleteResponse")});var Nb=M((zwe,Fx)=>{"use strict";var X8=(k(),v(K)),Wwe=Rn();function Ib(e,t){let r=Object.create(null);if(t.length===1&&X8.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(Ib,"parseRow");function Z8(e,t,r,n){let s=Ib(r,e);n.push(s)}o(Z8,"searchAll");function e5(e,t,r,n){let s=Ib(r,e);n[t]=s}o(e5,"searchAllToMap");function t5(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}o(t5,"iterateDBI");function Jc(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(Jc,"pushResults");function r5(e,t,r,n,s,i){t.toString().endsWith(e)&&Jc(t,r,n,s,i)}o(r5,"endsWith");function n5(e,t,r,n,s,i){t.toString().includes(e)&&Jc(t,r,n,s,i)}o(n5,"contains");function s5(e,t,r,n,s,i){t>e&&Jc(t,r,n,s,i)}o(s5,"greaterThanCompare");function i5(e,t,r,n,s,i){t>=e&&Jc(t,r,n,s,i)}o(i5,"greaterThanEqualCompare");function o5(e,t,r,n,s,i){t<e&&Jc(t,r,n,s,i)}o(o5,"lessThanCompare");function a5(e,t,r,n,s,i){t<=e&&Jc(t,r,n,s,i)}o(a5,"lessThanEqualCompare");Fx.exports={parseRow:Ib,searchAll:Z8,searchAllToMap:e5,iterateDBI:t5,endsWith:r5,contains:n5,greaterThanCompare:s5,greaterThanEqualCompare:i5,lessThanCompare:o5,lessThanEqualCompare:a5,pushResults:Jc}});var Mu=M((Zwe,Kx)=>{"use strict";var Ia=Et(),Qwe=z(),Kn=Rn(),M_=kt(),Qt=en().LMDB_ERRORS_ENUM,Jwe=ie(),c5=(k(),v(K)),v_=Nb(),{parseRow:l5}=v_,Xwe=require("lmdb"),{OVERFLOW_MARKER:Hx,MAX_SEARCH_KEY_LENGTH:u5}=M_;function kx(e,t,r,n=!1,s=void 0,i=void 0){return Xc(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(kx,"iterateFullIndex");function Im(e,t,r,n,s,i=!1,a=void 0,c=void 0,l=!1,u=!1){return Xc(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(Im,"iterateRangeBetween");function Xc(e,t,r,n){let s=e.database||e,i=Ia.openDBI(s,r);i[M_.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&Ia.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(Xc,"setupTransaction");function Gx(e,t,r,n){let s;return function(i,a){if(typeof i=="string"&&i.endsWith(Hx)){if(!s)if(r)s=Ia.openDBI(e,r);else{let l=Ia.listDBIs(e);for(let u=0,d=l.length;u<d&&(s=Ia.openDBI(e,l[u]),!s[M_.DBI_DEFINITION_NAME].is_hash_attribute);u++);}i=s.get(a,{transaction:t,lazy:!0})[n]}return i}}o(Gx,"getOverflowCheck");function d5(e,t,r,n=!1,s=void 0,i=void 0){if(Kn.validateEnv(e),t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);return Xc(e,t,t,(a,c,l)=>(U_(r),r=Nm(l,r),c.getRange({transaction:a,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(u=>l5(u.value,r))))}o(d5,"searchAll");function f5(e,t,r,n=!1,s=void 0,i=void 0){if(Kn.validateEnv(e),t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);U_(r),r=Nm(e.database||e,r);let a=new Map;for(let{key:c,value:l}of kx(e,t,t,n,s,i))a.set(c,v_.parseRow(l,r));return a}o(f5,"searchAllToMap");function m5(e,t,r=!1,n=void 0,s=void 0){if(Kn.validateEnv(e),t===void 0)throw new Error(Qt.ATTRIBUTE_REQUIRED);let i=Object.create(null),a=kx(e,void 0,t,r,n,s),c=a.transaction,l=Gx(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(m5,"iterateDBI");function h5(e,t){if(Kn.validateEnv(e),t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);return Ia.statDBI(e,t).entryCount}o(h5,"countAll");function p5(e,t,r,n,s=!1,i=void 0,a=void 0){return Na(e,r,n),Xc(e,t,r,(c,l,u,d)=>(n=Kn.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(p5,"equals");function E5(e,t,r){return Na(e,t,r),Ia.openDBI(e,t).getValuesCount(r)}o(E5,"count");function _5(e,t,r,n,s=!1,i=void 0,a=void 0){return Na(e,r,n),Xc(e,null,r,(c,l)=>{n=Kn.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(_5,"startsWith");function g5(e,t,r,n,s=!1,i=void 0,a=void 0){return qx(e,t,r,n,s,i,a,!0)}o(g5,"endsWith");function qx(e,t,r,n,s=!1,i=void 0,a=void 0,c=!1){return Na(e,r,n),Xc(e,null,r,(l,u,d,f)=>{let m=Gx(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(Hx)?u.getValues(h,{transaction:l}).map(_=>{let g=m(h,_);if(c?g.endsWith(n):g.includes(n))return{key:g,value:_}}).filter(_=>_):(c?p.endsWith(n):p.includes(n))?u[M_.DBI_DEFINITION_NAME].is_hash_attribute?{key:h,value:h}:u.getValues(h,{transaction:l}).map(_=>({key:h,value:_})):[]}).slice(a,i===void 0?void 0:i+(a||0))})}o(qx,"contains");function S5(e,t,r,n,s=!1,i=void 0,a=void 0){Na(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),Im(e,t,r,n,l,s,i,a,!0,!1)}o(S5,"greaterThan");function T5(e,t,r,n,s=!1,i=void 0,a=void 0){Na(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),Im(e,t,r,n,l,s,i,a,!1,!1)}o(T5,"greaterThanEqual");function R5(e,t,r,n,s=!1,i=void 0,a=void 0){Na(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),Im(e,t,r,l,n,s,i,a,!1,!0)}o(R5,"lessThan");function y5(e,t,r,n,s=!1,i=void 0,a=void 0){Na(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),Im(e,t,r,l,n,s,i,a,!1,!1)}o(y5,"lessThanEqual");function A5(e,t,r,n,s,i=!1,a=void 0,c=void 0){if(Kn.validateEnv(e),r===void 0)throw new Error(Qt.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(Qt.START_VALUE_REQUIRED);if(s===void 0)throw new Error(Qt.END_VALUE_REQUIRED);if(n=Kn.convertKeyValueToWrite(n),s=Kn.convertKeyValueToWrite(s),n>s)throw new Error(Qt.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return Im(e,t,r,n,s,i,a,c)}o(A5,"between");function b5(e,t,r,n){Kn.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);if(U_(r),r=Nm(s,r),n===void 0)throw new Error(Qt.ID_REQUIRED);let a=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(a=v_.parseRow(c,r)),a}o(b5,"searchByHash");function I5(e,t,r){Kn.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Qt.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}o(I5,"checkHashExists");function N5(e,t,r,n,s=[]){return Vx(e,t,r,n,s),$x(e,t,r,n,s).map(i=>i[1])}o(N5,"batchSearchByHash");function w5(e,t,r,n,s=[]){Vx(e,t,r,n,s);let i=new Map;for(let[a,c]of $x(e,t,r,n,s))i.set(a,c);return i}o(w5,"batchSearchByHashToMap");function $x(e,t,r,n,s=[]){return Xc(e,t,t,(i,a,c)=>{r=Nm(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,v_.parseRow(d,r)];s.push(u)}).filter(u=>u)})}o($x,"batchHashSearch");function Vx(e,t,r,n,s){if(Kn.validateEnv(e),t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);if(U_(r),n==null)throw new Error(Qt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(Qt.IDS_MUST_BE_ITERABLE)}o(Vx,"initializeBatchSearchByHash");function U_(e){if(!Array.isArray(e))throw e===void 0?new Error(Qt.FETCH_ATTRIBUTES_REQUIRED):new Error(Qt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}o(U_,"validateFetchAttributes");function Na(e,t,r){if(Kn.validateEnv(e),t===void 0)throw new Error(Qt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Qt.SEARCH_VALUE_REQUIRED);if(r?.length>u5)throw new Error(Qt.SEARCH_VALUE_TOO_LARGE)}o(Na,"validateComparisonFunctions");function Nm(e,t){return t.length===1&&c5.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=Ia.listDBIs(e)),t}o(Nm,"setGetWholeRowAttributes");Kx.exports={searchAll:d5,searchAllToMap:f5,count:E5,countAll:h5,equals:p5,startsWith:_5,endsWith:g5,contains:qx,searchByHash:b5,setGetWholeRowAttributes:Nm,batchSearchByHash:N5,batchSearchByHashToMap:w5,checkHashExists:I5,iterateDBI:m5,greaterThan:S5,greaterThanEqual:T5,lessThan:R5,lessThanEqual:y5,between:A5}});var vu=M((tOe,Qx)=>{var Yx=require("lodash"),Wx=ct(),$e=require("joi"),O5=ie(),{hdbSchemaTable:wm,checkValidTable:zx,hdbTable:jx,hdbDatabase:x_}=Li(),{handleHDBError:C5,hdbErrors:P5}=Ee(),{getDatabases:L5}=(Le(),v(ft)),{HTTP_STATUS_CODES:D5}=P5,M5=$e.object({database:x_,schema:x_,table:jx,search_attribute:wm,search_value:$e.any().required(),get_attributes:$e.array().min(1).items($e.alternatives(wm,$e.object())).optional(),desc:$e.bool(),limit:$e.number().integer().min(1),offset:$e.number().integer().min(0)}),v5=$e.object({database:x_,schema:x_,table:jx,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(wm,$e.object())).optional(),sort:$e.object({attribute:$e.alternatives(wm,$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(wm,$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()});Qx.exports=function(e,t){let r=null;switch(t){case"value":r=Wx.validateBySchema(e,M5);break;case"hashes":let i=function(a){s?s+=". "+a:s=a};var n=i;o(i,"addError");let s;i(zx("database",e.schema)),i(zx("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=Wx.validateBySchema(e,v5);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=O5.checkGlobalSchemaTable(e.schema,e.table);if(s)return C5(new Error,s,D5.NOT_FOUND);let a=L5()[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=Yx.filter(c,d=>d!=="*"&&!d.startsWith?.("$")&&d.attribute!=="*"&&!Array.isArray(d)&&!d.name&&!Yx.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 wb=M((nOe,Jx)=>{"use strict";var U5=Et(),x5=vu(),{getSchemaPath:B5}=yt();Jx.exports=F5;function F5(e){let t=x5(e,"hashes");if(t)throw t;let r=B5(e.schema,e.table);return U5.openEnvironment(r,e.table)}o(F5,"initialize")});var Ob=M((iOe,Xx)=>{"use strict";var H5=Mu(),k5=wb();Xx.exports=G5;async function G5(e){let t=await k5(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return H5.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}o(G5,"lmdbGetDataByHash")});var Uu=M((aOe,Zx)=>{"use strict";var Cb=class{static{o(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};Zx.exports=Cb});var t0=M((uOe,e0)=>{"use strict";var lOe=Uu(),q5=Mu(),$5=wb();e0.exports=V5;async function V5(e){let t=await $5(e),r=global.hdb_schema[e.schema][e.table];return q5.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}o(V5,"lmdbSearchByHash")});var ti=M((fOe,r0)=>{"use strict";var Pb=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}};r0.exports=Pb});var B_=M((hOe,c0)=>{"use strict";var rn=Mu(),K5=Et(),Y5=ie(),Ve=kt(),Zc=(k(),v(K)),W5=To(),n0=en().LMDB_ERRORS_ENUM,{getSchemaPath:z5}=yt(),bo=Zc.SEARCH_WILDCARDS;async function j5(e,t,r){let n;e.schema===Zc.SYSTEM_SCHEMA_NAME?n=W5[e.table]:n=global.hdb_schema[e.schema][e.table];let s=a0(e,n.hash_attribute,r,t);return i0(e,s,n.hash_attribute,r)}o(j5,"prepSearch");async function i0(e,t,r,n){let s=z5(e.schema,e.table),i=await K5.openEnvironment(s,e.table),a=o0(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(Q5(e,r)===!1){let d=e.search_attribute;if(d===r)return n?s0(a,()=>!0):a.map(m=>({[r]:m.key}));let f=o(m=>({[r]:m.value,[d]:m.key}),"toObject");return n?s0(a,f):a.map(f)}let u=e.search_attribute===r?a.map(d=>d.key):a.map(d=>d.value);return n===!0?rn.batchSearchByHashToMap(c,r,e.get_attributes,u):rn.batchSearchByHash(c,r,e.get_attributes,u)}o(i0,"executeSearch");function o0(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=rn.equals(e,i,t.search_attribute,t.search_value,a,c,l);break;case Ve.SEARCH_TYPES.CONTAINS:s=rn.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=rn.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=rn.startsWith(e,i,t.search_attribute,t.search_value,a,c,l);break;case Ve.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return rn.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case Ve.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return rn.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case Ve.SEARCH_TYPES.SEARCH_ALL:return rn.searchAll(e,n,t.get_attributes,a,c,l);case Ve.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return rn.searchAllToMap(e,n,t.get_attributes,a,c,l);case Ve.SEARCH_TYPES.BETWEEN:s=rn.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=rn.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=rn.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=rn.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=rn.lessThanEqual(e,i,t.search_attribute,t.search_value,a,c,l);break;default:return Object.create(null)}return s}o(o0,"searchByType");function s0(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}o(s0,"createMapFromIterable");function Q5(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(Q5,"checkToFetchMore");function a0(e,t,r,n){if(Y5.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),bo.indexOf(s)>-1)return r===!0?Ve.SEARCH_TYPES.SEARCH_ALL_TO_MAP:Ve.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(bo[0])<0&&s.indexOf(bo[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(bo.indexOf(i)>=0&&bo.indexOf(a)>=0)return e.search_value=e.search_value.slice(1,-1),Ve.SEARCH_TYPES.CONTAINS;if(bo.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),Ve.SEARCH_TYPES.ENDS_WITH;if(bo.indexOf(a)>=0)return e.search_value=e.search_value.slice(0,-1),Ve.SEARCH_TYPES.STARTS_WITH;if(s.includes(bo[0])||s.includes(bo[1]))return Ve.SEARCH_TYPES.EQUALS;throw new Error(n0.UNKNOWN_SEARCH_TYPE)}else switch(n){case Zc.VALUE_SEARCH_COMPARATORS.BETWEEN:return Ve.SEARCH_TYPES.BETWEEN;case Zc.VALUE_SEARCH_COMPARATORS.GREATER:return Ve.SEARCH_TYPES.GREATER_THAN;case Zc.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return Ve.SEARCH_TYPES.GREATER_THAN_EQUAL;case Zc.VALUE_SEARCH_COMPARATORS.LESS:return Ve.SEARCH_TYPES.LESS_THAN;case Zc.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return Ve.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(n0.UNKNOWN_SEARCH_TYPE)}}o(a0,"createSearchTypeFromSearchObject");c0.exports={executeSearch:i0,createSearchTypeFromSearchObject:a0,prepSearch:j5,searchByType:o0}});var u0=M((_Oe,l0)=>{"use strict";var EOe=ti(),J5=vu(),X5=ie(),Z5=(k(),v(K)),e9=B_();l0.exports=t9;function t9(e,t){if(!X5.isEmpty(t)&&Z5.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=J5(e,"value");if(n)throw n;return e9.prepSearch(e,t,!0)}o(t9,"lmdbGetDataByValue")});var Om=M((TOe,d0)=>{"use strict";var SOe=ti(),r9=vu(),n9=ie(),s9=(k(),v(K)),i9=B_();d0.exports=o9;async function o9(e,t){if(!n9.isEmpty(t)&&s9.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=r9(e,"value");if(n)throw n;return i9.prepSearch(e,t,!1)}o(o9,"lmdbSearchByValue")});var m0=M((AOe,f0)=>{"use strict";var yOe=kt(),Lb=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}},Db=class{static{o(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},Mb=class{static{o(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};f0.exports={SearchByConditionsObject:Lb,SearchCondition:Db,SortAttribute:Mb}});var g0=M((wOe,_0)=>{"use strict";var IOe=m0().SearchByConditionsObject,a9=ti(),c9=vu(),vb=Mu(),F_=kt(),{Resource:NOe}=(ya(),v(jv)),E0=B_(),l9=Nb(),u9=require("lodash"),{getSchemaPath:d9}=yt(),h0=Et(),{handleHDBError:f9,hdbErrors:m9}=Ee(),{HTTP_STATUS_CODES:h9}=m9,p9=1e8;_0.exports=E9;async function E9(e){let t=c9(e,"conditions");if(t)throw f9(t,t.message,h9.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=d9(e.schema,e.table),n=await h0.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let u of e.conditions)h0.openDBI(n,u.search_attribute);let i=u9.sortBy(e.conditions,u=>{if(u.estimated_count===void 0){let d=u.search_type;d===F_.SEARCH_TYPES.EQUALS?u.estimated_count=vb.count(n,u.search_attribute,u.search_value):d===F_.SEARCH_TYPES.CONTAINS||d===F_.SEARCH_TYPES.ENDS_WITH?u.estimated_count=1/0:u.estimated_count=p9}return u.estimated_count}),a=n.useReadTransaction();a.database=n;let c=await p0(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(E0.filterByType),f=d.length,m=vb.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=>l9.parseRow(h,m))}else{for(let f=1;f<i.length;f++){let m=i[f],h=await p0(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=vb.batchSearchByHash(a,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{a.done()},l}o(E9,"lmdbSearchByConditions");async function p0(e,t,r,n){let s=new a9(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===F_.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,E0.searchByType(e,s,i,n).map(a=>a.value)}o(p0,"executeConditionSearch")});var Cm=M((COe,S0)=>{"use strict";var _9=(k(),v(K)).OPERATIONS_ENUM,Ub=class{static{o(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=_9.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};S0.exports=Ub});var xb=M((LOe,w0)=>{"use strict";var A0=ti(),b0=Cm(),I0=Om(),N0=bm(),Cn=(k(),v(K)),T0=ie(),R0=Et(),{getTransactionAuditStorePath:g9,getSchemaPath:S9}=yt(),y0=z();w0.exports=T9;async function T9(e){try{if(T0.isEmpty(global.hdb_schema[e.schema])||T0.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await R9(e),await y9(e);let t=S9(e.schema,e.table);try{await R0.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")y0.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=g9(e.schema,e.table);await R0.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")y0.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}o(T9,"lmdbDropTable");async function R9(e){let t=new A0(Cn.SYSTEM_SCHEMA_NAME,Cn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Cn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Cn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await I0(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 b0(Cn.SYSTEM_SCHEMA_NAME,Cn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await N0(s)}o(R9,"deleteAttributesFromSystem");async function y9(e){let t=new A0(Cn.SYSTEM_SCHEMA_NAME,Cn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Cn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[Cn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,Cn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,Cn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await I0(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 b0(Cn.SYSTEM_SCHEMA_NAME,Cn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await N0(s)}catch(i){throw i}}o(y9,"dropTableFromSystem")});var C0=M((MOe,O0)=>{"use strict";var A9=require("fs-extra"),b9=ti(),I9=Uu(),N9=Cm(),w9=xb(),O9=bm(),C9=Ob(),P9=Om(),Io=(k(),v(K)),{getSchemaPath:L9}=yt(),{handleHDBError:D9,hdbErrors:M9}=Ee(),{HDB_ERROR_MSGS:v9,HTTP_STATUS_CODES:U9}=M9;O0.exports=x9;async function x9(e){let t;try{t=await B9(e.schema);let r=new b9(Io.SYSTEM_SCHEMA_NAME,Io.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Io.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[Io.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await P9(r));for(let a=0;a<n.length;a++){let c={schema:t,table:n[a].name};try{await w9(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new N9(Io.SYSTEM_SCHEMA_NAME,Io.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await O9(s);let i=L9(t);await A9.remove(i)}catch(r){throw r}}o(x9,"lmdbDropSchema");async function B9(e){let t=new I9(Io.SYSTEM_SCHEMA_NAME,Io.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[Io.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await C9(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw D9(new Error,v9.SCHEMA_NOT_FOUND(e),U9.NOT_FOUND,void 0,void 0,!0);return n}o(B9,"validateDropSchema")});var Pm=M((UOe,P0)=>{"use strict";var Bb=class{static{o(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};P0.exports=Bb});var Hb=M((FOe,L0)=>{"use strict";var F9=require("fs-extra"),H_=Et(),{getTransactionAuditStorePath:H9}=yt(),Fb=kt(),BOe=Pm();L0.exports=k9;async function k9(e){let t;try{let r=H9(e.schema,e.table);await F9.mkdirp(r),t=await H_.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{H_.createDBI(t,Fb.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),H_.createDBI(t,Fb.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),H_.createDBI(t,Fb.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(k9,"createTransactionsAuditEnvironment")});var v0=M((GOe,M0)=>{"use strict";var kb=(k(),v(K)),D0=Et(),G9=jc(),{getSystemSchemaPath:q9,getSchemaPath:$9}=yt(),kOe=To(),V9=P_(),Gb=C_(),K9=z(),Y9=Hb();M0.exports=W9;async function W9(e,t){let r=$9(t.schema,t.table),n=new Gb(t.schema,t.table,kb.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new Gb(t.schema,t.table,kb.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new Gb(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await D0.createEnvironment(r,t.table),e!==void 0){let a=await D0.openEnvironment(q9(),kb.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await G9.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 Y9(t)}catch(a){throw a}}o(W9,"lmdbCreateTable");async function qb(e){try{await V9(e)}catch(t){K9.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}o(qb,"createAttribute")});var x0=M(($Oe,U0)=>{"use strict";var z9=Rm(),j9=$f(),Q9=L_(),Lm=(k(),v(K)),J9=jc().updateRecords,X9=Et(),{getSchemaPath:Z9}=yt(),e7=ym(),t7=z();U0.exports=r7;async function r7(e){try{let{schemaTable:t,attributes:r}=z9(e);j9(e,r,t.hash_attribute),e.schema!==Lm.SYSTEM_SCHEMA_NAME&&(r.includes(Lm.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(Lm.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(Lm.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(Lm.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await Q9(e.hdb_auth_header,t,r),s=Z9(e.schema,e.table),i=await X9.openEnvironment(s,e.table),a=await J9(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await e7(e,a)}catch(c){t7.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(r7,"lmdbUpdateRecords")});var F0=M((KOe,B0)=>{"use strict";var n7=(k(),v(K)).OPERATIONS_ENUM,$b=class{static{o(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=n7.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};B0.exports=$b});var k0=M((zOe,H0)=>{"use strict";var WOe=F0(),s7=Rm(),i7=$f(),o7=L_(),Dm=(k(),v(K)),a7=jc().upsertRecords,c7=Et(),{getSchemaPath:l7}=yt(),u7=ym(),d7=z(),{handleHDBError:f7,hdbErrors:m7}=Ee();H0.exports=h7;async function h7(e){let t;try{t=s7(e)}catch(l){throw f7(l,l.message,m7.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schemaTable:r,attributes:n}=t;i7(e,n,r.hash_attribute),e.schema!==Dm.SYSTEM_SCHEMA_NAME&&(n.includes(Dm.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(Dm.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(Dm.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(Dm.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await o7(e.hdb_auth_header,r,n),i=l7(e.schema,e.table),a=await c7.openEnvironment(i,e.table),c=await a7(a,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await u7(e,c)}catch(l){d7.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(h7,"lmdbUpsertRecords")});var q0=M((QOe,G0)=>{"use strict";var Vb=class{static{o(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};G0.exports=Vb});var V0=M((XOe,$0)=>{"use strict";var Kb=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}};$0.exports=Kb});var W0=M((tCe,Y0)=>{"use strict";var Yb=Et(),{getTransactionAuditStorePath:p7}=yt(),eCe=q0(),Mm=kt(),E7=ie(),K0=V0(),_7=require("util").promisify,g7=_7(setTimeout),S7=1e4,T7=100;Y0.exports=R7;async function R7(e){let t=p7(e.schema,e.table),r=await Yb.openEnvironment(t,e.table,!0),n=Yb.listDBIs(r);Yb.initializeDBIs(r,Mm.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new K0;do s=await y7(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 g7(T7);while(s.transactions_deleted>0);return i}o(R7,"deleteAuditLogsBefore");async function y7(e,t){let r=new K0;try{let n=e.dbis[Mm.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[Mm.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];E7.isEmpty(c)||(s=e.dbis[Mm.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<a.hash_values.length;l++)s=e.dbis[Mm.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(a.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>S7)break}return await s,r}catch(n){throw n}}o(y7,"deleteTransactions")});var j0=M((nCe,z0)=>{"use strict";var Wb=class{static{o(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};z0.exports=Wb});var J0=M((oCe,Q0)=>{"use strict";var A7=ti(),b7=Cm(),iCe=j0(),Di=(k(),v(K)),I7=ie(),zb=Et(),N7=To(),w7=Om(),O7=bm(),{getSchemaPath:C7}=yt();Q0.exports=P7;async function P7(e,t=!0){let r;e.schema===Di.SYSTEM_SCHEMA_NAME?r=N7[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await D7(e),s=C7(e.schema,e.table),i=await zb.openEnvironment(s,e.table);return t===!0&&await L7(e,i,r.hash_attribute),zb.dropDBI(i,e.attribute),n}o(P7,"lmdbDropAttribute");async function L7(e,t,r){let n=zb.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(L7,"removeAttributeFromAllObjects");async function D7(e){let t=new A7(Di.SYSTEM_SCHEMA_NAME,Di.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Di.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Di.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,Di.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await w7(t)).filter(a=>a[Di.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(I7.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[Di.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new b7(Di.SYSTEM_SCHEMA_NAME,Di.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return O7(i)}o(D7,"dropAttributeFromSystem")});var nB=M((lCe,rB)=>{"use strict";var jb=Et(),xu=kt(),cCe=Rn(),Qb=(k(),v(K)),X0=ie(),{getTransactionAuditStorePath:M7}=yt(),v7=Mu(),k_=Pu(),U7=z();rB.exports=x7;async function x7(e){let t=M7(e.schema,e.table),r=await jb.openEnvironment(t,e.table,!0),n=jb.listDBIs(r);jb.initializeDBIs(r,xu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case Qb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return Z0(r,e.search_values);case Qb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,F7(r,e.search_values,s);case Qb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return B7(r,e.search_values);default:return Z0(r)}}o(x7,"readAuditLog");function Z0(e,t=[0,Date.now()]){X0.isEmpty(t[0])&&(t[0]=0),X0.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[xu.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 k_,s))}o(Z0,"searchTransactionsByTimestamp");function B7(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[xu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(a);r.set(s,tB(e,i))}return Object.fromEntries(r)}o(B7,"searchTransactionsByUsername");function F7(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let u=t[c],d=v7.equals(e,xu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,xu.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=tB(e,s),a=new Map;for(let c=0;c<i.length;c++){let l=i[c],u=l.timestamp,d=n.get(u);eB(l,"records",r,d,a),eB(l,"original_records",r,d,a)}return Object.fromEntries(a)}o(F7,"searchTransactionsByHashValues");function eB(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 k_(e.operation,e.user_name,i,void 0);f[t]=[c],u.push(f)}}else{let u=new k_(e.operation,e.user_name,i,void 0);u[t]=[c],s.set(l,[u])}}}o(eB,"loopRecords");function tB(e,t){let r=[];try{let n=e.dbis[xu.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 k_,i);r.push(a)}}catch(i){U7.warn(i)}return r}catch(n){throw n}}o(tB,"batchSearchTransactions")});var iB=M((mCe,sB)=>{"use strict";var{getSchemaPath:dCe}=yt(),fCe=Et(),{database:H7}=(Le(),v(ft));sB.exports={writeTransaction:k7};async function k7(e,t,r){return H7({database:e,table:t}).transaction(r)}o(k7,"writeTransaction")});var lB=M((pCe,cB)=>{"use strict";var{getSchemaPath:oB}=yt(),aB=Et();cB.exports={flush:G7,resetReadTxn:q7};async function G7(e,t){return(await aB.openEnvironment(oB(e,t),t.toString())).flushed}o(G7,"flush");async function q7(e,t){try{(await aB.openEnvironment(oB(e,t),t.toString())).resetReadTxn()}catch{}}o(q7,"resetReadTxn")});var mB=M((_Ce,fB)=>{"use strict";var{Readable:$7}=require("stream"),{getDatabases:V7}=(Le(),v(ft)),{readSync:K7,openSync:Y7,createReadStream:uB}=require("fs"),{open:W7}=require("lmdb"),dB=pm(),z7=Em(),{AUDIT_STORE_OPTIONS:j7}=(lo(),v(vv)),{INTERNAL_DBIS_NAME:Q7,AUDIT_STORE_NAME:J7}=kt();fB.exports=Z7;var Jb=32768,X7=100;async function Z7(e){let t=e.database||e.schema||"data",r=V7()[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=W7({noSync:!0,maxDbs:z7.MAX_DBS}),m,h=f.openDB(Q7,new dB(!1)),p=d.useReadTransaction(),_=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),_++%X7===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 dB(!P,P);await g(T,Y)}e.include_audit&&await g(J7,{...j7}),await m;let y=uB(f.path);return y.headers=l(),y.on("close",()=>{p.done(),f.close()}),y}let a=r[Object.keys(r)[0]].primaryStore,c=Y7(a.path);return a.transaction(()=>{let u=Buffer.alloc(Jb);K7(c,u,0,Jb),a.resetReadTxn();let d=a.useReadTransaction();d.renew();let f=uB(null,{fd:c,start:Jb}),m=new $7.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(Z7,"getBackup")});var EB=M((SCe,pB)=>{"use strict";var eee=z(),{handleHDBError:tee}=Ee(),ree=GU(),nee=P_(),see=Rb(),iee=Cx(),oee=bm(),aee=Ob(),cee=t0(),lee=u0(),uee=Om(),dee=g0(),fee=C0(),mee=v0(),hee=x0(),pee=k0(),Eee=W0(),_ee=xb(),gee=J0(),See=nB(),Tee=iB(),hB=lB(),Ree=mB(),Xb=class extends ree{static{o(this,"LMDBBridge")}async searchByConditions(t){return dee(t)}async getDataByHash(t){return await aee(t)}async searchByHash(t){return await cee(t)}async getDataByValue(t,r){return await lee(t,r)}async searchByValue(t){return await uee(t)}async createSchema(t){return await iee(t)}async dropSchema(t){return await fee(t)}async createTable(t,r){return await mee(t,r)}async dropTable(t){return await _ee(t)}async createAttribute(t){return await nee(t)}async createRecords(t){return await see(t)}async updateRecords(t){return await hee(t)}async upsertRecords(t){try{return await pee(t)}catch(r){throw tee(r,null,null,eee.ERR,r)}}async deleteRecords(t){return await oee(t)}async dropAttribute(t){return await gee(t)}async deleteAuditLogsBefore(t){return await Eee(t)}async readAuditLog(t){return await See(t)}writeTransaction(t,r,n){return Tee.writeTransaction(t,r,n)}flush(t,r){return hB.flush(t,r)}resetReadTxn(t,r){return hB.resetReadTxn(t,r)}getBackup(t){return Ree(t)}};pB.exports=Xb});function Pn(e){let t=e.getChanges();return t||(t=Object.create(null),e._setChanges(t)),t}function Um(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 Yn.ClientError(`${u} must be a string, attempt to assign ${m}`);Pn(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 Yn.ClientError(`${u} must be a string, attempt to assign ${m}`);Pn(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 Yn.ClientError(`${u} must be a number, attempt to assign ${h}`);Pn(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 Yn.ClientError(`${u} must be an integer between -2147483648 and 2147483647, attempt to assign ${m}`);Pn(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 Yn.ClientError(`${u} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${m}`);Pn(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 Yn.ClientError(`${u} must be a number, attempt to assign ${m}`);Pn(this)[u]=m},"set");break;case"Boolean":d=o(function(m){if(!(typeof m=="boolean"||m==null&&l.nullable!==!1))throw new Yn.ClientError(`${u} must be a boolean, attempt to assign ${m}`);Pn(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 Yn.ClientError(`${u} must be a Date, attempt to assign ${m}`);Pn(this)[u]=m},"set");break;case"Bytes":d=o(function(m){if(!(m instanceof Uint8Array||m==null&&l.nullable!==!1))throw new Yn.ClientError(`${u} must be a Buffer or Uint8Array, attempt to assign ${m}`);Pn(this)[u]=m},"set");break;case"Blob":d=o(function(m){if(!(m instanceof gs||m==null&&l.nullable!==!1))throw new Yn.ClientError(`${u} must be a Blob, attempt to assign ${m}`);Pn(this)[u]=m},"set");break;case"Any":case void 0:d=o(function(m){Pn(this)[u]=m},"set");break;default:d=o(function(m){if(!(typeof m=="object"||m==null&&l.nullable!==!1))throw new Yn.ClientError(`${u} must be an object, attempt to assign ${m}`);Pn(this)[u]=m},"set")}f={get(){let m=this.getChanges?.();if(m&&u in m){let p=m[u];if(p?.__op__){let _=this.getRecord()?.[u];return p.update(_)}return p}let h=this.getRecord()?.[u];if(h&&typeof h=="object"){let p=Zb(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 Yn.ClientError("Can not add a property to a sealed table schema");Pn(this)[l]=u}),a("deleteProperty",function(l){Pn(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?SB:gB);break}c=l}while(c&&c!==gB&&c!==SB)}function TB(e,t,r){if(typeof t=="string"){if(t==="then"||t==="getRecord"||t==="getChanges")return;if(_B[t])return _B[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=Zb(s);if(i)return n||(n=Object.create(null),r._setChanges(n)),n[t]=i,i}return s}}function yee(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 Zb(e,t){let r;switch(e.constructor){case Object:return t?(r=t.TrackedObject,r||(t.TrackedObject=r=class extends tl{static{o(this,"TrackedObject")}},Um(r,t)),new r(e)):new tl(e);case Array:let n=new q_(e.length,e);for(let s=0,i=e.length;s<i;s++){let a=e[s];a&&typeof a=="object"&&(a=Zb(a,t?.elements)),n[s]=a}return n;default:return e}}function $_(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=$_(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 wa(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=wa(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=Jy[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=wa(s);r[n]=s}if(!Array.isArray(e)&&e.getRecord)for(let n in e)Aee.call(e,n)&&(r||(r={...e.getRecord()}),r[n]=e[n]);return r?Object.freeze(r):e.getRecord?e.getRecord():e}function G_(e){let t=e.getRecord?.();if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[el]||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(G_(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(G_(s))return!0}else return!0}else return!0}}return!1}var Yn,_B,gB,SB,tl,Aee,el,q_,vm,eI=fe(()=>{Yn=w(Ee());BE();Ss();o(Pn,"getChanges");o(Um,"assignTrackedAccessors");_B=Object.prototype,gB=new Proxy({},{get:TB}),SB=new Proxy({},{get:TB,set:yee});o(TB,"getProxiedProperty");o(yee,"setProxiedProperty");o(Zb,"trackObject");tl=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}};Um(tl,{},!0);o($_,"collapseData");Aee=Object.prototype.hasOwnProperty;o(wa,"updateAndFreeze");o(G_,"hasChanges");el=Symbol.for("has-array-changes"),q_=class extends Array{static{o(this,"TrackedArray")}#e;[el];constructor(t,r){super(t),this.#e=r}getRecord(){return this.#e}splice(...t){return this[el]=!0,super.splice(...t)}push(...t){return this[el]=!0,super.push(...t)}pop(){return this[el]=!0,super.pop()}unshift(...t){return this[el]=!0,super.unshift(...t)}shift(){return this[el]=!0,super.shift()}};q_.prototype.constructor=Array;vm=class{static{o(this,"Addition")}__op__="add";value;constructor(t){this.value=t}update(t){return(+t||0)+this.value}}});var OB={};Ce(OB,{ResourceBridge:()=>nI});function sI({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 RB(e,t){let r=Mi(e),n=sI(e,r);if(!r)throw new ri.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;Mt(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&&$_(d)}catch(f){d={message:(0,wB.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 Mi(e){let t=e.database||e.schema||Iee,r=it()[t];if(!r)throw(0,ri.handleHDBError)(new Error,bee.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function yB(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*AB(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 bB,V_,ri,IB,tI,rI,NB,wB,bee,Iee,Nee,wee,nI,CB=fe(()=>{bB=w(EB()),V_=w(vu()),ri=w(Ee());Le();IB=w(Rm());k();tI=w(Ao()),rI=w(ei()),NB=w(ie());Dc();eI();wB=w(z()),{HDB_ERROR_MSGS:bee}=ri.hdbErrors,Iee="data",Nee=1e4,wee=10,nI=class extends bB.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,V_.default)(t,"conditions");if(r)throw(0,ri.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=Mi(t);if(!n)throw new ri.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:sI(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 ri.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 Mi(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=Mi(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 Mi(t).dropTable()}createSchema(t){return Bu({database:t.schema,table:null}),tI.signalSchemaChange(new rI.SchemaEventMsg(process.pid,G.CREATE_SCHEMA,t.schema))}async dropSchema(t){await iI(t.schema),tI.signalSchemaChange(new rI.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,IB.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),Mt(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=$_(m));for(let h in d)if(Object.prototype.hasOwnProperty.call(d,h)){let p=d[h];if(typeof p=="function")try{let _=p([[m]]);Array.isArray(_)&&(p=_[0].func_val,d[h]=p)}catch(_){throw _.message+="Trying to set key "+h+" on object"+JSON.stringify(d),_}}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),Mt(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 yB(a,c,s.timestamp)})}async deleteRecordsBefore(t){let r=it()[t.schema][t.table];if(!r.createdTimeProperty)throw new ri.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:bE.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,NB.asyncSetTimeout)(wee),l=[],s=!0},"chunkDelete");for await(let d of n)l.push(d[r.primaryKey]),c++,c%Nee===0&&await u();return l.length>0&&await u(),s?yB(i,a,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,V_.default)(t,"hashes");if(r)throw r;return RB(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of RB(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,V_.default)(t,"value");if(n)throw n;let s=Mi(t);if(!s)throw new ri.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===bE.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:sI(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async getDataByValue(t,r){let n=new Map,s=Mi(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){Mi({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return Mi(t).deleteHistory(t.timestamp,t.cleanup_deleted_records)}async readAuditLog(t){let r=Mi(t),n={};switch(t.search_type){case IE.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 IE.USERNAME:{let s=t.search_values;for await(let i of AB(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n}default:return AB(r,t.search_values?.[0],t.search_values?.[1],t.limit)}}};o(sI,"getSelect");o(RB,"getRecords");o(Mi,"getTable");o(yB,"createDeleteResponse");o(AB,"groupRecordsInHistory")});var Wn=M((PCe,PB)=>{"use strict";var{ResourceBridge:Oee}=(CB(),v(OB)),Cee=ce();Cee.initSync();var K_;function Pee(){return K_||(K_=new Oee,K_)}o(Pee,"getBridge");PB.exports=Pee()});var vB=M((DCe,MB)=>{"use strict";var LB=require("lodash"),xm=require("mathjs"),Lee=require("jsonata"),DB=ie();MB.exports={distinct_array:o(e=>Array.isArray(e)&&e.length>1?LB.uniqWith(e,LB.isEqual):e,"distinct_array"),searchJSON:Dee,mad:Bm.bind(null,xm.mad),mean:Bm.bind(null,xm.mean),mode:Bm.bind(null,xm.mode),prod:Bm.bind(null,xm.prod),median:Bm.bind(null,xm.median)};function Bm(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(Bm,"aggregateFunction");function Dee(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(DB.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),DB.isEmpty(this.__ala__.res[r])){let n=Lee(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}o(Dee,"searchJSON")});var xB=M((vCe,UB)=>{"use strict";var ir=require("moment"),oI="YYYY-MM-DDTHH:mm:ss.SSSZZ";ir.suppressDeprecationWarnings=!0;UB.exports={current_date:o(()=>ir().utc().format("YYYY-MM-DD"),"current_date"),current_time:o(()=>ir().utc().format("HH:mm:ss.SSS"),"current_time"),extract:o((e,t)=>{switch(t.toLowerCase()){case"year":return ir(e).utc().format("YYYY");case"month":return ir(e).utc().format("MM");case"day":return ir(e).utc().format("DD");case"hour":return ir(e).utc().format("HH");case"minute":return ir(e).utc().format("mm");case"second":return ir(e).utc().format("ss");case"millisecond":return ir(e).utc().format("SSS");default:break}},"extract"),date:o(e=>ir(e).utc().format(oI),"date"),date_format:o((e,t)=>ir(e).utc().format(t),"date_format"),date_add:o((e,t,r)=>ir(e).utc().add(t,r).valueOf(),"date_add"),date_sub:o((e,t,r)=>ir(e).utc().subtract(t,r).valueOf(),"date_sub"),date_diff:o((e,t,r)=>{let n=ir(e).utc(),s=ir(t).utc();return r?n.diff(s,r,!0):n.diff(s)},"date_diff"),now:o(()=>ir().utc().valueOf(),"now"),get_server_time:o(()=>ir().format(oI),"get_server_time"),offset_utc:o((e,t)=>ir(e).utc().utcOffset(t).format(oI),"offset_utc")}});var kB=M((xCe,HB)=>{"use strict";var Mee=require("@turf/area"),vee=require("@turf/length"),Uee=require("@turf/circle"),xee=require("@turf/difference"),Bee=require("@turf/distance"),Fee=require("@turf/boolean-contains"),Hee=require("@turf/boolean-equal"),kee=require("@turf/boolean-disjoint"),Gee=require("@turf/helpers"),BB=(k(),v(K)),Ye=ie(),No=z();HB.exports={geoArea:qee,geoLength:$ee,geoCircle:Vee,geoDifference:Kee,geoDistance:FB,geoNear:Yee,geoContains:Wee,geoEqual:zee,geoCrosses:jee,geoConvert:Qee};function qee(e){if(Ye.isEmpty(e))return NaN;typeof e=="string"&&(e=Ye.autoCastJSON(e));try{return Mee.default(e)}catch(t){return No.trace(t,e),NaN}}o(qee,"geoArea");function $ee(e,t){if(Ye.isEmpty(e))return NaN;typeof e=="string"&&(e=Ye.autoCastJSON(e));try{return vee.default(e,{units:t||"kilometers"})}catch(r){return No.trace(r,e),NaN}}o($ee,"geoLength");function Vee(e,t,r){if(Ye.isEmpty(e))return NaN;if(Ye.isEmpty(t))return NaN;typeof e=="string"&&(e=Ye.autoCastJSON(e));try{return Uee.default(e,t,{units:r||"kilometers"})}catch(n){return No.trace(n,e,t),NaN}}o(Vee,"geoCircle");function Kee(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 xee(e,t)}catch(r){return No.trace(r,e,t),NaN}}o(Kee,"geoDifference");function FB(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 Bee.default(e,t,{units:r||"kilometers"})}catch(n){return No.trace(n,e,t),NaN}}o(FB,"geoDistance");function Yee(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 FB(e,t,n)<=r}catch(s){return No.trace(s,e,t),!1}}o(Yee,"geoNear");function Wee(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 Fee.default(e,t)}catch(r){return No.trace(r,e,t),!1}}o(Wee,"geoContains");function zee(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 Hee.default(e,t)}catch(r){return No.trace(r,e,t),!1}}o(zee,"geoEqual");function jee(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!kee.default(e,t)}catch(r){return No.trace(r,e,t),!1}}o(jee,"geoCrosses");function Qee(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(BB.GEO_CONVERSION_ENUM[t]))throw new Error(`geoType of ${t} is invalid please use one of the following types: ${Object.keys(BB.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Ye.autoCastJSON(e)),Gee[t](e,r)}o(Qee,"geoConvert")});var Y_=M((FCe,GB)=>{var rl=vB(),zn=xB(),vi=kB();GB.exports=e=>{e.aggr.mad=e.aggr.MAD=rl.mad,e.aggr.mean=e.aggr.MEAN=rl.mean,e.aggr.mode=e.aggr.MODE=rl.mode,e.aggr.prod=e.aggr.PROD=rl.prod,e.aggr.median=e.aggr.MEDIAN=rl.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=rl.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=rl.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=zn.current_date,e.fn.current_time=e.fn.CURRENT_TIME=zn.current_time,e.fn.extract=e.fn.EXTRACT=zn.extract,e.fn.date=e.fn.DATE=zn.date,e.fn.date_format=e.fn.DATE_FORMAT=zn.date_format,e.fn.date_add=e.fn.DATE_ADD=zn.date_add,e.fn.date_sub=e.fn.DATE_SUB=zn.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=zn.date_diff,e.fn.now=e.fn.NOW=zn.now,e.fn.offset_utc=e.fn.OFFSET_UTC=zn.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=zn.get_server_time,e.fn.getdate=e.fn.GETDATE=zn.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=zn.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=vi.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=vi.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=vi.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=vi.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=vi.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=vi.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=vi.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=vi.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=vi.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=vi.geoNear}});var KB=M((HCe,VB)=>{"use strict";var Fm=require("lodash"),Ln=require("alasql");Ln.options.cache=!1;var Jee=Y_(),qB=require("clone"),W_=require("recursive-iterator"),ke=z(),tt=ie(),Fu=Wn(),Xee=(k(),v(K)),{hdbErrors:Zee}=Ee(),{getDatabases:$B}=(Le(),v(ft)),ete="IS NULL",ni="There was a problem performing this search. Please check the logs and try again.";Jee(Ln);var aI=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(ni)}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(ni)}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(ni)}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(ni)}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(ni)}}_getColumns(){let t=new W_(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(qB(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=Fm.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=$B()[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 W_(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 Ln.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 Ln.yy.LogicValue({value:i}):n instanceof Ln.yy.StringValue&&tt.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new Ln.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 W_(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(Xee.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&&Fm.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 Ln.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(qB(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(ete)>-1&&this.tables.forEach(s=>{let i={columnid:$B()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=Fm.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 Fu.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(ni)}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 Fu.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(ni)}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 Fu.getDataByValue(c,h.operation);if(l)for(let[_]of p)this.data[i].__mergedData[_]||(this.data[i].__mergedData[_]=[...n[i]],this._setMergedHashAttribute(i,_));else for(let[_,g]of p)this.data[i].__mergedData[_]?this._updateMergedAttribute(i,_,s.attribute,g[s.attribute]):(this.data[i].__mergedData[_]=[...n[i]],this._updateMergedAttribute(i,_,s.attribute,g[s.attribute]),this._setMergedHashAttribute(i,_))}}catch(d){throw ke.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),ke.error(d),new Error(ni)}else try{c.search_attribute=s.attribute,c.search_value="*";let d=await Fu.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(ni)}}}_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 Ln.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 Ln.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new Ln.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 Ln.yy.FuncValue:new Ln.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,_=h.as?h.as_orig:h.tableid_orig;a.push({key:`'${_}.${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 "${_}.${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 Ln.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 _=m[h];a.forEach(g=>{_[g.key]!==null&&_[g.key]!==void 0&&g.keys.add(_[g.key])})}a.forEach(h=>{let p=Object.keys(this.data[`${h.schema}_${h.table}`].__mergedData),_=Fm.difference(p,[...h.keys].map(g=>g.toString()));for(let g=0,y=_.length;g<y;g++){let T=_[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 W_(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=Fm.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(ni)}}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 Fu.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 _=s.columns[p],g=h[_]===void 0?null:h[_];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 Ln.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(Zee.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 Fu.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(ni)}}return Object.values(Object.values(this.data)[0].__mergedData)}};VB.exports=aI});var nn=M((GCe,YB)=>{"use strict";var tte=HU();YB.exports={searchByConditions:nte,searchByHash:ste,searchByValue:ite,search:ote};var cI=Wn(),{transformReq:lI}=ie(),rte=KB();async function nte(e){return lI(e),cI.searchByConditions(e)}o(nte,"searchByConditions");async function ste(e){lI(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of cI.searchByHash(e))r&&t.push(r);return t}o(ste,"searchByHash");async function ite(e){lI(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of cI.searchByValue(e))t.push(r);return t}o(ite,"searchByValue");function ote(e,t){try{let r=new tte(e);r.validate(),new rte(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}o(ote,"search")});var Ui=M(($Ce,QB)=>{"use strict";var Hm=require("crypto"),ate=ce(),{CONFIG_PARAMS:cte}=(k(),v(K)),zB="aes-256-cbc",lte=32,ute=16,uI=64,jB=32,dte=uI+jB,WB=new Map;QB.exports={encrypt:fte,decrypt:mte,createNatsTableStreamName:hte};function fte(e){let t=Hm.randomBytes(lte),r=Hm.randomBytes(ute),n=Hm.createCipheriv(zB,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(fte,"encrypt");function mte(e){let t=e.substr(0,uI),r=e.substr(uI,jB),n=e.substr(dte,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),a=Hm.createDecipheriv(zB,Buffer.from(t,"hex"),s),c=a.update(i);return c=Buffer.concat([c,a.final()]),c.toString()}o(mte,"decrypt");function hte(e,t){let r=ate.get(cte.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=WB.get(r);return n||(n=Hm.createHash("md5").update(r).digest("hex"),WB.set(r,n)),n}o(hte,"createNatsTableStreamName")});var Oa=M((YCe,eF)=>{"use strict";var KCe=nn(),km=z(),{validateBySchema:JB}=ct(),nl=require("joi"),pte=Ui(),z_=ie(),{handleHDBError:j_,hdbErrors:Ete,ClientError:XB}=Ee(),{HDB_ERROR_MSGS:Q_,HTTP_STATUS_CODES:dI}=Ete,ZB=ce();ZB.initSync();var{getDatabases:fI}=(Le(),v(ft)),_te=require("fs-extra"),gte=(k(),v(K));eF.exports={describeAll:Ste,describeTable:J_,describeSchema:Tte};async function Ste(e={}){try{let t=z_.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=fI(),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 J_({schema:f,table:h,exactCount:u});else if(n&&n[f].describe&&n[f].tables[h].describe){let _=n[f].tables[h].attribute_permissions;p=await J_({schema:f,table:h,exactCount:u},_)}p&&l.push(p)}catch(p){km.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 km.error("Got an error in describeAll"),km.error(t),j_(new Error,Q_.DESCRIBE_ALL_ERR)}}o(Ste,"describeAll");async function J_(e,t){z_.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=JB(e,nl.object({database:nl.string(),table:nl.string().required(),exact_count:nl.boolean().strict()}));if(i)throw new XB(i.message);let c=fI()[r];if(!c)throw j_(new Error,Q_.SCHEMA_NOT_FOUND(e.schema),dI.NOT_FOUND);let l=c[n];if(!l)throw j_(new Error,Q_.TABLE_NOT_FOUND(e.schema,e.table),dI.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 _te.stat(l.primaryStore.env.path)).size}catch(h){km.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")),ZB.get(gte.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(m.clustering_stream_name=pte.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 _ of p.getKeys({reverse:!0,limit:1}))m.last_updated_record=_[0];if(!m.last_updated_record&&l.indices.__updatedtime__)for(let _ of l.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))m.last_updated_record=_}catch(h){km.warn(`unable to stat table dbi due to ${h}`)}return m}o(J_,"descTable");async function Tte(e){z_.transformReq(e);let t=JB(e,nl.object({database:nl.string(),exact_count:nl.boolean().strict()}));if(t)throw new XB(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=fI()[n];if(!i)throw j_(new Error,Q_.SCHEMA_NOT_FOUND(e.schema),dI.NOT_FOUND);let a={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),z_.isEmpty(l)||l.describe){let u=await J_({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);u&&(a[u.name]=u)}}return a}o(Tte,"describeSchema")});var Dn=M((zCe,sF)=>{"use strict";var Z_=pb(),$r=ie(),Rte=require("util"),eg=Wn(),yte=Zs(),tF=z(),{handleHDBError:sl,hdbErrors:Ate}=Ee(),{HTTP_STATUS_CODES:il}=Ate,bte=Rte.promisify(yte.getTableSchema),Ite="updated",rF="inserted",nF="upserted";sF.exports={insert:wte,update:Ote,upsert:Cte,validation:Nte,flush:Pte};async function Nte(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 bte(e.schema,e.table),r=Z_(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 tF.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 tF.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(Nte,"validation");async function wte(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=Z_(e);if(t)throw sl(new Error,t.message,il.BAD_REQUEST);$r.transformReq(e);let r=$r.checkSchemaTableExist(e.schema,e.table);if(r)throw sl(new Error,r,il.BAD_REQUEST);let n=await eg.createRecords(e);return X_(rF,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}o(wte,"insertData");async function Ote(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=Z_(e);if(t)throw sl(new Error,t.message,il.BAD_REQUEST);$r.transformReq(e);let r=$r.checkSchemaTableExist(e.schema,e.table);if(r)throw sl(new Error,r,il.BAD_REQUEST);let n=await eg.updateRecords(e);return $r.isEmpty(n.existing_rows)?X_(Ite,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):X_(n.update_action,[],e,n.hashes,void 0,n.txn_time)}o(Ote,"updateData");async function Cte(e){if(e.operation!=="upsert")throw sl(new Error,"invalid operation, must be upsert",il.INTERNAL_SERVER_ERROR);let t=Z_(e);if(t)throw sl(new Error,t.message,il.BAD_REQUEST);$r.transformReq(e);let r=$r.checkSchemaTableExist(e.schema,e.table);if(r)throw sl(new Error,r,il.BAD_REQUEST);let n=await eg.upsertRecords(e);return X_(nF,n.written_hashes,e,[],n.new_attributes,n.txn_time)}o(Cte,"upsertData");function X_(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===rF?(a.inserted_hashes=t,a.skipped_hashes=n,a):e===nF?(a.upserted_hashes=t,a):(a.update_hashes=t,a.skipped_hashes=n,a)}o(X_,"returnObject");function Pte(e){return $r.transformReq(e),eg.flush(e.schema,e.table)}o(Pte,"flush")});var hI=M((QCe,aF)=>{var Lte=ct(),mI=require("joi"),{hdbTable:Dte,hdbDatabase:iF}=Li(),oF={schema:iF,database:iF,table:Dte},Mte={date:mI.date().iso().required()},vte={timestamp:mI.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};aF.exports=function(e,t){let r=t==="timestamp"?{...oF,...vte}:{...oF,...Mte},n=mI.object(r);return Lte.validateBySchema(e,n)}});var uF=M((JCe,lF)=>{var Ute=ct(),pI=require("joi"),{hdbTable:xte,hdbDatabase:cF}=Li(),Bte=pI.object({schema:cF,database:cF,table:xte,hash_values:pI.array().required(),ids:pI.array()});lF.exports=function(e){return Ute.validateBySchema(e,Bte)}});var SI=M((XCe,dF)=>{"use strict";var EI=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}},_I=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}},gI=class{static{o(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};dF.exports={InsertObject:EI,NoSQLSeachObject:_I,DeleteResponseObject:gI}});var cl=M((ePe,EF)=>{"use strict";var mF=hI(),Fte=uF(),ol=ie(),fF=require("moment"),hF=z(),{promisify:Hte,callbackify:kte}=require("util"),al=(k(),v(K)),Gte=Zs(),TI=Hte(Gte.getTableSchema),RI=Wn(),{DeleteResponseObject:qte}=SI(),{handleHDBError:Ca,hdbErrors:$te}=Ee(),{HDB_ERROR_MSGS:tg,HTTP_STATUS_CODES:Pa}=$te,Vte="records successfully deleted",Kte=kte(pF);EF.exports={delete:Kte,deleteRecord:pF,deleteFilesBefore:Yte,deleteAuditLogsBefore:Wte};async function Yte(e){let t=mF(e,"date");if(t)throw Ca(t,t.message,Pa.BAD_REQUEST,void 0,void 0,!0);if(ol.transformReq(e),!fF(e.date,fF.ISO_8601).isValid())throw Ca(new Error,tg.INVALID_DATE,Pa.BAD_REQUEST,al.LOG_LEVELS.ERROR,tg.INVALID_DATE,!0);let n=ol.checkSchemaTableExist(e.schema,e.table);if(n)throw Ca(new Error,n,Pa.NOT_FOUND,al.LOG_LEVELS.ERROR,n,!0);let s=await RI.deleteRecordsBefore(e);if(await TI(e.schema,e.table),hF.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}o(Yte,"deleteFilesBefore");async function Wte(e){let t=mF(e,"timestamp");if(t)throw Ca(t,t.message,Pa.BAD_REQUEST,void 0,void 0,!0);if(ol.transformReq(e),isNaN(e.timestamp))throw Ca(new Error,tg.INVALID_VALUE("Timestamp"),Pa.BAD_REQUEST,al.LOG_LEVELS.ERROR,tg.INVALID_VALUE("Timestamp"),!0);let r=ol.checkSchemaTableExist(e.schema,e.table);if(r)throw Ca(new Error,r,Pa.NOT_FOUND,al.LOG_LEVELS.ERROR,r,!0);let n=await RI.deleteAuditLogsBefore(e);return await TI(e.schema,e.table),hF.info(`Finished deleting audit logs before ${e.timestamp}`),n}o(Wte,"deleteAuditLogsBefore");async function pF(e){e.ids&&(e.hash_values=e.ids);let t=Fte(e);if(t)throw Ca(t,t.message,Pa.BAD_REQUEST,void 0,void 0,!0);ol.transformReq(e);let r=ol.checkSchemaTableExist(e.schema,e.table);if(r)throw Ca(new Error,r,Pa.NOT_FOUND,al.LOG_LEVELS.ERROR,r,!0);try{await TI(e.schema,e.table);let n=await RI.deleteRecords(e);return ol.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${Vte}`),n}catch(n){if(n.message===al.SEARCH_NOT_FOUND_MESSAGE){let s=new qte;return s.message=al.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}o(pF,"deleteRecord")});var rg={};Ce(rg,{HASH_FUNCTION:()=>Mr,hash:()=>bI,validate:()=>II});function yI(e=qm){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ";return Array.from(Gm.randomBytes(e)).map(r=>t[r%t.length]).join("")}function bI(e,t=Mr[gF?.toUpperCase()]??Mr.SHA256){return AI[t](e)}function II(e,t,r=Mr[gF?.toUpperCase()]??Mr.SHA256){return e?zte[r](e,t):!1}var Gm,Hu,_F,gF,qm,SF,Mr,AI,zte,ng=fe(()=>{Gm=w(require("node:crypto")),Hu=w(require("argon2")),_F=w(ce());k();gF=(0,_F.get)(U.AUTHENTICATION_HASHFUNCTION)?.toLowerCase(),qm=16,SF=9,Mr={MD5:"md5",SHA256:"sha256",ARGON2ID:"argon2id"};o(yI,"generateSalt");AI={[Mr.MD5]:(e,t=void 0)=>{t=t??yI(SF);let r=Gm.createHash(Mr.MD5).update(e+t).digest("hex");return t+r},[Mr.SHA256]:(e,t=void 0)=>{t=t??yI(qm);let r=Gm.createHash(Mr.SHA256).update(e+t).digest("hex");return t+r},[Mr.ARGON2ID]:async e=>{let t=yI(qm),r=await Hu.hash(e,{type:Hu.argon2id,salt:Buffer.from(t)});return t+r}},zte={[Mr.MD5]:(e,t)=>{let r=e.slice(0,SF);return e===AI[Mr.MD5](t,r)},[Mr.SHA256]:(e,t)=>{let r=e.slice(0,qm);return e===AI[Mr.SHA256](t,r)},[Mr.ARGON2ID]:async(e,t)=>await Hu.verify(e.slice(qm),t)};o(bI,"hash");o(II,"validate")});var RF=M((sPe,TF)=>{var NI=ct(),sn={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 jte(e){return sn.password.presence=!0,sn.username.presence=!0,sn.role.presence=!0,sn.active.presence=!0,NI.validateObject(e,sn)}o(jte,"addUserValidation");function Qte(e){return sn.password.presence=!1,sn.username.presence=!0,sn.role.presence=!1,sn.active.presence=!1,NI.validateObject(e,sn)}o(Qte,"alterUserValidation");function Jte(e){return sn.password.presence=!1,sn.username.presence=!0,sn.role.presence=!1,sn.active.presence=!1,NI.validateObject(e,sn)}o(Jte,"dropUserValidation");TF.exports={addUserValidation:jte,alterUserValidation:Qte,dropUserValidation:Jte}});var bt=M((aPe,AF)=>{"use strict";var{platform:oPe}=require("os"),Xte="nats-server.zip",wI="nats-server",Zte=process.platform==="win32"?`${wI}.exe`:wI,ere=/^[^\s.,*>]+$/,yF="__request__",tre=o(e=>`${e}.${yF}`,"REQUEST_SUBJECT"),rre={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},nre={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},sre={HUB:"hub.pid",LEAF:"leaf.pid"},ire={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},ore={SUCCESS:"success",ERROR:"error"},are={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},cre={TXN:"txn",MSGID:"msgid"},ku={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},lre={[ku.ERR]:1,[ku.WRN]:2,[ku.INF]:3,[ku.DBG]:4,[ku.TRC]:5},ure={debug:"-D",trace:"-DVV"};AF.exports={NATS_SERVER_ZIP:Xte,NATS_SERVER_NAME:wI,NATS_BINARY_NAME:Zte,PID_FILES:sre,NATS_CONFIG_FILES:nre,SERVER_SUFFIX:ire,NATS_TERM_CONSTRAINTS_RX:ere,REQUEST_SUFFIX:yF,UPDATE_REMOTE_RESPONSE_STATUSES:ore,CLUSTER_STATUS_STATUSES:are,REQUEST_SUBJECT:tre,SUBJECT_PREFIXES:cre,MSG_HEADERS:rre,LOG_LEVELS:ku,LOG_LEVEL_FLAGS:ure,LOG_LEVEL_HIERARCHY:lre}});var OI=M(on=>{"use strict";var dre={cert:"-----BEGIN CERTIFICATE-----\rMIIDXDCCAkSgAwIBAgIFNTE4MzQwDQYJKoZIhvcNAQELBQAwXTEXMBUGA1UEAxMO\rSGFycGVyREIsIEluYy4xCzAJBgNVBAYTAlVTMQswCQYDVQQIEwJDTzEPMA0GA1UE\rBxMGRGVudmVyMRcwFQYDVQQKEw5IYXJwZXJEQiwgSW5jLjAeFw0yMjAzMTEyMzAz\rNDlaFw0yNzAzMTAyMzAzNDlaMF0xFzAVBgNVBAMTDkhhcnBlckRCLCBJbmMuMQsw\rCQYDVQQGEwJVUzELMAkGA1UECBMCQ08xDzANBgNVBAcTBkRlbnZlcjEXMBUGA1UE\rChMOSGFycGVyREIsIEluYy4wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIB\rAQCsEUlBF8WImS78rCFXVKyntxfrW++4qZ3hGnoD2MHZAuDHyeP/5eGnaE9GQhKc\r4DwG4DGvh0wP2zIYnBfiQ3L2ZtnlDR9ZkKIQYGlVxTUn6T43krhK5nZKqDF43Yg3\rZEvO3cbJBjiKZx0eA2/toehdSsTAHHQx5gTDcggNe2tgoJHYPwi9YF/AxSBZrbgb\ryWlYgtYDmF32ytHP03GUCIdKOFuBPsHTGu4SkdEIdLIqO9oglW1YFH5qZ6NiwApW\rsP+GCuqOwDXXbdjr75iq9Tq/CDrjGFLaTPmvd2Q0qG/BtaCll0ghpG+yIHvt/iQs\rajS+LxEWAnVlGMaDdFErbDUtAgMBAAGjIzAhMA8GA1UdEwEB/wQFMAMBAf8wDgYD\rVR0PAQH/BAQDAgIEMA0GCSqGSIb3DQEBCwUAA4IBAQASR4YW/rPK7PNArHVe9zzM\rb0rKNX/2T9/0nybRhmE/+hdlSgliTAeebmwkUS2APckmekYt/q2ZY2NS65Fo/jjp\rG8TJrtcF4h+ylVqUp0ZXQLFtIsr7r2JZA7hJ6njW6G4DHSZ0gxtECLi4CBlTjzm5\rNmnmIDObvGRTuqmcdAZmXeObbta/He2XIzietukPAYX062pNM+G5XT5UM1eG/Vlp\rN86vjhpyI+ffKy+C60SJqxmKM3ydgN7oLscE7+2wLPN25XqN4W99OwGsp5dTdu/f\r5lPtFayXdJ55e/sNQKmGN+UGLrL05c2MWgjb8U/LFilnupUianceoeSERZmVjzKX\r-----END CERTIFICATE-----\r".replace(/\r/g,`\r
|
|
12
12
|
`),key:"-----BEGIN RSA PRIVATE KEY-----\rMIIEowIBAAKCAQEArBFJQRfFiJku/KwhV1Ssp7cX61vvuKmd4Rp6A9jB2QLgx8nj\r/+Xhp2hPRkISnOA8BuAxr4dMD9syGJwX4kNy9mbZ5Q0fWZCiEGBpVcU1J+k+N5K4\rSuZ2SqgxeN2IN2RLzt3GyQY4imcdHgNv7aHoXUrEwBx0MeYEw3IIDXtrYKCR2D8I\rvWBfwMUgWa24G8lpWILWA5hd9srRz9NxlAiHSjhbgT7B0xruEpHRCHSyKjvaIJVt\rWBR+amejYsAKVrD/hgrqjsA1123Y6++YqvU6vwg64xhS2kz5r3dkNKhvwbWgpZdI\rIaRvsiB77f4kLGo0vi8RFgJ1ZRjGg3RRK2w1LQIDAQABAoIBAQCEOmh78EOpnGZC\rYBjjHrvrysVD5gvLcfVUtl8Ls7gMB60re1eOIF+PoZZCHKZnDd6zPfiQtj1adg0C\rYnnsM/8VoaZS4gm0b3RLd3ubIQifWhuo40RissY2yxfxlPSH9LhZCY8ojnJG0cTL\resK579E8WCfopjUY33XLqEbN7Ylv39J+DSqInjqV3efJZUa+HqUJ98VxxzodcKMD\rP3bwUU4gHoSSp4pAsOFH5sQhaIWH1IcNjrAwpee2cJQuh4G157RRIuuUpagtaEG/\rXJIiAyBguJyu3JQFnIBQF01N5+omJgXYJ1L0m54543/iIRThmF3zDCDgCyUzmOk+\rH6As9fv1AoGBANOpOtOZLSAScjGsgJamT3ceJ2wCa86g2j8Oxu8lJUmUp5s3tA0v\rBFW5O3S4KR1EXwkLMBUMrfFM8YvzHWxsXBI6XV8azGLvyqPHxr65OhmpGYkGZMXu\rn9okgjkqlewnY2I073gvyK7ppX51UL5y9fF1vlsk+UlW+Rgx/vMHbdcjAoGBANAc\rxRUsxs4QJpbS4zD3JOkHjr24a97TrS3kCybAHUMpR2NrEHPZw9zex0/aphOJUHfL\rIMkOZdpfDqMfxWy4FAEmqBEMkO2SB+h0Wp4P+qp81ax4vGFiB0cD3wtixr11U1tt\rlZ/ZTdv4VDpDFNK1KaplhTDeyuCjeYfS3/GJia9vAoGAcOsAgjBevZR5rXx84WH6\rVO8WUu37u7FenXNxt9VWTinrPMh72uixZFY8nOk+rely1e1NCn3IMko9Ns9NbDFm\r8SaH95vhXArXTYbfxZIlp9jp0YtCqcHDL+p4Oq04bFMbFyJseu7rHj1x18QYfnHw\rOY/6LL/N6k1m+Hx7qgXVmIcCgYB/w0nTCBw84XlvWqSTqQaF8VfWbWP79mP5KmkW\rLxdH5g2noVEGbohqDnK6OXd/wusdwByukiJBf94Skyy25AOT+VFwthA7aU1ljhkb\rtJ+lDuJ28eBkwLPLCzthWBC+u0qjdJFJAzVjd/7tjcU43nNn4s90AzL12iaAFhvZ\rwyA+DQKBgGc/4cdyGJ3YkcA8150gQBawgJZ7q8V1JND87ggWA8wnK3cHn7rMZQl2\r3emDp9HEFXFex5dbGDDqZFAoesZCDxjknIn9oNfW4PvaWS8q7b6ZKLZG1p03Pu7/\rtYaD0kPbo0kysfFT/co+NgHbdykvIyboomfGdNLTUjYuy6lpwpvs\r-----END RSA PRIVATE KEY-----\r".replace(/\r/g,`\r
|
|
13
13
|
`)},fre="certificate.pem",mre="privateKey.pem",hre="caCertificate.pem",pre="natsCertificate.pem",Ere="natsCaCertificate.pem",It={DEFAULT:"default","DEFAULT-CA":"default-ca",SERVER:"server",CA:"ca","OPERATIONS-API":"operations-api","OPERATIONS-CA":"operations-ca"},_re={tls_certificate:It.SERVER,tlsCertificateAuthority:It.CA,customFunctions_tls_certificate:It.SERVER,customFunctionsTlsCertificateAuthority:It.CA,operationsApi_tls_certificate:It["OPERATIONS-API"],operationsApiTlsCertificateAuthority:It["OPERATIONS-CA"]},gre={[It.SERVER]:2,[It.DEFAULT]:1},Sre={[It["OPERATIONS-API"]]:3,[It.SERVER]:2,[It.DEFAULT]:1},Tre={[It["OPERATIONS-API"]]:3,[It.SERVER]:2,[It.DEFAULT]:1},Rre={[It["OPERATIONS-CA"]]:3,[It.CA]:2,[It["DEFAULT-CA"]]:1},yre={[It["OPERATIONS-CA"]]:3,[It.CA]:2,[It["DEFAULT-CA"]]:1},Are={[It.CA]:2,[It["DEFAULT-CA"]]:1};on.CERTIFICATE_PEM_NAME=fre;on.PRIVATEKEY_PEM_NAME=mre;on.CA_PEM_NAME=hre;on.CERT_NAME=It;on.CERT_CONFIG_NAME_MAP=_re;on.CERT_PREFERENCE_APP=gre;on.CERT_PREFERENCE_OPS=Sre;on.CERT_PREFERENCE_REP=Tre;on.CA_CERT_PREFERENCE_REP=Rre;on.CA_CERT_PREFERENCE_OPS=yre;on.CA_CERT_PREFERENCE_APP=Are;on.CERTIFICATE_VALUES=dre;on.NATS_CERTIFICATE_PEM_NAME=pre;on.NATS_CA_PEM_NAME=Ere});var PI=M((dPe,CF)=>{"use strict";var wF=require("fs-extra"),Se=require("joi"),bre=require("os"),{boolean:qe,string:_t,number:or,array:La}=Se.types(),{totalmem:bF}=require("os"),ll=require("path"),Ire=z(),CI=ie(),uPe=OI(),IF=(k(),v(K)),Nre=ct(),NF="log",wre="components",Ore="Invalid logging.rotation.maxSize unit. Available units are G, M or K",Cre="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",Pre="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",Lre="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",Dre="rootPath config parameter is undefined",Mn=Se.alternatives([or.min(0),_t]).optional().empty(null),sg=Se.alternatives([La.items(_t,{host:_t.required(),port:Mn},{hostname:_t.required(),port:Mn}).empty(null),La.items(_t)]),xi,OF=!1;CF.exports={configValidator:Mre,routesValidator:Hre,routeConstraints:sg};function Mre(e,t=!1){if(OF=t,xi=e.rootPath,CI.isEmpty(xi))throw Dre;let r=qe.optional(),n=or.min(0).max(1e3).empty(null).default(Fre),s=_t.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default($m),i=_t.optional().empty(null),a=_t.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null).required(),c=Se.string().empty(null).default($m),l=Se.custom(Ure).empty(null).default($m),u=e.clustering?.enabled,d=Se.object({certificate:i,certificateAuthority:i,privateKey:i}),f;return u===!0?f=Se.object({enabled:r,hubServer:Se.object({cluster:Se.object({name:Se.required().empty(null),network:Se.object({port:Mn,routes:sg}).required()}).required(),leafNodes:Se.object({network:Se.object({port:Mn}).required()}).required(),network:Se.object({port:Mn}).required()}).required(),leafServer:Se.object({network:Se.object({port:Mn,routes:sg}).required(),streams:Se.object({maxAge:or.min(120).allow(null).optional(),maxBytes:or.min(1).allow(null).optional(),maxMsgs:or.min(1).allow(null).optional(),path:c}).required()}).required(),logLevel:Se.valid("error","warn","info","debug","trace"),nodeName:a,republishMessages:qe.optional(),databaseLevel:qe.optional(),tls:Se.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:qe.required(),verify:qe.optional()}),user:_t.optional().empty(null)}).optional():f=Se.object({enabled:r,tls:Se.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:qe.optional()})}).optional(),Se.object({authentication:Se.alternatives(Se.object({authorizeLocal:qe,cacheTTL:or.required(),cookie:Se.object({domains:La.items(_t).optional(),expires:_t.optional()}),enableSessions:qe,hashFunction:_t.valid("md5","sha256","argon2id").optional().empty(null)}),qe).optional(),analytics:Se.object({aggregatePeriod:or,replicate:qe.optional()}),replication:Se.object({hostname:Se.alternatives(_t,or).optional().empty(null),url:_t.optional().empty(null),port:Mn,securePort:Mn,routes:La.optional().empty(null),databases:Se.alternatives(_t,La),enableRootCAs:qe.optional(),copyTablesToCatchUp:qe.optional()}).optional(),componentsRoot:s.optional(),clustering:f,localStudio:Se.object({enabled:r}).required(),logging:Se.object({auditAuthEvents:Se.object({logFailed:qe,logSuccessful:qe}),file:qe.required(),level:Se.valid("notify","fatal","error","warn","info","debug","trace"),rotation:Se.object({enabled:qe.optional(),compress:qe.optional(),interval:_t.custom(Bre).optional().empty(null),maxSize:_t.custom(xre).optional().empty(null),path:_t.optional().empty(null).default($m)}).required(),root:s,stdStreams:qe.required(),auditLog:qe.required()}).required(),operationsApi:Se.object({network:Se.object({cors:qe.optional(),corsAccessList:La.optional(),headersTimeout:or.min(1).optional(),keepAliveTimeout:or.min(1).optional(),port:Mn,domainSocket:Se.optional().empty("hdb/operations-server").default($m),securePort:Mn,timeout:or.min(1).optional()}).optional(),tls:Se.alternatives([Se.array().items(d),d])}).required(),rootPath:_t.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").required(),mqtt:Se.object({network:Se.object({port:Mn,securePort:Mn,mtls:Se.alternatives([qe.optional(),Se.object({user:_t.optional(),certificateAuthority:i,required:qe.optional()})])}).required(),webSocket:qe.optional(),requireAuthentication:qe.optional()}),http:Se.object({compressionThreshold:or.optional(),cors:qe.optional(),corsAccessList:La.optional(),headersTimeout:or.min(1).optional(),port:Mn,securePort:Mn,maxHeaderSize:or.optional(),mtls:Se.alternatives([qe.optional(),Se.object({user:_t.optional(),certificateAuthority:i,required:qe.optional()})]),threadRange:Se.alternatives([La.optional(),_t.optional()])}).required(),threads:Se.alternatives(n.optional(),Se.object({count:n.optional(),debug:Se.alternatives(qe.optional(),Se.object({startingPort:or.min(1).optional(),host:_t.optional(),waitForDebugger:qe.optional()})),maxHeapMemory:or.min(0).optional()})),storage:Se.object({writeAsync:qe.required(),overlappingSync:qe.optional(),caching:qe.optional(),compression:Se.alternatives([qe.optional(),Se.object({dictionary:_t.optional(),threshold:or.optional()})]),compactOnStart:qe.optional(),compactOnStartKeepBackup:qe.optional(),noReadAhead:qe.optional(),path:l,prefetchWrites:qe.optional(),maxFreeSpaceToLoad:or.optional(),maxFreeSpaceToRetain:or.optional()}).required(),ignoreScripts:qe.optional(),tls:Se.alternatives([Se.array().items(d),d])}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}o(Mre,"configValidator");function vre(e){return OF||wF.existsSync(e)?null:`Specified path ${e} does not exist.`}o(vre,"doesPathExist");function Ure(e,t){Se.assert(e,_t.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=vre(e);if(r)return t.message(r)}o(Ure,"validatePath");function xre(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(Ore);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(Pre):e}o(xre,"validateRotationMaxSize");function Bre(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message(Cre);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(Lre):e}o(Bre,"validateRotationInterval");function Fre(e,t){let r=t.state.path.join("."),n=bre.cpus().length,s=n-1;s<=2&&(s=2);let i=process.constrainedMemory?.()||bF();return i=Math.round(Math.min(i,bF())/1e6),s=Math.max(Math.min(s,Math.round((i-750)/300)),1),Ire.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}o(Fre,"setDefaultThreads");function $m(e,t){let r=t.state.path.join(".");if(!CI.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if(CI.isEmpty(xi))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return ll.join(xi,wre);case"logging.root":return ll.join(xi,NF);case"clustering.leafServer.streams.path":return ll.join(xi,"clustering","leaf");case"storage.path":let n=ll.join(xi,IF.LEGACY_DATABASES_DIR_NAME);return wF.existsSync(n)?n:ll.join(xi,IF.DATABASES_DIR_NAME);case"logging.rotation.path":return ll.join(xi,NF);case"operationsApi.network.domainSocket":return r==null?null:ll.join(xi,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}o($m,"setDefaultRoot");function Hre(e){let t=Se.object({routes:sg});return Nre.validateBySchema({routes:e},t)}o(Hre,"routesValidator")});var At=M(Jt=>{"use strict";var Is=(k(),v(K)),Rr=ie(),ar=z(),{configValidator:kre,routesValidator:PF}=PI(),an=require("fs-extra"),DF=require("yaml"),Qn=require("path"),Gre=require("is-number"),MF=require("properties-reader"),qre=require("lodash"),{handleHDBError:$re}=Ee(),{HTTP_STATUS_CODES:Vre,HDB_ERROR_MSGS:Gu}=en(),{server:Kre}=(Pr(),v(Df)),{PACKAGE_ROOT:vF}=Rt(),{DATABASES_PARAM_CONFIG:Vm,CONFIG_PARAMS:jn,CONFIG_PARAM_MAP:si}=Is,Yre="Unable to get config value because config is uninitialized",Wre="Config successfully initialized",zre="Error backing up config file",jre="Empty parameter sent to getConfigValue",UF=Qn.join(vF,"config","yaml",Is.HDB_DEFAULT_CONFIG_FILE),Qre=Qn.join(vF,"config","yaml","defaultNatsConfig.yaml"),Jre="Configuration successfully set. You must restart HarperDB for new config settings to take effect.",LF={logging_rotation_retain:"logging.rotation.retain",logging_rotation_rotate:"logging.rotation.rotate",logging_rotation_rotateinterval:"logging.rotation.rotateInterval",logging_rotation_rotatemodule:"logging.rotation.rotateModule",logging_rotation_timezone:"logging.rotation.timezone",logging_rotation_workerinterval:"logging.rotation.workerInterval"},ig,Ut,og;Jt.createConfigFile=Xre;Jt.getDefaultConfig=Zre;Jt.getConfigValue=BF;Jt.initConfig=ag;Jt.flattenConfig=qu;Jt.updateConfigValue=FF;Jt.updateConfigObject=tne;Jt.getConfiguration=sne;Jt.setConfiguration=ine;Jt.readConfigFile=vI;Jt.getClusteringRoutes=one;Jt.initOldConfig=HF;Jt.getConfigFromFile=ane;Jt.getConfigFilePath=ul;Jt.addConfig=cne;Jt.deleteConfigFromFile=lne;Jt.getConfigObj=une;Jt.resolvePath=LI;Jt.getFlatConfigObj=dne;function LI(e){if(e?.startsWith("~/"))return Qn.join(Rr.getHomeDir(),e.slice(1));let t=ce();try{return Qn.resolve(t.getHdbBasePath(),e)}catch(r){return console.error("Unable to resolve path",e,r),e}}o(LI,"resolvePath");function Xre(e,t=!1){let r=Da(UF);if(e.clustering_enabled||e.CLUSTERING_ENABLED||e.clustering){let c=DF.parseDocument(an.readFileSync(Qre,"utf8"),{simpleKeys:!0});r.addIn(["clustering"],c.toJSON().clustering)}ig=qu(r.toJSON());let n;for(let c in e){let l=si[c.toLowerCase()];if(l===jn.DATABASES){Array.isArray(e[c])?n=e[c]:n=Object.keys(e[c]).map(u=>({[u]:e[c][u]}));continue}if(!l&&(c.endsWith("_package")||c.endsWith("_port"))&&(l=c),l!==void 0){let u=l.split("_"),d=DI(l,e[c]);l==="rootPath"&&d?.endsWith("/")&&(d=d.slice(0,-1));try{r.setIn([...u],d)}catch(f){ar.error(f)}}}n&&xF(r,n),MI(r,t);let s=r.toJSON();Ut=qu(s);let i=r.getIn(["rootPath"]),a=Qn.join(i,Is.HDB_CONFIG_FILE);if(an.createFileSync(a),r.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${r.errors}`);an.writeFileSync(a,String(r)),ar.trace(`Config file written to ${a}`)}o(Xre,"createConfigFile");function xF(e,t){let r;try{try{r=JSON.parse(t)}catch(n){if(!Rr.isObject(t))throw n;r=t}for(let n of r){let s=Object.keys(n)[0];if(n[s].hasOwnProperty(Vm.TABLES))for(let i in n[s][Vm.TABLES])for(let a in n[s][Vm.TABLES][i]){let c=n[s][Vm.TABLES][i][a],l=[jn.DATABASES,s,Vm.TABLES,i,a];e.hasIn(l)?e.setIn(l,c):e.addIn(l,c)}else for(let i in n[s]){let a=n[s][i],c=[jn.DATABASES,s,i];e.hasIn(c)?e.setIn(c,a):e.addIn(c,a)}}}catch(n){ar.error("Error parsing schemas CLI/env config arguments",n)}}o(xF,"setSchemasConfig");function Zre(e){if(ig===void 0){let r=Da(UF);ig=qu(r.toJSON())}let t=si[e.toLowerCase()];if(t!==void 0)return ig[t.toLowerCase()]}o(Zre,"getDefaultConfig");function BF(e){if(e==null){ar.info(jre);return}if(Ut===void 0){ar.trace(Yre);return}let t=si[e.toLowerCase()];if(t!==void 0)return Ut[t.toLowerCase()]}o(BF,"getConfigValue");function ul(e=Rr.getPropsFilePath()){let t=Rr.getEnvCliRootPath();if(t)return LI(Qn.join(t,Is.HDB_CONFIG_FILE));let r=MF(e);return LI(r.get(Is.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}o(ul,"getConfigFilePath");function ag(e=!1){if(Ut===void 0||e){let t;if(!Rr.noBootFile()){t=Rr.getPropsFilePath();try{an.accessSync(t,an.constants.F_OK|an.constants.R_OK)}catch(i){throw ar.error(i),new Error(`HarperDB properties file at path ${t} does not exist`)}}let r=ul(t),n;if(r.includes("config/settings.js"))try{HF(r);return}catch(i){if(i.code!==Is.NODE_ERROR_CODES.ENOENT)throw i}try{n=Da(r)}catch(i){if(i.code===Is.NODE_ERROR_CODES.ENOENT){ar.trace(`HarperDB config file not found at ${r}.
|
|
14
14
|
This can occur during early stages of install where the config file has not yet been created`);return}else throw ar.error(i),new Error(`Error reading HarperDB config file at ${r}`)}ene(n,r),MI(n);let s=n.toJSON();if(Kre.config=s,Ut=qu(s),Ut.logging_rotation_rotate)for(let i in LF)Ut[i]&&ar.error(`Config ${LF[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);ar.trace(Wre)}}o(ag,"initConfig");function ene(e,t){let r=e.getIn(["rootPath"]),n=!1;if(e.hasIn(["storage","path"])||(e.setIn(["storage","path"],Qn.join(r,"database")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],Qn.join(r,"log")),n=!0),e.hasIn(["authentication"])||(e.addIn(["authentication"],{cacheTTL:3e4,enableSessions:!0,operationTokenTimeout:e.getIn(["operationsApi","authentication","operationTokenTimeout"])??"1d",refreshTokenTimeout:e.getIn(["operationsApi","authentication","refreshTokenTimeout"])??"30d"}),n=!0),e.hasIn(["analytics"])||(e.addIn(["analytics"],{aggregatePeriod:60,replicate:!1}),n=!0),n){if(ar.trace("Updating config file with missing config params"),e.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${e.errors}`);an.writeFileSync(t,String(e))}}o(ene,"checkForUpdatedConfig");function MI(e,t=!1){let r=e.toJSON();if(r.componentsRoot=r.componentsRoot??r?.customFunctions?.root,r?.http?.threads&&(r.threads=r?.http?.threads),r.http?.port&&r.http?.port===r.http?.securePort)throw Gu.CONFIG_VALIDATION("http.port and http.securePort cannot be the same value");if(r.operationsApi?.network?.port&&r.operationsApi?.network?.port===r.operationsApi?.network?.securePort)throw Gu.CONFIG_VALIDATION("operationsApi.network.port and operationsApi.network.securePort cannot be the same value");let n=kre(r,t);if(n.error)throw Gu.CONFIG_VALIDATION(n.error.message);typeof n.value.threads=="object"?e.setIn(["threads","count"],n.value.threads.count):e.setIn(["threads"],n.value.threads),e.setIn(["componentsRoot"],n.value.componentsRoot),e.setIn(["logging","root"],n.value.logging.root),e.setIn(["storage","path"],n.value.storage.path),e.setIn(["logging","rotation","path"],n.value.logging.rotation.path),e.setIn(["operationsApi","network","domainSocket"],n.value?.operationsApi?.network?.domainSocket),r?.clustering?.enabled&&e.setIn(["clustering","leafServer","streams","path"],n.value.clustering.leafServer.streams?.path)}o(MI,"validateConfig");function tne(e,t){Ut===void 0&&(Ut={});let r=si[e.toLowerCase()];if(r===void 0){ar.trace(`Unable to update config object because config param '${e}' does not exist`);return}Ut[r.toLowerCase()]=t}o(tne,"updateConfigObject");function FF(e,t,r=void 0,n=!1,s=!1,i=!1){Ut===void 0&&ag();let a=BF(si.hdb_root),c=Qn.join(a,Is.HDB_CONFIG_FILE),l=Da(c),u;if(r&&Ut){let m=!1;for(let h in r)if(r[h]!=Ut[h.toLowerCase()]){m=!0;break}if(!m){ar.trace("No changes detected in config parameters, skipping update");return}}if(r===void 0&&e.toLowerCase()===jn.DATABASES)u=t;else if(r===void 0){let m;if(i)m=e;else if(m=si[e.toLowerCase()],m===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let h=m.split("_"),p=DI(m,t);l.setIn([...h],p)}else for(let m in r){let h=si[m.toLowerCase()];if(h===jn.HTTP_SECUREPORT&&r[m]===Ut[jn.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),h===jn.OPERATIONSAPI_NETWORK_SECUREPORT&&r[m]===Ut[jn.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&l.setIn(["operationsApi","network","port"],null),h===jn.DATABASES){u=r[m];continue}if(h?.startsWith("threads_")){let p=l.getIn(["threads"]);p>=0&&(l.deleteIn(["threads"]),l.setIn(["threads","count"],p))}if(!h&&(m.endsWith("_package")||m.endsWith("_port"))&&(h=m),h!==void 0){let p=h.split("_"),_=Is.LEGACY_CONFIG_PARAMS[m.toUpperCase()];_&&_.startsWith("customFunctions")&&l.hasIn(_.split("_"))&&(h=_,p=_.split("_"));let g=DI(h,r[m]);h==="rootPath"&&g?.endsWith("/")&&(g=g.slice(0,-1));try{p.length>1&&typeof l.getIn(p.slice(0,-1))=="boolean"&&l.deleteIn(p.slice(0,-1)),l.setIn([...p],g)}catch(y){ar.error(y)}}}u&&xF(l,u),MI(l);let d=l.getIn(["rootPath"]),f=Qn.join(d,Is.HDB_CONFIG_FILE);if(n===!0&&rne(c,d),l.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${l.errors}`);an.writeFileSync(f,String(l)),s&&(Ut=qu(l.toJSON())),ar.trace(`Config parameter: ${e} updated with value: ${t}`)}o(FF,"updateConfigValue");function rne(e,t){try{let r=Qn.join(t,"backup",`${new Date(Date.now()).toISOString().replaceAll(":","-")}-${Is.HDB_CONFIG_FILE}.bak`);an.copySync(e,r),ar.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){ar.error(zre),ar.error(r)}}o(rne,"backupConfigFile");var nne=["databases"];function qu(e){return e.http&&Object.assign(e.http,e?.customFunctions?.network),e?.operationsApi?.network&&(e.operationsApi.network={...e.http,...e.operationsApi.network}),e?.operationsApi&&(e.operationsApi.tls={...e.tls,...e.operationsApi.tls}),og=e,r(e);function r(n){let s={};for(let i in n)if(n.hasOwnProperty(i)){if(typeof n[i]=="object"&&n[i]!==null&&!Array.isArray(n[i])&&!nne.includes(i)){let a=r(n[i]);for(let c in a){if(!a.hasOwnProperty(c))continue;c!=="package"&&(i=i.toLowerCase());let l=i+"_"+c;!jn[l.toUpperCase()]&&si[l]&&(s[si[l].toLowerCase()]=a[c]),s[l]=a[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}o(r,"squashObj")}o(qu,"flattenConfig");function DI(e,t){if(e===jn.CLUSTERING_NODENAME||e===jn.CLUSTERING_USER){if(t==null)return t;if(!isNaN(t))return t.toString();if(typeof t=="string"&&t.toLowerCase()==="true"||typeof t=="string"&&t.toLowerCase()==="false")return t}else{if(Gre(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||Rr.isObject(t)||t===null)return t;if(typeof t=="string"&&t.toLowerCase()==="true")return!0;if(typeof t=="string"&&t.toLowerCase()==="false")return!1}if(t===void 0||t.toLowerCase()==="undefined")return null;if(typeof t=="string"&&(t.startsWith("{")&&t.endsWith("}")||t.startsWith("[")&&t.endsWith("]")))try{return JSON.parse(t)}catch{}return Rr.autoCast(t)}o(DI,"castConfigValue");function sne(){let e=Rr.getPropsFilePath(),t=ul(e);return Da(t).toJSON()}o(sne,"getConfiguration");async function ine(e){let{operation:t,hdb_user:r,hdbAuthHeader:n,...s}=e;try{return FF(void 0,void 0,s,!0),Jre}catch(i){throw typeof i=="string"||i instanceof String?$re(i,i,Vre.BAD_REQUEST,void 0,void 0,!0):i}}o(ine,"setConfiguration");function vI(){let e=Rr.getPropsFilePath();try{an.accessSync(e,an.constants.F_OK|an.constants.R_OK)}catch(n){if(!Rr.noBootFile())throw ar.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=ul(e);return Da(t).toJSON()}o(vI,"readConfigFile");function Da(e){return DF.parseDocument(an.readFileSync(e,"utf8"),{simpleKeys:!0})}o(Da,"parseYamlDoc");function one(){let e=vI(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=Rr.isEmptyOrZeroLength(t)?[]:t;let r=PF(t);if(r)throw Gu.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=Rr.isEmptyOrZeroLength(n)?[]:n;let s=PF(n);if(s)throw Gu.CONFIG_VALIDATION(s.message);if(!Rr.isEmptyOrZeroLength(n)&&!Rr.isEmptyOrZeroLength(t)){let i=t.filter(a=>n.some(c=>c.host===a.host&&c.port===a.port));if(!Rr.isEmptyOrZeroLength(i)){let a=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw Gu.CONFIG_VALIDATION(a)}}return{hub_routes:t,leaf_routes:n}}o(one,"getClusteringRoutes");function HF(e){let t=MF(e);Ut={};for(let r in si){let n=t.get(r.toUpperCase());if(Rr.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=si[r].toLowerCase();s===jn.LOGGING_ROOT?Ut[s]=Qn.dirname(n):Ut[s]=n}return Ut}o(HF,"initOldConfig");function ane(e){let t=vI();return qre.get(t,e.replaceAll("_","."))}o(ane,"getConfigFromFile");async function cne(e,t){let r=Da(ul());if(r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),r.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${r.errors}`);await an.writeFile(ul(),String(r))}o(cne,"addConfig");function lne(e){let t=ul(Rr.getPropsFilePath()),r=Da(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=Qn.join(n,Is.HDB_CONFIG_FILE);an.writeFileSync(s,String(r))}o(lne,"deleteConfigFromFile");function une(){return og||(ag(),og)}o(une,"getConfigObj");function dne(){return Ut||ag(),Ut}o(dne,"getFlatConfigObj")});var Jn=M((pPe,vr)=>{"use strict";var qF="username is required",$F="nothing to update, must supply active, role or password to update",VF="password cannot be an empty string",KF="If role is specified, it cannot be empty.",YF="active must be true or false";vr.exports.addUser=Tne;vr.exports.alterUser=Rne;vr.exports.dropUser=Ane;vr.exports.getSuperUser=One;vr.exports.userInfo=bne;vr.exports.listUsers=lg;vr.exports.listUsersExternal=Ine;vr.exports.setUsersWithRolesCache=dl;vr.exports.findAndValidateUser=$I;vr.exports.getClusterUser=Cne;vr.exports.getUsersWithRolesCache=wne;vr.exports.USERNAME_REQUIRED=qF;vr.exports.ALTERUSER_NOTHING_TO_UPDATE=$F;vr.exports.EMPTY_PASSWORD=VF;vr.exports.EMPTY_ROLE=KF;vr.exports.ACTIVE_BOOLEAN=YF;var WF=Dn(),fne=cl(),Km=(ng(),v(rg)),zF=RF(),Ym=nn(),HI=Ao(),Bi=ie(),jF=require("validate.js"),kI=z(),{promisify:mne}=require("util"),GI=Ui(),xI=(k(),v(K)),kF=bt(),hne=At(),pne=ce(),Ene=To(),{hdbErrors:_ne,ClientError:ii}=Ee(),{HTTP_STATUS_CODES:wo,AUTHENTICATION_ERROR_MSGS:UI,HDB_ERROR_MSGS:$u}=_ne,{UserEventMsg:qI}=ei(),BI=require("lodash"),{server:cg}=(Pr(),v(Df)),gne=z();cg.getUser=(e,t)=>$I(e,t,t!=null);cg.authenticateUser=(e,t)=>$I(e,t);var QF={username:!0,active:!0,role:!0,password:!0},GF=new Map,Sne=mne(fne.delete),FI=pne.get(xI.CONFIG_PARAMS.AUTHENTICATION_HASHFUNCTION)??Km.HASH_FUNCTION.SHA256,Fi;async function Tne(e){let t=jF.cleanAttributes(e,QF),r=zF.addUserValidation(t);if(r)throw new ii(r.message);let n=await Ym.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($u.ROLE_NAME_NOT_FOUND(t.role),wo.NOT_FOUND);if(n.length>1)throw new ii($u.DUP_ROLES_FOUND(t.role),wo.CONFLICT);n[0].permission.cluster_user===!0&&(t.hash=GI.encrypt(t.password)),t.password=await Km.hash(t.password,FI),t.hash_function=FI,t.role=n[0].id;let s=await WF.insert({operation:"insert",schema:"system",table:"hdb_user",records:[t]});if(kI.debug(s),await dl(),s.skipped_hashes.length===1)throw new ii($u.USER_ALREADY_EXISTS(t.username),wo.CONFLICT);return HI.signalUserChange(new qI(process.pid)),`${t.username} successfully added`}o(Tne,"addUser");async function Rne(e){let t=jF.cleanAttributes(e,QF);if(Bi.isEmptyOrZeroLength(t.username))throw new Error(qF);if(Bi.isEmptyOrZeroLength(t.password)&&Bi.isEmptyOrZeroLength(t.role)&&Bi.isEmptyOrZeroLength(t.active))throw new Error($F);if(!Bi.isEmpty(t.password)&&Bi.isEmptyOrZeroLength(t.password.trim()))throw new Error(VF);if(!Bi.isEmpty(t.active)&&!Bi.isBoolean(t.active))throw new Error(YF);if(!Bi.isEmpty(t.password)&&!Bi.isEmptyOrZeroLength(t.password.trim())&&(yne(t.username)&&(t.hash=GI.encrypt(t.password)),t.password=await Km.hash(t.password,FI)),t.role==="")throw new Error(KF);if(t.role){let n=await Ym.searchByValue({schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]});if(!n||n.length===0)throw new ii($u.ALTER_USER_ROLE_NOT_FOUND(t.role),wo.NOT_FOUND);if(n.length>1)throw new ii($u.DUP_ROLES_FOUND(t.role),wo.CONFLICT);t.role=n[0].id}let r=await WF.update({operation:"update",schema:"system",table:"hdb_user",records:[t]});return await dl(),HI.signalUserChange(new qI(process.pid)),r}o(Rne,"alterUser");function yne(e){let t=!1,r=Fi.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}o(yne,"isClusterUser");async function Ane(e){let t=zF.dropUserValidation(e);if(t)throw new ii(t.message);if(Fi.get(e.username)===void 0)throw new ii($u.USER_NOT_EXIST(e.username),wo.NOT_FOUND);let r=await Sne({table:"hdb_user",schema:"system",hash_values:[e.username]});return kI.debug(r),await dl(),HI.signalUserChange(new qI(process.pid)),`${e.username} successfully deleted`}o(Ane,"dropUser");async function bne(e){let t={};if(!e||!e.hdb_user)return"There was no user info in the body";t=BI.cloneDeep(e.hdb_user);let r=await Ym.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(bne,"userInfo");async function Ine(){let e=await lg();return e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token,delete t.hash_function}),[...e.values()]}o(Ine,"listUsersExternal");async function lg(){let e=await Ym.searchByValue({schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]}),t={};for(let s of e)t[s.id]=BI.cloneDeep(s);if(Object.keys(t).length===0)return null;let r=await Ym.searchByValue({schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]}),n=new Map;for(let s of r)s=BI.cloneDeep(s),s.role=t[s.role],Nne(s.role),n.set(s.username,s);return n}o(lg,"listUsers");function Nne(e){if(!e){kI.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(Ene)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}o(Nne,"appendSystemTablesToRole");async function dl(e=void 0){e?Fi=e:Fi=await lg()}o(dl,"setUsersWithRolesCache");async function wne(){return Fi||await dl(),Fi}o(wne,"getUsersWithRolesCache");async function $I(e,t,r=!0){Fi||await dl();let n=Fi.get(e);if(!n){if(!r)return{username:e};throw new ii(UI.GENERIC_AUTH_FAIL,wo.UNAUTHORIZED)}if(n&&!n.active)throw new ii(UI.USER_INACTIVE,wo.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(GF.get(t)===n.password)return s;{let i=Km.validate(n.password,t,n.hash_function||Km.HASH_FUNCTION.MD5);if(i?.then&&(i=await i),i===!0)GF.set(t,n.password);else throw new ii(UI.GENERIC_AUTH_FAIL,wo.UNAUTHORIZED)}}return s}o($I,"findAndValidateUser");async function One(){Fi||await dl();for(let[,e]of Fi)if(e.role.role==="super_user")return e}o(One,"getSuperUser");async function Cne(){let e=await lg(),t=hne.getConfigFromFile(xI.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!(r==null||r?.role?.role!==xI.ROLE_TYPES_ENUM.CLUSTER_USER))return r.decrypt_hash=GI.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+kF.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+kF.SERVER_SUFFIX.ADMIN,r}o(Cne,"getClusterUser");var JF=[];cg.invalidateUser=function(e){for(let t of JF)try{t(e)}catch(r){gne.error("Error invalidating user",r)}};cg.onInvalidatedUser=function(e){JF.push(e)}});var zm=M((SPe,tH)=>{"use strict";var fl=z(),Xn=(k(),v(K)),Pne=AU(),_Pe=Zs(),gPe=Oa(),Lne=Jn(),{validateEvent:XF}=ei(),Wm=Wn(),Dne=require("process"),{resetDatabases:Mne}=(Le(),v(ft)),vne={[Xn.ITC_EVENT_TYPES.SCHEMA]:Une,[Xn.ITC_EVENT_TYPES.USER]:eH};async function Une(e){let t=XF(e);if(t){fl.error(t);return}fl.trace("ITC schemaHandler received schema event:",e),await Pne(e.message),await xne(e.message)}o(Une,"schemaHandler");async function xne(e){try{Wm.resetReadTxn(Xn.SYSTEM_SCHEMA_NAME,Xn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),Wm.resetReadTxn(Xn.SYSTEM_SCHEMA_NAME,Xn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),Wm.resetReadTxn(Xn.SYSTEM_SCHEMA_NAME,Xn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=Mne();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){fl.error(t)}}o(xne,"syncSchemaMetadata");var ZF=[];async function eH(e){try{try{Wm.resetReadTxn(Xn.SYSTEM_SCHEMA_NAME,Xn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),Wm.resetReadTxn(Xn.SYSTEM_SCHEMA_NAME,Xn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){fl.warn(r)}let t=XF(e);if(t){fl.error(t);return}fl.trace(`ITC userHandler ${Xn.HDB_ITC_CLIENT_PREFIX}${Dne.pid} received user event:`,e),await Lne.setUsersWithRolesCache();for(let r of ZF)r()}catch(t){fl.error(t)}}o(eH,"userHandler");eH.addListener=function(e){ZF.push(e)};tH.exports=vne});var ei=M((IPe,nH)=>{"use strict";var RPe=z(),VI=ie(),Bne=(k(),v(K)),{ITC_ERRORS:jm}=en(),{parentPort:yPe,threadId:Fne,isMainThread:Hne,workerData:APe}=require("worker_threads"),{onMessageFromWorkers:kne,broadcast:bPe,broadcastWithAcknowledgement:Gne}=st();nH.exports={sendItcEvent:qne,validateEvent:rH,SchemaEventMsg:$ne,UserEventMsg:Vne};var ug;kne(async(e,t)=>{ug=ug||zm(),rH(e),ug[e.type]&&await ug[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function qne(e){return!Hne&&e.message&&(e.message.originator=Fne),Gne(e)}o(qne,"sendItcEvent");function rH(e){if(typeof e!="object")return jm.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||VI.isEmpty(e.type))return jm.MISSING_TYPE;if(!e.hasOwnProperty("message")||VI.isEmpty(e.message))return jm.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||VI.isEmpty(e.message.originator))return jm.MISSING_ORIGIN;if(Bne.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return jm.INVALID_EVENT(e.type)}o(rH,"validateEvent");function $ne(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($ne,"SchemaEventMsg");function Vne(e){this.originator=e}o(Vne,"UserEventMsg")});var Ao=M((OPe,aH)=>{"use strict";var sH=(k(),v(K)),wPe=ie(),dg=z(),iH=iU(),Vu,{sendItcEvent:oH}=ei();function Kne(e){try{dg.info("signalSchemaChange called with message:",e),Vu=Vu||zm();let t=new iH(sH.ITC_EVENT_TYPES.SCHEMA,e);return Vu.schema(t),oH(t)}catch(t){dg.error(t)}}o(Kne,"signalSchemaChange");function Yne(e){try{dg.trace("signalUserChange called with message:",e),Vu=Vu||zm();let t=new iH(sH.ITC_EVENT_TYPES.USER,e);return Vu.user(t),oH(t)}catch(t){dg.error(t)}}o(Yne,"signalUserChange");aH.exports={signalSchemaChange:Kne,signalUserChange:Yne}});function fg(){return KI||(KI=et({table:"hdb_analytics_hostname",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"hostname"}]})),KI}function zne(e){return e=e.replace(Wne,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 jne(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 WI(e){let t=cH.default.createHash("shake128",{outputLength:4}),r;return(0,lH.isIPv6)(e)?r=zne(e):r=e.toLowerCase(),jne(Uint8Array.from(t.update(r).digest()))}var cH,lH,YI,KI,Wne,zI=fe(()=>{Le();cH=w(require("crypto")),lH=require("node:net"),YI=new Map;o(fg,"getAnalyticsHostnameTable");Wne=/(\d{1,3}\.){3}\d{1,3}$/;o(zne,"normalizeIPv6");o(jne,"nodeHashToNumber");o(WI,"stableNodeId")});var Oo,jI=fe(()=>{Oo={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 _g={};Ce(_g,{addAnalyticsListener:()=>Xm,calculateCPUUtilization:()=>NH,diffResourceUsage:()=>wH,recordAction:()=>gt,recordActionBinary:()=>Kr,recordHostname:()=>XI,setAnalyticsEnabled:()=>Qne});function Qne(e){RH=e}function Jne(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 Xne(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},pg.set(e,a)}function gt(e,t,r,n,s){if(!RH)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let a=pg.get(i);a?Jne(e,a):Xne(i,e,t,r,n,s),hg||Zne()}function Kr(e,t,r,n,s){gt(!!e,t,r,n,s)}function Xm(e){bH.push(e)}function Zne(){hg=performance.now(),setTimeout(async()=>{let e=performance.now()-hg;hg=0;let t=[],r={time:Date.now(),period:e,threadId:ml.threadId,metrics:t};for(let[s,i]of pg){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 IH){let m=Math.floor(c*f),h=a[m-1];if(m>l){let p=m-l;if(h===d){let _=u[u.length-1];typeof _=="number"?u[u.length-1]={value:_,count:1+p}:_.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 OH()}let n=process.memoryUsage();t.push({metric:"memory",threadId:ml.threadId,byThread:!0,...n});for(let s of bH)s(t);pg=new Map,ml.parentPort?ml.parentPort.postMessage({type:AH,report:r}):LH({report:r})},yH).unref()}async function XI(){let e=ve.hostname;Vr.trace?.("recordHostname server.hostname:",e);let t=WI(e);Vr.trace?.("recordHostname nodeId:",t);let r=fg();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 Ku(e,t){let r=ve.hostname,n=YI.get(r);n?Vr.trace?.("storeMetric cached nodeId:",n):(n=WI(r),Vr.trace?.("storeMetric new nodeId:",n),YI.set(r,n));let s={id:[(0,JI.getNextMonotonicTime)(),n],...t};Vr.trace?.(`storing metric ${JSON.stringify(s)}`),e.put(s.id,s)}function NH(e,t){let r=e.userCPUTime+e.systemCPUTime;return Vr.trace?.(`calculateCPUUtilization cpuTime: ${r} period: ${t}`),Math.round(r/t*100)/100}function wH(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 ese(e,t,r){let n=0;for(let[s,i]of Object.entries(r)){let a=`${t}.${s}`,c=i.getSize(),l={metric:Oo.TABLE_SIZE,database:t,table:s,size:c};Vr.trace?.(`table ${a} size metric: ${JSON.stringify(l)}`),Ku(e,l),n+=c}return n}function uH(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s?.getAuditSize();if(!i)return;let a=TH.statSync(s.primaryStore.env.path).size,c=ese(e,r,n),l=a-c,u={metric:Oo.DATABASE_SIZE,database:r,size:a,used:c,free:l,audit:i};Ku(e,u),Vr.trace?.(`database ${r} size metric: ${JSON.stringify(u)}`)}catch(s){Vr.warn?.("Error getting DB size metrics",s)}}function dH(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:Oo.STORAGE_VOLUME,database:r,...i};Ku(e,a),Vr.trace?.(`db ${r} storage volume metrics: ${JSON.stringify(a)}`)}catch(s){Vr.warn?.("Error getting DB volume metrics",s)}}async function tse(e,t=6e4){let r=ZI(),n=CH(),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:_e,...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 _r=He.count;for(let pt in Ne){let gr=Ne[pt];typeof gr=="number"&&(He[pt]=(He[pt]*_r+gr*le)/(_r+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 _r=l.get(Fe);_r?_r.push(...se):l.set(Fe,se)}}await OH()}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 _e of V){let Ne=_e[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 IH){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,_e,Ne,Fe,He,_r]=te;Object.assign(P,{p1:V,p10:le,p25:re,median:se,p75:_e,p90:Ne,p95:Fe,p99:He,p999:_r})}let f;for(let[,R]of c)R.time=d,Ku(n,R),f=!0;let m=Date.now(),{idle:h,active:p}=performance.eventLoopUtilization();if(f||p*10>h){let R={metric:Oo.MAIN_THREAD_UTILIZATION,idle:h-fH,active:p-mH,taskQueueLatency:await s,time:m,...process.memoryUsage()};Ku(n,R)}fH=h,mH=p;let _=process.resourceUsage();_.time=m,_.userCPUTime=_.userCPUTime/1e3,_.systemCPUTime=_.systemCPUTime/1e3,Vr.trace?.(`process.resourceUsage: ${JSON.stringify(_)}`);let g=wH(mg,_);Vr.trace?.(`diffed resourceUsage: ${JSON.stringify(g)}`),g.time=m,g.period=mg.time?m-mg.time:t,g.cpuUtilization=NH(g,g.period);let y={metric:Oo.RESOURCE_USAGE,...g};Ku(n,y),mg=_;let T=it();uH(n,T),uH(n,{system:T.system}),dH(n,T),dH(n,{system:T.system})}async function hH(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function ZI(){return pH||(pH=et({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function CH(){return EH||(EH=et({table:"hdb_analytics",database:"system",audit:!0,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function sse(){PH=!0;let e=(0,Jm.get)(U.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await tse(yH,e),await hH(ZI(),rse),await hH(CH(),nse)},Math.min(e/2,2147483647)).unref()}function LH(e,t){let r=e.report;r.threadId=t?.threadId||ml.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(_H+=n.mean*n.count);r.totalBytesProcessed=_H,t&&(r.metrics.push({metric:Oo.UTILIZATION,...t.performance.eventLoopUtilization(gH.get(t))}),gH.set(t,t.performance.eventLoopUtilization())),r.id=(0,JI.getNextMonotonicTime)(),ZI().primaryStore.put(r.id,r),PH||sse(),ise&&(DH=ase(r))}async function ase(e){if(await DH,!Ma){let r=(0,Qm.dirname)((0,Eg.getLogFilePath)());try{Ma=await(0,QI.open)((0,Qm.join)(r,"analytics.log"),"r+")}catch{Ma=await(0,QI.open)((0,Qm.join)(r,"analytics.log"),"w+")}}let t=(await Ma.stat()).size;if(t>ose){let r=Buffer.alloc(t);await Ma.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await Ma.write(r,{position:0}),await Ma.truncate(r.length),t=r.length}await Ma.write(JSON.stringify(e)+`
|