harperdb 4.6.1 → 4.6.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/bin/harperdb.js +2 -2
- package/bin/lite.js +1 -1
- package/launchServiceScripts/launchNatsIngestService.js +1 -1
- package/launchServiceScripts/launchNatsReplyService.js +1 -1
- package/launchServiceScripts/launchUpdateNodes4-0-0.js +1 -1
- package/npm-shrinkwrap.json +26 -26
- package/package.json +1 -1
- package/server/jobs/jobProcess.js +1 -1
- package/server/threads/threadServer.js +1 -1
- package/studio/build-local/asset-manifest.json +2 -2
- package/studio/build-local/index.html +1 -1
- package/studio/build-local/static/js/{main.1faf79b7.js → main.447848b8.js} +2 -2
- package/utility/scripts/restartHdb.js +1 -1
- /package/studio/build-local/static/js/{main.1faf79b7.js.LICENSE.txt → main.447848b8.js.LICENSE.txt} +0 -0
|
@@ -10,7 +10,7 @@
|
|
|
10
10
|
|
|
11
11
|
`:`data: ${e}
|
|
12
12
|
|
|
13
|
-
`},"serialize"),compressible:!1,q:.8});nn.set("application/x-www-form-urlencoded",{deserialize(e){let t=Buffer.isBuffer(e)?e.toString("utf8"):e,r={};for(let[n,s]of new URLSearchParams(t))if(r.hasOwnProperty(n)){let i=r[n];Array.isArray(i)?i.push(s):r.key=[i,s]}else r[n]=s;return r},serialize(e){let t=new URLSearchParams;for(let r in e)t.set(r,e);return t.toString()}});Nv={type:"application/json",serializeStream:Xf,serialize:Zf,deserialize:zZ,q:.5};nn.set("*/*",Nv);nn.set("",Nv);o(zZ,"tryJSONParse");o(tm,"registerContentHandlers");jZ=(0,bv.default)(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:a,type:c}=YE(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(YE,"findBestSerializer");Sv=cA.default.get(U.HTTP_COMPRESSIONTHRESHOLD);o(rm,"serialize");o(ga,"serializeMessage");o(fA,"asyncSerialization");o(mA,"hasAsyncSerialization");o(QZ,"streamToBuffer");JZ=["ascii","utf8","utf-8","utf16le","utf-16le","ucs2","ucs-2","base64","base64url","latin1","binary","hex"];o(XZ,"isBufferEncoding");o(ZZ,"parseContentType");o(ho,"getDeserializer");o(e6,"deserializerUnknownType");o(t6,"transformIterable");o(KE,"toCsvStream")});var gA={};Ce(gA,{Blob:()=>Ss,blobsWereEncoded:()=>kc,databasePaths:()=>pA,decodeBlobsWithWrites:()=>t_,decodeFromDatabase:()=>Gc,decodeWithBlobCallback:()=>r_,deleteBlob:()=>XE,deleteBlobsInObject:()=>Sa,deleteRootBlobPathsForDB:()=>_A,encodeBlobsAsBuffers:()=>d6,encodeBlobsWithFilePath:()=>e_,findBlobsInObject:()=>_u,getFileId:()=>ZE,getFilePathForBlob:()=>Bv,getRootBlobPathsForDB:()=>om,setDeletionDelay:()=>i6});function vv(){}function XE(e){let t=Bv(e);t&&setTimeout(()=>{(0,Ze.unlink)(t,r=>{r&&Eo.default.debug?.("Error trying to remove blob file",r)})},Uv)}function i6(e){Uv=e}function xv(e){let t=bn.get(e);if(!t)t={storageIndex:0,fileId:null,store:In},bn.set(e,t);else{if(t.saving)return t;t.store=In}return a6(t),t.source?hA(e,t.source,t):t.contentBuffer?o6(e,t):hA(e,sm.Readable.from(e.stream()),t),t}function hA(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(n6),h=(0,QE.createDeflate)(),t.pipe(h).pipe(f)):(m||f.write(r6),t.pipe(f)),t.on("error",_);function p(g){let y=BigInt(g),T=new Uint8Array(Rr),R=new DataView(T.buffer);return y|=BigInt(a?EA:Mv)<<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-Rr;e.size=g,(0,Ze.write)(f.fd,p(g),0,Rr,0,_)}})}),e}function ZE(e){return bn.get(e)?.fileId}function Bv(e){let t=bn.get(e);return t?.fileId&&im(t)}function om(e){if(!e)throw new Error("No store specified, can not determine blob storage path");let t=pA.get(e);if(!t){if(!e.databaseName)return Eo.default.warn?.("No database name specified, can not determine blob storage path"),[];let r=(0,JE.get)(U.STORAGE_BLOBPATHS);r?t=r.map(n=>(0,go.join)(n,e.databaseName)):t=[(0,go.join)((0,JE.getHdbBasePath)(),"blobs",e.databaseName)],pA.set(e,t)}return t}async function _A(e){let t=om(e);t&&await Promise.all(t.map(r=>Fv(r)))}async function Fv(e){if((0,Ze.existsSync)(e)){for(let t of await(0,js.readdir)(e,{withFileTypes:!0}))if(t.isDirectory())await Fv((0,go.join)(e,t.name));else try{await(0,js.unlink)((0,go.join)(e,t.name))}catch(r){Eo.default.warn?.("Error deleting file",r)}try{await(0,js.rmdir)(e)}catch(t){Eo.default.warn?.("Error deleting directory",t)}}}function im({storageIndex:e,fileId:t,store:r}){let n=om(r);return(0,go.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 o6(e,t){let r=t.contentBuffer,n=r.length;if(!(n<Dv))return e.size=n,hA(e,sm.Readable.from([r]),t)}function a6(e){let t=om(e.store),r=c6(),n=t?.length>1?l6(t,r):0,s=r.toString(16);e.storageIndex=n,e.fileId=s;let i=im(e),a=(0,go.dirname)(i);(0,Ze.existsSync)(a)||(0,Lv.ensureDirSync)(a),e.filePath=i}function c6(){let e=Pv.get(In);if(!e){let t=0,r=om(In);for(let n of r){let s=0;for(let i=0;i<3;i++){s=s*4096;let a=0;if((0,Ze.existsSync)(n))for(let c of(0,Ze.readdirSync)(n)){let l=parseInt(c,16);i===2&&c.length>3&&(l=parseInt(c.slice(-3),16),l+=parseInt(c.slice(0,-3),16)*68719476736),l>a&&(a=l)}s+=a,n=(0,go.join)(n,a.toString(16))}t=Math.max(t,s)}e=new BigInt64Array([BigInt(t)+1n]),e=new BigInt64Array(In.getUserSharedBuffer("blob-file-id",e.buffer)),Pv.set(In,e)}return Number(Atomics.add(e,0,1n))}function l6(e,t){let r=Date.now();if(!e.frequencyTable){e.lastUpdated=0;let s=new Array(jE);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,u6(e)),e.frequencyTable[t%jE]}async function u6(e){if(!js.statfs)return;let t=await Promise.all(e.map(async(s,i)=>{let a=await(0,js.statfs)(s),c=a.bavail*a.bsize;return Math.pow(c,.8)})),r=new Array(jE),n=t.map(s=>1/s);for(let s=0;s<jE;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 e_(e,t,r){Eu=t,In=r,kc=!1;try{return e()}finally{Eu=void 0,In=void 0}}function d6(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 t_(e,t){try{Gr=[],Hc=t,e()}catch(n){throw Hc=void 0,Gr=void 0,n}Hc=void 0;let r=Gr.length<2?Gr[0]:Promise.all(Gr);return Gr=void 0,r}function r_(e,t,r){In=r;try{return Hc=t,e()}finally{Hc=void 0}}function Gc(e,t){return In=t,e()}function Sa(e){_u(e,t=>{XE(t)})}function _u(e,t){if(e instanceof Ss)t(e);else if(Array.isArray(e))for(let r of e)typeof r=="object"&&r&&_u(r,t);else if(e&&typeof e=="object"&&!e[Symbol.iterator])for(let r in e){let n=e[r];typeof n=="object"&&n&&_u(e[r],t)}}function f6(){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 _o,js,Ze,QE,sm,Lv,JE,go,Eo,Dv,Rr,Mv,EA,Ov,r6,n6,Cv,bn,Hc,Ss,Eu,Gr,In,kc,nm,WE,s6,zE,Uv,pA,Pv,jE,Ts=fe(()=>{_o=require("msgpackr"),js=require("node:fs/promises"),Ze=require("node:fs"),QE=require("node:zlib"),sm=require("node:stream"),Lv=require("fs-extra"),JE=w(ce());k();go=require("path"),Eo=w(Ni());po();Dv=8192,Rr=8,Mv=0,EA=1,Ov=255,r6=new Uint8Array([0,Mv,255,255,255,255,255,255]),n6=new Uint8Array([0,EA,255,255,255,255,255,255]),Cv=0xffffffffffff,bn=new WeakMap,Ss=global.Blob||f6(),kc=!1,nm=new Uint8Array(8),WE=new DataView(nm.buffer),s6=6e4;o(vv,"InstanceOfBlobWithNoConstructor");vv.prototype=Ss.prototype;zE=class e extends vv{static{o(this,"FileBackedBlob")}type="";size;#e;#t;constructor(t){super(),t?.type&&(this.type=t.type),t?.size!=null&&(this.size=t.size)}on(t,r){if(t==="error")this.#e??=[],this.#e.push(r);else if(t==="size")this.#t??=[],this.#t.push(r);else throw new Error("Only 'error' and 'size' events are supported")}toJSON(){if(this.type?.startsWith("text")){let t=bn.get(this),{start:r,end:n,contentBuffer:s,asString:i}=t;return i||(s&&(n!==void 0||r!==void 0)&&(s=s.subarray(r??0,n??t.contentBuffer.length)),s?(t.asString=s.toString(),t.asString):(mA()&&fA(this.bytes().then(a=>t.contentBuffer=a)),`[blob: ${this.type}, ${this.size} bytes]`))}return{description:"Blobs that are not of type text/* can not be directly serialized as JSON, use as the body of a response or convert to another type"}}async text(){return(await this.bytes()).toString()}bytes(){let t=bn.get(this),{start:r,end:n,contentBuffer:s}=t;if(s)return(n!==void 0||r!==void 0)&&(s=s.subarray(r??0,n??t.contentBuffer.length)),Promise.resolve(s);let i=im(t),a,c=o(async()=>{let l,u=Rr;try{if(l=await(0,js.readFile)(i),l.length>=Rr){l.copy(nm,0,0,Rr);let f=WE.getBigUint64(0);if(Number(f>>48n)===Ov)throw new Error("Error in blob: "+buffer.subarray(Rr));if(u=Number(f&0xffffffffffffn),u<n&&(u=n),u<Cv&&(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]===EA?new Promise((f,m)=>{(0,QE.deflate)(l.subarray(Rr),(h,p)=>{h?m(h):f(d(p))})}):d(l.subarray(Rr))},"readContents");return c()}async arrayBuffer(){let t=await this.bytes(),r=new ArrayBuffer(t.length);return new Uint8Array(r).set(t),r}stream(){let t=bn.get(this),{contentBuffer:r,start:n,end:s}=t;if(r)return(s!=null||n!=null)&&(r=r.subarray(n??0,s??t.contentBuffer.length)),new ReadableStream({pull(_){_.enqueue(r),_.close()}});let i=im(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&&(Eo.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<Rr){y-- >0&&f!==!1?(p(),Eo.default.debug?.("File was empty, waiting for data to be written",i,y),setTimeout(()=>T(R,I),20).unref()):(Eo.default.debug?.("File was empty, throwing error",i,y),I(new Error(`Blob ${t.fileId} was empty`)));return}$.copy(nm,0,0,Rr);let j=WE.getBigUint64(0);if(Number(j>>48n)===Ov)return P(new Error("Error in blob: "+$.subarray(Rr)));if(g=Number(j&0xffffffffffffn),g<Cv&&h.size!==g&&(h.size=g,h.#t))for(let V of h.#t)V(g);$=$.subarray(Rr,x),l-=Rr}else if(x===0){let j=Buffer.allocUnsafe(8);return(0,Ze.read)(a,j,0,Rr,0,V=>{if(V)return P(V);if(nm.set(j),g=Number(WE.getBigUint64(0)&0xffffffffffffn),g>l){p()?u?d=setTimeout(()=>{P(new Error("File read timed out"))},s6).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 Eo.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=bn.get(this),i=new e(n&&{type:n});if(s?.fileId){let a={...s,start:t,end:r};bn.set(i,a),this.size!=null&&(i.size=(r==null?this.size:Math.min(r,this.size))-(t??0))}else if(s?.contentBuffer&&!s.storageBuffer){let a={...s,contentBuffer:s.contentBuffer.subarray(t,r)};bn.set(i,a),i.size=(r??this.size)-t}else throw new Error("Can not slice a streaming blob that is not backed by a file");return i}save(t){if(In=t?.primaryStore?.rootStore,!In)throw new Error("No target table specified");return xv(this).saving??Promise.resolve()}},Uv=500;o(XE,"deleteBlob");o(i6,"setDeletionDelay");global.createBlob=function(e,t){let r=new zE(t),n={storageIndex:0,fileId:null,flush:t?.flush,compress:t?.compress};if(bn.set(r,n),e instanceof Uint8Array)r.size=e.length,n.contentBuffer=e;else if(e instanceof sm.Readable)n.source=e;else if(typeof e=="string")n.contentBuffer=Buffer.from(e);else if(e?.[Symbol.asyncIterator]||e?.[Symbol.iterator])n.source=sm.Readable.from(e);else throw new Error("Invalid source type");return r};o(xv,"saveBlob");o(hA,"writeBlobWithStream");o(ZE,"getFileId");o(Bv,"getFilePathForBlob");pA=new Map;o(om,"getRootBlobPathsForDB");o(_A,"deleteRootBlobPathsForDB");o(Fv,"rimrafSteadily");o(im,"getFilePath");o(o6,"writeBlobWithBuffer");o(a6,"generateFilePath");Pv=new Map;o(c6,"getNextFileId");jE=128;o(l6,"getNextStorageIndex");o(u6,"createFrequencyTableForStoragePaths");o(e_,"encodeBlobsWithFilePath");o(d6,"encodeBlobsAsBuffers");o(t_,"decodeBlobsWithWrites");o(r_,"decodeWithBlobCallback");o(Gc,"decodeFromDatabase");o(Sa,"deleteBlobsInObject");o(_u,"findBlobsInObject");(0,_o.addExtension)({Class:Ss,type:11,unpack:o(function(e){let t=(0,_o.unpack)(e),r=new zE;if(Object.assign(r,t[0]),typeof t[1]!="object"){if(bn.set(r,{storageIndex:t[1],fileId:t[2],store:In}),Hc)return Hc(r)??r;if(!In)throw new Error("No store specified, cannot load blob from storage")}else bn.set(r,{storageIndex:0,fileId:null,storageBuffer:e,contentBuffer:t[1]}),r.size=t[1]?.length;return r},"unpack"),pack:o(function(e){let t=bn.get(e);if(Eu!==void 0&&(kc=!0,t?.recordId!==void 0&&t.recordId!==Eu))throw new Error("Cannot use the same blob in two different records");let r={...e};if(e.type&&(r.type=e.type),e.size!==void 0&&(r.size=e.size),t){if(t.storageBuffer)return t.storageBuffer;if(t.contentBuffer?.length<Dv)return r.size=t.contentBuffer.length,(0,_o.pack)([r,t.contentBuffer])}if(Eu!==void 0){if(t=xv(e),!t.fileId)throw new Error("Unable to save blob without file id");return t.recordId=Eu,(0,_o.pack)([r,t.storageIndex,t.fileId])}if(t)try{let n=(0,Ze.readFileSync)(im(t));if(n.length>=Rr&&(n.copy(nm,0,0,Rr),Number(WE.getBigUint64(0)&0xffffffffffffn)===n.length-Rr))return Buffer.concat([(0,_o.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,_o.addExtension)({Class:Promise,type:12,pack(){throw new Error("Cannot encode a promise")}});o(f6,"polyfillBlob")});var $v={};Ce($v,{onStorageReclamation:()=>am,runReclamationHandlers:()=>yA,setAvailableSpaceRatioGetter:()=>h6});function am(e,t,r){(r||(0,s_.getWorkerIndex)()===(0,s_.getWorkerCount)()-1)&&(n_.has(e)||n_.set(e,[]),n_.get(e).push({priority:0,handler:t}),RA||(RA=setTimeout(yA,kv).unref()))}async function yA(){for(let[e,t]of n_)try{let r=await qv(e),n=m6/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&&(TA.default.info?.(`Running storage reclamation handler for ${e} with priority ${n}`),await c)}}}catch(r){TA.default.error?.("Error running storage reclamation handlers",r)}RA=setTimeout(yA,kv).unref()}function h6(e){qv=e??Gv}var SA,s_,TA,i_,Hv,n_,m6,kv,RA,Gv,qv,o_=fe(()=>{SA=require("node:fs/promises"),s_=w(st()),TA=w(Ni());k();i_=w(ce()),Hv=w(ie());i_.default.initSync();n_=new Map,m6=i_.default.get(U.STORAGE_RECLAMATION_THRESHOLD)??.4,kv=(0,Hv.convertToMS)(i_.default.get(U.STORAGE_RECLAMATION_INTERVAL))||36e5;o(am,"onStorageReclamation");Gv=o(async e=>{if(SA.statfs){let t=await(0,SA.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"),qv=Gv;o(yA,"runReclamationHandlers");o(h6,"setAvailableSpaceRatioGetter")});var rU={};Ce(rU,{ACTION_32_BIT:()=>d_,ACTION_64_BIT:()=>_6,AUDIT_STORE_OPTIONS:()=>um,Decoder:()=>$c,HAS_BLOBS:()=>Nn,HAS_CURRENT_RESIDENCY_ID:()=>Vc,HAS_EXPIRATION_EXTENDED_TYPE:()=>mm,HAS_ORIGINATING_OPERATION:()=>fm,HAS_PREVIOUS_RESIDENCY_ID:()=>Kc,REMOTE_SEQUENCE_UPDATE:()=>f_,createAuditEntry:()=>Su,getLastRemoved:()=>OA,openAuditStore:()=>l_,readAuditEntry:()=>Ut,removeAuditEntry:()=>u_,setAuditRetention:()=>E6,transactionKeyEncoder:()=>Xv});function l_(e){let t=e.auditStore=e.openDB(AA.AUDIT_STORE_NAME,{create:!1,...um});t||(t=e.auditStore=e.openDB(AA.AUDIT_STORE_NAME,um),Kv(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=IA;am(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()-bA/(1+i*i)})){try{m=u_(t,p,_)}catch(g){gu.warn("Error removing audit entry",g)}if(h=p,await new Promise(setImmediate),++f>=p6){a=10;break}}await m}finally{f===0?a=Math.min(a<<1,bA/10):(Kv(t,h),a>100&&(a=a>>1)),d(void 0),c()}},a).unref()});return u}if(o(c,"scheduleAuditCleanup"),t.scheduleAuditCleanup=c,(0,lm.getWorkerIndex)()===(0,lm.getWorkerCount)()-1&&c(),(0,lm.getWorkerIndex)()===0&&!Vv)for(let l of t.getKeys({reverse:!0,limit:1}))l>Date.now()&&(Vv=!0,gu.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 u_(e,t,r){let n=g6(r),s;if(n&Nn){s=Ut(r);let i=e.tableStores[s.tableId],a=i?.getEntry(s.recordId);(!a||a.version!==s.version||!a.value)&&Gc(()=>Sa(s.getValue(i)),i.rootStore)}if((n&15)===NA){s=s||Ut(r);let i=s.tableId;e.tableStores[s.tableId]?.getEntry(s.recordId).version===s.version&&e.deleteCallbacks?.[i]?.(s.recordId,s.version)}return e.remove(t)}function Kv(e,t){wA[0]=t,e.put(Symbol.for("last-removed"),Zv)}function OA(e){let t=e.get(Symbol.for("last-removed"));if(t)return Zv.set(t),wA[0]}function E6(e,t=IA){bA=e,IA=t}function Su(e,t,r,n,s,i,a,c,l,u,d,f,m){let h=eU[a];if(!h)throw new Error(`Invalid audit entry type ${a}`);let p=1;if(n&&(n>1?Ta.setFloat64(0,n):Rs.set(CA),p=9),l){if(l&255)throw new Error("Illegal extended type");p+=3}y(s),y(t),g(r),Ta.setFloat64(p,e),p+=8,l&Vc&&y(u),l&Kc&&y(d),l&mm&&(Ta.setFloat64(p,f),p+=8),l&fm&&y(tU[m]),i?g(i):Rs[p++]=0,l?Ta.setUint32(n?8:0,h|l|3221225472):Rs[n?8:0]=h;let _=Rs.subarray(0,p);if(c)return Buffer.concat([_,c]);return _;function g(T){let R=p;p+=1,p=(0,qc.writeKey)(T,Rs,p);let I=p-R-1;I>127?I>16383?(gu.error("Key or username was too large for audit entry",T),p=R+1,Rs[R]=0):(Rs.copyWithin(R+2,R+1,p),Ta.setUint16(R,I|32768),p++):Rs[R]=I}function y(T){T<128?Rs[p++]=T:T<16384?(Ta.setUint16(p,T|32768),p+=2):T<1056964608?(Ta.setUint32(p,T|3221225472),p+=4):(Rs[p]=255,Ta.setUint32(p+1,T),p+=5)}}function g6(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 $c(e.buffer,e.byteOffset,e.byteLength));return n.position=t,n.readInt()}function Ut(e,t=0,r=void 0){try{let n=e.dataView||(e.dataView=new $c(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&Vc&&(m=n.readInt()),i&Kc&&(h=n.readInt()),i&mm&&(p=n.readFloat64()),i&fm){let R=n.readInt();_=tU[R]}l=n.readInt();let g=n.position,y=n.position+=l,T;return{type:eU[i&7],tableId:c,nodeId:a,get recordId(){return(0,qc.readKey)(e,u,d)},getBinaryRecordId(){return e.subarray(u,d)},version:f,previousLocalTime:s,get user(){return y>g?(0,qc.readKey)(e,g,y):void 0},get encoded(){return t?e.subarray(t,r):e},getValue(R,I,P){if(i&a_||i&cm&&!I)return T||(T=Gc(()=>R.decoder.decode(e.subarray(n.position,r)),R.rootStore)),T;if(i&cm&&P)return rA(R.getEntry(this.recordId),P,R)},getBinaryValue(){return i&(a_|cm)?e.subarray(n.position,r):void 0},extendedType:i,residencyId:m,previousResidencyId:h,expiresAt:p,originatingOperation:_}}catch(n){return gu.error("Reading audit entry error",n,e),{}}}var qc,c_,AA,lm,Jv,gu,Rs,Ta,Xv,um,bA,p6,wA,Zv,IA,Vv,a_,cm,Yv,NA,Wv,zv,jv,Qv,d_,_6,f_,Vc,Kc,fm,mm,Nn,eU,tU,$c,uo=fe(()=>{qc=require("ordered-binary"),c_=w(ce()),AA=w(kt());k();lm=w(st()),Jv=w(ie());Yc();gu=w(z());qE();Ts();o_();(0,c_.initSync)();Rs=Buffer.alloc(2816),Ta=new DataView(Rs.buffer,Rs.byteOffset,2816),Xv={writeKey(e,t,r){return e===dm?(t.set(dm,r),r+8):typeof e=="number"?((t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).setFloat64(r,e),r+8):(0,qc.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,qc.readKey)(e,t,r)}},um={encoding:"binary",keyEncoder:Xv},bA=(0,Jv.convertToMS)((0,c_.get)(U.LOGGING_AUDITRETENTION))||86400*3,p6=1e3,wA=new Float64Array(1),Zv=new Uint8Array(wA.buffer),IA=1e4,Vv=!1;o(l_,"openAuditStore");o(u_,"removeAuditEntry");o(Kv,"updateLastRemoved");o(OA,"getLastRemoved");o(E6,"setAuditRetention");a_=16,cm=32,Yv=1,NA=2,Wv=3,zv=4,jv=5,Qv=6,d_=14,_6=15,f_=11,Vc=512,Kc=1024,fm=2048,mm=4096,Nn=8192,eU={put:Yv|a_,[Yv]:"put",delete:NA,[NA]:"delete",message:Wv|a_,[Wv]:"message",invalidate:zv|cm,[zv]:"invalidate",patch:jv|cm,[jv]:"patch",relocate:Qv,[Qv]:"relocate"},tU={insert:1,update:2,upsert:3,1:"insert",2:"update",3:"upsert"};o(Su,"createAuditEntry");o(g6,"readAction");o(Ut,"readAuditEntry");$c=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 aU={};Ce(aU,{ENTRY:()=>T6,HAS_EXPIRATION:()=>p_,HAS_RESIDENCY_ID:()=>UA,HAS_STRUCTURE_UPDATE:()=>E_,LAST_TIMESTAMP_PLACEHOLDER:()=>dm,LOCAL_TIMESTAMP:()=>S6,METADATA:()=>Ru,NEW_TIMESTAMP_PLACEHOLDER:()=>sU,NO_TIMESTAMP:()=>PA,PENDING_LOCAL_TIME:()=>xA,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>CA,RecordEncoder:()=>vA,TIMESTAMP_ASSIGN_LAST:()=>y6,TIMESTAMP_ASSIGN_NEW:()=>iU,TIMESTAMP_ASSIGN_PREVIOUS:()=>oU,TIMESTAMP_PLACEHOLDER:()=>m_,TIMESTAMP_RECORD_PREVIOUS:()=>LA,entryMap:()=>Ra,handleLocalTimeForGets:()=>__,lastMetadata:()=>ct,recordUpdater:()=>BA,removeEntry:()=>zc});function b6(){return Em[0]=Em[0]^64,R6.getFloat64(0)}function __(e,t){let r=e.getEntry;e.readCount=0,e.cachePuts=!1,e.rootStore=t,e.encoder.rootStore=t,e.getEntry=function(a,c){e.readCount++,ct=null;let l=r.call(this,a,c);return l&&(ct&&(l.metadataFlags=ct[Ru],l.localTime=ct.localTime,l.residencyId=ct.residencyId,ct.expiresAt>=0&&(l.expiresAt=ct.expiresAt),ct=null),l.value&&Ra.set(l.value,l),l.key=a),l};let n=e.get;e.get=function(a,c){ct=null;let l=n.call(this,a,c);return ct&&l&&(Ra.set(l,ct),ct=null),l};let s=e.getRange;e.getRange=function(a){let c=s.call(this,a);return a.valuesForKey?c.map(l=>l?.value):a.values===!1||a.onlyCount?c:c.map(l=>(ct&&(l.metadataFlags=ct[Ru],l.localTime=ct.localTime,l.residencyId=ct.residencyId,ct.expiresAt>=0&&(l.expiresAt=ct.expiresAt),ct=null),l))};let i=e.useReadTransaction();if(i.done(),!i.done.isTracked){let a=i.constructor,c=i.use,l=i.done;a.prototype.use=function(){this.timerTracked||(this.timerTracked=!0,Wc.push(new WeakRef(this))),c.call(this)},a.prototype.done=function(){if(l.call(this),this.isDone)for(let u=0;u<Wc.length;u++){let d=Wc[u].deref();(!d||d.isDone||d.isCommitted)&&Wc.splice(u--,1)}},a.prototype.done.isTracked=!0}return e}function BA(e,t,r){return function(n,s,i,a,c=-1,l,u,d="put",f,m){f||l==null?Tu=i?.localTime?LA|oU:PA:Tu=l?i?.localTime?LA|16384:iU|16384:PA;let h=u?.expiresAt;if(h>=0&&(c|=p_),pm=c,DA=h,i?.version===a&&l===!1)throw new Error("Must retain local time if version is not changed");let p={version:a,instructedWrite:Tu>0},_,g=0;try{let y=i?.residencyId,T=u?.residencyId;T&&(MA=T,pm|=UA,g|=Vc),y!==T&&(g|=Kc,y||(y=0)),c&p_&&(g|=mm),u?.originatingOperation&&(g|=fm),f&&(p.ifVersion=_=i?.version??null),i&&i.value&&i.metadataFlags&Nn&&(r.getBinaryFast(i.localTime)||Sa(i.value));let R;if(s!==void 0&&(R=e_(()=>e.put(n,s,p),n,e.rootStore),kc&&(g|=Nn)),l){let I=u?.user?.username;if(m&&(e_(()=>e.encoder.encode(m),n,e.rootStore),kc&&(g|=Nn)),e.encoder.hasStructureUpdate&&(g|=E_,e.encoder.hasStructureUpdate=!1),f&&i?.localTime){let P=i?.localTime,Y=r.get(P);if(Y){let te=Ut(Y).previousLocalTime;return R=r.put(P,Su(a,t,n,te,u?.nodeId??server.replication.getThisNodeId(r)??0,I,d,hm,g,T,y,h),{ifVersion:_}),R}}R=r.put(s===void 0?sU:dm,Su(a,t,n,i?.localTime?1:0,u?.nodeId??server.replication?.getThisNodeId(r)??0,I,d,hm,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 zc(e,t,r){if(t)return t.value&&t.metadataFlags&Nn&&!e.auditStore.getBinaryFast(t.localTime)&&Sa(t.value),e.remove(t.key,r)}var nU,h_,m_,dm,CA,sU,S6,Ru,T6,Em,R6,PA,iU,y6,oU,LA,p_,UA,xA,E_,Ra,A6,hm,Tu,pm,DA,MA,ct,vA,Wc,Yc=fe(()=>{nU=require("msgpackr");uo();h_=w(z());Ts();Ts();m_=new Uint8Array([1,1,1,1,4,64,0,0]),dm=new Uint8Array([1,1,1,1,1,0,0,0]),CA=new Uint8Array([1,1,1,1,3,64,0,0]),sU=new Uint8Array([1,1,1,1,0,64,0,0]),S6=Symbol("local-timestamp"),Ru=Symbol("metadata"),T6=Symbol("entry"),Em=new Uint8Array(8),R6=new DataView(Em.buffer,0,8),PA=0,iU=0,y6=1,oU=3,LA=4,p_=16,UA=32,xA=1,E_=256,Ra=new WeakMap,Tu=0,pm=-1,DA=-1,MA=0,ct=null,vA=class extends nU.Encoder{static{o(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0;class r{static{o(this,"RecordObject")}getUpdatedTime(){return Ra.get(this)?.version}getExpiresAt(){return Ra.get(this)?.expiresAt}}t.structPrototype=r.prototype,super(t);let n=this.encode;this.encode=function(i,a){if(Tu||pm>=0){let c=0,l=Tu;l&&(c+=8,Tu=0);let u=pm,d=DA,f=MA;u>=0&&(c+=4,pm=-1,d>=0&&(c+=8,DA=-1),f&&(c+=4,MA=0));let m=A6=n.call(this,i,a|2048|c);hm=m.subarray((m.start||0)+c,m.end);let h=m.start||0;return l&&(m_[4]=l,m_[5]=l>>8,m.set(m_,h),h+=8),kc&&(u|=Nn),u>=0&&((m.dataView||(m.dataView=new DataView(m.buffer,m.byteOffset,m.byteLength))).setUint32(h,u|d_<<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 hm=n.call(this,i,a),hm};let s=this.saveStructures;this.saveStructures=function(i,a){let c=s.call(this,i,a);return this.hasStructureUpdate=!0,c}}decode(t,r){ct=null;let n=r?.start||0,s=r>-1?r:r?.end||t.length,i=t[n],a=0;try{if(i<32&&s>2){let c=n,l;if(i===2){if(t.copy)t.copy(Em,0,c),c+=8;else for(let m=0;m<8;m++)Em[m]=t[c++];l=b6(),i=t[c]}let u,d;i<32&&(i===d_?(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&p_&&(u=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8),a&UA&&(d=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4));let f=Gc(()=>r?.valueAsBuffer?t.subarray(c,s):super.decode(t.subarray(c,s),s-c),this.rootStore);return ct={localTime:l,[Ru]:a,expiresAt:u,residencyId:d},f}return r?.valueAsBuffer?t:Gc(()=>super.decode(t,r),this.rootStore)}catch(c){return h_.error("Error decoding record",c,"data: "+t.slice(0,40).toString("hex")),null}}};o(b6,"getTimestamp");o(__,"handleLocalTimeForGets");Wc=[];setInterval(()=>{for(let e=0;e<Wc.length;e++){let t=Wc[e].deref();!t||t.isDone||t.isCommitted?Wc.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(h_.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):h_.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(BA,"recordUpdater");o(zc,"removeEntry")});function kA(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?kA(f.conditions,f.operator,r,n,s,i,a,c):Iu(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=gm(p,r,i,c,g,h);return m&&_<f.length-1&&h&&(h=M6(r.primaryStore,p.estimated_count,h)),y}).filter(Boolean)}o(d,"mapConditionsToFilters")}function Iu(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=Ci(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=Iu({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=!!Ci(P.attributes,I.relationship.to)?.elements;te=C6(te,I,P.primaryStore,x,Y)}if(I.relationship.from){let x=o($=>($?.key!==void 0&&($=$.key),Iu({attribute:I.relationship.from,value:$},t,r,n,s,Y)),"searchEntry");I.elements?(i[c[0]]=Y,te=P6(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(GA[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]=Oi.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>ys.MAX_SEARCH_KEY_LENGTH&&(m=m.slice(0,ys.MAX_SEARCH_KEY_LENGTH)+ys.OVERFLOW_MARKER,_=!1,y=gm(e,n,null,i,d)),typeof h=="string"&&h.length>ys.MAX_SEARCH_KEY_LENGTH&&(h=h.slice(0,ys.MAX_SEARCH_KEY_LENGTH)+ys.OVERFLOW_MARKER,p=!0,y=y??gm(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??gm(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:ya.SKIP:new Promise((Y,te)=>setImmediate(()=>{try{Y(P&&y(P)?I:ya.SKIP)}catch(x){te(x)}}))}:I=>I.value==null&&!(I.metadataFlags&(wn|Aa))?ya.SKIP:I);return R.hasEntries=!0,R}else return f?f.customIndex?f.customIndex.search(e,a).map(R=>{if(typeof R=="object"&&R){let{key:I,...P}=R,Y=n.primaryStore.getEntry(I);return{...P,...Y}}return R}):f.getRange(T).map(y?function({key:R,value:I}){let P;return typeof R=="string"&&R.length>ys.MAX_SEARCH_KEY_LENGTH?P=n.primaryStore.get(I):P={[c]:R},this.isSync?y(P)?I:ya.SKIP:new Promise((Y,te)=>setImmediate(()=>{try{Y(y(P)?I:ya.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:ya.SKIP:new Promise((P,Y)=>setImmediate(()=>{try{P(I&&y(I)?R:ya.SKIP)}catch(te){Y(te)}}))})}function Ci(e,t){if(Array.isArray(t))if(t.length>1){let r=Ci(e,t[0]),n=(r?.definition?.tableClass||r?.elements?.definition?.tableClass)?.attributes??r?.properties;return n?Ci(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 C6(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 P6(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 gm(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=Ci(t.attributes,d),m=f.definition?.tableClass||f.elements.definition?.tableClass,h=n?.[d],p=gm({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=ct):(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()),GA[a]||a){case ys.SEARCH_TYPES.EQUALS:case void 0:return u(c,d=>d===l,!0);case"contains":return u(c,d=>d?.toString().includes(l));case"ends_with":return u(c,d=>d?.toString().endsWith(l));case"starts_with":return u(c,d=>typeof d=="string"&&d.startsWith(l),!0);case"prefix":return Array.isArray(l)?l[l.length-1]==null&&(l=l.slice(0,-1)):l=[l],u(c,d=>{if(!Array.isArray(d))return!1;for(let f=0,m=l.length;f<m;f++)if(d[f]!==l[f])return!1;return!0},!0);case"between":return l[0]instanceof Date&&(l[0]=l[0].getTime()),l[1]instanceof Date&&(l[1]=l[1].getTime()),u(c,d=>(0,Oi.compareKeys)(d,l[0])>=0&&(0,Oi.compareKeys)(d,l[1])<=0,!0);case"gt":return u(c,d=>(0,Oi.compareKeys)(d,l)>0);case"ge":return u(c,d=>(0,Oi.compareKeys)(d,l)>=0);case"lt":return u(c,d=>(0,Oi.compareKeys)(d,l)<0);case"le":return u(c,d=>(0,Oi.compareKeys)(d,l)<=0);case"ne":return u(c,d=>(0,Oi.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&&S_(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=Iu(e,r.transaction.getReadTxn(),!1,t),Y;y.to?Y=P.flatMap(x=>t.primaryStore.get(x)[y.to]):Y=P.map(Nu);let te=new Set(Y);y.idFilter=x=>te.has(Nu(x)),y.idFilter.idSet=te}return I}return o(y,"recordFilter"),s&&(y.idFilter=f),y}o(u,"attributeComparator")}function S_(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/So(e.primaryStore):i.estimated_count}return r.estimated_count=s,r.estimated_count}let n=r.comparator||r.search_type;if(n=GA[n]||n,n===ys.SEARCH_TYPES.EQUALS||!n){let s=r[0]??r.attribute;if(s==null||s===e.primaryKey)r.estimated_count=1;else if(Array.isArray(s)&&s.length>1){let i=Ci(e.attributes,s[0]),a=i.definition?.tableClass||i.elements.definition?.tableClass,c=S_(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*So(e.indices[i.relationship.from])/(So(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=So(e.primaryStore)-(i?i.getValuesCount(null):0):r.estimated_count=1/0}else if(n==="starts_with"||n==="prefix")r.estimated_count=w6*So(e.primaryStore)+1;else if(n==="between")r.estimated_count=N6*So(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=So(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=I6*So(e.primaryStore)+1}typeof r.descending=="boolean"&&(r.estimated_count/=2)}return r.estimated_count}return o(t,"estimateConditionForTable"),t}function T_(e,t){if(e)if(To=e,yu.lastIndex=0,L6.test(e))try{if(t&&(t.conditions=[]),Qs=t??new bu,_m(Qs,""),Lr!==To.length&&Gt("Unable to parse query, unexpected end of query"),Qs.parseErrorMessage&&(Qs.parseError=new FA(t.parseErrorMessage),!t))throw Qs.parseError;return Qs}catch(r){if(r.statusCode=400,r.message=`Unable to parse query, ${r.message} at position ${Lr} in '${To}'`,Qs.parseErrorMessage&&(r.message+=", "+Qs.parseErrorMessage),t)t.parseError=r;else throw r}else return t??new URLSearchParams(e)}function Gt(e){let t=`${e} at position ${Lr}`;Qs.parseErrorMessage=Qs.parseErrorMessage?Qs.parseErrorMessage+", "+t:t}function _m(e,t){let r=yu,n,s,i,a,c,l=decodeURIComponent,u;for(;n=r.exec(To);){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=cU):(l=decodeURIComponent,i="equals",d||Gt("attribute must be specified before equality comparator"),s=Au(d));break;case"==":case"!=":case"<":case"<=":case">":case">=":case"===":case"!==":i=O6[f],l=HA[i]?cU:decodeURIComponent,d||Gt(`attribute must be specified before comparator ${f}`),s=Au(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"&&lU(p,d),s===""){let _=e.conditions[e.conditions.length-1];_.chainedConditions=_.chainedConditions||[],_.chainedConditions.push(p),_.operator=u}else g_(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(Au(d)),s=void 0;break;case"(":yu.lastIndex=Lr;let h=_m(d?[]:new bu,")");switch(d){case"":g_(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=uU(h);break;default:Gt(`unknown query function call ${d}`)}To[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"),yu.lastIndex=Lr,m=_m([],"}"),m.name=d,e.push(m),To[Lr]===","?r.lastIndex=++Lr:a=!0;break;case"[":if(yu.lastIndex=Lr,d?(m=_m(new bu,"]"),m.name=d):m=_m(e.conditions?new bu:[],"]"),e.conditions)if(g_(e,u),To[Lr]==="="){l=decodeURIComponent,i="equals",s=Au(d),r.lastIndex=++Lr;break}else e.conditions.push(m),s=null;else e.push(m);To[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"&&lU(p,d),g_(e,u),e.conditions.push(p)}else d&&Gt("no attribute or comparison specified");else(d||e.length>0&&c)&&e.push(Au(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?D6:yu,r.lastIndex=Lr),Lr===To.length)return e}t&&Gt(`expected '${t}', but encountered end of string`)}function g_(e,t){e.conditions.length>0&&(e.operator?e.operator!==t&&Gt("Can not mix operators within a condition grouping"):e.operator=t)}function Au(e){return e.indexOf(".")>-1?e.split(".").map(Au):decodeURIComponent(e)}function cU(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 lU(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 uU(e){let t=dU(e[0]);return e.length>1&&(t.next=uU(e.slice(1))),t}function dU(e){if(Array.isArray(e)){let t=dU(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 Nu(e){return Array.isArray(e)?e.join("\0"):e}function So(e){let t=Date.now();return(e.estimatedEntryCountExpires||0)<t&&(e.estimatedEntryCount=e.getStats().entryCount,e.estimatedEntryCountExpires=t+1e4),e.estimatedEntryCount}function M6(e,t,r){return t*r/So(e)}var qr,ys,Oi,ya,I6,N6,w6,O6,HA,GA,FA,L6,yu,D6,Lr,Qs,To,bu,R_=fe(()=>{qr=w(Ee()),ys=w(kt()),Oi=require("ordered-binary"),ya=require("lmdb");Sm();Yc();I6=.3,N6=.1,w6=.05,O6={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},HA={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};o(kA,"executeConditions");o(Iu,"searchByIndex");o(Ci,"findAttribute");o(C6,"joinTo");o(P6,"joinFrom");GA={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(gm,"filterByType");o(S_,"estimateCondition");FA=class extends qr.Violation{static{o(this,"SyntaxViolation")}},L6=/[()[\]|!<>.]|(=\w*=)/,yu=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,D6=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/g;o(T_,"parseQuery");o(Gt,"recordError");o(_m,"parseBlock");o(g_,"assignOperator");o(Au,"decodeProperty");o(cU,"typedDecoding");o(lU,"wildcardDecoding");o(uU,"toSortObject");o(dU,"toSortEntry");bu=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(Nu,"flattenKey");o(So,"estimatedEntryCount");o(M6,"intersectionEstimate")});var fU,Js,y_=fe(()=>{fU=w(Ws());ba();Js=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,fU._assignPackageExport)("Resource",Dr)});var _U={};Ce(_U,{MultiPartId:()=>A_,Resource:()=>Dr,contextStorage:()=>Ou,snakeCase:()=>U6,transformForSelect:()=>b_});function U6(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function mU(e,t){if(jc=!1,e==="")return null;if(e=e.slice(1),t.splitSegments){if(e.indexOf("/")===-1)return e===""?(jc=!0,null):t.coerceId(decodeURIComponent(e));let r=e.split("/"),n=new A_;for(let s=0;s<r.length;s++){let i=r[s];if(!i&&s===r.length-1){jc=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}else{if(e==="")return jc=!0,null;e[e.length-1]==="/"&&(jc=!0)}return t.coerceId(decodeURIComponent(e))}function On(e,t){n.reliesOnPrototype=!0;let r=t.hasContent;return n;function n(s,i,a){let c,l,u,d;if(r){if(a)d=i,a=a.getContext?.()||a;else if(i)typeof s=="object"&&s&&(!Array.isArray(s)||typeof s[0]=="object")?(d=s,c=d[this.primaryKey]??null,a=i.getContext?.()||i):i?.transaction instanceof lo?a=i:d=i;else if(s&&typeof s=="object")d=s,s=void 0,c=d.getId?.()??d[this.primaryKey];else throw new wu.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 Js,l.id=c,u=!1)))}c===void 0&&(c=s.id??null,c==null&&(u=!0))}else c=s,l=new Js,l.id=c,c==null&&(u=!0);l||(l=new Js,l.id=c),u&&(l.isCollection=!0);let f;a||(a=Ou.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(_=>Ou.run(a,()=>p(_)),"runAction")),a?.transaction){let _=this.getResource(c,a,f);return _.then?_.then(h):h(_)}else return vt(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 wu.AccessViolation(a.user);return typeof d?.then=="function"?d.then(T=>e(_,l,a,T)):e(_,l,a,d)});if(!g)throw new wu.AccessViolation(a.user)}return typeof d?.then=="function"?d.then(g=>e(_,l,a,g)):e(_,l,a,d)}o(p,"authorizeActionOnResource")}}function Vn(e,t){let r=new wu.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 qA(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 b_(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):qA(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(qA(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(qA(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]=b_(c.select||c,d)}let u=a(c.name);return l(u)}else return a(c);else return c}}o(i,"handleProperty")}var hU,pU,wu,EU,Ou,v6,Dr,jc,A_,ba=fe(()=>{hU=require("crypto");Qf();pu();pU=w(Ws()),wu=w(Ee());Uc();R_();EU=require("async_hooks");y_();Ou=new EU.AsyncLocalStorage,v6={json:"application/json",cbor:"application/cbor",msgpack:"application/x-msgpack",csv:"text/csv"},Dr=class{static{o(this,"Resource")}#e;#t;#r;static transactions;static directURLMapping=!1;static loadAsInstance;constructor(t,r){this.#e=t;let n=r?.getContext?r.getContext()??null:void 0;this.#t=n!==void 0?n:r||null}static get=On(function(t,r,n,s){let i=t.get?.(r);if(i?.then)return i.then(a);return a(i);function a(c){let l;if((l=r?.select)&&c!=null&&!c.selectApplied){let u=b_(l,t.constructor);return typeof c?.map=="function"?c.map(u):u(c)}return c}},{type:"read",letItLinger:!0,ensureLoaded:!0,async:!0});static put=On(function(t,r,n,s){if(Array.isArray(s)&&t.#r&&t.constructor.loadAsInstance!==!1){let i=[];for(let a of s){let c=t.constructor,l=a[c.primaryKey],u=c.getResource(l,n,{async:!0});u.then?i.push(u.then(d=>d.put(a,n))):i.push(u.put(a,n))}return Promise.all(i)}return t.put?t.constructor.loadAsInstance===!1?t.put(r,s):t.put(s,r):Vn(t,"put")},{hasContent:!0,type:"update"});static patch=On(function(t,r,n,s){return t.patch?t.constructor.loadAsInstance===!1?t.patch(r,s):t.patch(s,r):Vn(t,"patch")},{hasContent:!0,type:"update"});static delete=On(function(t,r,n,s){return t.delete?t.delete(r):Vn(t,"delete")},{hasContent:!1,type:"delete"});static getNewId(){return(0,hU.randomUUID)()}static create(t,r,n){n?n.getContext&&(n=n.getContext()):n=Ou.getStore()??{};let s;return this.loadAsInstance===!1?s=t:t==null?s=r?.[this.primaryKey]??this.getNewId():Array.isArray(t)&&typeof t[0]!="object"?s=r?.[this.primaryKey]??[...t,this.getNewId()]:typeof t!="object"?s=r?.[this.primaryKey]??[t,this.getNewId()]:(s=t?.[this.primaryKey]??this.getNewId(),n=r||{},r=t),vt(n,async()=>{let i=new this(s,n),a=await i.create?i.create(s,r):Vn(i,"create");return n.newLocation=s??a?.[this.primaryKey],n.createdResource=!0,this.loadAsInstance===!1?a:i})}static invalidate=On(function(t,r,n,s){return t.invalidate?t.invalidate(r):Vn(t,"delete")},{hasContent:!1,type:"update"});static post=On(function(t,r,n,s){return t.#e!=null&&t.update?.(),t.constructor.loadAsInstance===!1?t.post(r,s):t.post(s,r)},{hasContent:!0,type:"create"});static update=On(function(t,r,n,s){return t.update(r,s)},{hasContent:!0,type:"create"});static connect=On(function(t,r,n,s){return t.connect?t.constructor.loadAsInstance===!1?t.connect(r,s):t.connect(s,r):Vn(t,"connect")},{hasContent:!0,type:"read"});static subscribe=On(function(t,r,n,s){return t.subscribe?t.subscribe(r):Vn(t,"subscribe")},{type:"read"});static publish=On(function(t,r,n,s){return t.#e!=null&&t.update?.(),t.publish?t.constructor.loadAsInstance===!1?t.publish(r,s):t.publish(s,r):Vn(t,"publish")},{hasContent:!0,type:"create"});static search=On(function(t,r,n){let s=t.search?t.search(r):Vn(t,"search"),i=n.select;if(i&&n.hasOwnProperty("select")&&s!=null&&!s.selectApplied){let a=b_(i,t.constructor);return s.map(a)}return s},{type:"read"});static query=On(function(t,r,n,s){return t.search?t.constructor.loadAsInstance===!1?t.search(r,s):t.search(s,r):Vn(t,"search")},{hasContent:!0,type:"read"});static copy=On(function(t,r,n,s){return t.copy?t.constructor.loadAsInstance===!1?t.copy(r,s):t.copy(s,r):Vn(t,"copy")},{hasContent:!0,type:"create"});static move=On(function(t,r,n,s){return t.move?t.constructor.loadAsInstance===!1?t.move(r,s):t.move(s,r):Vn(t,"move")},{hasContent:!0,type:"delete"});async post(t){if(this.#r)return(await this.constructor.create(this.#e,t,this.#t)).#e;Vn(this,"post")}static isCollection(t){return t&&t.#r}get isCollection(){return this.#r}static coerceId(t){return t}static parseQuery(t,r){return T_(t,r)}static parsePath(t,r,n){let s=t.indexOf(".");if(s>-1){let a=t.slice(s+1),c=r?.headers&&v6[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:mU(t,this),isCollection:jc}}let i=mU(t,this);return jc?{id:i,isCollection:!0}:i}static getResource(t,r,n){let s,i=r.getContext?.(),a;typeof r.isCollection=="boolean"&&r.hasOwnProperty("isCollection")?a=r.isCollection:a=n?.isCollection;let c=a&&this.Collection||this;if(i||(i=i===void 0?r:{}),i.transaction){let l;if(i.resourceCache?l=i.resourceCache:l=i.resourceCache=[],l.asMap){let u=l.asMap.get(t);if(s=u?.find(d=>d.constructor===c),s)return s;u||l.asMap.set(t,u=[]),u.push(s=new c(t,i))}else{if(s=l.find(u=>u.#e===t&&u.constructor===c),s)return s;if(l.push(s=new c(t,i)),l.length>10){let u=new Map;for(let d of l){let f=d.#e,m=u.get(f);m?m.push(d):u.set(f,[d])}i.resourceCache.length=0,i.resourceCache.asMap=u}}}else s=new c(t,i);return a&&(s.#r=!0),s}subscribe(t){return new $n}connect(t,r){return r?.subscribe!==!1?this.subscribe?.(r):new $n}allowRead(t,r){return t?.role.permission.super_user}allowUpdate(t,r,n){return t?.role.permission.super_user}allowCreate(t,r,n){return t?.role.permission.super_user}allowDelete(t,r){return t?.role.permission.super_user}getId(){return this.#e}getContext(){return this.#t}};(0,pU._assignPackageExport)("Resource",Dr);o(U6,"snakeCase");o(mU,"pathToId");A_=class extends Array{static{o(this,"MultiPartId")}toString(){return this.join("/")}};o(On,"transactional");o(Vn,"missingMethod");o(qA,"selectFromObject");o(b_,"transformForSelect")});var Qc,$A=fe(()=>{Qc=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 TU={};Ce(TU,{Resources:()=>I_,keyArrayToString:()=>Cu,resetResources:()=>x6,resources:()=>As});function x6(){return As=new I_,ve.resources=As,As}function Cu(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var gU,SU,I_,As,Pu=fe(()=>{Uc();$A();gU=w(z()),SU=w(Ee());Pr();I_=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 SU.ServerError(`Conflicting paths for ${t}`);gU.default.error(c),i.Resource=new Qc(c)}super.set(t,i);for(let[c,l]of this){let u=2;for(;(u=c.indexOf("/",u))>-1;){let d=this.get(c.slice(0,u));d&&(d.hasSubPaths=!0),u+=2}}}getMatch(t,r){let n=2,s=0,i,a=t.length;for(;n<a;){s=n,n=t.indexOf("/",n),n===-1&&(n=a);let u=n===a?t:t.slice(0,n),d=this.get(u),f=-1;if(!d&&n===a&&(f=u.indexOf("?",s),f!==-1)){let m=u.slice(0,f);d=this.get(m)}if(d&&(!r||d.exportTypes?.[r]!==!1)){if(d.relativeURL=t.slice(f!==-1?f:n),!d.hasSubPaths)return d;i=d}n+=2}if(i)return i;let c=t.indexOf("?"),l=c>-1?t.slice(0,c):t;return i=this.get(l),!i&&l.indexOf(".")>-1&&(i=this.get(l.split(".")[0])),i&&(!r||i.exportTypes?.[r]!==!1)?i.relativeURL=c>-1?t.slice(c):"":i||(i=this.get(""),i&&(!r||i.exportTypes?.[r]!==!1)&&(t.charAt(0)!=="/"&&(t="/"+t),i.relativeURL=t)),i}getResource(t,r){let n=this.getMatch(t);if(n)return t=n.relativeURL,n.Resource.getResource(this.pathToId(t,n.Resource),r)}call(t,r,n){return vt(r,async()=>{let s=this.getMatch(t);if(s)return t=s.relativeURL,n(s.Resource,s.path,t)})}setRepresentation(t,r,n){}};o(x6,"resetResources");o(Cu,"keyArrayToString")});function YA(e,t,r,n,s){let i=e.primaryStore.env.path,a=e.primaryStore.tableId,c;s?.crossThreads===!1?(c=yU,B6(e.primaryStore,e.auditStore)):(c=RU,e.primaryStore.env.hasSubscriptionCommitListener||(e.primaryStore.env.hasSubscriptionCommitListener=!0,e.primaryStore.on("committed",()=>{AU(RU[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=Cu(t);let d=new KA(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 AU(e){if(!e)return;let t=e.auditStore;t.resetReadTxn(),bU(e.auditStore);let r;for(let{key:n,value:s}of t.getRange({start:e.lastTxnTime,exclusiveStart:!0})){e.lastTxnTime=n;let i=Ut(s),a=e[i.tableId];if(!a)continue;let c=i.recordId,l=Cu(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,VA.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,VA.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 B6(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=yU[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{AU(l)}finally{r.threadLocalWrites[0]=l.lastTxnTime,r.unlock("thread-local-writes")}},"acquiredLock");r.attemptLock("thread-local-writes",u)&&u()})}}function bU(e){e.nextTransaction?.resolve();let t;e.nextTransaction=new Promise(r=>{t=r}),e.nextTransaction.resolve=t}function IU(e){return e.nextTransaction||(YA({primaryStore:e,auditStore:e},null,null,0,{scope:"full-database"}),bU(e)),e.nextTransaction}var VA,RU,yU,KA,WA=fe(()=>{VA=w(z());pu();Pu();uo();RU=Object.create(null),yU=Object.create(null);o(YA,"addSubscription");KA=class extends $n{static{o(this,"Subscription")}listener;subscriptions;startTime;includeDescendants;supportsTransactions;onlyChildren;constructor(t){super(),this.listener=t,this.on("close",()=>this.end())}end(){if(this.subscriptions){if(this.subscriptions.splice(this.subscriptions.indexOf(this),1),this.subscriptions.length===0){let t=this.subscriptions.tables;if(t){let r=this.subscriptions.key;if(t.delete(r),t.size===0){let n=t.envs,s=t.dbi;delete n[s]}}}this.subscriptions=null}}toJSON(){return{name:"subscription"}}};o(AU,"notifyFromTransactionData");o(B6,"listenToCommits");o(bU,"nextTransaction");o(IU,"whenNextTransaction")});var wU=M((PNe,NU)=>{"use strict";var zA=class{static{o(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};NU.exports=zA});var CU=M((DNe,OU)=>{"use strict";var jA=class{static{o(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};OU.exports=jA});var Tm=M((vNe,LU)=>{"use strict";var PU=ce(),F6=(k(),v(K)),{RecordEncoder:H6}=(Yc(),v(aU));PU.initSync();var k6=PU.get(F6.CONFIG_PARAMS.STORAGE_CACHING)!==!1,QA=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=k6&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:H6})}};LU.exports=QA});var Rm=M((xNe,DU)=>{"use strict";var Kn=ce(),bs=(k(),v(K));Kn.initSync();var N_=class{static{o(this,"OpenEnvironmentObject")}constructor(t,r=!1){this.path=t,this.mapSize=1073741824,this.maxDbs=1e4,this.maxReaders=2048,this.sharedStructuresKey=Symbol.for("structures"),this.readOnly=r,this.trackMetrics=!0,this.eventTurnBatching=!1,this.noSync=Kn.get(bs.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Kn.get(bs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Kn.get(bs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Kn.get(bs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Kn.get(bs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Kn.get(bs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Kn.get(bs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Kn.get(bs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Kn.get(bs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Kn.get(bs.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Kn.get(bs.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Kn.get(bs.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};DU.exports=N_;N_.MAX_DBS=1e4});var _t=M((FNe,qU)=>{"use strict";var XA=require("lmdb"),Xs=require("fs-extra"),Yn=require("path"),w_=An(),UU=z(),Cn=tn().LMDB_ERRORS_ENUM,O_=CU(),ZA=Tm(),xU=Rm(),Ia=kt(),MU=(k(),v(K)),{table:G6,resetDatabases:q6}=(Le(),v(ft)),vU=ce(),Zs=Ia.INTERNAL_DBIS_NAME,BU=Ia.DBI_DEFINITION_NAME,$6="data.mdb",V6="lock.mdb",ym=".mdb",K6="-lock",JA=class{static{o(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=Is(t,r),this.key_type=this.dbi[Ia.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[Ia.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new XA.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function C_(e,t){if(e===void 0)throw new Error(Cn.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(Cn.ENV_NAME_REQUIRED)}o(C_,"pathEnvNameValidation");async function eb(e,t,r=!0){try{await Xs.access(e)}catch(n){throw n.code==="ENOENT"?new Error(Cn.INVALID_BASE_PATH):n}try{let n=Yn.join(e,t+ym);return await Xs.access(n,Xs.constants.R_OK|Xs.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await Xs.access(Yn.join(e,t,$6),Xs.constants.R_OK|Xs.constants.F_OK),Yn.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(Cn.INVALID_ENVIRONMENT)}else throw new Error(Cn.INVALID_ENVIRONMENT);throw n}}o(eb,"validateEnvironmentPath");function P_(e,t){if(w_.validateEnv(e),t===void 0)throw new Error(Cn.DBI_NAME_REQUIRED)}o(P_,"validateEnvDBIName");async function Y6(e,t,r=!1,n=!1){C_(e,t);let s=Yn.basename(e);t=t.toString();let i=vU.get(MU.CONFIG_PARAMS.DATABASES);i||vU.setProperty(MU.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await eb(e,t,n),FU(e,t,r)}catch(a){if(a.message===Cn.INVALID_ENVIRONMENT){let c=Yn.join(e,t);await Xs.mkdirp(n?c:e);let l=new xU(n?c:c+ym,!1),u=XA.open(l);u.dbis=Object.create(null);let d=new ZA(!1);u.openDB(Zs,d),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let f=tb(e,t,r);return u[Ia.ENVIRONMENT_NAME_KEY]=f,global.lmdb_map[f]=u,u}throw a}}o(Y6,"createEnvironment");async function W6(e,t,r,n=!0){C_(e,t),t=t.toString();let s=Yn.join(e,t);return G6({table:t,database:Yn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}o(W6,"copyEnvironment");async function FU(e,t,r=!1){C_(e,t),t=t.toString();let n=tb(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 eb(e,t),i=Yn.join(e,t+ym),a=s!=i,c=new xU(s,a),l=XA.open(c);l.dbis=Object.create(null);let u=kU(l);for(let d=0;d<u.length;d++)Is(l,u[d]);return l[Ia.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}o(FU,"openEnvironment");async function z6(e,t,r=!1){C_(e,t),t=t.toString();let n=Yn.join(e,t+ym),s=await eb(e,t);if(global.lmdb_map!==void 0){let i=tb(e,t,r);if(global.lmdb_map[i]){let a=global.lmdb_map[i];await HU(a),delete global.lmdb_map[i]}}await Xs.remove(s),await Xs.remove(s===n?s+K6:Yn.join(Yn.dirname(s),V6))}o(z6,"deleteEnvironment");async function HU(e){w_.validateEnv(e);let t=e[Ia.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}o(HU,"closeEnvironment");function tb(e,t,r=!1){let s=`${Yn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}o(tb,"getCachedEnvironmentName");function j6(e){w_.validateEnv(e);let t=Object.create(null),r=Is(e,Zs);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==Zs)try{t[n]=Object.assign(new O_,s)}catch{UU.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}o(j6,"listDBIDefinitions");function kU(e){w_.validateEnv(e);let t=[],r=Is(e,Zs);for(let{key:n}of r.getRange({start:!1}))n!==Zs&&t.push(n);return t}o(kU,"listDBIs");function Q6(e,t){let n=Is(e,Zs).getEntry(t),s=new O_;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{UU.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}o(Q6,"getDBIDefinition");function GU(e,t,r,n=!r){if(P_(e,t),t=t.toString(),t===Zs)throw new Error(Cn.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return Is(e,t)}catch(s){if(s.message===Cn.DBI_DOES_NOT_EXIST){let i=new ZA(r,n===!0),a=e.openDB(t,i),c=new O_(r===!0,n);return a[BU]=c,Is(e,Zs).putSync(t,c),e.dbis[t]=a,a}throw s}}o(GU,"createDBI");function Is(e,t){if(P_(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==Zs?r=Q6(e,t):r=new O_,r===void 0)throw new Error(Cn.DBI_DOES_NOT_EXIST);let n;try{let s=new ZA(r.dup_sort,r.useVersions);if(n=e.openDB(t,s),n.db===void 0)throw new Error("MDB_NOTFOUND")}catch(s){throw s.message.includes("MDB_NOTFOUND")===!0?new Error(Cn.DBI_DOES_NOT_EXIST):s}return n[BU]=r,e.dbis[t]=n,n}o(Is,"openDBI");function J6(e,t){P_(e,t),t=t.toString();let r=Is(e,t),n=r.getStats();return r[Ia.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}o(J6,"statDBI");async function X6(e,t){try{let r=Yn.join(e,t+ym);return(await Xs.stat(r)).size}catch{throw new Error(Cn.INVALID_ENVIRONMENT)}}o(X6,"environmentDataSize");function Z6(e,t){if(P_(e,t),t=t.toString(),t===Zs)throw new Error(Cn.CANNOT_DROP_INTERNAL_DBIS_NAME);Is(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],Is(e,Zs).removeSync(t)}o(Z6,"dropDBI");function e8(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{Is(e,i)}catch(a){if(a.message===Cn.DBI_DOES_NOT_EXIST)GU(e,i,i!==t,i===t),n=!0;else throw a}}n&&q6()}o(e8,"initializeDBIs");qU.exports={openDBI:Is,openEnvironment:FU,createEnvironment:Y6,listDBIs:kU,listDBIDefinitions:j6,createDBI:GU,dropDBI:Z6,statDBI:J6,deleteEnvironment:z6,initializeDBIs:e8,TransactionCursor:JA,environmentDataSize:X6,copyEnvironment:W6,closeEnvironment:HU}});var KU=M((kNe,VU)=>{"use strict";var rb=_t(),t8=z(),$U=tn().LMDB_ERRORS_ENUM;VU.exports=r8;async function r8(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 rb.closeEnvironment(global.lmdb_map[a])}catch(c){if(c.message!==$U.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await rb.closeEnvironment(global.lmdb_map[n]),await rb.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==$U.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){t8.error(t)}}o(r8,"cleanLMDBMap")});var Ro=M((qNe,n8)=>{n8.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 ei=M(($Ne,zU)=>{var s8=Ro(),{promisify:i8}=require("util"),{getDatabases:WU}=(Le(),v(ft));zU.exports={setSchemaDataToGlobal:YU,getTableSchema:o8,getSystemSchema:a8,setSchemaDataToGlobalAsync:i8(YU)};function YU(e){global.hdb_schema=WU(),e&&e()}o(YU,"setSchemaDataToGlobal");function o8(e,t,r){let n=WU()[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(o8,"getTableSchema");function a8(){return s8}o(a8,"getSystemSchema")});var ax=M((YNe,ox)=>{"use strict";var nb=require("recursive-iterator"),c8=require("alasql"),sb=require("clone"),jU=ie(),{handleHDBError:QU,hdbErrors:l8}=Ee(),{HDB_ERROR_MSGS:JU,HTTP_STATUS_CODES:XU}=l8,{getDatabases:u8}=(Le(),v(ft)),d8=["DISTINCT_ARRAY"],ZU=Symbol("validateTables"),ib=Symbol("validateTable"),KNe=Symbol("getAllColumns"),ex=Symbol("validateAllColumns"),L_=Symbol("findColumn"),tx=Symbol("validateOrderBy"),Am=Symbol("validateSegment"),ob=Symbol("validateColumn"),rx=Symbol("setColumnsForTable"),nx=Symbol("checkColumnsForAsterisk"),sx=Symbol("validateGroupBy"),ix=Symbol("hasColumns"),ab=class{static{o(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[ZU](),this[nx](),this[ex]()}[ZU](){if(this[ix]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[ib](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[ib](t.table)})}}[ix](){let t=!1,r=new nb(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[ib](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=u8();if(!r[t.databaseid])throw QU(new Error,JU.SCHEMA_NOT_FOUND(t.databaseid),XU.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw QU(new Error,JU.TABLE_NOT_FOUND(t.databaseid,t.tableid),XU.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=sb(s);i.table=sb(t),this.attributes.push(i)})}[L_](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)}[nx](){let t=new nb(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[rx](r.tableid)}[rx](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new c8.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[ex](){this[Am](this.statement.columns,!1),this[Am](this.statement.joins,!1),this[Am](this.statement.where,!1),this[sx](this.statement.group,!1),this[Am](this.statement.order,!0)}[Am](t,r){if(!t)return;let n=new nb(t),s=[];for(let{node:i,path:a}of n)!jU.isEmpty(i)&&!jU.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[tx](i):s.push(this[ob](i)));return s}[sx](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&d8.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=sb(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[L_](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[L_](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`}[tx](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[ob](t)}[ob](t){let r=this[L_](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]}};ox.exports=ab});var lx=M((zNe,cx)=>{"use strict";var cb=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")}};cx.exports=cb});var dx=M((QNe,ux)=>{"use strict";var lb=class{static{o(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};ux.exports=lb});var mx=M((XNe,fx)=>{"use strict";var ub=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}};fx.exports=ub});var px=M((ewe,hx)=>{"use strict";var db=class{static{o(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};hx.exports=db});var Xc=M((iwe,gx)=>{"use strict";var f8=_t(),m8=dx(),h8=mx(),p8=px(),Pi=An(),bm=tn().LMDB_ERRORS_ENUM,E8=kt(),yo=(k(),v(K)),_8=ie(),g8=require("uuid"),rwe=require("lmdb"),{handleHDBError:S8,hdbErrors:T8}=Ee(),{OVERFLOW_MARKER:nwe,MAX_SEARCH_KEY_LENGTH:swe}=E8,Ex=ce();Ex.initSync();var D_=Ex.get(yo.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),fb=yo.TIME_STAMP_NAMES_ENUM.CREATED_TIME,Jc=yo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function R8(e,t,r,n,s=Pi.getNextMonotonicTime()){Eb(e,t,r,n),mb(e,t,r);let i=new m8,a=[],c=[];for(let l=0;l<n.length;l++){let u=n[l];_x(u,!0,s);let d=y8(e,t,r,u),f=u[t];a.push(d),c.push(f)}return hb(a,c,n,i,s)}o(R8,"insertRecords");function y8(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][yo.FUNC_VAL],n[a]=c)}let l=Pi.getIndexedValues(c),u=e.dbis[a];if(l){D_&&u.prefetch(l.map(d=>({key:d,value:s})),M_);for(let d=0,f=l.length;d<f;d++)u.put(l[d],s)}}D_&&e.dbis[t].prefetch([s],M_),e.dbis[t].put(s,n,n[Jc])})}o(y8,"insertRecord");function A8(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}o(A8,"removeSkippedRecords");function _x(e,t,r){let n=r>0;(n||!Number.isInteger(e[Jc]))&&(e[Jc]=r||(r=Pi.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[fb]))&&(e[fb]=r||Pi.getNextMonotonicTime()):delete e[fb]}o(_x,"setTimestamps");function mb(e,t,r){r.indexOf(yo.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(yo.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(yo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(yo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),f8.initializeDBIs(e,t,r)}o(mb,"initializeTransaction");async function b8(e,t,r,n,s=Pi.getNextMonotonicTime()){Eb(e,t,r,n),mb(e,t,r);let i=new h8,a=[],c=[],l=[];for(let u=0;u<n.length;u++){let d=n[u],f=d[t],m;try{m=pb(e,t,d,f,i,!0,s)}catch{i.skipped_hashes.push(f),a.push(u);continue}c.push(m),l.push(f)}return hb(c,l,n,i,s,a)}o(b8,"updateRecords");async function I8(e,t,r,n,s=Pi.getNextMonotonicTime()){try{Eb(e,t,r,n)}catch(l){throw S8(l,l.message,T8.HTTP_STATUS_CODES.BAD_REQUEST)}mb(e,t,r);let i=new p8,a=[],c=[];for(let l=0;l<n.length;l++){let u=n[l],d;_8.isEmpty(u[t])?(d=g8.v4(),u[t]=d):d=u[t];let f=pb(e,t,u,d,i,!1,s);a.push(f),c.push(d)}return hb(a,c,n,i,s)}o(I8,"upsertRecords");async function hb(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||Pi.getNextMonotonicTime(),A8(r,i),n}o(hb,"finalizeWrite");function pb(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(_x(r,!d,a),Number.isInteger(r[Jc])&&u[Jc]>r[Jc])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][yo.FUNC_VAL],r[p]=_)}if(_===y)continue;let T=Pi.getIndexedValues(y);if(T){D_&&g.prefetch(T.map(R=>({key:R,value:n})),M_);for(let R=0,I=T.length;R<I;R++)g.remove(T[R],n)}if(T=Pi.getIndexedValues(_),T){D_&&g.prefetch(T.map(R=>({key:R,value:n})),M_);for(let R=0,I=T.length;R<I;R++)g.put(T[R],n)}}let h={...u,...r};c.put(n,h,h[Jc])},"doPut");return l?f=c.ifVersion(n,l.version,m):f=c.ifNoExists(n,m),f.then(h=>h?!0:pb(e,t,r,n,s,i,a))}o(pb,"updateUpsertRecord");function N8(e,t,r){if(Pi.validateEnv(e),t===void 0)throw new Error(bm.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(bm.WRITE_ATTRIBUTES_REQUIRED):new Error(bm.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}o(N8,"validateBasic");function Eb(e,t,r,n){if(N8(e,t,r),!Array.isArray(n))throw n===void 0?new Error(bm.RECORDS_REQUIRED):new Error(bm.RECORDS_MUST_BE_ARRAY)}o(Eb,"validateWrite");function M_(){}o(M_,"noop");gx.exports={insertRecords:R8,updateRecords:b8,upsertRecords:I8}});var Tx=M((awe,Sx)=>{"use strict";var w8=require("uuid"),_b=class{static{o(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||w8.v4(),this.schema_table=`${this.schema}.${this.table}`}};Sx.exports=_b});var v_=M((lwe,Rx)=>{"use strict";var O8=Tx(),gb=class extends O8{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}};Rx.exports=gb});var Ax=M((dwe,yx)=>{"use strict";yx.exports=P8;var C8="inserted";function P8(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===C8?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}o(P8,"returnObject")});var U_=M((hwe,Ix)=>{"use strict";var L8=(k(),v(K)),Sb=_t(),D8=Xc(),{getSystemSchemaPath:M8,getSchemaPath:v8}=At(),mwe=Ro(),{validateBySchema:U8}=at(),Im=require("joi"),x8=v_(),B8=Ax(),{handleHDBError:F8,hdbErrors:H8,ClientError:k8}=Ee(),bx=ie(),{HTTP_STATUS_CODES:G8}=H8,q8="inserted";Ix.exports=$8;async function $8(e){let t=U8(e,Im.object({database:Im.string(),schema:Im.string(),table:Im.string().required(),attribute:Im.string().required()}));if(t)throw new k8(t.message);let r=!e.skip_table_check&&bx.checkGlobalSchemaTable(e.schema,e.table);if(r)throw F8(new Error,r,G8.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=bx.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 x8(e.schema,e.table,e.attribute,e.id);try{let i=await Sb.openEnvironment(v8(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}`);Sb.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let a=await Sb.openEnvironment(M8(),L8.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await D8.insertRecords(a,HDB_TABLE_INFO.hash_attribute,hdbAttributeAttributes,[s]);return B8(q8,c,{records:[s]},l)}catch(i){throw i}}o($8,"lmdbCreateAttribute")});var Di=M((Ewe,wx)=>{"use strict";var Nx=ie(),V8=(k(),v(K)),Lu=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Li=require("joi"),Na={schema_format:{pattern:Lu,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},K8=Li.alternatives(Li.string().min(1).max(Na.schema_length.maximum).pattern(Lu).messages({"string.pattern.base":"{:#label} "+Na.schema_format.message}),Li.number(),Li.array()).required(),Y8=Li.alternatives(Li.string().min(1).max(Na.schema_length.maximum).pattern(Lu).messages({"string.pattern.base":"{:#label} "+Na.schema_format.message}),Li.number()),W8=Li.alternatives(Li.string().min(1).max(Na.schema_length.maximum).pattern(Lu).messages({"string.pattern.base":"{:#label} "+Na.schema_format.message}),Li.number()).required();function z8(e,t){return t?typeof t!="string"?`'${property_name}' must be a string`:t.length?t.length>Na.schema_length.maximum?`'${property_name}' maximum of 250 characters`:Lu.test(t)?"":`'${property_name}' has illegal characters`:`'${property_name}' must be at least one character`:`'${property_name}' is required`}o(z8,"checkValidTable");function j8(e,t){return Nx.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}o(j8,"validateSchemaExists");function Q8(e,t){let r=t.state.ancestors[0].schema;return Nx.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}o(Q8,"validateTableExists");function J8(e,t){return e.toLowerCase()===V8.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${hdb_terms.SYSTEM_SCHEMA_NAME}' name is reserved`):e}o(J8,"validateSchemaName");wx.exports={commonValidators:Na,schemaRegex:Lu,hdbSchemaTable:K8,validateSchemaExists:j8,validateTableExists:Q8,validateSchemaName:J8,checkValidTable:z8,hdbDatabase:Y8,hdbTable:W8}});var Rb=M((gwe,Cx)=>{var{hdbTable:X8,hdbDatabase:Ox}=Di(),Z8=at(),Tb=require("joi"),e5={undefined:"undefined",null:"null"},t5=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||e5[a]!==void 0)&&(s===void 0?s=`Invalid attribute name: '${a}'`:s+=`. Invalid attribute name: '${a}'`)}return s?t.message(s):e},"customRecordsVal"),r5=Tb.object({database:Ox,schema:Ox,table:X8,records:Tb.array().items(Tb.object().custom(t5)).required()});Cx.exports=function(e){return Z8.validateBySchema(e,r5)}});var Nm=M((Rwe,Lx)=>{"use strict";var Ao=ie(),Px=z(),Twe=Rb(),{getDatabases:n5}=(Le(),v(ft)),{ClientError:Zc}=Ee();Lx.exports=s5;function s5(e){if(Ao.isEmpty(e))throw new Zc("invalid update parameters defined.");if(Ao.isEmptyOrZeroLength(e.schema))throw new Zc("invalid schema specified.");if(Ao.isEmptyOrZeroLength(e.table))throw new Zc("invalid table specified.");if(!Array.isArray(e.records))throw new Zc("records must be an array");let t=n5()[e.schema]?.[e.table];if(Ao.isEmpty(t))throw new Zc(`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&&Ao.isEmptyOrZeroLength(a[r]))throw Px.error("a valid hash attribute must be provided with update record:",a),new Zc("a valid hash attribute must be provided with update record, check log for more info");if(!Ao.isEmptyOrZeroLength(a[r])&&(a[r]==="null"||a[r]==="undefined"))throw Px.error(`a valid hash value must be provided with ${e.operation} record:`,a),new Zc(`Invalid hash value: '${a[r]}' is not a valid hash attribute value, check log for more info`);!Ao.isEmpty(a[r])&&a[r]!==""&&n.has(Ao.autoCast(a[r]))&&(a.skip=!0),n.add(Ao.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(s5,"insertUpdateValidate")});var x_=M((Awe,Mx)=>{"use strict";var Dx=ie(),i5=(k(),v(K)),o5=z(),a5=U_(),c5=v_(),l5=bo(),{SchemaEventMsg:u5}=ti(),d5="already exists in";Mx.exports=f5;async function f5(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 m5(e,t.schema,t.name,i)})),s}o(f5,"lmdbCheckForNewAttributes");async function m5(e,t,r,n){let s=new c5(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await h5(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(d5))o5.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}o(m5,"createNewAttribute");async function h5(e){let t;return t=await a5(e),l5.signalSchemaChange(new u5(process.pid,i5.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}o(h5,"createAttribute")});var Du=M((Iwe,vx)=>{"use strict";var yb=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}};vx.exports=yb});var xx=M((wwe,Ux)=>{"use strict";var p5=Du(),E5=(k(),v(K)).OPERATIONS_ENUM,Ab=class extends p5{static{o(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(E5.INSERT,r,n,s,i),this.records=t}};Ux.exports=Ab});var Fx=M((Cwe,Bx)=>{"use strict";var _5=Du(),g5=(k(),v(K)).OPERATIONS_ENUM,bb=class extends _5{static{o(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,a=void 0){super(g5.UPDATE,n,s,i,a),this.records=t,this.original_records=r}};Bx.exports=bb});var kx=M((Lwe,Hx)=>{"use strict";var S5=Du(),T5=(k(),v(K)).OPERATIONS_ENUM,Ib=class extends S5{static{o(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,a=void 0){super(T5.UPSERT,n,s,i,a),this.records=t,this.original_records=r}};Hx.exports=Ib});var qx=M((Mwe,Gx)=>{"use strict";var R5=Du(),y5=(k(),v(K)).OPERATIONS_ENUM,Nb=class extends R5{static{o(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(y5.DELETE,n,s,t,i),this.original_records=r}};Gx.exports=Nb});var wm=M((xwe,Yx)=>{"use strict";var Uwe=require("path"),$x=_t(),A5=xx(),b5=Fx(),I5=kx(),N5=qx(),Mu=kt(),Vx=ie(),{CONFIG_PARAMS:w5}=(k(),v(K)),Kx=ce();Kx.initSync();var B_=(k(),v(K)).OPERATIONS_ENUM,{getTransactionAuditStorePath:O5}=At();Yx.exports=C5;async function C5(e,t){if(Kx.get(w5.LOGGING_AUDITLOG)===!1)return;let r=O5(e.schema,e.table),n=await $x.openEnvironment(r,e.table,!0),s=P5(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){$x.initializeDBIs(n,Mu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Mu.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[Mu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[Mu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),Vx.isEmpty(s.user_name)||n.dbis[Mu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let a=0;a<s.hash_values.length;a++)n.dbis[Mu.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[a],i)})}}o(C5,"writeTransaction");function P5(e,t){let r=Vx.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===B_.INSERT)return new A5(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===B_.UPDATE)return new b5(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===B_.UPSERT)return new I5(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===B_.DELETE)return new N5(t.deleted,t.original_records,r,t.txn_time,e.__origin)}o(P5,"createTransactionObject")});var wb=M((Hwe,Wx)=>{"use strict";var L5=Nm(),Fwe=Wf(),Om=(k(),v(K)),D5=zf(),M5=Xc().insertRecords,v5=_t(),U5=z(),x5=x_(),{getSchemaPath:B5}=At(),F5=wm();Wx.exports=H5;async function H5(e){try{let{schemaTable:t,attributes:r}=L5(e);D5(e,r,t.hash_attribute),e.schema!==Om.SYSTEM_SCHEMA_NAME&&(r.includes(Om.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(Om.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(Om.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(Om.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await x5(e.hdb_auth_header,t,r),s=B5(e.schema,e.table),i=await v5.openEnvironment(s,e.table),a=await M5(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await F5(e,a)}catch(c){U5.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(H5,"lmdbCreateRecords")});var Qx=M((Gwe,jx)=>{"use strict";var zx=(k(),v(K)),k5=wb(),G5=Wf(),q5=require("fs-extra"),{getSchemaPath:$5}=At();jx.exports=V5;async function V5(e){let t=[{name:e.schema,createddate:Date.now()}],r=new G5(zx.SYSTEM_SCHEMA_NAME,zx.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await k5(r),await q5.mkdirp($5(e.schema))}o(V5,"lmdbCreateSchema")});var Xx=M(($we,Jx)=>{"use strict";var Ob=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}};Jx.exports=Ob});var r0=M((zwe,t0)=>{"use strict";var Zx=_t(),Cb=An(),Pb=tn().LMDB_ERRORS_ENUM,K5=kt(),e0=z(),Kwe=ie(),Y5=require("lmdb"),W5=Xx(),z5=(k(),v(K)),{OVERFLOW_MARKER:Ywe,MAX_SEARCH_KEY_LENGTH:Wwe}=K5,j5=z5.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function Q5(e,t,r,n){if(Cb.validateEnv(e),t===void 0)throw new Error(Pb.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(Pb.IDS_REQUIRED):new Error(Pb.IDS_MUST_BE_ITERABLE);try{let s=Zx.listDBIs(e);Zx.initializeDBIs(e,t,s);let i=new W5,a,c=[],l=[];for(let m=0,h=r.length;m<h;m++)try{a=r[m];let p=e.dbis[t].get(a);if(!p||n&&p[j5]>n){i.skipped.push(a);continue}let _=e.dbis[t].ifVersion(a,Y5.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=Cb.getIndexedValues(R);if(I)for(let P=0,Y=I.length;P<Y;P++)T.remove(I[P],a)}catch{e0.warn(`cannot delete from attribute: ${y}, ${R}:${a}`)}}});c.push(_),l.push(a),i.original_records.push(p)}catch(p){e0.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=Cb.getNextMonotonicTime(),i}catch(s){throw s}}o(Q5,"deleteRecords");t0.exports={deleteRecords:Q5}});var Cm=M((Qwe,s0)=>{"use strict";var vu=ie(),J5=r0(),X5=_t(),{getSchemaPath:Z5}=At(),e9=wm(),t9=z();s0.exports=r9;async function r9(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(vu.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(vu.isEmptyOrZeroLength(e.hash_values)&&!vu.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];vu.isEmpty(l)||e.hash_values.push(l)}}if(vu.isEmptyOrZeroLength(e.hash_values))return n0([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(vu.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=Z5(e.schema,e.table),i=await X5.openEnvironment(s,e.table),a=await J5.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await e9(e,a)}catch(c){t9.error(`unable to write transaction due to ${c.message}`)}return n0(a.deleted,a.skipped,a.txn_time)}catch(s){throw s}}o(r9,"lmdbDeleteRecords");function n0(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(n0,"createDeleteResponse")});var Db=M((Zwe,i0)=>{"use strict";var n9=(k(),v(K)),Xwe=An();function Lb(e,t){let r=Object.create(null);if(t.length===1&&n9.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(Lb,"parseRow");function s9(e,t,r,n){let s=Lb(r,e);n.push(s)}o(s9,"searchAll");function i9(e,t,r,n){let s=Lb(r,e);n[t]=s}o(i9,"searchAllToMap");function o9(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}o(o9,"iterateDBI");function el(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(el,"pushResults");function a9(e,t,r,n,s,i){t.toString().endsWith(e)&&el(t,r,n,s,i)}o(a9,"endsWith");function c9(e,t,r,n,s,i){t.toString().includes(e)&&el(t,r,n,s,i)}o(c9,"contains");function l9(e,t,r,n,s,i){t>e&&el(t,r,n,s,i)}o(l9,"greaterThanCompare");function u9(e,t,r,n,s,i){t>=e&&el(t,r,n,s,i)}o(u9,"greaterThanEqualCompare");function d9(e,t,r,n,s,i){t<e&&el(t,r,n,s,i)}o(d9,"lessThanCompare");function f9(e,t,r,n,s,i){t<=e&&el(t,r,n,s,i)}o(f9,"lessThanEqualCompare");i0.exports={parseRow:Lb,searchAll:s9,searchAllToMap:i9,iterateDBI:o9,endsWith:a9,contains:c9,greaterThanCompare:l9,greaterThanEqualCompare:u9,lessThanCompare:d9,lessThanEqualCompare:f9,pushResults:el}});var Uu=M((sOe,f0)=>{"use strict";var wa=_t(),tOe=z(),Wn=An(),F_=kt(),Jt=tn().LMDB_ERRORS_ENUM,rOe=ie(),m9=(k(),v(K)),H_=Db(),{parseRow:h9}=H_,nOe=require("lmdb"),{OVERFLOW_MARKER:o0,MAX_SEARCH_KEY_LENGTH:p9}=F_;function a0(e,t,r,n=!1,s=void 0,i=void 0){return tl(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(a0,"iterateFullIndex");function Pm(e,t,r,n,s,i=!1,a=void 0,c=void 0,l=!1,u=!1){return tl(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(Pm,"iterateRangeBetween");function tl(e,t,r,n){let s=e.database||e,i=wa.openDBI(s,r);i[F_.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&wa.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(tl,"setupTransaction");function c0(e,t,r,n){let s;return function(i,a){if(typeof i=="string"&&i.endsWith(o0)){if(!s)if(r)s=wa.openDBI(e,r);else{let l=wa.listDBIs(e);for(let u=0,d=l.length;u<d&&(s=wa.openDBI(e,l[u]),!s[F_.DBI_DEFINITION_NAME].is_hash_attribute);u++);}i=s.get(a,{transaction:t,lazy:!0})[n]}return i}}o(c0,"getOverflowCheck");function E9(e,t,r,n=!1,s=void 0,i=void 0){if(Wn.validateEnv(e),t===void 0)throw new Error(Jt.HASH_ATTRIBUTE_REQUIRED);return tl(e,t,t,(a,c,l)=>(k_(r),r=Lm(l,r),c.getRange({transaction:a,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(u=>h9(u.value,r))))}o(E9,"searchAll");function _9(e,t,r,n=!1,s=void 0,i=void 0){if(Wn.validateEnv(e),t===void 0)throw new Error(Jt.HASH_ATTRIBUTE_REQUIRED);k_(r),r=Lm(e.database||e,r);let a=new Map;for(let{key:c,value:l}of a0(e,t,t,n,s,i))a.set(c,H_.parseRow(l,r));return a}o(_9,"searchAllToMap");function g9(e,t,r=!1,n=void 0,s=void 0){if(Wn.validateEnv(e),t===void 0)throw new Error(Jt.ATTRIBUTE_REQUIRED);let i=Object.create(null),a=a0(e,void 0,t,r,n,s),c=a.transaction,l=c0(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(g9,"iterateDBI");function S9(e,t){if(Wn.validateEnv(e),t===void 0)throw new Error(Jt.HASH_ATTRIBUTE_REQUIRED);return wa.statDBI(e,t).entryCount}o(S9,"countAll");function T9(e,t,r,n,s=!1,i=void 0,a=void 0){return Oa(e,r,n),tl(e,t,r,(c,l,u,d)=>(n=Wn.convertKeyValueToWrite(n),d===r?l.get(n,{transaction:c,lazy:!0})===void 0?[]:[{key:n,value:n}]:l.getValues(n,{transaction:c,reverse:s,limit:i,offset:a}).map(f=>({key:n,value:f}))))}o(T9,"equals");function R9(e,t,r){return Oa(e,t,r),wa.openDBI(e,t).getValuesCount(r)}o(R9,"count");function y9(e,t,r,n,s=!1,i=void 0,a=void 0){return Oa(e,r,n),tl(e,null,r,(c,l)=>{n=Wn.convertKeyValueToWrite(n);let u=!0;typeof n=="number"&&(u=!1);let d;if(s===!0){let f;for(let m of l.getKeys({transaction:c,start:n}))if(!m.startsWith(n)){f=m;break}return f!==void 0&&(Number.isInteger(a)?a++:i++),d=l.getRange({transaction:c,start:f,end:void 0,reverse:s,limit:i,offset:a}).map(m=>{let{key:h}=m;if(h!==f){if(h.toString().startsWith(n))return m;if(u===!0)return d.DONE}}),d.filter(m=>m)}else return d=l.getRange({transaction:c,start:n,reverse:s,limit:i,offset:a}).map(f=>{if(f.key.toString().startsWith(n))return f;if(u===!0)return d.DONE}),u?d:d.filter(f=>f)})}o(y9,"startsWith");function A9(e,t,r,n,s=!1,i=void 0,a=void 0){return l0(e,t,r,n,s,i,a,!0)}o(A9,"endsWith");function l0(e,t,r,n,s=!1,i=void 0,a=void 0,c=!1){return Oa(e,r,n),tl(e,null,r,(l,u,d,f)=>{let m=c0(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(o0)?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[F_.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(l0,"contains");function b9(e,t,r,n,s=!1,i=void 0,a=void 0){Oa(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),Pm(e,t,r,n,l,s,i,a,!0,!1)}o(b9,"greaterThan");function I9(e,t,r,n,s=!1,i=void 0,a=void 0){Oa(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),Pm(e,t,r,n,l,s,i,a,!1,!1)}o(I9,"greaterThanEqual");function N9(e,t,r,n,s=!1,i=void 0,a=void 0){Oa(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),Pm(e,t,r,l,n,s,i,a,!1,!0)}o(N9,"lessThan");function w9(e,t,r,n,s=!1,i=void 0,a=void 0){Oa(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),Pm(e,t,r,l,n,s,i,a,!1,!1)}o(w9,"lessThanEqual");function O9(e,t,r,n,s,i=!1,a=void 0,c=void 0){if(Wn.validateEnv(e),r===void 0)throw new Error(Jt.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(Jt.START_VALUE_REQUIRED);if(s===void 0)throw new Error(Jt.END_VALUE_REQUIRED);if(n=Wn.convertKeyValueToWrite(n),s=Wn.convertKeyValueToWrite(s),n>s)throw new Error(Jt.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return Pm(e,t,r,n,s,i,a,c)}o(O9,"between");function C9(e,t,r,n){Wn.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(Jt.HASH_ATTRIBUTE_REQUIRED);if(k_(r),r=Lm(s,r),n===void 0)throw new Error(Jt.ID_REQUIRED);let a=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(a=H_.parseRow(c,r)),a}o(C9,"searchByHash");function P9(e,t,r){Wn.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(Jt.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Jt.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}o(P9,"checkHashExists");function L9(e,t,r,n,s=[]){return d0(e,t,r,n,s),u0(e,t,r,n,s).map(i=>i[1])}o(L9,"batchSearchByHash");function D9(e,t,r,n,s=[]){d0(e,t,r,n,s);let i=new Map;for(let[a,c]of u0(e,t,r,n,s))i.set(a,c);return i}o(D9,"batchSearchByHashToMap");function u0(e,t,r,n,s=[]){return tl(e,t,t,(i,a,c)=>{r=Lm(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,H_.parseRow(d,r)];s.push(u)}).filter(u=>u)})}o(u0,"batchHashSearch");function d0(e,t,r,n,s){if(Wn.validateEnv(e),t===void 0)throw new Error(Jt.HASH_ATTRIBUTE_REQUIRED);if(k_(r),n==null)throw new Error(Jt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(Jt.IDS_MUST_BE_ITERABLE)}o(d0,"initializeBatchSearchByHash");function k_(e){if(!Array.isArray(e))throw e===void 0?new Error(Jt.FETCH_ATTRIBUTES_REQUIRED):new Error(Jt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}o(k_,"validateFetchAttributes");function Oa(e,t,r){if(Wn.validateEnv(e),t===void 0)throw new Error(Jt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Jt.SEARCH_VALUE_REQUIRED);if(r?.length>p9)throw new Error(Jt.SEARCH_VALUE_TOO_LARGE)}o(Oa,"validateComparisonFunctions");function Lm(e,t){return t.length===1&&m9.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=wa.listDBIs(e)),t}o(Lm,"setGetWholeRowAttributes");f0.exports={searchAll:E9,searchAllToMap:_9,count:R9,countAll:S9,equals:T9,startsWith:y9,endsWith:A9,contains:l0,searchByHash:C9,setGetWholeRowAttributes:Lm,batchSearchByHash:L9,batchSearchByHashToMap:D9,checkHashExists:P9,iterateDBI:g9,greaterThan:b9,greaterThanEqual:I9,lessThan:N9,lessThanEqual:w9,between:O9}});var xu=M((oOe,_0)=>{var m0=require("lodash"),h0=at(),$e=require("joi"),M9=ie(),{hdbSchemaTable:Dm,checkValidTable:p0,hdbTable:E0,hdbDatabase:G_}=Di(),{handleHDBError:v9,hdbErrors:U9}=Ee(),{getDatabases:x9}=(Le(),v(ft)),{HTTP_STATUS_CODES:B9}=U9,F9=$e.object({database:G_,schema:G_,table:E0,search_attribute:Dm,search_value:$e.any().required(),get_attributes:$e.array().min(1).items($e.alternatives(Dm,$e.object())).optional(),desc:$e.bool(),limit:$e.number().integer().min(1),offset:$e.number().integer().min(0)}),H9=$e.object({database:G_,schema:G_,table:E0,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(Dm,$e.object())).optional(),sort:$e.object({attribute:$e.alternatives(Dm,$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(Dm,$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()});_0.exports=function(e,t){let r=null;switch(t){case"value":r=h0.validateBySchema(e,F9);break;case"hashes":let i=function(a){s?s+=". "+a:s=a};var n=i;o(i,"addError");let s;i(p0("database",e.schema)),i(p0("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=h0.validateBySchema(e,H9);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=M9.checkGlobalSchemaTable(e.schema,e.table);if(s)return v9(new Error,s,B9.NOT_FOUND);let a=x9()[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=m0.filter(c,d=>d!=="*"&&!d.startsWith?.("$")&&d.attribute!=="*"&&!Array.isArray(d)&&!d.name&&!m0.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 Mb=M((cOe,g0)=>{"use strict";var k9=_t(),G9=xu(),{getSchemaPath:q9}=At();g0.exports=$9;function $9(e){let t=G9(e,"hashes");if(t)throw t;let r=q9(e.schema,e.table);return k9.openEnvironment(r,e.table)}o($9,"initialize")});var vb=M((uOe,S0)=>{"use strict";var V9=Uu(),K9=Mb();S0.exports=Y9;async function Y9(e){let t=await K9(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return V9.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}o(Y9,"lmdbGetDataByHash")});var Bu=M((fOe,T0)=>{"use strict";var Ub=class{static{o(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};T0.exports=Ub});var y0=M((pOe,R0)=>{"use strict";var hOe=Bu(),W9=Uu(),z9=Mb();R0.exports=j9;async function j9(e){let t=await z9(e),r=global.hdb_schema[e.schema][e.table];return W9.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}o(j9,"lmdbSearchByHash")});var ri=M((_Oe,A0)=>{"use strict";var xb=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}};A0.exports=xb});var q_=M((SOe,C0)=>{"use strict";var sn=Uu(),Q9=_t(),J9=ie(),Ve=kt(),rl=(k(),v(K)),X9=Ro(),b0=tn().LMDB_ERRORS_ENUM,{getSchemaPath:Z9}=At(),Io=rl.SEARCH_WILDCARDS;async function e7(e,t,r){let n;e.schema===rl.SYSTEM_SCHEMA_NAME?n=X9[e.table]:n=global.hdb_schema[e.schema][e.table];let s=O0(e,n.hash_attribute,r,t);return N0(e,s,n.hash_attribute,r)}o(e7,"prepSearch");async function N0(e,t,r,n){let s=Z9(e.schema,e.table),i=await Q9.openEnvironment(s,e.table),a=w0(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(t7(e,r)===!1){let d=e.search_attribute;if(d===r)return n?I0(a,()=>!0):a.map(m=>({[r]:m.key}));let f=o(m=>({[r]:m.value,[d]:m.key}),"toObject");return n?I0(a,f):a.map(f)}let u=e.search_attribute===r?a.map(d=>d.key):a.map(d=>d.value);return n===!0?sn.batchSearchByHashToMap(c,r,e.get_attributes,u):sn.batchSearchByHash(c,r,e.get_attributes,u)}o(N0,"executeSearch");function w0(e,t,r,n){let s,i=n;t.get_attributes.indexOf(n)<0&&(i=void 0);let{reverse:a,limit:c,offset:l}=t;switch(a=typeof a=="boolean"?a:!1,c=Number.isInteger(c)?c:void 0,l=Number.isInteger(l)?l:void 0,r){case Ve.SEARCH_TYPES.EQUALS:s=sn.equals(e,i,t.search_attribute,t.search_value,a,c,l);break;case Ve.SEARCH_TYPES.CONTAINS:s=sn.contains(e,i,t.search_attribute,t.search_value,a,c,l);break;case Ve.SEARCH_TYPES.ENDS_WITH:case Ve.SEARCH_TYPES._ENDS_WITH:s=sn.endsWith(e,i,t.search_attribute,t.search_value,a,c,l);break;case Ve.SEARCH_TYPES.STARTS_WITH:case Ve.SEARCH_TYPES._STARTS_WITH:s=sn.startsWith(e,i,t.search_attribute,t.search_value,a,c,l);break;case Ve.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return sn.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case Ve.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return sn.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case Ve.SEARCH_TYPES.SEARCH_ALL:return sn.searchAll(e,n,t.get_attributes,a,c,l);case Ve.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return sn.searchAllToMap(e,n,t.get_attributes,a,c,l);case Ve.SEARCH_TYPES.BETWEEN:s=sn.between(e,i,t.search_attribute,t.search_value,t.end_value,a,c,l);break;case Ve.SEARCH_TYPES.GREATER_THAN:case Ve.SEARCH_TYPES._GREATER_THAN:s=sn.greaterThan(e,i,t.search_attribute,t.search_value,a,c,l);break;case Ve.SEARCH_TYPES.GREATER_THAN_EQUAL:case Ve.SEARCH_TYPES._GREATER_THAN_EQUAL:s=sn.greaterThanEqual(e,i,t.search_attribute,t.search_value,a,c,l);break;case Ve.SEARCH_TYPES.LESS_THAN:case Ve.SEARCH_TYPES._LESS_THAN:s=sn.lessThan(e,i,t.search_attribute,t.search_value,a,c,l);break;case Ve.SEARCH_TYPES.LESS_THAN_EQUAL:case Ve.SEARCH_TYPES._LESS_THAN_EQUAL:s=sn.lessThanEqual(e,i,t.search_attribute,t.search_value,a,c,l);break;default:return Object.create(null)}return s}o(w0,"searchByType");function I0(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}o(I0,"createMapFromIterable");function t7(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(t7,"checkToFetchMore");function O0(e,t,r,n){if(J9.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),Io.indexOf(s)>-1)return r===!0?Ve.SEARCH_TYPES.SEARCH_ALL_TO_MAP:Ve.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(Io[0])<0&&s.indexOf(Io[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(Io.indexOf(i)>=0&&Io.indexOf(a)>=0)return e.search_value=e.search_value.slice(1,-1),Ve.SEARCH_TYPES.CONTAINS;if(Io.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),Ve.SEARCH_TYPES.ENDS_WITH;if(Io.indexOf(a)>=0)return e.search_value=e.search_value.slice(0,-1),Ve.SEARCH_TYPES.STARTS_WITH;if(s.includes(Io[0])||s.includes(Io[1]))return Ve.SEARCH_TYPES.EQUALS;throw new Error(b0.UNKNOWN_SEARCH_TYPE)}else switch(n){case rl.VALUE_SEARCH_COMPARATORS.BETWEEN:return Ve.SEARCH_TYPES.BETWEEN;case rl.VALUE_SEARCH_COMPARATORS.GREATER:return Ve.SEARCH_TYPES.GREATER_THAN;case rl.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return Ve.SEARCH_TYPES.GREATER_THAN_EQUAL;case rl.VALUE_SEARCH_COMPARATORS.LESS:return Ve.SEARCH_TYPES.LESS_THAN;case rl.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return Ve.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(b0.UNKNOWN_SEARCH_TYPE)}}o(O0,"createSearchTypeFromSearchObject");C0.exports={executeSearch:N0,createSearchTypeFromSearchObject:O0,prepSearch:e7,searchByType:w0}});var L0=M((yOe,P0)=>{"use strict";var ROe=ri(),r7=xu(),n7=ie(),s7=(k(),v(K)),i7=q_();P0.exports=o7;function o7(e,t){if(!n7.isEmpty(t)&&s7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=r7(e,"value");if(n)throw n;return i7.prepSearch(e,t,!0)}o(o7,"lmdbGetDataByValue")});var Mm=M((IOe,D0)=>{"use strict";var bOe=ri(),a7=xu(),c7=ie(),l7=(k(),v(K)),u7=q_();D0.exports=d7;async function d7(e,t){if(!c7.isEmpty(t)&&l7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=a7(e,"value");if(n)throw n;return u7.prepSearch(e,t,!1)}o(d7,"lmdbSearchByValue")});var v0=M((OOe,M0)=>{"use strict";var wOe=kt(),Bb=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}},Fb=class{static{o(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},Hb=class{static{o(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};M0.exports={SearchByConditionsObject:Bb,SearchCondition:Fb,SortAttribute:Hb}});var H0=M((DOe,F0)=>{"use strict";var POe=v0().SearchByConditionsObject,f7=ri(),m7=xu(),kb=Uu(),$_=kt(),{Resource:LOe}=(ba(),v(_U)),B0=q_(),h7=Db(),p7=require("lodash"),{getSchemaPath:E7}=At(),U0=_t(),{handleHDBError:_7,hdbErrors:g7}=Ee(),{HTTP_STATUS_CODES:S7}=g7,T7=1e8;F0.exports=R7;async function R7(e){let t=m7(e,"conditions");if(t)throw _7(t,t.message,S7.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=E7(e.schema,e.table),n=await U0.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let u of e.conditions)U0.openDBI(n,u.search_attribute);let i=p7.sortBy(e.conditions,u=>{if(u.estimated_count===void 0){let d=u.search_type;d===$_.SEARCH_TYPES.EQUALS?u.estimated_count=kb.count(n,u.search_attribute,u.search_value):d===$_.SEARCH_TYPES.CONTAINS||d===$_.SEARCH_TYPES.ENDS_WITH?u.estimated_count=1/0:u.estimated_count=T7}return u.estimated_count}),a=n.useReadTransaction();a.database=n;let c=await x0(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(B0.filterByType),f=d.length,m=kb.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=>h7.parseRow(h,m))}else{for(let f=1;f<i.length;f++){let m=i[f],h=await x0(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=kb.batchSearchByHash(a,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{a.done()},l}o(R7,"lmdbSearchByConditions");async function x0(e,t,r,n){let s=new f7(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===$_.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,B0.searchByType(e,s,i,n).map(a=>a.value)}o(x0,"executeConditionSearch")});var vm=M((vOe,k0)=>{"use strict";var y7=(k(),v(K)).OPERATIONS_ENUM,Gb=class{static{o(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=y7.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};k0.exports=Gb});var qb=M((xOe,z0)=>{"use strict";var V0=ri(),K0=vm(),Y0=Mm(),W0=Cm(),Pn=(k(),v(K)),G0=ie(),q0=_t(),{getTransactionAuditStorePath:A7,getSchemaPath:b7}=At(),$0=z();z0.exports=I7;async function I7(e){try{if(G0.isEmpty(global.hdb_schema[e.schema])||G0.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await N7(e),await w7(e);let t=b7(e.schema,e.table);try{await q0.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")$0.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=A7(e.schema,e.table);await q0.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")$0.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}o(I7,"lmdbDropTable");async function N7(e){let t=new V0(Pn.SYSTEM_SCHEMA_NAME,Pn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Pn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Pn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await Y0(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 K0(Pn.SYSTEM_SCHEMA_NAME,Pn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await W0(s)}o(N7,"deleteAttributesFromSystem");async function w7(e){let t=new V0(Pn.SYSTEM_SCHEMA_NAME,Pn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Pn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[Pn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,Pn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,Pn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await Y0(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 K0(Pn.SYSTEM_SCHEMA_NAME,Pn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await W0(s)}catch(i){throw i}}o(w7,"dropTableFromSystem")});var Q0=M((FOe,j0)=>{"use strict";var O7=require("fs-extra"),C7=ri(),P7=Bu(),L7=vm(),D7=qb(),M7=Cm(),v7=vb(),U7=Mm(),No=(k(),v(K)),{getSchemaPath:x7}=At(),{handleHDBError:B7,hdbErrors:F7}=Ee(),{HDB_ERROR_MSGS:H7,HTTP_STATUS_CODES:k7}=F7;j0.exports=G7;async function G7(e){let t;try{t=await q7(e.schema);let r=new C7(No.SYSTEM_SCHEMA_NAME,No.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,No.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[No.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await U7(r));for(let a=0;a<n.length;a++){let c={schema:t,table:n[a].name};try{await D7(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new L7(No.SYSTEM_SCHEMA_NAME,No.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await M7(s);let i=x7(t);await O7.remove(i)}catch(r){throw r}}o(G7,"lmdbDropSchema");async function q7(e){let t=new P7(No.SYSTEM_SCHEMA_NAME,No.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[No.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await v7(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw B7(new Error,H7.SCHEMA_NOT_FOUND(e),k7.NOT_FOUND,void 0,void 0,!0);return n}o(q7,"validateDropSchema")});var Um=M((kOe,J0)=>{"use strict";var $b=class{static{o(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};J0.exports=$b});var Kb=M(($Oe,X0)=>{"use strict";var $7=require("fs-extra"),V_=_t(),{getTransactionAuditStorePath:V7}=At(),Vb=kt(),qOe=Um();X0.exports=K7;async function K7(e){let t;try{let r=V7(e.schema,e.table);await $7.mkdirp(r),t=await V_.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{V_.createDBI(t,Vb.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),V_.createDBI(t,Vb.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),V_.createDBI(t,Vb.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(K7,"createTransactionsAuditEnvironment")});var tB=M((YOe,eB)=>{"use strict";var Yb=(k(),v(K)),Z0=_t(),Y7=Xc(),{getSystemSchemaPath:W7,getSchemaPath:z7}=At(),KOe=Ro(),j7=U_(),Wb=v_(),Q7=z(),J7=Kb();eB.exports=X7;async function X7(e,t){let r=z7(t.schema,t.table),n=new Wb(t.schema,t.table,Yb.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new Wb(t.schema,t.table,Yb.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new Wb(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await Z0.createEnvironment(r,t.table),e!==void 0){let a=await Z0.openEnvironment(W7(),Yb.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await Y7.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 zb(n),await zb(s),await zb(i)}await J7(t)}catch(a){throw a}}o(X7,"lmdbCreateTable");async function zb(e){try{await j7(e)}catch(t){Q7.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}o(zb,"createAttribute")});var nB=M((zOe,rB)=>{"use strict";var Z7=Nm(),eee=zf(),tee=x_(),xm=(k(),v(K)),ree=Xc().updateRecords,nee=_t(),{getSchemaPath:see}=At(),iee=wm(),oee=z();rB.exports=aee;async function aee(e){try{let{schemaTable:t,attributes:r}=Z7(e);eee(e,r,t.hash_attribute),e.schema!==xm.SYSTEM_SCHEMA_NAME&&(r.includes(xm.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(xm.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(xm.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(xm.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await tee(e.hdb_auth_header,t,r),s=see(e.schema,e.table),i=await nee.openEnvironment(s,e.table),a=await ree(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await iee(e,a)}catch(c){oee.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(aee,"lmdbUpdateRecords")});var iB=M((QOe,sB)=>{"use strict";var cee=(k(),v(K)).OPERATIONS_ENUM,jb=class{static{o(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=cee.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};sB.exports=jb});var aB=M((ZOe,oB)=>{"use strict";var XOe=iB(),lee=Nm(),uee=zf(),dee=x_(),Bm=(k(),v(K)),fee=Xc().upsertRecords,mee=_t(),{getSchemaPath:hee}=At(),pee=wm(),Eee=z(),{handleHDBError:_ee,hdbErrors:gee}=Ee();oB.exports=See;async function See(e){let t;try{t=lee(e)}catch(l){throw _ee(l,l.message,gee.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schemaTable:r,attributes:n}=t;uee(e,n,r.hash_attribute),e.schema!==Bm.SYSTEM_SCHEMA_NAME&&(n.includes(Bm.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(Bm.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(Bm.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(Bm.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await dee(e.hdb_auth_header,r,n),i=hee(e.schema,e.table),a=await mee.openEnvironment(i,e.table),c=await fee(a,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await pee(e,c)}catch(l){Eee.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(See,"lmdbUpsertRecords")});var lB=M((tCe,cB)=>{"use strict";var Qb=class{static{o(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};cB.exports=Qb});var dB=M((nCe,uB)=>{"use strict";var Jb=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}};uB.exports=Jb});var hB=M((oCe,mB)=>{"use strict";var Xb=_t(),{getTransactionAuditStorePath:Tee}=At(),iCe=lB(),Fm=kt(),Ree=ie(),fB=dB(),yee=require("util").promisify,Aee=yee(setTimeout),bee=1e4,Iee=100;mB.exports=Nee;async function Nee(e){let t=Tee(e.schema,e.table),r=await Xb.openEnvironment(t,e.table,!0),n=Xb.listDBIs(r);Xb.initializeDBIs(r,Fm.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new fB;do s=await wee(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 Aee(Iee);while(s.transactions_deleted>0);return i}o(Nee,"deleteAuditLogsBefore");async function wee(e,t){let r=new fB;try{let n=e.dbis[Fm.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[Fm.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];Ree.isEmpty(c)||(s=e.dbis[Fm.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<a.hash_values.length;l++)s=e.dbis[Fm.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(a.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>bee)break}return await s,r}catch(n){throw n}}o(wee,"deleteTransactions")});var EB=M((cCe,pB)=>{"use strict";var Zb=class{static{o(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};pB.exports=Zb});var gB=M((dCe,_B)=>{"use strict";var Oee=ri(),Cee=vm(),uCe=EB(),Mi=(k(),v(K)),Pee=ie(),eI=_t(),Lee=Ro(),Dee=Mm(),Mee=Cm(),{getSchemaPath:vee}=At();_B.exports=Uee;async function Uee(e,t=!0){let r;e.schema===Mi.SYSTEM_SCHEMA_NAME?r=Lee[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await Bee(e),s=vee(e.schema,e.table),i=await eI.openEnvironment(s,e.table);return t===!0&&await xee(e,i,r.hash_attribute),eI.dropDBI(i,e.attribute),n}o(Uee,"lmdbDropAttribute");async function xee(e,t,r){let n=eI.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(xee,"removeAttributeFromAllObjects");async function Bee(e){let t=new Oee(Mi.SYSTEM_SCHEMA_NAME,Mi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Mi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Mi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,Mi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await Dee(t)).filter(a=>a[Mi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(Pee.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[Mi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new Cee(Mi.SYSTEM_SCHEMA_NAME,Mi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return Mee(i)}o(Bee,"dropAttributeFromSystem")});var bB=M((hCe,AB)=>{"use strict";var tI=_t(),Fu=kt(),mCe=An(),rI=(k(),v(K)),SB=ie(),{getTransactionAuditStorePath:Fee}=At(),Hee=Uu(),K_=Du(),kee=z();AB.exports=Gee;async function Gee(e){let t=Fee(e.schema,e.table),r=await tI.openEnvironment(t,e.table,!0),n=tI.listDBIs(r);tI.initializeDBIs(r,Fu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case rI.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return TB(r,e.search_values);case rI.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,$ee(r,e.search_values,s);case rI.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return qee(r,e.search_values);default:return TB(r)}}o(Gee,"readAuditLog");function TB(e,t=[0,Date.now()]){SB.isEmpty(t[0])&&(t[0]=0),SB.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[Fu.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(TB,"searchTransactionsByTimestamp");function qee(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[Fu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(a);r.set(s,yB(e,i))}return Object.fromEntries(r)}o(qee,"searchTransactionsByUsername");function $ee(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let u=t[c],d=Hee.equals(e,Fu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Fu.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=yB(e,s),a=new Map;for(let c=0;c<i.length;c++){let l=i[c],u=l.timestamp,d=n.get(u);RB(l,"records",r,d,a),RB(l,"original_records",r,d,a)}return Object.fromEntries(a)}o($ee,"searchTransactionsByHashValues");function RB(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(RB,"loopRecords");function yB(e,t){let r=[];try{let n=e.dbis[Fu.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){kee.warn(i)}return r}catch(n){throw n}}o(yB,"batchSearchTransactions")});var NB=M((gCe,IB)=>{"use strict";var{getSchemaPath:ECe}=At(),_Ce=_t(),{database:Vee}=(Le(),v(ft));IB.exports={writeTransaction:Kee};async function Kee(e,t,r){return Vee({database:e,table:t}).transaction(r)}o(Kee,"writeTransaction")});var PB=M((TCe,CB)=>{"use strict";var{getSchemaPath:wB}=At(),OB=_t();CB.exports={flush:Yee,resetReadTxn:Wee};async function Yee(e,t){return(await OB.openEnvironment(wB(e,t),t.toString())).flushed}o(Yee,"flush");async function Wee(e,t){try{(await OB.openEnvironment(wB(e,t),t.toString())).resetReadTxn()}catch{}}o(Wee,"resetReadTxn")});var vB=M((yCe,MB)=>{"use strict";var{Readable:zee}=require("stream"),{getDatabases:jee}=(Le(),v(ft)),{readSync:Qee,openSync:Jee,createReadStream:LB}=require("fs"),{open:Xee}=require("lmdb"),DB=Tm(),Zee=Rm(),{AUDIT_STORE_OPTIONS:ete}=(uo(),v(rU)),{INTERNAL_DBIS_NAME:tte,AUDIT_STORE_NAME:rte}=kt();MB.exports=ste;var nI=32768,nte=100;async function ste(e){let t=e.database||e.schema||"data",r=jee()[t],n=new Date().toISOString(),s=e.tables||e.table&&[e.table];if(s){let u=r[s[0]];if(!u)throw new Error(`Can not find table ${s[0]}`);let d=u.dbisDB,f=Xee({noSync:!0,maxDbs:Zee.MAX_DBS}),m,h=f.openDB(tte,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),_++%nte===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(rte,{...ete}),await m;let y=LB(f.path);return y.headers=l(),y.on("close",()=>{p.done(),f.close()}),y}let a=r[Object.keys(r)[0]].primaryStore,c=Jee(a.path);return a.transaction(()=>{let u=Buffer.alloc(nI);Qee(c,u,0,nI),a.resetReadTxn();let d=a.useReadTransaction();d.renew();let f=LB(null,{fd:c,start:nI}),m=new zee.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(ste,"getBackup")});var BB=M((bCe,xB)=>{"use strict";var ite=z(),{handleHDBError:ote}=Ee(),ate=lx(),cte=U_(),lte=wb(),ute=Qx(),dte=Cm(),fte=vb(),mte=y0(),hte=L0(),pte=Mm(),Ete=H0(),_te=Q0(),gte=tB(),Ste=nB(),Tte=aB(),Rte=hB(),yte=qb(),Ate=gB(),bte=bB(),Ite=NB(),UB=PB(),Nte=vB(),sI=class extends ate{static{o(this,"LMDBBridge")}async searchByConditions(t){return Ete(t)}async getDataByHash(t){return await fte(t)}async searchByHash(t){return await mte(t)}async getDataByValue(t,r){return await hte(t,r)}async searchByValue(t){return await pte(t)}async createSchema(t){return await ute(t)}async dropSchema(t){return await _te(t)}async createTable(t,r){return await gte(t,r)}async dropTable(t){return await yte(t)}async createAttribute(t){return await cte(t)}async createRecords(t){return await lte(t)}async updateRecords(t){return await Ste(t)}async upsertRecords(t){try{return await Tte(t)}catch(r){throw ote(r,null,null,ite.ERR,r)}}async deleteRecords(t){return await dte(t)}async dropAttribute(t){return await Ate(t)}async deleteAuditLogsBefore(t){return await Rte(t)}async readAuditLog(t){return await bte(t)}writeTransaction(t,r,n){return Ite.writeTransaction(t,r,n)}flush(t,r){return UB.flush(t,r)}resetReadTxn(t,r){return UB.resetReadTxn(t,r)}getBackup(t){return Nte(t)}};xB.exports=sI});function Ln(e){let t=e.getChanges();return t||(t=Object.create(null),e._setChanges(t)),t}function km(e,t,r=!1){let n=e.prototype,s={},i=t.attributes||t.properties||[];for(let l of i){let u=l.name,d,f;if(l.resolve)f={get(){return l.resolve(this,this.getContext?.())},set(m){return l.set(this,m)},configurable:!0};else{switch(l.type){case"String":d=o(function(m){if(!(typeof m=="string"||m==null&&l.nullable!==!1))throw new zn.ClientError(`${u} must be a string, attempt to assign ${m}`);Ln(this)[u]=m},"set");break;case"ID":d=o(function(m){if(!(typeof m=="string"||m?.length>0&&m.every?.(h=>typeof h=="string")||m==null&&l.nullable!==!1))throw new zn.ClientError(`${u} must be a string, attempt to assign ${m}`);Ln(this)[u]=m},"set");break;case"Float":case"Number":d=o(function(m){let h=m?.__op__?m.value:m;if(!(typeof h=="number"||m==null&&l.nullable!==!1))throw new zn.ClientError(`${u} must be a number, attempt to assign ${h}`);Ln(this)[u]=m},"set");break;case"Int":d=o(function(m){let h=m?.__op__?m.value:m;if(!(h>>0===h||m==null&&l.nullable!==!1))if(typeof h=="number"&&Math.abs((h>>0)-h)<=1)h=Math.round(h),m?.__op__?m.value=h:m=h;else throw new zn.ClientError(`${u} must be an integer between -2147483648 and 2147483647, attempt to assign ${m}`);Ln(this)[u]=m},"set");break;case"Long":d=o(function(m){let h=m?.__op__?m.value:m;if(!(Math.round(h)===m&&Math.abs(h)<=9007199254740992||m==null&&l.nullable!==!1))if(typeof h=="number"&&Math.abs(h)<=9007199254740992)h=Math.round(h),m?.__op__?m.value=h:m=h;else throw new zn.ClientError(`${u} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${m}`);Ln(this)[u]=m},"set");break;case"BigInt":d=o(function(m){let h=m?.__op__?m.value:m;if(!(typeof h=="bigint"||m==null&&l.nullable!==!1))if(typeof h=="string"||typeof h=="number")h=BigInt(h),m?.__op__?m.value=h:m=h;else throw new zn.ClientError(`${u} must be a number, attempt to assign ${m}`);Ln(this)[u]=m},"set");break;case"Boolean":d=o(function(m){if(!(typeof m=="boolean"||m==null&&l.nullable!==!1))throw new zn.ClientError(`${u} must be a boolean, attempt to assign ${m}`);Ln(this)[u]=m},"set");break;case"Date":d=o(function(m){if(!(m instanceof Date||m==null&&l.nullable!==!1))if(typeof m=="string"||typeof m=="number")m=new Date(m);else throw new zn.ClientError(`${u} must be a Date, attempt to assign ${m}`);Ln(this)[u]=m},"set");break;case"Bytes":d=o(function(m){if(!(m instanceof Uint8Array||m==null&&l.nullable!==!1))throw new zn.ClientError(`${u} must be a Buffer or Uint8Array, attempt to assign ${m}`);Ln(this)[u]=m},"set");break;case"Blob":d=o(function(m){if(!(m instanceof Ss||m==null&&l.nullable!==!1))throw new zn.ClientError(`${u} must be a Blob, attempt to assign ${m}`);Ln(this)[u]=m},"set");break;case"Any":case void 0:d=o(function(m){Ln(this)[u]=m},"set");break;default:d=o(function(m){if(!(typeof m=="object"||m==null&&l.nullable!==!1))throw new zn.ClientError(`${u} must be an object, attempt to assign ${m}`);Ln(this)[u]=m},"set")}f={get(){let m=this.getChanges?.();if(m&&u in m){let p=m[u];if(p?.__op__){let _=this.getRecord()?.[u];return p.update(_)}return p}let h=this.getRecord()?.[u];if(h&&typeof h=="object"){let p=iI(h,l);if(p)return m||this._setChanges(m=Object.create(null)),m[u]=p}return h},set:d,enumerable:!0,configurable:!0}}f.get.isAttribute=!0,s[u]=f,(!(u in n)||Object.getOwnPropertyDescriptor(n,u)?.get?.isAttribute)&&Object.defineProperty(n,u,f)}a("getProperty",function(l){let u=s[l];if(u)return u.get.call(this);let d=this.getChanges();return d?.[l]!==void 0?d[l]:this.getRecord()?.[l]}),a("set",function(l,u){let d=s[l];if(d)return d.set.call(this,u);if(t.sealed)throw new zn.ClientError("Can not add a property to a sealed table schema");Ln(this)[l]=u}),a("deleteProperty",function(l){Ln(this)[l]=void 0}),a("toJSON",function(){let l=this.getChanges?.(),u;for(let f in l){u||(u={...this.getRecord()});let m=l[f];if(m?.__op__){let h=u[f];m=m.update(h)}u[f]=m}return Object.keys(this).length>0&&(u||(u={...this.getRecord()}),Object.assign(u,this)),u||this.getRecord()}),n.get||a("get",n.getProperty),n.delete||a("delete",n.deleteProperty),n.then||a("then",null);function a(l,u){Object.defineProperty(n,l,{value:u,configurable:!0})}o(a,"setMethod");let c=n;do{let l=Object.getPrototypeOf(c);if(l===Object.prototype){Object.setPrototypeOf(c,r?kB:HB);break}c=l}while(c&&c!==HB&&c!==kB)}function GB(e,t,r){if(typeof t=="string"){if(t==="then"||t==="getRecord"||t==="getChanges")return;if(FB[t])return FB[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=iI(s);if(i)return n||(n=Object.create(null),r._setChanges(n)),n[t]=i,i}return s}}function wte(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 iI(e,t){let r;switch(e.constructor){case Object:return t?(r=t.TrackedObject,r||(t.TrackedObject=r=class extends sl{static{o(this,"TrackedObject")}},km(r,t)),new r(e)):new sl(e);case Array:let n=new W_(e.length,e);for(let s=0,i=e.length;s<i;s++){let a=e[s];a&&typeof a=="object"&&(a=iI(a,t?.elements)),n[s]=a}return n;default:return e}}function z_(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=z_(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 Ca(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=Ca(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=nA[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=Ca(s);r[n]=s}if(!Array.isArray(e)&&e.getRecord)for(let n in e)Ote.call(e,n)&&(r||(r={...e.getRecord()}),r[n]=e[n]);return r?Object.freeze(r):e.getRecord?e.getRecord():e}function Y_(e){let t=e.getRecord?.();if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[nl]||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(Y_(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(Y_(s))return!0}else return!0}else return!0}}return!1}var zn,FB,HB,kB,sl,Ote,nl,W_,Hm,oI=fe(()=>{zn=w(Ee());qE();Ts();o(Ln,"getChanges");o(km,"assignTrackedAccessors");FB=Object.prototype,HB=new Proxy({},{get:GB}),kB=new Proxy({},{get:GB,set:wte});o(GB,"getProxiedProperty");o(wte,"setProxiedProperty");o(iI,"trackObject");sl=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}};km(sl,{},!0);o(z_,"collapseData");Ote=Object.prototype.hasOwnProperty;o(Ca,"updateAndFreeze");o(Y_,"hasChanges");nl=Symbol.for("has-array-changes"),W_=class extends Array{static{o(this,"TrackedArray")}#e;[nl];constructor(t,r){super(t),this.#e=r}getRecord(){return this.#e}splice(...t){return this[nl]=!0,super.splice(...t)}push(...t){return this[nl]=!0,super.push(...t)}pop(){return this[nl]=!0,super.pop()}unshift(...t){return this[nl]=!0,super.unshift(...t)}shift(){return this[nl]=!0,super.shift()}};W_.prototype.constructor=Array;Hm=class{static{o(this,"Addition")}__op__="add";value;constructor(t){this.value=t}update(t){return(+t||0)+this.value}}});var jB={};Ce(jB,{ResourceBridge:()=>lI});function uI({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 qB(e,t){let r=vi(e),n=uI(e,r);if(!r)throw new ni.ClientError(`Table ${e.table} not found`);let s;n&&r.attributes.length-n.length>2&&n.length<5&&(s=!0);let i={user:e.hdb_user,onlyIfCached:e.onlyIfCached,noCacheStore:e.noCacheStore,noCache:e.noCache,replicateFrom:e.replicateFrom},a;vt(i,()=>new Promise(u=>a=u));let c=e.ids||e.hash_values,l=0;return{[Symbol.asyncIterator](){return{async next(){if(l<c.length){let u=c[l++],d;try{d=await r.get({id:u,lazy:s,select:n},i),d=d&&z_(d)}catch(f){d={message:(0,zB.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 vi(e){let t=e.database||e.schema||Pte,r=it()[t];if(!r)throw(0,ni.handleHDBError)(new Error,Cte.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function $B(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*VB(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 KB,j_,ni,YB,aI,cI,WB,zB,Cte,Pte,Lte,Dte,lI,QB=fe(()=>{KB=w(BB()),j_=w(xu()),ni=w(Ee());Le();YB=w(Nm());k();aI=w(bo()),cI=w(ti()),WB=w(ie());Uc();oI();zB=w(z()),{HDB_ERROR_MSGS:Cte}=ni.hdbErrors,Pte="data",Lte=1e4,Dte=10,lI=class extends KB.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,j_.default)(t,"conditions");if(r)throw(0,ni.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=vi(t);if(!n)throw new ni.ClientError(`Table ${t.table} not found`);let s=t.conditions.map(i);function i(a){if("conditions"in a&&a.conditions)return a.conditions=a.conditions.map(i),a;{let c=a;return{attribute:c.search_attribute??c.attribute,comparator:c.search_type??c.comparator,value:c.search_value!==void 0?c.search_value:c.value}}}return o(i,"mapCondition"),n.search({conditions:s,operator:t.operator?t.operator.toLowerCase():void 0,limit:t.limit,offset:t.offset,reverse:t.reverse,select:uI(t,n),sort:t.sort,allowFullScan:!0},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async createTable(t,r){let n=r.attributes,s=!!n,i=r.primary_key||r.hash_attribute;if(n)for(let a of n)a.is_primary_key?(a.isPrimaryKey=!0,delete a.is_primary_key):a.name===i&&i&&(a.isPrimaryKey=!0);else{if(!i)throw new ni.ClientError("A primary key must be specified with a `primary_key` property or with `attributes`");n=[{name:i,isPrimaryKey:!0},{name:"__createdtime__",indexed:!0},{name:"__updatedtime__",indexed:!0}]}et({database:r.database??r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration,audit:r.audit})}async createAttribute(t){return await vi(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=vi(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 vi(t).dropTable()}createSchema(t){return Hu({database:t.schema,table:null}),aI.signalSchemaChange(new cI.SchemaEventMsg(process.pid,G.CREATE_SCHEMA,t.schema))}async dropSchema(t){await dI(t.schema),aI.signalSchemaChange(new cI.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,YB.default)(t),s,i=it()[t.schema][t.table],a={user:t.hdb_user,expiresAt:t.expiresAt,originatingOperation:t.operation};return t.replicateTo&&(a.replicateTo=t.replicateTo),t.replicatedConfirmation&&(a.replicatedConfirmation=t.replicatedConfirmation),vt(a,async c=>{if(!i.schemaDefined){s=[];for(let d of n)i.attributes.find(m=>m.name==d)||s.push(d);s.length>0&&await i.addAttributes(s.map(d=>({name:d,indexed:!0})))}let l=[],u=[];for(let d of t.records){let f=d[i.primaryKey],m=f!=null&&await i.get(f,a);if(t.requires_existing&&!m||t.requires_no_existing&&m){u.push(d[i.primaryKey]);continue}m&&(m=z_(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),vt(n,async s=>{let i=t.hash_values||t.records.map(l=>l[r.primaryKey]),a=[],c=[];for(let l of i)await r.delete(l,n)?a.push(l):c.push(l);return $B(a,c,s.timestamp)})}async deleteRecordsBefore(t){let r=it()[t.schema][t.table];if(!r.createdTimeProperty)throw new ni.ClientError("Table must have a '__createdtime__' attribute or @createdTime timestamp defined to perform this operation");let n=await r.search({conditions:[{attribute:r.createdTimeProperty.name,value:Date.parse(t.date),comparator:AE.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,WB.asyncSetTimeout)(Dte),l=[],s=!0},"chunkDelete");for await(let d of n)l.push(d[r.primaryKey]),c++,c%Lte===0&&await u();return l.length>0&&await u(),s?$B(i,a,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,j_.default)(t,"hashes");if(r)throw r;return qB(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of qB(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&Uy[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,j_.default)(t,"value");if(n)throw n;let s=vi(t);if(!s)throw new ni.ClientError(`Table ${t.table} not found`);let i=t.search_value;i.includes?.("*")&&(i.startsWith("*")?i.endsWith("*")?i!=="*"&&(r="contains",i=i.slice(1,-1)):(r="ends_with",i=i.slice(1)):i.endsWith("*")&&(r="starts_with",i=i.slice(0,-1))),r===AE.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:uI(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async getDataByValue(t,r){let n=new Map,s=vi(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){vi({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return vi(t).deleteHistory(t.timestamp,t.cleanup_deleted_records)}async readAuditLog(t){let r=vi(t),n={};switch(t.search_type){case bE.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 bE.USERNAME:{let s=t.search_values;for await(let i of VB(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n}default:return VB(r,t.search_values?.[0],t.search_values?.[1],t.limit)}}};o(uI,"getSelect");o(qB,"getRecords");o(vi,"getTable");o($B,"createDeleteResponse");o(VB,"groupRecordsInHistory")});var jn=M((UCe,JB)=>{"use strict";var{ResourceBridge:Mte}=(QB(),v(jB)),vte=ce();vte.initSync();var Q_;function Ute(){return Q_||(Q_=new Mte,Q_)}o(Ute,"getBridge");JB.exports=Ute()});var tF=M((BCe,eF)=>{"use strict";var XB=require("lodash"),Gm=require("mathjs"),xte=require("jsonata"),ZB=ie();eF.exports={distinct_array:o(e=>Array.isArray(e)&&e.length>1?XB.uniqWith(e,XB.isEqual):e,"distinct_array"),searchJSON:Bte,mad:qm.bind(null,Gm.mad),mean:qm.bind(null,Gm.mean),mode:qm.bind(null,Gm.mode),prod:qm.bind(null,Gm.prod),median:qm.bind(null,Gm.median)};function qm(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(qm,"aggregateFunction");function Bte(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(ZB.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),ZB.isEmpty(this.__ala__.res[r])){let n=xte(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}o(Bte,"searchJSON")});var nF=M((HCe,rF)=>{"use strict";var ar=require("moment"),fI="YYYY-MM-DDTHH:mm:ss.SSSZZ";ar.suppressDeprecationWarnings=!0;rF.exports={current_date:o(()=>ar().utc().format("YYYY-MM-DD"),"current_date"),current_time:o(()=>ar().utc().format("HH:mm:ss.SSS"),"current_time"),extract:o((e,t)=>{switch(t.toLowerCase()){case"year":return ar(e).utc().format("YYYY");case"month":return ar(e).utc().format("MM");case"day":return ar(e).utc().format("DD");case"hour":return ar(e).utc().format("HH");case"minute":return ar(e).utc().format("mm");case"second":return ar(e).utc().format("ss");case"millisecond":return ar(e).utc().format("SSS");default:break}},"extract"),date:o(e=>ar(e).utc().format(fI),"date"),date_format:o((e,t)=>ar(e).utc().format(t),"date_format"),date_add:o((e,t,r)=>ar(e).utc().add(t,r).valueOf(),"date_add"),date_sub:o((e,t,r)=>ar(e).utc().subtract(t,r).valueOf(),"date_sub"),date_diff:o((e,t,r)=>{let n=ar(e).utc(),s=ar(t).utc();return r?n.diff(s,r,!0):n.diff(s)},"date_diff"),now:o(()=>ar().utc().valueOf(),"now"),get_server_time:o(()=>ar().format(fI),"get_server_time"),offset_utc:o((e,t)=>ar(e).utc().utcOffset(t).format(fI),"offset_utc")}});var aF=M((GCe,oF)=>{"use strict";var Fte=require("@turf/area"),Hte=require("@turf/length"),kte=require("@turf/circle"),Gte=require("@turf/difference"),qte=require("@turf/distance"),$te=require("@turf/boolean-contains"),Vte=require("@turf/boolean-equal"),Kte=require("@turf/boolean-disjoint"),Yte=require("@turf/helpers"),sF=(k(),v(K)),Ye=ie(),wo=z();oF.exports={geoArea:Wte,geoLength:zte,geoCircle:jte,geoDifference:Qte,geoDistance:iF,geoNear:Jte,geoContains:Xte,geoEqual:Zte,geoCrosses:ere,geoConvert:tre};function Wte(e){if(Ye.isEmpty(e))return NaN;typeof e=="string"&&(e=Ye.autoCastJSON(e));try{return Fte.default(e)}catch(t){return wo.trace(t,e),NaN}}o(Wte,"geoArea");function zte(e,t){if(Ye.isEmpty(e))return NaN;typeof e=="string"&&(e=Ye.autoCastJSON(e));try{return Hte.default(e,{units:t||"kilometers"})}catch(r){return wo.trace(r,e),NaN}}o(zte,"geoLength");function jte(e,t,r){if(Ye.isEmpty(e))return NaN;if(Ye.isEmpty(t))return NaN;typeof e=="string"&&(e=Ye.autoCastJSON(e));try{return kte.default(e,t,{units:r||"kilometers"})}catch(n){return wo.trace(n,e,t),NaN}}o(jte,"geoCircle");function Qte(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 Gte(e,t)}catch(r){return wo.trace(r,e,t),NaN}}o(Qte,"geoDifference");function iF(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 qte.default(e,t,{units:r||"kilometers"})}catch(n){return wo.trace(n,e,t),NaN}}o(iF,"geoDistance");function Jte(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 iF(e,t,n)<=r}catch(s){return wo.trace(s,e,t),!1}}o(Jte,"geoNear");function Xte(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 $te.default(e,t)}catch(r){return wo.trace(r,e,t),!1}}o(Xte,"geoContains");function Zte(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 Vte.default(e,t)}catch(r){return wo.trace(r,e,t),!1}}o(Zte,"geoEqual");function ere(e,t){if(Ye.isEmpty(e)||Ye.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Ye.autoCastJSON(e)),typeof t=="string"&&(t=Ye.autoCastJSON(t));try{return!Kte.default(e,t)}catch(r){return wo.trace(r,e,t),!1}}o(ere,"geoCrosses");function tre(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(sF.GEO_CONVERSION_ENUM[t]))throw new Error(`geoType of ${t} is invalid please use one of the following types: ${Object.keys(sF.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Ye.autoCastJSON(e)),Yte[t](e,r)}o(tre,"geoConvert")});var J_=M(($Ce,cF)=>{var il=tF(),Qn=nF(),Ui=aF();cF.exports=e=>{e.aggr.mad=e.aggr.MAD=il.mad,e.aggr.mean=e.aggr.MEAN=il.mean,e.aggr.mode=e.aggr.MODE=il.mode,e.aggr.prod=e.aggr.PROD=il.prod,e.aggr.median=e.aggr.MEDIAN=il.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=il.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=il.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=Qn.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Qn.current_time,e.fn.extract=e.fn.EXTRACT=Qn.extract,e.fn.date=e.fn.DATE=Qn.date,e.fn.date_format=e.fn.DATE_FORMAT=Qn.date_format,e.fn.date_add=e.fn.DATE_ADD=Qn.date_add,e.fn.date_sub=e.fn.DATE_SUB=Qn.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Qn.date_diff,e.fn.now=e.fn.NOW=Qn.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Qn.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Qn.get_server_time,e.fn.getdate=e.fn.GETDATE=Qn.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Qn.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=Ui.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=Ui.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=Ui.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=Ui.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=Ui.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=Ui.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=Ui.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=Ui.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=Ui.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=Ui.geoNear}});var fF=M((VCe,dF)=>{"use strict";var $m=require("lodash"),Dn=require("alasql");Dn.options.cache=!1;var rre=J_(),lF=require("clone"),X_=require("recursive-iterator"),ke=z(),tt=ie(),ku=jn(),nre=(k(),v(K)),{hdbErrors:sre}=Ee(),{getDatabases:uF}=(Le(),v(ft)),ire="IS NULL",si="There was a problem performing this search. Please check the logs and try again.";rre(Dn);var mI=class{static{o(this,"SQLSearch")}constructor(t,r){if(tt.isEmpty(t))throw ke.error("AST statement for SQL select process cannot be empty"),"statement cannot be null";this.statement=t,this.columns={},this.all_table_attributes=r,this.fetch_attributes=[],this.exact_search_values={},this.comparator_search_values={},this.tables=[],this.data={},this.has_aggregator=!1,this.has_ordinal=!1,this.has_outer_join=!1,this._getColumns(),this._getTables(),this._conditionsToFetchAttributeValues(),this._setAliasesForColumns(),tt.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!tt.isEmptyOrZeroLength(n))return ke.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw ke.error("Error thrown from checkEmptySQL in SQLSearch class method search."),ke.error(n),new Error(si)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw ke.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),ke.error(n),new Error(si)}if(Object.keys(this.data).length===0)return ke.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw ke.error("Error thrown from processJoins in SQLSearch class method search."),ke.error(n),new Error(si)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw ke.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),ke.error(n),new Error(si)}try{return t=await this._finalSQL(),t}catch(n){throw ke.error("Error thrown from finalSQL in SQLSearch class method search."),ke.error(n),new Error(si)}}_getColumns(){let t=new X_(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(lF(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=$m.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=uF()[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 X_(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!tt.isEmpty(r)&&r.right)if(tt.isNotEmptyAndHasValue(r.right.value)){let n=tt.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new Dn.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=tt.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new Dn.yy.LogicValue({value:i}):n instanceof Dn.yy.StringValue&&tt.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new Dn.yy.NumValue({value:i}))});if(t){ke.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new X_(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(nre.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&&$m.pullAt(this.statement.columns,t)}_findColumn(t){let r=this.all_table_attributes.filter(n=>{if(t.columnid_orig&&t.tableid_orig)return(n.table.as===t.tableid_orig||n.table.tableid===t.tableid_orig)&&n.attribute===t.columnid_orig;if(t.tableid)return(n.table.as===t.tableid||n.table.tableid===t.tableid)&&n.attribute===t.columnid;let s=t.columnid_orig?t.columnid_orig:t.columnid;return n.attribute===s});if(tt.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);tt.isEmptyOrZeroLength(n)||(r=this.all_table_attributes.filter(s=>s.attribute===n[0].columnid&&n[0].tableid&&n[0].tableid===(s.table.as?s.table.as:s.table.tableid)))}return r[0]}async _checkEmptySQL(){let t=[];if(tt.isEmptyOrZeroLength(this.all_table_attributes)&&!tt.isEmptyOrZeroLength(this.columns.columns))return t;if(tt.isEmptyOrZeroLength(this.all_table_attributes)&&tt.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await Dn.promise(r)}catch(r){throw ke.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),ke.error(r),new Error("There was a problem with the SQL statement")}return t}_addFetchColumns(t){t&&t.length>0&&t.forEach(r=>{let n=this._findColumn(r);n&&this.fetch_attributes.push(lF(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(ire)>-1&&this.tables.forEach(s=>{let i={columnid:uF()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=$m.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 ku.getDataByHash(c);for(let f of c.hash_values)d.get(f)&&!this.data[i].__mergedData[f]&&(this.data[i].__mergedData[f]=[...n[i]],this._setMergedHashAttribute(i,f))}catch(d){throw ke.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),ke.error(d),new Error(si)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[u].values).map(async d=>{let f={...c};f.search_value=d;let m=await ku.getDataByValue(f);for(let[h,p]of m)this.data[i].__mergedData[h]?this._updateMergedAttribute(i,h,s.attribute,p[s.attribute]):(this.data[i].__mergedData[h]=[...n[i]],this._updateMergedAttribute(i,h,s.attribute,p[s.attribute]),this._setMergedHashAttribute(i,h))}))}catch(d){throw ke.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),ke.error(d),new Error(si)}else if(!tt.isEmpty(this.comparator_search_values[u])&&!this.comparator_search_values[u].ignore&&!tt.isEmptyOrZeroLength(this.comparator_search_values[u].comparators))try{let d=this.comparator_search_values[u].comparators;for(let f=0,m=d.length;f<m;f++){let h=d[f];c.search_attribute=h.attribute,c.search_value=h.search_value;let p=await ku.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(si)}else try{c.search_attribute=s.attribute,c.search_value="*";let d=await ku.getDataByValue(c);if(l)for(let[f]of d)this.data[i].__mergedData[f]||(this.data[i].__mergedData[f]=[...n[i]],this._setMergedHashAttribute(i,f));else for(let[f,m]of d)this.data[i].__mergedData[f]?this._updateMergedAttribute(i,f,s.attribute,m[s.attribute]):(this.data[i].__mergedData[f]=[...n[i]],this._updateMergedAttribute(i,f,s.attribute,m[s.attribute]),this._setMergedHashAttribute(i,f))}catch(d){throw ke.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),ke.error(d),new Error(si)}}}_isSimpleSelect(){let t=!0;return Object.keys(this.statement).length!==2||!this.statement.columns||!this.statement.from||this.statement.from.length!==1?(t=!1,t):(this.statement.columns.forEach(r=>{r instanceof Dn.yy.Column||(t=!1)}),t)}_updateOrderByToAliases(){this.statement.order.forEach(t=>{if(t.expression.aggregatorid){t.is_aggregator=!0;return}if(t.expression.value){t.is_ordinal=!0,this.has_ordinal=!0;return}else t.is_ordinal=!1;let r=this.statement.columns.filter(s=>{let i=s.aggregatorid?s.expression:s,a=s.aggregatorid?s.as_orig:i.as_orig;return t.expression.tableid?i.columnid_orig===t.expression.columnid_orig&&i.tableid_orig===t.expression.tableid_orig:i.columnid_orig===t.expression.columnid_orig||t.expression.columnid_orig===a});r[0]||r.push(this._findColumn(t.expression));let n=r[0];if(t.is_func=!!n.funcid,t.is_aggregator=!!n.aggregatorid,n.as)if(n.as&&!t.expression.tableid)t.expression.columnid=n.as,t.expression.columnid_orig=n.as_orig;else{let s=new Dn.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new Dn.yy.Column,t.expression),t.initial_select_column.as=`[${t.expression.columnid_orig}]`,t.expression.columnid=t.initial_select_column.as;return}if(!t.is_aggregator){let s=t.is_func?new Dn.yy.FuncValue:new Dn.yy.Column;t.initial_select_column=Object.assign(s,n)}})}_addNonAggregatorsToFetchColumns(){let r=this.statement.order.filter(n=>!n.is_aggregator&&!n.is_ordinal).map(n=>n.is_func?{columnid:n.initial_select_column.args.filter(i=>!!i.columnid_orig)[0].columnid_orig}:{columnid:n.expression.columnid_orig});this._addFetchColumns(r)}async _processJoins(){let t=[],r=[],n=this.statement.from[0],s=[n],i=["? "+(n.as?" AS "+n.as:n.tableid)];t.push(Object.values(this.data[`${n.databaseid_orig}_${n.as?n.as_orig:n.tableid_orig}`].__mergedData)),this.statement.joins&&this.statement.joins.forEach(h=>{h.joinmode&&h.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(h.table);let p=h.joinmode+" JOIN ? AS "+(h.as?h.as:h.table.tableid);h.on&&(p+=" ON "+h.on.toString()),i.push(p),t.push(Object.values(this.data[`${h.table.databaseid_orig}_${h.table.as?h.table.as_orig:h.table.tableid_orig}`].__mergedData))});let a=[],c={};s.forEach(h=>{let p=this.data[`${h.databaseid_orig}_${h.as?h.as_orig:h.tableid_orig}`].__hashName,_=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 Dn.promise(p,t),t=null}catch(h){throw ke.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),ke.error(h),new Error("There was a problem processing the data.")}if(m&&m.length>0){for(let h=0,p=m.length;h<p;h++){let _=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),_=$m.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 X_(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=$m.uniqBy(n,i=>[i.table.databaseid,i.table.as?i.table.as:i.table.tableid,i.attribute].join());try{await this._getData(n)}catch(i){throw ke.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),ke.error(i),new Error(si)}}async _getData(t){try{let r=t.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]?n[i].columns.push(s.attribute):n[i]={schema:s.table.databaseid,table:s.table.tableid,columns:[s.attribute]},n},{});for(let n in r){let s=r[n],i=this.data[n].__mergedData,a=[];for(let d in i)a.push(i[d][0]);this.data[n].__mergedAttributes.push(...s.columns);let c={schema:s.schema,table:s.table,hash_values:a,get_attributes:s.columns},l=await ku.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 Dn.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),ke.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw ke.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),ke.error(s),new Error("There was a problem running the generated sql.")}return n}_translateUndefinedValues(t){try{let r=[];for(let n of t){let s=Object.create(null);Object.keys(n).forEach(i=>{n[i]===void 0?s[i]=null:s[i]=n[i]}),r.push(s)}return r}catch(r){return ke.error(sre.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 ku.getDataByValue(i);for(let[c,l]of a)this.data[s].__mergedData[c]||(l[n.attribute]===void 0&&(l[n.attribute]=null),this.data[s].__mergedData[c]={...r[s]}),this.data[s].__mergedData[c][t[n.attribute]]=l[n.attribute]??null}catch(a){throw ke.error("There was an error when processing this SQL operation. Check your logs"),ke.error(a),new Error(si)}}return Object.values(Object.values(this.data)[0].__mergedData)}};dF.exports=mI});var on=M((YCe,mF)=>{"use strict";var ore=ax();mF.exports={searchByConditions:cre,searchByHash:lre,searchByValue:ure,search:dre};var hI=jn(),{transformReq:pI}=ie(),are=fF();async function cre(e){return pI(e),hI.searchByConditions(e)}o(cre,"searchByConditions");async function lre(e){pI(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of hI.searchByHash(e))r&&t.push(r);return t}o(lre,"searchByHash");async function ure(e){pI(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of hI.searchByValue(e))t.push(r);return t}o(ure,"searchByValue");function dre(e,t){try{let r=new ore(e);r.validate(),new are(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}o(dre,"search")});var xi=M((zCe,_F)=>{"use strict";var Vm=require("crypto"),fre=ce(),{CONFIG_PARAMS:mre}=(k(),v(K)),pF="aes-256-cbc",hre=32,pre=16,EI=64,EF=32,Ere=EI+EF,hF=new Map;_F.exports={encrypt:_re,decrypt:gre,createNatsTableStreamName:Sre};function _re(e){let t=Vm.randomBytes(hre),r=Vm.randomBytes(pre),n=Vm.createCipheriv(pF,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(_re,"encrypt");function gre(e){let t=e.substr(0,EI),r=e.substr(EI,EF),n=e.substr(Ere,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),a=Vm.createDecipheriv(pF,Buffer.from(t,"hex"),s),c=a.update(i);return c=Buffer.concat([c,a.final()]),c.toString()}o(gre,"decrypt");function Sre(e,t){let r=fre.get(mre.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=hF.get(r);return n||(n=Vm.createHash("md5").update(r).digest("hex"),hF.set(r,n)),n}o(Sre,"createNatsTableStreamName")});var Pa=M((JCe,RF)=>{"use strict";var QCe=on(),Km=z(),{validateBySchema:gF}=at(),ol=require("joi"),Tre=xi(),Z_=ie(),{handleHDBError:eg,hdbErrors:Rre,ClientError:SF}=Ee(),{HDB_ERROR_MSGS:tg,HTTP_STATUS_CODES:_I}=Rre,TF=ce();TF.initSync();var{getDatabases:gI}=(Le(),v(ft)),yre=require("fs-extra"),Are=(k(),v(K));RF.exports={describeAll:bre,describeTable:rg,describeSchema:Ire};async function bre(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=gI(),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 rg({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 rg({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),eg(new Error,tg.DESCRIBE_ALL_ERR)}}o(bre,"describeAll");async function rg(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=gF(e,ol.object({database:ol.string(),table:ol.string().required(),exact_count:ol.boolean().strict()}));if(i)throw new SF(i.message);let c=gI()[r];if(!c)throw eg(new Error,tg.SCHEMA_NOT_FOUND(e.schema),_I.NOT_FOUND);let l=c[n];if(!l)throw eg(new Error,tg.TABLE_NOT_FOUND(e.schema,e.table),_I.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 yre.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")),TF.get(Are.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(m.clustering_stream_name=Tre.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(rg,"descTable");async function Ire(e){Z_.transformReq(e);let t=gF(e,ol.object({database:ol.string(),exact_count:ol.boolean().strict()}));if(t)throw new SF(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=gI()[n];if(!i)throw eg(new Error,tg.SCHEMA_NOT_FOUND(e.schema),_I.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 rg({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);u&&(a[u.name]=u)}}return a}o(Ire,"describeSchema")});var Mn=M((ZCe,IF)=>{"use strict";var sg=Rb(),$r=ie(),Nre=require("util"),ig=jn(),wre=ei(),yF=z(),{handleHDBError:al,hdbErrors:Ore}=Ee(),{HTTP_STATUS_CODES:cl}=Ore,Cre=Nre.promisify(wre.getTableSchema),Pre="updated",AF="inserted",bF="upserted";IF.exports={insert:Dre,update:Mre,upsert:vre,validation:Lre,flush:Ure};async function Lre(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 Cre(e.schema,e.table),r=sg(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 yF.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 yF.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(Lre,"validation");async function Dre(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=sg(e);if(t)throw al(new Error,t.message,cl.BAD_REQUEST);$r.transformReq(e);let r=$r.checkSchemaTableExist(e.schema,e.table);if(r)throw al(new Error,r,cl.BAD_REQUEST);let n=await ig.createRecords(e);return ng(AF,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}o(Dre,"insertData");async function Mre(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=sg(e);if(t)throw al(new Error,t.message,cl.BAD_REQUEST);$r.transformReq(e);let r=$r.checkSchemaTableExist(e.schema,e.table);if(r)throw al(new Error,r,cl.BAD_REQUEST);let n=await ig.updateRecords(e);return $r.isEmpty(n.existing_rows)?ng(Pre,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):ng(n.update_action,[],e,n.hashes,void 0,n.txn_time)}o(Mre,"updateData");async function vre(e){if(e.operation!=="upsert")throw al(new Error,"invalid operation, must be upsert",cl.INTERNAL_SERVER_ERROR);let t=sg(e);if(t)throw al(new Error,t.message,cl.BAD_REQUEST);$r.transformReq(e);let r=$r.checkSchemaTableExist(e.schema,e.table);if(r)throw al(new Error,r,cl.BAD_REQUEST);let n=await ig.upsertRecords(e);return ng(bF,n.written_hashes,e,[],n.new_attributes,n.txn_time)}o(vre,"upsertData");function ng(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===AF?(a.inserted_hashes=t,a.skipped_hashes=n,a):e===bF?(a.upserted_hashes=t,a):(a.update_hashes=t,a.skipped_hashes=n,a)}o(ng,"returnObject");function Ure(e){return $r.transformReq(e),ig.flush(e.schema,e.table)}o(Ure,"flush")});var TI=M((tPe,OF)=>{var xre=at(),SI=require("joi"),{hdbTable:Bre,hdbDatabase:NF}=Di(),wF={schema:NF,database:NF,table:Bre},Fre={date:SI.date().iso().required()},Hre={timestamp:SI.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};OF.exports=function(e,t){let r=t==="timestamp"?{...wF,...Hre}:{...wF,...Fre},n=SI.object(r);return xre.validateBySchema(e,n)}});var LF=M((rPe,PF)=>{var kre=at(),RI=require("joi"),{hdbTable:Gre,hdbDatabase:CF}=Di(),qre=RI.object({schema:CF,database:CF,table:Gre,hash_values:RI.array().required(),ids:RI.array()});PF.exports=function(e){return kre.validateBySchema(e,qre)}});var II=M((nPe,DF)=>{"use strict";var yI=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}},AI=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}},bI=class{static{o(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};DF.exports={InsertObject:yI,NoSQLSeachObject:AI,DeleteResponseObject:bI}});var dl=M((iPe,BF)=>{"use strict";var vF=TI(),$re=LF(),ll=ie(),MF=require("moment"),UF=z(),{promisify:Vre,callbackify:Kre}=require("util"),ul=(k(),v(K)),Yre=ei(),NI=Vre(Yre.getTableSchema),wI=jn(),{DeleteResponseObject:Wre}=II(),{handleHDBError:La,hdbErrors:zre}=Ee(),{HDB_ERROR_MSGS:og,HTTP_STATUS_CODES:Da}=zre,jre="records successfully deleted",Qre=Kre(xF);BF.exports={delete:Qre,deleteRecord:xF,deleteFilesBefore:Jre,deleteAuditLogsBefore:Xre};async function Jre(e){let t=vF(e,"date");if(t)throw La(t,t.message,Da.BAD_REQUEST,void 0,void 0,!0);if(ll.transformReq(e),!MF(e.date,MF.ISO_8601).isValid())throw La(new Error,og.INVALID_DATE,Da.BAD_REQUEST,ul.LOG_LEVELS.ERROR,og.INVALID_DATE,!0);let n=ll.checkSchemaTableExist(e.schema,e.table);if(n)throw La(new Error,n,Da.NOT_FOUND,ul.LOG_LEVELS.ERROR,n,!0);let s=await wI.deleteRecordsBefore(e);if(await NI(e.schema,e.table),UF.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}o(Jre,"deleteFilesBefore");async function Xre(e){let t=vF(e,"timestamp");if(t)throw La(t,t.message,Da.BAD_REQUEST,void 0,void 0,!0);if(ll.transformReq(e),isNaN(e.timestamp))throw La(new Error,og.INVALID_VALUE("Timestamp"),Da.BAD_REQUEST,ul.LOG_LEVELS.ERROR,og.INVALID_VALUE("Timestamp"),!0);let r=ll.checkSchemaTableExist(e.schema,e.table);if(r)throw La(new Error,r,Da.NOT_FOUND,ul.LOG_LEVELS.ERROR,r,!0);let n=await wI.deleteAuditLogsBefore(e);return await NI(e.schema,e.table),UF.info(`Finished deleting audit logs before ${e.timestamp}`),n}o(Xre,"deleteAuditLogsBefore");async function xF(e){e.ids&&(e.hash_values=e.ids);let t=$re(e);if(t)throw La(t,t.message,Da.BAD_REQUEST,void 0,void 0,!0);ll.transformReq(e);let r=ll.checkSchemaTableExist(e.schema,e.table);if(r)throw La(new Error,r,Da.NOT_FOUND,ul.LOG_LEVELS.ERROR,r,!0);try{await NI(e.schema,e.table);let n=await wI.deleteRecords(e);return ll.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${jre}`),n}catch(n){if(n.message===ul.SEARCH_NOT_FOUND_MESSAGE){let s=new Wre;return s.message=ul.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}o(xF,"deleteRecord")});var ag={};Ce(ag,{HASH_FUNCTION:()=>Mr,hash:()=>PI,validate:()=>LI});function OI(e=Wm){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ";return Array.from(Ym.randomBytes(e)).map(r=>t[r%t.length]).join("")}function PI(e,t=Mr[HF?.toUpperCase()]??Mr.SHA256){return CI[t](e)}function LI(e,t,r=Mr[HF?.toUpperCase()]??Mr.SHA256){return e?Zre[r](e,t):!1}var Ym,Gu,FF,HF,Wm,kF,Mr,CI,Zre,cg=fe(()=>{Ym=w(require("node:crypto")),Gu=w(require("argon2")),FF=w(ce());k();HF=(0,FF.get)(U.AUTHENTICATION_HASHFUNCTION)?.toLowerCase(),Wm=16,kF=9,Mr={MD5:"md5",SHA256:"sha256",ARGON2ID:"argon2id"};o(OI,"generateSalt");CI={[Mr.MD5]:(e,t=void 0)=>{t=t??OI(kF);let r=Ym.createHash(Mr.MD5).update(e+t).digest("hex");return t+r},[Mr.SHA256]:(e,t=void 0)=>{t=t??OI(Wm);let r=Ym.createHash(Mr.SHA256).update(e+t).digest("hex");return t+r},[Mr.ARGON2ID]:async e=>{let t=OI(Wm),r=await Gu.hash(e,{type:Gu.argon2id,salt:Buffer.from(t)});return t+r}},Zre={[Mr.MD5]:(e,t)=>{let r=e.slice(0,kF);return e===CI[Mr.MD5](t,r)},[Mr.SHA256]:(e,t)=>{let r=e.slice(0,Wm);return e===CI[Mr.SHA256](t,r)},[Mr.ARGON2ID]:async(e,t)=>await Gu.verify(e.slice(Wm),t)};o(PI,"hash");o(LI,"validate")});var qF=M((lPe,GF)=>{var DI=at(),an={username:{presence:!0,exclusion:{within:["system"],message:"You cannot create tables within the system schema"}},password:{presence:!0},role:{presence:!0,format:"[\\w\\-\\_]+"},active:{presence:!0,inclusion:{within:[!0,!1],message:"must be a boolean"}}};function ene(e){return an.password.presence=!0,an.username.presence=!0,an.role.presence=!0,an.active.presence=!0,DI.validateObject(e,an)}o(ene,"addUserValidation");function tne(e){return an.password.presence=!1,an.username.presence=!0,an.role.presence=!1,an.active.presence=!1,DI.validateObject(e,an)}o(tne,"alterUserValidation");function rne(e){return an.password.presence=!1,an.username.presence=!0,an.role.presence=!1,an.active.presence=!1,DI.validateObject(e,an)}o(rne,"dropUserValidation");GF.exports={addUserValidation:ene,alterUserValidation:tne,dropUserValidation:rne}});var It=M((fPe,VF)=>{"use strict";var{platform:dPe}=require("os"),nne="nats-server.zip",MI="nats-server",sne=process.platform==="win32"?`${MI}.exe`:MI,ine=/^[^\s.,*>]+$/,$F="__request__",one=o(e=>`${e}.${$F}`,"REQUEST_SUBJECT"),ane={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},cne={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},lne={HUB:"hub.pid",LEAF:"leaf.pid"},une={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},dne={SUCCESS:"success",ERROR:"error"},fne={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},mne={TXN:"txn",MSGID:"msgid"},qu={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},hne={[qu.ERR]:1,[qu.WRN]:2,[qu.INF]:3,[qu.DBG]:4,[qu.TRC]:5},pne={debug:"-D",trace:"-DVV"};VF.exports={NATS_SERVER_ZIP:nne,NATS_SERVER_NAME:MI,NATS_BINARY_NAME:sne,PID_FILES:lne,NATS_CONFIG_FILES:cne,SERVER_SUFFIX:une,NATS_TERM_CONSTRAINTS_RX:ine,REQUEST_SUFFIX:$F,UPDATE_REMOTE_RESPONSE_STATUSES:dne,CLUSTER_STATUS_STATUSES:fne,REQUEST_SUBJECT:one,SUBJECT_PREFIXES:mne,MSG_HEADERS:ane,LOG_LEVELS:qu,LOG_LEVEL_FLAGS:pne,LOG_LEVEL_HIERARCHY:hne}});var Jn=M((hPe,vr)=>{"use strict";var WF="username is required",zF="nothing to update, must supply active, role or password to update",jF="password cannot be an empty string",QF="If role is specified, it cannot be empty.",JF="active must be true or false";vr.exports.addUser=bne;vr.exports.alterUser=Ine;vr.exports.dropUser=wne;vr.exports.getSuperUser=Dne;vr.exports.userInfo=One;vr.exports.listUsers=ug;vr.exports.listUsersExternal=Cne;vr.exports.setUsersWithRolesCache=fl;vr.exports.findAndValidateUser=qI;vr.exports.getClusterUser=Mne;vr.exports.getUsersWithRolesCache=Lne;vr.exports.USERNAME_REQUIRED=WF;vr.exports.ALTERUSER_NOTHING_TO_UPDATE=zF;vr.exports.EMPTY_PASSWORD=jF;vr.exports.EMPTY_ROLE=QF;vr.exports.ACTIVE_BOOLEAN=JF;var XF=Mn(),Ene=dl(),zm=(cg(),v(ag)),ZF=qF(),jm=on(),FI=bo(),Bi=ie(),eH=require("validate.js"),HI=z(),{promisify:_ne}=require("util"),kI=xi(),UI=(k(),v(K)),KF=It(),gne=yt(),Sne=ce(),Tne=Ro(),{hdbErrors:Rne,ClientError:ii}=Ee(),{HTTP_STATUS_CODES:Oo,AUTHENTICATION_ERROR_MSGS:vI,HDB_ERROR_MSGS:$u}=Rne,{UserEventMsg:GI}=ti(),xI=require("lodash"),{server:lg}=(Pr(),v(Bf)),yne=z();lg.getUser=(e,t)=>qI(e,t,t!=null);lg.authenticateUser=(e,t)=>qI(e,t);var tH={username:!0,active:!0,role:!0,password:!0},YF=new Map,Ane=_ne(Ene.delete),BI=Sne.get(UI.CONFIG_PARAMS.AUTHENTICATION_HASHFUNCTION)??zm.HASH_FUNCTION.SHA256,Fi;async function bne(e){let t=eH.cleanAttributes(e,tH),r=ZF.addUserValidation(t);if(r)throw new ii(r.message);let n=await jm.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),Oo.NOT_FOUND);if(n.length>1)throw new ii($u.DUP_ROLES_FOUND(t.role),Oo.CONFLICT);n[0].permission.cluster_user===!0&&(t.hash=kI.encrypt(t.password)),t.password=await zm.hash(t.password,BI),t.hash_function=BI,t.role=n[0].id;let s=await XF.insert({operation:"insert",schema:"system",table:"hdb_user",records:[t]});if(HI.debug(s),await fl(),s.skipped_hashes.length===1)throw new ii($u.USER_ALREADY_EXISTS(t.username),Oo.CONFLICT);return FI.signalUserChange(new GI(process.pid)),`${t.username} successfully added`}o(bne,"addUser");async function Ine(e){let t=eH.cleanAttributes(e,tH);if(Bi.isEmptyOrZeroLength(t.username))throw new Error(WF);if(Bi.isEmptyOrZeroLength(t.password)&&Bi.isEmptyOrZeroLength(t.role)&&Bi.isEmptyOrZeroLength(t.active))throw new Error(zF);if(!Bi.isEmpty(t.password)&&Bi.isEmptyOrZeroLength(t.password.trim()))throw new Error(jF);if(!Bi.isEmpty(t.active)&&!Bi.isBoolean(t.active))throw new Error(JF);if(!Bi.isEmpty(t.password)&&!Bi.isEmptyOrZeroLength(t.password.trim())&&(Nne(t.username)&&(t.hash=kI.encrypt(t.password)),t.password=await zm.hash(t.password,BI)),t.role==="")throw new Error(QF);if(t.role){let n=await jm.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),Oo.NOT_FOUND);if(n.length>1)throw new ii($u.DUP_ROLES_FOUND(t.role),Oo.CONFLICT);t.role=n[0].id}let r=await XF.update({operation:"update",schema:"system",table:"hdb_user",records:[t]});return await fl(),FI.signalUserChange(new GI(process.pid)),r}o(Ine,"alterUser");function Nne(e){let t=!1,r=Fi.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}o(Nne,"isClusterUser");async function wne(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),Oo.NOT_FOUND);let r=await Ane({table:"hdb_user",schema:"system",hash_values:[e.username]});return HI.debug(r),await fl(),FI.signalUserChange(new GI(process.pid)),`${e.username} successfully deleted`}o(wne,"dropUser");async function One(e){let t={};if(!e||!e.hdb_user)return"There was no user info in the body";t=xI.cloneDeep(e.hdb_user);let r=await jm.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(One,"userInfo");async function Cne(){let e=await ug();return e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token,delete t.hash_function}),[...e.values()]}o(Cne,"listUsersExternal");async function ug(){let e=await jm.searchByValue({schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]}),t={};for(let s of e)t[s.id]=xI.cloneDeep(s);if(Object.keys(t).length===0)return null;let r=await jm.searchByValue({schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]}),n=new Map;for(let s of r)s=xI.cloneDeep(s),s.role=t[s.role],Pne(s.role),n.set(s.username,s);return n}o(ug,"listUsers");function Pne(e){if(!e){HI.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(Tne)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}o(Pne,"appendSystemTablesToRole");async function fl(e=void 0){e?Fi=e:Fi=await ug()}o(fl,"setUsersWithRolesCache");async function Lne(){return Fi||await fl(),Fi}o(Lne,"getUsersWithRolesCache");async function qI(e,t,r=!0){Fi||await fl();let n=Fi.get(e);if(!n){if(!r)return{username:e};throw new ii(vI.GENERIC_AUTH_FAIL,Oo.UNAUTHORIZED)}if(n&&!n.active)throw new ii(vI.USER_INACTIVE,Oo.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(YF.get(t)===n.password)return s;{let i=zm.validate(n.password,t,n.hash_function||zm.HASH_FUNCTION.MD5);if(i?.then&&(i=await i),i===!0)YF.set(t,n.password);else throw new ii(vI.GENERIC_AUTH_FAIL,Oo.UNAUTHORIZED)}}return s}o(qI,"findAndValidateUser");async function Dne(){Fi||await fl();for(let[,e]of Fi)if(e.role.role==="super_user")return e}o(Dne,"getSuperUser");async function Mne(){let e=await ug(),t=gne.getConfigFromFile(UI.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!(r==null||r?.role?.role!==UI.ROLE_TYPES_ENUM.CLUSTER_USER))return r.decrypt_hash=kI.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(Mne,"getClusterUser");var rH=[];lg.invalidateUser=function(e){for(let t of rH)try{t(e)}catch(r){yne.error("Error invalidating user",r)}};lg.onInvalidatedUser=function(e){rH.push(e)}});var Jm=M((gPe,oH)=>{"use strict";var ml=z(),Xn=(k(),v(K)),vne=KU(),EPe=ei(),_Pe=Pa(),Une=Jn(),{validateEvent:nH}=ti(),Qm=jn(),xne=require("process"),{resetDatabases:Bne}=(Le(),v(ft)),Fne={[Xn.ITC_EVENT_TYPES.SCHEMA]:Hne,[Xn.ITC_EVENT_TYPES.USER]:iH};async function Hne(e){let t=nH(e);if(t){ml.error(t);return}ml.trace("ITC schemaHandler received schema event:",e),await vne(e.message),await kne(e.message)}o(Hne,"schemaHandler");async function kne(e){try{Qm.resetReadTxn(Xn.SYSTEM_SCHEMA_NAME,Xn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),Qm.resetReadTxn(Xn.SYSTEM_SCHEMA_NAME,Xn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),Qm.resetReadTxn(Xn.SYSTEM_SCHEMA_NAME,Xn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=Bne();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){ml.error(t)}}o(kne,"syncSchemaMetadata");var sH=[];async function iH(e){try{try{Qm.resetReadTxn(Xn.SYSTEM_SCHEMA_NAME,Xn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),Qm.resetReadTxn(Xn.SYSTEM_SCHEMA_NAME,Xn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){ml.warn(r)}let t=nH(e);if(t){ml.error(t);return}ml.trace(`ITC userHandler ${Xn.HDB_ITC_CLIENT_PREFIX}${xne.pid} received user event:`,e),await Une.setUsersWithRolesCache();for(let r of sH)r()}catch(t){ml.error(t)}}o(iH,"userHandler");iH.addListener=function(e){sH.push(e)};oH.exports=Fne});var ti=M((bPe,cH)=>{"use strict";var TPe=z(),$I=ie(),Gne=(k(),v(K)),{ITC_ERRORS:Xm}=tn(),{parentPort:RPe,threadId:qne,isMainThread:$ne,workerData:yPe}=require("worker_threads"),{onMessageFromWorkers:Vne,broadcast:APe,broadcastWithAcknowledgement:Kne}=st();cH.exports={sendItcEvent:Yne,validateEvent:aH,SchemaEventMsg:Wne,UserEventMsg:zne};var dg;Vne(async(e,t)=>{dg=dg||Jm(),aH(e),dg[e.type]&&await dg[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function Yne(e){return!$ne&&e.message&&(e.message.originator=qne),Kne(e)}o(Yne,"sendItcEvent");function aH(e){if(typeof e!="object")return Xm.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||$I.isEmpty(e.type))return Xm.MISSING_TYPE;if(!e.hasOwnProperty("message")||$I.isEmpty(e.message))return Xm.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||$I.isEmpty(e.message.originator))return Xm.MISSING_ORIGIN;if(Gne.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return Xm.INVALID_EVENT(e.type)}o(aH,"validateEvent");function Wne(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(Wne,"SchemaEventMsg");function zne(e){this.originator=e}o(zne,"UserEventMsg")});var bo=M((wPe,fH)=>{"use strict";var lH=(k(),v(K)),NPe=ie(),fg=z(),uH=wU(),Vu,{sendItcEvent:dH}=ti();function jne(e){try{fg.info("signalSchemaChange called with message:",e),Vu=Vu||Jm();let t=new uH(lH.ITC_EVENT_TYPES.SCHEMA,e);return Vu.schema(t),dH(t)}catch(t){fg.error(t)}}o(jne,"signalSchemaChange");function Qne(e){try{fg.trace("signalUserChange called with message:",e),Vu=Vu||Jm();let t=new uH(lH.ITC_EVENT_TYPES.USER,e);return Vu.user(t),dH(t)}catch(t){fg.error(t)}}o(Qne,"signalUserChange");fH.exports={signalSchemaChange:jne,signalUserChange:Qne}});function mg(){return VI||(VI=et({table:"hdb_analytics_hostname",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"hostname"}]})),VI}function Xne(e){return e=e.replace(Jne,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 Zne(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 YI(e){let t=mH.default.createHash("shake128",{outputLength:4}),r;return(0,hH.isIPv6)(e)?r=Xne(e):r=e.toLowerCase(),Zne(Uint8Array.from(t.update(r).digest()))}var mH,hH,KI,VI,Jne,WI=fe(()=>{Le();mH=w(require("crypto")),hH=require("node:net"),KI=new Map;o(mg,"getAnalyticsHostnameTable");Jne=/(\d{1,3}\.){3}\d{1,3}$/;o(Xne,"normalizeIPv6");o(Zne,"nodeHashToNumber");o(YI,"stableNodeId")});var Co,zI=fe(()=>{Co={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 gg={};Ce(gg,{addAnalyticsListener:()=>th,calculateCPUUtilization:()=>LH,diffResourceUsage:()=>DH,recordAction:()=>gt,recordActionBinary:()=>Kr,recordHostname:()=>JI,setAnalyticsEnabled:()=>ese});function ese(e){NH=e}function tse(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 rse(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},Eg.set(e,a)}function gt(e,t,r,n,s){if(!NH)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let a=Eg.get(i);a?tse(e,a):rse(i,e,t,r,n,s),pg||nse()}function Kr(e,t,r,n,s){gt(!!e,t,r,n,s)}function th(e){CH.push(e)}function nse(){pg=performance.now(),setTimeout(async()=>{let e=performance.now()-pg;pg=0;let t=[],r={time:Date.now(),period:e,threadId:hl.threadId,metrics:t};for(let[s,i]of Eg){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 PH){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 MH()}let n=process.memoryUsage();t.push({metric:"memory",threadId:hl.threadId,byThread:!0,...n});for(let s of CH)s(t);Eg=new Map,hl.parentPort?hl.parentPort.postMessage({type:OH,report:r}):xH({report:r})},wH).unref()}async function JI(){let e=ve.hostname;Vr.trace?.("recordHostname server.hostname:",e);let t=YI(e);Vr.trace?.("recordHostname nodeId:",t);let r=mg();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=KI.get(r);n?Vr.trace?.("storeMetric cached nodeId:",n):(n=YI(r),Vr.trace?.("storeMetric new nodeId:",n),KI.set(r,n));let s={id:[(0,QI.getNextMonotonicTime)(),n],...t};Vr.trace?.(`storing metric ${JSON.stringify(s)}`),e.put(s.id,s)}function LH(e,t){let r=e.userCPUTime+e.systemCPUTime;return Vr.trace?.(`calculateCPUUtilization cpuTime: ${r} period: ${t}`),Math.round(r/t*100)/100}function DH(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 sse(e,t,r){let n=0;for(let[s,i]of Object.entries(r)){let a=`${t}.${s}`,c=i.getSize(),l={metric:Co.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 pH(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s?.getAuditSize();if(!i)return;let a=IH.statSync(s.primaryStore.env.path).size,c=sse(e,r,n),l=a-c,u={metric:Co.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 EH(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s?.getStorageStats();if(!i)return;let a={metric:Co.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 ise(e,t=6e4){let r=XI(),n=vH(),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 MH()}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 PH){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:Co.MAIN_THREAD_UTILIZATION,idle:h-_H,active:p-gH,taskQueueLatency:await s,time:m,...process.memoryUsage()};Ku(n,R)}_H=h,gH=p;let _=process.resourceUsage();_.time=m,_.userCPUTime=_.userCPUTime/1e3,_.systemCPUTime=_.systemCPUTime/1e3,Vr.trace?.(`process.resourceUsage: ${JSON.stringify(_)}`);let g=DH(hg,_);Vr.trace?.(`diffed resourceUsage: ${JSON.stringify(g)}`),g.time=m,g.period=hg.time?m-hg.time:t,g.cpuUtilization=LH(g,g.period);let y={metric:Co.RESOURCE_USAGE,...g};Ku(n,y),hg=_;let T=it();pH(n,T),pH(n,{system:T.system}),EH(n,T),EH(n,{system:T.system})}async function SH(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function XI(){return TH||(TH=et({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function vH(){return RH||(RH=et({table:"hdb_analytics",database:"system",audit:!0,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function cse(){UH=!0;let e=(0,eh.get)(U.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await ise(wH,e),await SH(XI(),ose),await SH(vH(),ase)},Math.min(e/2,2147483647)).unref()}function xH(e,t){let r=e.report;r.threadId=t?.threadId||hl.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(yH+=n.mean*n.count);r.totalBytesProcessed=yH,t&&(r.metrics.push({metric:Co.UTILIZATION,...t.performance.eventLoopUtilization(AH.get(t))}),AH.set(t,t.performance.eventLoopUtilization())),r.id=(0,QI.getNextMonotonicTime)(),XI().primaryStore.put(r.id,r),UH||cse(),lse&&(BH=dse(r))}async function dse(e){if(await BH,!Ma){let r=(0,Zm.dirname)((0,_g.getLogFilePath)());try{Ma=await(0,jI.open)((0,Zm.join)(r,"analytics.log"),"r+")}catch{Ma=await(0,jI.open)((0,Zm.join)(r,"analytics.log"),"w+")}}let t=(await Ma.stat()).size;if(t>use){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)+`
|
|
13
|
+
`},"serialize"),compressible:!1,q:.8});nn.set("application/x-www-form-urlencoded",{deserialize(e){let t=Buffer.isBuffer(e)?e.toString("utf8"):e,r={};for(let[n,s]of new URLSearchParams(t))if(r.hasOwnProperty(n)){let i=r[n];Array.isArray(i)?i.push(s):r.key=[i,s]}else r[n]=s;return r},serialize(e){let t=new URLSearchParams;for(let r in e)t.set(r,e);return t.toString()}});Nv={type:"application/json",serializeStream:Xf,serialize:Zf,deserialize:zZ,q:.5};nn.set("*/*",Nv);nn.set("",Nv);o(zZ,"tryJSONParse");o(tm,"registerContentHandlers");jZ=(0,bv.default)(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:a,type:c}=YE(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(YE,"findBestSerializer");Sv=cA.default.get(U.HTTP_COMPRESSIONTHRESHOLD);o(rm,"serialize");o(ga,"serializeMessage");o(fA,"asyncSerialization");o(mA,"hasAsyncSerialization");o(QZ,"streamToBuffer");JZ=["ascii","utf8","utf-8","utf16le","utf-16le","ucs2","ucs-2","base64","base64url","latin1","binary","hex"];o(XZ,"isBufferEncoding");o(ZZ,"parseContentType");o(ho,"getDeserializer");o(e6,"deserializerUnknownType");o(t6,"transformIterable");o(KE,"toCsvStream")});var gA={};Ce(gA,{Blob:()=>Ss,blobsWereEncoded:()=>kc,databasePaths:()=>pA,decodeBlobsWithWrites:()=>t_,decodeFromDatabase:()=>Gc,decodeWithBlobCallback:()=>r_,deleteBlob:()=>XE,deleteBlobsInObject:()=>Sa,deleteRootBlobPathsForDB:()=>_A,encodeBlobsAsBuffers:()=>d6,encodeBlobsWithFilePath:()=>e_,findBlobsInObject:()=>_u,getFileId:()=>ZE,getFilePathForBlob:()=>Bv,getRootBlobPathsForDB:()=>om,setDeletionDelay:()=>i6});function vv(){}function XE(e){let t=Bv(e);t&&setTimeout(()=>{(0,Ze.unlink)(t,r=>{r&&Eo.default.debug?.("Error trying to remove blob file",r)})},Uv)}function i6(e){Uv=e}function xv(e){let t=bn.get(e);if(!t)t={storageIndex:0,fileId:null,store:In},bn.set(e,t);else{if(t.saving)return t;t.store=In}return a6(t),t.source?hA(e,t.source,t):t.contentBuffer?o6(e,t):hA(e,sm.Readable.from(e.stream()),t),t}function hA(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(n6),h=(0,QE.createDeflate)(),t.pipe(h).pipe(f)):(m||f.write(r6),t.pipe(f)),t.on("error",_);function p(g){let y=BigInt(g),T=new Uint8Array(Rr),R=new DataView(T.buffer);return y|=BigInt(a?EA:Mv)<<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-Rr;e.size=g,(0,Ze.write)(f.fd,p(g),0,Rr,0,_)}})}),e}function ZE(e){return bn.get(e)?.fileId}function Bv(e){let t=bn.get(e);return t?.fileId&&im(t)}function om(e){if(!e)throw new Error("No store specified, can not determine blob storage path");let t=pA.get(e);if(!t){if(!e.databaseName)return Eo.default.warn?.("No database name specified, can not determine blob storage path"),[];let r=(0,JE.get)(U.STORAGE_BLOBPATHS);r?t=r.map(n=>(0,go.join)(n,e.databaseName)):t=[(0,go.join)((0,JE.getHdbBasePath)(),"blobs",e.databaseName)],pA.set(e,t)}return t}async function _A(e){let t=om(e);t&&await Promise.all(t.map(r=>Fv(r)))}async function Fv(e){if((0,Ze.existsSync)(e)){for(let t of await(0,js.readdir)(e,{withFileTypes:!0}))if(t.isDirectory())await Fv((0,go.join)(e,t.name));else try{await(0,js.unlink)((0,go.join)(e,t.name))}catch(r){Eo.default.warn?.("Error deleting file",r)}try{await(0,js.rmdir)(e)}catch(t){Eo.default.warn?.("Error deleting directory",t)}}}function im({storageIndex:e,fileId:t,store:r}){let n=om(r);return(0,go.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 o6(e,t){let r=t.contentBuffer,n=r.length;if(!(n<Dv))return e.size=n,hA(e,sm.Readable.from([r]),t)}function a6(e){let t=om(e.store),r=c6(),n=t?.length>1?l6(t,r):0,s=r.toString(16);e.storageIndex=n,e.fileId=s;let i=im(e),a=(0,go.dirname)(i);(0,Ze.existsSync)(a)||(0,Lv.ensureDirSync)(a),e.filePath=i}function c6(){let e=Pv.get(In);if(!e){let t=0,r=om(In);for(let n of r){let s=0;for(let i=0;i<3;i++){s=s*4096;let a=0;if((0,Ze.existsSync)(n))for(let c of(0,Ze.readdirSync)(n)){let l=parseInt(c,16);i===2&&c.length>3&&(l=parseInt(c.slice(-3),16),l+=parseInt(c.slice(0,-3),16)*68719476736),l>a&&(a=l)}s+=a,n=(0,go.join)(n,a.toString(16))}t=Math.max(t,s)}e=new BigInt64Array([BigInt(t)+1n]),e=new BigInt64Array(In.getUserSharedBuffer("blob-file-id",e.buffer)),Pv.set(In,e)}return Number(Atomics.add(e,0,1n))}function l6(e,t){let r=Date.now();if(!e.frequencyTable){e.lastUpdated=0;let s=new Array(jE);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,u6(e)),e.frequencyTable[t%jE]}async function u6(e){if(!js.statfs)return;let t=await Promise.all(e.map(async(s,i)=>{let a=await(0,js.statfs)(s),c=a.bavail*a.bsize;return Math.pow(c,.8)})),r=new Array(jE),n=t.map(s=>1/s);for(let s=0;s<jE;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 e_(e,t,r){Eu=t,In=r,kc=!1;try{return e()}finally{Eu=void 0,In=void 0}}function d6(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 t_(e,t){try{Gr=[],Hc=t,e()}catch(n){throw Hc=void 0,Gr=void 0,n}Hc=void 0;let r=Gr.length<2?Gr[0]:Promise.all(Gr);return Gr=void 0,r}function r_(e,t,r){In=r;try{return Hc=t,e()}finally{Hc=void 0}}function Gc(e,t){return In=t,e()}function Sa(e){_u(e,t=>{XE(t)})}function _u(e,t){if(e instanceof Ss)t(e);else if(Array.isArray(e))for(let r of e)typeof r=="object"&&r&&_u(r,t);else if(e&&typeof e=="object"&&!e[Symbol.iterator])for(let r in e){let n=e[r];typeof n=="object"&&n&&_u(e[r],t)}}function f6(){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 _o,js,Ze,QE,sm,Lv,JE,go,Eo,Dv,Rr,Mv,EA,Ov,r6,n6,Cv,bn,Hc,Ss,Eu,Gr,In,kc,nm,WE,s6,zE,Uv,pA,Pv,jE,Ts=fe(()=>{_o=require("msgpackr"),js=require("node:fs/promises"),Ze=require("node:fs"),QE=require("node:zlib"),sm=require("node:stream"),Lv=require("fs-extra"),JE=w(ce());k();go=require("path"),Eo=w(Ni());po();Dv=8192,Rr=8,Mv=0,EA=1,Ov=255,r6=new Uint8Array([0,Mv,255,255,255,255,255,255]),n6=new Uint8Array([0,EA,255,255,255,255,255,255]),Cv=0xffffffffffff,bn=new WeakMap,Ss=global.Blob||f6(),kc=!1,nm=new Uint8Array(8),WE=new DataView(nm.buffer),s6=6e4;o(vv,"InstanceOfBlobWithNoConstructor");vv.prototype=Ss.prototype;zE=class e extends vv{static{o(this,"FileBackedBlob")}type="";size;#e;#t;constructor(t){super(),t?.type&&(this.type=t.type),t?.size!=null&&(this.size=t.size)}on(t,r){if(t==="error")this.#e??=[],this.#e.push(r);else if(t==="size")this.#t??=[],this.#t.push(r);else throw new Error("Only 'error' and 'size' events are supported")}toJSON(){if(this.type?.startsWith("text")){let t=bn.get(this),{start:r,end:n,contentBuffer:s,asString:i}=t;return i||(s&&(n!==void 0||r!==void 0)&&(s=s.subarray(r??0,n??t.contentBuffer.length)),s?(t.asString=s.toString(),t.asString):(mA()&&fA(this.bytes().then(a=>t.contentBuffer=a)),`[blob: ${this.type}, ${this.size} bytes]`))}return{description:"Blobs that are not of type text/* can not be directly serialized as JSON, use as the body of a response or convert to another type"}}async text(){return(await this.bytes()).toString()}bytes(){let t=bn.get(this),{start:r,end:n,contentBuffer:s}=t;if(s)return(n!==void 0||r!==void 0)&&(s=s.subarray(r??0,n??t.contentBuffer.length)),Promise.resolve(s);let i=im(t),a,c=o(async()=>{let l,u=Rr;try{if(l=await(0,js.readFile)(i),l.length>=Rr){l.copy(nm,0,0,Rr);let f=WE.getBigUint64(0);if(Number(f>>48n)===Ov)throw new Error("Error in blob: "+buffer.subarray(Rr));if(u=Number(f&0xffffffffffffn),u<n&&(u=n),u<Cv&&(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]===EA?new Promise((f,m)=>{(0,QE.deflate)(l.subarray(Rr),(h,p)=>{h?m(h):f(d(p))})}):d(l.subarray(Rr))},"readContents");return c()}async arrayBuffer(){let t=await this.bytes(),r=new ArrayBuffer(t.length);return new Uint8Array(r).set(t),r}stream(){let t=bn.get(this),{contentBuffer:r,start:n,end:s}=t;if(r)return(s!=null||n!=null)&&(r=r.subarray(n??0,s??t.contentBuffer.length)),new ReadableStream({pull(_){_.enqueue(r),_.close()}});let i=im(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&&(Eo.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<Rr){y-- >0&&f!==!1?(p(),Eo.default.debug?.("File was empty, waiting for data to be written",i,y),setTimeout(()=>T(R,I),20).unref()):(Eo.default.debug?.("File was empty, throwing error",i,y),I(new Error(`Blob ${t.fileId} was empty`)));return}$.copy(nm,0,0,Rr);let j=WE.getBigUint64(0);if(Number(j>>48n)===Ov)return P(new Error("Error in blob: "+$.subarray(Rr)));if(g=Number(j&0xffffffffffffn),g<Cv&&h.size!==g&&(h.size=g,h.#t))for(let V of h.#t)V(g);$=$.subarray(Rr,x),l-=Rr}else if(x===0){let j=Buffer.allocUnsafe(8);return(0,Ze.read)(a,j,0,Rr,0,V=>{if(V)return P(V);if(nm.set(j),g=Number(WE.getBigUint64(0)&0xffffffffffffn),g>l){p()?u?d=setTimeout(()=>{P(new Error("File read timed out"))},s6).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 Eo.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=bn.get(this),i=new e(n&&{type:n});if(s?.fileId){let a={...s,start:t,end:r};bn.set(i,a),this.size!=null&&(i.size=(r==null?this.size:Math.min(r,this.size))-(t??0))}else if(s?.contentBuffer&&!s.storageBuffer){let a={...s,contentBuffer:s.contentBuffer.subarray(t,r)};bn.set(i,a),i.size=(r??this.size)-t}else throw new Error("Can not slice a streaming blob that is not backed by a file");return i}save(t){if(In=t?.primaryStore?.rootStore,!In)throw new Error("No target table specified");return xv(this).saving??Promise.resolve()}},Uv=500;o(XE,"deleteBlob");o(i6,"setDeletionDelay");global.createBlob=function(e,t){let r=new zE(t),n={storageIndex:0,fileId:null,flush:t?.flush,compress:t?.compress};if(bn.set(r,n),e instanceof Uint8Array)r.size=e.length,n.contentBuffer=e;else if(e instanceof sm.Readable)n.source=e;else if(typeof e=="string")n.contentBuffer=Buffer.from(e);else if(e?.[Symbol.asyncIterator]||e?.[Symbol.iterator])n.source=sm.Readable.from(e);else throw new Error("Invalid source type");return r};o(xv,"saveBlob");o(hA,"writeBlobWithStream");o(ZE,"getFileId");o(Bv,"getFilePathForBlob");pA=new Map;o(om,"getRootBlobPathsForDB");o(_A,"deleteRootBlobPathsForDB");o(Fv,"rimrafSteadily");o(im,"getFilePath");o(o6,"writeBlobWithBuffer");o(a6,"generateFilePath");Pv=new Map;o(c6,"getNextFileId");jE=128;o(l6,"getNextStorageIndex");o(u6,"createFrequencyTableForStoragePaths");o(e_,"encodeBlobsWithFilePath");o(d6,"encodeBlobsAsBuffers");o(t_,"decodeBlobsWithWrites");o(r_,"decodeWithBlobCallback");o(Gc,"decodeFromDatabase");o(Sa,"deleteBlobsInObject");o(_u,"findBlobsInObject");(0,_o.addExtension)({Class:Ss,type:11,unpack:o(function(e){let t=(0,_o.unpack)(e),r=new zE;if(Object.assign(r,t[0]),typeof t[1]!="object"){if(bn.set(r,{storageIndex:t[1],fileId:t[2],store:In}),Hc)return Hc(r)??r;if(!In)throw new Error("No store specified, cannot load blob from storage")}else bn.set(r,{storageIndex:0,fileId:null,storageBuffer:e,contentBuffer:t[1]}),r.size=t[1]?.length;return r},"unpack"),pack:o(function(e){let t=bn.get(e);if(Eu!==void 0&&(kc=!0,t?.recordId!==void 0&&t.recordId!==Eu))throw new Error("Cannot use the same blob in two different records");let r={...e};if(e.type&&(r.type=e.type),e.size!==void 0&&(r.size=e.size),t){if(t.storageBuffer)return t.storageBuffer;if(t.contentBuffer?.length<Dv)return r.size=t.contentBuffer.length,(0,_o.pack)([r,t.contentBuffer])}if(Eu!==void 0){if(t=xv(e),!t.fileId)throw new Error("Unable to save blob without file id");return t.recordId=Eu,(0,_o.pack)([r,t.storageIndex,t.fileId])}if(t)try{let n=(0,Ze.readFileSync)(im(t));if(n.length>=Rr&&(n.copy(nm,0,0,Rr),Number(WE.getBigUint64(0)&0xffffffffffffn)===n.length-Rr))return Buffer.concat([(0,_o.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,_o.addExtension)({Class:Promise,type:12,pack(){throw new Error("Cannot encode a promise")}});o(f6,"polyfillBlob")});var $v={};Ce($v,{onStorageReclamation:()=>am,runReclamationHandlers:()=>yA,setAvailableSpaceRatioGetter:()=>h6});function am(e,t,r){(r||(0,s_.getWorkerIndex)()===(0,s_.getWorkerCount)()-1)&&(n_.has(e)||n_.set(e,[]),n_.get(e).push({priority:0,handler:t}),RA||(RA=setTimeout(yA,kv).unref()))}async function yA(){for(let[e,t]of n_)try{let r=await qv(e),n=m6/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&&(TA.default.info?.(`Running storage reclamation handler for ${e} with priority ${n}`),await c)}}}catch(r){TA.default.error?.("Error running storage reclamation handlers",r)}RA=setTimeout(yA,kv).unref()}function h6(e){qv=e??Gv}var SA,s_,TA,i_,Hv,n_,m6,kv,RA,Gv,qv,o_=fe(()=>{SA=require("node:fs/promises"),s_=w(st()),TA=w(Ni());k();i_=w(ce()),Hv=w(ie());i_.default.initSync();n_=new Map,m6=i_.default.get(U.STORAGE_RECLAMATION_THRESHOLD)??.4,kv=(0,Hv.convertToMS)(i_.default.get(U.STORAGE_RECLAMATION_INTERVAL))||36e5;o(am,"onStorageReclamation");Gv=o(async e=>{if(SA.statfs){let t=await(0,SA.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"),qv=Gv;o(yA,"runReclamationHandlers");o(h6,"setAvailableSpaceRatioGetter")});var rU={};Ce(rU,{ACTION_32_BIT:()=>d_,ACTION_64_BIT:()=>_6,AUDIT_STORE_OPTIONS:()=>um,Decoder:()=>$c,HAS_BLOBS:()=>Nn,HAS_CURRENT_RESIDENCY_ID:()=>Vc,HAS_EXPIRATION_EXTENDED_TYPE:()=>mm,HAS_ORIGINATING_OPERATION:()=>fm,HAS_PREVIOUS_RESIDENCY_ID:()=>Kc,REMOTE_SEQUENCE_UPDATE:()=>f_,createAuditEntry:()=>Su,getLastRemoved:()=>OA,openAuditStore:()=>l_,readAuditEntry:()=>Ut,removeAuditEntry:()=>u_,setAuditRetention:()=>E6,transactionKeyEncoder:()=>Xv});function l_(e){let t=e.auditStore=e.openDB(AA.AUDIT_STORE_NAME,{create:!1,...um});t||(t=e.auditStore=e.openDB(AA.AUDIT_STORE_NAME,um),Kv(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=IA;am(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()-bA/(1+i*i)})){try{m=u_(t,p,_)}catch(g){gu.warn("Error removing audit entry",g)}if(h=p,await new Promise(setImmediate),++f>=p6){a=10;break}}await m}finally{f===0?a=Math.min(a<<1,bA/10):(Kv(t,h),a>100&&(a=a>>1)),d(void 0),c()}},a).unref()});return u}if(o(c,"scheduleAuditCleanup"),t.scheduleAuditCleanup=c,(0,lm.getWorkerIndex)()===(0,lm.getWorkerCount)()-1&&c(),(0,lm.getWorkerIndex)()===0&&!Vv)for(let l of t.getKeys({reverse:!0,limit:1}))l>Date.now()&&(Vv=!0,gu.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 u_(e,t,r){let n=g6(r),s;if(n&Nn){s=Ut(r);let i=e.tableStores[s.tableId],a=i?.getEntry(s.recordId);(!a||a.version!==s.version||!a.value)&&Gc(()=>Sa(s.getValue(i)),i.rootStore)}if((n&15)===NA){s=s||Ut(r);let i=s.tableId;e.tableStores[s.tableId]?.getEntry(s.recordId)?.version===s.version&&e.deleteCallbacks?.[i]?.(s.recordId,s.version)}return e.remove(t)}function Kv(e,t){wA[0]=t,e.put(Symbol.for("last-removed"),Zv)}function OA(e){let t=e.get(Symbol.for("last-removed"));if(t)return Zv.set(t),wA[0]}function E6(e,t=IA){bA=e,IA=t}function Su(e,t,r,n,s,i,a,c,l,u,d,f,m){let h=eU[a];if(!h)throw new Error(`Invalid audit entry type ${a}`);let p=1;if(n&&(n>1?Ta.setFloat64(0,n):Rs.set(CA),p=9),l){if(l&255)throw new Error("Illegal extended type");p+=3}y(s),y(t),g(r),Ta.setFloat64(p,e),p+=8,l&Vc&&y(u),l&Kc&&y(d),l&mm&&(Ta.setFloat64(p,f),p+=8),l&fm&&y(tU[m]),i?g(i):Rs[p++]=0,l?Ta.setUint32(n?8:0,h|l|3221225472):Rs[n?8:0]=h;let _=Rs.subarray(0,p);if(c)return Buffer.concat([_,c]);return _;function g(T){let R=p;p+=1,p=(0,qc.writeKey)(T,Rs,p);let I=p-R-1;I>127?I>16383?(gu.error("Key or username was too large for audit entry",T),p=R+1,Rs[R]=0):(Rs.copyWithin(R+2,R+1,p),Ta.setUint16(R,I|32768),p++):Rs[R]=I}function y(T){T<128?Rs[p++]=T:T<16384?(Ta.setUint16(p,T|32768),p+=2):T<1056964608?(Ta.setUint32(p,T|3221225472),p+=4):(Rs[p]=255,Ta.setUint32(p+1,T),p+=5)}}function g6(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 $c(e.buffer,e.byteOffset,e.byteLength));return n.position=t,n.readInt()}function Ut(e,t=0,r=void 0){try{let n=e.dataView||(e.dataView=new $c(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&Vc&&(m=n.readInt()),i&Kc&&(h=n.readInt()),i&mm&&(p=n.readFloat64()),i&fm){let R=n.readInt();_=tU[R]}l=n.readInt();let g=n.position,y=n.position+=l,T;return{type:eU[i&7],tableId:c,nodeId:a,get recordId(){return(0,qc.readKey)(e,u,d)},getBinaryRecordId(){return e.subarray(u,d)},version:f,previousLocalTime:s,get user(){return y>g?(0,qc.readKey)(e,g,y):void 0},get encoded(){return t?e.subarray(t,r):e},getValue(R,I,P){if(i&a_||i&cm&&!I)return T||(T=Gc(()=>R.decoder.decode(e.subarray(n.position,r)),R.rootStore)),T;if(i&cm&&P)return rA(R.getEntry(this.recordId),P,R)},getBinaryValue(){return i&(a_|cm)?e.subarray(n.position,r):void 0},extendedType:i,residencyId:m,previousResidencyId:h,expiresAt:p,originatingOperation:_}}catch(n){return gu.error("Reading audit entry error",n,e),{}}}var qc,c_,AA,lm,Jv,gu,Rs,Ta,Xv,um,bA,p6,wA,Zv,IA,Vv,a_,cm,Yv,NA,Wv,zv,jv,Qv,d_,_6,f_,Vc,Kc,fm,mm,Nn,eU,tU,$c,uo=fe(()=>{qc=require("ordered-binary"),c_=w(ce()),AA=w(kt());k();lm=w(st()),Jv=w(ie());Yc();gu=w(z());qE();Ts();o_();(0,c_.initSync)();Rs=Buffer.alloc(2816),Ta=new DataView(Rs.buffer,Rs.byteOffset,2816),Xv={writeKey(e,t,r){return e===dm?(t.set(dm,r),r+8):typeof e=="number"?((t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).setFloat64(r,e),r+8):(0,qc.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,qc.readKey)(e,t,r)}},um={encoding:"binary",keyEncoder:Xv},bA=(0,Jv.convertToMS)((0,c_.get)(U.LOGGING_AUDITRETENTION))||86400*3,p6=1e3,wA=new Float64Array(1),Zv=new Uint8Array(wA.buffer),IA=1e4,Vv=!1;o(l_,"openAuditStore");o(u_,"removeAuditEntry");o(Kv,"updateLastRemoved");o(OA,"getLastRemoved");o(E6,"setAuditRetention");a_=16,cm=32,Yv=1,NA=2,Wv=3,zv=4,jv=5,Qv=6,d_=14,_6=15,f_=11,Vc=512,Kc=1024,fm=2048,mm=4096,Nn=8192,eU={put:Yv|a_,[Yv]:"put",delete:NA,[NA]:"delete",message:Wv|a_,[Wv]:"message",invalidate:zv|cm,[zv]:"invalidate",patch:jv|cm,[jv]:"patch",relocate:Qv,[Qv]:"relocate"},tU={insert:1,update:2,upsert:3,1:"insert",2:"update",3:"upsert"};o(Su,"createAuditEntry");o(g6,"readAction");o(Ut,"readAuditEntry");$c=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 aU={};Ce(aU,{ENTRY:()=>T6,HAS_EXPIRATION:()=>p_,HAS_RESIDENCY_ID:()=>UA,HAS_STRUCTURE_UPDATE:()=>E_,LAST_TIMESTAMP_PLACEHOLDER:()=>dm,LOCAL_TIMESTAMP:()=>S6,METADATA:()=>Ru,NEW_TIMESTAMP_PLACEHOLDER:()=>sU,NO_TIMESTAMP:()=>PA,PENDING_LOCAL_TIME:()=>xA,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>CA,RecordEncoder:()=>vA,TIMESTAMP_ASSIGN_LAST:()=>y6,TIMESTAMP_ASSIGN_NEW:()=>iU,TIMESTAMP_ASSIGN_PREVIOUS:()=>oU,TIMESTAMP_PLACEHOLDER:()=>m_,TIMESTAMP_RECORD_PREVIOUS:()=>LA,entryMap:()=>Ra,handleLocalTimeForGets:()=>__,lastMetadata:()=>ct,recordUpdater:()=>BA,removeEntry:()=>zc});function b6(){return Em[0]=Em[0]^64,R6.getFloat64(0)}function __(e,t){let r=e.getEntry;e.readCount=0,e.cachePuts=!1,e.rootStore=t,e.encoder.rootStore=t,e.getEntry=function(a,c){e.readCount++,ct=null;let l=r.call(this,a,c);return l&&(ct&&(l.metadataFlags=ct[Ru],l.localTime=ct.localTime,l.residencyId=ct.residencyId,ct.expiresAt>=0&&(l.expiresAt=ct.expiresAt),ct=null),l.value&&Ra.set(l.value,l),l.key=a),l};let n=e.get;e.get=function(a,c){ct=null;let l=n.call(this,a,c);return ct&&l&&(Ra.set(l,ct),ct=null),l};let s=e.getRange;e.getRange=function(a){let c=s.call(this,a);return a.valuesForKey?c.map(l=>l?.value):a.values===!1||a.onlyCount?c:c.map(l=>(ct&&(l.metadataFlags=ct[Ru],l.localTime=ct.localTime,l.residencyId=ct.residencyId,ct.expiresAt>=0&&(l.expiresAt=ct.expiresAt),ct=null),l))};let i=e.useReadTransaction();if(i.done(),!i.done.isTracked){let a=i.constructor,c=i.use,l=i.done;a.prototype.use=function(){this.timerTracked||(this.timerTracked=!0,Wc.push(new WeakRef(this))),c.call(this)},a.prototype.done=function(){if(l.call(this),this.isDone)for(let u=0;u<Wc.length;u++){let d=Wc[u].deref();(!d||d.isDone||d.isCommitted)&&Wc.splice(u--,1)}},a.prototype.done.isTracked=!0}return e}function BA(e,t,r){return function(n,s,i,a,c=-1,l,u,d="put",f,m){f||l==null?Tu=i?.localTime?LA|oU:PA:Tu=l?i?.localTime?LA|16384:iU|16384:PA;let h=u?.expiresAt;if(h>=0&&(c|=p_),pm=c,DA=h,i?.version===a&&l===!1)throw new Error("Must retain local time if version is not changed");let p={version:a,instructedWrite:Tu>0},_,g=0;try{let y=i?.residencyId,T=u?.residencyId;T&&(MA=T,pm|=UA,g|=Vc),y!==T&&(g|=Kc,y||(y=0)),c&p_&&(g|=mm),u?.originatingOperation&&(g|=fm),f&&(p.ifVersion=_=i?.version??null),i&&i.value&&i.metadataFlags&Nn&&(r.getBinaryFast(i.localTime)||Sa(i.value));let R;if(s!==void 0&&(R=e_(()=>e.put(n,s,p),n,e.rootStore),kc&&(g|=Nn)),l){let I=u?.user?.username;if(m&&(e_(()=>e.encoder.encode(m),n,e.rootStore),kc&&(g|=Nn)),e.encoder.hasStructureUpdate&&(g|=E_,e.encoder.hasStructureUpdate=!1),f&&i?.localTime){let P=i?.localTime,Y=r.get(P);if(Y){let te=Ut(Y).previousLocalTime;return R=r.put(P,Su(a,t,n,te,u?.nodeId??server.replication.getThisNodeId(r)??0,I,d,hm,g,T,y,h),{ifVersion:_}),R}}R=r.put(s===void 0?sU:dm,Su(a,t,n,i?.localTime?1:0,u?.nodeId??server.replication?.getThisNodeId(r)??0,I,d,hm,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 zc(e,t,r){if(t)return t.value&&t.metadataFlags&Nn&&!e.auditStore.getBinaryFast(t.localTime)&&Sa(t.value),e.remove(t.key,r)}var nU,h_,m_,dm,CA,sU,S6,Ru,T6,Em,R6,PA,iU,y6,oU,LA,p_,UA,xA,E_,Ra,A6,hm,Tu,pm,DA,MA,ct,vA,Wc,Yc=fe(()=>{nU=require("msgpackr");uo();h_=w(z());Ts();Ts();m_=new Uint8Array([1,1,1,1,4,64,0,0]),dm=new Uint8Array([1,1,1,1,1,0,0,0]),CA=new Uint8Array([1,1,1,1,3,64,0,0]),sU=new Uint8Array([1,1,1,1,0,64,0,0]),S6=Symbol("local-timestamp"),Ru=Symbol("metadata"),T6=Symbol("entry"),Em=new Uint8Array(8),R6=new DataView(Em.buffer,0,8),PA=0,iU=0,y6=1,oU=3,LA=4,p_=16,UA=32,xA=1,E_=256,Ra=new WeakMap,Tu=0,pm=-1,DA=-1,MA=0,ct=null,vA=class extends nU.Encoder{static{o(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0;class r{static{o(this,"RecordObject")}getUpdatedTime(){return Ra.get(this)?.version}getExpiresAt(){return Ra.get(this)?.expiresAt}}t.structPrototype=r.prototype,super(t);let n=this.encode;this.encode=function(i,a){if(Tu||pm>=0){let c=0,l=Tu;l&&(c+=8,Tu=0);let u=pm,d=DA,f=MA;u>=0&&(c+=4,pm=-1,d>=0&&(c+=8,DA=-1),f&&(c+=4,MA=0));let m=A6=n.call(this,i,a|2048|c);hm=m.subarray((m.start||0)+c,m.end);let h=m.start||0;return l&&(m_[4]=l,m_[5]=l>>8,m.set(m_,h),h+=8),kc&&(u|=Nn),u>=0&&((m.dataView||(m.dataView=new DataView(m.buffer,m.byteOffset,m.byteLength))).setUint32(h,u|d_<<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 hm=n.call(this,i,a),hm};let s=this.saveStructures;this.saveStructures=function(i,a){let c=s.call(this,i,a);return this.hasStructureUpdate=!0,c}}decode(t,r){ct=null;let n=r?.start||0,s=r>-1?r:r?.end||t.length,i=t[n],a=0;try{if(i<32&&s>2){let c=n,l;if(i===2){if(t.copy)t.copy(Em,0,c),c+=8;else for(let m=0;m<8;m++)Em[m]=t[c++];l=b6(),i=t[c]}let u,d;i<32&&(i===d_?(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&p_&&(u=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8),a&UA&&(d=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4));let f=Gc(()=>r?.valueAsBuffer?t.subarray(c,s):super.decode(t.subarray(c,s),s-c),this.rootStore);return ct={localTime:l,[Ru]:a,expiresAt:u,residencyId:d},f}return r?.valueAsBuffer?t:Gc(()=>super.decode(t,r),this.rootStore)}catch(c){return h_.error("Error decoding record",c,"data: "+t.slice(0,40).toString("hex")),null}}};o(b6,"getTimestamp");o(__,"handleLocalTimeForGets");Wc=[];setInterval(()=>{for(let e=0;e<Wc.length;e++){let t=Wc[e].deref();!t||t.isDone||t.isCommitted?Wc.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(h_.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):h_.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(BA,"recordUpdater");o(zc,"removeEntry")});function kA(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?kA(f.conditions,f.operator,r,n,s,i,a,c):Iu(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=gm(p,r,i,c,g,h);return m&&_<f.length-1&&h&&(h=M6(r.primaryStore,p.estimated_count,h)),y}).filter(Boolean)}o(d,"mapConditionsToFilters")}function Iu(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=Ci(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=Iu({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=!!Ci(P.attributes,I.relationship.to)?.elements;te=C6(te,I,P.primaryStore,x,Y)}if(I.relationship.from){let x=o($=>($?.key!==void 0&&($=$.key),Iu({attribute:I.relationship.from,value:$},t,r,n,s,Y)),"searchEntry");I.elements?(i[c[0]]=Y,te=P6(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(GA[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]=Oi.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>ys.MAX_SEARCH_KEY_LENGTH&&(m=m.slice(0,ys.MAX_SEARCH_KEY_LENGTH)+ys.OVERFLOW_MARKER,_=!1,y=gm(e,n,null,i,d)),typeof h=="string"&&h.length>ys.MAX_SEARCH_KEY_LENGTH&&(h=h.slice(0,ys.MAX_SEARCH_KEY_LENGTH)+ys.OVERFLOW_MARKER,p=!0,y=y??gm(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??gm(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:ya.SKIP:new Promise((Y,te)=>setImmediate(()=>{try{Y(P&&y(P)?I:ya.SKIP)}catch(x){te(x)}}))}:I=>I.value==null&&!(I.metadataFlags&(wn|Aa))?ya.SKIP:I);return R.hasEntries=!0,R}else return f?f.customIndex?f.customIndex.search(e,a).map(R=>{if(typeof R=="object"&&R){let{key:I,...P}=R,Y=n.primaryStore.getEntry(I);return{...P,...Y}}return R}):f.getRange(T).map(y?function({key:R,value:I}){let P;return typeof R=="string"&&R.length>ys.MAX_SEARCH_KEY_LENGTH?P=n.primaryStore.get(I):P={[c]:R},this.isSync?y(P)?I:ya.SKIP:new Promise((Y,te)=>setImmediate(()=>{try{Y(y(P)?I:ya.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:ya.SKIP:new Promise((P,Y)=>setImmediate(()=>{try{P(I&&y(I)?R:ya.SKIP)}catch(te){Y(te)}}))})}function Ci(e,t){if(Array.isArray(t))if(t.length>1){let r=Ci(e,t[0]),n=(r?.definition?.tableClass||r?.elements?.definition?.tableClass)?.attributes??r?.properties;return n?Ci(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 C6(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 P6(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 gm(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=Ci(t.attributes,d),m=f.definition?.tableClass||f.elements.definition?.tableClass,h=n?.[d],p=gm({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=ct):(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()),GA[a]||a){case ys.SEARCH_TYPES.EQUALS:case void 0:return u(c,d=>d===l,!0);case"contains":return u(c,d=>d?.toString().includes(l));case"ends_with":return u(c,d=>d?.toString().endsWith(l));case"starts_with":return u(c,d=>typeof d=="string"&&d.startsWith(l),!0);case"prefix":return Array.isArray(l)?l[l.length-1]==null&&(l=l.slice(0,-1)):l=[l],u(c,d=>{if(!Array.isArray(d))return!1;for(let f=0,m=l.length;f<m;f++)if(d[f]!==l[f])return!1;return!0},!0);case"between":return l[0]instanceof Date&&(l[0]=l[0].getTime()),l[1]instanceof Date&&(l[1]=l[1].getTime()),u(c,d=>(0,Oi.compareKeys)(d,l[0])>=0&&(0,Oi.compareKeys)(d,l[1])<=0,!0);case"gt":return u(c,d=>(0,Oi.compareKeys)(d,l)>0);case"ge":return u(c,d=>(0,Oi.compareKeys)(d,l)>=0);case"lt":return u(c,d=>(0,Oi.compareKeys)(d,l)<0);case"le":return u(c,d=>(0,Oi.compareKeys)(d,l)<=0);case"ne":return u(c,d=>(0,Oi.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&&S_(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=Iu(e,r.transaction.getReadTxn(),!1,t),Y;y.to?Y=P.flatMap(x=>t.primaryStore.get(x)[y.to]):Y=P.map(Nu);let te=new Set(Y);y.idFilter=x=>te.has(Nu(x)),y.idFilter.idSet=te}return I}return o(y,"recordFilter"),s&&(y.idFilter=f),y}o(u,"attributeComparator")}function S_(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/So(e.primaryStore):i.estimated_count}return r.estimated_count=s,r.estimated_count}let n=r.comparator||r.search_type;if(n=GA[n]||n,n===ys.SEARCH_TYPES.EQUALS||!n){let s=r[0]??r.attribute;if(s==null||s===e.primaryKey)r.estimated_count=1;else if(Array.isArray(s)&&s.length>1){let i=Ci(e.attributes,s[0]),a=i.definition?.tableClass||i.elements.definition?.tableClass,c=S_(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*So(e.indices[i.relationship.from])/(So(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=So(e.primaryStore)-(i?i.getValuesCount(null):0):r.estimated_count=1/0}else if(n==="starts_with"||n==="prefix")r.estimated_count=w6*So(e.primaryStore)+1;else if(n==="between")r.estimated_count=N6*So(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=So(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=I6*So(e.primaryStore)+1}typeof r.descending=="boolean"&&(r.estimated_count/=2)}return r.estimated_count}return o(t,"estimateConditionForTable"),t}function T_(e,t){if(e)if(To=e,yu.lastIndex=0,L6.test(e))try{if(t&&(t.conditions=[]),Qs=t??new bu,_m(Qs,""),Lr!==To.length&&Gt("Unable to parse query, unexpected end of query"),Qs.parseErrorMessage&&(Qs.parseError=new FA(t.parseErrorMessage),!t))throw Qs.parseError;return Qs}catch(r){if(r.statusCode=400,r.message=`Unable to parse query, ${r.message} at position ${Lr} in '${To}'`,Qs.parseErrorMessage&&(r.message+=", "+Qs.parseErrorMessage),t)t.parseError=r;else throw r}else return t??new URLSearchParams(e)}function Gt(e){let t=`${e} at position ${Lr}`;Qs.parseErrorMessage=Qs.parseErrorMessage?Qs.parseErrorMessage+", "+t:t}function _m(e,t){let r=yu,n,s,i,a,c,l=decodeURIComponent,u;for(;n=r.exec(To);){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=cU):(l=decodeURIComponent,i="equals",d||Gt("attribute must be specified before equality comparator"),s=Au(d));break;case"==":case"!=":case"<":case"<=":case">":case">=":case"===":case"!==":i=O6[f],l=HA[i]?cU:decodeURIComponent,d||Gt(`attribute must be specified before comparator ${f}`),s=Au(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"&&lU(p,d),s===""){let _=e.conditions[e.conditions.length-1];_.chainedConditions=_.chainedConditions||[],_.chainedConditions.push(p),_.operator=u}else g_(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(Au(d)),s=void 0;break;case"(":yu.lastIndex=Lr;let h=_m(d?[]:new bu,")");switch(d){case"":g_(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=uU(h);break;default:Gt(`unknown query function call ${d}`)}To[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"),yu.lastIndex=Lr,m=_m([],"}"),m.name=d,e.push(m),To[Lr]===","?r.lastIndex=++Lr:a=!0;break;case"[":if(yu.lastIndex=Lr,d?(m=_m(new bu,"]"),m.name=d):m=_m(e.conditions?new bu:[],"]"),e.conditions)if(g_(e,u),To[Lr]==="="){l=decodeURIComponent,i="equals",s=Au(d),r.lastIndex=++Lr;break}else e.conditions.push(m),s=null;else e.push(m);To[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"&&lU(p,d),g_(e,u),e.conditions.push(p)}else d&&Gt("no attribute or comparison specified");else(d||e.length>0&&c)&&e.push(Au(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?D6:yu,r.lastIndex=Lr),Lr===To.length)return e}t&&Gt(`expected '${t}', but encountered end of string`)}function g_(e,t){e.conditions.length>0&&(e.operator?e.operator!==t&&Gt("Can not mix operators within a condition grouping"):e.operator=t)}function Au(e){return e.indexOf(".")>-1?e.split(".").map(Au):decodeURIComponent(e)}function cU(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 lU(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 uU(e){let t=dU(e[0]);return e.length>1&&(t.next=uU(e.slice(1))),t}function dU(e){if(Array.isArray(e)){let t=dU(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 Nu(e){return Array.isArray(e)?e.join("\0"):e}function So(e){let t=Date.now();return(e.estimatedEntryCountExpires||0)<t&&(e.estimatedEntryCount=e.getStats().entryCount,e.estimatedEntryCountExpires=t+1e4),e.estimatedEntryCount}function M6(e,t,r){return t*r/So(e)}var qr,ys,Oi,ya,I6,N6,w6,O6,HA,GA,FA,L6,yu,D6,Lr,Qs,To,bu,R_=fe(()=>{qr=w(Ee()),ys=w(kt()),Oi=require("ordered-binary"),ya=require("lmdb");Sm();Yc();I6=.3,N6=.1,w6=.05,O6={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},HA={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};o(kA,"executeConditions");o(Iu,"searchByIndex");o(Ci,"findAttribute");o(C6,"joinTo");o(P6,"joinFrom");GA={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(gm,"filterByType");o(S_,"estimateCondition");FA=class extends qr.Violation{static{o(this,"SyntaxViolation")}},L6=/[()[\]|!<>.]|(=\w*=)/,yu=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,D6=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/g;o(T_,"parseQuery");o(Gt,"recordError");o(_m,"parseBlock");o(g_,"assignOperator");o(Au,"decodeProperty");o(cU,"typedDecoding");o(lU,"wildcardDecoding");o(uU,"toSortObject");o(dU,"toSortEntry");bu=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(Nu,"flattenKey");o(So,"estimatedEntryCount");o(M6,"intersectionEstimate")});var fU,Js,y_=fe(()=>{fU=w(Ws());ba();Js=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,fU._assignPackageExport)("Resource",Dr)});var _U={};Ce(_U,{MultiPartId:()=>A_,Resource:()=>Dr,contextStorage:()=>Ou,snakeCase:()=>U6,transformForSelect:()=>b_});function U6(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function mU(e,t){if(jc=!1,e==="")return null;if(e=e.slice(1),t.splitSegments){if(e.indexOf("/")===-1)return e===""?(jc=!0,null):t.coerceId(decodeURIComponent(e));let r=e.split("/"),n=new A_;for(let s=0;s<r.length;s++){let i=r[s];if(!i&&s===r.length-1){jc=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}else{if(e==="")return jc=!0,null;e[e.length-1]==="/"&&(jc=!0)}return t.coerceId(decodeURIComponent(e))}function On(e,t){n.reliesOnPrototype=!0;let r=t.hasContent;return n;function n(s,i,a){let c,l,u,d;if(r){if(a)d=i,a=a.getContext?.()||a;else if(i)typeof s=="object"&&s&&(!Array.isArray(s)||typeof s[0]=="object")?(d=s,c=d[this.primaryKey]??null,a=i.getContext?.()||i):i?.transaction instanceof lo?a=i:d=i;else if(s&&typeof s=="object")d=s,s=void 0,c=d.getId?.()??d[this.primaryKey];else throw new wu.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 Js,l.id=c,u=!1)))}c===void 0&&(c=s.id??null,c==null&&(u=!0))}else c=s,l=new Js,l.id=c,c==null&&(u=!0);l||(l=new Js,l.id=c),u&&(l.isCollection=!0);let f;a||(a=Ou.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(_=>Ou.run(a,()=>p(_)),"runAction")),a?.transaction){let _=this.getResource(c,a,f);return _.then?_.then(h):h(_)}else return vt(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 wu.AccessViolation(a.user);return typeof d?.then=="function"?d.then(T=>e(_,l,a,T)):e(_,l,a,d)});if(!g)throw new wu.AccessViolation(a.user)}return typeof d?.then=="function"?d.then(g=>e(_,l,a,g)):e(_,l,a,d)}o(p,"authorizeActionOnResource")}}function Vn(e,t){let r=new wu.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 qA(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 b_(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):qA(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(qA(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(qA(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]=b_(c.select||c,d)}let u=a(c.name);return l(u)}else return a(c);else return c}}o(i,"handleProperty")}var hU,pU,wu,EU,Ou,v6,Dr,jc,A_,ba=fe(()=>{hU=require("crypto");Qf();pu();pU=w(Ws()),wu=w(Ee());Uc();R_();EU=require("async_hooks");y_();Ou=new EU.AsyncLocalStorage,v6={json:"application/json",cbor:"application/cbor",msgpack:"application/x-msgpack",csv:"text/csv"},Dr=class{static{o(this,"Resource")}#e;#t;#r;static transactions;static directURLMapping=!1;static loadAsInstance;constructor(t,r){this.#e=t;let n=r?.getContext?r.getContext()??null:void 0;this.#t=n!==void 0?n:r||null}static get=On(function(t,r,n,s){let i=t.get?.(r);if(i?.then)return i.then(a);return a(i);function a(c){let l;if((l=r?.select)&&c!=null&&!c.selectApplied){let u=b_(l,t.constructor);return typeof c?.map=="function"?c.map(u):u(c)}return c}},{type:"read",letItLinger:!0,ensureLoaded:!0,async:!0});static put=On(function(t,r,n,s){if(Array.isArray(s)&&t.#r&&t.constructor.loadAsInstance!==!1){let i=[];for(let a of s){let c=t.constructor,l=a[c.primaryKey],u=c.getResource(l,n,{async:!0});u.then?i.push(u.then(d=>d.put(a,n))):i.push(u.put(a,n))}return Promise.all(i)}return t.put?t.constructor.loadAsInstance===!1?t.put(r,s):t.put(s,r):Vn(t,"put")},{hasContent:!0,type:"update"});static patch=On(function(t,r,n,s){return t.patch?t.constructor.loadAsInstance===!1?t.patch(r,s):t.patch(s,r):Vn(t,"patch")},{hasContent:!0,type:"update"});static delete=On(function(t,r,n,s){return t.delete?t.delete(r):Vn(t,"delete")},{hasContent:!1,type:"delete"});static getNewId(){return(0,hU.randomUUID)()}static create(t,r,n){n?n.getContext&&(n=n.getContext()):n=Ou.getStore()??{};let s;return this.loadAsInstance===!1?s=t:t==null?s=r?.[this.primaryKey]??this.getNewId():Array.isArray(t)&&typeof t[0]!="object"?s=r?.[this.primaryKey]??[...t,this.getNewId()]:typeof t!="object"?s=r?.[this.primaryKey]??[t,this.getNewId()]:(s=t?.[this.primaryKey]??this.getNewId(),n=r||{},r=t),vt(n,async()=>{let i=new this(s,n),a=await i.create?i.create(s,r):Vn(i,"create");return n.newLocation=s??a?.[this.primaryKey],n.createdResource=!0,this.loadAsInstance===!1?a:i})}static invalidate=On(function(t,r,n,s){return t.invalidate?t.invalidate(r):Vn(t,"delete")},{hasContent:!1,type:"update"});static post=On(function(t,r,n,s){return t.#e!=null&&t.update?.(),t.constructor.loadAsInstance===!1?t.post(r,s):t.post(s,r)},{hasContent:!0,type:"create"});static update=On(function(t,r,n,s){return t.update(r,s)},{hasContent:!0,type:"create"});static connect=On(function(t,r,n,s){return t.connect?t.constructor.loadAsInstance===!1?t.connect(r,s):t.connect(s,r):Vn(t,"connect")},{hasContent:!0,type:"read"});static subscribe=On(function(t,r,n,s){return t.subscribe?t.subscribe(r):Vn(t,"subscribe")},{type:"read"});static publish=On(function(t,r,n,s){return t.#e!=null&&t.update?.(),t.publish?t.constructor.loadAsInstance===!1?t.publish(r,s):t.publish(s,r):Vn(t,"publish")},{hasContent:!0,type:"create"});static search=On(function(t,r,n){let s=t.search?t.search(r):Vn(t,"search"),i=n.select;if(i&&n.hasOwnProperty("select")&&s!=null&&!s.selectApplied){let a=b_(i,t.constructor);return s.map(a)}return s},{type:"read"});static query=On(function(t,r,n,s){return t.search?t.constructor.loadAsInstance===!1?t.search(r,s):t.search(s,r):Vn(t,"search")},{hasContent:!0,type:"read"});static copy=On(function(t,r,n,s){return t.copy?t.constructor.loadAsInstance===!1?t.copy(r,s):t.copy(s,r):Vn(t,"copy")},{hasContent:!0,type:"create"});static move=On(function(t,r,n,s){return t.move?t.constructor.loadAsInstance===!1?t.move(r,s):t.move(s,r):Vn(t,"move")},{hasContent:!0,type:"delete"});async post(t){if(this.#r)return(await this.constructor.create(this.#e,t,this.#t)).#e;Vn(this,"post")}static isCollection(t){return t&&t.#r}get isCollection(){return this.#r}static coerceId(t){return t}static parseQuery(t,r){return T_(t,r)}static parsePath(t,r,n){let s=t.indexOf(".");if(s>-1){let a=t.slice(s+1),c=r?.headers&&v6[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:mU(t,this),isCollection:jc}}let i=mU(t,this);return jc?{id:i,isCollection:!0}:i}static getResource(t,r,n){let s,i=r.getContext?.(),a;typeof r.isCollection=="boolean"&&r.hasOwnProperty("isCollection")?a=r.isCollection:a=n?.isCollection;let c=a&&this.Collection||this;if(i||(i=i===void 0?r:{}),i.transaction){let l;if(i.resourceCache?l=i.resourceCache:l=i.resourceCache=[],l.asMap){let u=l.asMap.get(t);if(s=u?.find(d=>d.constructor===c),s)return s;u||l.asMap.set(t,u=[]),u.push(s=new c(t,i))}else{if(s=l.find(u=>u.#e===t&&u.constructor===c),s)return s;if(l.push(s=new c(t,i)),l.length>10){let u=new Map;for(let d of l){let f=d.#e,m=u.get(f);m?m.push(d):u.set(f,[d])}i.resourceCache.length=0,i.resourceCache.asMap=u}}}else s=new c(t,i);return a&&(s.#r=!0),s}subscribe(t){return new $n}connect(t,r){return r?.subscribe!==!1?this.subscribe?.(r):new $n}allowRead(t,r){return t?.role.permission.super_user}allowUpdate(t,r,n){return t?.role.permission.super_user}allowCreate(t,r,n){return t?.role.permission.super_user}allowDelete(t,r){return t?.role.permission.super_user}getId(){return this.#e}getContext(){return this.#t}};(0,pU._assignPackageExport)("Resource",Dr);o(U6,"snakeCase");o(mU,"pathToId");A_=class extends Array{static{o(this,"MultiPartId")}toString(){return this.join("/")}};o(On,"transactional");o(Vn,"missingMethod");o(qA,"selectFromObject");o(b_,"transformForSelect")});var Qc,$A=fe(()=>{Qc=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 TU={};Ce(TU,{Resources:()=>I_,keyArrayToString:()=>Cu,resetResources:()=>x6,resources:()=>As});function x6(){return As=new I_,ve.resources=As,As}function Cu(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var gU,SU,I_,As,Pu=fe(()=>{Uc();$A();gU=w(z()),SU=w(Ee());Pr();I_=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 SU.ServerError(`Conflicting paths for ${t}`);gU.default.error(c),i.Resource=new Qc(c)}super.set(t,i);for(let[c,l]of this){let u=2;for(;(u=c.indexOf("/",u))>-1;){let d=this.get(c.slice(0,u));d&&(d.hasSubPaths=!0),u+=2}}}getMatch(t,r){let n=2,s=0,i,a=t.length;for(;n<a;){s=n,n=t.indexOf("/",n),n===-1&&(n=a);let u=n===a?t:t.slice(0,n),d=this.get(u),f=-1;if(!d&&n===a&&(f=u.indexOf("?",s),f!==-1)){let m=u.slice(0,f);d=this.get(m)}if(d&&(!r||d.exportTypes?.[r]!==!1)){if(d.relativeURL=t.slice(f!==-1?f:n),!d.hasSubPaths)return d;i=d}n+=2}if(i)return i;let c=t.indexOf("?"),l=c>-1?t.slice(0,c):t;return i=this.get(l),!i&&l.indexOf(".")>-1&&(i=this.get(l.split(".")[0])),i&&(!r||i.exportTypes?.[r]!==!1)?i.relativeURL=c>-1?t.slice(c):"":i||(i=this.get(""),i&&(!r||i.exportTypes?.[r]!==!1)&&(t.charAt(0)!=="/"&&(t="/"+t),i.relativeURL=t)),i}getResource(t,r){let n=this.getMatch(t);if(n)return t=n.relativeURL,n.Resource.getResource(this.pathToId(t,n.Resource),r)}call(t,r,n){return vt(r,async()=>{let s=this.getMatch(t);if(s)return t=s.relativeURL,n(s.Resource,s.path,t)})}setRepresentation(t,r,n){}};o(x6,"resetResources");o(Cu,"keyArrayToString")});function YA(e,t,r,n,s){let i=e.primaryStore.env.path,a=e.primaryStore.tableId,c;s?.crossThreads===!1?(c=yU,B6(e.primaryStore,e.auditStore)):(c=RU,e.primaryStore.env.hasSubscriptionCommitListener||(e.primaryStore.env.hasSubscriptionCommitListener=!0,e.primaryStore.on("committed",()=>{AU(RU[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=Cu(t);let d=new KA(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 AU(e){if(!e)return;let t=e.auditStore;t.resetReadTxn(),bU(e.auditStore);let r;for(let{key:n,value:s}of t.getRange({start:e.lastTxnTime,exclusiveStart:!0})){e.lastTxnTime=n;let i=Ut(s),a=e[i.tableId];if(!a)continue;let c=i.recordId,l=Cu(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,VA.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,VA.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 B6(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=yU[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{AU(l)}finally{r.threadLocalWrites[0]=l.lastTxnTime,r.unlock("thread-local-writes")}},"acquiredLock");r.attemptLock("thread-local-writes",u)&&u()})}}function bU(e){e.nextTransaction?.resolve();let t;e.nextTransaction=new Promise(r=>{t=r}),e.nextTransaction.resolve=t}function IU(e){return e.nextTransaction||(YA({primaryStore:e,auditStore:e},null,null,0,{scope:"full-database"}),bU(e)),e.nextTransaction}var VA,RU,yU,KA,WA=fe(()=>{VA=w(z());pu();Pu();uo();RU=Object.create(null),yU=Object.create(null);o(YA,"addSubscription");KA=class extends $n{static{o(this,"Subscription")}listener;subscriptions;startTime;includeDescendants;supportsTransactions;onlyChildren;constructor(t){super(),this.listener=t,this.on("close",()=>this.end())}end(){if(this.subscriptions){if(this.subscriptions.splice(this.subscriptions.indexOf(this),1),this.subscriptions.length===0){let t=this.subscriptions.tables;if(t){let r=this.subscriptions.key;if(t.delete(r),t.size===0){let n=t.envs,s=t.dbi;delete n[s]}}}this.subscriptions=null}}toJSON(){return{name:"subscription"}}};o(AU,"notifyFromTransactionData");o(B6,"listenToCommits");o(bU,"nextTransaction");o(IU,"whenNextTransaction")});var wU=M((PNe,NU)=>{"use strict";var zA=class{static{o(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};NU.exports=zA});var CU=M((DNe,OU)=>{"use strict";var jA=class{static{o(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};OU.exports=jA});var Tm=M((vNe,LU)=>{"use strict";var PU=ce(),F6=(k(),v(K)),{RecordEncoder:H6}=(Yc(),v(aU));PU.initSync();var k6=PU.get(F6.CONFIG_PARAMS.STORAGE_CACHING)!==!1,QA=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=k6&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:H6})}};LU.exports=QA});var Rm=M((xNe,DU)=>{"use strict";var Kn=ce(),bs=(k(),v(K));Kn.initSync();var N_=class{static{o(this,"OpenEnvironmentObject")}constructor(t,r=!1){this.path=t,this.mapSize=1073741824,this.maxDbs=1e4,this.maxReaders=2048,this.sharedStructuresKey=Symbol.for("structures"),this.readOnly=r,this.trackMetrics=!0,this.eventTurnBatching=!1,this.noSync=Kn.get(bs.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Kn.get(bs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Kn.get(bs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Kn.get(bs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Kn.get(bs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Kn.get(bs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Kn.get(bs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Kn.get(bs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Kn.get(bs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Kn.get(bs.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Kn.get(bs.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Kn.get(bs.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};DU.exports=N_;N_.MAX_DBS=1e4});var _t=M((FNe,qU)=>{"use strict";var XA=require("lmdb"),Xs=require("fs-extra"),Yn=require("path"),w_=An(),UU=z(),Cn=tn().LMDB_ERRORS_ENUM,O_=CU(),ZA=Tm(),xU=Rm(),Ia=kt(),MU=(k(),v(K)),{table:G6,resetDatabases:q6}=(Le(),v(ft)),vU=ce(),Zs=Ia.INTERNAL_DBIS_NAME,BU=Ia.DBI_DEFINITION_NAME,$6="data.mdb",V6="lock.mdb",ym=".mdb",K6="-lock",JA=class{static{o(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=Is(t,r),this.key_type=this.dbi[Ia.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[Ia.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new XA.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function C_(e,t){if(e===void 0)throw new Error(Cn.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(Cn.ENV_NAME_REQUIRED)}o(C_,"pathEnvNameValidation");async function eb(e,t,r=!0){try{await Xs.access(e)}catch(n){throw n.code==="ENOENT"?new Error(Cn.INVALID_BASE_PATH):n}try{let n=Yn.join(e,t+ym);return await Xs.access(n,Xs.constants.R_OK|Xs.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await Xs.access(Yn.join(e,t,$6),Xs.constants.R_OK|Xs.constants.F_OK),Yn.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(Cn.INVALID_ENVIRONMENT)}else throw new Error(Cn.INVALID_ENVIRONMENT);throw n}}o(eb,"validateEnvironmentPath");function P_(e,t){if(w_.validateEnv(e),t===void 0)throw new Error(Cn.DBI_NAME_REQUIRED)}o(P_,"validateEnvDBIName");async function Y6(e,t,r=!1,n=!1){C_(e,t);let s=Yn.basename(e);t=t.toString();let i=vU.get(MU.CONFIG_PARAMS.DATABASES);i||vU.setProperty(MU.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await eb(e,t,n),FU(e,t,r)}catch(a){if(a.message===Cn.INVALID_ENVIRONMENT){let c=Yn.join(e,t);await Xs.mkdirp(n?c:e);let l=new xU(n?c:c+ym,!1),u=XA.open(l);u.dbis=Object.create(null);let d=new ZA(!1);u.openDB(Zs,d),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let f=tb(e,t,r);return u[Ia.ENVIRONMENT_NAME_KEY]=f,global.lmdb_map[f]=u,u}throw a}}o(Y6,"createEnvironment");async function W6(e,t,r,n=!0){C_(e,t),t=t.toString();let s=Yn.join(e,t);return G6({table:t,database:Yn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}o(W6,"copyEnvironment");async function FU(e,t,r=!1){C_(e,t),t=t.toString();let n=tb(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 eb(e,t),i=Yn.join(e,t+ym),a=s!=i,c=new xU(s,a),l=XA.open(c);l.dbis=Object.create(null);let u=kU(l);for(let d=0;d<u.length;d++)Is(l,u[d]);return l[Ia.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}o(FU,"openEnvironment");async function z6(e,t,r=!1){C_(e,t),t=t.toString();let n=Yn.join(e,t+ym),s=await eb(e,t);if(global.lmdb_map!==void 0){let i=tb(e,t,r);if(global.lmdb_map[i]){let a=global.lmdb_map[i];await HU(a),delete global.lmdb_map[i]}}await Xs.remove(s),await Xs.remove(s===n?s+K6:Yn.join(Yn.dirname(s),V6))}o(z6,"deleteEnvironment");async function HU(e){w_.validateEnv(e);let t=e[Ia.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}o(HU,"closeEnvironment");function tb(e,t,r=!1){let s=`${Yn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}o(tb,"getCachedEnvironmentName");function j6(e){w_.validateEnv(e);let t=Object.create(null),r=Is(e,Zs);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==Zs)try{t[n]=Object.assign(new O_,s)}catch{UU.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}o(j6,"listDBIDefinitions");function kU(e){w_.validateEnv(e);let t=[],r=Is(e,Zs);for(let{key:n}of r.getRange({start:!1}))n!==Zs&&t.push(n);return t}o(kU,"listDBIs");function Q6(e,t){let n=Is(e,Zs).getEntry(t),s=new O_;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{UU.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}o(Q6,"getDBIDefinition");function GU(e,t,r,n=!r){if(P_(e,t),t=t.toString(),t===Zs)throw new Error(Cn.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return Is(e,t)}catch(s){if(s.message===Cn.DBI_DOES_NOT_EXIST){let i=new ZA(r,n===!0),a=e.openDB(t,i),c=new O_(r===!0,n);return a[BU]=c,Is(e,Zs).putSync(t,c),e.dbis[t]=a,a}throw s}}o(GU,"createDBI");function Is(e,t){if(P_(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==Zs?r=Q6(e,t):r=new O_,r===void 0)throw new Error(Cn.DBI_DOES_NOT_EXIST);let n;try{let s=new ZA(r.dup_sort,r.useVersions);if(n=e.openDB(t,s),n.db===void 0)throw new Error("MDB_NOTFOUND")}catch(s){throw s.message.includes("MDB_NOTFOUND")===!0?new Error(Cn.DBI_DOES_NOT_EXIST):s}return n[BU]=r,e.dbis[t]=n,n}o(Is,"openDBI");function J6(e,t){P_(e,t),t=t.toString();let r=Is(e,t),n=r.getStats();return r[Ia.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}o(J6,"statDBI");async function X6(e,t){try{let r=Yn.join(e,t+ym);return(await Xs.stat(r)).size}catch{throw new Error(Cn.INVALID_ENVIRONMENT)}}o(X6,"environmentDataSize");function Z6(e,t){if(P_(e,t),t=t.toString(),t===Zs)throw new Error(Cn.CANNOT_DROP_INTERNAL_DBIS_NAME);Is(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],Is(e,Zs).removeSync(t)}o(Z6,"dropDBI");function e8(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{Is(e,i)}catch(a){if(a.message===Cn.DBI_DOES_NOT_EXIST)GU(e,i,i!==t,i===t),n=!0;else throw a}}n&&q6()}o(e8,"initializeDBIs");qU.exports={openDBI:Is,openEnvironment:FU,createEnvironment:Y6,listDBIs:kU,listDBIDefinitions:j6,createDBI:GU,dropDBI:Z6,statDBI:J6,deleteEnvironment:z6,initializeDBIs:e8,TransactionCursor:JA,environmentDataSize:X6,copyEnvironment:W6,closeEnvironment:HU}});var KU=M((kNe,VU)=>{"use strict";var rb=_t(),t8=z(),$U=tn().LMDB_ERRORS_ENUM;VU.exports=r8;async function r8(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 rb.closeEnvironment(global.lmdb_map[a])}catch(c){if(c.message!==$U.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await rb.closeEnvironment(global.lmdb_map[n]),await rb.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==$U.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){t8.error(t)}}o(r8,"cleanLMDBMap")});var Ro=M((qNe,n8)=>{n8.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 ei=M(($Ne,zU)=>{var s8=Ro(),{promisify:i8}=require("util"),{getDatabases:WU}=(Le(),v(ft));zU.exports={setSchemaDataToGlobal:YU,getTableSchema:o8,getSystemSchema:a8,setSchemaDataToGlobalAsync:i8(YU)};function YU(e){global.hdb_schema=WU(),e&&e()}o(YU,"setSchemaDataToGlobal");function o8(e,t,r){let n=WU()[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(o8,"getTableSchema");function a8(){return s8}o(a8,"getSystemSchema")});var ax=M((YNe,ox)=>{"use strict";var nb=require("recursive-iterator"),c8=require("alasql"),sb=require("clone"),jU=ie(),{handleHDBError:QU,hdbErrors:l8}=Ee(),{HDB_ERROR_MSGS:JU,HTTP_STATUS_CODES:XU}=l8,{getDatabases:u8}=(Le(),v(ft)),d8=["DISTINCT_ARRAY"],ZU=Symbol("validateTables"),ib=Symbol("validateTable"),KNe=Symbol("getAllColumns"),ex=Symbol("validateAllColumns"),L_=Symbol("findColumn"),tx=Symbol("validateOrderBy"),Am=Symbol("validateSegment"),ob=Symbol("validateColumn"),rx=Symbol("setColumnsForTable"),nx=Symbol("checkColumnsForAsterisk"),sx=Symbol("validateGroupBy"),ix=Symbol("hasColumns"),ab=class{static{o(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[ZU](),this[nx](),this[ex]()}[ZU](){if(this[ix]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[ib](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[ib](t.table)})}}[ix](){let t=!1,r=new nb(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[ib](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=u8();if(!r[t.databaseid])throw QU(new Error,JU.SCHEMA_NOT_FOUND(t.databaseid),XU.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw QU(new Error,JU.TABLE_NOT_FOUND(t.databaseid,t.tableid),XU.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=sb(s);i.table=sb(t),this.attributes.push(i)})}[L_](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)}[nx](){let t=new nb(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[rx](r.tableid)}[rx](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new c8.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[ex](){this[Am](this.statement.columns,!1),this[Am](this.statement.joins,!1),this[Am](this.statement.where,!1),this[sx](this.statement.group,!1),this[Am](this.statement.order,!0)}[Am](t,r){if(!t)return;let n=new nb(t),s=[];for(let{node:i,path:a}of n)!jU.isEmpty(i)&&!jU.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[tx](i):s.push(this[ob](i)));return s}[sx](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&d8.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=sb(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[L_](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[L_](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`}[tx](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[ob](t)}[ob](t){let r=this[L_](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]}};ox.exports=ab});var lx=M((zNe,cx)=>{"use strict";var cb=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")}};cx.exports=cb});var dx=M((QNe,ux)=>{"use strict";var lb=class{static{o(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};ux.exports=lb});var mx=M((XNe,fx)=>{"use strict";var ub=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}};fx.exports=ub});var px=M((ewe,hx)=>{"use strict";var db=class{static{o(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};hx.exports=db});var Xc=M((iwe,gx)=>{"use strict";var f8=_t(),m8=dx(),h8=mx(),p8=px(),Pi=An(),bm=tn().LMDB_ERRORS_ENUM,E8=kt(),yo=(k(),v(K)),_8=ie(),g8=require("uuid"),rwe=require("lmdb"),{handleHDBError:S8,hdbErrors:T8}=Ee(),{OVERFLOW_MARKER:nwe,MAX_SEARCH_KEY_LENGTH:swe}=E8,Ex=ce();Ex.initSync();var D_=Ex.get(yo.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),fb=yo.TIME_STAMP_NAMES_ENUM.CREATED_TIME,Jc=yo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function R8(e,t,r,n,s=Pi.getNextMonotonicTime()){Eb(e,t,r,n),mb(e,t,r);let i=new m8,a=[],c=[];for(let l=0;l<n.length;l++){let u=n[l];_x(u,!0,s);let d=y8(e,t,r,u),f=u[t];a.push(d),c.push(f)}return hb(a,c,n,i,s)}o(R8,"insertRecords");function y8(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][yo.FUNC_VAL],n[a]=c)}let l=Pi.getIndexedValues(c),u=e.dbis[a];if(l){D_&&u.prefetch(l.map(d=>({key:d,value:s})),M_);for(let d=0,f=l.length;d<f;d++)u.put(l[d],s)}}D_&&e.dbis[t].prefetch([s],M_),e.dbis[t].put(s,n,n[Jc])})}o(y8,"insertRecord");function A8(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}o(A8,"removeSkippedRecords");function _x(e,t,r){let n=r>0;(n||!Number.isInteger(e[Jc]))&&(e[Jc]=r||(r=Pi.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[fb]))&&(e[fb]=r||Pi.getNextMonotonicTime()):delete e[fb]}o(_x,"setTimestamps");function mb(e,t,r){r.indexOf(yo.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(yo.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(yo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(yo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),f8.initializeDBIs(e,t,r)}o(mb,"initializeTransaction");async function b8(e,t,r,n,s=Pi.getNextMonotonicTime()){Eb(e,t,r,n),mb(e,t,r);let i=new h8,a=[],c=[],l=[];for(let u=0;u<n.length;u++){let d=n[u],f=d[t],m;try{m=pb(e,t,d,f,i,!0,s)}catch{i.skipped_hashes.push(f),a.push(u);continue}c.push(m),l.push(f)}return hb(c,l,n,i,s,a)}o(b8,"updateRecords");async function I8(e,t,r,n,s=Pi.getNextMonotonicTime()){try{Eb(e,t,r,n)}catch(l){throw S8(l,l.message,T8.HTTP_STATUS_CODES.BAD_REQUEST)}mb(e,t,r);let i=new p8,a=[],c=[];for(let l=0;l<n.length;l++){let u=n[l],d;_8.isEmpty(u[t])?(d=g8.v4(),u[t]=d):d=u[t];let f=pb(e,t,u,d,i,!1,s);a.push(f),c.push(d)}return hb(a,c,n,i,s)}o(I8,"upsertRecords");async function hb(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||Pi.getNextMonotonicTime(),A8(r,i),n}o(hb,"finalizeWrite");function pb(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(_x(r,!d,a),Number.isInteger(r[Jc])&&u[Jc]>r[Jc])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][yo.FUNC_VAL],r[p]=_)}if(_===y)continue;let T=Pi.getIndexedValues(y);if(T){D_&&g.prefetch(T.map(R=>({key:R,value:n})),M_);for(let R=0,I=T.length;R<I;R++)g.remove(T[R],n)}if(T=Pi.getIndexedValues(_),T){D_&&g.prefetch(T.map(R=>({key:R,value:n})),M_);for(let R=0,I=T.length;R<I;R++)g.put(T[R],n)}}let h={...u,...r};c.put(n,h,h[Jc])},"doPut");return l?f=c.ifVersion(n,l.version,m):f=c.ifNoExists(n,m),f.then(h=>h?!0:pb(e,t,r,n,s,i,a))}o(pb,"updateUpsertRecord");function N8(e,t,r){if(Pi.validateEnv(e),t===void 0)throw new Error(bm.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(bm.WRITE_ATTRIBUTES_REQUIRED):new Error(bm.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}o(N8,"validateBasic");function Eb(e,t,r,n){if(N8(e,t,r),!Array.isArray(n))throw n===void 0?new Error(bm.RECORDS_REQUIRED):new Error(bm.RECORDS_MUST_BE_ARRAY)}o(Eb,"validateWrite");function M_(){}o(M_,"noop");gx.exports={insertRecords:R8,updateRecords:b8,upsertRecords:I8}});var Tx=M((awe,Sx)=>{"use strict";var w8=require("uuid"),_b=class{static{o(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||w8.v4(),this.schema_table=`${this.schema}.${this.table}`}};Sx.exports=_b});var v_=M((lwe,Rx)=>{"use strict";var O8=Tx(),gb=class extends O8{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}};Rx.exports=gb});var Ax=M((dwe,yx)=>{"use strict";yx.exports=P8;var C8="inserted";function P8(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===C8?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}o(P8,"returnObject")});var U_=M((hwe,Ix)=>{"use strict";var L8=(k(),v(K)),Sb=_t(),D8=Xc(),{getSystemSchemaPath:M8,getSchemaPath:v8}=At(),mwe=Ro(),{validateBySchema:U8}=at(),Im=require("joi"),x8=v_(),B8=Ax(),{handleHDBError:F8,hdbErrors:H8,ClientError:k8}=Ee(),bx=ie(),{HTTP_STATUS_CODES:G8}=H8,q8="inserted";Ix.exports=$8;async function $8(e){let t=U8(e,Im.object({database:Im.string(),schema:Im.string(),table:Im.string().required(),attribute:Im.string().required()}));if(t)throw new k8(t.message);let r=!e.skip_table_check&&bx.checkGlobalSchemaTable(e.schema,e.table);if(r)throw F8(new Error,r,G8.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=bx.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 x8(e.schema,e.table,e.attribute,e.id);try{let i=await Sb.openEnvironment(v8(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}`);Sb.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let a=await Sb.openEnvironment(M8(),L8.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await D8.insertRecords(a,HDB_TABLE_INFO.hash_attribute,hdbAttributeAttributes,[s]);return B8(q8,c,{records:[s]},l)}catch(i){throw i}}o($8,"lmdbCreateAttribute")});var Di=M((Ewe,wx)=>{"use strict";var Nx=ie(),V8=(k(),v(K)),Lu=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Li=require("joi"),Na={schema_format:{pattern:Lu,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},K8=Li.alternatives(Li.string().min(1).max(Na.schema_length.maximum).pattern(Lu).messages({"string.pattern.base":"{:#label} "+Na.schema_format.message}),Li.number(),Li.array()).required(),Y8=Li.alternatives(Li.string().min(1).max(Na.schema_length.maximum).pattern(Lu).messages({"string.pattern.base":"{:#label} "+Na.schema_format.message}),Li.number()),W8=Li.alternatives(Li.string().min(1).max(Na.schema_length.maximum).pattern(Lu).messages({"string.pattern.base":"{:#label} "+Na.schema_format.message}),Li.number()).required();function z8(e,t){return t?typeof t!="string"?`'${property_name}' must be a string`:t.length?t.length>Na.schema_length.maximum?`'${property_name}' maximum of 250 characters`:Lu.test(t)?"":`'${property_name}' has illegal characters`:`'${property_name}' must be at least one character`:`'${property_name}' is required`}o(z8,"checkValidTable");function j8(e,t){return Nx.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}o(j8,"validateSchemaExists");function Q8(e,t){let r=t.state.ancestors[0].schema;return Nx.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}o(Q8,"validateTableExists");function J8(e,t){return e.toLowerCase()===V8.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${hdb_terms.SYSTEM_SCHEMA_NAME}' name is reserved`):e}o(J8,"validateSchemaName");wx.exports={commonValidators:Na,schemaRegex:Lu,hdbSchemaTable:K8,validateSchemaExists:j8,validateTableExists:Q8,validateSchemaName:J8,checkValidTable:z8,hdbDatabase:Y8,hdbTable:W8}});var Rb=M((gwe,Cx)=>{var{hdbTable:X8,hdbDatabase:Ox}=Di(),Z8=at(),Tb=require("joi"),e5={undefined:"undefined",null:"null"},t5=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||e5[a]!==void 0)&&(s===void 0?s=`Invalid attribute name: '${a}'`:s+=`. Invalid attribute name: '${a}'`)}return s?t.message(s):e},"customRecordsVal"),r5=Tb.object({database:Ox,schema:Ox,table:X8,records:Tb.array().items(Tb.object().custom(t5)).required()});Cx.exports=function(e){return Z8.validateBySchema(e,r5)}});var Nm=M((Rwe,Lx)=>{"use strict";var Ao=ie(),Px=z(),Twe=Rb(),{getDatabases:n5}=(Le(),v(ft)),{ClientError:Zc}=Ee();Lx.exports=s5;function s5(e){if(Ao.isEmpty(e))throw new Zc("invalid update parameters defined.");if(Ao.isEmptyOrZeroLength(e.schema))throw new Zc("invalid schema specified.");if(Ao.isEmptyOrZeroLength(e.table))throw new Zc("invalid table specified.");if(!Array.isArray(e.records))throw new Zc("records must be an array");let t=n5()[e.schema]?.[e.table];if(Ao.isEmpty(t))throw new Zc(`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&&Ao.isEmptyOrZeroLength(a[r]))throw Px.error("a valid hash attribute must be provided with update record:",a),new Zc("a valid hash attribute must be provided with update record, check log for more info");if(!Ao.isEmptyOrZeroLength(a[r])&&(a[r]==="null"||a[r]==="undefined"))throw Px.error(`a valid hash value must be provided with ${e.operation} record:`,a),new Zc(`Invalid hash value: '${a[r]}' is not a valid hash attribute value, check log for more info`);!Ao.isEmpty(a[r])&&a[r]!==""&&n.has(Ao.autoCast(a[r]))&&(a.skip=!0),n.add(Ao.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(s5,"insertUpdateValidate")});var x_=M((Awe,Mx)=>{"use strict";var Dx=ie(),i5=(k(),v(K)),o5=z(),a5=U_(),c5=v_(),l5=bo(),{SchemaEventMsg:u5}=ti(),d5="already exists in";Mx.exports=f5;async function f5(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 m5(e,t.schema,t.name,i)})),s}o(f5,"lmdbCheckForNewAttributes");async function m5(e,t,r,n){let s=new c5(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await h5(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(d5))o5.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}o(m5,"createNewAttribute");async function h5(e){let t;return t=await a5(e),l5.signalSchemaChange(new u5(process.pid,i5.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}o(h5,"createAttribute")});var Du=M((Iwe,vx)=>{"use strict";var yb=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}};vx.exports=yb});var xx=M((wwe,Ux)=>{"use strict";var p5=Du(),E5=(k(),v(K)).OPERATIONS_ENUM,Ab=class extends p5{static{o(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(E5.INSERT,r,n,s,i),this.records=t}};Ux.exports=Ab});var Fx=M((Cwe,Bx)=>{"use strict";var _5=Du(),g5=(k(),v(K)).OPERATIONS_ENUM,bb=class extends _5{static{o(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,a=void 0){super(g5.UPDATE,n,s,i,a),this.records=t,this.original_records=r}};Bx.exports=bb});var kx=M((Lwe,Hx)=>{"use strict";var S5=Du(),T5=(k(),v(K)).OPERATIONS_ENUM,Ib=class extends S5{static{o(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,a=void 0){super(T5.UPSERT,n,s,i,a),this.records=t,this.original_records=r}};Hx.exports=Ib});var qx=M((Mwe,Gx)=>{"use strict";var R5=Du(),y5=(k(),v(K)).OPERATIONS_ENUM,Nb=class extends R5{static{o(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(y5.DELETE,n,s,t,i),this.original_records=r}};Gx.exports=Nb});var wm=M((xwe,Yx)=>{"use strict";var Uwe=require("path"),$x=_t(),A5=xx(),b5=Fx(),I5=kx(),N5=qx(),Mu=kt(),Vx=ie(),{CONFIG_PARAMS:w5}=(k(),v(K)),Kx=ce();Kx.initSync();var B_=(k(),v(K)).OPERATIONS_ENUM,{getTransactionAuditStorePath:O5}=At();Yx.exports=C5;async function C5(e,t){if(Kx.get(w5.LOGGING_AUDITLOG)===!1)return;let r=O5(e.schema,e.table),n=await $x.openEnvironment(r,e.table,!0),s=P5(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){$x.initializeDBIs(n,Mu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Mu.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[Mu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[Mu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),Vx.isEmpty(s.user_name)||n.dbis[Mu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let a=0;a<s.hash_values.length;a++)n.dbis[Mu.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[a],i)})}}o(C5,"writeTransaction");function P5(e,t){let r=Vx.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===B_.INSERT)return new A5(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===B_.UPDATE)return new b5(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===B_.UPSERT)return new I5(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===B_.DELETE)return new N5(t.deleted,t.original_records,r,t.txn_time,e.__origin)}o(P5,"createTransactionObject")});var wb=M((Hwe,Wx)=>{"use strict";var L5=Nm(),Fwe=Wf(),Om=(k(),v(K)),D5=zf(),M5=Xc().insertRecords,v5=_t(),U5=z(),x5=x_(),{getSchemaPath:B5}=At(),F5=wm();Wx.exports=H5;async function H5(e){try{let{schemaTable:t,attributes:r}=L5(e);D5(e,r,t.hash_attribute),e.schema!==Om.SYSTEM_SCHEMA_NAME&&(r.includes(Om.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(Om.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(Om.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(Om.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await x5(e.hdb_auth_header,t,r),s=B5(e.schema,e.table),i=await v5.openEnvironment(s,e.table),a=await M5(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await F5(e,a)}catch(c){U5.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(H5,"lmdbCreateRecords")});var Qx=M((Gwe,jx)=>{"use strict";var zx=(k(),v(K)),k5=wb(),G5=Wf(),q5=require("fs-extra"),{getSchemaPath:$5}=At();jx.exports=V5;async function V5(e){let t=[{name:e.schema,createddate:Date.now()}],r=new G5(zx.SYSTEM_SCHEMA_NAME,zx.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await k5(r),await q5.mkdirp($5(e.schema))}o(V5,"lmdbCreateSchema")});var Xx=M(($we,Jx)=>{"use strict";var Ob=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}};Jx.exports=Ob});var r0=M((zwe,t0)=>{"use strict";var Zx=_t(),Cb=An(),Pb=tn().LMDB_ERRORS_ENUM,K5=kt(),e0=z(),Kwe=ie(),Y5=require("lmdb"),W5=Xx(),z5=(k(),v(K)),{OVERFLOW_MARKER:Ywe,MAX_SEARCH_KEY_LENGTH:Wwe}=K5,j5=z5.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function Q5(e,t,r,n){if(Cb.validateEnv(e),t===void 0)throw new Error(Pb.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(Pb.IDS_REQUIRED):new Error(Pb.IDS_MUST_BE_ITERABLE);try{let s=Zx.listDBIs(e);Zx.initializeDBIs(e,t,s);let i=new W5,a,c=[],l=[];for(let m=0,h=r.length;m<h;m++)try{a=r[m];let p=e.dbis[t].get(a);if(!p||n&&p[j5]>n){i.skipped.push(a);continue}let _=e.dbis[t].ifVersion(a,Y5.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=Cb.getIndexedValues(R);if(I)for(let P=0,Y=I.length;P<Y;P++)T.remove(I[P],a)}catch{e0.warn(`cannot delete from attribute: ${y}, ${R}:${a}`)}}});c.push(_),l.push(a),i.original_records.push(p)}catch(p){e0.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=Cb.getNextMonotonicTime(),i}catch(s){throw s}}o(Q5,"deleteRecords");t0.exports={deleteRecords:Q5}});var Cm=M((Qwe,s0)=>{"use strict";var vu=ie(),J5=r0(),X5=_t(),{getSchemaPath:Z5}=At(),e9=wm(),t9=z();s0.exports=r9;async function r9(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(vu.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(vu.isEmptyOrZeroLength(e.hash_values)&&!vu.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];vu.isEmpty(l)||e.hash_values.push(l)}}if(vu.isEmptyOrZeroLength(e.hash_values))return n0([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(vu.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=Z5(e.schema,e.table),i=await X5.openEnvironment(s,e.table),a=await J5.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await e9(e,a)}catch(c){t9.error(`unable to write transaction due to ${c.message}`)}return n0(a.deleted,a.skipped,a.txn_time)}catch(s){throw s}}o(r9,"lmdbDeleteRecords");function n0(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(n0,"createDeleteResponse")});var Db=M((Zwe,i0)=>{"use strict";var n9=(k(),v(K)),Xwe=An();function Lb(e,t){let r=Object.create(null);if(t.length===1&&n9.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(Lb,"parseRow");function s9(e,t,r,n){let s=Lb(r,e);n.push(s)}o(s9,"searchAll");function i9(e,t,r,n){let s=Lb(r,e);n[t]=s}o(i9,"searchAllToMap");function o9(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}o(o9,"iterateDBI");function el(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(el,"pushResults");function a9(e,t,r,n,s,i){t.toString().endsWith(e)&&el(t,r,n,s,i)}o(a9,"endsWith");function c9(e,t,r,n,s,i){t.toString().includes(e)&&el(t,r,n,s,i)}o(c9,"contains");function l9(e,t,r,n,s,i){t>e&&el(t,r,n,s,i)}o(l9,"greaterThanCompare");function u9(e,t,r,n,s,i){t>=e&&el(t,r,n,s,i)}o(u9,"greaterThanEqualCompare");function d9(e,t,r,n,s,i){t<e&&el(t,r,n,s,i)}o(d9,"lessThanCompare");function f9(e,t,r,n,s,i){t<=e&&el(t,r,n,s,i)}o(f9,"lessThanEqualCompare");i0.exports={parseRow:Lb,searchAll:s9,searchAllToMap:i9,iterateDBI:o9,endsWith:a9,contains:c9,greaterThanCompare:l9,greaterThanEqualCompare:u9,lessThanCompare:d9,lessThanEqualCompare:f9,pushResults:el}});var Uu=M((sOe,f0)=>{"use strict";var wa=_t(),tOe=z(),Wn=An(),F_=kt(),Jt=tn().LMDB_ERRORS_ENUM,rOe=ie(),m9=(k(),v(K)),H_=Db(),{parseRow:h9}=H_,nOe=require("lmdb"),{OVERFLOW_MARKER:o0,MAX_SEARCH_KEY_LENGTH:p9}=F_;function a0(e,t,r,n=!1,s=void 0,i=void 0){return tl(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(a0,"iterateFullIndex");function Pm(e,t,r,n,s,i=!1,a=void 0,c=void 0,l=!1,u=!1){return tl(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(Pm,"iterateRangeBetween");function tl(e,t,r,n){let s=e.database||e,i=wa.openDBI(s,r);i[F_.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&wa.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(tl,"setupTransaction");function c0(e,t,r,n){let s;return function(i,a){if(typeof i=="string"&&i.endsWith(o0)){if(!s)if(r)s=wa.openDBI(e,r);else{let l=wa.listDBIs(e);for(let u=0,d=l.length;u<d&&(s=wa.openDBI(e,l[u]),!s[F_.DBI_DEFINITION_NAME].is_hash_attribute);u++);}i=s.get(a,{transaction:t,lazy:!0})[n]}return i}}o(c0,"getOverflowCheck");function E9(e,t,r,n=!1,s=void 0,i=void 0){if(Wn.validateEnv(e),t===void 0)throw new Error(Jt.HASH_ATTRIBUTE_REQUIRED);return tl(e,t,t,(a,c,l)=>(k_(r),r=Lm(l,r),c.getRange({transaction:a,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(u=>h9(u.value,r))))}o(E9,"searchAll");function _9(e,t,r,n=!1,s=void 0,i=void 0){if(Wn.validateEnv(e),t===void 0)throw new Error(Jt.HASH_ATTRIBUTE_REQUIRED);k_(r),r=Lm(e.database||e,r);let a=new Map;for(let{key:c,value:l}of a0(e,t,t,n,s,i))a.set(c,H_.parseRow(l,r));return a}o(_9,"searchAllToMap");function g9(e,t,r=!1,n=void 0,s=void 0){if(Wn.validateEnv(e),t===void 0)throw new Error(Jt.ATTRIBUTE_REQUIRED);let i=Object.create(null),a=a0(e,void 0,t,r,n,s),c=a.transaction,l=c0(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(g9,"iterateDBI");function S9(e,t){if(Wn.validateEnv(e),t===void 0)throw new Error(Jt.HASH_ATTRIBUTE_REQUIRED);return wa.statDBI(e,t).entryCount}o(S9,"countAll");function T9(e,t,r,n,s=!1,i=void 0,a=void 0){return Oa(e,r,n),tl(e,t,r,(c,l,u,d)=>(n=Wn.convertKeyValueToWrite(n),d===r?l.get(n,{transaction:c,lazy:!0})===void 0?[]:[{key:n,value:n}]:l.getValues(n,{transaction:c,reverse:s,limit:i,offset:a}).map(f=>({key:n,value:f}))))}o(T9,"equals");function R9(e,t,r){return Oa(e,t,r),wa.openDBI(e,t).getValuesCount(r)}o(R9,"count");function y9(e,t,r,n,s=!1,i=void 0,a=void 0){return Oa(e,r,n),tl(e,null,r,(c,l)=>{n=Wn.convertKeyValueToWrite(n);let u=!0;typeof n=="number"&&(u=!1);let d;if(s===!0){let f;for(let m of l.getKeys({transaction:c,start:n}))if(!m.startsWith(n)){f=m;break}return f!==void 0&&(Number.isInteger(a)?a++:i++),d=l.getRange({transaction:c,start:f,end:void 0,reverse:s,limit:i,offset:a}).map(m=>{let{key:h}=m;if(h!==f){if(h.toString().startsWith(n))return m;if(u===!0)return d.DONE}}),d.filter(m=>m)}else return d=l.getRange({transaction:c,start:n,reverse:s,limit:i,offset:a}).map(f=>{if(f.key.toString().startsWith(n))return f;if(u===!0)return d.DONE}),u?d:d.filter(f=>f)})}o(y9,"startsWith");function A9(e,t,r,n,s=!1,i=void 0,a=void 0){return l0(e,t,r,n,s,i,a,!0)}o(A9,"endsWith");function l0(e,t,r,n,s=!1,i=void 0,a=void 0,c=!1){return Oa(e,r,n),tl(e,null,r,(l,u,d,f)=>{let m=c0(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(o0)?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[F_.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(l0,"contains");function b9(e,t,r,n,s=!1,i=void 0,a=void 0){Oa(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),Pm(e,t,r,n,l,s,i,a,!0,!1)}o(b9,"greaterThan");function I9(e,t,r,n,s=!1,i=void 0,a=void 0){Oa(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),Pm(e,t,r,n,l,s,i,a,!1,!1)}o(I9,"greaterThanEqual");function N9(e,t,r,n,s=!1,i=void 0,a=void 0){Oa(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),Pm(e,t,r,l,n,s,i,a,!1,!0)}o(N9,"lessThan");function w9(e,t,r,n,s=!1,i=void 0,a=void 0){Oa(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),Pm(e,t,r,l,n,s,i,a,!1,!1)}o(w9,"lessThanEqual");function O9(e,t,r,n,s,i=!1,a=void 0,c=void 0){if(Wn.validateEnv(e),r===void 0)throw new Error(Jt.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(Jt.START_VALUE_REQUIRED);if(s===void 0)throw new Error(Jt.END_VALUE_REQUIRED);if(n=Wn.convertKeyValueToWrite(n),s=Wn.convertKeyValueToWrite(s),n>s)throw new Error(Jt.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return Pm(e,t,r,n,s,i,a,c)}o(O9,"between");function C9(e,t,r,n){Wn.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(Jt.HASH_ATTRIBUTE_REQUIRED);if(k_(r),r=Lm(s,r),n===void 0)throw new Error(Jt.ID_REQUIRED);let a=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(a=H_.parseRow(c,r)),a}o(C9,"searchByHash");function P9(e,t,r){Wn.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(Jt.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Jt.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}o(P9,"checkHashExists");function L9(e,t,r,n,s=[]){return d0(e,t,r,n,s),u0(e,t,r,n,s).map(i=>i[1])}o(L9,"batchSearchByHash");function D9(e,t,r,n,s=[]){d0(e,t,r,n,s);let i=new Map;for(let[a,c]of u0(e,t,r,n,s))i.set(a,c);return i}o(D9,"batchSearchByHashToMap");function u0(e,t,r,n,s=[]){return tl(e,t,t,(i,a,c)=>{r=Lm(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,H_.parseRow(d,r)];s.push(u)}).filter(u=>u)})}o(u0,"batchHashSearch");function d0(e,t,r,n,s){if(Wn.validateEnv(e),t===void 0)throw new Error(Jt.HASH_ATTRIBUTE_REQUIRED);if(k_(r),n==null)throw new Error(Jt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(Jt.IDS_MUST_BE_ITERABLE)}o(d0,"initializeBatchSearchByHash");function k_(e){if(!Array.isArray(e))throw e===void 0?new Error(Jt.FETCH_ATTRIBUTES_REQUIRED):new Error(Jt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}o(k_,"validateFetchAttributes");function Oa(e,t,r){if(Wn.validateEnv(e),t===void 0)throw new Error(Jt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Jt.SEARCH_VALUE_REQUIRED);if(r?.length>p9)throw new Error(Jt.SEARCH_VALUE_TOO_LARGE)}o(Oa,"validateComparisonFunctions");function Lm(e,t){return t.length===1&&m9.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=wa.listDBIs(e)),t}o(Lm,"setGetWholeRowAttributes");f0.exports={searchAll:E9,searchAllToMap:_9,count:R9,countAll:S9,equals:T9,startsWith:y9,endsWith:A9,contains:l0,searchByHash:C9,setGetWholeRowAttributes:Lm,batchSearchByHash:L9,batchSearchByHashToMap:D9,checkHashExists:P9,iterateDBI:g9,greaterThan:b9,greaterThanEqual:I9,lessThan:N9,lessThanEqual:w9,between:O9}});var xu=M((oOe,_0)=>{var m0=require("lodash"),h0=at(),$e=require("joi"),M9=ie(),{hdbSchemaTable:Dm,checkValidTable:p0,hdbTable:E0,hdbDatabase:G_}=Di(),{handleHDBError:v9,hdbErrors:U9}=Ee(),{getDatabases:x9}=(Le(),v(ft)),{HTTP_STATUS_CODES:B9}=U9,F9=$e.object({database:G_,schema:G_,table:E0,search_attribute:Dm,search_value:$e.any().required(),get_attributes:$e.array().min(1).items($e.alternatives(Dm,$e.object())).optional(),desc:$e.bool(),limit:$e.number().integer().min(1),offset:$e.number().integer().min(0)}),H9=$e.object({database:G_,schema:G_,table:E0,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(Dm,$e.object())).optional(),sort:$e.object({attribute:$e.alternatives(Dm,$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(Dm,$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()});_0.exports=function(e,t){let r=null;switch(t){case"value":r=h0.validateBySchema(e,F9);break;case"hashes":let i=function(a){s?s+=". "+a:s=a};var n=i;o(i,"addError");let s;i(p0("database",e.schema)),i(p0("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=h0.validateBySchema(e,H9);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=M9.checkGlobalSchemaTable(e.schema,e.table);if(s)return v9(new Error,s,B9.NOT_FOUND);let a=x9()[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=m0.filter(c,d=>d!=="*"&&!d.startsWith?.("$")&&d.attribute!=="*"&&!Array.isArray(d)&&!d.name&&!m0.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 Mb=M((cOe,g0)=>{"use strict";var k9=_t(),G9=xu(),{getSchemaPath:q9}=At();g0.exports=$9;function $9(e){let t=G9(e,"hashes");if(t)throw t;let r=q9(e.schema,e.table);return k9.openEnvironment(r,e.table)}o($9,"initialize")});var vb=M((uOe,S0)=>{"use strict";var V9=Uu(),K9=Mb();S0.exports=Y9;async function Y9(e){let t=await K9(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return V9.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}o(Y9,"lmdbGetDataByHash")});var Bu=M((fOe,T0)=>{"use strict";var Ub=class{static{o(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};T0.exports=Ub});var y0=M((pOe,R0)=>{"use strict";var hOe=Bu(),W9=Uu(),z9=Mb();R0.exports=j9;async function j9(e){let t=await z9(e),r=global.hdb_schema[e.schema][e.table];return W9.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}o(j9,"lmdbSearchByHash")});var ri=M((_Oe,A0)=>{"use strict";var xb=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}};A0.exports=xb});var q_=M((SOe,C0)=>{"use strict";var sn=Uu(),Q9=_t(),J9=ie(),Ve=kt(),rl=(k(),v(K)),X9=Ro(),b0=tn().LMDB_ERRORS_ENUM,{getSchemaPath:Z9}=At(),Io=rl.SEARCH_WILDCARDS;async function e7(e,t,r){let n;e.schema===rl.SYSTEM_SCHEMA_NAME?n=X9[e.table]:n=global.hdb_schema[e.schema][e.table];let s=O0(e,n.hash_attribute,r,t);return N0(e,s,n.hash_attribute,r)}o(e7,"prepSearch");async function N0(e,t,r,n){let s=Z9(e.schema,e.table),i=await Q9.openEnvironment(s,e.table),a=w0(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(t7(e,r)===!1){let d=e.search_attribute;if(d===r)return n?I0(a,()=>!0):a.map(m=>({[r]:m.key}));let f=o(m=>({[r]:m.value,[d]:m.key}),"toObject");return n?I0(a,f):a.map(f)}let u=e.search_attribute===r?a.map(d=>d.key):a.map(d=>d.value);return n===!0?sn.batchSearchByHashToMap(c,r,e.get_attributes,u):sn.batchSearchByHash(c,r,e.get_attributes,u)}o(N0,"executeSearch");function w0(e,t,r,n){let s,i=n;t.get_attributes.indexOf(n)<0&&(i=void 0);let{reverse:a,limit:c,offset:l}=t;switch(a=typeof a=="boolean"?a:!1,c=Number.isInteger(c)?c:void 0,l=Number.isInteger(l)?l:void 0,r){case Ve.SEARCH_TYPES.EQUALS:s=sn.equals(e,i,t.search_attribute,t.search_value,a,c,l);break;case Ve.SEARCH_TYPES.CONTAINS:s=sn.contains(e,i,t.search_attribute,t.search_value,a,c,l);break;case Ve.SEARCH_TYPES.ENDS_WITH:case Ve.SEARCH_TYPES._ENDS_WITH:s=sn.endsWith(e,i,t.search_attribute,t.search_value,a,c,l);break;case Ve.SEARCH_TYPES.STARTS_WITH:case Ve.SEARCH_TYPES._STARTS_WITH:s=sn.startsWith(e,i,t.search_attribute,t.search_value,a,c,l);break;case Ve.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return sn.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case Ve.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return sn.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case Ve.SEARCH_TYPES.SEARCH_ALL:return sn.searchAll(e,n,t.get_attributes,a,c,l);case Ve.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return sn.searchAllToMap(e,n,t.get_attributes,a,c,l);case Ve.SEARCH_TYPES.BETWEEN:s=sn.between(e,i,t.search_attribute,t.search_value,t.end_value,a,c,l);break;case Ve.SEARCH_TYPES.GREATER_THAN:case Ve.SEARCH_TYPES._GREATER_THAN:s=sn.greaterThan(e,i,t.search_attribute,t.search_value,a,c,l);break;case Ve.SEARCH_TYPES.GREATER_THAN_EQUAL:case Ve.SEARCH_TYPES._GREATER_THAN_EQUAL:s=sn.greaterThanEqual(e,i,t.search_attribute,t.search_value,a,c,l);break;case Ve.SEARCH_TYPES.LESS_THAN:case Ve.SEARCH_TYPES._LESS_THAN:s=sn.lessThan(e,i,t.search_attribute,t.search_value,a,c,l);break;case Ve.SEARCH_TYPES.LESS_THAN_EQUAL:case Ve.SEARCH_TYPES._LESS_THAN_EQUAL:s=sn.lessThanEqual(e,i,t.search_attribute,t.search_value,a,c,l);break;default:return Object.create(null)}return s}o(w0,"searchByType");function I0(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}o(I0,"createMapFromIterable");function t7(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(t7,"checkToFetchMore");function O0(e,t,r,n){if(J9.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),Io.indexOf(s)>-1)return r===!0?Ve.SEARCH_TYPES.SEARCH_ALL_TO_MAP:Ve.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(Io[0])<0&&s.indexOf(Io[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(Io.indexOf(i)>=0&&Io.indexOf(a)>=0)return e.search_value=e.search_value.slice(1,-1),Ve.SEARCH_TYPES.CONTAINS;if(Io.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),Ve.SEARCH_TYPES.ENDS_WITH;if(Io.indexOf(a)>=0)return e.search_value=e.search_value.slice(0,-1),Ve.SEARCH_TYPES.STARTS_WITH;if(s.includes(Io[0])||s.includes(Io[1]))return Ve.SEARCH_TYPES.EQUALS;throw new Error(b0.UNKNOWN_SEARCH_TYPE)}else switch(n){case rl.VALUE_SEARCH_COMPARATORS.BETWEEN:return Ve.SEARCH_TYPES.BETWEEN;case rl.VALUE_SEARCH_COMPARATORS.GREATER:return Ve.SEARCH_TYPES.GREATER_THAN;case rl.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return Ve.SEARCH_TYPES.GREATER_THAN_EQUAL;case rl.VALUE_SEARCH_COMPARATORS.LESS:return Ve.SEARCH_TYPES.LESS_THAN;case rl.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return Ve.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(b0.UNKNOWN_SEARCH_TYPE)}}o(O0,"createSearchTypeFromSearchObject");C0.exports={executeSearch:N0,createSearchTypeFromSearchObject:O0,prepSearch:e7,searchByType:w0}});var L0=M((yOe,P0)=>{"use strict";var ROe=ri(),r7=xu(),n7=ie(),s7=(k(),v(K)),i7=q_();P0.exports=o7;function o7(e,t){if(!n7.isEmpty(t)&&s7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=r7(e,"value");if(n)throw n;return i7.prepSearch(e,t,!0)}o(o7,"lmdbGetDataByValue")});var Mm=M((IOe,D0)=>{"use strict";var bOe=ri(),a7=xu(),c7=ie(),l7=(k(),v(K)),u7=q_();D0.exports=d7;async function d7(e,t){if(!c7.isEmpty(t)&&l7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=a7(e,"value");if(n)throw n;return u7.prepSearch(e,t,!1)}o(d7,"lmdbSearchByValue")});var v0=M((OOe,M0)=>{"use strict";var wOe=kt(),Bb=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}},Fb=class{static{o(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},Hb=class{static{o(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};M0.exports={SearchByConditionsObject:Bb,SearchCondition:Fb,SortAttribute:Hb}});var H0=M((DOe,F0)=>{"use strict";var POe=v0().SearchByConditionsObject,f7=ri(),m7=xu(),kb=Uu(),$_=kt(),{Resource:LOe}=(ba(),v(_U)),B0=q_(),h7=Db(),p7=require("lodash"),{getSchemaPath:E7}=At(),U0=_t(),{handleHDBError:_7,hdbErrors:g7}=Ee(),{HTTP_STATUS_CODES:S7}=g7,T7=1e8;F0.exports=R7;async function R7(e){let t=m7(e,"conditions");if(t)throw _7(t,t.message,S7.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=E7(e.schema,e.table),n=await U0.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let u of e.conditions)U0.openDBI(n,u.search_attribute);let i=p7.sortBy(e.conditions,u=>{if(u.estimated_count===void 0){let d=u.search_type;d===$_.SEARCH_TYPES.EQUALS?u.estimated_count=kb.count(n,u.search_attribute,u.search_value):d===$_.SEARCH_TYPES.CONTAINS||d===$_.SEARCH_TYPES.ENDS_WITH?u.estimated_count=1/0:u.estimated_count=T7}return u.estimated_count}),a=n.useReadTransaction();a.database=n;let c=await x0(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(B0.filterByType),f=d.length,m=kb.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=>h7.parseRow(h,m))}else{for(let f=1;f<i.length;f++){let m=i[f],h=await x0(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=kb.batchSearchByHash(a,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{a.done()},l}o(R7,"lmdbSearchByConditions");async function x0(e,t,r,n){let s=new f7(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===$_.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,B0.searchByType(e,s,i,n).map(a=>a.value)}o(x0,"executeConditionSearch")});var vm=M((vOe,k0)=>{"use strict";var y7=(k(),v(K)).OPERATIONS_ENUM,Gb=class{static{o(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=y7.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};k0.exports=Gb});var qb=M((xOe,z0)=>{"use strict";var V0=ri(),K0=vm(),Y0=Mm(),W0=Cm(),Pn=(k(),v(K)),G0=ie(),q0=_t(),{getTransactionAuditStorePath:A7,getSchemaPath:b7}=At(),$0=z();z0.exports=I7;async function I7(e){try{if(G0.isEmpty(global.hdb_schema[e.schema])||G0.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await N7(e),await w7(e);let t=b7(e.schema,e.table);try{await q0.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")$0.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=A7(e.schema,e.table);await q0.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")$0.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}o(I7,"lmdbDropTable");async function N7(e){let t=new V0(Pn.SYSTEM_SCHEMA_NAME,Pn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Pn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Pn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await Y0(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 K0(Pn.SYSTEM_SCHEMA_NAME,Pn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await W0(s)}o(N7,"deleteAttributesFromSystem");async function w7(e){let t=new V0(Pn.SYSTEM_SCHEMA_NAME,Pn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Pn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[Pn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,Pn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,Pn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await Y0(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 K0(Pn.SYSTEM_SCHEMA_NAME,Pn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await W0(s)}catch(i){throw i}}o(w7,"dropTableFromSystem")});var Q0=M((FOe,j0)=>{"use strict";var O7=require("fs-extra"),C7=ri(),P7=Bu(),L7=vm(),D7=qb(),M7=Cm(),v7=vb(),U7=Mm(),No=(k(),v(K)),{getSchemaPath:x7}=At(),{handleHDBError:B7,hdbErrors:F7}=Ee(),{HDB_ERROR_MSGS:H7,HTTP_STATUS_CODES:k7}=F7;j0.exports=G7;async function G7(e){let t;try{t=await q7(e.schema);let r=new C7(No.SYSTEM_SCHEMA_NAME,No.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,No.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[No.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await U7(r));for(let a=0;a<n.length;a++){let c={schema:t,table:n[a].name};try{await D7(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new L7(No.SYSTEM_SCHEMA_NAME,No.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await M7(s);let i=x7(t);await O7.remove(i)}catch(r){throw r}}o(G7,"lmdbDropSchema");async function q7(e){let t=new P7(No.SYSTEM_SCHEMA_NAME,No.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[No.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await v7(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw B7(new Error,H7.SCHEMA_NOT_FOUND(e),k7.NOT_FOUND,void 0,void 0,!0);return n}o(q7,"validateDropSchema")});var Um=M((kOe,J0)=>{"use strict";var $b=class{static{o(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};J0.exports=$b});var Kb=M(($Oe,X0)=>{"use strict";var $7=require("fs-extra"),V_=_t(),{getTransactionAuditStorePath:V7}=At(),Vb=kt(),qOe=Um();X0.exports=K7;async function K7(e){let t;try{let r=V7(e.schema,e.table);await $7.mkdirp(r),t=await V_.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{V_.createDBI(t,Vb.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),V_.createDBI(t,Vb.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),V_.createDBI(t,Vb.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(K7,"createTransactionsAuditEnvironment")});var tB=M((YOe,eB)=>{"use strict";var Yb=(k(),v(K)),Z0=_t(),Y7=Xc(),{getSystemSchemaPath:W7,getSchemaPath:z7}=At(),KOe=Ro(),j7=U_(),Wb=v_(),Q7=z(),J7=Kb();eB.exports=X7;async function X7(e,t){let r=z7(t.schema,t.table),n=new Wb(t.schema,t.table,Yb.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new Wb(t.schema,t.table,Yb.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new Wb(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await Z0.createEnvironment(r,t.table),e!==void 0){let a=await Z0.openEnvironment(W7(),Yb.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await Y7.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 zb(n),await zb(s),await zb(i)}await J7(t)}catch(a){throw a}}o(X7,"lmdbCreateTable");async function zb(e){try{await j7(e)}catch(t){Q7.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}o(zb,"createAttribute")});var nB=M((zOe,rB)=>{"use strict";var Z7=Nm(),eee=zf(),tee=x_(),xm=(k(),v(K)),ree=Xc().updateRecords,nee=_t(),{getSchemaPath:see}=At(),iee=wm(),oee=z();rB.exports=aee;async function aee(e){try{let{schemaTable:t,attributes:r}=Z7(e);eee(e,r,t.hash_attribute),e.schema!==xm.SYSTEM_SCHEMA_NAME&&(r.includes(xm.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(xm.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(xm.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(xm.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await tee(e.hdb_auth_header,t,r),s=see(e.schema,e.table),i=await nee.openEnvironment(s,e.table),a=await ree(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await iee(e,a)}catch(c){oee.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(aee,"lmdbUpdateRecords")});var iB=M((QOe,sB)=>{"use strict";var cee=(k(),v(K)).OPERATIONS_ENUM,jb=class{static{o(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=cee.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};sB.exports=jb});var aB=M((ZOe,oB)=>{"use strict";var XOe=iB(),lee=Nm(),uee=zf(),dee=x_(),Bm=(k(),v(K)),fee=Xc().upsertRecords,mee=_t(),{getSchemaPath:hee}=At(),pee=wm(),Eee=z(),{handleHDBError:_ee,hdbErrors:gee}=Ee();oB.exports=See;async function See(e){let t;try{t=lee(e)}catch(l){throw _ee(l,l.message,gee.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schemaTable:r,attributes:n}=t;uee(e,n,r.hash_attribute),e.schema!==Bm.SYSTEM_SCHEMA_NAME&&(n.includes(Bm.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(Bm.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(Bm.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(Bm.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await dee(e.hdb_auth_header,r,n),i=hee(e.schema,e.table),a=await mee.openEnvironment(i,e.table),c=await fee(a,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await pee(e,c)}catch(l){Eee.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(See,"lmdbUpsertRecords")});var lB=M((tCe,cB)=>{"use strict";var Qb=class{static{o(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};cB.exports=Qb});var dB=M((nCe,uB)=>{"use strict";var Jb=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}};uB.exports=Jb});var hB=M((oCe,mB)=>{"use strict";var Xb=_t(),{getTransactionAuditStorePath:Tee}=At(),iCe=lB(),Fm=kt(),Ree=ie(),fB=dB(),yee=require("util").promisify,Aee=yee(setTimeout),bee=1e4,Iee=100;mB.exports=Nee;async function Nee(e){let t=Tee(e.schema,e.table),r=await Xb.openEnvironment(t,e.table,!0),n=Xb.listDBIs(r);Xb.initializeDBIs(r,Fm.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new fB;do s=await wee(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 Aee(Iee);while(s.transactions_deleted>0);return i}o(Nee,"deleteAuditLogsBefore");async function wee(e,t){let r=new fB;try{let n=e.dbis[Fm.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[Fm.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];Ree.isEmpty(c)||(s=e.dbis[Fm.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<a.hash_values.length;l++)s=e.dbis[Fm.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(a.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>bee)break}return await s,r}catch(n){throw n}}o(wee,"deleteTransactions")});var EB=M((cCe,pB)=>{"use strict";var Zb=class{static{o(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};pB.exports=Zb});var gB=M((dCe,_B)=>{"use strict";var Oee=ri(),Cee=vm(),uCe=EB(),Mi=(k(),v(K)),Pee=ie(),eI=_t(),Lee=Ro(),Dee=Mm(),Mee=Cm(),{getSchemaPath:vee}=At();_B.exports=Uee;async function Uee(e,t=!0){let r;e.schema===Mi.SYSTEM_SCHEMA_NAME?r=Lee[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await Bee(e),s=vee(e.schema,e.table),i=await eI.openEnvironment(s,e.table);return t===!0&&await xee(e,i,r.hash_attribute),eI.dropDBI(i,e.attribute),n}o(Uee,"lmdbDropAttribute");async function xee(e,t,r){let n=eI.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(xee,"removeAttributeFromAllObjects");async function Bee(e){let t=new Oee(Mi.SYSTEM_SCHEMA_NAME,Mi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Mi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Mi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,Mi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await Dee(t)).filter(a=>a[Mi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(Pee.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[Mi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new Cee(Mi.SYSTEM_SCHEMA_NAME,Mi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return Mee(i)}o(Bee,"dropAttributeFromSystem")});var bB=M((hCe,AB)=>{"use strict";var tI=_t(),Fu=kt(),mCe=An(),rI=(k(),v(K)),SB=ie(),{getTransactionAuditStorePath:Fee}=At(),Hee=Uu(),K_=Du(),kee=z();AB.exports=Gee;async function Gee(e){let t=Fee(e.schema,e.table),r=await tI.openEnvironment(t,e.table,!0),n=tI.listDBIs(r);tI.initializeDBIs(r,Fu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case rI.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return TB(r,e.search_values);case rI.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,$ee(r,e.search_values,s);case rI.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return qee(r,e.search_values);default:return TB(r)}}o(Gee,"readAuditLog");function TB(e,t=[0,Date.now()]){SB.isEmpty(t[0])&&(t[0]=0),SB.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[Fu.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(TB,"searchTransactionsByTimestamp");function qee(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[Fu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(a);r.set(s,yB(e,i))}return Object.fromEntries(r)}o(qee,"searchTransactionsByUsername");function $ee(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let u=t[c],d=Hee.equals(e,Fu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Fu.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=yB(e,s),a=new Map;for(let c=0;c<i.length;c++){let l=i[c],u=l.timestamp,d=n.get(u);RB(l,"records",r,d,a),RB(l,"original_records",r,d,a)}return Object.fromEntries(a)}o($ee,"searchTransactionsByHashValues");function RB(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(RB,"loopRecords");function yB(e,t){let r=[];try{let n=e.dbis[Fu.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){kee.warn(i)}return r}catch(n){throw n}}o(yB,"batchSearchTransactions")});var NB=M((gCe,IB)=>{"use strict";var{getSchemaPath:ECe}=At(),_Ce=_t(),{database:Vee}=(Le(),v(ft));IB.exports={writeTransaction:Kee};async function Kee(e,t,r){return Vee({database:e,table:t}).transaction(r)}o(Kee,"writeTransaction")});var PB=M((TCe,CB)=>{"use strict";var{getSchemaPath:wB}=At(),OB=_t();CB.exports={flush:Yee,resetReadTxn:Wee};async function Yee(e,t){return(await OB.openEnvironment(wB(e,t),t.toString())).flushed}o(Yee,"flush");async function Wee(e,t){try{(await OB.openEnvironment(wB(e,t),t.toString())).resetReadTxn()}catch{}}o(Wee,"resetReadTxn")});var vB=M((yCe,MB)=>{"use strict";var{Readable:zee}=require("stream"),{getDatabases:jee}=(Le(),v(ft)),{readSync:Qee,openSync:Jee,createReadStream:LB}=require("fs"),{open:Xee}=require("lmdb"),DB=Tm(),Zee=Rm(),{AUDIT_STORE_OPTIONS:ete}=(uo(),v(rU)),{INTERNAL_DBIS_NAME:tte,AUDIT_STORE_NAME:rte}=kt();MB.exports=ste;var nI=32768,nte=100;async function ste(e){let t=e.database||e.schema||"data",r=jee()[t],n=new Date().toISOString(),s=e.tables||e.table&&[e.table];if(s){let u=r[s[0]];if(!u)throw new Error(`Can not find table ${s[0]}`);let d=u.dbisDB,f=Xee({noSync:!0,maxDbs:Zee.MAX_DBS}),m,h=f.openDB(tte,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),_++%nte===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(rte,{...ete}),await m;let y=LB(f.path);return y.headers=l(),y.on("close",()=>{p.done(),f.close()}),y}let a=r[Object.keys(r)[0]].primaryStore,c=Jee(a.path);return a.transaction(()=>{let u=Buffer.alloc(nI);Qee(c,u,0,nI),a.resetReadTxn();let d=a.useReadTransaction();d.renew();let f=LB(null,{fd:c,start:nI}),m=new zee.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(ste,"getBackup")});var BB=M((bCe,xB)=>{"use strict";var ite=z(),{handleHDBError:ote}=Ee(),ate=lx(),cte=U_(),lte=wb(),ute=Qx(),dte=Cm(),fte=vb(),mte=y0(),hte=L0(),pte=Mm(),Ete=H0(),_te=Q0(),gte=tB(),Ste=nB(),Tte=aB(),Rte=hB(),yte=qb(),Ate=gB(),bte=bB(),Ite=NB(),UB=PB(),Nte=vB(),sI=class extends ate{static{o(this,"LMDBBridge")}async searchByConditions(t){return Ete(t)}async getDataByHash(t){return await fte(t)}async searchByHash(t){return await mte(t)}async getDataByValue(t,r){return await hte(t,r)}async searchByValue(t){return await pte(t)}async createSchema(t){return await ute(t)}async dropSchema(t){return await _te(t)}async createTable(t,r){return await gte(t,r)}async dropTable(t){return await yte(t)}async createAttribute(t){return await cte(t)}async createRecords(t){return await lte(t)}async updateRecords(t){return await Ste(t)}async upsertRecords(t){try{return await Tte(t)}catch(r){throw ote(r,null,null,ite.ERR,r)}}async deleteRecords(t){return await dte(t)}async dropAttribute(t){return await Ate(t)}async deleteAuditLogsBefore(t){return await Rte(t)}async readAuditLog(t){return await bte(t)}writeTransaction(t,r,n){return Ite.writeTransaction(t,r,n)}flush(t,r){return UB.flush(t,r)}resetReadTxn(t,r){return UB.resetReadTxn(t,r)}getBackup(t){return Nte(t)}};xB.exports=sI});function Ln(e){let t=e.getChanges();return t||(t=Object.create(null),e._setChanges(t)),t}function km(e,t,r=!1){let n=e.prototype,s={},i=t.attributes||t.properties||[];for(let l of i){let u=l.name,d,f;if(l.resolve)f={get(){return l.resolve(this,this.getContext?.())},set(m){return l.set(this,m)},configurable:!0};else{switch(l.type){case"String":d=o(function(m){if(!(typeof m=="string"||m==null&&l.nullable!==!1))throw new zn.ClientError(`${u} must be a string, attempt to assign ${m}`);Ln(this)[u]=m},"set");break;case"ID":d=o(function(m){if(!(typeof m=="string"||m?.length>0&&m.every?.(h=>typeof h=="string")||m==null&&l.nullable!==!1))throw new zn.ClientError(`${u} must be a string, attempt to assign ${m}`);Ln(this)[u]=m},"set");break;case"Float":case"Number":d=o(function(m){let h=m?.__op__?m.value:m;if(!(typeof h=="number"||m==null&&l.nullable!==!1))throw new zn.ClientError(`${u} must be a number, attempt to assign ${h}`);Ln(this)[u]=m},"set");break;case"Int":d=o(function(m){let h=m?.__op__?m.value:m;if(!(h>>0===h||m==null&&l.nullable!==!1))if(typeof h=="number"&&Math.abs((h>>0)-h)<=1)h=Math.round(h),m?.__op__?m.value=h:m=h;else throw new zn.ClientError(`${u} must be an integer between -2147483648 and 2147483647, attempt to assign ${m}`);Ln(this)[u]=m},"set");break;case"Long":d=o(function(m){let h=m?.__op__?m.value:m;if(!(Math.round(h)===m&&Math.abs(h)<=9007199254740992||m==null&&l.nullable!==!1))if(typeof h=="number"&&Math.abs(h)<=9007199254740992)h=Math.round(h),m?.__op__?m.value=h:m=h;else throw new zn.ClientError(`${u} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${m}`);Ln(this)[u]=m},"set");break;case"BigInt":d=o(function(m){let h=m?.__op__?m.value:m;if(!(typeof h=="bigint"||m==null&&l.nullable!==!1))if(typeof h=="string"||typeof h=="number")h=BigInt(h),m?.__op__?m.value=h:m=h;else throw new zn.ClientError(`${u} must be a number, attempt to assign ${m}`);Ln(this)[u]=m},"set");break;case"Boolean":d=o(function(m){if(!(typeof m=="boolean"||m==null&&l.nullable!==!1))throw new zn.ClientError(`${u} must be a boolean, attempt to assign ${m}`);Ln(this)[u]=m},"set");break;case"Date":d=o(function(m){if(!(m instanceof Date||m==null&&l.nullable!==!1))if(typeof m=="string"||typeof m=="number")m=new Date(m);else throw new zn.ClientError(`${u} must be a Date, attempt to assign ${m}`);Ln(this)[u]=m},"set");break;case"Bytes":d=o(function(m){if(!(m instanceof Uint8Array||m==null&&l.nullable!==!1))throw new zn.ClientError(`${u} must be a Buffer or Uint8Array, attempt to assign ${m}`);Ln(this)[u]=m},"set");break;case"Blob":d=o(function(m){if(!(m instanceof Ss||m==null&&l.nullable!==!1))throw new zn.ClientError(`${u} must be a Blob, attempt to assign ${m}`);Ln(this)[u]=m},"set");break;case"Any":case void 0:d=o(function(m){Ln(this)[u]=m},"set");break;default:d=o(function(m){if(!(typeof m=="object"||m==null&&l.nullable!==!1))throw new zn.ClientError(`${u} must be an object, attempt to assign ${m}`);Ln(this)[u]=m},"set")}f={get(){let m=this.getChanges?.();if(m&&u in m){let p=m[u];if(p?.__op__){let _=this.getRecord()?.[u];return p.update(_)}return p}let h=this.getRecord()?.[u];if(h&&typeof h=="object"){let p=iI(h,l);if(p)return m||this._setChanges(m=Object.create(null)),m[u]=p}return h},set:d,enumerable:!0,configurable:!0}}f.get.isAttribute=!0,s[u]=f,(!(u in n)||Object.getOwnPropertyDescriptor(n,u)?.get?.isAttribute)&&Object.defineProperty(n,u,f)}a("getProperty",function(l){let u=s[l];if(u)return u.get.call(this);let d=this.getChanges();return d?.[l]!==void 0?d[l]:this.getRecord()?.[l]}),a("set",function(l,u){let d=s[l];if(d)return d.set.call(this,u);if(t.sealed)throw new zn.ClientError("Can not add a property to a sealed table schema");Ln(this)[l]=u}),a("deleteProperty",function(l){Ln(this)[l]=void 0}),a("toJSON",function(){let l=this.getChanges?.(),u;for(let f in l){u||(u={...this.getRecord()});let m=l[f];if(m?.__op__){let h=u[f];m=m.update(h)}u[f]=m}return Object.keys(this).length>0&&(u||(u={...this.getRecord()}),Object.assign(u,this)),u||this.getRecord()}),n.get||a("get",n.getProperty),n.delete||a("delete",n.deleteProperty),n.then||a("then",null);function a(l,u){Object.defineProperty(n,l,{value:u,configurable:!0})}o(a,"setMethod");let c=n;do{let l=Object.getPrototypeOf(c);if(l===Object.prototype){Object.setPrototypeOf(c,r?kB:HB);break}c=l}while(c&&c!==HB&&c!==kB)}function GB(e,t,r){if(typeof t=="string"){if(t==="then"||t==="getRecord"||t==="getChanges")return;if(FB[t])return FB[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=iI(s);if(i)return n||(n=Object.create(null),r._setChanges(n)),n[t]=i,i}return s}}function wte(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 iI(e,t){let r;switch(e.constructor){case Object:return t?(r=t.TrackedObject,r||(t.TrackedObject=r=class extends sl{static{o(this,"TrackedObject")}},km(r,t)),new r(e)):new sl(e);case Array:let n=new W_(e.length,e);for(let s=0,i=e.length;s<i;s++){let a=e[s];a&&typeof a=="object"&&(a=iI(a,t?.elements)),n[s]=a}return n;default:return e}}function z_(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=z_(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 Ca(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=Ca(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=nA[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=Ca(s);r[n]=s}if(!Array.isArray(e)&&e.getRecord)for(let n in e)Ote.call(e,n)&&(r||(r={...e.getRecord()}),r[n]=e[n]);return r?Object.freeze(r):e.getRecord?e.getRecord():e}function Y_(e){let t=e.getRecord?.();if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[nl]||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(Y_(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(Y_(s))return!0}else return!0}else return!0}}return!1}var zn,FB,HB,kB,sl,Ote,nl,W_,Hm,oI=fe(()=>{zn=w(Ee());qE();Ts();o(Ln,"getChanges");o(km,"assignTrackedAccessors");FB=Object.prototype,HB=new Proxy({},{get:GB}),kB=new Proxy({},{get:GB,set:wte});o(GB,"getProxiedProperty");o(wte,"setProxiedProperty");o(iI,"trackObject");sl=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}};km(sl,{},!0);o(z_,"collapseData");Ote=Object.prototype.hasOwnProperty;o(Ca,"updateAndFreeze");o(Y_,"hasChanges");nl=Symbol.for("has-array-changes"),W_=class extends Array{static{o(this,"TrackedArray")}#e;[nl];constructor(t,r){super(t),this.#e=r}getRecord(){return this.#e}splice(...t){return this[nl]=!0,super.splice(...t)}push(...t){return this[nl]=!0,super.push(...t)}pop(){return this[nl]=!0,super.pop()}unshift(...t){return this[nl]=!0,super.unshift(...t)}shift(){return this[nl]=!0,super.shift()}};W_.prototype.constructor=Array;Hm=class{static{o(this,"Addition")}__op__="add";value;constructor(t){this.value=t}update(t){return(+t||0)+this.value}}});var jB={};Ce(jB,{ResourceBridge:()=>lI});function uI({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 qB(e,t){let r=vi(e),n=uI(e,r);if(!r)throw new ni.ClientError(`Table ${e.table} not found`);let s;n&&r.attributes.length-n.length>2&&n.length<5&&(s=!0);let i={user:e.hdb_user,onlyIfCached:e.onlyIfCached,noCacheStore:e.noCacheStore,noCache:e.noCache,replicateFrom:e.replicateFrom},a;vt(i,()=>new Promise(u=>a=u));let c=e.ids||e.hash_values,l=0;return{[Symbol.asyncIterator](){return{async next(){if(l<c.length){let u=c[l++],d;try{d=await r.get({id:u,lazy:s,select:n},i),d=d&&z_(d)}catch(f){d={message:(0,zB.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 vi(e){let t=e.database||e.schema||Pte,r=it()[t];if(!r)throw(0,ni.handleHDBError)(new Error,Cte.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function $B(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*VB(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 KB,j_,ni,YB,aI,cI,WB,zB,Cte,Pte,Lte,Dte,lI,QB=fe(()=>{KB=w(BB()),j_=w(xu()),ni=w(Ee());Le();YB=w(Nm());k();aI=w(bo()),cI=w(ti()),WB=w(ie());Uc();oI();zB=w(z()),{HDB_ERROR_MSGS:Cte}=ni.hdbErrors,Pte="data",Lte=1e4,Dte=10,lI=class extends KB.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,j_.default)(t,"conditions");if(r)throw(0,ni.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=vi(t);if(!n)throw new ni.ClientError(`Table ${t.table} not found`);let s=t.conditions.map(i);function i(a){if("conditions"in a&&a.conditions)return a.conditions=a.conditions.map(i),a;{let c=a;return{attribute:c.search_attribute??c.attribute,comparator:c.search_type??c.comparator,value:c.search_value!==void 0?c.search_value:c.value}}}return o(i,"mapCondition"),n.search({conditions:s,operator:t.operator?t.operator.toLowerCase():void 0,limit:t.limit,offset:t.offset,reverse:t.reverse,select:uI(t,n),sort:t.sort,allowFullScan:!0},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async createTable(t,r){let n=r.attributes,s=!!n,i=r.primary_key||r.hash_attribute;if(n)for(let a of n)a.is_primary_key?(a.isPrimaryKey=!0,delete a.is_primary_key):a.name===i&&i&&(a.isPrimaryKey=!0);else{if(!i)throw new ni.ClientError("A primary key must be specified with a `primary_key` property or with `attributes`");n=[{name:i,isPrimaryKey:!0},{name:"__createdtime__",indexed:!0},{name:"__updatedtime__",indexed:!0}]}et({database:r.database??r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration,audit:r.audit})}async createAttribute(t){return await vi(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=vi(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 vi(t).dropTable()}createSchema(t){return Hu({database:t.schema,table:null}),aI.signalSchemaChange(new cI.SchemaEventMsg(process.pid,G.CREATE_SCHEMA,t.schema))}async dropSchema(t){await dI(t.schema),aI.signalSchemaChange(new cI.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,YB.default)(t),s,i=it()[t.schema][t.table],a={user:t.hdb_user,expiresAt:t.expiresAt,originatingOperation:t.operation};return t.replicateTo&&(a.replicateTo=t.replicateTo),t.replicatedConfirmation&&(a.replicatedConfirmation=t.replicatedConfirmation),vt(a,async c=>{if(!i.schemaDefined){s=[];for(let d of n)i.attributes.find(m=>m.name==d)||s.push(d);s.length>0&&await i.addAttributes(s.map(d=>({name:d,indexed:!0})))}let l=[],u=[];for(let d of t.records){let f=d[i.primaryKey],m=f!=null&&await i.get(f,a);if(t.requires_existing&&!m||t.requires_no_existing&&m){u.push(d[i.primaryKey]);continue}m&&(m=z_(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),vt(n,async s=>{let i=t.hash_values||t.records.map(l=>l[r.primaryKey]),a=[],c=[];for(let l of i)await r.delete(l,n)?a.push(l):c.push(l);return $B(a,c,s.timestamp)})}async deleteRecordsBefore(t){let r=it()[t.schema][t.table];if(!r.createdTimeProperty)throw new ni.ClientError("Table must have a '__createdtime__' attribute or @createdTime timestamp defined to perform this operation");let n=await r.search({conditions:[{attribute:r.createdTimeProperty.name,value:Date.parse(t.date),comparator:AE.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,WB.asyncSetTimeout)(Dte),l=[],s=!0},"chunkDelete");for await(let d of n)l.push(d[r.primaryKey]),c++,c%Lte===0&&await u();return l.length>0&&await u(),s?$B(i,a,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,j_.default)(t,"hashes");if(r)throw r;return qB(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of qB(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&Uy[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,j_.default)(t,"value");if(n)throw n;let s=vi(t);if(!s)throw new ni.ClientError(`Table ${t.table} not found`);let i=t.search_value;i.includes?.("*")&&(i.startsWith("*")?i.endsWith("*")?i!=="*"&&(r="contains",i=i.slice(1,-1)):(r="ends_with",i=i.slice(1)):i.endsWith("*")&&(r="starts_with",i=i.slice(0,-1))),r===AE.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:uI(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async getDataByValue(t,r){let n=new Map,s=vi(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){vi({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return vi(t).deleteHistory(t.timestamp,t.cleanup_deleted_records)}async readAuditLog(t){let r=vi(t),n={};switch(t.search_type){case bE.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 bE.USERNAME:{let s=t.search_values;for await(let i of VB(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n}default:return VB(r,t.search_values?.[0],t.search_values?.[1],t.limit)}}};o(uI,"getSelect");o(qB,"getRecords");o(vi,"getTable");o($B,"createDeleteResponse");o(VB,"groupRecordsInHistory")});var jn=M((UCe,JB)=>{"use strict";var{ResourceBridge:Mte}=(QB(),v(jB)),vte=ce();vte.initSync();var Q_;function Ute(){return Q_||(Q_=new Mte,Q_)}o(Ute,"getBridge");JB.exports=Ute()});var tF=M((BCe,eF)=>{"use strict";var XB=require("lodash"),Gm=require("mathjs"),xte=require("jsonata"),ZB=ie();eF.exports={distinct_array:o(e=>Array.isArray(e)&&e.length>1?XB.uniqWith(e,XB.isEqual):e,"distinct_array"),searchJSON:Bte,mad:qm.bind(null,Gm.mad),mean:qm.bind(null,Gm.mean),mode:qm.bind(null,Gm.mode),prod:qm.bind(null,Gm.prod),median:qm.bind(null,Gm.median)};function qm(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(qm,"aggregateFunction");function Bte(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(ZB.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),ZB.isEmpty(this.__ala__.res[r])){let n=xte(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}o(Bte,"searchJSON")});var nF=M((HCe,rF)=>{"use strict";var ar=require("moment"),fI="YYYY-MM-DDTHH:mm:ss.SSSZZ";ar.suppressDeprecationWarnings=!0;rF.exports={current_date:o(()=>ar().utc().format("YYYY-MM-DD"),"current_date"),current_time:o(()=>ar().utc().format("HH:mm:ss.SSS"),"current_time"),extract:o((e,t)=>{switch(t.toLowerCase()){case"year":return ar(e).utc().format("YYYY");case"month":return ar(e).utc().format("MM");case"day":return ar(e).utc().format("DD");case"hour":return ar(e).utc().format("HH");case"minute":return ar(e).utc().format("mm");case"second":return ar(e).utc().format("ss");case"millisecond":return ar(e).utc().format("SSS");default:break}},"extract"),date:o(e=>ar(e).utc().format(fI),"date"),date_format:o((e,t)=>ar(e).utc().format(t),"date_format"),date_add:o((e,t,r)=>ar(e).utc().add(t,r).valueOf(),"date_add"),date_sub:o((e,t,r)=>ar(e).utc().subtract(t,r).valueOf(),"date_sub"),date_diff:o((e,t,r)=>{let n=ar(e).utc(),s=ar(t).utc();return r?n.diff(s,r,!0):n.diff(s)},"date_diff"),now:o(()=>ar().utc().valueOf(),"now"),get_server_time:o(()=>ar().format(fI),"get_server_time"),offset_utc:o((e,t)=>ar(e).utc().utcOffset(t).format(fI),"offset_utc")}});var aF=M((GCe,oF)=>{"use strict";var Fte=require("@turf/area"),Hte=require("@turf/length"),kte=require("@turf/circle"),Gte=require("@turf/difference"),qte=require("@turf/distance"),$te=require("@turf/boolean-contains"),Vte=require("@turf/boolean-equal"),Kte=require("@turf/boolean-disjoint"),Yte=require("@turf/helpers"),sF=(k(),v(K)),Ye=ie(),wo=z();oF.exports={geoArea:Wte,geoLength:zte,geoCircle:jte,geoDifference:Qte,geoDistance:iF,geoNear:Jte,geoContains:Xte,geoEqual:Zte,geoCrosses:ere,geoConvert:tre};function Wte(e){if(Ye.isEmpty(e))return NaN;typeof e=="string"&&(e=Ye.autoCastJSON(e));try{return Fte.default(e)}catch(t){return wo.trace(t,e),NaN}}o(Wte,"geoArea");function zte(e,t){if(Ye.isEmpty(e))return NaN;typeof e=="string"&&(e=Ye.autoCastJSON(e));try{return Hte.default(e,{units:t||"kilometers"})}catch(r){return wo.trace(r,e),NaN}}o(zte,"geoLength");function jte(e,t,r){if(Ye.isEmpty(e))return NaN;if(Ye.isEmpty(t))return NaN;typeof e=="string"&&(e=Ye.autoCastJSON(e));try{return kte.default(e,t,{units:r||"kilometers"})}catch(n){return wo.trace(n,e,t),NaN}}o(jte,"geoCircle");function Qte(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 Gte(e,t)}catch(r){return wo.trace(r,e,t),NaN}}o(Qte,"geoDifference");function iF(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 qte.default(e,t,{units:r||"kilometers"})}catch(n){return wo.trace(n,e,t),NaN}}o(iF,"geoDistance");function Jte(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 iF(e,t,n)<=r}catch(s){return wo.trace(s,e,t),!1}}o(Jte,"geoNear");function Xte(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 $te.default(e,t)}catch(r){return wo.trace(r,e,t),!1}}o(Xte,"geoContains");function Zte(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 Vte.default(e,t)}catch(r){return wo.trace(r,e,t),!1}}o(Zte,"geoEqual");function ere(e,t){if(Ye.isEmpty(e)||Ye.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Ye.autoCastJSON(e)),typeof t=="string"&&(t=Ye.autoCastJSON(t));try{return!Kte.default(e,t)}catch(r){return wo.trace(r,e,t),!1}}o(ere,"geoCrosses");function tre(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(sF.GEO_CONVERSION_ENUM[t]))throw new Error(`geoType of ${t} is invalid please use one of the following types: ${Object.keys(sF.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Ye.autoCastJSON(e)),Yte[t](e,r)}o(tre,"geoConvert")});var J_=M(($Ce,cF)=>{var il=tF(),Qn=nF(),Ui=aF();cF.exports=e=>{e.aggr.mad=e.aggr.MAD=il.mad,e.aggr.mean=e.aggr.MEAN=il.mean,e.aggr.mode=e.aggr.MODE=il.mode,e.aggr.prod=e.aggr.PROD=il.prod,e.aggr.median=e.aggr.MEDIAN=il.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=il.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=il.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=Qn.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Qn.current_time,e.fn.extract=e.fn.EXTRACT=Qn.extract,e.fn.date=e.fn.DATE=Qn.date,e.fn.date_format=e.fn.DATE_FORMAT=Qn.date_format,e.fn.date_add=e.fn.DATE_ADD=Qn.date_add,e.fn.date_sub=e.fn.DATE_SUB=Qn.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Qn.date_diff,e.fn.now=e.fn.NOW=Qn.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Qn.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Qn.get_server_time,e.fn.getdate=e.fn.GETDATE=Qn.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Qn.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=Ui.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=Ui.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=Ui.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=Ui.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=Ui.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=Ui.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=Ui.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=Ui.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=Ui.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=Ui.geoNear}});var fF=M((VCe,dF)=>{"use strict";var $m=require("lodash"),Dn=require("alasql");Dn.options.cache=!1;var rre=J_(),lF=require("clone"),X_=require("recursive-iterator"),ke=z(),tt=ie(),ku=jn(),nre=(k(),v(K)),{hdbErrors:sre}=Ee(),{getDatabases:uF}=(Le(),v(ft)),ire="IS NULL",si="There was a problem performing this search. Please check the logs and try again.";rre(Dn);var mI=class{static{o(this,"SQLSearch")}constructor(t,r){if(tt.isEmpty(t))throw ke.error("AST statement for SQL select process cannot be empty"),"statement cannot be null";this.statement=t,this.columns={},this.all_table_attributes=r,this.fetch_attributes=[],this.exact_search_values={},this.comparator_search_values={},this.tables=[],this.data={},this.has_aggregator=!1,this.has_ordinal=!1,this.has_outer_join=!1,this._getColumns(),this._getTables(),this._conditionsToFetchAttributeValues(),this._setAliasesForColumns(),tt.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!tt.isEmptyOrZeroLength(n))return ke.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw ke.error("Error thrown from checkEmptySQL in SQLSearch class method search."),ke.error(n),new Error(si)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw ke.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),ke.error(n),new Error(si)}if(Object.keys(this.data).length===0)return ke.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw ke.error("Error thrown from processJoins in SQLSearch class method search."),ke.error(n),new Error(si)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw ke.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),ke.error(n),new Error(si)}try{return t=await this._finalSQL(),t}catch(n){throw ke.error("Error thrown from finalSQL in SQLSearch class method search."),ke.error(n),new Error(si)}}_getColumns(){let t=new X_(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(lF(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=$m.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=uF()[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 X_(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!tt.isEmpty(r)&&r.right)if(tt.isNotEmptyAndHasValue(r.right.value)){let n=tt.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new Dn.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=tt.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new Dn.yy.LogicValue({value:i}):n instanceof Dn.yy.StringValue&&tt.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new Dn.yy.NumValue({value:i}))});if(t){ke.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new X_(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(nre.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&&$m.pullAt(this.statement.columns,t)}_findColumn(t){let r=this.all_table_attributes.filter(n=>{if(t.columnid_orig&&t.tableid_orig)return(n.table.as===t.tableid_orig||n.table.tableid===t.tableid_orig)&&n.attribute===t.columnid_orig;if(t.tableid)return(n.table.as===t.tableid||n.table.tableid===t.tableid)&&n.attribute===t.columnid;let s=t.columnid_orig?t.columnid_orig:t.columnid;return n.attribute===s});if(tt.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);tt.isEmptyOrZeroLength(n)||(r=this.all_table_attributes.filter(s=>s.attribute===n[0].columnid&&n[0].tableid&&n[0].tableid===(s.table.as?s.table.as:s.table.tableid)))}return r[0]}async _checkEmptySQL(){let t=[];if(tt.isEmptyOrZeroLength(this.all_table_attributes)&&!tt.isEmptyOrZeroLength(this.columns.columns))return t;if(tt.isEmptyOrZeroLength(this.all_table_attributes)&&tt.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await Dn.promise(r)}catch(r){throw ke.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),ke.error(r),new Error("There was a problem with the SQL statement")}return t}_addFetchColumns(t){t&&t.length>0&&t.forEach(r=>{let n=this._findColumn(r);n&&this.fetch_attributes.push(lF(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(ire)>-1&&this.tables.forEach(s=>{let i={columnid:uF()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=$m.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 ku.getDataByHash(c);for(let f of c.hash_values)d.get(f)&&!this.data[i].__mergedData[f]&&(this.data[i].__mergedData[f]=[...n[i]],this._setMergedHashAttribute(i,f))}catch(d){throw ke.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),ke.error(d),new Error(si)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[u].values).map(async d=>{let f={...c};f.search_value=d;let m=await ku.getDataByValue(f);for(let[h,p]of m)this.data[i].__mergedData[h]?this._updateMergedAttribute(i,h,s.attribute,p[s.attribute]):(this.data[i].__mergedData[h]=[...n[i]],this._updateMergedAttribute(i,h,s.attribute,p[s.attribute]),this._setMergedHashAttribute(i,h))}))}catch(d){throw ke.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),ke.error(d),new Error(si)}else if(!tt.isEmpty(this.comparator_search_values[u])&&!this.comparator_search_values[u].ignore&&!tt.isEmptyOrZeroLength(this.comparator_search_values[u].comparators))try{let d=this.comparator_search_values[u].comparators;for(let f=0,m=d.length;f<m;f++){let h=d[f];c.search_attribute=h.attribute,c.search_value=h.search_value;let p=await ku.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(si)}else try{c.search_attribute=s.attribute,c.search_value="*";let d=await ku.getDataByValue(c);if(l)for(let[f]of d)this.data[i].__mergedData[f]||(this.data[i].__mergedData[f]=[...n[i]],this._setMergedHashAttribute(i,f));else for(let[f,m]of d)this.data[i].__mergedData[f]?this._updateMergedAttribute(i,f,s.attribute,m[s.attribute]):(this.data[i].__mergedData[f]=[...n[i]],this._updateMergedAttribute(i,f,s.attribute,m[s.attribute]),this._setMergedHashAttribute(i,f))}catch(d){throw ke.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),ke.error(d),new Error(si)}}}_isSimpleSelect(){let t=!0;return Object.keys(this.statement).length!==2||!this.statement.columns||!this.statement.from||this.statement.from.length!==1?(t=!1,t):(this.statement.columns.forEach(r=>{r instanceof Dn.yy.Column||(t=!1)}),t)}_updateOrderByToAliases(){this.statement.order.forEach(t=>{if(t.expression.aggregatorid){t.is_aggregator=!0;return}if(t.expression.value){t.is_ordinal=!0,this.has_ordinal=!0;return}else t.is_ordinal=!1;let r=this.statement.columns.filter(s=>{let i=s.aggregatorid?s.expression:s,a=s.aggregatorid?s.as_orig:i.as_orig;return t.expression.tableid?i.columnid_orig===t.expression.columnid_orig&&i.tableid_orig===t.expression.tableid_orig:i.columnid_orig===t.expression.columnid_orig||t.expression.columnid_orig===a});r[0]||r.push(this._findColumn(t.expression));let n=r[0];if(t.is_func=!!n.funcid,t.is_aggregator=!!n.aggregatorid,n.as)if(n.as&&!t.expression.tableid)t.expression.columnid=n.as,t.expression.columnid_orig=n.as_orig;else{let s=new Dn.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new Dn.yy.Column,t.expression),t.initial_select_column.as=`[${t.expression.columnid_orig}]`,t.expression.columnid=t.initial_select_column.as;return}if(!t.is_aggregator){let s=t.is_func?new Dn.yy.FuncValue:new Dn.yy.Column;t.initial_select_column=Object.assign(s,n)}})}_addNonAggregatorsToFetchColumns(){let r=this.statement.order.filter(n=>!n.is_aggregator&&!n.is_ordinal).map(n=>n.is_func?{columnid:n.initial_select_column.args.filter(i=>!!i.columnid_orig)[0].columnid_orig}:{columnid:n.expression.columnid_orig});this._addFetchColumns(r)}async _processJoins(){let t=[],r=[],n=this.statement.from[0],s=[n],i=["? "+(n.as?" AS "+n.as:n.tableid)];t.push(Object.values(this.data[`${n.databaseid_orig}_${n.as?n.as_orig:n.tableid_orig}`].__mergedData)),this.statement.joins&&this.statement.joins.forEach(h=>{h.joinmode&&h.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(h.table);let p=h.joinmode+" JOIN ? AS "+(h.as?h.as:h.table.tableid);h.on&&(p+=" ON "+h.on.toString()),i.push(p),t.push(Object.values(this.data[`${h.table.databaseid_orig}_${h.table.as?h.table.as_orig:h.table.tableid_orig}`].__mergedData))});let a=[],c={};s.forEach(h=>{let p=this.data[`${h.databaseid_orig}_${h.as?h.as_orig:h.tableid_orig}`].__hashName,_=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 Dn.promise(p,t),t=null}catch(h){throw ke.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),ke.error(h),new Error("There was a problem processing the data.")}if(m&&m.length>0){for(let h=0,p=m.length;h<p;h++){let _=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),_=$m.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 X_(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=$m.uniqBy(n,i=>[i.table.databaseid,i.table.as?i.table.as:i.table.tableid,i.attribute].join());try{await this._getData(n)}catch(i){throw ke.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),ke.error(i),new Error(si)}}async _getData(t){try{let r=t.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]?n[i].columns.push(s.attribute):n[i]={schema:s.table.databaseid,table:s.table.tableid,columns:[s.attribute]},n},{});for(let n in r){let s=r[n],i=this.data[n].__mergedData,a=[];for(let d in i)a.push(i[d][0]);this.data[n].__mergedAttributes.push(...s.columns);let c={schema:s.schema,table:s.table,hash_values:a,get_attributes:s.columns},l=await ku.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 Dn.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),ke.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw ke.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),ke.error(s),new Error("There was a problem running the generated sql.")}return n}_translateUndefinedValues(t){try{let r=[];for(let n of t){let s=Object.create(null);Object.keys(n).forEach(i=>{n[i]===void 0?s[i]=null:s[i]=n[i]}),r.push(s)}return r}catch(r){return ke.error(sre.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 ku.getDataByValue(i);for(let[c,l]of a)this.data[s].__mergedData[c]||(l[n.attribute]===void 0&&(l[n.attribute]=null),this.data[s].__mergedData[c]={...r[s]}),this.data[s].__mergedData[c][t[n.attribute]]=l[n.attribute]??null}catch(a){throw ke.error("There was an error when processing this SQL operation. Check your logs"),ke.error(a),new Error(si)}}return Object.values(Object.values(this.data)[0].__mergedData)}};dF.exports=mI});var on=M((YCe,mF)=>{"use strict";var ore=ax();mF.exports={searchByConditions:cre,searchByHash:lre,searchByValue:ure,search:dre};var hI=jn(),{transformReq:pI}=ie(),are=fF();async function cre(e){return pI(e),hI.searchByConditions(e)}o(cre,"searchByConditions");async function lre(e){pI(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of hI.searchByHash(e))r&&t.push(r);return t}o(lre,"searchByHash");async function ure(e){pI(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of hI.searchByValue(e))t.push(r);return t}o(ure,"searchByValue");function dre(e,t){try{let r=new ore(e);r.validate(),new are(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}o(dre,"search")});var xi=M((zCe,_F)=>{"use strict";var Vm=require("crypto"),fre=ce(),{CONFIG_PARAMS:mre}=(k(),v(K)),pF="aes-256-cbc",hre=32,pre=16,EI=64,EF=32,Ere=EI+EF,hF=new Map;_F.exports={encrypt:_re,decrypt:gre,createNatsTableStreamName:Sre};function _re(e){let t=Vm.randomBytes(hre),r=Vm.randomBytes(pre),n=Vm.createCipheriv(pF,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(_re,"encrypt");function gre(e){let t=e.substr(0,EI),r=e.substr(EI,EF),n=e.substr(Ere,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),a=Vm.createDecipheriv(pF,Buffer.from(t,"hex"),s),c=a.update(i);return c=Buffer.concat([c,a.final()]),c.toString()}o(gre,"decrypt");function Sre(e,t){let r=fre.get(mre.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=hF.get(r);return n||(n=Vm.createHash("md5").update(r).digest("hex"),hF.set(r,n)),n}o(Sre,"createNatsTableStreamName")});var Pa=M((JCe,RF)=>{"use strict";var QCe=on(),Km=z(),{validateBySchema:gF}=at(),ol=require("joi"),Tre=xi(),Z_=ie(),{handleHDBError:eg,hdbErrors:Rre,ClientError:SF}=Ee(),{HDB_ERROR_MSGS:tg,HTTP_STATUS_CODES:_I}=Rre,TF=ce();TF.initSync();var{getDatabases:gI}=(Le(),v(ft)),yre=require("fs-extra"),Are=(k(),v(K));RF.exports={describeAll:bre,describeTable:rg,describeSchema:Ire};async function bre(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=gI(),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 rg({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 rg({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),eg(new Error,tg.DESCRIBE_ALL_ERR)}}o(bre,"describeAll");async function rg(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=gF(e,ol.object({database:ol.string(),table:ol.string().required(),exact_count:ol.boolean().strict()}));if(i)throw new SF(i.message);let c=gI()[r];if(!c)throw eg(new Error,tg.SCHEMA_NOT_FOUND(e.schema),_I.NOT_FOUND);let l=c[n];if(!l)throw eg(new Error,tg.TABLE_NOT_FOUND(e.schema,e.table),_I.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 yre.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")),TF.get(Are.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(m.clustering_stream_name=Tre.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(rg,"descTable");async function Ire(e){Z_.transformReq(e);let t=gF(e,ol.object({database:ol.string(),exact_count:ol.boolean().strict()}));if(t)throw new SF(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=gI()[n];if(!i)throw eg(new Error,tg.SCHEMA_NOT_FOUND(e.schema),_I.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 rg({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);u&&(a[u.name]=u)}}return a}o(Ire,"describeSchema")});var Mn=M((ZCe,IF)=>{"use strict";var sg=Rb(),$r=ie(),Nre=require("util"),ig=jn(),wre=ei(),yF=z(),{handleHDBError:al,hdbErrors:Ore}=Ee(),{HTTP_STATUS_CODES:cl}=Ore,Cre=Nre.promisify(wre.getTableSchema),Pre="updated",AF="inserted",bF="upserted";IF.exports={insert:Dre,update:Mre,upsert:vre,validation:Lre,flush:Ure};async function Lre(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 Cre(e.schema,e.table),r=sg(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 yF.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 yF.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(Lre,"validation");async function Dre(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=sg(e);if(t)throw al(new Error,t.message,cl.BAD_REQUEST);$r.transformReq(e);let r=$r.checkSchemaTableExist(e.schema,e.table);if(r)throw al(new Error,r,cl.BAD_REQUEST);let n=await ig.createRecords(e);return ng(AF,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}o(Dre,"insertData");async function Mre(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=sg(e);if(t)throw al(new Error,t.message,cl.BAD_REQUEST);$r.transformReq(e);let r=$r.checkSchemaTableExist(e.schema,e.table);if(r)throw al(new Error,r,cl.BAD_REQUEST);let n=await ig.updateRecords(e);return $r.isEmpty(n.existing_rows)?ng(Pre,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):ng(n.update_action,[],e,n.hashes,void 0,n.txn_time)}o(Mre,"updateData");async function vre(e){if(e.operation!=="upsert")throw al(new Error,"invalid operation, must be upsert",cl.INTERNAL_SERVER_ERROR);let t=sg(e);if(t)throw al(new Error,t.message,cl.BAD_REQUEST);$r.transformReq(e);let r=$r.checkSchemaTableExist(e.schema,e.table);if(r)throw al(new Error,r,cl.BAD_REQUEST);let n=await ig.upsertRecords(e);return ng(bF,n.written_hashes,e,[],n.new_attributes,n.txn_time)}o(vre,"upsertData");function ng(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===AF?(a.inserted_hashes=t,a.skipped_hashes=n,a):e===bF?(a.upserted_hashes=t,a):(a.update_hashes=t,a.skipped_hashes=n,a)}o(ng,"returnObject");function Ure(e){return $r.transformReq(e),ig.flush(e.schema,e.table)}o(Ure,"flush")});var TI=M((tPe,OF)=>{var xre=at(),SI=require("joi"),{hdbTable:Bre,hdbDatabase:NF}=Di(),wF={schema:NF,database:NF,table:Bre},Fre={date:SI.date().iso().required()},Hre={timestamp:SI.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};OF.exports=function(e,t){let r=t==="timestamp"?{...wF,...Hre}:{...wF,...Fre},n=SI.object(r);return xre.validateBySchema(e,n)}});var LF=M((rPe,PF)=>{var kre=at(),RI=require("joi"),{hdbTable:Gre,hdbDatabase:CF}=Di(),qre=RI.object({schema:CF,database:CF,table:Gre,hash_values:RI.array().required(),ids:RI.array()});PF.exports=function(e){return kre.validateBySchema(e,qre)}});var II=M((nPe,DF)=>{"use strict";var yI=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}},AI=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}},bI=class{static{o(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};DF.exports={InsertObject:yI,NoSQLSeachObject:AI,DeleteResponseObject:bI}});var dl=M((iPe,BF)=>{"use strict";var vF=TI(),$re=LF(),ll=ie(),MF=require("moment"),UF=z(),{promisify:Vre,callbackify:Kre}=require("util"),ul=(k(),v(K)),Yre=ei(),NI=Vre(Yre.getTableSchema),wI=jn(),{DeleteResponseObject:Wre}=II(),{handleHDBError:La,hdbErrors:zre}=Ee(),{HDB_ERROR_MSGS:og,HTTP_STATUS_CODES:Da}=zre,jre="records successfully deleted",Qre=Kre(xF);BF.exports={delete:Qre,deleteRecord:xF,deleteFilesBefore:Jre,deleteAuditLogsBefore:Xre};async function Jre(e){let t=vF(e,"date");if(t)throw La(t,t.message,Da.BAD_REQUEST,void 0,void 0,!0);if(ll.transformReq(e),!MF(e.date,MF.ISO_8601).isValid())throw La(new Error,og.INVALID_DATE,Da.BAD_REQUEST,ul.LOG_LEVELS.ERROR,og.INVALID_DATE,!0);let n=ll.checkSchemaTableExist(e.schema,e.table);if(n)throw La(new Error,n,Da.NOT_FOUND,ul.LOG_LEVELS.ERROR,n,!0);let s=await wI.deleteRecordsBefore(e);if(await NI(e.schema,e.table),UF.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}o(Jre,"deleteFilesBefore");async function Xre(e){let t=vF(e,"timestamp");if(t)throw La(t,t.message,Da.BAD_REQUEST,void 0,void 0,!0);if(ll.transformReq(e),isNaN(e.timestamp))throw La(new Error,og.INVALID_VALUE("Timestamp"),Da.BAD_REQUEST,ul.LOG_LEVELS.ERROR,og.INVALID_VALUE("Timestamp"),!0);let r=ll.checkSchemaTableExist(e.schema,e.table);if(r)throw La(new Error,r,Da.NOT_FOUND,ul.LOG_LEVELS.ERROR,r,!0);let n=await wI.deleteAuditLogsBefore(e);return await NI(e.schema,e.table),UF.info(`Finished deleting audit logs before ${e.timestamp}`),n}o(Xre,"deleteAuditLogsBefore");async function xF(e){e.ids&&(e.hash_values=e.ids);let t=$re(e);if(t)throw La(t,t.message,Da.BAD_REQUEST,void 0,void 0,!0);ll.transformReq(e);let r=ll.checkSchemaTableExist(e.schema,e.table);if(r)throw La(new Error,r,Da.NOT_FOUND,ul.LOG_LEVELS.ERROR,r,!0);try{await NI(e.schema,e.table);let n=await wI.deleteRecords(e);return ll.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${jre}`),n}catch(n){if(n.message===ul.SEARCH_NOT_FOUND_MESSAGE){let s=new Wre;return s.message=ul.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}o(xF,"deleteRecord")});var ag={};Ce(ag,{HASH_FUNCTION:()=>Mr,hash:()=>PI,validate:()=>LI});function OI(e=Wm){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ";return Array.from(Ym.randomBytes(e)).map(r=>t[r%t.length]).join("")}function PI(e,t=Mr[HF?.toUpperCase()]??Mr.SHA256){return CI[t](e)}function LI(e,t,r=Mr[HF?.toUpperCase()]??Mr.SHA256){return e?Zre[r](e,t):!1}var Ym,Gu,FF,HF,Wm,kF,Mr,CI,Zre,cg=fe(()=>{Ym=w(require("node:crypto")),Gu=w(require("argon2")),FF=w(ce());k();HF=(0,FF.get)(U.AUTHENTICATION_HASHFUNCTION)?.toLowerCase(),Wm=16,kF=9,Mr={MD5:"md5",SHA256:"sha256",ARGON2ID:"argon2id"};o(OI,"generateSalt");CI={[Mr.MD5]:(e,t=void 0)=>{t=t??OI(kF);let r=Ym.createHash(Mr.MD5).update(e+t).digest("hex");return t+r},[Mr.SHA256]:(e,t=void 0)=>{t=t??OI(Wm);let r=Ym.createHash(Mr.SHA256).update(e+t).digest("hex");return t+r},[Mr.ARGON2ID]:async e=>{let t=OI(Wm),r=await Gu.hash(e,{type:Gu.argon2id,salt:Buffer.from(t)});return t+r}},Zre={[Mr.MD5]:(e,t)=>{let r=e.slice(0,kF);return e===CI[Mr.MD5](t,r)},[Mr.SHA256]:(e,t)=>{let r=e.slice(0,Wm);return e===CI[Mr.SHA256](t,r)},[Mr.ARGON2ID]:async(e,t)=>await Gu.verify(e.slice(Wm),t)};o(PI,"hash");o(LI,"validate")});var qF=M((lPe,GF)=>{var DI=at(),an={username:{presence:!0,exclusion:{within:["system"],message:"You cannot create tables within the system schema"}},password:{presence:!0},role:{presence:!0,format:"[\\w\\-\\_]+"},active:{presence:!0,inclusion:{within:[!0,!1],message:"must be a boolean"}}};function ene(e){return an.password.presence=!0,an.username.presence=!0,an.role.presence=!0,an.active.presence=!0,DI.validateObject(e,an)}o(ene,"addUserValidation");function tne(e){return an.password.presence=!1,an.username.presence=!0,an.role.presence=!1,an.active.presence=!1,DI.validateObject(e,an)}o(tne,"alterUserValidation");function rne(e){return an.password.presence=!1,an.username.presence=!0,an.role.presence=!1,an.active.presence=!1,DI.validateObject(e,an)}o(rne,"dropUserValidation");GF.exports={addUserValidation:ene,alterUserValidation:tne,dropUserValidation:rne}});var It=M((fPe,VF)=>{"use strict";var{platform:dPe}=require("os"),nne="nats-server.zip",MI="nats-server",sne=process.platform==="win32"?`${MI}.exe`:MI,ine=/^[^\s.,*>]+$/,$F="__request__",one=o(e=>`${e}.${$F}`,"REQUEST_SUBJECT"),ane={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},cne={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},lne={HUB:"hub.pid",LEAF:"leaf.pid"},une={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},dne={SUCCESS:"success",ERROR:"error"},fne={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},mne={TXN:"txn",MSGID:"msgid"},qu={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},hne={[qu.ERR]:1,[qu.WRN]:2,[qu.INF]:3,[qu.DBG]:4,[qu.TRC]:5},pne={debug:"-D",trace:"-DVV"};VF.exports={NATS_SERVER_ZIP:nne,NATS_SERVER_NAME:MI,NATS_BINARY_NAME:sne,PID_FILES:lne,NATS_CONFIG_FILES:cne,SERVER_SUFFIX:une,NATS_TERM_CONSTRAINTS_RX:ine,REQUEST_SUFFIX:$F,UPDATE_REMOTE_RESPONSE_STATUSES:dne,CLUSTER_STATUS_STATUSES:fne,REQUEST_SUBJECT:one,SUBJECT_PREFIXES:mne,MSG_HEADERS:ane,LOG_LEVELS:qu,LOG_LEVEL_FLAGS:pne,LOG_LEVEL_HIERARCHY:hne}});var Jn=M((hPe,vr)=>{"use strict";var WF="username is required",zF="nothing to update, must supply active, role or password to update",jF="password cannot be an empty string",QF="If role is specified, it cannot be empty.",JF="active must be true or false";vr.exports.addUser=bne;vr.exports.alterUser=Ine;vr.exports.dropUser=wne;vr.exports.getSuperUser=Dne;vr.exports.userInfo=One;vr.exports.listUsers=ug;vr.exports.listUsersExternal=Cne;vr.exports.setUsersWithRolesCache=fl;vr.exports.findAndValidateUser=qI;vr.exports.getClusterUser=Mne;vr.exports.getUsersWithRolesCache=Lne;vr.exports.USERNAME_REQUIRED=WF;vr.exports.ALTERUSER_NOTHING_TO_UPDATE=zF;vr.exports.EMPTY_PASSWORD=jF;vr.exports.EMPTY_ROLE=QF;vr.exports.ACTIVE_BOOLEAN=JF;var XF=Mn(),Ene=dl(),zm=(cg(),v(ag)),ZF=qF(),jm=on(),FI=bo(),Bi=ie(),eH=require("validate.js"),HI=z(),{promisify:_ne}=require("util"),kI=xi(),UI=(k(),v(K)),KF=It(),gne=yt(),Sne=ce(),Tne=Ro(),{hdbErrors:Rne,ClientError:ii}=Ee(),{HTTP_STATUS_CODES:Oo,AUTHENTICATION_ERROR_MSGS:vI,HDB_ERROR_MSGS:$u}=Rne,{UserEventMsg:GI}=ti(),xI=require("lodash"),{server:lg}=(Pr(),v(Bf)),yne=z();lg.getUser=(e,t)=>qI(e,t,t!=null);lg.authenticateUser=(e,t)=>qI(e,t);var tH={username:!0,active:!0,role:!0,password:!0},YF=new Map,Ane=_ne(Ene.delete),BI=Sne.get(UI.CONFIG_PARAMS.AUTHENTICATION_HASHFUNCTION)??zm.HASH_FUNCTION.SHA256,Fi;async function bne(e){let t=eH.cleanAttributes(e,tH),r=ZF.addUserValidation(t);if(r)throw new ii(r.message);let n=await jm.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),Oo.NOT_FOUND);if(n.length>1)throw new ii($u.DUP_ROLES_FOUND(t.role),Oo.CONFLICT);n[0].permission.cluster_user===!0&&(t.hash=kI.encrypt(t.password)),t.password=await zm.hash(t.password,BI),t.hash_function=BI,t.role=n[0].id;let s=await XF.insert({operation:"insert",schema:"system",table:"hdb_user",records:[t]});if(HI.debug(s),await fl(),s.skipped_hashes.length===1)throw new ii($u.USER_ALREADY_EXISTS(t.username),Oo.CONFLICT);return FI.signalUserChange(new GI(process.pid)),`${t.username} successfully added`}o(bne,"addUser");async function Ine(e){let t=eH.cleanAttributes(e,tH);if(Bi.isEmptyOrZeroLength(t.username))throw new Error(WF);if(Bi.isEmptyOrZeroLength(t.password)&&Bi.isEmptyOrZeroLength(t.role)&&Bi.isEmptyOrZeroLength(t.active))throw new Error(zF);if(!Bi.isEmpty(t.password)&&Bi.isEmptyOrZeroLength(t.password.trim()))throw new Error(jF);if(!Bi.isEmpty(t.active)&&!Bi.isBoolean(t.active))throw new Error(JF);if(!Bi.isEmpty(t.password)&&!Bi.isEmptyOrZeroLength(t.password.trim())&&(Nne(t.username)&&(t.hash=kI.encrypt(t.password)),t.password=await zm.hash(t.password,BI)),t.role==="")throw new Error(QF);if(t.role){let n=await jm.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),Oo.NOT_FOUND);if(n.length>1)throw new ii($u.DUP_ROLES_FOUND(t.role),Oo.CONFLICT);t.role=n[0].id}let r=await XF.update({operation:"update",schema:"system",table:"hdb_user",records:[t]});return await fl(),FI.signalUserChange(new GI(process.pid)),r}o(Ine,"alterUser");function Nne(e){let t=!1,r=Fi.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}o(Nne,"isClusterUser");async function wne(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),Oo.NOT_FOUND);let r=await Ane({table:"hdb_user",schema:"system",hash_values:[e.username]});return HI.debug(r),await fl(),FI.signalUserChange(new GI(process.pid)),`${e.username} successfully deleted`}o(wne,"dropUser");async function One(e){let t={};if(!e||!e.hdb_user)return"There was no user info in the body";t=xI.cloneDeep(e.hdb_user);let r=await jm.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(One,"userInfo");async function Cne(){let e=await ug();return e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token,delete t.hash_function}),[...e.values()]}o(Cne,"listUsersExternal");async function ug(){let e=await jm.searchByValue({schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]}),t={};for(let s of e)t[s.id]=xI.cloneDeep(s);if(Object.keys(t).length===0)return null;let r=await jm.searchByValue({schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]}),n=new Map;for(let s of r)s=xI.cloneDeep(s),s.role=t[s.role],Pne(s.role),n.set(s.username,s);return n}o(ug,"listUsers");function Pne(e){if(!e){HI.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(Tne)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}o(Pne,"appendSystemTablesToRole");async function fl(e=void 0){e?Fi=e:Fi=await ug()}o(fl,"setUsersWithRolesCache");async function Lne(){return Fi||await fl(),Fi}o(Lne,"getUsersWithRolesCache");async function qI(e,t,r=!0){Fi||await fl();let n=Fi.get(e);if(!n){if(!r)return{username:e};throw new ii(vI.GENERIC_AUTH_FAIL,Oo.UNAUTHORIZED)}if(n&&!n.active)throw new ii(vI.USER_INACTIVE,Oo.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(YF.get(t)===n.password)return s;{let i=zm.validate(n.password,t,n.hash_function||zm.HASH_FUNCTION.MD5);if(i?.then&&(i=await i),i===!0)YF.set(t,n.password);else throw new ii(vI.GENERIC_AUTH_FAIL,Oo.UNAUTHORIZED)}}return s}o(qI,"findAndValidateUser");async function Dne(){Fi||await fl();for(let[,e]of Fi)if(e.role.role==="super_user")return e}o(Dne,"getSuperUser");async function Mne(){let e=await ug(),t=gne.getConfigFromFile(UI.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!(r==null||r?.role?.role!==UI.ROLE_TYPES_ENUM.CLUSTER_USER))return r.decrypt_hash=kI.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(Mne,"getClusterUser");var rH=[];lg.invalidateUser=function(e){for(let t of rH)try{t(e)}catch(r){yne.error("Error invalidating user",r)}};lg.onInvalidatedUser=function(e){rH.push(e)}});var Jm=M((gPe,oH)=>{"use strict";var ml=z(),Xn=(k(),v(K)),vne=KU(),EPe=ei(),_Pe=Pa(),Une=Jn(),{validateEvent:nH}=ti(),Qm=jn(),xne=require("process"),{resetDatabases:Bne}=(Le(),v(ft)),Fne={[Xn.ITC_EVENT_TYPES.SCHEMA]:Hne,[Xn.ITC_EVENT_TYPES.USER]:iH};async function Hne(e){let t=nH(e);if(t){ml.error(t);return}ml.trace("ITC schemaHandler received schema event:",e),await vne(e.message),await kne(e.message)}o(Hne,"schemaHandler");async function kne(e){try{Qm.resetReadTxn(Xn.SYSTEM_SCHEMA_NAME,Xn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),Qm.resetReadTxn(Xn.SYSTEM_SCHEMA_NAME,Xn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),Qm.resetReadTxn(Xn.SYSTEM_SCHEMA_NAME,Xn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=Bne();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){ml.error(t)}}o(kne,"syncSchemaMetadata");var sH=[];async function iH(e){try{try{Qm.resetReadTxn(Xn.SYSTEM_SCHEMA_NAME,Xn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),Qm.resetReadTxn(Xn.SYSTEM_SCHEMA_NAME,Xn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){ml.warn(r)}let t=nH(e);if(t){ml.error(t);return}ml.trace(`ITC userHandler ${Xn.HDB_ITC_CLIENT_PREFIX}${xne.pid} received user event:`,e),await Une.setUsersWithRolesCache();for(let r of sH)r()}catch(t){ml.error(t)}}o(iH,"userHandler");iH.addListener=function(e){sH.push(e)};oH.exports=Fne});var ti=M((bPe,cH)=>{"use strict";var TPe=z(),$I=ie(),Gne=(k(),v(K)),{ITC_ERRORS:Xm}=tn(),{parentPort:RPe,threadId:qne,isMainThread:$ne,workerData:yPe}=require("worker_threads"),{onMessageFromWorkers:Vne,broadcast:APe,broadcastWithAcknowledgement:Kne}=st();cH.exports={sendItcEvent:Yne,validateEvent:aH,SchemaEventMsg:Wne,UserEventMsg:zne};var dg;Vne(async(e,t)=>{dg=dg||Jm(),aH(e),dg[e.type]&&await dg[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function Yne(e){return!$ne&&e.message&&(e.message.originator=qne),Kne(e)}o(Yne,"sendItcEvent");function aH(e){if(typeof e!="object")return Xm.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||$I.isEmpty(e.type))return Xm.MISSING_TYPE;if(!e.hasOwnProperty("message")||$I.isEmpty(e.message))return Xm.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||$I.isEmpty(e.message.originator))return Xm.MISSING_ORIGIN;if(Gne.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return Xm.INVALID_EVENT(e.type)}o(aH,"validateEvent");function Wne(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(Wne,"SchemaEventMsg");function zne(e){this.originator=e}o(zne,"UserEventMsg")});var bo=M((wPe,fH)=>{"use strict";var lH=(k(),v(K)),NPe=ie(),fg=z(),uH=wU(),Vu,{sendItcEvent:dH}=ti();function jne(e){try{fg.info("signalSchemaChange called with message:",e),Vu=Vu||Jm();let t=new uH(lH.ITC_EVENT_TYPES.SCHEMA,e);return Vu.schema(t),dH(t)}catch(t){fg.error(t)}}o(jne,"signalSchemaChange");function Qne(e){try{fg.trace("signalUserChange called with message:",e),Vu=Vu||Jm();let t=new uH(lH.ITC_EVENT_TYPES.USER,e);return Vu.user(t),dH(t)}catch(t){fg.error(t)}}o(Qne,"signalUserChange");fH.exports={signalSchemaChange:jne,signalUserChange:Qne}});function mg(){return VI||(VI=et({table:"hdb_analytics_hostname",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"hostname"}]})),VI}function Xne(e){return e=e.replace(Jne,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 Zne(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 YI(e){let t=mH.default.createHash("shake128",{outputLength:4}),r;return(0,hH.isIPv6)(e)?r=Xne(e):r=e.toLowerCase(),Zne(Uint8Array.from(t.update(r).digest()))}var mH,hH,KI,VI,Jne,WI=fe(()=>{Le();mH=w(require("crypto")),hH=require("node:net"),KI=new Map;o(mg,"getAnalyticsHostnameTable");Jne=/(\d{1,3}\.){3}\d{1,3}$/;o(Xne,"normalizeIPv6");o(Zne,"nodeHashToNumber");o(YI,"stableNodeId")});var Co,zI=fe(()=>{Co={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 gg={};Ce(gg,{addAnalyticsListener:()=>th,calculateCPUUtilization:()=>LH,diffResourceUsage:()=>DH,recordAction:()=>gt,recordActionBinary:()=>Kr,recordHostname:()=>JI,setAnalyticsEnabled:()=>ese});function ese(e){NH=e}function tse(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 rse(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},Eg.set(e,a)}function gt(e,t,r,n,s){if(!NH)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let a=Eg.get(i);a?tse(e,a):rse(i,e,t,r,n,s),pg||nse()}function Kr(e,t,r,n,s){gt(!!e,t,r,n,s)}function th(e){CH.push(e)}function nse(){pg=performance.now(),setTimeout(async()=>{let e=performance.now()-pg;pg=0;let t=[],r={time:Date.now(),period:e,threadId:hl.threadId,metrics:t};for(let[s,i]of Eg){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 PH){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 MH()}let n=process.memoryUsage();t.push({metric:"memory",threadId:hl.threadId,byThread:!0,...n});for(let s of CH)s(t);Eg=new Map,hl.parentPort?hl.parentPort.postMessage({type:OH,report:r}):xH({report:r})},wH).unref()}async function JI(){let e=ve.hostname;Vr.trace?.("recordHostname server.hostname:",e);let t=YI(e);Vr.trace?.("recordHostname nodeId:",t);let r=mg();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=KI.get(r);n?Vr.trace?.("storeMetric cached nodeId:",n):(n=YI(r),Vr.trace?.("storeMetric new nodeId:",n),KI.set(r,n));let s={id:[(0,QI.getNextMonotonicTime)(),n],...t};Vr.trace?.(`storing metric ${JSON.stringify(s)}`),e.put(s.id,s)}function LH(e,t){let r=e.userCPUTime+e.systemCPUTime;return Vr.trace?.(`calculateCPUUtilization cpuTime: ${r} period: ${t}`),Math.round(r/t*100)/100}function DH(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 sse(e,t,r){let n=0;for(let[s,i]of Object.entries(r)){let a=`${t}.${s}`,c=i.getSize(),l={metric:Co.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 pH(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s?.getAuditSize();if(!i)return;let a=IH.statSync(s.primaryStore.env.path).size,c=sse(e,r,n),l=a-c,u={metric:Co.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 EH(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s?.getStorageStats();if(!i)return;let a={metric:Co.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 ise(e,t=6e4){let r=XI(),n=vH(),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 MH()}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 PH){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:Co.MAIN_THREAD_UTILIZATION,idle:h-_H,active:p-gH,taskQueueLatency:await s,time:m,...process.memoryUsage()};Ku(n,R)}_H=h,gH=p;let _=process.resourceUsage();_.time=m,_.userCPUTime=_.userCPUTime/1e3,_.systemCPUTime=_.systemCPUTime/1e3,Vr.trace?.(`process.resourceUsage: ${JSON.stringify(_)}`);let g=DH(hg,_);Vr.trace?.(`diffed resourceUsage: ${JSON.stringify(g)}`),g.time=m,g.period=hg.time?m-hg.time:t,g.cpuUtilization=LH(g,g.period);let y={metric:Co.RESOURCE_USAGE,...g};Ku(n,y),hg=_;let T=it();pH(n,T),pH(n,{system:T.system}),EH(n,T),EH(n,{system:T.system})}async function SH(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function XI(){return TH||(TH=et({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function vH(){return RH||(RH=et({table:"hdb_analytics",database:"system",audit:!0,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function cse(){UH=!0;let e=(0,eh.get)(U.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await ise(wH,e),await SH(XI(),ose),await SH(vH(),ase)},Math.min(e/2,2147483647)).unref()}function xH(e,t){let r=e.report;r.threadId=t?.threadId||hl.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(yH+=n.mean*n.count);r.totalBytesProcessed=yH,t&&(r.metrics.push({metric:Co.UTILIZATION,...t.performance.eventLoopUtilization(AH.get(t))}),AH.set(t,t.performance.eventLoopUtilization())),r.id=(0,QI.getNextMonotonicTime)(),XI().primaryStore.put(r.id,r),UH||cse(),lse&&(BH=dse(r))}async function dse(e){if(await BH,!Ma){let r=(0,Zm.dirname)((0,_g.getLogFilePath)());try{Ma=await(0,jI.open)((0,Zm.join)(r,"analytics.log"),"r+")}catch{Ma=await(0,jI.open)((0,Zm.join)(r,"analytics.log"),"w+")}}let t=(await Ma.stat()).size;if(t>use){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)+`
|
|
14
14
|
`,t)}var hl,bH,_g,Zm,jI,QI,eh,IH,Vr,Eg,NH,pg,wH,OH,CH,PH,_H,gH,hg,MH,ose,ase,TH,RH,UH,yH,AH,lse,BH,Ma,use,Hi=fe(()=>{hl=require("worker_threads"),bH=w(st());Le();_g=w(z()),Zm=require("path"),jI=require("fs/promises"),QI=w(An()),eh=w(ce());k();Pr();IH=w(require("node:fs"));WI();zI();Vr=(0,_g.forComponent)("analytics").conditional;(0,eh.initSync)();Eg=new Map,NH=(0,eh.get)(U.ANALYTICS_AGGREGATEPERIOD)>-1;o(ese,"setAnalyticsEnabled");o(tse,"recordExistingAction");o(rse,"recordNewAction");o(gt,"recordAction");ve.recordAnalytics=gt;o(Kr,"recordActionBinary");pg=0,wH=1e3,OH="analytics-report",CH=[];o(th,"addAnalyticsListener");PH=[.01,.1,.25,.5,.75,.9,.95,.99,.999,1];o(nse,"sendAnalytics");o(JI,"recordHostname");o(Ku,"storeMetric");o(LH,"calculateCPUUtilization");o(DH,"diffResourceUsage");o(sse,"storeTableSizeMetrics");o(pH,"storeDBSizeMetrics");o(EH,"storeVolumeMetrics");o(ise,"aggregation");_H=0,gH=0,hg={userCPUTime:0,systemCPUTime:0},MH=o(()=>new Promise(setImmediate),"rest");o(SH,"cleanup");ose=36e5,ase=31536e6;o(XI,"getRawAnalyticsTable");o(vH,"getAnalyticsTable");(0,bH.setChildListenerByType)(OH,xH);o(cse,"startScheduledTasks");yH=0,AH=new Map,lse=!1;o(xH,"recordAnalytics");use=1e6;o(dse,"logAnalytics")});function rh(e,t,r,n){if(e.append)e.append(t,r,n);else if(e.set){let s=e.get(t);if(s)if(n)r=(typeof s=="string"?s:s.join(", "))+", "+r;else if(typeof s=="string")r=[s,r];else{s.push(r);return}return e.set(t,r)}else e[t]=(e[t]?e[t]+", ":"")+r}function FH(e,t){(typeof e.set!="function"||typeof e.has!="function")&&(e=new Ns(e));for(let[r,n]of t)e.has(r)?r.toLowerCase()==="set-cookie"&&e.append?.(r,n,!0):e.set(r,n);return e}var Ns,nh=fe(()=>{Ns=class extends Map{static{o(this,"Headers")}constructor(t){if(t)if(t[Symbol.iterator])super(t);else{super();for(let r in t)this.set(r,t[r])}else super()}set(t,r){return typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r),super.set(t.toLowerCase(),[t,r])}get(t){return typeof t!="string"&&(t=""+t),super.get(t.toLowerCase())?.[1]}has(t){return typeof t!="string"&&(t=""+t),super.has(t.toLowerCase())}setIfNone(t,r){typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r);let n=t.toLowerCase();if(!super.has(n))return super.set(n,[t,r])}append(t,r,n){typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r);let s=t.toLowerCase(),i=super.get(s);if(i){let a=i[1];if(n)r=(typeof a=="string"?a:a.join(", "))+", "+r;else if(typeof a=="string")r=[a,r];else{a.push(r);return}}return super.set(s,[t,r])}[Symbol.iterator](){return super.values()[Symbol.iterator]()}};o(rh,"appendHeader");o(FH,"mergeHeaders")});var jH={};Ce(jH,{EVICTED:()=>Aa,INVALIDATED:()=>wn,coerceType:()=>Tg,makeTable:()=>yg,setServerUtilities:()=>tN});function yg(e){let{primaryKey:t,indices:r,tableId:n,tableName:s,primaryStore:i,databasePath:a,databaseName:c,auditStore:l,schemaDefined:u,dbisDB:d,sealed:f,splitSegments:m,replicate:h}=e,{expirationMS:p,evictionMS:_,audit:g,trackDeletes:y}=e;_??=0;let{attributes:T}=e;T||(T=[]);let R=BA(i,n,l),I,P,Y={},te=Promise.resolve(),x,$,j;for(let q of T)(q.assignCreatedTime||q.name==="__createdtime__")&&(x=q),(q.assignUpdatedTime||q.name==="__updatedtime__")&&($=q),q.expiresAt&&(j=q),q.isPrimaryKey&&(Y=q);let V,le=[],re=[],se=1,_e=2,Ne={},Fe={},He=864e5,_r=0,pt,gr,wr,ou=!1,au,Ft,Nf,wf=El.get(U.REPLICATION_DATABASES);if(Array.isArray(wf)){for(let q of wf)if(q.name===c&&q.replicateTo>=0){Nf=q.replicateTo;break}}let hE=i.getRange({start:!1,end:!1}).constructor,Ty=10,pE=6;g&&Nc(),am(i.env.path,q=>{if(P)return da(q)});class cu extends sl{static{o(this,"Updatable")}getUpdatedTime(){return Ra.get(this.getRecord())?.version}getExpiresAt(){return Ra.get(this.getRecord())?.expiresAt}addTo(E,S){if(typeof S=="number"||typeof S=="bigint")this.set(E,new Hm(S));else throw new Error("Can not add or subtract a non-numeric value")}subtractFrom(E,S){return this.addTo(E,-S)}}class Me extends Dr{#e;#t;#r;#n;#s;#i;static name=s;static primaryStore=i;static auditStore=l;static primaryKey=t;static tableName=s;static tableId=n;static indices=r;static audit=g;static databasePath=a;static databaseName=c;static attributes=T;static replicate=h;static sealed=f;static splitSegments=m??!0;static createdTimeProperty=x;static updatedTimeProperty=$;static propertyResolvers;static userResolvers={};static sources=[];static getResidencyById;static get expirationMS(){return p}static dbisDB=d;static schemaDefined=u;static sourcedFrom(E,S){if(S&&(this.sourceOptions=S,(S.expiration||S.eviction||S.scanInterval)&&this.setTTLExpiration(S)),S?.intermediateSource)E.intermediateSource=!0,this.sources.unshift(E);else{if(this.sources.some(O=>!O.intermediateSource)){if(this.sources.some(O=>O.name===E.name))return;throw new Error("Can not have multiple canonical (non-intermediate) sources")}this.sources.push(E)}P=P||E.get&&(!E.get.reliesOnPrototype||E.prototype.get),I=I||E.load;let A=o(O=>{let D=this.sources;if(D=D.filter(F=>F.intermediateSource&&F[O]&&(!F[O].reliesOnPrototype||F.prototype[O])),D.length>0)if(D.length===1){let F=D[0];return(L,H,W)=>{if(L?.source!==F)return F[O](H,W,L)}}else return(F,L,H)=>{let W=[];for(let ee of D){if(F?.source===ee)break;W.push(ee[O](L,H,F))}return Promise.all(W)}},"getApplyToIntermediateSource"),N=this.sources[this.sources.length-1];N.intermediateSource&&(N={});let b=o(O=>{if(N[O]&&(!N[O].reliesOnPrototype||N.prototype[O]))return(D,F,L)=>{if(!D?.source)return N[O](F,L,D)}},"getApplyToCanonicalSource");Ne={put:b("put"),patch:b("patch"),delete:b("delete"),publish:b("publish")},Fe={put:A("put"),patch:A("patch"),delete:A("delete"),publish:A("publish"),invalidate:A("invalidate")};let C=N.shouldRevalidateEvents;return(async()=>{let O=!1,D,F=o(async(L,H)=>{let W=L.value,ee=L.table?Ge[c][L.table]:Me;if(c===vf&&(L.table===uu.ROLE_TABLE_NAME||L.table===uu.USER_TABLE_NAME)&&(O=!0),L.id===void 0&&(L.id=W[ee.primaryKey],L.id===void 0))throw new Error("Replication message without an id "+JSON.stringify(L));L.source=E;let oe={residencyId:fa(L.residencyList),isNotification:!0,ensureLoaded:!1,nodeId:L.nodeId},B=L.id,ue=await ee.getResource(B,H,oe);switch(L.finished&&await L.finished,L.type){case"put":return C?ue._writeInvalidate(B,W,oe):ue._writeUpdate(B,W,!0,oe);case"patch":return C?ue._writeInvalidate(B,W,oe):ue._writeUpdate(B,W,!1,oe);case"delete":return ue._writeDelete(B,oe);case"publish":case"message":return ue._writePublish(B,W,oe);case"invalidate":return ue._writeInvalidate(B,W,oe);case"relocate":return ue._writeRelocate(B,oe);default:xe.default.error?.("Unknown operation",L.type,L.id)}},"writeUpdate");try{let L=E.subscribe;L&&y==null&&(y=!0);let H={crossThreads:!1,inTransactionUpdates:!0,supportsTransactions:!0,omitCurrent:!0},W=E.subscribeOnThisThread?E.subscribeOnThisThread((0,pl.getWorkerIndex)(),H):(0,pl.getWorkerIndex)()===0,ee=L&&W&&await E.subscribe?.(H);if(ee){let oe;for await(let B of ee)try{if(!(B.type==="transaction"?B.writes[0]:B)){xe.default.error?.("Bad subscription event",B);continue}if(B.source=E,B.type==="end_txn"){if(oe?.resolve(),B.localTime&&D!==B.localTime){if(B.remoteNodeIds?.length>0){let ge=[Symbol.for("seq"),B.remoteNodeIds[0]],X=d.get(ge),de=X?.nodes;de||(de=[]);for(let he of B.remoteNodeIds.slice(1)){let Ae=de.find(Oe=>Oe.id===he);de=de.filter(Oe=>Oe.id!==he||Oe===Ae),Ae||(Ae={id:he,seqId:0},de.push(Ae)),Ae.seqId=Math.max(X?.seqId??1,B.localTime),he===oe?.nodeId&&(Ae.lastTxnTime=B.timestamp)}let ne=Math.max(X?.seqId??1,B.localTime);xe.default.trace?.("Received txn",c,new Date(ne),new Date(B.localTime),B.remoteNodeIds),d.put(ge,{seqId:ne,nodes:de})}D=B.localTime}B.onCommit&&oe?.committed.then(B.onCommit);continue}if(oe)if(B.beginTxn)oe.resolve();else{oe.write_promises.push(F(B,oe));continue}!B.timestamp&&B.version&&(B.timestamp=B.version);let ae=vt(B,()=>{if(B.type==="transaction"){let ge=[];for(let X of B.writes)try{ge.push(F(X,B))}catch(de){throw de.message+=" writing "+JSON.stringify(X)+" of event "+JSON.stringify(B),de}return Promise.all(ge)}else if(B.type==="define_schema"){let ge=this.attributes.slice(0),X=!1;for(let de of B.attributes)ge.find(ne=>ne.name===de.name)||(ge.push(de),X=!0);X&&(et({table:s,database:c,attributes:ge,origin:"cluster"}),ih.signalSchemaChange(new oh.SchemaEventMsg(process.pid,G.CREATE_TABLE,c,s)))}else return B.beginTxn?(oe=B,oe.write_promises=[F(B,B)],new Promise(ge=>{oe.resolve=()=>ge(Promise.all(oe.write_promises))})):F(B,B)});oe&&(oe.committed=ae),O&&ae&&!ae?.waitingForUserChange&&(ae.then(()=>ih.signalUserChange(new oh.UserEventMsg(process.pid))),ae.waitingForUserChange=!0),B.onCommit&&(ae?ae.then(B.onCommit):B.onCommit())}catch(ue){xe.default.error?.("error in subscription handler",ue)}}}catch(L){xe.default.error?.(L)}})(),this}static get isCaching(){return P}static get shouldRevalidateEvents(){return this.prototype.get!==Me.prototype.get}static getResource(E,S,A){let N=super.getResource(E,S,A);if(E!=null&&this.loadAsInstance!==!1){Or(E);try{if(N.getRecord?.())return N;if(typeof E=="object"&&E&&!Array.isArray(E))throw new Error(`Invalid id ${JSON.stringify(E)}`);let b=!A?.async||i.cache?.get?.(E),C=Cr(S),O=C.getReadTxn();if(O?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");return Tc(E,S,{transaction:O,ensureLoaded:A?.ensureLoaded},b,D=>{if(D?Me._updateResource(N,D):N.#e=null,S.onlyIfCached){if(!N.doesExist())throw new lt.ServerError("Entry is not cached",504)}else if(A?.ensureLoaded){let F=yc(E,D,S,N);if(F)return C?.disregardReadTxn(),N.#i=!0,S.loadedFromSource=!0,oi(F,L=>(Me._updateResource(N,L),N))}return N})}catch(b){throw b.message.includes("Unable to serialize object")&&(b.message+=": "+JSON.stringify(E)),b}}return N}static _updateResource(E,S){E.#n=S,E.#e=S?.value??null,E.#r=S?.version}ensureLoaded(){let E=yc(this.getId(),this.#n,this.getContext());if(E)return this.#i=!0,this.getContext().loadedFromSource=!0,oi(E,S=>{this.#n=S,this.#e=S.value,this.#r=S.version})}static getNewId(){let E=Y?.type;if(E==="String"||E==="ID")return super.getNewId();if(!Ft){let b=i.getEntry(Symbol.for("id_allocation")),C=b?.value,O;if(C&&C.nodeName===server.hostname&&(!yse(i)||C.pid===process.pid)){let D=C.start,F=C.end;O=D;for(let L of i.getKeys({start:F,end:D,limit:1,reverse:!0}))O=L}else C=N(b?.version??null),O=C.start;Ft=new BigInt64Array([BigInt(O)+1n]),Ft=new BigInt64Array(i.getUserSharedBuffer("id",Ft.buffer)),Ft.maxSafeId=C.end}let S=Number(Atomics.add(Ft,0,1n)),A=E==="Int"?512:1048576;if(S+A>=Ft.maxSafeId){let b=o(C=>{Ft.maxSafeId=S+(E==="Int"?1023:4194303);let O=(E==="Int"?Math.pow(2,31):Math.pow(2,49))-1,D=C?void 0:i.useReadTransaction(),F=Number(Ft[0]);for(let W of i.getKeys({start:F+1,end:O,limit:1,transaction:D}))O=W;D?.done();let{value:L,version:H}=i.getEntry(Symbol.for("id_allocation"));if(Ft.maxSafeId<O){if(L.end>Ft.maxSafeId-100)return;xe.default.info?.("New id allocation",S,Ft.maxSafeId,H),i.put(Symbol.for("id_allocation"),{start:L.start,end:Ft.maxSafeId,nodeName:server.hostname,pid:process.pid},Date.now(),H)}else{xe.default.warn?.(`Id conflict detected, starting new id allocation range, attempting to allocate to ${Ft.maxSafeId}, but id of ${O} detected`);let W=N(H);W.alreadyUpdated||Atomics.store(Ft,0,BigInt(W.start+1)),Ft.maxSafeId=W.end}},"updateEnd");S+A===Ft.maxSafeId?setImmediate(b):S+100>=Ft.maxSafeId&&(xe.default.warn?.(`Synchronous id allocation required on table ${s}${E=="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`),i.transactionSync(()=>b(!0)))}return S;function N(b){let C=(E==="Int"?Math.pow(2,31):Math.pow(2,49))-1,O=C/4,D,F,L=!1,H,W;do{H=Math.floor(Math.random()*C),W={start:H,end:H+(E==="Int"?1024:4194304),nodeName:server.hostname,pid:process.pid},D=0;for(let ee of i.getKeys({start:H,limit:1,reverse:!0}))D=ee;F=C;for(let ee of i.getKeys({start:H+1,end:C,limit:1}))F=ee;O*=.875,O<1e3&&!L&&(L=!0,xe.default.error?.(`Id allocation in table ${s} is very dense, limited safe range of numbers to allocate ids in${E==="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`,H,D,F,O))}while(!(O<F-H&&(O<H-D||D===0)));return i.transactionSync(()=>{let ee=i.getEntry(Symbol.for("id_allocation"));return(ee?.version??null)==b?(xe.default.info?.("Allocated new id range",W),i.put(Symbol.for("id_allocation"),W,Date.now()),W):(xe.default.debug?.("Looks like ids were already allocated"),{alreadyUpdated:!0,...ee.value})})}}static setTTLExpiration(E){if(typeof E=="number")p=E*1e3,_||(_=0);else if(E&&typeof E=="object")p=E.expiration*1e3,_=(E.eviction||0)*1e3,He=E.scanInterval*1e3;else throw new Error("Invalid expiration value type");if(p<0)throw new Error("Expiration can not be negative");He=He||(p+_)/4,da()}static getResidencyRecord(E){return d.get([Symbol.for("residency_by_id"),E])}static setResidency(E){Me.getResidency=E&&((S,A)=>{try{return E(S,A)}catch(N){throw N.message+=` in residency function for table ${s}`,N}})}static setResidencyById(E){Me.getResidencyById=E&&(S=>{try{return E(S)}catch(A){throw A.message+=` in residency function for table ${s}`,A}})}static getResidency(E,S){if(Me.getResidencyById)return Me.getResidencyById(E[t]);let A=Nf;if(S.replicateTo!=null){if(Array.isArray(S.replicateTo))return S.replicateTo.includes(server.hostname)?S.replicateTo:[server.hostname,...S.replicateTo];S.replicateTo>=0&&(A=S.replicateTo)}if(A>=0&&server.nodes){let N=[server.hostname];if(S.previousResidency)N.push(...S.previousResidency.slice(0,A));else{let b=server.nodes.map(D=>D.name),C=Math.floor(b.length*Math.random());N.push(...b.slice(C,C+A));let O=C+A-b.length;O>0&&N.push(...b.slice(0,O))}return N}}static enableAuditing(E=!0){g=E,E&&Nc(),Me.audit=E}static coerceId(E){return E===""?null:Tg(E,Y)}static async dropTable(){delete Ge[c][s];for(let E of i.getRange({versions:!0,snapshot:!1,lazy:!0}))E.metadataFlags&Nn&&E.value&&Sa(E.value);if(c===a){for(let E of T)d.remove(Me.tableName+"/"+E.name),r[E.name]?.drop();d.remove(Me.tableName+"/"),i.drop(),await d.committed}else console.log("legacy dropTable"),await i.close(),eN.default.unlinkSync(i.env.path);ih.signalSchemaChange(new oh.SchemaEventMsg(process.pid,G.DROP_TABLE,c,s))}get(E){let S=this.constructor;if(typeof E=="string"&&S.loadAsInstance!==!1)return this.getProperty(E);if(Cf(E))return this.search(E);if(E&&E.id===void 0&&!E.toString()){let A={records:"./",name:s,database:c,auditSize:l?.getStats().entryCount,attributes:T,recordCount:void 0,estimatedRecordRange:void 0};return this.getContext()?.includeExpensiveRecordCountEstimates?Me.getRecordCount().then(N=>(A.recordCount=N.recordCount,A.estimatedRecordRange=N.estimatedRange,A)):A}if(E!==void 0&&S.loadAsInstance===!1){let A=this.getContext(),N=Cr(A),b=N.getReadTxn();if(b?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");let C=Sr(E);Or(C);let O=!0;return E.checkPermission&&(O=this.allowRead(A.user,E)),oi(O,D=>{if(!D)throw new lt.AccessViolation(A.user);let F=!0;return Tc(C,A,{transaction:b,ensureLoaded:F},!1,L=>{if(A.onlyIfCached){if(!L?.value)throw new lt.ServerError("Entry is not cached",504)}else if(F){let H=yc(C,L,A);if(H)return N?.disregardReadTxn(),A.loadedFromSource=!0,H.then(W=>W?.value)}return L?.value})})}if(E?.property)return this.getProperty(E.property);if(this.doesExist()||E?.ensureLoaded===!1||this.getContext()?.returnNonexistent)return this}allowRead(E,S){let A=Rc(E,S);if(A?.read){if(A.isSuperUser)return!0;let N=A.attribute_permissions,b=S?.select;if(N?.length>0||ou&&b){if(S||(S={}),b){let C=N?.length>0&&ZI(N,"read");S.select=b.map(O=>{let D=O.name||O;if(!C||C[D]){let F=wr[D]?.definition?.tableClass;if(F){if(O.name||(O={name:O}),!O.checkPermission&&S.checkPermission&&(O.checkPermission=S.checkPermission),!F.prototype.allowRead.call(null,E,O))return!1;if(!O.select)return O.name}return O}}).filter(Boolean)}else S.select=N.filter(C=>C.read&&!wr[C.attribute_name]).map(C=>C.attribute_name);return S}else return!0}}allowUpdate(E,S,A){let N=Rc(E,A);if(N?.update){let b=N.attribute_permissions;if(b?.length>0){let C=ZI(b,"update");for(let O in S)if(!C[O])return!1;for(let O of b){let D=O.attribute_name;!O.update&&!(D in S)&&(S[D]=this.getProperty(D))}}return Ic(this.getContext())}}allowCreate(E,S,A){if(this.isCollection){let N=Rc(E,A);if(N?.insert){let b=N.attribute_permissions;if(b?.length>0){let C=ZI(b,"insert");for(let O in S)if(!C[O])return!1;return Ic(this.getContext())}else return Ic(this.getContext())}}else return this.allowUpdate(E,{})}allowDelete(E,S){return Rc(E,S)?.delete&&Ic(this.getContext())}update(E,S){let A,N=typeof S=="boolean"||S===void 0&&(E==null||typeof E=="object"&&!(E instanceof URLSearchParams)),b=!1;N?(b=S,S=E,A=this.getId()):A=Sr(E);let C=this.getContext();if(!Cr(C))throw new Error("Can not update a table resource outside of a transaction");if(S===!1)return this;if(typeof S=="object"&&S)if(b)Object.isFrozen(S)&&(S={...S}),this.#e={},this.#t=S;else if(N){let D=this.#t;D&&(S=Object.assign(D,S)),this.#t=S}else{let D=!0;if(E==null)throw new TypeError("Can not put a record without a target");return E.checkPermission&&(D=this.allowUpdate(C.user,S,E)),oi(D,F=>{if(!F)throw new lt.AccessViolation(C.user);return oi(i.get(Sr(E)),L=>{let H=new cu(L);return H._setChanges(S),this._writeUpdate(A,H.getChanges(),!1),H})})}return this._writeUpdate(A,this.#t,b),this}addTo(E,S){if(typeof S=="number"||typeof S=="bigint")this.#s===kH?this.set(E,(+this.getProperty(E)||0)+S):(this.#s||this.update(),this.set(E,new Hm(S)));else throw new Error("Can not add a non-numeric value")}subtractFrom(E,S){if(typeof S=="number")return this.addTo(E,-S);throw new Error("Can not subtract a non-numeric value")}getMetadata(){return this.#n}getRecord(){return this.#e}getChanges(){return this.#t}_setChanges(E){this.#t=E}setRecord(E){this.#e=E}invalidate(E){let S=!0,A=this.getContext();return E?.checkPermission&&(S=this.allowDelete(A.user,E,A)),oi(S,N=>{if(!N)throw new lt.AccessViolation(A.user);this._writeInvalidate(E?Sr(E):this.getId())})}_writeInvalidate(E,S,A){let N=this.getContext();Or(E),Cr(this.getContext()).addWrite({key:E,store:i,invalidated:!0,entry:this.#n,before:Ne.invalidate?.bind(this,N,E),beforeIntermediate:Fe.invalidate?.bind(this,N,E),commit:o((C,O)=>{if(!(bc(C,O,A?.nodeId)<=0)){S??=null;for(let D in r)S||(S={}),S[D]===void 0&&(S[D]=this.getProperty(D));xe.default.trace?.(`Invalidating entry in ${s} id: ${E}, timestamp: ${new Date(C).toISOString()}`),R(E,S,O,C,wn,g,{user:N?.user,residencyId:A?.residencyId,nodeId:A?.nodeId},"invalidate")}},"commit")})}_writeRelocate(E,S){let A=this.getContext();Or(E),Cr(this.getContext()).addWrite({key:E,store:i,invalidated:!0,entry:this.#n,before:Ne.relocate?.bind(this,A,E),beforeIntermediate:Fe.relocate?.bind(this,A,E),commit:o((b,C)=>{if(bc(b,C,S?.nodeId)<=0)return;let O=Me.getResidencyRecord(S.residencyId),D=0,F=null,L=C?.value;if(O&&!O.includes(server.hostname)){for(let H in r)F||(F={}),F[H]=L(H);D=wn}else F=L;xe.default.trace?.(`Relocating entry id: ${E}, timestamp: ${new Date(b).toISOString()}`),R(E,F,C,b,D,g,{user:A.user,residencyId:S.residencyId,nodeId:S.nodeId,expiresAt:S.expiresAt},"relocate",!1,null)},"commit")})}static _recordRelocate(E,S){let A={previousResidency:this.getResidencyRecord(E.residencyId),isRelocation:!0},N=wc(this.getResidency(S.value,A)),b;if(N){if(!N.includes(server.hostname))return!1;b=fa(N)}let O=R(E.key,S.value,E,E.version,0,!0,{residencyId:b,expiresAt:S.expiresAt},"relocate",!1,null);return!0}static evict(E,S,A){let N=this.Source,b;if(!((P||g)&&(!S||(b=i.getEntry(E),!b||!S)||b.version!==A))){if(P){if(i.hasLock(E,b.version))return;let C;for(let O in r)C||(C={}),C[O]=S[O];if(C)return R(E,C,b,A,Aa,null,null,null,!0)}if(i.ifVersion(E,A,()=>{oo(E,S,null)}),g)return R(E,null,b,A,Aa,null,null,null,!0);zc(i,b??i.getEntry(E),A)}}lock(){throw new Error("Not yet implemented")}static operation(E,S){return E.table||=s,E.schema||=c,zH.operation(E,S)}put(E,S){if(S===void 0||S instanceof URLSearchParams)this.update(E,!0);else{let A=!0;if(E==null)throw new TypeError("Can not put a record without a target");let N=this.getContext();return E.checkPermission&&(A=this.allowUpdate(N.user,S,E)),oi(A,b=>{if(!b)throw new lt.AccessViolation(N.user);if(Array.isArray(S))for(let C of S){let O=C[t];this._writeUpdate(O,C,!0)}else{let C=Sr(E);this._writeUpdate(C,S,!0)}})}}create(E,S){let A=!0,N=this.getContext();if(!S&&!(E instanceof URLSearchParams)&&(S=E,E=void 0),!S||typeof S!="object"||Array.isArray(S))throw new TypeError("Can not create a record without an object");return E?.checkPermission&&(A=this.allowCreate(N.user,S,E)),oi(A,b=>{if(!b)throw new lt.AccessViolation(N.user);let C=Sr(E)??S[t];if(C===void 0)C=this.constructor.getNewId();else if(i.get(C))throw new lt.ClientError("Record already exists",409);return this._writeUpdate(C,S,!0),S})}patch(E,S){if(S===void 0||S instanceof URLSearchParams)this.update(E,!1);else{let A=this.update(E,S);if(A?.then)return A.then(()=>{})}}_writeUpdate(E,S,A,N){let b=this.getContext(),C=Cr(b);Or(E);let O=this.#n??i.getEntry(E);this.#s=A?kH:gse;let D={key:E,store:i,entry:O,nodeName:b?.nodeName,validate:o(F=>{S||(S=this.#t),A||S&&Y_(this.#t===S?this:S)?b?.source||(C.checkOverloaded(),this.validate(S,!A),$&&(S[$.name]=$.type==="Date"?new Date(F):$.type==="String"?new Date(F).toISOString():F),A&&(t&&S[t]!==E&&(S[t]=E),x&&(O?.value?S[x.name]=O?.value[x.name]:S[x.name]=x.type==="Date"?new Date(F):x.type==="String"?new Date(F).toISOString():F),S=Ca(S))):C.removeWrite(D)},"validate"),before:A?Ne.put?()=>Ne.put(b,E,S):null:Ne.patch?()=>Ne.patch(b,E,S):Ne.put?()=>Ne.put(b,E,Ca(this)):null,beforeIntermediate:A?Fe.put?()=>Fe.put(b,E,S):null:Fe.patch?()=>Fe.patch(b,E,S):Fe.put?()=>Fe.put(b,E,Ca(this)):null,commit:o((F,L,H)=>{if(H){if(b&&L?.version>(b.lastModified||0)&&(b.lastModified=L.version),this.#n=L,L?.value&&L.value.getRecord)throw new Error("Can not assign a record to a record, check for circular references");A||(this.#e=L?.value??null)}this.#t=void 0,this.#r=F;let W=L?.value,ee=S;this.#s=0;let oe=!1,B=bc(F,L,N?.nodeId),ue;if(B<=0){if(g){let ne=L.localTime,he=L.version;xe.default.trace?.("Applying CRDT update to record with id: ",E,"txn time",new Date(F),"applying later update from:",new Date(he),"local recorded time",new Date(ne));let Ae=[];for(;ne>F||he>=F&&ne>0;){let Oe=l.get(ne);if(!Oe)break;let ze=Ut(Oe);if(he=ze.version,he>=F){if(he===F){if(B=bc(F,{version:he,localTime:ne},N?.nodeId),B===0)return;if(B>0)continue}if(ze.type==="patch")Ae.push(ze),ue=S;else if(ze.type==="put"||ze.type==="delete")return}ne=ze.previousLocalTime}if(!ne){xe.default.debug?.("No further audit history, must drop update",E,"existing version preserved",L);return}Ae.sort((Oe,ze)=>Oe.version-ze.version);for(let Oe of Ae){let ze=Oe.getValue(i);if(xe.default.debug?.("Rebuilding update with future patch:",new Date(Oe.version),ze,Oe),ee=GE(ee,ze,A),!ee)return}}else{if(A)return;ee=GE(ee,W,A),xe.default.debug?.("Rebuilding update without audit:",ee)}xe.default.trace?.("Rebuilt record to save:",ee," is full update:",A)}let ae;if(A?ae=ee:this.constructor.loadAsInstance===!1?ae=Ca(W,ee):(this.#e=W,ae=Ca(this,ee)),this.#e=ae,ae&&ae.getRecord)throw new Error("Can not assign a record to a record, check for circular references");let ge;if(N?.residencyId!=null)ge=N.residencyId;else{O?.residencyId&&(b.previousResidency=Me.getResidencyRecord(O.residencyId));let ne=wc(Me.getResidency(ae,b));if(ne&&!ne.includes(server.hostname))if(ue??=ae,oe=!0,Me.getResidencyById)ae=void 0;else{ae=null;for(let he in r)ae||(ae={}),ae[he]=ue[he]}ge=fa(ne)}A||(ue=S);let X=b?.expiresAt??(p?p+Date.now():-1);xe.default.trace?.(`Saving record with id: ${E}, timestamp: ${new Date(F).toISOString()}${X?", expires at: "+new Date(X).toISOString():""}${L?", replaces entry from: "+new Date(L.version).toISOString():", new entry"}`,(()=>{try{return JSON.stringify(ae).slice(0,100)}catch{return""}})()),oo(E,W,ae);let de=A?"put":"patch";R(E,ae,L,F,oe?wn:0,g,{omitLocalRecord:oe,user:b?.user,residencyId:ge,expiresAt:X,nodeId:N?.nodeId,originatingOperation:b?.originatingOperation},de,!1,ue),b.expiresAt&&da()},"commit")};C.addWrite(D)}async delete(E){if(Cf(E)){E.select=["$id"];for await(let S of this.search(E))this._writeDelete(S.$id);return!0}if(E){let S=!0,A=this.getContext();return E.checkPermission&&(S=this.allowDelete(A.user,E,A)),oi(S,N=>{if(!N)throw new lt.AccessViolation(A.user);let b=Sr(E);return this._writeDelete(b),!0})}return this._writeDelete(this.getId()),!!this.#e}_writeDelete(E,S){let A=Cr(this.getContext());Or(E);let N=this.getContext();return A.addWrite({key:E,store:i,entry:this.#n,nodeName:N?.nodeName,before:Ne.delete?.bind(this,N,E),beforeIntermediate:Fe.delete?.bind(this,N,E),commit:o((b,C,O)=>{let D=C?.value;O&&(N&&C?.version>(N.lastModified||0)&&(N.lastModified=C.version),Me._updateResource(this,C)),!(bc(b,C,S?.nodeId)<=0)&&(oo(this.getId(),D),xe.default.trace?.(`Deleting record with id: ${E}, txn timestamp: ${new Date(b).toISOString()}`),g||y?(R(E,null,C,b,0,g,{user:N?.user,nodeId:S?.nodeId},"delete"),g||da()):zc(i,C))},"commit")}),!0}search(E){let S=this.getContext(),A=Cr(S);if(!E)throw new Error("No query provided");if(E.parseError)throw E.parseError;if(E.checkPermission&&!this.allowRead(S.user,E))throw new lt.AccessViolation(S.user);let N=E.conditions;N?N.length===void 0&&(N=N[Symbol.iterator]?Array.from(N):[N]):N=Array.isArray(E)?E:E[Symbol.iterator]?Array.from(E):[];let b=E.id??this.getId();b&&(N=[{attribute:null,comparator:Array.isArray(b)?"prefix":"starts_with",value:b}].concat(N));let C,O={};function D(ne,he){let Ae;switch(he){case"and":case void 0:if(ne.length<1)throw new Error('An "and" operator requires at least one condition');Ae=!0;break;case"or":if(ne.length<2)throw new Error('An "or" operator requires at least two conditions');break;default:throw new Error("Invalid operator "+he)}for(let Oe of ne){if(Oe.conditions){Oe.conditions=D(Oe.conditions,Oe.operator);continue}let ze=Oe[0]??Oe.attribute,kr=ze==null?Y:Ci(T,ze);if(kr)(kr.type||HA[Oe.comparator])&&(Oe[1]===void 0?Oe.value=L(Oe.value,kr):Oe[1]=L(Oe[1],kr));else if(ze!=null)throw(0,lt.handleHDBError)(new Error,`${ze} is not a defined attribute`,404);if(Oe.chainedConditions)if(Oe.chainedConditions.length===1&&(!Oe.operator||Oe.operator=="and")){let ye=Oe.chainedConditions[0],We,Xe;if(ye.comparator==="gt"||ye.comparator==="greater_than"||ye.comparator==="ge"||ye.comparator==="greater_than_equal"?(We=Oe,Xe=ye):(We=ye,Xe=Oe),We.comparator!=="lt"&&We.comparator!=="less_than"&&We.comparator!=="le"&&We.comparator!=="less_than_equal")throw new Error("Invalid chained condition, only less than and greater than conditions can be chained together");let jt=Xe.comparator==="ge"||Xe.comparator==="greater_than_equal",Dt=We.comparator==="le"||We.comparator==="less_than_equal";Oe.comparator=(jt?"ge":"gt")+(Dt?"le":"lt"),Oe.value=[Xe.value,We.value]}else throw new Error("Multiple chained conditions are not currently supported")}return ne}o(D,"prepareConditions");function F(ne,he){if(E.enforceExecutionOrder)return ne;for(let Ae of ne)Ae.conditions&&(Ae.conditions=F(Ae.conditions,Ae.operator));return ne.length>1&&he!=="or"?fse(ne,S_(Me)):ne}o(F,"orderConditions");function L(ne,he){return Array.isArray(ne)?ne.map(Ae=>Tg(Ae,he)):Tg(ne,he)}o(L,"coerceTypedValues");let H=E.operator;(N.length>0||H)&&(N=D(N,H));let W=typeof E.sort=="object"&&E.sort,ee;if(W&&H!=="or"){let ne=W.attribute;if(ne==null)throw new lt.ClientError("Sort requires an attribute");if(C=N.find(he=>Nu(he.attribute)===Nu(ne)),!C){let he=Ci(T,ne);if(!he)throw(0,lt.handleHDBError)(new Error,`${Array.isArray(ne)?ne.join("."):ne} is not a defined attribute`,404);if(he.indexed)C={...W,comparator:"sort"},N.push(C);else if(N.length===0&&!E.allowFullScan)throw(0,lt.handleHDBError)(new Error,`${Array.isArray(ne)?ne.join("."):ne} is not indexed and not combined with any other conditions`,404)}C&&(C.descending=!!W.descending)}N=F(N,H),W&&(C&&N[0]===C?W.next&&(ee={dbOrderedAttribute:W.attribute,attribute:W.next.attribute,descending:W.next.descending,next:W.next.next}):(C&&N.splice(N.indexOf(C),1),ee=W));let oe=E.select;if(N.length===0&&(N=[{attribute:t,comparator:"greater_than",value:!0}]),E.explain)return{conditions:N,operator:H,postOrdering:ee,selectApplied:!!oe};let B=A.useReadTxn(),ue=kA(N,H,Me,B,E,S,(ne,he)=>Pf(ne,oe,S,B,he),O),ae=E.ensureLoaded!==!1;ee||(ue=de(ue));let ge=Me.transformEntryForSelect(oe,S,B,O,ae,!0),X=Me.transformToOrderedSelect(ue,oe,ee,S,B,ge);function de(ne){return E.offset||E.limit!==void 0?ne.slice(E.offset,E.limit!==void 0?(E.offset||0)+E.limit:void 0):ne}return o(de,"applyOffset"),ee&&(X=de(X)),X.onDone=()=>{X.onDone=null,A.doneReadTxn()},X.selectApplied=!0,X.getColumns=()=>{if(oe){let ne=[];for(let he of oe)he==="*"?ne.push(...T.map(Ae=>Ae.name)):ne.push(he.name||he);return ne}return T.filter(ne=>!ne.computed&&!ne.relationship).map(ne=>ne.name)},X}static transformToOrderedSelect(E,S,A,N,b,C){let O=new hE;if(A){E=Pf(E,S,N,b,null);let D;O.iterate=function(){let L,H=E[Symbol.asyncIterator]?E[Symbol.asyncIterator]():E[Symbol.iterator](),W,ee=A.dbOrderedAttribute,oe,B,ue=!0;function ae(X){let de=X.next&&ae(X.next),ne=X.descending;return N.sort=X,(he,Ae)=>{let Oe=Ac(he,X.attribute,N),ze=Ac(Ae,X.attribute,N),kr=ne?(0,_l.compareKeys)(ze,Oe):(0,_l.compareKeys)(Oe,ze);return kr===0?de?.(he,Ae)||0:kr}}o(ae,"createComparator");let ge=ae(A);return{async next(){let X;if(L)if(X=L.next(),X.done){if(W)return O.onDone&&O.onDone(),X}else return{value:await C.call(this,X.value)};D=[],oe&&D.push(oe);do if(X=await H.next(),X.done){if(W=!0,D.length)break;return O.onDone&&O.onDone(),X}else{let de=X.value;if(de?.then&&(de=await de),ee){let ne=Ac(de,ee,N);if(ue)ue=!1,B=ne;else if(ne!==B){B=ne,oe=de;break}}D.push(de)}while(!0);return A.isGrouped,D.sort(ge),L=D[Symbol.iterator](),X=L.next(),X.done?(O.onDone&&O.onDone(),X):{value:await C.call(this,X.value)}},return(){O.onDone&&O.onDone(),H.return()},throw(){O.onDone&&O.onDone(),H.throw()}}};let F=o(L=>{if(typeof S=="object"&&Array.isArray(L.attribute))for(let H=0;H<S.length;H++){let W=S[H],ee;if(W.name===L.attribute[0]){for(ee=W.sort||(W.sort={});ee.next;)ee=ee.next;ee.attribute=L.attribute.slice(1),ee.descending=L.descending}else W===L.attribute[0]&&(S[H]=ee={name:W,sort:{attribute:L.attribute.slice(1),descending:L.descending}})}L.next&&F(L.next)},"applySortingOnSelect");F(A)}else O.iterate=(E[Symbol.asyncIterator]||E[Symbol.iterator]).bind(E),O=O.map(function(D){try{let F=C.call(this,D);return typeof F?.catch=="function"?F.catch(L=>{throw L.partialObject={[t]:D.key},L}):F}catch(F){throw F.partialObject={[t]:D.key},F}});return O}static transformEntryForSelect(E,S,A,N,b,C){let O;b&&P&&!(typeof E=="string"?[E]:E)?.every(L=>{let H;return typeof L=="object"?H=L.name:H=L,r[H]||H===t})&&(O=!0);let D,F=o(function(L){let H;if(S?.transaction?.stale&&(S.transaction.stale=!1),L!=null){if(H=L.deref?L.deref():L.value,!H&&(L.key===void 0||L.deref)||L.metadataFlags&wn){if(L.metadataFlags&wn&&S.replicateFrom===!1&&C&&L.residencyId)return Ua.SKIP;if(L=Tc(L.key??L,S,{transaction:A,lazy:E?.length<4,ensureLoaded:b},this?.isSync,W=>W),L?.then)return L.then(F.bind(this));H=L?.value}if(O&&L?.metadataFlags&(wn|Aa)||L?.expiresAt!=null&&L?.expiresAt<Date.now()){if(S.onlyIfCached)return{[t]:L.key,message:"This entry has expired"};let W=yc(L.key??L,L,S);if(W?.then)return W.then(F)}}if(H==null)return C?Ua.SKIP:H;if(E&&!(E[0]==="*"&&E.length===1)){let W,ee=o((B,ue)=>{let ae;typeof B=="object"?ae=B.name:ae=B;let ge=wr?.[ae],X;if(ge){let de=N?.[ae];if(de)if(de.hasMappings){let he=ge.from?H[ge.from]:Nu(L.key);X=de.get(he),X||(X=[])}else X=de.fromRecord?.(H);else X=ge(H,S,L,!0);let ne=o(he=>{if(ge.directReturn)return ue(he,ae);if(he&&typeof he=="object"){let Ae=ge.definition?.tableClass||Me;D||(D={});let Oe=D[ae]||(D[ae]=Ae.transformEntryForSelect(ae===B?null:B.select||(Array.isArray(B)?B:null),S,A,de,b));if(Array.isArray(he)){let ze=[],kr=Ae.transformToOrderedSelect(he,B.select,typeof B.sort=="object"&&B.sort,S,A,Oe)[this.isSync?Symbol.iterator:Symbol.asyncIterator](),ye=o(Xe=>{for(;!Xe.done;){if(Xe?.then)return Xe.then(ye);ze.push(Xe.value),Xe=kr.next()}ue(ze,ae)},"nextValue"),We=ye(kr.next());We&&(W||(W=[]),W.push(We));return}else if(he=Oe.call(this,he),he?.then){W||(W=[]),W.push(he.then(ze=>ue(ze,ae)));return}}ue(he,ae)},"handleResolvedValue");X?.then?(W||(W=[]),W.push(X.then(ne))):ne(X);return}else X=H[ae],X&&typeof X=="object"&&ae!==B&&(X=Me.transformEntryForSelect(B.select||B,S,A,null)({value:X}));ue(X,ae)},"selectAttribute"),oe;if(typeof E=="string")ee(E,B=>{oe=B});else if(Array.isArray(E))if(E.asArray)oe=[],E.forEach((B,ue)=>{B==="*"?E[ue]=H:ee(B,ae=>oe[ue]=ae)});else{oe={};let B=E.forceNulls;for(let ue of E)if(ue==="*")for(let ae in H)oe[ae]=H[ae];else ee(ue,(ae,ge)=>{ae===void 0&&B&&(ae=null),oe[ge]=ae})}else throw new lt.ClientError("Invalid select"+E);return W?Promise.all(W).then(()=>oe):oe}return H},"transform");return F}async subscribe(E){if(!l)throw new Error("Can not subscribe to a table without an audit log");g||et({table:s,database:c,schemaDefined:u,attributes:T,audit:!0}),E||(E={});let S=!E.rawEvents,A=[],N=this,b=YA(Me,this.getId()??null,function(O,D,F,L){try{let H=D.getValue?.(i,S),W=D.type;if(!H&&W==="patch"&&S){let oe=i.getEntry(O);oe?.version===D.version?H=oe.value:H=D.getValue?.(i,!0,F),W="put"}let ee={id:O,localTime:F,value:H,version:D.version,type:W,beginTxn:L};A?A.push(ee):this.send(ee)}catch(H){xe.default.error?.(H)}},E.startTime||0,E),C=(async()=>{this.isCollection&&(b.includeDescendants=!0,E.onlyChildren&&(b.onlyChildren=!0)),E.supportsTransactions&&(b.supportsTransactions=!0);let O=this.getId(),D=E.previousCount;D>1e3&&(D=1e3);let F=E.startTime;if(this.isCollection){if(F){if(D)throw new lt.ClientError("startTime and previousCount can not be combined for a table level subscription");for(let{key:L,value:H}of l.getRange({start:F,exclusiveStart:!0,snapshot:!1})){let W=Ut(H);if(W.tableId!==n)continue;let ee=W.recordId;if(O==null||VH(O,ee)){let oe=W.getValue(i,S,L);if(b.send({id:ee,localTime:L,value:oe,version:W.version,type:W.type}),b.queue?.length>qH&&await b.waitForDrain()===!1)return}b.startTime=L}}else if(D){let L=[];for(let{key:H,value:W}of l.getRange({start:"z",end:!1,reverse:!0}))try{let ee=Ut(W);if(ee.tableId!==n)continue;let oe=ee.recordId;if(O==null||VH(O,oe)){let B=ee.getValue(i,S,H);if(L.push({id:oe,localTime:H,value:B,version:ee.version,type:ee.type}),--D<=0)break}}catch(ee){xe.default.error("Error getting history entry",H,ee)}for(let H=L.length;H>0;)b.send(L[--H]);L[0]&&(b.startTime=L[0].localTime)}else if(!E.omitCurrent){for(let{key:L,value:H,version:W,localTime:ee}of i.getRange({start:O??!1,end:O==null?void 0:[O,_l.MAXIMUM_KEY],versions:!0,snapshot:!1}))if(H&&(b.send({id:L,localTime:ee,value:H,version:W,type:"put"}),b.queue?.length>qH&&await b.waitForDrain()===!1))return}}else{D&&!F&&(F=0);let L=this.#n?.localTime;if(L===xA&&(i.cache?.delete(O),this.#n=i.getEntry(O),xe.default.trace?.("re-retrieved record",L,this.#n?.localTime),L=this.#n?.localTime),xe.default.trace?.("Subscription from",F,"from",O,L),F<L){let H=[],W=L;do{let ee=l.get(W);if(ee){E.omitCurrent=!0;let oe=Ut(ee),B=oe.getValue(i,S,W);S&&(oe.type="put"),H.push({id:O,value:B,localTime:W,...oe}),W=oe.previousLocalTime}else break;D&&D--}while(W>F&&D!==0);for(let ee=H.length;ee>0;)b.send(H[--ee]);b.startTime=L}!E.omitCurrent&&this.doesExist()&&b.send({id:O,localTime:L,value:this.#e,version:this.#r,type:"put"})}for(let L of A)b.send(L);A=null})();return E.listener&&b.on("data",E.listener),b}static subscribeOnThisThread(E,S){return E===0||S?.crossThreads===!1}doesExist(){return!!(this.#e||this.#s)}publish(E,S,A){if(S===void 0||S instanceof URLSearchParams)this._writePublish(this.getId(),E,S);else{let N=!0,b=this.getContext();return E.checkPermission&&(N=this.allowCreate(b.user,E,b)),oi(N,C=>{if(!C)throw new lt.AccessViolation(b.user);let O=Sr(E);this._writePublish(O,S,A)})}}_writePublish(E,S,A){let N=Cr(this.getContext());E??=null,E!==null&&Or(E);let b=this.getContext();N.addWrite({key:E,store:i,entry:this.#n,nodeName:b?.nodeName,validate:o(()=>{b?.source||(N.checkOverloaded(),this.validate(S))},"validate"),before:Ne.publish?.bind(this,b,E,S),beforeIntermediate:Fe.publish?.bind(this,b,E,S),commit:o((C,O,D)=>{O===void 0&&y&&!g&&da(),xe.default.trace?.(`Publishing message to id: ${E}, timestamp: ${new Date(C).toISOString()}`),R(E,O?.value??null,O,O?.version||C,0,!0,{user:b?.user,residencyId:A?.residencyId,expiresAt:b?.expiresAt,nodeId:A?.nodeId},"message",!1,S)},"commit")})}validate(E,S){let A,N=o((b,C,O)=>{if(C.type&&b!=null)if(S&&b.__op__&&(b=b.value),C.properties){typeof b!="object"&&(A||(A=[])).push(`Value ${ws(b)} in property ${O} must be an object${C.type?" ("+C.type+")":""}`);let D=C.properties;for(let F=0,L=D.length;F<L;F++){let H=D[F];if(H.relationship||H.computed){E.hasOwnProperty(H.name)&&(A||(A=[])).push(`Computed property ${O}.${H.name} may not be directly assigned a value`);continue}let W=N(b[H.name],H,O+"."+H.name);W&&(b[H.name]=W)}if(C.sealed&&b!=null&&typeof b=="object")for(let F in b)D.find(L=>L.name===F)||(A||(A=[])).push(`Property ${F} is not allowed within object in property ${O}`)}else switch(C.type){case"Int":(typeof b!="number"||b>>0!==b)&&(A||(A=[])).push(`Value ${ws(b)} in property ${O} must be an integer (from -2147483648 to 2147483647)`);break;case"Long":(typeof b!="number"||!(Math.floor(b)===b&&Math.abs(b)<=9007199254740992))&&(A||(A=[])).push(`Value ${ws(b)} in property ${O} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof b!="number"&&(A||(A=[])).push(`Value ${ws(b)} in property ${O} must be a number`);break;case"ID":typeof b=="string"||b?.length>0&&b.every?.(D=>typeof D=="string")||(A||(A=[])).push(`Value ${ws(b)} in property ${O} must be a string, or an array of strings`);break;case"String":typeof b!="string"&&(A||(A=[])).push(`Value ${ws(b)} in property ${O} must be a string`);break;case"Boolean":typeof b!="boolean"&&(A||(A=[])).push(`Value ${ws(b)} in property ${O} must be a boolean`);break;case"Date":if(!(b instanceof Date)){if(typeof b=="string"||typeof b=="number")return new Date(b);(A||(A=[])).push(`Value ${ws(b)} in property ${O} must be a Date`)}break;case"BigInt":if(typeof b!="bigint"){if(typeof b=="string"||typeof b=="number")return BigInt(b);(A||(A=[])).push(`Value ${ws(b)} in property ${O} must be a bigint`)}break;case"Bytes":if(!(b instanceof Uint8Array)){if(typeof b=="string")return Buffer.from(b);(A||(A=[])).push(`Value ${ws(b)} in property ${O} must be a Buffer or Uint8Array`)}break;case"Blob":if(!(b instanceof Ss)){if(typeof b=="string"&&(b=Buffer.from(b)),b instanceof Buffer)return createBlob(b,{type:"text/plain"});(A||(A=[])).push(`Value ${ws(b)} in property ${O} must be a Blob`)}break;case"array":if(Array.isArray(b)){if(C.elements)for(let D=0,F=b.length;D<F;D++){let L=b[D],H=N(L,C.elements,O+"[*]");H&&(b[D]=H)}}else(A||(A=[])).push(`Value ${ws(b)} in property ${O} must be an Array`);break}C.nullable===!1&&b==null&&(A||(A=[])).push(`Property ${O} is required (and not does not allow null values)`)},"validateValue");for(let b=0,C=T.length;b<C;b++){let O=T[b];if(O.relationship||O.computed){Object.hasOwn(E,O.name)&&(A||(A=[])).push(`Computed property ${O.name} may not be directly assigned a value`);continue}if(!S||O.name in E){let D=N(E[O.name],O,O.name);D!==void 0&&(E[O.name]=D)}}if(f)for(let b in E)T.find(C=>C.name===b)||(A||(A=[])).push(`Property ${b} is not allowed`);if(A)throw new lt.ClientError(A.join(". "))}getUpdatedTime(){return this.#r}wasLoadedFromSource(){return P?!!this.#i:void 0}static async addAttributes(E){let S=T.slice(0);for(let A of E){if(!A.name)throw new lt.ClientError("Attribute name is required");if(A.name.match(/[`/]/))throw new lt.ClientError("Attribute names cannot include backticks or forward slashes");mse(A.name),S.push(A)}return et({table:s,database:c,schemaDefined:u,attributes:S}),Me.indexingOperation}static async removeAttributes(E){let S=T.filter(A=>!E.includes(A.name));return et({table:s,database:c,schemaDefined:u,attributes:S}),Me.indexingOperation}static getSize(){let E=i.getStats();return(E.treeBranchPageCount+E.treeLeafPageCount+E.overflowPages)*E.pageSize}static getAuditSize(){let E=l?.getStats();return E&&(E.treeBranchPageCount+E.treeLeafPageCount+E.overflowPages)*E.pageSize}static getStorageStats(){let E=i.env.path,S=eN.default.statfsSync?.(E)??{};return{available:S.bavail*S.bsize,free:S.bfree*S.bsize,size:S.blocks*S.bsize}}static async getRecordCount(E){let S=i.getStats().entryCount,A=1e3/2,N=performance.now(),b=Math.floor(S/2),C=E?.exactCount,O=0,D=0,F;for(let{value:L}of i.getRange({start:!0,lazy:!0,snapshot:!1}))if(L!=null&&O++,D++,await va(),!C&&D<b&&performance.now()-N>A){F=D;break}if(F){let L=O;O=0;for(let{value:X}of i.getRange({start:"\uFFFF",reverse:!0,lazy:!0,limit:F,snapshot:!1}))X!=null&&O++,await va();let H=F*2,W=(O+L)/H,ee=Math.pow((O-L+1)/F/2,2)+W*(1-W)/H,oe=Math.max(Math.sqrt(ee)*S,1),B=Math.round(W*S),ue=Math.max(B-1.96*oe,O+L),ae=Math.min(B+1.96*oe,S),ge=Math.pow(10,Math.round(Math.log10(oe)));return ge>B&&(ge=ge/10),O=Math.round(B/ge)*ge,{recordCount:O,estimatedRange:[Math.round(ue),Math.round(ae)]}}return{recordCount:O}}static updatedAttributes(){wr=this.propertyResolvers={$id:o((E,S,A)=>({value:A.key}),"$id"),$updatedtime:o((E,S,A)=>A.version,"$updatedtime"),$updatedTime:o((E,S,A)=>A.version,"$updatedTime"),$expiresAt:o((E,S,A)=>A.expiresAt,"$expiresAt"),$record:o((E,S,A)=>A?{value:E}:E,"$record"),$distance:o((E,S,A)=>A&&(A.distance??S?.vectorDistances?.get(A)),"$distance")};for(let E of this.attributes){E.isPrimaryKey&&(Y=E),E.resolve=null;let S=E.relationship,A=E.computed;if(S)if(E.indexed&&console.error("A relationship property can not be directly indexed, (but you may want to index the foreign key attribute)"),A&&console.error("A relationship property is already computed and can not be combined with a computed function (the relationship will be given precedence)"),ou=!0,S.to)E.elements?.definition?(wr[E.name]=E.resolve=(N,b,C,O)=>{let D=N[S.from?S.from:t],F=E.elements.definition.tableClass;return O?Iu({attribute:S.to,value:D},Cr(b).getReadTxn(),!1,F,!1).map(L=>L&&L.key!==void 0?L:F.primaryStore.getEntry(L,{transaction:Cr(b).getReadTxn()})).asArray:F.search([{attribute:S.to,value:D}],b).asArray},E.set=()=>{},E.resolve.definition=E.elements.definition,E.resolve.to=S.to,S.from&&(E.resolve.from=S.from)):console.error(`The one-to-many/many-to-many relationship property "${E.name}" in table "${s}" must have an array type referencing a table as the elements`);else if(S.from){let N=E.definition||E.elements?.definition;N?(wr[E.name]=E.resolve=(b,C,O,D)=>{let F=b[S.from];if(F!==void 0){if(E.elements){let L,H=F?.map(W=>{let ee=N.tableClass.primaryStore[D?"getEntry":"get"](W,{transaction:Cr(C).getReadTxn()});return ee?.then&&(L=!0),ee});return S.filterMissing?L?Promise.all(H).then(W=>W.filter(KH)):H.filter(KH):L?Promise.all(H):H}return N.tableClass.primaryStore[D?"getEntry":"get"](F,{transaction:Cr(C).getReadTxn()})}},E.set=(b,C)=>{if(Array.isArray(C)){let O=C.map(D=>D.getId?.()||D[N.tableClass.primaryKey]);b[S.from]=O}else{let O=C.getId?.()||C[N.tableClass.primaryKey];b[S.from]=O}},E.resolve.definition=E.definition||E.elements?.definition,E.resolve.from=S.from):console.error(`The relationship property "${E.name}" in table "${s}" must be a type that references a table`)}else console.error(`The relationship directive on "${E.name}" in table "${s}" must use either "from" or "to" arguments`);else if(A)typeof A.from=="function"&&this.setComputedAttribute(E.name,A.from),wr[E.name]=E.resolve=(N,b,C)=>{let O=typeof A.from=="string"?N[A.from]:N,D=this.userResolvers[E.name];if(D)return D(O,b,C);xe.default.warn(`Computed attribute "${E.name}" does not have a function assigned to it. Please use setComputedAttribute('${E.name}', resolver) to assign a resolver function.`),this.userResolvers[E.name]=()=>{}},E.resolve.directReturn=!0;else if(r[E.name]?.customIndex?.propertyResolver){let N=r[E.name].customIndex;wr[E.name]=(b,C,O)=>{let D=b[E.name];return N.propertyResolver(D,C,O)},wr[E.name].directReturn=!0}}km(this,this),km(cu,this,!0);for(let E of T){let S=E.name;E.resolve&&Object.defineProperty(i.encoder.structPrototype,S,{get(){return E.resolve(this,Ou.getStore())},set(A){return E.set(this,A)},configurable:!0})}}static setComputedAttribute(E,S){let A=Ci(T,E);if(!A){console.error(`The attribute "${E}" does not exist in the table "${s}"`);return}if(!A.computed){console.error(`The attribute "${E}" is not defined as computed in the table "${s}"`);return}this.userResolvers[E]=S}static async deleteHistory(E=0,S=!1){let A;for(let{key:N,value:b}of l.getRange({start:0,end:E}))await va(),Ut(b).tableId===n&&(A=u_(l,N,b));if(S)for(let N of i.getRange({start:0,versions:!0})){let{key:b,value:C,localTime:O}=N;await va(),C===null&&O<E&&(A=zc(i,N))}await A}static async*getHistory(E=0,S=1/0){for(let{key:A,value:N}of l.getRange({start:E||1,end:S})){await va();let b=Ut(N);b.tableId===n&&(yield{id:b.recordId,localTime:A,version:b.version,type:b.type,value:b.getValue(i,!0,A),user:b.user,operation:b.originatingOperation})}}static async getHistoryOfRecord(E){let S=[];if(E==null)throw new Error("An id is required");let A=i.getEntry(E);if(!A)return S;let N=A.localTime;if(!N)throw new Error("The entry does not have a local audit time");let b=0;do{await va();let C=l.get(N);if(C){let O=Ut(C);S.push({id:O.recordId,localTime:N,version:O.version,type:O.type,value:O.getValue(i,!0,N),user:O.user}),N=O.previousLocalTime}else break}while(b<1e3&&N);return S.reverse()}static cleanup(){V?.remove()}}Me.updatedAttributes();let Of=Me.prototype;return p&&Me.setTTLExpiration(p/1e3),j&&EE(),Me;function oo(q,E,S){let A;for(let N in r){let b=r[N],C=b.isIndexing,O=wr[N],D=S&&(O?O(S):S[N]),F=E&&(O?O(E):E[N]);if(D===F&&!C)continue;if(b.customIndex){b.customIndex.index(q,D,F);continue}A=!0;let L=b.indexNulls,H=(0,sh.getIndexedValues)(D,L),W=(0,sh.getIndexedValues)(F,L);if(W?.length>0){let ee=new Set(W);if(H=H?H.filter(oe=>{if(ee.has(oe))ee.delete(oe);else return!0}):[],W=Array.from(ee),(W.length>0||H.length>0)&&HH){let oe=W.concat(H).map(B=>({key:B,value:q}));b.prefetch(oe,$H)}for(let oe=0,B=W.length;oe<B;oe++)b.remove(W[oe],q)}else H?.length>0&&HH&&b.prefetch(H.map(ee=>({key:ee,value:q})),$H);if(H)for(let ee=0,oe=H.length;ee<oe;ee++)b.put(H[ee],q)}return A}o(oo,"updateIndices");function Or(q){switch(typeof q){case"number":return!0;case"string":if(q.length<659)return!0;if(q.length>GH)throw new Error("Primary key size is too large: "+q.length);break;case"object":if(q===null)throw new Error("Invalid primary key of null");break;case"bigint":if(q<2n**64n&&q>-(2n**64n))return!0;break;default:throw new Error("Invalid primary key type: "+typeof q)}if((0,_l.writeKey)(q,Sse,0)>GH)throw new Error("Primary key size is too large: "+q.length);return!0}o(Or,"checkValidId");function Sr(q){return typeof q=="object"&&q?q.id:q}o(Sr,"requestTargetToId");function Cf(q){return typeof q=="object"&&q&&q.isCollection}o(Cf,"isSearchTarget");function Es(q){}o(Es,"isRequestTarget");function Tc(q,E,S,A,N){if(Me.getResidencyById&&S.ensureLoaded&&E?.replicateFrom!==!1){let C=wc(Me.getResidencyById(q));if(C&&!C.includes(server.hostname)&&I)return I({key:q,residency:C}).then(N)}let b=o(()=>{if(E?.transaction?.stale&&(E.transaction.stale=!1),S.transaction?.isDone)return N(null,q);let C=i.getEntry(q,S);return C?.residencyId&&C.metadataFlags&wn&&I&&S.ensureLoaded&&E?.replicateFrom!==!1?I(C).then(O=>N(O,q),O=>(xe.default.error?.("Error loading remote record",q,C,S,O),N(null,q))):(C&&E&&(C?.version>(E.lastModified||0)&&(E.lastModified=C.version),C?.localTime&&!E.lastRefreshed&&(E.lastRefreshed=C.localTime)),N(C,q))},"whenPrefetched");return A?b():se>0?(se--,b()):new Promise((C,O)=>{se===0?(se--,i.prefetch([q],()=>{D(),F()})):(le.push(q),re.push(F),le.length>pE&&(se--,D()));function D(){if(le.length>0){let L=re;i.prefetch(le,()=>{se===-1?D():se++;for(let H of L)H()}),le=[],re=[],_e>2&&_e--}else se=_e,_e<Ty&&_e++}o(D,"prefetch");function F(){try{C(b())}catch(L){O(L)}}o(F,"load")})}o(Tc,"loadLocalRecord");function Rc(q,E){let S=E?.checkPermission;if(typeof S!="object"){if(!q?.role)return;S=q.role.permission}if(S.super_user)return Tse;let A=S[c],N,b=A?.tables;if(b)return b[s];if(c==="data"&&(N=S[s])&&!N.tables)return N}o(Rc,"getTablePermissions");function yc(q,E,S,A){if(P){let N=!1;if(S.noCache?N=!0:(E?(!E.value||E.metadataFlags&(wn|Aa)||E.expiresAt!=null&&E.expiresAt<Date.now())&&(N=!0):N=!0,Kr(!N,"cache-hit",s)),N){let b=lu(q,E,S).then(C=>(C?.value&&C?.value.getRecord?.()&&xe.default.error?.("Can not assign a record that is already a resource"),S&&(C?.version>(S.lastModified||0)&&(S.lastModified=C.version),S.lastRefreshed=Date.now()),C));if(S?.onlyIfCached||E?.value&&A?.allowStaleWhileRevalidate?.(E,q)){if(b.catch(C=>xe.default.warn?.(C)),S?.onlyIfCached&&!A.doesExist())throw new lt.ServerError("Entry is not cached",504);return}else return b}}else if(E?.value&&E.expiresAt!=null&&E.expiresAt<Date.now())return Me.evict(E.key,E.value,E.version),E.value=null,{then(N){return N(E)}}}o(yc,"ensureLoadedFromSource");function Cr(q){let E=q?.transaction;if(E){if(!E.lmdbDb)return E.lmdbDb=i,E;do{if(E.lmdbDb?.path===i.path)return E;let S=E.next;if(!S)return E=E.next=new lo,E.lmdbDb=i,E;E=S}while(!0)}else return new HE}o(Cr,"txnForContext");function Ac(q,E,S){if(!q)return;let A=(q.deref?q.deref():q.value)??i.getEntry(q.key)?.value;if(typeof E=="object"){let b=wr,C=A;for(let O=0,D=E.length;O<D;O++){let F=E[O],L=b?.[F];C=L&&C?L(C,S,q):C?.[F],q=null,b=L?.definition?.tableClass?.propertyResolvers}return C}let N=wr[E];return N?N(A,S,q):A[E]}o(Ac,"getAttributeValue");function Pf(q,E,S,A,N){let b=N?.length,C={transaction:A,lazy:b>0||typeof E=="string"||E?.length<4,alwaysPrefetch:!0},O;function D(F,L){let H=F?.value;if(!H)return Ua.SKIP;for(let W=0;W<b;W++)if(!O?.includes(W)&&!N[W](H,F))return Ua.SKIP;return L!==void 0&&(F.key=L),F}if(o(D,"processEntry"),b>0||!q.hasEntries){let F=q.map(L=>{if(O=null,typeof L=="object"&&L?.key!==void 0)return b>0?D(L):L;if(L==null)return Ua.SKIP;for(let H=0;H<b;H++){let ee=N[H].idFilter;if(ee){if(!ee(L))return Ua.SKIP;O||(O=[]),O.push(H)}}return Tc(L,S,C,!1,D)});return Array.isArray(q)&&(F=F.filter(L=>L!==Ua.SKIP)),F.hasEntries=!0,F}return q}o(Pf,"transformToEntries");function bc(q,E,S=server.replication?.getThisNodeId(l)){if(q<=E?.version){if(E?.version===q&&S!==void 0){let A=server.replication?.exportIdMapping(l),N=E.localTime,b=N&&l.get(N);if(b){let C,O,D=Ut(b);for(let F in A)A[F]===S&&(C=F),A[F]===D.nodeId&&(O=F);if(C>O)return 1;if(C===O)return 0}}return-1}return 1}o(bc,"precedesExistingVersion");async function lu(q,E,S){let A=E?.metadataFlags,N=E?.version,b,C;if(!i.attemptLock(q,N,()=>{clearTimeout(C);let L=i.getEntry(q);!L||!L.value||L.metadataFlags&(wn|Aa)?b(lu(q,i.getEntry(q),S)):b(L)}))return new Promise(L=>{b=L,C=setTimeout(()=>{i.unlock(q,N)},_se)});let O=E?.value,D={requestContext:S,replacingRecord:O,replacingEntry:E,replacingVersion:N,noCacheStore:!1,source:null,resourceCache:S?.resourceCache,transaction:void 0,expiresAt:void 0,lastModified:void 0},F=S?.responseHeaders;return new Promise((L,H)=>{let W;oi(vt(D,async ee=>{let oe=performance.now(),B,ue,ae;try{for(let ne of Me.sources)if(ne.get&&(!ne.get.reliesOnPrototype||ne.prototype.get)){if(ne.available?.(E)===!1)continue;if(D.source=ne,B=await ne.get(q,D),B)break}ae=A&wn;let X=D.lastModified||ae&&N;ue=ae||X>N||!O,X||(X=(0,sh.getNextMonotonicTime)());let de=performance.now()-oe;if(gt(de,"cache-resolution",s,null,"success"),F&&rh(F,"Server-Timing",`cache-resolve;dur=${de.toFixed(2)}`,!0),ee.timestamp=X,p&&D.expiresAt==null&&(D.expiresAt=Date.now()+p),B){if(typeof B!="object")throw new Error("Only objects can be cached and stored in tables");if(B.status>0&&B.headers)if(B.status>=300)if(B.status===304)B=O,X=N;else throw new lt.ServerError(B.body||"Error from source",B.status);else B=B.body;typeof B.toJSON=="function"&&(B=B.toJSON()),t&&B[t]!==q&&(B[t]=q)}W=!0,L({key:q,version:X,value:B})}catch(X){X.message+=` while resolving record ${q} for ${s}`,O&&((X.code==="ECONNRESET"||X.code==="ECONNREFUSED"||X.code==="EAI_AGAIN")&&!S?.mustRevalidate||S?.staleIfError&&(X.statusCode===500||X.statusCode===502||X.statusCode===503||X.statusCode===504))?(L({key:q,version:N,value:O}),xe.default.trace?.(X.message,"(returned stale record)")):H(X);let de=performance.now()-oe;gt(de,"cache-resolution",s,null,"fail"),F&&rh(F,"Server-Timing",`cache-resolve;dur=${de.toFixed(2)}`,!0),D.transaction.abort();return}if(S?.noCacheStore||D.noCacheStore){D.transaction.abort();return}Cr(D).addWrite({key:q,store:i,entry:E,nodeName:"source",commit:o((X,de)=>{if(de?.version!==N)return;let ne=oo(q,O,B);if(B){Fe.put?.(D,q,B),de&&(S.previousResidency=Me.getResidencyRecord(de.residencyId));let he,Ae=!1,Oe,ze=wc(Me.getResidency(B,S));if(ze){if(!ze.includes(server.hostname))if(he=B,Ae=!0,Me.getResidencyById)B=void 0;else{B=null;for(let kr in r)B||(B={}),B[kr]=he[kr]}Oe=fa(ze)}xe.default.trace?.(`Writing resolved record from source with id: ${q}, timestamp: ${new Date(X).toISOString()}`),R(q,B,de,X,Ae?wn:0,g&&(ue||Ae)||null,{user:D?.user,expiresAt:D.expiresAt,residencyId:Oe},"put",!!ae,he)}else de&&(Fe.delete?.(D,q),xe.default.trace?.(`Deleting resolved record from source with id: ${q}, timestamp: ${new Date(X).toISOString()}`),g||y?R(q,null,de,X,0,g&&ue||null,{user:D?.user},"delete",!!ae):zc(i,de,N))},"commit")})}),()=>{i.unlock(q,N)},ee=>{i.unlock(q,N),W&&xe.default.error?.("Error committing cache update",ee)})})}o(lu,"getFromSource");function Ic(q){if(!q||q.user?.role?.permission?.super_user)return!0;if(q.replicateTo)throw new lt.ClientError("Can not specify replication parameters without super user permissions",403);if(q.replicatedConfirmation)throw new lt.ClientError("Can not specify replication confirmation without super user permissions",403);return!0}o(Ic,"checkContextPermissions");function da(q){let E=!1;if(q&&(q-_r>1&&(E=!0),_r=q),!(He===pt&&!E)&&(pt=He,(0,pl.getWorkerIndex)()===(0,pl.getWorkerCount)()-1))return gr&&clearTimeout(gr),He?new Promise(S=>{let A=new Date;A.setMonth(0),A.setDate(1),A.setHours(0),A.setMinutes(0),A.setSeconds(0);let N=He/(1+_r),b=E?Date.now():Math.ceil((Date.now()-A.getTime())/N)*N+A.getTime(),C=o(O=>{xe.default.trace?.(`Scheduled next cleanup scan at ${new Date(O)}`),gr=setTimeout(()=>te=te.then(async()=>{if(C(Math.max(O+He,Date.now())),i.rootStore.status!=="open"){clearTimeout(gr);return}let D=50,F=new Array(D),L=0,H=Math.pow(_r,8)*(El.get(U.STORAGE_RECLAMATION_EVICTIONFACTOR)??1e5),W=_/Math.pow(Math.max(_r,1),4);xe.default.info?.(`Starting cleanup scan for ${s}, evict threshold ${H}, adjusted eviction ${W}ms`);function ee(oe,B,ue,ae){let ge=oe+W-Date.now();if(ge<0)return!0;if(_r){let X=i.lastSize;return ue&Nn&&_u(ae,de=>{de.size&&(X+=de.size)}),xe.default.trace?.(`shouldEvict adjusted ${ge} ${X}, ${ge*(oe-B)/X} < ${H}`),ge*(oe-B)/X<H}return!1}o(ee,"shouldEvict");try{let oe=0;for(let B of i.getRange({start:!1,snapshot:!1,versions:!0,lazy:!0})){let{key:ue,value:ae,version:ge,expiresAt:X,metadataFlags:de}=B,ne;ae===null&&!g&&ge+Ese<Date.now()?ne=zc(i,B,ge):X!=null&&ee(X,ge,de,ae)&&(ne=Me.evict(ue,ae,ge),oe++),ne&&(await F[L],F[L]=ne.catch(he=>{xe.default.error?.("Cleanup error",he)}),++L>=D&&(L=0)),await va()}xe.default.info?.(`Finished cleanup scan for ${s}, evicted ${oe} entries`)}catch(oe){xe.default.warn?.(`Error in cleanup scan for ${s}:`,oe)}S(void 0),_r=0}),Math.min(O-Date.now(),2147483647)).unref()},"startNextTimer");C(b)}):void 0}o(da,"scheduleCleanup");function Nc(){V=l?.addDeleteRemovalCallback(n,i,(q,E)=>{i.remove(q,E)})}o(Nc,"addDeleteRemoval");function EE(){(0,pl.getWorkerIndex)()===0&&setInterval(async()=>{if(!au){au=!0;try{let q=j.name,E=r[q];if(!E)throw new Error(`expiresAt attribute ${j} must be indexed`);for(let S of E.getRange({start:!0,values:!1,end:Date.now(),snapshot:!1})){for(let A of E.getValues(S)){let N=i.getEntry(A);N?.value?N.value[q]<Date.now()&&Me.evict(A,N.value,N.version):i.ifVersion(A,N?.version,()=>E.remove(S,A))}await va()}}catch(q){xe.default.error?.("Error in evicting old records",q)}finally{au=!1}}},pse).unref()}o(EE,"runRecordExpirationEviction");function wc(q){if(q!=null){if(Array.isArray(q))return q;if(typeof q=="number"){if(q>=65536)throw new Error(`Shard id ${q} must be below 65536`);let E=server.shards?.get?.(q);if(E)return xe.default.trace?.(`Shard ${q} mapped to ${E.map(S=>S.name).join(", ")}`),E.map(S=>S.name);throw new Error(`Shard ${q} is not defined`)}throw new Error(`Shard or residency list ${q} is not a valid type, must be a shard number or residency list of node hostnames`)}}o(wc,"residencyFromFunction");function fa(q){if(q){let E=q.join(","),S=d.get([Symbol.for("residency_by_set"),E]);return S||(d.put([Symbol.for("residency_by_set"),E],S=Math.floor(Math.random()*2147418112)+65535),d.put([Symbol.for("residency_by_id"),S],q),S)}}o(fa,"getResidencyId")}function ZI(e,t){let r=e.attr_object||(e.attr_object={}),n=r[t];if(n)return n;n=r[t]=Object.create(null);for(let s of e)n[s.attribute_name]=s[t];return n}function $H(){}function tN(e){zH=e}function Tg(e,t){let r=t?.type;if(e===null)return e;if(e===""&&r&&r!=="String"&&r!=="Any")return null;try{switch(r){case"Int":case"Long":if(e[0]==="$")return Sg(parseInt(e.slice(1),36));if(e==="null")return null;if(!/^-?[0-9]+$/.test(e)&&!(e instanceof Date))throw new SyntaxError;return Sg(+e);case"Float":return e==="null"?null:Sg(+e);case"BigInt":return e==="null"?null:BigInt(e);case"Boolean":return e==="true"?!0:e==="false"?!1:e;case"Date":if(isNaN(e)){if(e==="null")return null;Rse.test(e)||(e+="Z");let n=new Date(e);return Sg(n.getTime()),n}return new Date(+e);case void 0:case"Any":return(0,Rg.autoCast)(e);default:return e}}catch(n){throw n.message=`Invalid value for attribute ${t.name}: "${e}", expecting ${r}`,n.statusCode=400,n}}function Sg(e){if(isNaN(e))throw new SyntaxError;return e}function VH(e,t){if(e==null)return!0;if(!Array.isArray(t))return e===t||t.startsWith?.(e);if(Array.isArray(e)){let r=e.length;if(e[r-1]===null&&r--,t.length>=r){for(let n=0;n<r;n++)if(t[n]!==e[n])return!1;return!0}return!1}else if(t[0]===e)return!0}function oi(e,t,r){return e?.then?e.then(t,r):t(e)}function KH(e){return e!=null}function ws(e){try{return JSON.stringify(e)}catch{return e}}function yse(e){let t=process.pid;return e.env.readerList().slice(1).some(r=>+r.match(/\d+/)?.[0]!=t)}var Ua,sh,YH,WH,El,lt,ih,oh,xe,_l,pl,Rg,eN,fse,mse,hse,zH,pse,Ese,HH,_se,kH,gse,wn,Aa,Sse,GH,qH,Tse,nLe,Rse,va,Sm=fe(()=>{k();Ua=require("lmdb"),sh=w(An()),YH=w(require("lodash")),WH=w(zf());ba();Qf();El=w(ce());WA();lt=w(Ee()),ih=w(bo()),oh=w(ti());Le();R_();xe=w(Ni());oI();Uc();_l=require("ordered-binary"),pl=w(st());uo();Rg=w(ie());Yc();Hi();qE();nh();eN=w(require("node:fs"));Ts();o_();({sortBy:fse}=YH.default),{validateAttribute:mse}=WH.default,hse=new Uint8Array(9);hse[8]=192;pse=6e4,Ese=864e5;El.initSync();HH=El.get(U.STORAGE_PREFETCHWRITES),_se=1e4,kH=1,gse=2,wn=1,Aa=8,Sse=Buffer.allocUnsafeSlow(8192),GH=1978,qH=100,Tse={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},nLe=(0,Rg.convertToMS)(El.get(U.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;o(yg,"makeTable");o(ZI,"attributesAsObject");o($H,"noop");o(tN,"setServerUtilities");Rse=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;o(Tg,"coerceType");o(Sg,"rejectNaN");o(VH,"isDescendantId");va=o(()=>new Promise(setImmediate),"rest");o(oi,"when");o(KH,"exists");o(ws,"stringify");o(yse,"hasOtherProcesses")});function Ag(e,t){if(!Array.isArray(e)||!Array.isArray(t))throw new Error("Euclidean distance comparison requires an array");let r=0,n=Math.max(e.length,t.length);for(let s=0;s<n;s++){let i=e[s]||0,a=t[s]||0,c=i-a;r+=c*c}return r}function bg(e,t){if(!Array.isArray(e)||!Array.isArray(t))throw new Error("Cosine distance comparison requires an array");let r=0,n=0,s=0,i=Math.max(e.length,t.length);for(let a=0;a<i;a++){let c=e[a]||0,l=t[a]||0;r+=c*l,n+=c*c,s+=l*l}return n=Math.sqrt(n),s=Math.sqrt(s),1-r/(n*s||1)}var QH=fe(()=>{o(Ag,"euclideanDistance");o(bg,"cosineDistance")});var JH,XH,Wu,ki,Yu,Ase,bse,Ig,ZH=fe(()=>{QH();JH=require("msgpackr"),XH=w(Ni()),Wu=w(Ee()),ki=(0,XH.loggerWithTag)("HNSW"),Yu=Symbol.for("entryPoint"),Ase=Symbol.for("key"),bse=10,Ig=class{static{o(this,"HierarchicalNavigableSmallWorld")}static useObjectStore=!0;indexStore;M=16;efConstruction=100;efConstructionSearch=50;mL=1/Math.log(this.M);optimizeRouting=.5;nodesVisitedCount=0;idIncrementer;distance;constructor(t,r){this.indexStore=t,t&&(this.indexStore.encoder.useFloat32=JH.FLOAT32_OPTIONS.ALWAYS),this.distance=r?.distance==="euclidean"?Ag:bg,r&&(r.M!==void 0&&(this.M=r.M,this.mL=1/Math.log(this.M)),r.efConstruction!==void 0&&(this.efConstruction=this.efConstructionSearch=r.efConstruction),r.efConstructionSearch!==void 0&&(this.efConstructionSearch=r.efConstructionSearch),r.mL!==void 0&&(this.mL=r.mL),r.optimizeRouting!==void 0&&(this.optimizeRouting=r.optimizeRouting))}index(t,r,n){let s=typeof t=="number"?[Ase,t]:t,i=this.indexStore.get(s);if(!i){if(!r)return;if(!this.idIncrementer){let f=0;for(let m of this.indexStore.getKeys({reverse:!0,limit:1,start:1/0,end:0}))typeof m=="number"&&(f=m);this.idIncrementer=new BigInt64Array([BigInt(f)+1n]),this.idIncrementer=new BigInt64Array(this.indexStore.getUserSharedBuffer("next-id",this.idIncrementer.buffer))}i=Number(Atomics.add(this.idIncrementer,0,1n)),this.indexStore.put(s,i)}let a=new Map,c,l=this.indexStore.get(Yu);if(n?c={...this.indexStore.get(i)}:c={},r){let f=l&&this.indexStore.get(l);if(f===void 0){let _=Math.floor(-Math.log(Math.random())*this.mL),g={vector:r,level:_,primaryKey:t};for(let y=0;y<=_;y++)g[y]=[];if(this.indexStore.put(i,g),typeof i!="number")throw new Error("Invalid nodeId: "+i);ki.debug?.("setting entry point to",i),this.indexStore.put(Yu,i);return}let m=c.level??Math.min(Math.floor(-Math.log(Math.random())*this.mL),bse),h=f.level;if(m>=h){if(typeof i!="number")throw new Error("Invalid nodeId: "+i);ki.debug?.("setting entry point to",i),this.indexStore.put(Yu,i)}for(;h>m;){let _=this.searchLayer(r,l,f,this.efConstruction,h);_.length>0&&(l=_[0].id,f=_[0].node),h--}let p=new Array(m+1);for(let _=0;_<=m;_++)p[_]=[];for(let _=Math.min(m,h);_>=0;_--){let g=this.searchLayer(r,l,f,this.efConstruction,_);g=g.slice(0,this.M<<1),g.length===0&&_===0&&ki.info?.("should not have zero connections for",l);let y=p[_];for(let T=0;T<g.length;T++){let{id:R,distance:I,node:P}=g[T];if(R===i)continue;let Y=[];if(this.optimizeRouting){let $=!1,j=P[_],V=1+this.optimizeRouting*(1+.5*T/this.M);for(let le=0;le<j.length;le++){let{id:re,distance:se}=j[le],_e=1+this.optimizeRouting*(1+.5*le/this.M);for(let Ne=0;Ne<y.length;Ne++){let{id:Fe,distance:He}=y[Ne];if(Fe===re){I*V>He+se?$=!0:se*_e>I+He&&(Y.push({fromId:Fe,toId:R}),Y.push({fromId:R,toId:Fe}));break}}if($)break}if($)continue}else if(T>=(_>0?this.M:this.M<<1))continue;y.push({id:R,distance:I});for(let{fromId:$,toId:j}of Y){let V=d($);V||(V=d($,this.indexStore.get($)));for(let le=0;le<V[_].length;le++)if(V[_][le].id===j){Object.isFrozen(V[_])&&(V[_]=V[_].slice()),V[_].splice(le,1);break}}let te=c[_],x=te?.find(({id:$})=>$===R);if(x){let $=te?.indexOf(x);te.copied||(te=[...te],te.copied=!0,c[_]=te),te.splice($,1)}else this.addConnection(R,d(R,P),i,_,I,d)}}this.indexStore.put(i,{vector:r,level:m,primaryKey:t,...p})}else{if(l===i){let f=c.level??0;for(let m=f;m>=0&&(l=c[m][0]?.id,l===void 0);m--);if(l===void 0){let m=-1;for(let{key:h,value:p}of this.indexStore.getRange({start:0,end:1/0}))if(p.level>m){if(l=h,p.level===f)break;m=p.level}}if(l===void 0)this.indexStore.remove(Yu);else{if(typeof l!="number")throw new Error("Invalid nodeId: "+l);ki.debug?.("setting entry point to",l),this.indexStore.put(Yu,l)}}this.indexStore.remove(i)}let u=new Map;if(c.level!==void 0)for(let f=0;f<=c.level;f++){let m=c[f];for(let{id:h}of m){let p=d(h,this.indexStore.get(h));for(let _=0;_<=f;_++)p[_]=p[_]?.filter(({id:g})=>g!==i),p[_].length===0&&(ki.info?.("node was left orphaned, will reindex",h),u.set(p.primaryKey,p.vector))}}function d(f,m){let h=a.get(f);return!h&&m&&(h={...m},a.set(f,h)),h}o(d,"updateNode");for(let[f,m]of a)this.indexStore.put(f,m);for(let[f,m]of u)this.index(f,m,m);this.checkSymmetry(i,this.indexStore.get(i))}getEntryPoint(){let t=this.indexStore.get(Yu);if(t===void 0)return;let r=this.indexStore.get(t);return{id:t,...r}}searchLayer(t,r,n,s,i,a=this.distance){let c=new Set([r]),l=[{id:r,distance:this.distance(t,n.vector),node:n}],u=[...l];for(;l.length>0;){l.sort((h,p)=>h.distance-p.distance);let d=l.shift(),f=u[u.length-1].distance;if(d.distance>f)break;let m=d.node;for(let{id:h}of m[i]||[]){if(c.has(h)||h===void 0)continue;c.add(h);let p=this.indexStore.get(h);if(!p)continue;this.nodesVisitedCount++;let _=a(t,p.vector);if(_<f||u.length<s){let g={id:h,distance:_,node:p};l.push(g),u.push(g)}}u.sort((h,p)=>h.distance-p.distance),u.length>s&&u.splice(s,u.length-s)}return u.visited=c.size,u}search({target:t,value:r,descending:n,distance:s,comparator:i}){let a=0;switch(i){case"lt":case"le":a=r;case"sort":break;default:throw new Wu.ClientError(`Can not use "${i}" comparator with HNSW`)}if(n)throw new Wu.ClientError("Can not use descending sort order with HNSW");let c;if(s==="cosine")c=bg;else if(s==="euclidean")c=Ag;else{if(s)throw new Wu.ClientError("Unknown distance function");c=this.distance}if(!t)throw new Wu.ClientError("A target vector must be provided for an HNSW query");if(!Array.isArray(t))throw new Wu.ClientError("The target vector must be an array");let l=this.getEntryPoint();if(!l)return[];let u=l.id,d=[];for(let f=l.level;f>=0;f--)if(d=this.searchLayer(t,u,l,this.efConstructionSearch,f,c),d.length>0){let m=d[0];l=m.node,u=m.id}return a&&(d=d.filter(f=>f.distance<a)),d.map(f=>({key:f.node.primaryKey,distance:f.distance}))}checkSymmetry(t,r){if(!r)return;let n=0,s;for(;(s=r[n])&&s.length!==0;){for(let{id:i}of s){let a=this.indexStore.get(i);if(!a){ki.info?.("could not find neighbor node",a);continue}a[n]?.find(({id:l})=>l==t)||ki.info?.("asymmetry detected",a[n])}n++}}addConnection(t,r,n,s,i,a){r[s]||(r[s]=[]);let c=s===0?this.M<<1:this.M;if(this.optimizeRouting&&(c<<=2),r[s].length>=c+(c>>2)){ki.warn?.("maxConnections reached, removing some connections",c);let l=[...r[s]];l.sort((f,m)=>f.distance-m.distance);let u=l.slice(0,c),d=l.slice(c);r[s]=u;for(let f of d){let m=a(f.id)??this.indexStore.get(f.id);m&&m[s]&&(m=a(f.id,m),m[s]=m[s].filter(({id:h})=>h!==t),s===0&&m[s].length===0&&ki.info?.("should not remove last connection",t,n))}}r[s].find(({id:l})=>l===n)?ki.debug?.("already connected",t,n):r[s]=[...r[s],{id:n,distance:i}]}validateConnectivity(t=0){let r=this.getEntryPoint(),n=new Set,s=[r.id];n.add(r.id);let i=0;for(;s.length>0;){let a=s.shift(),c=this.indexStore.get(a);for(let l=t;l<=c.level;l++)for(let{id:u}of c[l]||[])i++,n.has(u)||(n.add(u),s.push(u))}return n.size!==this.totalNodes&&console.log("visited",n.size,"total",this.totalNodes),{isFullyConnected:n.size===this.totalNodes,averageConnections:i/n.size}}get totalNodes(){return Array.from(this.indexStore.getKeys({start:0,end:1/0})).length}estimateCountAsSort(){return Math.sqrt(this.indexStore.getStats().entryCount*this.efConstructionSearch)}propertyResolver(t,r,n){let s=r?.sort;if(s){let i=s.vectorDistances;if(i){let l=i.get(n);if(l)return l}else i=r.vectorDistances=s.vectorDistances=new Map;let a=this.distance;s.type&&(a=s.distance==="euclidean"?Ag:bg);let c=a(s.target,t);return i.set(n,c),c}return t}}});var rN,ek=fe(()=>{ZH();rN={HNSW:Ig}});var ft={};Ce(ft,{database:()=>Hu,databaseEnvs:()=>Po,databases:()=>Ge,dropDatabase:()=>dI,dropTableMeta:()=>Cse,getDatabases:()=>it,getDefaultCompression:()=>Lg,getTables:()=>Ise,onRemovedDB:()=>fh,onUpdatedTable:()=>gl,readMetaDb:()=>ah,resetDatabases:()=>Zu,table:()=>et,tables:()=>cn});function Ise(){return Cg||it(),cn||{}}function it(){if(Cg)return Ge;Cg=!0,Qu=new Map;let e=(0,qt.getHdbBasePath)()&&(0,xt.join)((0,qt.getHdbBasePath)(),Pc),t=(0,qt.get)(U.DATABASES)||{};if(process.env.SCHEMAS_DATA_PATH&&(t.data={path:process.env.SCHEMAS_DATA_PATH}),e=process.env.STORAGE_PATH||(0,qt.get)(U.STORAGE_PATH)||e&&((0,Zn.existsSync)(e)?e:(0,xt.join)((0,qt.getHdbBasePath)(),yE)),!e)return;if((0,Zn.existsSync)(e))for(let n of(0,Zn.readdirSync)(e,{withFileTypes:!0})){let s=(0,xt.basename)(n.name,".mdb");n.isFile()&&(0,xt.extname)(n.name).toLowerCase()===".mdb"&&!t[s]?.path&&ah((0,xt.join)(e,n.name),null,s)}if((0,Zn.existsSync)((0,ju.getBaseSchemaPath)())){for(let n of(0,Zn.readdirSync)((0,ju.getBaseSchemaPath)(),{withFileTypes:!0}))if(!n.isFile()){let s=(0,xt.join)((0,ju.getBaseSchemaPath)(),n.name),i=(0,xt.join)((0,ju.getTransactionAuditStoreBasePath)(),n.name);for(let a of(0,Zn.readdirSync)(s,{withFileTypes:!0}))if(a.isFile()&&(0,xt.extname)(a.name).toLowerCase()===".mdb"){let c=(0,xt.join)(i,a.name);ah((0,xt.join)(s,a.name),(0,xt.basename)(a.name,".mdb"),n.name,c,!0)}}}if(t)for(let n in t){let s=t[n],i=s.path;if((0,Zn.existsSync)(i))for(let c of(0,Zn.readdirSync)(i,{withFileTypes:!0}))c.isFile()&&(0,xt.extname)(c.name).toLowerCase()===".mdb"&&ah((0,xt.join)(i,c.name),(0,xt.basename)(c.name,".mdb"),n);let a=s.tables;if(a)for(let c in a){let l=a[c],u=(0,xt.join)(l.path,(0,xt.basename)(c+".mdb"));(0,Zn.existsSync)(u)&&ah(u,c,n,null,!0)}}for(let n in Ge){let s=Qu.get(n);if(s){let i=Ge[n];n.includes("delete")&&yr.trace(`defined tables ${Array.from(s.keys())}`);for(let a in i)s.has(a)||(yr.trace(`delete table class ${a}`),delete i[a])}else if(delete Ge[n],n==="data"){for(let i in cn)delete cn[i];delete cn[Pg]}}let r=["hdb_temp","hdb_certificate","hdb_raw_analytics","hdb_session_will","hdb_job","hdb_license","hdb_info"];if((0,qt.get)(U.ANALYTICS_REPLICATE)===!1?r.push("hdb_analytics"):(Ge.system?.hdb_analytics?.enableAuditing(),Ge.system?.hdb_analytics_hostname?.enableAuditing()),Ge.system)for(let n of r)Ge.system[n]&&(Ge.system[n].replicate=!1);return Qu=null,Ge}function Zu(){Cg=!1;for(let[,e]of Po)e.needsDeletion=!0;it();for(let[e,t]of Po)if(t.needsDeletion&&!e.endsWith("system.mdb")){t.close(),Po.delete(e);let r=Ge[t.databaseName];for(let n in r)if(r[n].primaryStore.path===e){delete Ge[t.databaseName],lh.forEach(i=>i(t.databaseName));break}}return Ge}function ah(e,t,r=iN,n,s){let i=new nN.default(e,!1);try{let a=Po.get(e);a?a.needsDeletion=!1:(a=(0,Ju.open)(i),Po.set(e,a));let c=new Xu.default(!1),l=a.dbisDb||(a.dbisDb=a.openDB(Ng.INTERNAL_DBIS_NAME,c)),u=a.auditStore;u||(n?(0,Zn.existsSync)(n)&&(i.path=n,u=(0,Ju.open)(i),u.isLegacy=!0):u=l_(a));let d=ik(r),f=d[Pg],m=new Map;for(let{key:h,value:p}of l.getRange({start:!1})){let[_,g]=h.toString().split("/");g===""?g=p.name:g||(g=_,_=t,p.name||(p.name=g,p.indexed=!p.is_hash_attribute)),f?.add(_);let y=m.get(_);y||m.set(_,y={attributes:[]}),(g==null||p.is_hash_attribute)&&(y.primary=p),g!=null&&y.attributes.push(p),Object.defineProperty(p,"key",{value:h,configurable:!0})}for(let[h,p]of m){let{attributes:_,primary:g}=p;if(!g){for(let se of _)if(se.is_hash_attribute||se.isPrimaryKey){g=se;break}if(!g){yr.warn(`Unable to find a primary key attribute on table ${h}, with attributes: ${JSON.stringify(_)}`);continue}}let y=d[h],T={},R=[],I,P,Y=typeof g.audit=="boolean"?g.audit:(0,qt.get)(U.LOGGING_AUDITLOG),te=g.trackDeletes,x=g.expiration,$=g.eviction,j=g.sealed,V=g.splitSegments,le=g.replicate;if(y)T=y.indices,R=y.attributes,y.schemaVersion++;else{I=g.tableId,I?I>=(l.get(zu)||0)&&(l.putSync(zu,I+1),yr.info(`Updating next table id (it was out of sync) to ${I+1} for ${h}`)):(g.tableId=I=l.get(zu),I||(I=1),yr.debug("Table {tableName} missing an id, assigning {tableId}"),l.putSync(zu,I+1),l.putSync(g.key,g));let se=new Xu.default(!g.is_hash_attribute,g.is_hash_attribute);if(se.compression=g.compression,se.compression){let _e=(0,qt.get)(U.STORAGE_COMPRESSION_THRESHOLD)||sk;se.compression.threshold=_e}P=__(a.openDB(g.key,se),a),a.databaseName=r,P.tableId=I}let re;for(let se of _){se.attribute=se.name;try{if(!se.is_hash_attribute&&(se.indexed||se.attribute&&!se.name)){if(!T[se.name]){let Ne=ak(se.key,a,se);T[se.name]=Ne,T[se.name].indexNulls=se.indexNulls}let _e=R.find(Ne=>Ne.name===se.name);_e?R.splice(R.indexOf(_e),1,se):R.push(se),re=!0}}catch(_e){yr.error("Error trying to update attribute",se,R,T,_e)}}for(let se of R)if(!_.find(Ne=>Ne.name===se.name)){if(se.is_hash_attribute){yr.error("Unable to remove existing primary key attribute",se);continue}se.indexed&&(R.splice(R.indexOf(se),1),re=!0)}if(y)re&&(y.schemaVersion++,y.updatedAttributes());else{y=ok(d,h,yg({primaryStore:P,auditStore:u,audit:Y,sealed:j,splitSegments:V,replicate:le,expirationMS:x&&x*1e3,evictionMS:$&&$*1e3,trackDeletes:te,tableName:h,tableId:I,primaryKey:g.name,databasePath:s?r+"/"+h:r,databaseName:r,indices:T,attributes:_,schemaDefined:g.schemaDefined,dbisDB:l})),y.schemaVersion=1;for(let se of ch)se(y)}}return a}catch(a){throw a.message+=` opening database ${e}`,a}}function ik(e){let t=Ge[e];if(t||(e==="data"?t=Ge[e]=cn:e==="system"?Object.defineProperty(Ge,"system",{value:t=Object.create(null),configurable:!0}):t=Ge[e]=Object.create(null)),Qu&&!Qu.has(e)){let r=new Set;t[Pg]=r,Qu.set(e,r)}return t}function ok(e,t,r){return e[t]=r,r}function Hu({database:e,table:t}){e||(e=iN),it();let r=ik(e),n=(0,xt.join)((0,qt.getHdbBasePath)(),Pc),s=(0,qt.get)(U.DATABASES)||{};process.env.SCHEMAS_DATA_PATH&&(s.data={path:process.env.SCHEMAS_DATA_PATH});let i=t&&s[e]?.tables?.[t]?.path;n=i||s[e]?.path||process.env.STORAGE_PATH||(0,qt.get)(U.STORAGE_PATH)||((0,Zn.existsSync)(n)?n:(0,xt.join)((0,qt.getHdbBasePath)(),yE));let a=(0,xt.join)(n,(i?t:e)+".mdb"),c=Po.get(a);if(!c||c.status==="closed"){let l=new nN.default(a,!1);c=(0,Ju.open)(l),Po.set(a,c)}return c.auditStore||(c.auditStore=l_(c)),c}async function dI(e){if(!Ge[e])throw new Error("Schema does not exist");let t=Ge[e],r;for(let n in t)r=t[n].primaryStore.rootStore,Po.delete(r.path),r.status==="open"&&(await r.close(),await uh.remove(r.path));if(r||(r=Hu({database:e,table:null}),r.status==="open"&&(await r.close(),await uh.remove(r.path))),e==="data"){for(let n in cn)delete cn[n];delete cn[Pg]}delete Ge[e],lh.forEach(n=>n(e)),await _A(r)}function ak(e,t,r){let n=r.is_hash_attribute||r.indexed.type&&rN[r.indexed.type]?.useObjectStore,s=new Xu.default(!n,n),i=t.openDB(e,s);if(r.indexed.type){let a=rN[r.indexed.type];a?i.customIndex=new a(i,r.indexed):yr.error(`The indexing type '${r.indexed.type}' is unknown`)}return i}function et(e){let{table:t,database:r,expiration:n,eviction:s,scanInterval:i,attributes:a,audit:c,sealed:l,splitSegments:u,replicate:d,trackDeletes:f,schemaDefined:m,origin:h}=e;r||(r=iN);let p=Hu({database:r,table:t}),_=Ge[r];yr.trace(`Defining ${t} in ${r}`);let g=_?.[t];if(p.status==="closed")throw new Error(`Can not use a closed data store for ${t}`);let y,T,R;m==null&&(m=!0);let I=new Xu.default(!1);for(let V of a)V.attribute&&!V.name?(V.name=V.attribute,V.indexed=!0):V.attribute=V.name,V.expiresAt&&(V.indexed=!0);let P,Y;if(g){if(y=g.primaryKey,g.primaryStore.rootStore.status==="closed")throw new Error(`Can not use a closed data store from ${t} class`);u==null&&(u=g.splitSegments),g.attributes.splice(0,g.attributes.length,...a)}else{let V=p.auditStore;T=a.find(_e=>_e.isPrimaryKey)||{},y=T.name,T.is_hash_attribute=T.isPrimaryKey=!0,T.schemaDefined=m,T.compression=Lg(),f&&(T.trackDeletes=!0),c=T.audit=typeof c=="boolean"?c:(0,qt.get)(U.LOGGING_AUDITLOG),n&&(T.expiration=n),s&&(T.eviction=s),u??=!1,T.splitSegments=u,typeof l=="boolean"&&(T.sealed=l),typeof d=="boolean"&&(T.replicate=d),h&&(T.origins?T.origins.includes(h)||T.origins.push(h):T.origins=[h]),yr.trace(`${t} table loading, opening primary store`);let le=new Xu.default(!1,!0);le.compression=T.compression;let re=t+"/";if(R=p.dbisDb=p.openDB(Ng.INTERNAL_DBIS_NAME,I),j(),R.get(re))return Y&&Y(),Zu(),et(e);let se=__(p.openDB(re,le),p);p.databaseName=r,se.tableId=R.get(zu),yr.trace(`Assigning new table id ${se.tableId} for ${t}`),se.tableId||(se.tableId=1),R.put(zu,se.tableId+1),T.tableId=se.tableId,g=ok(_,t,yg({primaryStore:se,auditStore:V,audit:c,sealed:l,splitSegments:u,replicate:d,trackDeletes:f,expirationMS:n&&n*1e3,evictionMS:s&&s*1e3,primaryKey:y,tableName:t,tableId:se.tableId,databasePath:r,databaseName:r,indices:{},attributes:a,schemaDefined:m,dbisDB:R})),g.schemaVersion=1,P=!0,R.put(re,T)}let te=g.indices;R=R||(p.dbisDb=p.openDB(Ng.INTERNAL_DBIS_NAME,I)),g.dbisDB=R;let x=[];for(let{key:V,value:le}of R.getRange({start:!0})){let[re,se]=V.toString().split("/");if(se===""&&(se=le.name),se){if(re!==t)continue}else continue;let _e=a.find(Fe=>Fe.name===se),Ne=!_e?.indexed&&le.indexed&&!le.isPrimaryKey;if((!_e||Ne)&&(j(),P=!0,_e||R.remove(V),Ne)){let Fe=g.indices[re];Fe&&x.push(Fe)}}let $=[];try{for(let V of a||[]){if((V.relationship||V.computed)&&(P=!0,V.relationship))continue;let le=t+"/"+(V.name||"");Object.defineProperty(V,"key",{value:le,configurable:!0});let re=R.get(le);if(V.isPrimaryKey){if(re=re||R.get(le=t+"/")||{},c!==void 0&&c!==g.audit||l!==void 0&&l!==g.sealed||d!==void 0&&d!==g.replicate||(+n||void 0)!==(+re.expiration||void 0)||(+s||void 0)!==(+re.eviction||void 0)||V.type!==re.type){let _e={...re};typeof c=="boolean"&&(c&&g.enableAuditing(c),_e.audit=c),n&&(_e.expiration=+n),s&&(_e.eviction=+s),l!==void 0&&(_e.sealed=l),d!==void 0&&(_e.replicate=d),V.type&&(_e.type=V.type),P=!0,j(),R.put(le,_e)}continue}re?.attribute&&!re.name&&(re.indexed=!0);let se=!re||re.type!==V.type||JSON.stringify(re.indexed)!==JSON.stringify(V.indexed)||re.nullable!==V.nullable||re.version!==V.version||JSON.stringify(re.properties)!==JSON.stringify(V.properties)||JSON.stringify(re.elements)!==JSON.stringify(V.elements);if(V.indexed){let _e=ak(le,p,V);(se||re.indexingPID&&re.indexingPID!==process.pid||re.restartNumber<dh.workerData?.restartNumber)&&(P=!0,j(),re=R.get(le),(se||re.indexingPID&&re.indexingPID!==process.pid||re.restartNumber<dh.workerData?.restartNumber)&&(P=!0,V.indexNulls===void 0&&(V.indexNulls=!0),g.primaryStore.getStats().entryCount>0&&(V.lastIndexedKey=re?.lastIndexedKey??void 0,V.indexingPID=process.pid,_e.isIndexing=!0,Object.defineProperty(V,"dbi",{value:_e}),$.push(V))),R.put(le,V)),re?.indexNulls&&V.indexNulls===void 0&&(V.indexNulls=!0),_e.indexNulls=V.indexNulls,te[V.name]=_e}else se&&(P=!0,j(),R.put(le,V))}}finally{Y&&Y()}if(P&&(g.schemaVersion++,g.updatedAttributes()),yr.trace(`${t} table loading, running index`),$.length>0||x.length>0?g.indexingOperation=Ose(g,$,x):P&&wg.signalSchemaChange(new Og.SchemaEventMsg(process.pid,"schema-change",g.databaseName,g.tableName)),g.origin=h,P)for(let V of ch)V(g,h!=="cluster");return(n||s||i)&&g.setTTLExpiration({expiration:n,eviction:s,scanInterval:i}),yr.trace(`${t} table loaded`),g;function j(){Y||p.transactionSync(()=>({then(V){Y=V}}))}o(j,"startTxn")}async function Ose(e,t,r){try{yr.info(`Indexing ${e.tableName} attributes`,t);let n=e.schemaVersion;await wg.signalSchemaChange(new Og.SchemaEventMsg(process.pid,"schema-change",e.databaseName,e.tableName));let s;for(let u of r)s=u.drop();let i,a={},c=0,l=t.length;if(await new Promise(u=>setImmediate(u)),l>0){let u;for(let f of t)(0,Ju.compareKeys)(f.lastIndexedKey,u)<0&&(u=f.lastIndexedKey),f.lastIndexedKey==null&&f.dbi.clearAsync();let d=0;for(let{key:f,value:m,version:h}of e.primaryStore.getRange({start:u,lazy:l<4,versions:!0,snapshot:!1}))if(m){if(d++,s=e.primaryStore.ifVersion(f,h,()=>{for(let p=0;p<l;p++){let _=t[p],g=_.name,y=_.dbi;try{let T=_.resolve,R=m&&(T?T(m):m[g]);if(y.customIndex){y.customIndex.index(f,R);continue}let I=(0,tk.getIndexedValues)(R);if(I)for(let P=0,Y=I.length;P<Y;P++)y.put(I[P],f)}catch(T){a[g]||(a[g]=!0,yr.error(`Error indexing attribute ${g}`,T))}}}),s.then(()=>d--,p=>{d--,yr.error(p)}),dh.workerData&&dh.workerData.restartNumber!==nk.restartNumber&&(i=!0),++c%100===0||i){for(let p of t)p.lastIndexedKey=f,e.dbisDB.put(p.key,p);if(i)return}d>Nse?await s:d>wse&&await new Promise(p=>setImmediate(p))}for(let f of t)delete f.lastIndexedKey,delete f.indexingPID,f.dbi.isIndexing=!1,s=e.dbisDB.put(f.key,f)}await s,await wg.signalSchemaChange(new Og.SchemaEventMsg(process.pid,"indexing-finished",e.databaseName,e.tableName)),yr.info(`Finished indexing ${e.tableName} attributes`,t)}catch(n){yr.error("Error in indexing",n)}}function Cse({table:e,database:t}){let r=Hu({database:t,table:e}),n=[],s=r.dbisDb;for(let i of s.getKeys({start:e+"/",end:e+"0"}))n.push(s.remove(i));return Promise.all(n)}function gl(e){return ch.push(e),{remove(){let t=ch.indexOf(e);t>-1&&ch.splice(t,1)}}}function fh(e){return lh.push(e),{remove(){let t=lh.indexOf(e);t>-1&&lh.splice(t,1)}}}function Lg(){let e=(0,qt.get)(U.STORAGE_COMPRESSION),t=(0,qt.get)(U.STORAGE_COMPRESSION_DICTIONARY),r=(0,qt.get)(U.STORAGE_COMPRESSION_THRESHOLD)||sk,n={startingOffset:32};return t&&(n.dictionary=uh.readFileSync(t)),r&&(n.threshold=r),e&&n}var qt,Ng,Ju,xt,Zn,ju,Xu,nN,uh,sN,tk,wg,Og,dh,rk,nk,yr,iN,Pg,sk,cn,Ge,zu,ch,lh,Cg,Po,Qu,Nse,wse,Le=fe(()=>{qt=w(ce()),Ng=w(kt()),Ju=require("lmdb"),xt=require("path"),Zn=require("fs"),ju=w(At());Sm();Xu=w(Tm()),nN=w(Rm());k();uh=w(require("fs-extra")),sN=w(Ws()),tk=w(An()),wg=w(bo()),Og=w(ti()),dh=require("worker_threads"),rk=w(z()),nk=w(st());uo();Yc();Ts();ek();yr=(0,rk.forComponent)("storage"),iN="data",Pg=Symbol("defined-tables"),sk=((0,qt.get)(U.STORAGE_PAGESIZE)||4096)-60;(0,qt.initSync)();cn=Object.create(null),Ge=Object.create(null);(0,sN._assignPackageExport)("databases",Ge);(0,sN._assignPackageExport)("tables",cn);zu=Symbol.for("next-table-id"),ch=[],lh=[],Po=new Map;o(Ise,"getTables");o(it,"getDatabases");o(Zu,"resetDatabases");o(ah,"readMetaDb");o(ik,"ensureDB");o(ok,"setTable");o(Hu,"database");o(dI,"dropDatabase");o(ak,"openIndex");o(et,"table");Nse=1e3,wse=10;o(Ose,"runIndexing");o(Cse,"dropTableMeta");o(gl,"onUpdatedTable");o(fh,"onRemovedDB");o(Lg,"getDefaultCompression")});var cN={};Ce(cN,{loadGQLSchema:()=>Dse,start:()=>aN,startOnMainThread:()=>Lse});function aN({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r,n,s,i){let{parse:a,Source:c,Kind:l,NamedTypeNode:u,StringValueNode:d}=await import("graphql"),f=a(new c(r.toString(),s)),m=new Map,h=[],p;for(let y of f.definitions)switch(y.kind){case l.OBJECT_TYPE_DEFINITION:let Y=function(x){if(x.kind==="NonNullType"){let V=Y(x.type);return V.nullable=!1,V}if(x.kind==="ListType")return{type:"array",elements:Y(x.type)};let j={type:x.name?.value};return Object.defineProperty(j,"location",{value:x.loc.startToken}),j};o(Y,"getProperty");let T=y.name.value,R=[],I={table:null,database:null,properties:R};m.set(T,I);for(let x of y.directives){if(x.name.value==="table"){for(let j of x.arguments)I[j.name.value]=j.value.value;I.schema&&(I.database=I.schema),I.table||(I.table=T),I.audit&&(I.audit=I.audit!=="false"),I.attributes=I.properties,h.push(I)}if(x.name.value==="sealed"&&(I.sealed=!0),x.name.value==="splitSegments"&&(I.splitSegments=!0),x.name.value==="replicate"&&(I.replicate=!0),x.name.value==="export"){I.export=!0;for(let j of x.arguments)typeof I.export!="object"&&(I.export={}),I.export[j.name.value]=j.value.value}}let P=!1,te={};for(let x of y.fields){let $=Y(x.type);$.name=x.name.value,R.push($),te[$.name]=void 0;for(let j of x.directives){let V=j.name.value;if(V==="primaryKey")P?console.warn("Can not define two attributes as a primary key at",j.loc):($.isPrimaryKey=!0,P=!0);else if(V==="indexed"){let le={};for(let re of j.arguments||[])le[re.name.value]=re.value.value;$.indexed=le}else if(V==="computed"){for(let le of j.arguments||[])if(le.name.value==="from"){let re=le.value.value;$.computed={from:g(re,le,te)},$.version==null&&($.version=re)}else le.name.value==="version"&&($.version=le.value.value);$.computed=$.computed||!0}else if(V==="relationship"){let le={};for(let re of j.arguments)le[re.name.value]=re.value.value;$.relationship=le}else if(V==="createdTime")$.assignCreatedTime=!0;else if(V==="updatedTime")$.assignUpdatedTime=!0;else if(V==="expiresAt")$.expiresAt=!0;else if(V==="allow"){let le=$.authorizedRoles=[];for(let re of j.arguments)re.name.value==="role"&&le.push(re.value.value)}else server.knownGraphQLDirectives.includes(V)&&console.warn(`@${V} is an unknown directive, at`,j.loc)}}I.type=T,T==="Query"&&(p=I)}function _(y){let T=m.get(y.type);T?(Object.defineProperty(y,"properties",{value:T.properties}),Object.defineProperty(y,"definition",{value:T})):y.type==="array"?_(y.elements):Pse.includes(y.type)||(0,lk.getWorkerIndex)()===0&&console.error(`The type ${y.type} is unknown at line ${y.location.line}, column ${y.location.column}, in ${s}`)}o(_,"connectPropertyType");for(let y of m.values())for(let T of y.properties)_(T);for(let y of h)y.tableClass=e(y),y.export&&(y.export.name===""?i.set((0,oN.dirname)(n),y.tableClass):i.set((0,oN.dirname)(n)+"/"+(y.export.name||y.type),y.tableClass,y.export));function g(y,T,R){return new ck.Script(`function computed(attributes) { return function(record) { with(attributes) { with (record) { return ${y}; } } } } computed;`,{filename:s,lineOffset:T.loc.startToken.line-1,columnOffset:T.loc.startToken.column}).runInThisContext()(R)}o(g,"createComputedFrom")}}var oN,ck,lk,Pse,Lse,Dse,uk=fe(()=>{oN=require("path"),ck=require("node:vm");Le();lk=w(st()),Pse=["ID","Int","Float","Long","String","Boolean","Date","Bytes","Any","BigInt","Blob"];server.knownGraphQLDirectives&&(server.knownGraphQLDirectives=["table","sealed","export","primaryKey","indexed","computed","relationship","createdTime","updatedTime","expiresAt","allow"]);o(aN,"start");Lse=aN,Dse=aN({ensureTable:et}).handleFile});var uN={};Ce(uN,{start:()=>Gse});function Mse(e){if(e.kind!==Be.Kind.OPERATION_DEFINITION&&e.kind!==Be.Kind.FRAGMENT_DEFINITION)throw new Ur(`Unexpected non-executable definition type ${e.kind}.`)}function dk(e){if(typeof e!="object"||e===null)throw new Gi("Request body must be an object.");if(!("query"in e))throw new Gi("Request body must contain a `query` field.");if(typeof e.query!="string")throw new Gi("Request body `query` field must be a string.");if("variables"in e&&(typeof e.variables!="object"||e.variables===null))throw new Gi("Request body `variables` field must be an object.");if("operationName"in e&&typeof e.operationName!="string")throw new Gi("Request body `operationName` field must be a string.")}function lN(e){return parseInt(e.value,10)}function mk(e){return parseFloat(e.value)}function hk(e,t,r){let n=r.get(e.name.value);return pk(n)?Ek(n,t):{attribute:t,value:n}}function pk(e){return typeof e=="object"&&e!=null&&!Array.isArray(e)}function Ek(e,t){return t=typeof t=="string"?[t]:t,Object.entries(e).flatMap(([r,n])=>(t=[...t,r],pk(n)?Ek(n,t):{attribute:t,value:n}))}function vse(e,t,r){switch(t=[...t,e.name.value],e.value.kind){case Be.Kind.NULL:return{attribute:t,value:null};case Be.Kind.INT:return{attribute:t,value:lN(e.value)};case Be.Kind.FLOAT:return{attribute:t,value:mk(e.value)};case Be.Kind.BOOLEAN:case Be.Kind.STRING:return{attribute:t,value:e.value.value};case Be.Kind.VARIABLE:return hk(e.value,t,r);case Be.Kind.OBJECT:return _k(e.value,t,r);case Be.Kind.LIST:case Be.Kind.ENUM:default:throw new Ur(`Value type, ${e.value.kind}, is not supported.`)}}function _k(e,t,r){return e.fields.flatMap(n=>vse(n,t,r))}function Use(e,t){switch(e.value.kind){case Be.Kind.NULL:return{attribute:e.name.value,value:null};case Be.Kind.INT:return{attribute:e.name.value,value:lN(e.value)};case Be.Kind.FLOAT:return{attribute:e.name.value,value:mk(e.value)};case Be.Kind.BOOLEAN:case Be.Kind.STRING:return{attribute:e.name.value,value:e.value.value};case Be.Kind.VARIABLE:return hk(e.value,e.name.value,t);case Be.Kind.OBJECT:return _k(e.value,[e.name.value],t);case Be.Kind.LIST:case Be.Kind.ENUM:default:throw new Ur(`Argument type, ${e.value.kind}, is not supported.`)}}function xse(e,t){return e.flatMap(r=>Use(r,t))}function Dg(e,t){return e.selections.flatMap(r=>{switch(r.kind){case Be.Kind.FIELD:return r;case Be.Kind.FRAGMENT_SPREAD:{let n=r.name.value,s=t.get(n);if(s==null)throw new Ur(`Fragment \`${n}\` not found.`);return Dg(s.selectionSet,t)}case Be.Kind.INLINE_FRAGMENT:return Dg(r.selectionSet,t)}})}function gk(e,t){return Dg(e,t).map(r=>r.selectionSet?.selections.length>0?{name:r.name.value,select:gk(r.selectionSet,t)}:r.name.value)}async function Bse(e,t,r,n){let s=As.getMatch(e.name.value,"graphql");if(s===void 0)throw new Ur(`Resource \`${e.name.value}\` not found.`);let i=s.Resource,a={select:gk(e.selectionSet,r),conditions:xse(e.arguments,t)},c=[];n.authorize=!0;for await(let l of i.search(a,n))c.push(l);return[e.name.value,c]}function Sk(e){switch(e.kind){case Be.Kind.NULL:return null;case Be.Kind.INT:return lN(e);case Be.Kind.FLOAT:return parseFloat(e.value);case Be.Kind.STRING:case Be.Kind.BOOLEAN:return e.value;case Be.Kind.OBJECT:return e.fields.reduce((t,r)=>({[r.name.value]:Sk(r.value),...t}),{});case Be.Kind.LIST:case Be.Kind.ENUM:default:throw new Ur(`Value type, ${e.kind}, is not supported.`)}}function Fse(e,t){let r=new Map;for(let n of e){let s=n.variable.name.value,i=t?.[s];if(i===void 0&&n.defaultValue!==void 0&&(i=Sk(n.defaultValue)),n.type.kind===Be.Kind.NON_NULL_TYPE&&!(s in t)&&i===void 0)throw new Ur(`Variable $${s} is required, but not provided.`);r.set(n.variable.name.value,i??null)}return r}async function Hse(e,t,r,n){if(e.operation===Be.OperationTypeNode.SUBSCRIPTION)throw new Ur("Subscriptions are not supported.");if(e.operation===Be.OperationTypeNode.MUTATION)throw new Ur("Mutations are not supported yet.");let s=Fse(e.variableDefinitions,t),i=await Promise.all(Dg(e.selectionSet,r).map(c=>Bse(c,s,r,n))),a={data:{}};for(let[c,l]of i)a.data[c]=l;return a}async function fk({query:e,variables:t={},operationName:r},n){let s=Be.parse(e),i=new Map,a=new Map;for(let u of s.definitions)if(Mse(u),u.kind===Be.Kind.FRAGMENT_DEFINITION)a.set(u.name.value,u);else{if(u.name===void 0&&s.definitions.length>1)throw new Ur("Unnamed operations are only allowed when there is a single operation in the document.");let d=u.name?.value??"Unnamed Query";if(i.has(d))throw new Ur(`Duplicate operation definition: ${d}`);i.set(d,u)}let c;if(r==null)if(i.size===1)c=i.entries().next().value[1];else throw new Ur("Operation name is required when there are multiple operations in the document.");else if(c=i.get(r),c==null)throw new Ur(`Operation \`${r}\` not found.`);let l=await Hse(c,t,a,n);return{status:200,headers:{"Content-Type":"application/graphql-response+json; charset=utf-8"},body:JSON.stringify(l)}}async function kse(e){switch(e.method){case"GET":{let t=new URLSearchParams(e.url.split("?")[1]),r={};for(let[n,s]of t)r[n]=n==="variables"||n==="extensions"?JSON.parse(s):s;return dk(r),fk(r,e)}case"POST":{let r=await ho(e.headers.get("content-type"),!0)(e._nodeRequest);return dk(r),fk(r,e)}default:throw new Gi("Method Not Allowed",405,{Allow:"GET, POST"})}}function Gse(e){e.server.http(async(t,r)=>{if(!t.url.startsWith("/graphql"))return r(t);try{return await kse(t)}catch(n){logger.error(n);let s=t.headers.get("accept")??"application/graphql-response+json";switch(s){case"application/json":{if(n instanceof Gi)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json",...n.headers}};if(n instanceof Be.GraphQLError)return{status:200,body:JSON.stringify({errors:[n]}),headers:{"Content-Type":"application/json"}};if(n instanceof Ur)return{status:200,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json"}};if(n instanceof Error)return{status:500,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json"}};break}default:logger.info(`Unsupported accept header, ${s}, defaulting to application/graphql-response+json`);case"application/graphql-response+json":{if(n instanceof Gi)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json",...n.headers}};if(n instanceof Be.GraphQLError)return{status:400,body:JSON.stringify({errors:[n]}),headers:{"Content-Type":"application/graphql-response+json"}};if(n instanceof Ur)return{status:400,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json"}};if(n instanceof Error)return{status:500,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json"}};break}}throw n}},{port:e.port,securePort:e.securePort})}var Be,Ur,Gi,Tk=fe(()=>{Be=w(require("graphql"));po();Pu();o(Mse,"assertExecutableDefinitionNode");o(dk,"assertRequestParams");o(lN,"processIntValueNode");o(mk,"processFloatValueNode");o(hk,"processVariableNode");o(pk,"isObject");o(Ek,"transformObjectIntoQueryCondition");o(vse,"processObjectFieldNode");o(_k,"processObjectValueNode");o(Use,"processArgumentNode");o(xse,"buildConditionsQuery");o(Dg,"fillInFragments");o(gk,"buildSelectQuery");o(Bse,"processFieldNode");o(Sk,"processConstValueNode");o(Fse,"resolveVariables");o(Hse,"executeOperation");o(fk,"resolver");Ur=class extends Error{static{o(this,"GraphQLQueryingError")}},Gi=class extends Error{static{o(this,"HTTPError")}statusCode;headers;constructor(t,r=400,n={}){super(t),this.statusCode=r,this.headers=n}};o(kse,"graphqlQueryingHandler");o(Gse,"start")});var Nk=M((NLe,Ik)=>{var ed=require("validate.js"),yk=at(),td=(k(),v(K)),{handleHDBError:qse,hdbErrors:$se}=Ee(),{HDB_ERROR_MSGS:Xt,HTTP_STATUS_CODES:Vse}=$se,dN=o(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),Kse={STRUCTURE_USER:"structure_user"},Rk=Object.values(td.ROLE_TYPES_ENUM),Yse="attribute_permissions",Wse="attribute_name",{PERMS_CRUD_ENUM:rd}=td,zse=[Yse,...Object.values(rd)],Ak=[rd.READ,rd.INSERT,rd.UPDATE],jse=[Wse,...Ak];function Qse(e){let t=dN();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,bk(e,t)}o(Qse,"addRoleValidation");function Jse(e){let t=dN();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,bk(e,t)}o(Jse,"alterRoleValidation");function Xse(e){let t=dN();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,yk.validateObject(e,t)}o(Xse,"dropRoleValidation");var Zse=["operation","role","id","permission","hdb_user","access"];function bk(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let a=0,c=n.length;a<c;a++)Zse.includes(n[a])||s.push(n[a]);s.length>0&&cr(Xt.INVALID_ROLE_JSON_KEYS(s),r);let i=yk.validateObject(e,t);if(i&&i.message.split(",").forEach(a=>{cr(a,r)}),e.permission){let a=eie(e);a&&cr(a,r),Rk.forEach(c=>{e.permission[c]&&!ed.isBoolean(e.permission[c])&&cr(Xt.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let a in e.permission)if(Rk.indexOf(a)<0){if(a===Kse.STRUCTURE_USER){let l=e.permission[a];if(typeof l=="boolean")continue;if(Array.isArray(l)){for(let u=0,d=l.length;u<d;u++){let f=l[u];global.hdb_schema[f]||cr(Xt.SCHEMA_NOT_FOUND(f),r)}continue}cr(Xt.STRUCTURE_USER_ROLE_TYPE_ERROR(a),r);continue}let c=e.permission[a];if(!a||!global.hdb_schema[a]){cr(Xt.SCHEMA_NOT_FOUND(a),r);continue}if(c.tables)for(let l in c.tables){let u=c.tables[l];if(!l||!global.hdb_schema[a][l]){cr(Xt.TABLE_NOT_FOUND(a,l),r);continue}if(Object.keys(u).forEach(d=>{zse.includes(d)||cr(Xt.INVALID_PERM_KEY(d),r,a,l)}),Object.values(rd).forEach(d=>{ed.isDefined(u[d])?ed.isBoolean(u[d])||cr(Xt.TABLE_PERM_NOT_BOOLEAN(d),r,a,l):cr(Xt.TABLE_PERM_MISSING(d),r,a,l)}),u.attribute_permissions===void 0){cr(Xt.ATTR_PERMS_ARRAY_MISSING,r,a,l);continue}else if(!(Array.isArray(u.attribute_permissions)||u.attribute_permissions===null)){cr(Xt.ATTR_PERMS_NOT_ARRAY,r,a,l);continue}if(u.attribute_permissions){let d=global.hdb_schema[a][l].attributes.map(({attribute:m})=>m),f={read:!1,insert:!1,update:!1};for(let m in u.attribute_permissions){let h=u.attribute_permissions[m];if(Object.keys(h).forEach(_=>{!jse.includes(_)&&_!==rd.DELETE&&cr(Xt.INVALID_ATTR_PERM_KEY(_),r,a,l)}),!ed.isDefined(h.attribute_name)){cr(Xt.ATTR_PERM_MISSING_NAME,r,a,l);continue}let p=h.attribute_name;if(!d.includes(p)){cr(Xt.INVALID_ATTRIBUTE_IN_PERMS(p),r,a,l);continue}Ak.forEach(_=>{ed.isDefined(h[_])?ed.isBoolean(h[_])||cr(Xt.ATTR_PERM_NOT_BOOLEAN(_,p),r,a,l):cr(Xt.ATTR_PERM_MISSING(_,p),r,a,l)}),!f.read&&h.read===!0&&(f.read=!0),!f.insert&&h.insert===!0&&(f.insert=!0),!f.update&&h.update===!0&&(f.update=!0)}if(u.read===!1&&f.read===!0||u.insert===!1&&f.insert===!0||u.update===!1&&f.update===!0){let m=`${a}.${l}`;cr(Xt.MISMATCHED_TABLE_ATTR_PERMS(m),r,a,l)}}}}return tie(r)}o(bk,"customValidate");Ik.exports={addRoleValidation:Qse,alterRoleValidation:Jse,dropRoleValidation:Xse};function eie(e){let{operation:t,permission:r}=e;if(t===td.OPERATIONS_ENUM.ADD_ROLE||t===td.OPERATIONS_ENUM.ALTER_ROLE){let n=r.super_user===!0,s=r.cluster_user===!0;if(Object.keys(r).length>1&&(n||s)){if(s&&n)return Xt.SU_CU_ROLE_COMBINED_ERROR;{let a=r.super_user?td.ROLE_TYPES_ENUM.SUPER_USER:td.ROLE_TYPES_ENUM.CLUSTER_USER;return Xt.SU_CU_ROLE_NO_PERMS_ALLOWED(a)}}}return null}o(eie,"validateNoSUPerms");function tie(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:Xt.ROLE_PERMS_ERROR,...e};return qse(new Error,n,Vse.BAD_REQUEST)}else return null}o(tie,"generateRolePermResponse");function cr(e,t,r,n){if(!r)t.main_permissions.push(e);else{let s=n?r+"_"+n:r;t.schema_permissions[s]?t.schema_permissions[s].push(e):t.schema_permissions[s]=[e]}}o(cr,"addPermError")});var hh=M((CLe,Pk)=>{"use strict";var wk=Mn(),Ok=on(),rie=dl(),mN=Nk(),hN=bo(),OLe=require("uuid").v4,nie=require("util"),Mg=(k(),v(K)),sie=ie(),pN=Ok.searchByValue,iie=Ok.searchByHash,oie=nie.promisify(rie.delete),aie=ri(),cie=Bu(),{hdbErrors:lie,handleHDBError:Sl}=Ee(),{HDB_ERROR_MSGS:Ck,HTTP_STATUS_CODES:mh}=lie,{UserEventMsg:EN}=ti();Pk.exports={addRole:uie,alterRole:die,dropRole:fie,listRoles:mie};function fN(e){try{e.hdb_auth_header&&delete e.hdb_auth_header,e.HDB_INTERNAL_PATH&&delete e.HDB_INTERNAL_PATH,e.operation&&delete e.operation,e.hdb_user&&delete e.hdb_user}catch{}return e}o(fN,"scrubRoleDetails");async function uie(e){let t=mN.addRoleValidation(e);if(t)throw t;e=fN(e);let r={schema:"system",table:"hdb_role",search_attribute:"role",search_value:e.role,hash_attribute:"id",get_attributes:["*"]},n;try{n=Array.from(await pN(r)||[])}catch(i){throw Sl(i)}if(n&&n.length>0)throw Sl(new Error,Ck.ROLE_ALREADY_EXISTS(e.role),mh.CONFLICT,void 0,void 0,!0);e.id||(e.id=e.role);let s={operation:"insert",schema:"system",table:"hdb_role",hash_attribute:"id",records:[e]};return await wk.insert(s),hN.signalUserChange(new EN(process.pid)),e=fN(e),e}o(uie,"addRole");async function die(e){let t=mN.alterRoleValidation(e);if(t)throw t;e=fN(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await wk.update(r)}catch(s){throw Sl(s)}if(n&&n?.message==="updated 0 of 1 records")throw Sl(new Error,"Invalid role id",mh.BAD_REQUEST,void 0,void 0,!0);return await hN.signalUserChange(new EN(process.pid)),e}o(die,"alterRole");async function fie(e){let t=mN.dropRoleValidation(e);if(t)throw Sl(new Error,t,mh.BAD_REQUEST,void 0,void 0,!0);let r=new cie(Mg.SYSTEM_SCHEMA_NAME,Mg.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await iie(r));if(n.length===0)throw Sl(new Error,Ck.ROLE_NOT_FOUND,mh.NOT_FOUND,void 0,void 0,!0);let s=new aie(Mg.SYSTEM_SCHEMA_NAME,Mg.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await pN(s)),a=!1;if(sie.isEmptyOrZeroLength(i)===!1){for(let l=0;l<i.length;l++)if(i[l].active===!0){a=!0;break}}if(a===!0)throw Sl(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,mh.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await oie(c),hN.signalUserChange(new EN(process.pid)),`${n[0].role} successfully deleted`}o(fie,"dropRole");async function mie(){return pN({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}o(mie,"listRoles")});var _N={};Ce(_N,{start:()=>Mk,startOnMainThread:()=>Eie});function Mk({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r){let n=(0,Lk.parseDocument)(r.toString(),{simpleKeys:!0}).toJSON();for(let s in n){let i=n[s];i.permission||(i={permission:i},i.permission.access&&(i.access=i.permission.access,delete i.permission.access));for(let a in i.permission){if(hie.includes(a))continue;let c=i.permission[a];c.tables||(i.permission[a]=c={tables:c});for(let l in c.tables){let u=c.tables[l];if(u.read=!!u.read,u.insert=!!u.insert,u.update=!!u.update,u.delete=!!u.delete,u.attributes){let d=[];for(let f in u.attributes){let m=u.attributes[f];m.attribute_name=f,d.push(m)}u.attribute_permissions=d,delete u.attributes}if(u.attribute_permissions){if(!Array.isArray(u.attribute_permissions))throw new Error("attribute_permissions must be an array if defined");for(let d of u.attribute_permissions)d.read=!!d.read,d.insert=!!d.insert,d.update=!!d.update}else u.attribute_permissions=null}}i.role=i.id=s,await pie(i)}}}async function pie(e){let t=it().system.hdb_role;for await(let r of t.search([{attribute:"role",value:e.role}])){let{__createdtime__:n,__updatedtime__:s,...i}=r;return(0,Dk.isEqual)(i,e)?void 0:(e.id=r.id,(0,vg.alterRole)(e))}return(0,vg.addRole)(e)}var vg,Lk,Dk,hie,Eie,vk=fe(()=>{Le();vg=w(hh()),Lk=require("yaml"),Dk=require("lodash"),hie=["super_user","cluster_user","structure_user"];o(Mk,"start");o(pie,"ensureRole");Eie=Mk});async function Ug(e){let t=(0,Bk.pathToFileURL)(e).toString();if(_ie)return ph||(ph=gie(Tie)),(await(await ph).import(t)).namespace;try{return await import(t)}catch(r){try{(await import("internal/util")).default.decorateErrorStack(r)}catch{}throw r}}async function gie(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),ph=new Compartment({console,Math,Date,fetch:Sie,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,xk.extname)(r)||(r+=".js"),r)},importHook:o(async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){s.Resource=Dr,s.tables=cn,s.databases=Ge}};let n=await(0,Uk.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)},"importHook")}),ph}function Sie(e,t){let r=typeof e=="string"||e.url;if(new URL(r).protocol!="https")throw new Error("Only https is allowed in fetch");return fetch(e,t)}function Tie(){return{Resource:Dr,tables:cn}}var Uk,xk,Bk,_ie,ph,gN=fe(()=>{ba();Le();Uk=require("fs/promises"),xk=require("path"),Bk=require("url"),_ie=!1;o(Ug,"secureImport");o(gie,"getCompartment");o(Sie,"secureOnlyFetch");o(Tie,"getGlobalVars")});var SN={};Ce(SN,{handleApplication:()=>Rie,suppressHandleApplicationWarning:()=>yie});function Fk(e){return typeof e=="function"&&("get"in e||"put"in e||"post"in e||"delete"in e)}async function Rie(e){e.handleEntry(t=>{if(t.entryType!=="file"){e.logger.warn(`jsResource plugin cannot handle entry type ${t.entryType}. Modify the 'files' option in ${e.configFilePath} to only include files.`);return}if(t.eventType!=="add"){e.requestRestart();return}Ug(t.absolutePath).then(r=>{let n=(0,xg.dirname)(t.urlPath);Fk(r.default)&&(e.resources.set(n,r.default),e.logger.debug(`Registered root resource: ${n}`)),Hk(e,r,n)}).catch(r=>{e.logger.error(`Failed to load resource module ${t.absolutePath}: ${r}`),e.requestRestart()})})}function Hk(e,t,r){for(let n in t){let s=t[n],i=(0,xg.join)(r,n);Fk(s)?(e.resources.set(i,s),e.logger.debug(`Registered resource: ${i}`)):typeof s=="object"&&Hk(e,s,i)}}var xg,yie,kk=fe(()=>{gN();xg=require("path");o(Fk,"isResource");o(Rie,"handleApplication");o(Hk,"recurseForResources");yie=!0});var RN={};Ce(RN,{start:()=>Aie});function Aie({resources:e}){e.set("login",TN),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var TN,Gk=fe(()=>{ba();o(Aie,"start");TN=class extends Dr{static{o(this,"Login")}static async get(t,r,n){}static async post(t,r,n){let{username:s,password:i,redirect:a}=r;return{data:await n.login(s,i)}}}});function Yk(e){let t={openapi:bie,info:{title:"HarperDB HTTP REST interface",version:Kk.packageJson.version},paths:{},components:{schemas:{},securitySchemes:{basicAuth:{type:"http",scheme:"basic"},bearerAuth:{type:"http",scheme:"bearer",bearerFormat:"JWT"}}}},r=[{basicAuth:[],bearerAuth:[]}];for(let[,n]of e){if(!n.path||n.Resource.isError)continue;let{path:s}=n,i=s.split("/").slice(-1),{attributes:a,primaryKey:c,prototype:l}=n.Resource;if(c=c??"id",!c)continue;let u={},d=[];if(a)for(let{type:R,name:I,elements:P,relationship:Y,definition:te}of a){if(Y)R==="array"?u[I]={type:"array",items:{$ref:xa+P.type}}:u[I]={$ref:xa+R};else{let x=te??P?.definition;if(x){if(!t.components.schemas[x.type]){let $={};x.properties.forEach(j=>{$[j.name]=new IN(yN[j.type],j.type)}),t.components.schemas[x.type]=new Vk($)}R==="array"?u[I]={type:"array",items:{$ref:xa+x.type}}:u[I]={$ref:xa+x.type}}else R==="array"?P.type==="Any"||P.type=="ID"?u[I]={type:"array",items:{format:P.type}}:u[I]={type:"array",items:new IN(yN[P.type],P.type)}:R==="Any"||R=="ID"?u[I]={format:R}:u[I]=new IN(yN[R],R)}d.push(new NN(I,"query",u[I]))}let f=Object.keys(u),m=new NN(c,"path",{format:"ID"});m.required=!0,m.description="primary key of record";let h=new NN("property","path",{enum:f});h.required=!0,t.components.schemas[i]=new Vk(u);let p=l.post!==Resource.prototype.post||l.update,_=typeof l.put=="function",g=typeof l.get=="function",y=typeof l.delete=="function",T="/"+s+"/";p&&(t.paths[T]={},t.paths[T].post=new Iie(i,r,"create a new record auto-assigning a primary key")),g&&(t.paths[T]||(t.paths[T]={}),t.paths[T].get=new AN(d,r,{200:new bN({$ref:xa+i})},"search for records by the specified property name and value pairs")),y&&(t.paths[T]||(t.paths[T]={}),t.paths[T].delete=new $k(d,r,"delete all the records that match the provided query",{204:new qk})),T="/"+s+"/{"+c+"}",g&&(t.paths[T]={},t.paths[T].get=new AN([m],r,{200:new bN({$ref:xa+i})},"retrieve a record by its primary key")),_&&(t.paths[T]||(t.paths[T]={}),t.paths[T].put=new Nie([m],r,i,"create or update the record with the URL path that maps to the record's primary key")),y&&(t.paths[T]||(t.paths[T]={}),t.paths[T].delete=new $k([m],r,"delete a record with the given primary key",{204:new qk})),g&&h.schema.enum.length>0&&(T="/"+s+"/{"+c+"}.{property}",t.paths[T]={},t.paths[T].get=new AN([m,h],r,{200:new bN({enum:f})},"used to retrieve the specified property of the specified record"))}return t}function Iie(e,t,r){this.description=r,this.requestBody={content:{"application/json":{schema:{$ref:xa+e}}}},this.security=t,this.responses={200:{description:wN,headers:{Location:{description:"primary key of new record",schema:{type:"string",format:"ID"}}},content:{"application/json":{schema:{type:"string",format:"ID"}}}}}}function AN(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.responses=r}function bN(e){this.description=wN,this.content={"application/json":{schema:e}}}function qk(){this.description="successfully processed request, no content returned to client"}function Nie(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.requestBody={content:{"application/json":{schema:{$ref:xa+r}}}},this.responses={200:{description:wN}}}function $k(e,t,r,n){this.description=r,this.parameters=e,this.security=t,this.responses=n}function Vk(e){this.type="object",this.properties=e}function IN(e,t){this.type=e,this.format=t}function NN(e,t,r){this.name=e,this.in=t,this.schema=r}var Kk,bie,yN,xa,wN,Wk=fe(()=>{Kk=w(Rt()),bie="3.0.3",yN={Int:"integer",Float:"number",Long:"integer",String:"string",Boolean:"boolean",Date:"string",Bytes:"string",BigInt:"integer",array:"array"},xa="#/components/schemas/",wN="successful operation";o(Yk,"generateJsonApi");o(Iie,"Post");o(AN,"Get");o(bN,"Response200");o(qk,"Response204");o(Nie,"Put");o($k,"Delete");o(Vk,"ResourceSchema");o(IN,"Type");o(NN,"Parameter")});var jk={};Ce(jk,{Request:()=>Ba,createReuseportFd:()=>Bg});var zk,Ba,ON,CN,Bg,Eh=fe(()=>{zk=require("os"),Ba=class{static{o(this,"Request")}#e;constructor(t,r){this.method=t.method;let n=t.url;this._nodeRequest=t,this._nodeResponse=r,this.url=n,this.headers=new CN(t.headers)}get absoluteURL(){return this.protocol+"://"+this.host+this.url}get pathname(){let t=this.url.indexOf("?");return t>-1?this.url.slice(0,t):this.url}set pathname(t){let r=this.url.indexOf("?");r>-1?this.url=t+this.url.slice(r):this.url=t}get protocol(){return this._nodeRequest.socket.encrypted?"https":"http"}get ip(){return this._nodeRequest.socket.remoteAddress}get authorized(){return this._nodeRequest.socket.authorized}get peerCertificate(){return this._nodeRequest.socket.getPeerCertificate()}get mtlsConfig(){return this._nodeRequest.socket.server.mtlsConfig}get body(){return this.#e||(this.#e=new ON(this._nodeRequest))}get host(){return this._nodeRequest.authority||this._nodeRequest.headers.host}get httpVersion(){return this._nodeRequest.httpVersion}get isAborted(){return!1}sendEarlyHints(t,r={}){r.link=t,this._nodeResponse.writeEarlyHints(r)}},ON=class{static{o(this,"RequestBody")}#e;constructor(t){this.#e=t}on(t,r){return this.#e.on(t,r),this}pipe(t,r){return this.#e.pipe(t,r)}},CN=class{constructor(t){this.asObject=t}static{o(this,"Headers")}set(t,r){this.asObject[t.toLowerCase()]=r}get(t){return this.asObject[t.toLowerCase()]}has(t){return this.asObject.hasOwnProperty(t.toLowerCase())}[Symbol.iterator](){return Object.entries(this.asObject)[Symbol.iterator]()}keys(){return Object.keys(this.asObject)}values(){return Object.values(this.asObject)}delete(t){delete this.asObject[t.toLowerCase()]}forEach(t){for(let[r,n]of this)t(n,r,this)}};(0,zk.platform)()!="win32"&&(Bg=require("node-unix-socket").createReuseportFd)});var Hg={};Ce(Hg,{parseHeaderValue:()=>LN,start:()=>Cie});async function Oie(e,t){let r=e.headers.asObject,n=r.accept==="text/event-stream",s=n?"CONNECT":e.method;e.search&&T_(e);let i=new Ns;try{e.responseHeaders=i;let a=e.url.slice(1),c,l;if(a!==Qk){let g=Fg.getMatch(a,n?"sse":"rest");if(!g)return t(e);e.handlerPath=g.path,c=new Js(g.relativeURL),c.async=!0,l=g.Resource}if(l?.isCaching){let g=r["cache-control"];if(g){let y=LN(g);for(let T of y)switch(T.name){case"max-age":e.expiresAt=T.value*1e3+Date.now();break;case"only-if-cached":e.onlyIfCached=!0;break;case"no-cache":e.noCache=!0;break;case"no-store":e.noCacheStore=!0;break;case"stale-if-error":e.staleIfError=!0;break;case"must-revalidate":e.mustRevalidate=!0;break}}}let u=r["x-replicate-to"];if(u){let g=LN(u).map(y=>(y.next?.name==="confirm"&&y.next.value>=0&&(e.replicatedConfirmation=+y.next.value),y.name));e.replicateTo=g.length===1&&+g[0]>=0?+g[0]:g[0]==="*"?void 0:g}r["x-replicate-from"]==="none"&&(e.replicateFrom=!1);let f=await vt(e,()=>{if(r["content-length"]||r["transfer-encoding"])try{e.data=ho(r["content-type"],!0)(e.body,e.headers)}catch(g){throw new nd.ClientError(g,400)}if(e.authorize=!0,a===Qk&&s==="GET"){if(e?.user?.role?.permission?.super_user)return Yk(Fg);throw new nd.ServerError("Forbidden",403)}switch(c.checkPermission=e.user?.role?.permission??{},s){case"GET":case"HEAD":return l.get(c,e);case"POST":return l.post(c,e.data,e);case"PUT":return l.put(c,e.data,e);case"DELETE":return l.delete(c,e);case"PATCH":return l.patch(c,e.data,e);case"OPTIONS":i.setIfNone("Allow","GET, HEAD, POST, PUT, DELETE, PATCH, OPTIONS, TRACE, QUERY, COPY, MOVE");return;case"CONNECT":return l.connect(c,null,e);case"TRACE":return"HarperDB is the terminating server";case"QUERY":return l.query(c,e.data,e);case"COPY":return l.copy(c,r.destination,e);case"MOVE":return l.move(c,r.destination,e);case"BREW":throw new nd.ClientError("HarperDB is short and stout and can't brew coffee",418);default:throw new nd.ServerError(`Method ${s} is not recognized`,501)}}),m=200,h;if(f==null)m=s==="GET"||s==="HEAD"?404:204,PN.lastModified&&e.lastModified&&i.setIfNone("Last-Modified",new Date(e.lastModified).toUTCString());else if(f.status>0&&f.headers){let g=FH(f.headers,i);return f.headers!==g&&(f.headers=g),f.data!==void 0&&(f.body=rm(f.data,e,f)),f}else if(h=e.lastModified){wie[0]=h;let g=String.fromCharCode(34,(Yr[0]&63)+62,(Yr[0]>>6)+(Yr[1]<<2&63)+62,(Yr[1]>>4)+(Yr[2]<<4&63)+62,(Yr[2]>>2)+62,(Yr[3]&63)+62,(Yr[3]>>6)+(Yr[4]<<2&63)+62,(Yr[4]>>4)+(Yr[5]<<4&63)+62,(Yr[5]>>2)+62,(Yr[6]&63)+62,(Yr[6]>>6)+(Yr[7]<<2&63)+62,34),y=r["if-none-match"];y&&g==y?(f?.onDone&&f.onDone(),m=304,f=void 0):i.setIfNone("ETag",g),PN.lastModified&&i.setIfNone("Last-Modified",new Date(h).toUTCString())}e.createdResource&&(m=201),e.newLocation&&i.setIfNone("Location",e.newLocation);let p={status:m,headers:i,body:void 0},_=e.loadedFromSource??f?.wasLoadedFromSource?.();return _!==void 0&&(p.wasCacheMiss=_,!_&&h&&i.setIfNone("Age",Math.round((Date.now()-(e.lastRefreshed||h))/1e3))),f!==void 0&&(p.body=rm(f,e,p),s==="HEAD"&&(p.body=void 0)),p}catch(a){a.statusCode?a.statusCode===500?ai.warn(a):ai.info(a):ai.error(a),a.statusCode===405&&(a.method&&(a.message+=` to handle HTTP method ${a.method.toUpperCase()||""}`),a.allow&&(a.allow.push("trace","head","options"),i.setIfNone("Allow",a.allow.map(l=>l.toUpperCase()).join(", "))));let c={status:a.statusCode||500,headers:i,body:void 0};return c.body=rm(a.contentType?a:Zk(a),e,c),c}}function Cie(e){PN=e,!Jk&&(Jk=!0,e.includeExpensiveRecordCountEstimates&&(Ba.prototype.includeExpensiveRecordCountEstimates=!0),Fg=e.resources,e.server.http(async(t,r)=>{if(!t.isWebSocket)return Oie(t,r)},e),e.webSocket!==!1&&e.server.ws(async(t,r,n)=>{_h++;let s=new $n;Xk||(Xk=!0,th(l=>{_h>0&&l.push({metric:"ws-connections",connections:_h,byThread:!0})}));let i;t.on("error",l=>{i=!0,ai.warn(l)});let a;t.on("message",o(function(u){a||(a=ho(r.requestedContentType??r.headers.asObject["content-type"],!1));let d=a(u);gt(u.length,"bytes-received",r.handlerPath,"message","ws"),s.push(d)},"message"));let c;t.on("close",()=>{_h--,Kr(!i,"connection","ws","disconnect"),s.emit("close"),c&&c.return()});try{await n;let l=r.url.slice(1),u=Fg.getMatch(l,"ws");if(Kr(!!u,"connection","ws","connect"),u){r.handlerPath=u.path,gt(p=>({count:p.count,total:_h}),"connections",r.handlerPath,"connect","ws"),r.authorize=!0;let d=new Js(u.relativeURL);d.checkPermission=r.user?.role?.permission??{};let f=u.Resource;c=(await vt(r,()=>f.connect(d,s,r)))[Symbol.asyncIterator]();let h;for(;!(h=await c.next()).done;){let p=await ga(h.value,r);t.send(p),gt(p.length,"bytes-sent",r.handlerPath,"message","ws"),t._socket.writableNeedDrain&&await new Promise(_=>t._socket.once("drain",_))}}else return t.close(1011,`No resource was found to handle ${r.pathname}`)}catch(l){l.statusCode?l.statusCode===500?ai.warn(l):ai.info(l):ai.error(l),t.close(Pie[l.statusCode]||1011,Zk(l))}t.close()},e))}function LN(e){return e.trim().split(",").map(t=>{let r,n=t.trim().split(";"),s;for(;s=n.pop();)if(s.includes("=")){let[i,a]=s.trim().split("=");i=i.trim(),a&&(a=a.trim()),r={name:i.toLowerCase(),value:a,next:r}}else r={name:s.toLowerCase(),next:r};return r})}var ai,nd,Zk,Yr,wie,PN,Qk,Jk,Fg,Xk,_h,Pie,eG=fe(()=>{po();Hi();ai=w(z()),nd=w(Ee());R_();pu();Uc();nh();Wk();Eh();y_();({errorToString:Zk}=ai),Yr=new Uint8Array(8),wie=new Float64Array(Yr.buffer,0,1),PN={},Qk="openapi";o(Oie,"http");_h=0;o(Cie,"start");Pie={401:3e3,403:3003};o(LN,"parseHeaderValue")});var DN=M((tDe,rG)=>{var{recordAction:kg,recordActionBinary:tG}=(Hi(),v(gg)),Lie=require("fastify-plugin"),Die=200;rG.exports=Lie(function(e,t,r){e.addHook("onResponse",async(n,s)=>{let i=s.elapsedTime}),e.addHook("onSend",async(n,s,i)=>{let a=s.elapsedTime,c=performance.now(),l=s.request.routeOptions,u,d,f;l.config?.isOperation?(u=n.body?.operation,d="operation"):(u=l.url,d="fastify-route",f=l.method),kg(a,"duration",u,f,d),tG(s.raw.statusCode<400,"success",u,f,d),tG(1,"response_"+s.raw.statusCode,u,f,d);let m=Die;i?.pipe?(i.on("data",g=>{m+=g.length}),i.on("end",()=>{kg(performance.now()-c,"transfer",u,f,d),kg(m,"bytes-sent",u,f,d)})):(m+=i?.length||0,kg(m,"bytes-sent",u,f,d));let h=a.toFixed(3),p=s.getHeader("Server-Timing"),_=`db;dur=${h}`;s.header("Server-Timing",p?`${p}, ${_}`:_)}),r()},{name:"hdb-request-time"})});var sG=M((rDe,nG)=>{var Mie=at(),vie={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};nG.exports=function(e){return Mie.validateObject(e,vie)}});var Gg=M((nDe,iG)=>{"use strict";var Uie=(k(),v(K)).OPERATIONS_ENUM,MN=class{static{o(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=Uie.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};iG.exports=MN});var Th={};Ce(Th,{createTokens:()=>xN,getJWTRSAKeys:()=>Yg,refreshOperationToken:()=>BN,validateOperationToken:()=>FN,validateRefreshToken:()=>Wg});async function Yg(){if(qg)return qg;try{let e=gh.default.join(Sh.default.getHdbBasePath(),Ly),t=await $g.default.readFile(gh.default.join(e,Uf.JWT_PASSPHRASE_NAME),"utf8"),r=await $g.default.readFile(gh.default.join(e,Uf.JWT_PRIVATE_KEY_NAME),"utf8");return qg={publicKey:await $g.default.readFile(gh.default.join(e,Uf.JWT_PUBLIC_KEY_NAME),"utf8"),privateKey:r,passphrase:t},qg}catch(e){throw Kg.default.error(e),new ci.ClientError(id.NO_ENCRYPTION_KEYS,sd.INTERNAL_SERVER_ERROR)}}async function xN(e){let t=(0,vN.validateBySchema)(e,qi.default.object({username:qi.default.string().optional(),password:qi.default.string().optional(),role:qi.default.string().optional(),expires_in:qi.default.alternatives(qi.default.string(),qi.default.number()).optional()}));if(t)throw new ci.ClientError(t.message);let r;try{let f=e.bypass_auth!==!0;!e.username&&!e.password&&(e.username=e.hdb_user?.username,f=!1),r=await(0,UN.findAndValidateUser)(e.username,e.password,f)}catch(f){throw Kg.default.error(f),new ci.ClientError(id.INVALID_CREDENTIALS,sd.UNAUTHORIZED)}if(!r)throw new ci.ClientError(id.INVALID_CREDENTIALS,sd.UNAUTHORIZED);let n=!1,s=!1;r.role?.permission&&(n=r.role.permission.super_user===!0,s=r.role.permission.cluster_user===!0);let i={username:e.username,super_user:n,cluster_user:s};e.role&&(i.role=e.role);let a=await Yg(),c=await od.default.sign(i,{key:a.privateKey,passphrase:a.passphrase},{expiresIn:e.expires_in??uG,algorithm:Vg,subject:ad.OPERATION}),l=await od.default.sign(i,{key:a.privateKey,passphrase:a.passphrase},{expiresIn:xie,algorithm:Vg,subject:ad.REFRESH}),u=PI(l,Mr.SHA256);if((await(0,oG.update)(new aG.default(vf,uu.USER_TABLE_NAME,[{username:e.username,refresh_token:u}]))).skipped_hashes.length>0)throw new ci.ClientError(id.REFRESH_TOKEN_SAVE_FAILED,sd.INTERNAL_SERVER_ERROR);return cG.default.signalUserChange(new lG.UserEventMsg(process.pid)),{operation_token:c,refresh_token:l}}async function BN(e){let t=(0,vN.validateBySchema)(e,qi.default.object({refresh_token:qi.default.string().required()}).required());if(t)throw new ci.ClientError(t.message);let{refresh_token:r}=e;await Wg(r);let n=await Yg(),s=await od.default.decode(r);return{operation_token:await od.default.sign({username:s.username,super_user:s.super_user,cluster_user:s.cluster_user},{key:n.privateKey,passphrase:n.passphrase},{expiresIn:uG,algorithm:Vg,subject:ad.OPERATION})}}async function FN(e){return dG(e,ad.OPERATION)}async function Wg(e){return dG(e,ad.REFRESH)}async function dG(e,t){try{let r=await Yg(),n=await od.default.verify(e,r.publicKey,{algorithms:Vg,subject:t});if(n.role)throw new Error("Invalid token");let s=await(0,UN.findAndValidateUser)(n.username,void 0,!1);if(t===ad.REFRESH&&!LI(s.refresh_token,e))throw new Error("Invalid token");return s}catch(r){throw Kg.default.warn(r),r?.name==="TokenExpiredError"?new ci.ClientError(id.TOKEN_EXPIRED,sd.FORBIDDEN):new ci.ClientError(id.INVALID_TOKEN,sd.UNAUTHORIZED)}}var od,$g,gh,qi,vN,ci,Kg,UN,oG,aG,cG,lG,Sh,sd,id,uG,xie,Vg,ad,qg,cd=fe(()=>{od=w(require("jsonwebtoken")),$g=w(require("fs-extra")),gh=w(require("node:path")),qi=w(require("joi")),vN=w(at());k();ci=w(Ee()),Kg=w(z());cg();UN=w(Jn()),oG=w(Mn()),aG=w(Gg()),cG=w(bo()),lG=w(ti()),Sh=w(ce()),{HTTP_STATUS_CODES:sd,AUTHENTICATION_ERROR_MSGS:id}=ci.hdbErrors;Sh.default.initSync();uG=Sh.default.get(U.AUTHENTICATION_OPERATIONTOKENTIMEOUT)||"1d",xie=Sh.default.get(U.AUTHENTICATION_REFRESHTOKENTIMEOUT)||"30d",Vg="RS256",ad={OPERATION:"operation",REFRESH:"refresh"};o(Yg,"getJWTRSAKeys");o(xN,"createTokens");o(BN,"refreshOperationToken");o(FN,"validateOperationToken");o(Wg,"validateRefreshToken");o(dG,"validateToken")});var HN=M((cDe,hG)=>{"use strict";var Bie=sG(),ld=require("passport"),Fie=require("passport-local").Strategy,Hie=require("passport-http").BasicStrategy,kie=require("util"),Gie=Jn(),mG=kie.callbackify(Gie.findAndValidateUser),aDe=tn(),qie=(k(),v(K)),fG=(cd(),v(Th));ld.use(new Fie(function(e,t,r){mG(e,t,r)}));ld.use(new Hie(function(e,t,r){mG(e,t,r)}));ld.serializeUser(function(e,t){t(null,e)});ld.deserializeUser(function(e,t){t(null,e)});function $ie(e,t,r){if(e.raw?.user!==void 0)return r(null,e.raw.user);let n,s;if(e.headers?.authorization){let a=e.headers.authorization.split(" ");n=a[0],s=a[1]}function i(a,c){return a?r(a):c?r(null,c):r("Must login")}switch(o(i,"handleResponse"),n){case"Basic":ld.authenticate("basic",{session:!1},(a,c)=>{i(a,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===qie.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?fG.validateRefreshToken(s).then(a=>{e.body.refresh_token=s,r(null,a)}).catch(a=>{r(a)}):fG.validateOperationToken(s).then(a=>{r(null,a)}).catch(a=>{r(a)});break;default:ld.authenticate("local",{session:!1},function(a,c){i(a,c)})(e,t,r);break}}o($ie,"authorize");function Vie(e,t){let r=Bie(e);if(r){t(r);return}let n={authorized:!0,messages:[]},s=e.user.role;if(!s?.permission)return t("Invalid role");let i=JSON.parse(s.permission);if(i.super_user)return t(null,n);if(!i[e.schema])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.schema} schema`),t(null,n);if(!i[e.schema].tables[e.table])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.table} table`),t(null,n);if(!i[e.schema].tables[e.table][e.operation])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.operation} on ${e.table} table`),t(null,n);if(i[e.schema].tables[e.table].attribute_permissions&&!e.attributes)return n.authorized=!1,n.messages.push(`${e.schema}.${e.table} has attribute permissions. Missing attributes to validate`),t(null,n);if(i[e.schema].tables[e.table].attribute_permissions&&e.attributes){let a=i[e.schema].tables[e.table].attribute_permissions;for(let c in a)e.attributes.indexOf(a[c].attribute_name)>-1&&!a[c][e.operation]&&(n.authorized=!1,n.messages.push(`Not authorized to ${e.operation} ${a[c].attribute_name} `))}return t(null,n)}o(Vie,"checkPermissions");hG.exports={authorize:$ie,checkPermissions:Vie}});var zg=M((uDe,pG)=>{"use strict";var Kie=jn();pG.exports={writeTransaction:Yie};function Yie(e,t,r){return Kie.writeTransaction(e,t,r)}o(Yie,"writeTransaction")});var SG=M((mDe,gG)=>{"use strict";var Wie=on(),zie=ei(),EG=z(),jie=Mn(),fDe=zg(),Qie=require("clone"),GN=require("alasql"),Jie=J_(),_G=require("util"),Xie=_G.promisify(zie.getTableSchema),Zie=_G.promisify(Wie.search),eoe=(k(),v(K)),kN=ie();Jie(GN);gG.exports={update:roe};var toe="There was a problem performing this update. Please check the logs and try again.";async function roe({statement:e,hdb_user:t}){let r=await Xie(e.table.databaseid,e.table.tableid),n=noe(e.columns);kN.backtickASTSchemaItems(e);let{table:s,where:i}=e,a=Qie(s),c=kN.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,u=GN.parse(l).statements[0],d=await Zie(u),f=soe(n,d);return ioe(a,f,t)}o(roe,"update");function noe(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=GN.compile(`SELECT ${r.expression.toString()} AS [${eoe.FUNC_VAL}] FROM ?`)}),t}catch(t){throw EG.error(t),new Error(toe)}}o(noe,"createUpdateRecord");function soe(e,t){return kN.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}o(soe,"buildUpdateRecords");async function ioe(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await jie.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){EG.error(`Error delete new_attributes from update response: ${i}`)}return s}o(ioe,"updateRecords")});var RG=M((_De,TG)=>{var ooe=require("alasql"),aoe=on(),coe=z(),loe=jn(),$N=require("util"),qN=ie(),uoe=(k(),v(K)),doe=ei(),pDe=zg(),EDe=Mn(),foe="record",moe="successfully deleted",hoe=$N.callbackify(goe),poe=$N.promisify(aoe.search),Eoe=$N.promisify(doe.getTableSchema);TG.exports={convertDelete:hoe};function _oe(e){return`${e.deleted_hashes.length} ${foe}${e.deleted_hashes.length===1?"":"s"} ${moe}`}o(_oe,"generateReturnMessage");async function goe({statement:e,hdb_user:t}){let r=await Eoe(e.table.databaseid,e.table.tableid);qN.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=qN.isEmpty(s)?"":` WHERE ${s.toString()}`,a=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=ooe.parse(a).statements[0],l={operation:uoe.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await poe(c);let u=await loe.deleteRecords(l);return qN.isEmptyOrZeroLength(u.message)&&(u.message=_oe(u)),delete u.txn_time,u}catch(u){throw coe.error(u),u.hdb_code?u.message:u}}o(goe,"convertDelete")});var NG=M((SDe,IG)=>{"use strict";var Soe=Pa(),{hdbErrors:yG}=Ee(),{getDatabases:AG}=(Le(),v(ft));IG.exports={checkSchemaExists:bG,checkSchemaTableExists:Toe,schemaDescribe:Soe};async function bG(e){if(!AG()[e])return yG.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}o(bG,"checkSchemaExists");async function Toe(e,t){let r=await bG(e);if(r)return r;if(!AG()[e][t])return yG.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}o(Toe,"checkSchemaTableExists")});var zN=M((bDe,FG)=>{"use strict";var{decode:Roe}=require("msgpackr"),{isMainThread:RDe,parentPort:yDe,threadId:ADe}=require("worker_threads"),Jg=lr(),ud=It(),YN=(k(),v(K)),ln=z(),KN=ce(),yoe=(k(),v(K)),{onMessageByType:Aoe}=st(),PG=xi(),{recordAction:wG,recordActionBinary:boe}=(Hi(),v(gg)),{publishToStream:Ioe}=Jg,{ConsumerEvents:OG}=require("nats"),Noe=on(),{promisify:woe}=require("util"),{decodeBlobsWithWrites:Ooe}=(Ts(),v(gA)),LG=woe(setTimeout),Xg=1e4,Zg,Qg,Coe,Poe,DG,Rh=new Map,dd=new Map;FG.exports={initialize:MG,ingestConsumer:WN,setSubscription:Loe,setIgnoreOrigin:voe,getDatabaseSubscriptions:Moe,updateConsumer:vG};async function MG(){Aoe(YN.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,async n=>{await vG(n)}),DG=!0,ln.notify("Initializing clustering ingest service.");let{connection:e,jsm:t,js:r}=await Jg.getNATSReferences();Zg=e,Qg=e.info.server_name,Coe=t,Poe=r}o(MG,"initialize");async function vG(e){if(e.status==="start"){let{js:t,jsm:r}=await UG(e.node_domain_name);WN(e.stream_name,t,r,e.node_domain_name)}else if(e.status==="stop"){let t=Rh.get(e.stream_name+e.node_domain_name);t&&(ln.notify("Closing ingest consumer for node:",e.node_domain_name,"stream:",e.stream_name),await t.close?.(),Rh.set(e.stream_name+e.node_domain_name,"close")),dd.get(e.node_domain_name)==="failed"&&dd.set(e.node_domain_name,"close")}}o(vG,"updateConsumer");var eS=new Map;function Loe(e,t,r){let n=eS.get(e);n||eS.set(e,n=new Map),n.set(t,r),DG||MG().then(Doe)}o(Loe,"setSubscription");async function Doe(){let e=await Noe.searchByValue({database:"system",table:"hdb_nodes",search_attribute:"name",search_value:"*"});for await(let t of e){let r=t.name+ud.SERVER_SUFFIX.LEAF,n,s;for(let i of t.subscriptions||[])if(i.subscribe===!0){if(!n&&({js:n,jsm:s}=await UG(r),!n))break;let{schema:a,table:c}=i,l=PG.createNatsTableStreamName(a,c);WN(l,n,s,r)}}}o(Doe,"accessConsumers");async function UG(e){let t,r,n=1;for(;!r;)try{t=await Zg.jetstream({domain:e}),r=await Zg.jetstreamManager({domain:e,checkAPI:!1})}catch(s){if(dd.get(e)==="close")break;dd.set(e,"failed"),n%10===1&&ln.warn("Nats ingest attempting to connect to:",e,"Nats error:",s.message);let i=n++*100<Xg?n++*100:Xg;await LG(i)}return{js:t,jsm:r}}o(UG,"connectToRemoteJS");function Moe(){return eS}o(Moe,"getDatabaseSubscriptions");var xG;function voe(e){xG=e}o(voe,"setIgnoreOrigin");var BG=100,CG=new Array(BG),jg=0;async function WN(e,t,r,n){let{connection:s}=await Jg.getNATSReferences();Zg=s,Qg=s.info.server_name;let i,a=1;for(;!i;)try{i=await t.consumers.get(e,Qg),ln.notify("Initializing ingest consumer for node:",n,"stream:",e)}catch(u){if(dd.get(n)==="close")break;a%10===1&&ln.warn("Nats ingest error getting consumer:",n,"stream:",e,"Nats error:",u.message),u.code==="404"&&(ln.notify("Nats ingest creating consumer for node:",n,"stream:",e),i=await Jg.createConsumer(r,e,Qg,new Date(Date.now()).toISOString()));let d=a++*100<Xg?a++*100:Xg;await LG(d)}let c=!1,l;for(;!c;){if(Rh.get(e+n)==="close"||dd.get(n)==="close"){Rh.delete(e+n),c=!0;continue}l=await i.consume({max_messages:KN.get(YN.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS)??100,bind:!0}),Rh.set(e+n,l);let u=!1;(async()=>{for await(let d of await l.status())if(d.type===OG.ConsumerDeleted&&(await l.close(),c=!0),d.type===OG.HeartbeatsMissed){let f=d.data;ln.trace(`${f} clustering ingest consumer heartbeats missed, node: ${n} stream: ${l.consumer.stream}`),f===100&&(ln.warn(`Restarting clustering ingest consumer due to missed heartbeat threshold being met, node: ${n} stream: ${l.consumer.stream}`),l.stop(),u=!0)}})();try{for await(let d of l)await CG[jg],CG[jg]=Uoe(d).catch(f=>{ln.error(f)}),++jg>=BG&&(jg=0)}catch(d){d.message==="consumer deleted"?(ln.notify("Nats consumer deleted, closing messages for node:",n,"stream:",l.consumer.stream),await l.close(),c=!0):ln.error("Error consuming clustering ingest, restarting consumer",d)}}}o(WN,"ingestConsumer");async function Uoe(e){let t;await Ooe(()=>{t=Roe(e.data)}),wG(e.data.length,"bytes-received",e.subject,t.operation,"ingest"),ln.trace("Nats message processor message size:",e?.msg?._msg?.size,"bytes");let r=e.headers,n=!1,s=KN.get(YN.CONFIG_PARAMS.CLUSTERING_NODENAME);r.has(ud.MSG_HEADERS.TRANSACTED_NODES)&&r.values(ud.MSG_HEADERS.TRANSACTED_NODES).indexOf(s)>-1&&(n=!0);let i=r.get(ud.MSG_HEADERS.ORIGIN);if(n||(n=i===s&&!xG),boe(n,"echo",e.subject,t.operation,"ingest"),n){e.ack();return}r.append(ud.MSG_HEADERS.TRANSACTED_NODES,s);try{let{operation:a,schema:c,next:l,table:u,records:d,hash_values:f,__origin:m,expiresAt:h}=t;ln.trace("processing message:",a,c,u,(d?"records: "+d.map(P=>P?.id):"")+(f?"ids: "+f:""),"with sequence:",e.seq),ln.trace(`messageProcessor nats msg id: ${e.headers.get(ud.MSG_HEADERS.NATS_MSG_ID)}`);let p;d||(d=f);let _=new Promise(P=>p=P),{timestamp:g,user:y,node_name:T}=m||{},R=eS.get(c)?.get(u);if(!R)throw new Error(`Missing table for replication message: ${u}`);if(a==="define_schema")t.type=a,t.onCommit=p,R.send(t);else if(d.length===1&&!l)R.send({type:VN(a),value:d[0],id:f?.[0],expiresAt:h,timestamp:g,table:u,onCommit:p,user:y,nodeName:T});else{let P=d.map((Y,te)=>({type:VN(a),value:Y,expiresAt:h,id:f?.[te],table:u}));for(;l;)P.push({type:VN(l.operation),value:l.record,expiresAt:l.expiresAt,id:l.id,table:l.table}),l=l.next;R.send({type:"transaction",writes:P,table:u,timestamp:g,onCommit:p,user:y,nodeName:T})}KN.get(yoe.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&Ioe(e.subject.split(".").slice(0,-1).join("."),PG.createNatsTableStreamName(c,u),e.headers,e.data),await _;let I=Date.now()-g;g&&wG(I,"replication-latency",e.subject,a,"ingest")}catch(a){ln.error(a)}e.ack()}o(Uoe,"messageProcessor");function VN(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}o(VN,"convertOperation")});var lr=M((LDe,tq)=>{"use strict";var xr=ce();xr.initSync();var xoe=require("fs-extra"),Boe=require("semver"),bh=require("path"),{monotonicFactory:Foe}=require("ulidx"),kG=Foe(),Hoe=require("util"),GG=require("child_process"),koe=Hoe.promisify(GG.exec),Goe=GG.spawn,Wr=It(),Qe=(k(),v(K)),{packageJson:qoe,PACKAGE_ROOT:$oe}=Rt(),tS=ie(),li=z(),rS=xi(),Voe=zg(),yh=yt(),{broadcast:Koe,onMessageByType:Yoe,getWorkerIndex:Woe}=st(),{isMainThread:qG}=require("worker_threads"),{Encoder:zoe,decode:XN}=require("msgpackr"),$G=new zoe,{isEmpty:Al}=tS,VG=Jn(),NDe=48*36e11;qG&&Yoe(Qe.ITC_EVENT_TYPES.RESTART,()=>{un=void 0,yl=void 0});var{connect:joe,StorageType:Qoe,RetentionPolicy:Joe,AckPolicy:ZN,DeliverPolicy:ew,DiscardPolicy:Xoe,NatsConnection:wDe,JetStreamManager:ODe,JetStreamClient:CDe,StringCodec:PDe,JSONCodec:Zoe,createInbox:tw,headers:eae,ErrorCode:HG}=require("nats"),{recordAction:tae}=(Hi(),v(gg)),{encodeBlobsAsBuffers:rae}=(Ts(),v(gA)),KG=Zoe(),nae="clustering",sae=qoe.engines[Wr.NATS_SERVER_NAME],iae=bh.join($oe,"dependencies"),JN=bh.join(iae,`${process.platform}-${process.arch}`,Wr.NATS_BINARY_NAME),jN,QN,Ah,Tl,Rl;tq.exports={runCommand:YG,checkNATSServerInstalled:oae,createConnection:rw,getConnection:Ih,getJetStreamManager:Nh,getJetStream:zG,getNATSReferences:$i,getServerList:cae,createLocalStream:nw,listStreams:jG,deleteLocalStream:lae,getServerConfig:fd,listRemoteStreams:uae,viewStream:dae,viewStreamIterator:fae,publishToStream:mae,request:Eae,reloadNATS:sw,reloadNATSHub:_ae,reloadNATSLeaf:gae,extractServerName:pae,requestErrorHandler:Sae,createLocalTableStream:ZG,createTableStreams:yae,purgeTableStream:eq,purgeSchemaTableStreams:Aae,getStreamInfo:bae,updateLocalStreams:Nae,closeConnection:aae,getJsmServerName:nS,addNatsMsgHeader:QG,clearClientCache:WG,updateRemoteConsumer:Tae,createConsumer:JG,updateConsumerIterator:Rae};async function YG(e,t=void 0){let{stdout:r,stderr:n}=await koe(e,{cwd:t});if(n)throw new Error(n.replace(`
|
|
15
15
|
`,""));return r.replace(`
|
|
16
16
|
`,"")}o(YG,"runCommand");async function oae(){try{await xoe.access(JN)}catch{return!1}let e=await YG(`${JN} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return Boe.eq(t,sae)}o(oae,"checkNATSServerInstalled");async function rw(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let a=await VG.getClusterUser();if(Al(a))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=a.username,r=a.decrypt_hash}li.trace("create nats connection called");let i=await joe({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:xr.get(Qe.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:xr.get(Qe.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:xr.get(Qe.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),li.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(a=>{a&&li.error("Error with Nats client connection, connection closed",a),i===un&&WG()}),i}o(rw,"createConnection");function WG(){un=void 0,Tl=void 0,Rl=void 0,yl=void 0}o(WG,"clearClientCache");async function aae(){un&&(await un.drain(),un=void 0,Tl=void 0,Rl=void 0,yl=void 0)}o(aae,"closeConnection");var un,yl;async function Ih(){return yl||(yl=rw(xr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),un=await yl),un||yl}o(Ih,"getConnection");async function Nh(){if(Tl)return Tl;Al(un)&&await Ih();let{domain:e}=fd(Qe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(Al(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return Tl=await un.jetstreamManager({domain:e,timeout:6e4}),Tl}o(Nh,"getJetStreamManager");async function zG(){if(Rl)return Rl;Al(un)&&await Ih();let{domain:e}=fd(Qe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(Al(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return Rl=un.jetstream({domain:e,timeout:6e4}),Rl}o(zG,"getJetStream");async function $i(){let e=un||await Ih(),t=Tl||await Nh(),r=Rl||await zG();return{connection:e,jsm:t,js:r}}o($i,"getNATSReferences");async function cae(e){let t=xr.get(Qe.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await VG.getClusterUser(),s=await rw(t,r,n),i=tw(),a=s.subscribe(i),c=[],l,u=(async()=>{for await(let d of a){let f=KG.decode(d.data);f.response_time=Date.now()-l,c.push(f)}})();return l=Date.now(),await s.publish("$SYS.REQ.SERVER.PING.VARZ",void 0,{reply:i}),await s.publish("$SYS.REQ.SERVER.PING",void 0,{reply:i}),await s.flush(),await tS.asyncSetTimeout(e),await a.drain(),await s.close(),await u,c}o(cae,"getServerList");async function nw(e,t){let{jsm:r}=await $i(),n=xr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=xr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=xr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:Qoe.File,retention:Joe.Limits,subjects:t,discard:Xoe.Old,maxMsgs:s,maxBytes:i,maxAge:n})}o(nw,"createLocalStream");async function jG(){let{jsm:e}=await $i(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}o(jG,"listStreams");async function lae(e){let{jsm:t}=await $i();await t.streams.delete(e)}o(lae,"deleteLocalStream");async function uae(e){let{connection:t}=await $i(),r=[],n=tw(),s=t.subscribe(n),i=(async()=>{for await(let a of s)r.push(KG.decode(a.data))})();return await t.publish(`$JS.${e}.API.STREAM.LIST`,void 0,{reply:n}),await t.flush(),await s.drain(),await i,r}o(uae,"listRemoteStreams");async function dae(e,t=void 0,r=void 0){let{jsm:n,js:s}=await $i(),i=kG(),a={durable_name:i,ack_policy:ZN.Explicit};t&&(a.deliver_policy=ew.StartTime,a.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,a);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];let u=[];for await(let d of l){let f=XN(d.data),m={nats_timestamp:d.info.timestampNanos,nats_sequence:d.info.streamSequence,entry:f};if(d.headers&&(m.origin=d.headers.get(Wr.MSG_HEADERS.ORIGIN)),u.push(m),d.ack(),d.info.pending===0)break}return await c.delete(),u}o(dae,"viewStream");async function*fae(e,t=void 0,r=void 0){let{jsm:n,js:s}=await $i(),i=kG(),a={durable_name:i,ack_policy:ZN.Explicit};t&&(a.deliver_policy=ew.StartTime,a.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,a);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];for await(let u of l){let d=XN(u.data);d[0]||(d=[d]);for(let f of d){let m={nats_timestamp:u.info.timestampNanos,nats_sequence:u.info.streamSequence,entry:f};u.headers&&(m.origin=u.headers.get(Wr.MSG_HEADERS.ORIGIN)),yield m}if(u.ack(),u.info.pending===0)break}await c.delete()}o(fae,"viewStreamIterator");async function mae(e,t,r,n){li.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=QG(n,r);let{js:s}=await $i(),i=await nS(),a=`${e}.${i}`,c=await rae(()=>n instanceof Uint8Array?n:$G.encode(n));try{li.trace(`publishToStream publishing to subject: ${a}`),tae(c.length,"bytes-sent",e,n.operation,"replication"),await s.publish(a,c,{headers:r})}catch(l){if(l.code&&l.code.toString()==="503")return XG(async()=>{try{await s.publish(a,c,{headers:r})}catch{if(l.code&&l.code.toString()==="503"){li.trace(`publishToStream creating stream: ${t}`);let d=a.split(".");d[2]="*",await nw(t,[a]),await s.publish(a,c,{headers:r})}else throw l}});throw l}}o(mae,"publishToStream");function QG(e,t){t===void 0&&(t=eae());let r=xr.get(Qe.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(Wr.MSG_HEADERS.ORIGIN)&&r&&t.append(Wr.MSG_HEADERS.ORIGIN,r),t}o(QG,"addNatsMsgHeader");function fd(e){e=e.toLowerCase();let t=bh.join(xr.get(Qe.CONFIG_PARAMS.ROOTPATH),nae);if(e===Qe.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return Al(QN)&&(QN={port:yh.getConfigFromFile(Qe.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:yh.getConfigFromFile(Qe.CONFIG_PARAMS.CLUSTERING_NODENAME)+Wr.SERVER_SUFFIX.HUB,config_file:Wr.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:bh.join(t,Wr.PID_FILES.HUB),hdbNatsPath:t}),QN;if(e===Qe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return Al(jN)&&(jN={port:yh.getConfigFromFile(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:yh.getConfigFromFile(Qe.CONFIG_PARAMS.CLUSTERING_NODENAME)+Wr.SERVER_SUFFIX.LEAF,config_file:Wr.NATS_CONFIG_FILES.LEAF_SERVER,domain:yh.getConfigFromFile(Qe.CONFIG_PARAMS.CLUSTERING_NODENAME)+Wr.SERVER_SUFFIX.LEAF,pid_file_path:bh.join(t,Wr.PID_FILES.LEAF),hdbNatsPath:t}),jN;li.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}o(fd,"getServerConfig");async function JG(e,t,r,n){try{await e.consumers.add(t,{ack_policy:ZN.Explicit,durable_name:r,deliver_policy:ew.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}o(JG,"createConsumer");async function hae(e,t,r){await e.consumers.delete(t,r)}o(hae,"removeConsumer");function pae(e){return e.split(".")[1]}o(pae,"extractServerName");async function Eae(e,t,r=6e4,n=tw()){if(!tS.isObject(t))throw new Error("data param must be an object");let s=$G.encode(t),{connection:i}=await $i(),a={timeout:r};n&&(a.reply=n,a.noMux=!0);let c=await i.request(e,s,a);return XN(c.data)}o(Eae,"request");function sw(e){return new Promise(async(t,r)=>{let n=Goe(JN,["--signal",`reload=${e}`],{cwd:__dirname}),s,i;n.on("error",a=>{r(a)}),n.stdout.on("data",a=>{i+=a.toString()}),n.stderr.on("data",a=>{s+=a.toString()}),n.stderr.on("close",a=>{s&&r(s),t(i)})})}o(sw,"reloadNATS");async function _ae(){let{pid_file_path:e}=fd(Qe.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await sw(e)}o(_ae,"reloadNATSHub");async function gae(){let{pid_file_path:e}=fd(Qe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await sw(e)}o(gae,"reloadNATSLeaf");function Sae(e,t,r){let n;switch(e.code){case HG.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case HG.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}o(Sae,"requestErrorHandler");async function Tae(e,t){let r=t+Wr.SERVER_SUFFIX.LEAF,{connection:n}=await $i(),{jsm:s}=await Oae(r),{schema:i,table:a}=e,c=rS.createNatsTableStreamName(i,a),l=e.start_time?e.start_time:new Date(Date.now()).toISOString();await XG(async()=>{if(e.subscribe===!0)await JG(s,c,n.info.server_name,l);else try{await hae(s,c,n.info.server_name)}catch(u){li.trace(u)}})}o(Tae,"updateRemoteConsumer");async function Rae(e,t,r,n){let s=rS.createNatsTableStreamName(e,t),i=r+Wr.SERVER_SUFFIX.LEAF,a={type:Qe.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!qG&&Woe()<xr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=zN();await c(a)}await Koe(a),n==="stop"&&await tS.asyncSetTimeout(1e3)}o(Rae,"updateConsumerIterator");function XG(e){return Voe.writeTransaction(Qe.SYSTEM_SCHEMA_NAME,Qe.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}o(XG,"exclusiveLock");async function ZG(e,t){let r=rS.createNatsTableStreamName(e,t),n=await nS(),s=Iae(e,t,n);await nw(r,[s])}o(ZG,"createLocalTableStream");async function yae(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await ZG(n,s)}}o(yae,"createTableStreams");async function eq(e,t,r=void 0){if(xr.get(Qe.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=rS.createNatsTableStreamName(e,t),{domain:s}=fd(Qe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await Ih()).jetstreamManager({domain:s,timeout:24e4})).streams.purge(n,r)}catch(n){if(n.message==="stream not found")li.warn(n);else throw n}}o(eq,"purgeTableStream");async function Aae(e,t){if(xr.get(Qe.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await eq(e,t[r])}o(Aae,"purgeSchemaTableStreams");async function bae(e){return(await Nh()).streams.info(e)}o(bae,"getStreamInfo");function Iae(e,t,r){return`${Wr.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}o(Iae,"createSubjectName");async function nS(){if(Ah)return Ah;if(Ah=(await Nh())?.nc?.info?.server_name,Ah===void 0)throw new Error("Unable to get jetstream manager server name");return Ah}o(nS,"getJsmServerName");async function Nae(){let e=await Nh(),t=await nS(),r=await jG();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let a=wae(n),c=i.split(".");if(c[c.length-1]===t&&!a||s.name==="__HARPERDB_WORK_QUEUE__")continue;let u=i.split(".");u[u.length-1]=t;let d=u.join(".");li.trace(`Updating stream subject name from: ${i} to: ${d}`),s.subjects[0]=d,await e.streams.update(s.name,s)}}o(Nae,"updateLocalStreams");function wae(e){let{config:t}=e,r=!1,n=xr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=xr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=xr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);return i=i===null?-1:i,n!==t.max_age&&(t.max_age=n,r=!0),s!==t.max_bytes&&(t.max_bytes=s,r=!0),i!==t.max_msgs&&(t.max_msgs=i,r=!0),r}o(wae,"updateStreamLimits");async function Oae(e){let t,r;try{t=await un.jetstream({domain:e}),r=await un.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw li.error("Unable to connect to:",e),n}return{js:t,jsm:r}}o(Oae,"connectToRemoteJS")});function iw(e){let t=e.get(sS),r=t?(0,md.unpack)(t):null;r||(r={remoteNameToId:{}});let n=rt(),s=!1;r.nodeName=rt();let i=r.remoteNameToId;if(i[n]!==0){let a=0,c;for(let l in i){let u=i[l];u===0?c=l:u>a&&(a=u)}if(c){a++,i[c]=a;let l=[Symbol.for("seq"),a];e.rootStore.dbisDb.transactionSync(()=>{e.rootStore.dbisDb.get(l)||e.rootStore.dbisDb.putSync(l,{seqId:Oh(e)??1,nodes:[]})})}i[n]=0,e.putSync(sS,(0,md.pack)(r))}return r}function wh(e){return iw(e).remoteNameToId}function nq(e,t){let r=iw(t),n=r.remoteNameToId,s=new Map,i=!1;for(let a in e){let c=e[a],l=n[a];if(l==null){let u=0;for(let d in n){let f=n[d];f>u&&(u=f)}l=u+1,n[a]=l,i=!0}s.set(c,l)}return i&&t.putSync(sS,(0,md.pack)(r)),s}function iS(e,t){let r=iw(t),n=r.remoteNameToId,s=n[e];if(s==null){let i=0;for(let a in n){let c=n[a];c>i&&(i=c)}s=i+1,n[e]=s,t.putSync(sS,(0,md.pack)(r))}return rq.trace?.("The remote node name map",e,n,s),s}var rq,md,sS,ow=fe(()=>{rq=w(Ni());es();md=require("msgpackr"),sS=Symbol.for("remote-ids");o(iw,"getIdMappingRecord");o(wh,"exportIdMapping");o(nq,"remoteToLocalNodeId");o(iS,"getIdOfRemoteNode")});var aw={};Ce(aw,{commitsAwaitingReplication:()=>pd,getHDBNodeTable:()=>$t,getReplicationSharedStatus:()=>Ed,iterateRoutes:()=>Ph,shouldReplicateToNode:()=>Ch,subscribeToNodeUpdates:()=>_d});function $t(){return sq||(sq=et({table:"hdb_nodes",database:"system",attributes:[{name:"name",isPrimaryKey:!0},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"},{attribute:"ca"},{attribute:"ca_info"},{attribute:"replicates"},{attribute:"revoked_certificates"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]}))}function Ed(e,t,r,n){return new Float64Array(e.getUserSharedBuffer(["replicated",t,r],new ArrayBuffer(48),n&&{callback:n}))}function _d(e){$t().subscribe({}).then(async t=>{for await(let r of t){let n=r?.value?.name;cq.debug?.("adding node",n,"on node",rt()," on process",process.pid),server.nodes=server.nodes.filter(i=>i.name!==n),r.type==="put"&&n!==rt()&&(r.value?server.nodes.push(r.value):console.error("Invalid node update event",r));let s=new Map;for await(let i of $t().search({}))if(i.shard!=null){let a=s.get(i.shard);a||s.set(i.shard,a=[]),a.push(i)}server.shards=s,(r.type==="put"||r.type==="delete")&&e(r.value,r.id)}})}function Ch(e,t){return(e.replicates===!0||e.replicates?.sends)&&databases[t]&&$t().primaryStore.get(rt())?.replicates||e.subscriptions?.some(r=>(r.database||r.schema)===t&&r.subscribe)}function Cae(){_d(e=>{Fa({},(t,r)=>{let n=e.name,s=iq.get(n);if(s||iq.set(n,s=new Map),s.has(r))return;let i;for(let a in t)if(i=t[a].auditStore,i)break;if(i){let a=Ed(i,r,n,()=>{let c=a[0],l=a.lastTime;for(let{txnTime:u,onConfirm:d}of pd.get(r)||[])u>l&&u<=c&&d();a.lastTime=c});a.lastTime=0,s.set(r,a)}})})}function*Ph(e){for(let t of e.routes||[]){let r=t.url,n;if(typeof t=="string"?t.includes("://")?r=t:n=t:n=t.hostname??t.host,n&&!r){let s=hd.default.get(U.REPLICATION_SECUREPORT)??(!hd.default.get(U.REPLICATION_PORT)&&hd.default.get(U.OPERATIONSAPI_NETWORK_SECUREPORT)),i;(i=n.match(/:(\d+)$/)?.[1])?n=n.slice(0,-i[0].length-1):t.port?i=t.port:i=s||hd.default.get(U.REPLICATION_PORT)||hd.default.get(U.OPERATIONSAPI_NETWORK_PORT);let a=i?.lastIndexOf?.(":");a>0&&(i=+i.slice(a+1).replace(/[\[\]]/g,"")),r=(s?"wss://":"ws://")+n+":"+i}if(!r){oq.isMainThread&&console.error("Invalid route, must specify a url or host (with port)");continue}yield{replicates:!t.subscriptions,url:r,subscription:t.subscriptions,routes:t.routes,startTime:t.startTime,revoked_certificates:t.revokedCertificates}}}var oq,aq,hd,cq,sq,iq,pd,bl=fe(()=>{Le();es();Qf();oq=require("worker_threads"),aq=w(Ee()),hd=w(ce());k();cq=w(Ni());server.nodes=[];o($t,"getHDBNodeTable");o(Ed,"getReplicationSharedStatus");o(_d,"subscribeToNodeUpdates");o(Ch,"shouldReplicateToNode");iq=new Map;ov((e,t,r)=>{if(r>server.nodes.length)throw new aq.ClientError(`Cannot confirm replication to more nodes (${r}) than are in the network (${server.nodes.length})`);pd||(pd=new Map,Cae());let n=pd.get(e);return n||(n=[],pd.set(e,n)),new Promise(s=>{let i=0;n.push({txnTime:t,onConfirm:o(()=>{++i===r&&s()},"onConfirm")})})});o(Cae,"startSubscriptionToReplications");o(Ph,"iterateRoutes")});var fq={};Ce(fq,{connectedToNode:()=>Il,disconnectedFromNode:()=>Td,ensureNode:()=>Do,requestClusterStatus:()=>dq,startOnMainThread:()=>lw});async function lw(e){let t=0,r=it();for(let i of Object.getOwnPropertyNames(r)){let a=r[i];for(let c in a){let l=a[c];if(l.auditStore){oS.set(i,Oh(l.auditStore));break}}}Vi.whenThreadsStarted.then(async()=>{let i=[];for await(let l of r.system.hdb_nodes?.search([])||[])i.push(l);let a=rt();function c(){let l=$t().primaryStore.get(a);if(l!==null){let u=e.url??Ha();if(l===void 0||l.url!==u||l.shard!==e.shard)return Do(a,{name:a,url:u,shard:e.shard,replicates:!0})}}o(c,"ensureThisNode"),$t().primaryStore.get(a)&&c();for(let l of Ph(e))try{let u=!l.subscriptions;if(u&&await c(),u&&l.replicates==null&&(l.replicates=!0),i.find(d=>d.url===l.url))continue;s(l)}catch(u){console.error(u)}_d(s)});let n;function s(i,a=i?.name){let c=rt()&&a===rt()||Ha()&&i?.url===Ha();if(c){let f=!!i?.replicates;if(n!==void 0&&n!==f)for(let m of $t().search([]))m.replicates&&m.name!==a&&s(m,m.name);n=f}if(ut.trace("Setting up node replication for",i),!i){for(let[f,m]of Lo){let h;for(let[p,{worker:_,nodes:g}]of m){let y=g[0];if(y&&y.name==a){h=!0;for(let[T,{worker:R}]of m)m.delete(T),ut.warn("Node was deleted, unsubscribing from node",a,T,f),R?.postMessage({type:"unsubscribe-from-node",node:a,database:T,url:f});break}}if(h){Lo.get(f).iterator.remove(),Lo.delete(f);return}}return}if(c)return;if(!i.url){ut.info(`Node ${i.name} is missing url`);return}let l=Lo.get(i.url);if(l&&l.iterator.remove(),!(i.replicates===!0||i.replicates?.sends)&&!i.subscriptions?.length&&!l)return;if(ut.info(`Added node ${i.name} at ${i.url} for process ${rt()}`),i.replicates&&i.subscriptions&&(i={...i,subscriptions:null}),i.name){for(let[f,m]of gd)if(i.url===m.url){gd.delete(f);break}gd.set(i.name,i)}let u=it();if(l||(l=new Map,Lo.set(i.url,l)),l.iterator=Fa(e,(f,m,h)=>{h?d(m,!0):d(m,!1)}),i.subscriptions)for(let f of i.subscriptions){let m=f.database||f.schema;u[m]||(ut.warn(`Database ${m} not found for node ${i.name}, making a subscription anyway`),d(m,!1))}function d(f,m){ut.trace("Setting up replication for database",f,"on node",i.name);let h=l.get(f),p,_=[{replicateByDefault:m,...i}];oS.has(f)&&(_.push({replicateByDefault:m,name:rt(),startTime:oS.get(f),endTime:Date.now(),replicates:!0}),oS.delete(f));let g=Ch(i,f),y=Vi.workers.filter(T=>T.name==="http");if(h?(p=h.worker,h.nodes=_):g&&(t=t%y.length,p=y[t++],l.set(f,{worker:p,nodes:_,url:i.url}),p?.on("exit",()=>{l.get(f)?.worker===p&&(l.delete(f),d(f,m))})),g)setTimeout(()=>{let T={type:"subscribe-to-node",database:f,nodes:_};p?p.postMessage(T):Sd(T)},Pae);else{ut.info("Node no longer should be used, unsubscribing from node",{replicates:i.replicates,databaseName:f,node:i,subscriptions:i.subscriptions,hasDatabase:!!u[f],thisReplicates:$t().primaryStore.get(rt())?.replicates}),$t().primaryStore.get(rt())?.replicates||(n=!1,ut.info("Disabling replication, this node name",rt(),$t().primaryStore.get(rt()),f));let T={type:"unsubscribe-from-node",database:f,url:i.url,name:i.name};p?p.postMessage(T):cS(T)}}o(d,"onDatabase")}o(s,"onNodeUpdate"),Td=o(function(i){try{ut.info("Disconnected from node",i.name,i.url,"finished",!!i.finished);let a=Array.from(gd.keys()),c=a.sort(),l=c.indexOf(i.name||ui(i.url));if(l===-1){ut.warn("Disconnected node not found in node map",i.name,a);return}let u=Lo.get(i.url),d=u?.get(i.database);if(!d){ut.warn("Disconnected node not found in replication map",i.database,u);return}if(d.connected=!1,i.finished)return;let f=d.nodes[0];if(!(f.replicates===!0||f.replicates?.sends||f.subscriptions?.length))return;let m=(l+1)%c.length;for(;l!==m;){let h=c[m],p=gd.get(h);u=Lo.get(p.url);let _=u?.get(i.database);if(!_){m=(m+1)%c.length;continue}let{worker:g,nodes:y}=_,T=!1;for(let R of d.nodes){if(y.some(I=>I.name===R.name)){ut.info(`Disconnected node is already failing over to ${h} for ${i.database}`);continue}y.push(R),T=!0}if(!T){ut.info(`Disconnected node ${i.name} has no nodes to fail over to ${h}`);return}d.redirectingTo=_,ut.info(`Failing over ${i.database} from ${i.name} to ${h}`),g?g.postMessage({type:"subscribe-to-node",database:i.database,nodes:y}):Sd({database:i.database,nodes:y});return}ut.warn("Unable to find any other node to fail over to",i.name,i.url)}catch(a){ut.error("Error failing over node",a)}},"disconnectedFromNode"),Il=o(function(i){let a=Lo.get(i.url),c=a?.get(i.database);if(!c){ut.warn("Connected node not found in replication map, this may be because the node is being removed",i.database,a);return}if(c.connected=!0,c.latency=i.latency,c.redirectingTo){let{worker:l,nodes:u}=c.redirectingTo,d=u.find(f=>f.name===i.name);c.redirectingTo=null,d&&(u.splice(u.indexOf(d),1),l?l.postMessage({type:"subscribe-to-node",database:i.database,nodes:u}):Sd({database:i.database,nodes:u}))}},"connectedToNode"),(0,Vi.onMessageByType)("disconnected-from-node",Td),(0,Vi.onMessageByType)("connected-to-node",Il),(0,Vi.onMessageByType)("request-cluster-status",dq)}function dq(e,t){let r=[];for(let[n,s]of gd)try{let i=Lo.get(s.url);ut.info("Getting cluster status for",n,s.url,"has dbs",i?.size);let a=[];if(i){for(let[l,{worker:u,connected:d,nodes:f,latency:m}]of i)a.push({database:l,connected:d,latency:m,threadId:u?.threadId,nodes:f.map(h=>h.name)});let c=(0,cw.cloneDeep)(s);c.database_sockets=a,delete c.ca,delete c.node_name,delete c.__updatedtime__,delete c.__createdtime__,r.push(c)}}catch(i){ut.warn("Error getting cluster status for",s?.url,i)}return t?.postMessage({type:"cluster-status",connections:r}),{connections:r}}async function Do(e,t){let r=$t();e=e??ui(t.url),t.name=e;try{if(t.ca){let s=new uq.X509Certificate(t.ca);t.ca_info={issuer:s.issuer.replace(/\n/g," "),subject:s.subject.replace(/\n/g," "),subjectAltName:s.subjectAltName,serialNumber:s.serialNumber,validFrom:s.validFrom,validTo:s.validTo}}}catch(s){ut.error("Error parsing replication CA info for hdb_nodes table",s.message)}let n=r.primaryStore.get(e);if(ut.debug(`Ensuring node ${e} at ${t.url}, existing record:`,n,"new record:",t),!n)await r.patch(t);else{t.replicates&&!lq.default.get(U.CLUSTERING_ENABLED)&&(t.subscriptions=null);for(let s in t)if(n[s]!==t[s]&&s==="subscriptions"&&t[s]&&n[s]){let i=[],a=(0,cw.cloneDeep)(n[s]);for(let c of t[s]){let l=!1;for(let u of a)if((c.database??c.schema)===(u.database??u.schema)&&c.table===u.table){u.publish=c.publish,u.subscribe=c.subscribe,l=!0;break}l||i.push(c)}t.subscriptions=[...a,...i];break}if(Array.isArray(t.revoked_certificates)){let s=n.revoked_certificates||[];t.revoked_certificates=[...new Set([...s,...t.revoked_certificates])]}ut.info(`Updating node ${e} at ${t.url}`),await r.patch(t)}}var Vi,aS,ut,cw,lq,uq,Pae,Lo,Td,Il,gd,oS,Lh=fe(()=>{Le();Vi=w(st());es();aS=require("worker_threads");bl();ut=w(z()),cw=require("lodash"),lq=w(ce());k();uq=require("crypto"),Pae=200,Lo=new Map,gd=new Map,oS=new Map;o(lw,"startOnMainThread");o(dq,"requestClusterStatus");aS.parentPort&&(Td=o(e=>{aS.parentPort.postMessage({type:"disconnected-from-node",...e})},"disconnectedFromNode"),Il=o(e=>{aS.parentPort.postMessage({type:"connected-to-node",...e})},"connectedToNode"),(0,Vi.onMessageByType)("subscribe-to-node",e=>{Sd(e)}),(0,Vi.onMessageByType)("unsubscribe-from-node",e=>{cS(e)}));o(Do,"ensureNode")});var rs=M(Vt=>{"use strict";var ur=require("path"),{watch:Lae}=require("chokidar"),vn=require("fs-extra"),Rd=require("node-forge"),gq=require("net"),{generateKeyPair:uw,X509Certificate:Mo,createPrivateKey:Sq}=require("crypto"),Dae=require("util");uw=Dae.promisify(uw);var Nt=Rd.pki,di=require("joi"),{v4:Tq}=require("uuid"),{validateBySchema:hw}=at(),{forComponent:Mae}=z(),ts=ce(),Os=(k(),v(K)),{CONFIG_PARAMS:wl}=Os,fi=Fy(),{ClientError:Ga}=Ee(),uS=require("node:tls"),{relative:Rq,join:vae}=require("node:path"),{CERT_PREFERENCE_APP:zDe,CERTIFICATE_VALUES:mq}=fi,Uae=Lc(),dw=yt(),{table:xae,getDatabases:Bae,databases:lS}=(Le(),v(ft)),{getJWTRSAKeys:hq}=(cd(),v(Th)),mt=Mae("tls");Vt.generateKeys=_w;Vt.updateConfigCert=Cq;Vt.createCsr=Vae;Vt.signCertificate=Kae;Vt.setCertTable=yd;Vt.loadCertificates=Nq;Vt.reviewSelfSignedCert=Sw;Vt.createTLSSelector=Lq;Vt.listCertificates=Mq;Vt.addCertificate=Jae;Vt.removeCertificate=Zae;Vt.createNatsCerts=zae;Vt.generateCertsKeys=Wae;Vt.getReplicationCert=Mh;Vt.getReplicationCertAuth=$ae;Vt.renewSelfSigned=jae;Vt.hostnamesFromCert=Rw;Vt.getKey=ece;Vt.getHostnamesFromCertificate=tce;Vt.getPrimaryHostName=Tw;var{urlToNodeName:yq,getThisNodeUrl:Fae,getThisNodeName:fS,clearThisNodeName:Hae}=(es(),v(vo)),{readFileSync:kae,statSync:Aq}=require("node:fs"),jDe=ce(),{getTicketKeys:Gae,onMessageFromWorkers:qae}=st(),ka=z(),{isMainThread:bq}=require("worker_threads"),{TLSSocket:Iq,createSecureContext:QDe}=require("node:tls"),pw=3650,Dh=["127.0.0.1","localhost","::1"],Ew=[{name:"countryName",value:"USA"},{name:"stateOrProvinceName",value:"Colorado"},{name:"localityName",value:"Denver"},{name:"organizationName",value:"HarperDB, Inc."}];qae(async e=>{e.type===Os.ITC_EVENT_TYPES.RESTART&&(ts.initSync(!0),await Sw())});var zr;function $a(){return zr||(zr=Bae().system.hdb_certificate,zr||(zr=xae({table:"hdb_certificate",database:"system",attributes:[{name:"name",isPrimaryKey:!0},{attribute:"uses"},{attribute:"certificate"},{attribute:"is_authority"},{attribute:"private_key_name"},{attribute:"details"},{attribute:"is_self_signed"},{attribute:"__updatedtime__"}]}))),zr}o($a,"getCertTable");async function Mh(){let e=Lq("operations-api"),t={secureContexts:null,setSecureContext:o(s=>{},"setSecureContext")};await e.initialize(t);let r=t.secureContexts.get(fS());if(!r)return;let n=new Mo(r.options.cert);return r.cert_parsed=n,r.issuer=n.issuer,r}o(Mh,"getReplicationCert");async function $ae(){$a();let e=(await Mh()).options.cert,r=new Mo(e).issuer.match(/CN=(.*)/)?.[1];return zr.get(r)}o($ae,"getReplicationCertAuth");var pq,qa=new Map;function Nq(){if(pq)return;pq=!0;let e=[{configKey:wl.TLS},{configKey:wl.OPERATIONSAPI_TLS}];$a();let t=ur.dirname(dw.getConfigFilePath()),r;for(let{configKey:n}of e){let s=dw.getConfigFromFile(n);if(s){Array.isArray(s)||(s=[s]);for(let i of s){let a=i.privateKey,c=a&&Rq(vae(t,"keys"),a);c&&Eq(a,l=>{qa.set(c,l)},"private key");for(let l of[!1,!0]){let u=i[l?"certificateAuthority":"certificate"];if(u&&bq){let d;Eq(u,f=>{if(mq.cert===f)return;let m=i.hostname??i.hostnames??i.host??i.hosts;m&&!Array.isArray(m)&&(m=[m]);let h=Pq(u),p=new Mo(h),_;try{_=Tw(p)}catch(R){mt.error("error extracting host name from certificate",R);return}if(_==null){mt.error("No host name found on certificate");return}if(p.checkIssued(new Mo(mq.cert)))return;let g=zr.primaryStore.get(_),y=Aq(u).mtimeMs,T=!g||g.is_self_signed?1:g.file_timestamp??g.__updatedtime__;if(g&&y<=T){y<T&&mt.info(`Certificate ${_} at ${u} is older (${new Date(y)}) than the certificate in the database (${T>1?new Date(T):"only self signed certificate available"})`);return}r=zr.put({name:_,uses:["https",...n.includes("operations")?["operations"]:[]],ciphers:i.ciphers,certificate:h,private_key_name:c,is_authority:l,hostnames:m,fileTimestamp:y,details:{issuer:p.issuer.replace(/\n/g," "),subject:p.subject.replace(/\n/g," "),subject_alt_name:p.subjectAltName,serial_number:p.serialNumber,valid_from:p.validFrom,valid_to:p.validTo}})},l?"certificate authority":"certificate")}}}}}return r}o(Nq,"loadCertificates");function Eq(e,t,r){let n,s=o((i,a)=>{try{let c=a.mtimeMs;c&&c!==n&&(n&&bq&&mt.warn(`Reloading ${r}:`,i),n=c,t(Pq(i)))}catch(c){mt.error(`Error loading ${r}:`,i,c)}},"loadFile");vn.existsSync(e)?s(e,Aq(e)):mt.error(`${r} file not found:`,e),Lae(e,{persistent:!1}).on("change",s)}o(Eq,"loadAndWatch");function fw(){let e=Fae();if(e==null){let t=Dh[0];return mt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return yq(e)}o(fw,"getHost");function dS(){let e=fS();if(e==null){let t=Dh[0];return mt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return e}o(dS,"getCommonName");async function Vae(){let e=await Mh(),t=Nt.certificateFromPem(e.options.cert),r=Nt.privateKeyFromPem(e.options.key);mt.info("Creating CSR with cert named:",e.name);let n=Nt.createCertificationRequest();n.publicKey=t.publicKey;let s=[{name:"commonName",value:dS()},...Ew];mt.info("Creating CSR with subject",s),n.setSubject(s);let i=[{name:"unstructuredName",value:"HarperDB, Inc."},{name:"extensionRequest",extensions:wq()}];return mt.info("Creating CSR with attributes",i),n.setAttributes(i),n.sign(r),Rd.pki.certificationRequestToPem(n)}o(Vae,"createCsr");function wq(){let e=Dh.includes(dS())?Dh:[...Dh,dS()];return e.includes(fw())||e.push(fw()),[{name:"basicConstraints",cA:!1,critical:!0},{name:"keyUsage",digitalSignature:!0,keyEncipherment:!0,critical:!0},{name:"extKeyUsage",serverAuth:!0,clientAuth:!0},{name:"nsCertType",client:!0,server:!0},{name:"subjectAltName",altNames:e.map(t=>gq.isIP(t)?{type:7,ip:t}:{type:2,value:t})}]}o(wq,"certExtensions");async function Kae(e){let t={},r=ur.join(ts.getHdbBasePath(),Os.LICENSE_KEY_DIR_NAME);if(e.csr){let n,s;$a();for await(let d of zr.search([]))if(d.is_authority&&!d.details.issuer.includes("HarperDB-Certificate-Authority")){if(qa.has(d.private_key_name)){n=qa.get(d.private_key_name),s=d;break}else if(d.private_key_name&&await vn.exists(ur.join(r,d.private_key_name))){n=vn.readFile(ur.join(r,d.private_key_name)),s=d;break}}if(!n){let d=await mw();s=d.ca,n=d.private_key}n=Nt.privateKeyFromPem(n),t.signingCA=s.certificate;let i=Nt.certificateFromPem(s.certificate);mt.info("Signing CSR with cert named",s.name);let a=Nt.certificationRequestFromPem(e.csr);try{a.verify()}catch(d){return mt.error(d),new Error("Error verifying CSR: "+d.message)}let c=Rd.pki.createCertificate();c.serialNumber="0"+Math.random().toString().slice(2,9),c.validity.notBefore=new Date;let l=new Date;c.validity.notAfter=l,c.validity.notAfter.setDate(l.getDate()+pw),mt.info("sign cert setting validity:",c.validity),mt.info("sign cert setting subject from CSR:",a.subject.attributes),c.setSubject(a.subject.attributes),mt.info("sign cert setting issuer:",i.subject.attributes),c.setIssuer(i.subject.attributes);let u=a.getAttribute({name:"extensionRequest"}).extensions;mt.info("sign cert adding extensions from CSR:",u),c.setExtensions(u),c.publicKey=a.publicKey,c.sign(n,Rd.md.sha256.create()),t.certificate=Nt.certificateToPem(c)}else mt.info("Sign cert did not receive a CSR from:",e.url,"only the CA will be returned");return t}o(Kae,"signCertificate");async function Yae(e,t){await yd({name:fS(),uses:["https","wss"],certificate:e,private_key_name:"privateKey.pem",is_authority:!1,is_self_signed:!0}),await yd({name:t.subject.getField("CN").value,uses:["https","wss"],certificate:Nt.certificateToPem(t),private_key_name:"privateKey.pem",is_authority:!0,is_self_signed:!0})}o(Yae,"createCertificateTable");async function yd(e){let t=new Mo(e.certificate);e.details={issuer:t.issuer.replace(/\n/g," "),subject:t.subject.replace(/\n/g," "),subject_alt_name:t.subjectAltName,serial_number:t.serialNumber,valid_from:t.validFrom,valid_to:t.validTo},$a(),await zr.patch(e)}o(yd,"setCertTable");async function _w(){let e=await uw("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}});return{publicKey:Nt.publicKeyFromPem(e.publicKey),privateKey:Nt.privateKeyFromPem(e.privateKey)}}o(_w,"generateKeys");async function gw(e,t,r){let n=Nt.createCertificate();if(!t){let a=await Mh();t=Nt.certificateFromPem(a.options.cert).publicKey}n.publicKey=t,n.serialNumber="0"+Math.random().toString().slice(2,9),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+pw);let i=[{name:"commonName",value:dS()},...Ew];return n.setSubject(i),n.setIssuer(r.subject.attributes),n.setExtensions(wq()),n.sign(e,Rd.md.sha256.create()),Nt.certificateToPem(n)}o(gw,"generateCertificates");async function mw(){let e=await Mq(),t;for(let r of e){if(!r.is_authority)continue;let n=await Dq(r.private_key_name);if(r.private_key_name&&n&&new Mo(r.certificate).checkPrivateKey(Sq(n))){mt.trace(`CA named: ${r.name} found with matching private key`),t={ca:r,private_key:n};break}}if(t)return t;mt.trace("No CA found with matching private key")}o(mw,"getCertAuthority");async function Oq(e,t,r=!0){let n=Nt.createCertificate();n.publicKey=t,n.serialNumber="0"+Math.random().toString().slice(2,9),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+pw);let i=[{name:"commonName",value:`HarperDB-Certificate-Authority-${ts.get(wl.REPLICATION_HOSTNAME)??yq(ts.get(wl.REPLICATION_URL))??Tq().split("-")[0]}`},...Ew];n.setSubject(i),n.setIssuer(i),n.setExtensions([{name:"basicConstraints",cA:!0,critical:!0},{name:"keyUsage",keyCertSign:!0,critical:!0}]),n.sign(e,Rd.md.sha256.create());let a=ur.join(ts.getHdbBasePath(),Os.LICENSE_KEY_DIR_NAME),c=ur.join(a,fi.PRIVATEKEY_PEM_NAME);return r&&await vn.writeFile(c,Nt.privateKeyToPem(e)),n}o(Oq,"generateCertAuthority");async function Wae(){let{privateKey:e,publicKey:t}=await _w(),r=await Oq(e,t),n=await gw(e,t,r);await Yae(n,r),Cq()}o(Wae,"generateCertsKeys");async function zae(){let e=await gw(Nt.privateKeyFromPem(fi.CERTIFICATE_VALUES.key),void 0,Nt.certificateFromPem(fi.CERTIFICATE_VALUES.cert)),t=ur.join(ts.getHdbBasePath(),Os.LICENSE_KEY_DIR_NAME),r=ur.join(t,fi.NATS_CERTIFICATE_PEM_NAME);await vn.exists(r)||await vn.writeFile(r,e);let n=ur.join(t,fi.NATS_CA_PEM_NAME);await vn.exists(n)||await vn.writeFile(n,fi.CERTIFICATE_VALUES.cert)}o(zae,"createNatsCerts");async function jae(){$a();for await(let e of zr.search([{attribute:"is_self_signed",value:!0}]))await zr.delete(e.name);await Sw()}o(jae,"renewSelfSigned");async function Sw(){Hae(),await Nq(),$a();let e=await mw();if(!e){mt.notify("A matching Certificate Authority and key was not found. A new CA will be created in advance, so it's available if needed.");let r=o(u=>{try{return{key:Nt.privateKeyFromPem(vn.readFileSync(u)),keyPath:u}}catch(d){return mt.warn(`Failed to parse private key from ${u}:`,d.message),{key:null,keyPath:u}}},"tryToParseKey"),n=ts.get(wl.TLS),s,i;if(Array.isArray(n)){for(let u of n)if(u.privateKey){let d=r(u.privateKey);if(s=d.key,i=d.keyPath,d.key)break}}else{let u=ts.get(wl.TLS_PRIVATEKEY),d=r(u);s=d.key,i=d.keyPath}let a=ur.join(ts.getHdbBasePath(),Os.LICENSE_KEY_DIR_NAME),c=Rq(a,i);s||(mt.warn("Unable to parse the TLS key",i,"A new key will be generated and used to create Certificate Authority"),{privateKey:s}=await _w(),vn.existsSync(ur.join(a,fi.PRIVATEKEY_PEM_NAME))&&(c=`privateKey${Tq().split("-")[0]}.pem`),await vn.writeFile(ur.join(a,c),Nt.privateKeyToPem(s)));let l=await Oq(s,Nt.setRsaPublicKey(s.n,s.e),!1);await yd({name:l.subject.getField("CN").value,uses:["https"],certificate:Nt.certificateToPem(l),private_key_name:c,is_authority:!0,is_self_signed:!0})}if(!await Mh()){let r=fS();mt.notify(`A suitable replication certificate was not found, creating new self singed cert named: ${r}`),e=e??await mw();let n=Nt.certificateFromPem(e.ca.certificate),s=n.publicKey,i=await gw(Nt.privateKeyFromPem(e.private_key),s,n);await yd({name:r,uses:["https","operations","wss"],certificate:i,is_authority:!1,private_key_name:e.ca.private_key_name,is_self_signed:!0})}}o(Sw,"reviewSelfSignedCert");function Cq(){let e=Uae(Object.keys(Os.CONFIG_PARAM_MAP),!0),t=ur.join(ts.getHdbBasePath(),Os.LICENSE_KEY_DIR_NAME),r=ur.join(t,fi.PRIVATEKEY_PEM_NAME),n=ur.join(t,fi.NATS_CERTIFICATE_PEM_NAME),s=ur.join(t,fi.NATS_CA_PEM_NAME),i=Os.CONFIG_PARAMS,a={[i.TLS_PRIVATEKEY]:e[i.TLS_PRIVATEKEY.toLowerCase()]?e[i.TLS_PRIVATEKEY.toLowerCase()]:r};e[i.TLS_CERTIFICATE.toLowerCase()]&&(a[i.TLS_CERTIFICATE]=e[i.TLS_CERTIFICATE.toLowerCase()]),e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(a[i.TLS_CERTIFICATEAUTHORITY]=e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]&&(a[i.OPERATIONSAPI_TLS_CERTIFICATE]=e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]),e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]&&(a[i.OPERATIONSAPI_TLS_PRIVATEKEY]=e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(a[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY]=e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]),(e[i.CLUSTERING_ENABLED.toLowerCase()]||e.clustering)&&(a[i.CLUSTERING_TLS_CERTIFICATE]=e[i.CLUSTERING_TLS_CERTIFICATE.toLowerCase()]??n,a[i.CLUSTERING_TLS_CERT_AUTH]=e[i.CLUSTERING_TLS_CERT_AUTH.toLowerCase()]??s,a[i.CLUSTERING_TLS_PRIVATEKEY]=e[i.CLUSTERING_TLS_PRIVATEKEY.toLowerCase()]??r),dw.updateConfigValue(void 0,void 0,a,!1,!0)}o(Cq,"updateConfigCert");function Pq(e){return e.startsWith("-----BEGIN")?e:kae(e,"utf8")}o(Pq,"readPEM");var _q=uS.createSecureContext;uS.createSecureContext=function(e){if(!e.cert||!e.key)return _q(e);let t={...e};delete t.key,delete t.cert;let r=_q(t);return r.context.setCert(e.cert),r.context.setKey(e.key,void 0),r};var Qae=Iq.prototype._init;Iq.prototype._init=function(e,t){Qae.call(this,e,t);let r=this;this._handle.oncertcb=function(n){let s=n.servername;r._SNICallback(s,(i,a)=>{this.sni_context=a?.context||a,this.certCbDone()})}};var Nl=new Map;function Lq(e,t){let r=new Map,n,s=!1;return i.initialize=a=>i.ready?i.ready:(a&&(a.secureContexts=r,a.secureContextsListeners=[]),i.ready=new Promise((c,l)=>{async function u(){try{r.clear(),Nl.clear();let d=0;if(lS===void 0){c();return}for await(let f of lS.system.hdb_certificate.search([])){let m=f.certificate,h=new Mo(m);f.is_authority&&(h.asString=m,Nl.set(h.subject,m))}for await(let f of lS.system.hdb_certificate.search([]))try{if(f.is_authority)continue;let m=e==="operations-api",h=f.is_self_signed?1:2;m&&f.uses?.includes?.("operations")&&(h+=1);let p=await Dq(f.private_key_name),_=f.certificate,g=new Mo(_);if(Nl.has(g.issuer)&&(_+=`
|