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.
@@ -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()}});Cv={type:"application/json",serializeStream:Xf,serialize:Zf,deserialize:XZ,q:.5};nn.set("*/*",Cv);nn.set("",Cv);o(XZ,"tryJSONParse");o(tm,"registerContentHandlers");ZZ=(0,wv.default)(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:a,type:c}=jE(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(jE,"findBestSerializer");yv=hA.default.get(U.HTTP_COMPRESSIONTHRESHOLD);o(rm,"serialize");o(ga,"serializeMessage");o(gA,"asyncSerialization");o(SA,"hasAsyncSerialization");o(e6,"streamToBuffer");t6=["ascii","utf8","utf-8","utf16le","utf-16le","ucs2","ucs-2","base64","base64url","latin1","binary","hex"];o(r6,"isBufferEncoding");o(n6,"parseContentType");o(ho,"getDeserializer");o(s6,"deserializerUnknownType");o(i6,"transformIterable");o(zE,"toCsvStream")});var bA={};Ce(bA,{Blob:()=>Ss,blobsWereEncoded:()=>qc,databasePaths:()=>RA,decodeBlobsWithWrites:()=>s_,decodeFromDatabase:()=>Gc,decodeWithBlobCallback:()=>i_,deleteBlob:()=>t_,deleteBlobsInObject:()=>Sa,deleteRootBlobPathsForDB:()=>AA,encodeBlobsAsBuffers:()=>p6,encodeBlobsWithFilePath:()=>n_,findBlobsInObject:()=>gu,getFileId:()=>r_,getFilePathForBlob:()=>kv,getRootBlobPathsForDB:()=>om,setDeletionDelay:()=>l6});function Bv(){}function t_(e){let t=kv(e);t&&setTimeout(()=>{(0,Ze.unlink)(t,r=>{r&&Eo.default.debug?.("Error trying to remove blob file",r)})},Fv)}function l6(e){Fv=e}function Hv(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 d6(t),t.source?TA(e,t.source,t):t.contentBuffer?u6(e,t):TA(e,sm.Readable.from(e.stream()),t),t}function TA(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(a6),h=(0,ZE.createDeflate)(),t.pipe(h).pipe(f)):(m||f.write(o6),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?yA:xv)<<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 r_(e){return bn.get(e)?.fileId}function kv(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=RA.get(e);if(!t){if(!e.databaseName)return Eo.default.warn?.("No database name specified, can not determine blob storage path"),[];let r=(0,e_.get)(U.STORAGE_BLOBPATHS);r?t=r.map(n=>(0,go.join)(n,e.databaseName)):t=[(0,go.join)((0,e_.getHdbBasePath)(),"blobs",e.databaseName)],RA.set(e,t)}return t}async function AA(e){let t=om(e);t&&await Promise.all(t.map(r=>qv(r)))}async function qv(e){if((0,Ze.existsSync)(e)){for(let t of await(0,Js.readdir)(e,{withFileTypes:!0}))if(t.isDirectory())await qv((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 u6(e,t){let r=t.contentBuffer,n=r.length;if(!(n<Uv))return e.size=n,TA(e,sm.Readable.from([r]),t)}function d6(e){let t=om(e.store),r=f6(),n=t?.length>1?m6(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,vv.ensureDirSync)(a),e.filePath=i}function f6(){let e=Mv.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)),Mv.set(In,e)}return Number(Atomics.add(e,0,1n))}function m6(e,t){let r=Date.now();if(!e.frequencyTable){e.lastUpdated=0;let s=new Array(XE);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,h6(e)),e.frequencyTable[t%XE]}async function h6(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(XE),n=t.map(s=>1/s);for(let s=0;s<XE;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 n_(e,t,r){_u=t,In=r,qc=!1;try{return e()}finally{_u=void 0,In=void 0}}function p6(e){qr=[];let t;try{t=e()}catch(n){throw qr=void 0,n}let r=qr.length<2?qr[0]:Promise.all(qr);return qr=void 0,r?r.then(()=>e()):t}function s_(e,t){try{qr=[],kc=t,e()}catch(n){throw kc=void 0,qr=void 0,n}kc=void 0;let r=qr.length<2?qr[0]:Promise.all(qr);return qr=void 0,r}function i_(e,t,r){In=r;try{return kc=t,e()}finally{kc=void 0}}function Gc(e,t){return In=t,e()}function Sa(e){gu(e,t=>{t_(t)})}function gu(e,t){if(e instanceof Ss)t(e);else if(Array.isArray(e))for(let r of e)typeof r=="object"&&r&&gu(r,t);else if(e&&typeof e=="object"&&!e[Symbol.iterator])for(let r in e){let n=e[r];typeof n=="object"&&n&&gu(e[r],t)}}function E6(){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,ZE,sm,vv,e_,go,Eo,Uv,Rr,xv,yA,Lv,o6,a6,Dv,bn,kc,Ss,_u,qr,In,qc,nm,JE,c6,QE,Fv,RA,Mv,XE,Ts=fe(()=>{_o=require("msgpackr"),Js=require("node:fs/promises"),Ze=require("node:fs"),ZE=require("node:zlib"),sm=require("node:stream"),vv=require("fs-extra"),e_=w(ce());k();go=require("path"),Eo=w(Ni());po();Uv=8192,Rr=8,xv=0,yA=1,Lv=255,o6=new Uint8Array([0,xv,255,255,255,255,255,255]),a6=new Uint8Array([0,yA,255,255,255,255,255,255]),Dv=0xffffffffffff,bn=new WeakMap,Ss=global.Blob||E6(),qc=!1,nm=new Uint8Array(8),JE=new DataView(nm.buffer),c6=6e4;o(Bv,"InstanceOfBlobWithNoConstructor");Bv.prototype=Ss.prototype;QE=class e extends Bv{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):(SA()&&gA(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=JE.getBigUint64(0);if(Number(f>>48n)===Lv)throw new Error("Error in blob: "+buffer.subarray(Rr));if(u=Number(f&0xffffffffffffn),u<n&&(u=n),u<Dv&&(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]===yA?new Promise((f,m)=>{(0,ZE.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=JE.getBigUint64(0);if(Number(j>>48n)===Lv)return P(new Error("Error in blob: "+$.subarray(Rr)));if(g=Number(j&0xffffffffffffn),g<Dv&&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(JE.getBigUint64(0)&0xffffffffffffn),g>l){p()?u?d=setTimeout(()=>{P(new Error("File read timed out"))},c6).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 Hv(this).saving??Promise.resolve()}},Fv=500;o(t_,"deleteBlob");o(l6,"setDeletionDelay");global.createBlob=function(e,t){let r=new QE(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(Hv,"saveBlob");o(TA,"writeBlobWithStream");o(r_,"getFileId");o(kv,"getFilePathForBlob");RA=new Map;o(om,"getRootBlobPathsForDB");o(AA,"deleteRootBlobPathsForDB");o(qv,"rimrafSteadily");o(im,"getFilePath");o(u6,"writeBlobWithBuffer");o(d6,"generateFilePath");Mv=new Map;o(f6,"getNextFileId");XE=128;o(m6,"getNextStorageIndex");o(h6,"createFrequencyTableForStoragePaths");o(n_,"encodeBlobsWithFilePath");o(p6,"encodeBlobsAsBuffers");o(s_,"decodeBlobsWithWrites");o(i_,"decodeWithBlobCallback");o(Gc,"decodeFromDatabase");o(Sa,"deleteBlobsInObject");o(gu,"findBlobsInObject");(0,_o.addExtension)({Class:Ss,type:11,unpack:o(function(e){let t=(0,_o.unpack)(e),r=new QE;if(Object.assign(r,t[0]),typeof t[1]!="object"){if(bn.set(r,{storageIndex:t[1],fileId:t[2],store:In}),kc)return kc(r)??r;if(!In)throw new Error("No store specified, cannot load blob from storage")}else bn.set(r,{storageIndex:0,fileId:null,storageBuffer:e,contentBuffer:t[1]}),r.size=t[1]?.length;return r},"unpack"),pack:o(function(e){let t=bn.get(e);if(_u!==void 0&&(qc=!0,t?.recordId!==void 0&&t.recordId!==_u))throw new Error("Cannot use the same blob in two different records");let r={...e};if(e.type&&(r.type=e.type),e.size!==void 0&&(r.size=e.size),t){if(t.storageBuffer)return t.storageBuffer;if(t.contentBuffer?.length<Uv)return r.size=t.contentBuffer.length,(0,_o.pack)([r,t.contentBuffer])}if(_u!==void 0){if(t=Hv(e),!t.fileId)throw new Error("Unable to save blob without file id");return t.recordId=_u,(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(JE.getBigUint64(0)&0xffffffffffffn)===n.length-Rr))return Buffer.concat([(0,_o.pack)([r]),n]);if(qr)qr.push(e.bytes());else throw new Error("Incomplete blob");return Buffer.alloc(0)}catch(n){if(n.code==="ENOENT"&&qr)return qr.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(E6,"polyfillBlob")});var Yv={};Ce(Yv,{onStorageReclamation:()=>am,runReclamationHandlers:()=>OA,setAvailableSpaceRatioGetter:()=>g6});function am(e,t,r){(r||(0,a_.getWorkerIndex)()===(0,a_.getWorkerCount)()-1)&&(o_.has(e)||o_.set(e,[]),o_.get(e).push({priority:0,handler:t}),wA||(wA=setTimeout(OA,$v).unref()))}async function OA(){for(let[e,t]of o_)try{let r=await Kv(e),n=_6/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&&(NA.default.info?.(`Running storage reclamation handler for ${e} with priority ${n}`),await c)}}}catch(r){NA.default.error?.("Error running storage reclamation handlers",r)}wA=setTimeout(OA,$v).unref()}function g6(e){Kv=e??Vv}var IA,a_,NA,c_,Gv,o_,_6,$v,wA,Vv,Kv,l_=fe(()=>{IA=require("node:fs/promises"),a_=w(st()),NA=w(Ni());k();c_=w(ce()),Gv=w(ie());c_.default.initSync();o_=new Map,_6=c_.default.get(U.STORAGE_RECLAMATION_THRESHOLD)??.4,$v=(0,Gv.convertToMS)(c_.default.get(U.STORAGE_RECLAMATION_INTERVAL))||36e5;o(am,"onStorageReclamation");Vv=o(async e=>{if(IA.statfs){let t=await(0,IA.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"),Kv=Vv;o(OA,"runReclamationHandlers");o(g6,"setAvailableSpaceRatioGetter")});var iU={};Ce(iU,{ACTION_32_BIT:()=>h_,ACTION_64_BIT:()=>R6,AUDIT_STORE_OPTIONS:()=>um,Decoder:()=>Vc,HAS_BLOBS:()=>Nn,HAS_CURRENT_RESIDENCY_ID:()=>Kc,HAS_EXPIRATION_EXTENDED_TYPE:()=>mm,HAS_ORIGINATING_OPERATION:()=>fm,HAS_PREVIOUS_RESIDENCY_ID:()=>Yc,REMOTE_SEQUENCE_UPDATE:()=>p_,createAuditEntry:()=>Tu,getLastRemoved:()=>vA,openAuditStore:()=>f_,readAuditEntry:()=>Ut,removeAuditEntry:()=>m_,setAuditRetention:()=>T6,transactionKeyEncoder:()=>tU});function f_(e){let t=e.auditStore=e.openDB(CA.AUDIT_STORE_NAME,{create:!1,...um});t||(t=e.auditStore=e.openDB(CA.AUDIT_STORE_NAME,um),zv(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=LA;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()-PA/(1+i*i)})){try{m=m_(t,p,_)}catch(g){Su.warn("Error removing audit entry",g)}if(h=p,await new Promise(setImmediate),++f>=S6){a=10;break}}await m}finally{f===0?a=Math.min(a<<1,PA/10):(zv(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&&!Wv)for(let l of t.getKeys({reverse:!0,limit:1}))l>Date.now()&&(Wv=!0,Su.error("The current time is before the last recorded entry in the audit log. Time reversal can undermine the integrity of data tracking and certificate validation and the time must be corrected."));return t}function m_(e,t,r){let n=y6(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)===DA){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 zv(e,t){MA[0]=t,e.put(Symbol.for("last-removed"),rU)}function vA(e){let t=e.get(Symbol.for("last-removed"));if(t)return rU.set(t),MA[0]}function T6(e,t=LA){PA=e,LA=t}function Tu(e,t,r,n,s,i,a,c,l,u,d,f,m){let h=nU[a];if(!h)throw new Error(`Invalid audit entry type ${a}`);let p=1;if(n&&(n>1?Ta.setFloat64(0,n):Rs.set(UA),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&Kc&&y(u),l&Yc&&y(d),l&mm&&(Ta.setFloat64(p,f),p+=8),l&fm&&y(sU[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,$c.writeKey)(T,Rs,p);let I=p-R-1;I>127?I>16383?(Su.error("Key or username was too large for audit entry",T),p=R+1,Rs[R]=0):(Rs.copyWithin(R+2,R+1,p),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 y6(e){let t=0;e[0]==66&&(t=8);let r=e[t];if(r<128)return r;let n=e.dataView||(e.dataView=new Vc(e.buffer,e.byteOffset,e.byteLength));return n.position=t,n.readInt()}function Ut(e,t=0,r=void 0){try{let n=e.dataView||(e.dataView=new Vc(e.buffer,e.byteOffset,e.byteLength));n.position=t;let s;e[n.position]==66&&(s=n.readFloat64());let i=n.readInt(),a=n.readInt(),c=n.readInt(),l=n.readInt(),u=n.position,d=n.position+=l,f=n.readFloat64(),m,h,p,_;if(i&Kc&&(m=n.readInt()),i&Yc&&(h=n.readInt()),i&mm&&(p=n.readFloat64()),i&fm){let R=n.readInt();_=sU[R]}l=n.readInt();let g=n.position,y=n.position+=l,T;return{type:nU[i&7],tableId:c,nodeId:a,get recordId(){return(0,$c.readKey)(e,u,d)},getBinaryRecordId(){return e.subarray(u,d)},version:f,previousLocalTime:s,get user(){return y>g?(0,$c.readKey)(e,g,y):void 0},get encoded(){return t?e.subarray(t,r):e},getValue(R,I,P){if(i&u_||i&cm&&!I)return T||(T=Gc(()=>R.decoder.decode(e.subarray(n.position,r)),R.rootStore)),T;if(i&cm&&P)return cA(R.getEntry(this.recordId),P,R)},getBinaryValue(){return i&(u_|cm)?e.subarray(n.position,r):void 0},extendedType:i,residencyId:m,previousResidencyId:h,expiresAt:p,originatingOperation:_}}catch(n){return Su.error("Reading audit entry error",n,e),{}}}var $c,d_,CA,lm,eU,Su,Rs,Ta,tU,um,PA,S6,MA,rU,LA,Wv,u_,cm,jv,DA,Jv,Qv,Xv,Zv,h_,R6,p_,Kc,Yc,fm,mm,Nn,nU,sU,Vc,uo=fe(()=>{$c=require("ordered-binary"),d_=w(ce()),CA=w(kt());k();lm=w(st()),eU=w(ie());Wc();Su=w(z());KE();Ts();l_();(0,d_.initSync)();Rs=Buffer.alloc(2816),Ta=new DataView(Rs.buffer,Rs.byteOffset,2816),tU={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,$c.writeKey)(e,t,r)},readKey(e,t,r){return e[t]===66?(e.dataView||(e.dataView=new DataView(e.buffer,e.byteOffset,e.byteLength))).getFloat64(t):(0,$c.readKey)(e,t,r)}},um={encoding:"binary",keyEncoder:tU},PA=(0,eU.convertToMS)((0,d_.get)(U.LOGGING_AUDITRETENTION))||86400*3,S6=1e3,MA=new Float64Array(1),rU=new Uint8Array(MA.buffer),LA=1e4,Wv=!1;o(f_,"openAuditStore");o(m_,"removeAuditEntry");o(zv,"updateLastRemoved");o(vA,"getLastRemoved");o(T6,"setAuditRetention");u_=16,cm=32,jv=1,DA=2,Jv=3,Qv=4,Xv=5,Zv=6,h_=14,R6=15,p_=11,Kc=512,Yc=1024,fm=2048,mm=4096,Nn=8192,nU={put:jv|u_,[jv]:"put",delete:DA,[DA]:"delete",message:Jv|u_,[Jv]:"message",invalidate:Qv|cm,[Qv]:"invalidate",patch:Xv|cm,[Xv]:"patch",relocate:Zv,[Zv]:"relocate"},sU={insert:1,update:2,upsert:3,1:"insert",2:"update",3:"upsert"};o(Tu,"createAuditEntry");o(y6,"readAction");o(Ut,"readAuditEntry");Vc=class extends DataView{static{o(this,"Decoder")}position=0;readInt(){let t;return t=this.getUint8(this.position++),t>=128?t>=192?t===255?(t=this.getUint32(this.position),this.position+=4,t):(t=this.getUint32(this.position-1)&1073741823,this.position+=3,t):(t=this.getUint16(this.position-1)&32767,this.position++,t):t}readFloat64(){try{let t=this.getFloat64(this.position);return this.position+=8,t}catch(t){throw t.message=`Error reading float64: ${t.message} at position ${this.position}`,t}}}});var uU={};Ce(uU,{ENTRY:()=>b6,HAS_EXPIRATION:()=>g_,HAS_RESIDENCY_ID:()=>qA,HAS_STRUCTURE_UPDATE:()=>S_,LAST_TIMESTAMP_PLACEHOLDER:()=>dm,LOCAL_TIMESTAMP:()=>A6,METADATA:()=>yu,NEW_TIMESTAMP_PLACEHOLDER:()=>aU,NO_TIMESTAMP:()=>xA,PENDING_LOCAL_TIME:()=>GA,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>UA,RecordEncoder:()=>kA,TIMESTAMP_ASSIGN_LAST:()=>N6,TIMESTAMP_ASSIGN_NEW:()=>cU,TIMESTAMP_ASSIGN_PREVIOUS:()=>lU,TIMESTAMP_PLACEHOLDER:()=>E_,TIMESTAMP_RECORD_PREVIOUS:()=>BA,entryMap:()=>Ra,handleLocalTimeForGets:()=>T_,lastMetadata:()=>ct,recordUpdater:()=>$A,removeEntry:()=>jc});function O6(){return Em[0]=Em[0]^64,I6.getFloat64(0)}function T_(e,t){let r=e.getEntry;e.readCount=0,e.cachePuts=!1,e.rootStore=t,e.encoder.rootStore=t,e.getEntry=function(a,c){e.readCount++,ct=null;let l=r.call(this,a,c);return l&&(ct&&(l.metadataFlags=ct[yu],l.localTime=ct.localTime,l.residencyId=ct.residencyId,ct.expiresAt>=0&&(l.expiresAt=ct.expiresAt),ct=null),l.value&&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[yu],l.localTime=ct.localTime,l.residencyId=ct.residencyId,ct.expiresAt>=0&&(l.expiresAt=ct.expiresAt),ct=null),l))};let i=e.useReadTransaction();if(i.done(),!i.done.isTracked){let a=i.constructor,c=i.use,l=i.done;a.prototype.use=function(){this.timerTracked||(this.timerTracked=!0,zc.push(new WeakRef(this))),c.call(this)},a.prototype.done=function(){if(l.call(this),this.isDone)for(let u=0;u<zc.length;u++){let d=zc[u].deref();(!d||d.isDone||d.isCommitted)&&zc.splice(u--,1)}},a.prototype.done.isTracked=!0}return e}function $A(e,t,r){return function(n,s,i,a,c=-1,l,u,d="put",f,m){f||l==null?Ru=i?.localTime?BA|lU:xA:Ru=l?i?.localTime?BA|16384:cU|16384:xA;let h=u?.expiresAt;if(h>=0&&(c|=g_),pm=c,FA=h,i?.version===a&&l===!1)throw new Error("Must retain local time if version is not changed");let p={version:a,instructedWrite:Ru>0},_,g=0;try{let y=i?.residencyId,T=u?.residencyId;T&&(HA=T,pm|=qA,g|=Kc),y!==T&&(g|=Yc,y||(y=0)),c&g_&&(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=n_(()=>e.put(n,s,p),n,e.rootStore),qc&&(g|=Nn)),l){let I=u?.user?.username;if(m&&(n_(()=>e.encoder.encode(m),n,e.rootStore),qc&&(g|=Nn)),e.encoder.hasStructureUpdate&&(g|=S_,e.encoder.hasStructureUpdate=!1),f&&i?.localTime){let P=i?.localTime,Y=r.get(P);if(Y){let te=Ut(Y).previousLocalTime;return R=r.put(P,Tu(a,t,n,te,u?.nodeId??server.replication.getThisNodeId(r)??0,I,d,hm,g,T,y,h),{ifVersion:_}),R}}R=r.put(s===void 0?aU:dm,Tu(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 jc(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 oU,__,E_,dm,UA,aU,A6,yu,b6,Em,I6,xA,cU,N6,lU,BA,g_,qA,GA,S_,Ra,w6,hm,Ru,pm,FA,HA,ct,kA,zc,Wc=fe(()=>{oU=require("msgpackr");uo();__=w(z());Ts();Ts();E_=new Uint8Array([1,1,1,1,4,64,0,0]),dm=new Uint8Array([1,1,1,1,1,0,0,0]),UA=new Uint8Array([1,1,1,1,3,64,0,0]),aU=new Uint8Array([1,1,1,1,0,64,0,0]),A6=Symbol("local-timestamp"),yu=Symbol("metadata"),b6=Symbol("entry"),Em=new Uint8Array(8),I6=new DataView(Em.buffer,0,8),xA=0,cU=0,N6=1,lU=3,BA=4,g_=16,qA=32,GA=1,S_=256,Ra=new WeakMap,Ru=0,pm=-1,FA=-1,HA=0,ct=null,kA=class extends oU.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(Ru||pm>=0){let c=0,l=Ru;l&&(c+=8,Ru=0);let u=pm,d=FA,f=HA;u>=0&&(c+=4,pm=-1,d>=0&&(c+=8,FA=-1),f&&(c+=4,HA=0));let m=w6=n.call(this,i,a|2048|c);hm=m.subarray((m.start||0)+c,m.end);let h=m.start||0;return l&&(E_[4]=l,E_[5]=l>>8,m.set(E_,h),h+=8),qc&&(u|=Nn),u>=0&&((m.dataView||(m.dataView=new DataView(m.buffer,m.byteOffset,m.byteLength))).setUint32(h,u|h_<<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=O6(),i=t[c]}let u,d;i<32&&(i===h_?(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&g_&&(u=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8),a&qA&&(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,[yu]:a,expiresAt:u,residencyId:d},f}return r?.valueAsBuffer?t:Gc(()=>super.decode(t,r),this.rootStore)}catch(c){return __.error("Error decoding record",c,"data: "+t.slice(0,40).toString("hex")),null}}};o(O6,"getTimestamp");o(T_,"handleLocalTimeForGets");zc=[];setInterval(()=>{for(let e=0;e<zc.length;e++){let t=zc[e].deref();!t||t.isDone||t.isCommitted?zc.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(__.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):__.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($A,"recordUpdater");o(jc,"removeEntry")});function YA(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?YA(f.conditions,f.operator,r,n,s,i,a,c):Nu(f,n,f.descending||s.reverse===!0,r,s.allowFullScan,c,i)}o(u,"executeCondition");function d(f,m,h){return f.map((p,_)=>{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=B6(r.primaryStore,p.estimated_count,h)),y}).filter(Boolean)}o(d,"mapConditionsToFilters")}function Nu(e,t,r,n,s,i,a){let c=e[0]??e.attribute,l=e[1]??e.value,u=e.comparator;if(l===void 0&&u!=="sort")throw new Gr.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 Gr.ClientError("Can not directly query a relational attribute, must query an attribute within the target table");let P=I.definition?.tableClass||I.elements?.definition?.tableClass,Y=new Map,te=Nu({attribute:c.length>2?c.slice(1):c[1],value:l,comparator:u},t,r,P,s,Y);if(I.relationship.to){i[c[0]]=Y;let x=!!Ci(P.attributes,I.relationship.to)?.elements;te=M6(te,I,P.primaryStore,x,Y)}if(I.relationship.from){let x=o($=>($?.key!==void 0&&($=$.key),Nu({attribute:I.relationship.from,value:$},t,r,n,s,Y)),"searchEntry");I.elements?(i[c[0]]=Y,te=v6(te,I,P.primaryStore,Y,x)):te=te.flatMap(x)}return te}else if(c.length===1)c=c[0];else throw new Gr.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(WA[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 Gr.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 Gr.ClientError(`"${c}" is not indexed, can not search for this attribute`,404);if(s===!1&&g)throw new Gr.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 Gr.ServerError(`"${c}" is not indexed yet, can not search for this attribute`,503);if(l===null&&f&&!f.indexNulls)throw new Gr.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 Gr.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 M6(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 v6(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()),WA[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 Gr.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&&y_(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=Nu(e,r.transaction.getReadTxn(),!1,t),Y;y.to?Y=P.flatMap(x=>t.primaryStore.get(x)[y.to]):Y=P.map(wu);let te=new Set(Y);y.idFilter=x=>te.has(wu(x)),y.idFilter.idSet=te}return I}return o(y,"recordFilter"),s&&(y.idFilter=f),y}o(u,"attributeComparator")}function y_(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=WA[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=y_(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=L6*So(e.primaryStore)+1;else if(n==="between")r.estimated_count=P6*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=C6*So(e.primaryStore)+1}typeof r.descending=="boolean"&&(r.estimated_count/=2)}return r.estimated_count}return o(t,"estimateConditionForTable"),t}function A_(e,t){if(e)if(To=e,Au.lastIndex=0,U6.test(e))try{if(t&&(t.conditions=[]),Qs=t??new Iu,_m(Qs,""),Lr!==To.length&&qt("Unable to parse query, unexpected end of query"),Qs.parseErrorMessage&&(Qs.parseError=new VA(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 qt(e){let t=`${e} at position ${Lr}`;Qs.parseErrorMessage=Qs.parseErrorMessage?Qs.parseErrorMessage+", "+t:t}function _m(e,t){let r=Au,n,s,i,a,c,l=decodeURIComponent,u;for(;n=r.exec(To);){Lr=r.lastIndex;let[,d,f]=n;a?(d&&qt(`expected operator, but encountered '${d}'`),a=!1,c=!1):c=!0;let m;switch(f){case"=":s!=null?(d.length<=2?i=d:qt(`invalid FIQL operator ${d}`),l=dU):(l=decodeURIComponent,i="equals",d||qt("attribute must be specified before equality comparator"),s=bu(d));break;case"==":case"!=":case"<":case"<=":case">":case">=":case"===":case"!==":i=D6[f],l=KA[i]?dU:decodeURIComponent,d||qt(`attribute must be specified before comparator ${f}`),s=bu(d);break;case"&=":case"|=":case"|":case"&":case"":case void 0:if(s==null)s===void 0&&(t&&qt(`expected '${t}', but encountered ${f[0]?"'"+f[0]+"'":"end of string"}}`),qt(`no comparison specified before ${f?"'"+f+"'":"end of string"}`));else{e.conditions||qt("conditions/comparisons are not allowed in a property list");let p={comparator:i,attribute:s||null,value:l(d)};if(i==="eq"&&fU(p,d),s===""){let _=e.conditions[e.conditions.length-1];_.chainedConditions=_.chainedConditions||[],_.chainedConditions.push(p),_.operator=u}else R_(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?qt("conditions/comparisons are not allowed in a property list"):e.push(bu(d)),s=void 0;break;case"(":Au.lastIndex=Lr;let h=_m(d?[]:new Iu,")");switch(d){case"":R_(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:qt("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":qt("group by is not implemented yet");case"sort":e.sort=mU(h);break;default:qt(`unknown query function call ${d}`)}To[Lr]===","?r.lastIndex=++Lr:a=!0,s=null;break;case"{":e.conditions&&qt("property sets are not allowed in a queries"),d||qt("property sets must have a defined parent property name"),Au.lastIndex=Lr,m=_m([],"}"),m.name=d,e.push(m),To[Lr]===","?r.lastIndex=++Lr:a=!0;break;case"[":if(Au.lastIndex=Lr,d?(m=_m(new Iu,"]"),m.name=d):m=_m(e.conditions?new Iu:[],"]"),e.conditions)if(R_(e,u),To[Lr]==="="){l=decodeURIComponent,i="equals",s=bu(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"&&fU(p,d),R_(e,u),e.conditions.push(p)}else d&&qt("no attribute or comparison specified");else(d||e.length>0&&c)&&e.push(bu(d));return e}else qt(t?`expected '${t}', but encountered '${f[0]}'`:`unexpected token '${f[0]}'`);default:qt(`unexpected operator '${f}'`)}if(t!==")"&&(r=s?x6:Au,r.lastIndex=Lr),Lr===To.length)return e}t&&qt(`expected '${t}', but encountered end of string`)}function R_(e,t){e.conditions.length>0&&(e.operator?e.operator!==t&&qt("Can not mix operators within a condition grouping"):e.operator=t)}function bu(e){return e.indexOf(".")>-1?e.split(".").map(bu):decodeURIComponent(e)}function dU(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 Gr.ClientError(`Unknown type ${t}`)}return decodeURIComponent(e)}function fU(e,t){if(t.indexOf("*")>-1)if(t.endsWith("*"))e.comparator="starts_with",e.value=decodeURIComponent(t.slice(0,-1));else throw new Gr.ClientError("wildcard can only be used at the end of a string")}function mU(e){let t=hU(e[0]);return e.length>1&&(t.next=mU(e.slice(1))),t}function hU(e){if(Array.isArray(e)){let t=hU(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}}qt(`Unknown sort type ${e}`)}function wu(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 B6(e,t,r){return t*r/So(e)}var Gr,ys,Oi,ya,C6,P6,L6,D6,KA,WA,VA,U6,Au,x6,Lr,Qs,To,Iu,b_=fe(()=>{Gr=w(Ee()),ys=w(kt()),Oi=require("ordered-binary"),ya=require("lmdb");Sm();Wc();C6=.3,P6=.1,L6=.05,D6={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},KA={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};o(YA,"executeConditions");o(Nu,"searchByIndex");o(Ci,"findAttribute");o(M6,"joinTo");o(v6,"joinFrom");WA={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(y_,"estimateCondition");VA=class extends Gr.Violation{static{o(this,"SyntaxViolation")}},U6=/[()[\]|!<>.]|(=\w*=)/,Au=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,x6=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/g;o(A_,"parseQuery");o(qt,"recordError");o(_m,"parseBlock");o(R_,"assignOperator");o(bu,"decodeProperty");o(dU,"typedDecoding");o(fU,"wildcardDecoding");o(mU,"toSortObject");o(hU,"toSortEntry");Iu=class{static{o(this,"Query")}constructor(){this.conditions=[]}[Symbol.iterator](){return this.conditions[Symbol.iterator]()}get(t){for(let r=0;r<this.conditions.length;r++){let n=this.conditions[r];if(n.attribute===t)return n.value}}getAll(){let t=[];for(let r=0,n=this.conditions.length;r<n;r++){let s=this.conditions[r];s.attribute&&t.push(s.value)}return t}};o(wu,"flattenKey");o(So,"estimatedEntryCount");o(B6,"intersectionEstimate")});var pU,Xs,I_=fe(()=>{pU=w(zs());ba();Xs=class extends URLSearchParams{static{o(this,"RequestTarget")}#e;pathname;search;id;isCollection;constructor(t){let r,n;if(t&&(r=t.indexOf("?"))>-1){n=t.slice(0,r);let s=t.slice(r+1);super(s),this.search=s}else super(),n=t;this.pathname=n??"",this.#e=t}toString(){return this.#e?this.#e:this.size>0?this.pathname+"?"+super.toString():this.pathname}get url(){return this.toString()}delete(t){super.delete(t),this.conditions&&(this.conditions=this.conditions.filter(r=>r.attribute!==t)),this.#e=void 0}set(t,r){this.delete(t),super.set(t,r),this.conditions?.push({attribute:t,value:r})}append(t,r){super.append(t,r),this.#e=void 0,this.conditions?.push({attribute:t,value:r})}};(0,pU._assignPackageExport)("Resource",Dr)});var TU={};Ce(TU,{MultiPartId:()=>N_,Resource:()=>Dr,contextStorage:()=>Cu,snakeCase:()=>H6,transformForSelect:()=>w_});function H6(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function EU(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 N_;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 Ou.ClientError(`Invalid argument for data, must be an object, but got ${s}`);c===null&&(u=!0)}else i?a=i.getContext?.()||i:s&&typeof s=="object"&&!Array.isArray(s)&&(a=s);if(c===void 0)if(typeof s=="object"&&s){if(l=s,c=s instanceof URLSearchParams?s.toString():s.url,s.conditions)c=s.id;else if(typeof c=="string")if(this.directURLMapping)c=c.slice(1),l.id=c;else{let _=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 Xs,l.id=c,u=!1)))}c===void 0&&(c=s.id??null,c==null&&(u=!0))}else c=s,l=new Xs,l.id=c,c==null&&(u=!0);l||(l=new Xs,l.id=c),u&&(l.isCollection=!0);let f;a||(a=Cu.getStore()??{}),l.ensureLoaded!=null||l.async||u?(f={...t},l.ensureLoaded!=null&&(f.ensureLoaded=l.ensureLoaded),l.async&&(f.async=l.async),u&&(f.isCollection=!0)):f=t;let m=this.loadAsInstance,h=p;if((m===!1?!this.explicitContext:this.explicitContext===!1)&&(h=o(_=>Cu.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 Ou.AccessViolation(a.user);return typeof d?.then=="function"?d.then(T=>e(_,l,a,T)):e(_,l,a,d)});if(!g)throw new Ou.AccessViolation(a.user)}return typeof d?.then=="function"?d.then(g=>e(_,l,a,g)):e(_,l,a,d)}o(p,"authorizeActionOnResource")}}function Kn(e,t){let r=new Ou.ClientError(`The ${e.constructor.name} does not have a ${t} method implemented`,405);r.allow=[],r.method=t;for(let n of["get","put","post","delete","query","move","copy"])typeof e[n]=="function"&&r.allow.push(n);throw r}function zA(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 w_(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):zA(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(zA(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(zA(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]=w_(c.select||c,d)}let u=a(c.name);return l(u)}else return a(c);else return c}}o(i,"handleProperty")}var _U,gU,Ou,SU,Cu,F6,Dr,Jc,N_,ba=fe(()=>{_U=require("crypto");Jf();Eu();gU=w(zs()),Ou=w(Ee());xc();b_();SU=require("async_hooks");I_();Cu=new SU.AsyncLocalStorage,F6={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=w_(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):Kn(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):Kn(t,"patch")},{hasContent:!0,type:"update"});static delete=On(function(t,r,n,s){return t.delete?t.delete(r):Kn(t,"delete")},{hasContent:!1,type:"delete"});static getNewId(){return(0,_U.randomUUID)()}static create(t,r,n){n?n.getContext&&(n=n.getContext()):n=Cu.getStore()??{};let s;return this.loadAsInstance===!1?s=t:t==null?s=r?.[this.primaryKey]??this.getNewId():Array.isArray(t)&&typeof t[0]!="object"?s=r?.[this.primaryKey]??[...t,this.getNewId()]:typeof t!="object"?s=r?.[this.primaryKey]??[t,this.getNewId()]:(s=t?.[this.primaryKey]??this.getNewId(),n=r||{},r=t),vt(n,async()=>{let i=new this(s,n),a=await i.create?i.create(s,r):Kn(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):Kn(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):Kn(t,"connect")},{hasContent:!0,type:"read"});static subscribe=On(function(t,r,n,s){return t.subscribe?t.subscribe(r):Kn(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):Kn(t,"publish")},{hasContent:!0,type:"create"});static search=On(function(t,r,n){let s=t.search?t.search(r):Kn(t,"search"),i=n.select;if(i&&n.hasOwnProperty("select")&&s!=null&&!s.selectApplied){let a=w_(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):Kn(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):Kn(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):Kn(t,"move")},{hasContent:!0,type:"delete"});async post(t){if(this.#r)return(await this.constructor.create(this.#e,t,this.#t)).#e;Kn(this,"post")}static isCollection(t){return t&&t.#r}get isCollection(){return this.#r}static coerceId(t){return t}static parseQuery(t,r){return A_(t,r)}static parsePath(t,r,n){let s=t.indexOf(".");if(s>-1){let a=t.slice(s+1),c=r?.headers&&F6[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:EU(t,this),isCollection:Jc}}let i=EU(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 Vn}connect(t,r){return r?.subscribe!==!1?this.subscribe?.(r):new Vn}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,gU._assignPackageExport)("Resource",Dr);o(H6,"snakeCase");o(EU,"pathToId");N_=class extends Array{static{o(this,"MultiPartId")}toString(){return this.join("/")}};o(On,"transactional");o(Kn,"missingMethod");o(zA,"selectFromObject");o(w_,"transformForSelect")});var Qc,jA=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 AU={};Ce(AU,{Resources:()=>O_,keyArrayToString:()=>Pu,resetResources:()=>k6,resources:()=>As});function k6(){return As=new O_,ve.resources=As,As}function Pu(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var RU,yU,O_,As,Lu=fe(()=>{xc();jA();RU=w(z()),yU=w(Ee());Pr();O_=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 yU.ServerError(`Conflicting paths for ${t}`);RU.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(k6,"resetResources");o(Pu,"keyArrayToString")});function XA(e,t,r,n,s){let i=e.primaryStore.env.path,a=e.primaryStore.tableId,c;s?.crossThreads===!1?(c=IU,q6(e.primaryStore,e.auditStore)):(c=bU,e.primaryStore.env.hasSubscriptionCommitListener||(e.primaryStore.env.hasSubscriptionCommitListener=!0,e.primaryStore.on("committed",()=>{NU(bU[i])})));let l=c[i]||(c[i]=[]);if(l.auditStore=e.auditStore,l.lastTxnTime==null&&(l.lastTxnTime=Date.now()),s?.scope==="full-database")return;let u=l[a];u||(u=l[a]=new Map,u.envs=l,u.tableId=a,u.store=e.primaryStore),t=Pu(t);let d=new QA(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 NU(e){if(!e)return;let t=e.auditStore;t.resetReadTxn(),wU(e.auditStore);let r;for(let{key:n,value:s}of t.getRange({start:e.lastTxnTime,exclusiveStart:!0})){e.lastTxnTime=n;let i=Ut(s),a=e[i.tableId];if(!a)continue;let c=i.recordId,l=Pu(c),u=0;do{let d=a.get(l);if(d){for(let m of d)if(!(u>0&&!(m.includeDescendants&&!(m.onlyChildren&&u>1)))){if(m.startTime>=n){(0,JA.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,JA.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 q6(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=IU[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{NU(l)}finally{r.threadLocalWrites[0]=l.lastTxnTime,r.unlock("thread-local-writes")}},"acquiredLock");r.attemptLock("thread-local-writes",u)&&u()})}}function wU(e){e.nextTransaction?.resolve();let t;e.nextTransaction=new Promise(r=>{t=r}),e.nextTransaction.resolve=t}function OU(e){return e.nextTransaction||(XA({primaryStore:e,auditStore:e},null,null,0,{scope:"full-database"}),wU(e)),e.nextTransaction}var JA,bU,IU,QA,ZA=fe(()=>{JA=w(z());Eu();Lu();uo();bU=Object.create(null),IU=Object.create(null);o(XA,"addSubscription");QA=class extends Vn{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(NU,"notifyFromTransactionData");o(q6,"listenToCommits");o(wU,"nextTransaction");o(OU,"whenNextTransaction")});var PU=M((qNe,CU)=>{"use strict";var eb=class{static{o(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};CU.exports=eb});var DU=M(($Ne,LU)=>{"use strict";var tb=class{static{o(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};LU.exports=tb});var Tm=M((KNe,vU)=>{"use strict";var MU=ce(),G6=(k(),v(K)),{RecordEncoder:$6}=(Wc(),v(uU));MU.initSync();var V6=MU.get(G6.CONFIG_PARAMS.STORAGE_CACHING)!==!1,rb=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=V6&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:$6})}};vU.exports=rb});var Rm=M((WNe,UU)=>{"use strict";var Yn=ce(),bs=(k(),v(K));Yn.initSync();var C_=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=Yn.get(bs.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Yn.get(bs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Yn.get(bs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Yn.get(bs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Yn.get(bs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Yn.get(bs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Yn.get(bs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Yn.get(bs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Yn.get(bs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Yn.get(bs.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Yn.get(bs.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Yn.get(bs.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};UU.exports=C_;C_.MAX_DBS=1e4});var _t=M((jNe,KU)=>{"use strict";var sb=require("lmdb"),Zs=require("fs-extra"),Wn=require("path"),P_=An(),FU=z(),Cn=tn().LMDB_ERRORS_ENUM,L_=DU(),ib=Tm(),HU=Rm(),Ia=kt(),xU=(k(),v(K)),{table:K6,resetDatabases:Y6}=(Le(),v(ft)),BU=ce(),ei=Ia.INTERNAL_DBIS_NAME,kU=Ia.DBI_DEFINITION_NAME,W6="data.mdb",z6="lock.mdb",ym=".mdb",j6="-lock",nb=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 sb.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function D_(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(D_,"pathEnvNameValidation");async function ob(e,t,r=!0){try{await Zs.access(e)}catch(n){throw n.code==="ENOENT"?new Error(Cn.INVALID_BASE_PATH):n}try{let n=Wn.join(e,t+ym);return await Zs.access(n,Zs.constants.R_OK|Zs.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await Zs.access(Wn.join(e,t,W6),Zs.constants.R_OK|Zs.constants.F_OK),Wn.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(ob,"validateEnvironmentPath");function M_(e,t){if(P_.validateEnv(e),t===void 0)throw new Error(Cn.DBI_NAME_REQUIRED)}o(M_,"validateEnvDBIName");async function J6(e,t,r=!1,n=!1){D_(e,t);let s=Wn.basename(e);t=t.toString();let i=BU.get(xU.CONFIG_PARAMS.DATABASES);i||BU.setProperty(xU.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await ob(e,t,n),qU(e,t,r)}catch(a){if(a.message===Cn.INVALID_ENVIRONMENT){let c=Wn.join(e,t);await Zs.mkdirp(n?c:e);let l=new HU(n?c:c+ym,!1),u=sb.open(l);u.dbis=Object.create(null);let d=new ib(!1);u.openDB(ei,d),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let f=ab(e,t,r);return u[Ia.ENVIRONMENT_NAME_KEY]=f,global.lmdb_map[f]=u,u}throw a}}o(J6,"createEnvironment");async function Q6(e,t,r,n=!0){D_(e,t),t=t.toString();let s=Wn.join(e,t);return K6({table:t,database:Wn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}o(Q6,"copyEnvironment");async function qU(e,t,r=!1){D_(e,t),t=t.toString();let n=ab(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 ob(e,t),i=Wn.join(e,t+ym),a=s!=i,c=new HU(s,a),l=sb.open(c);l.dbis=Object.create(null);let u=$U(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(qU,"openEnvironment");async function X6(e,t,r=!1){D_(e,t),t=t.toString();let n=Wn.join(e,t+ym),s=await ob(e,t);if(global.lmdb_map!==void 0){let i=ab(e,t,r);if(global.lmdb_map[i]){let a=global.lmdb_map[i];await GU(a),delete global.lmdb_map[i]}}await Zs.remove(s),await Zs.remove(s===n?s+j6:Wn.join(Wn.dirname(s),z6))}o(X6,"deleteEnvironment");async function GU(e){P_.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(GU,"closeEnvironment");function ab(e,t,r=!1){let s=`${Wn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}o(ab,"getCachedEnvironmentName");function Z6(e){P_.validateEnv(e);let t=Object.create(null),r=Is(e,ei);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==ei)try{t[n]=Object.assign(new L_,s)}catch{FU.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}o(Z6,"listDBIDefinitions");function $U(e){P_.validateEnv(e);let t=[],r=Is(e,ei);for(let{key:n}of r.getRange({start:!1}))n!==ei&&t.push(n);return t}o($U,"listDBIs");function e8(e,t){let n=Is(e,ei).getEntry(t),s=new L_;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{FU.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}o(e8,"getDBIDefinition");function VU(e,t,r,n=!r){if(M_(e,t),t=t.toString(),t===ei)throw new Error(Cn.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return Is(e,t)}catch(s){if(s.message===Cn.DBI_DOES_NOT_EXIST){let i=new ib(r,n===!0),a=e.openDB(t,i),c=new L_(r===!0,n);return a[kU]=c,Is(e,ei).putSync(t,c),e.dbis[t]=a,a}throw s}}o(VU,"createDBI");function Is(e,t){if(M_(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==ei?r=e8(e,t):r=new L_,r===void 0)throw new Error(Cn.DBI_DOES_NOT_EXIST);let n;try{let s=new ib(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[kU]=r,e.dbis[t]=n,n}o(Is,"openDBI");function t8(e,t){M_(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(t8,"statDBI");async function r8(e,t){try{let r=Wn.join(e,t+ym);return(await Zs.stat(r)).size}catch{throw new Error(Cn.INVALID_ENVIRONMENT)}}o(r8,"environmentDataSize");function n8(e,t){if(M_(e,t),t=t.toString(),t===ei)throw new Error(Cn.CANNOT_DROP_INTERNAL_DBIS_NAME);Is(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],Is(e,ei).removeSync(t)}o(n8,"dropDBI");function s8(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)VU(e,i,i!==t,i===t),n=!0;else throw a}}n&&Y6()}o(s8,"initializeDBIs");KU.exports={openDBI:Is,openEnvironment:qU,createEnvironment:J6,listDBIs:$U,listDBIDefinitions:Z6,createDBI:VU,dropDBI:n8,statDBI:t8,deleteEnvironment:X6,initializeDBIs:s8,TransactionCursor:nb,environmentDataSize:r8,copyEnvironment:Q6,closeEnvironment:GU}});var zU=M((QNe,WU)=>{"use strict";var cb=_t(),i8=z(),YU=tn().LMDB_ERRORS_ENUM;WU.exports=o8;async function o8(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 cb.closeEnvironment(global.lmdb_map[a])}catch(c){if(c.message!==YU.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await cb.closeEnvironment(global.lmdb_map[n]),await cb.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==YU.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){i8.error(t)}}o(o8,"cleanLMDBMap")});var Ro=M((ZNe,a8)=>{a8.exports={hdb_user:{hash_attribute:"username",name:"hdb_user",schema:"system",residence:["*"],attributes:[{attribute:"username"},{attribute:"password"},{attribute:"role"},{attribute:"active"},{attribute:"hash"},{attribute:"refresh_token"},{attribute:"hash_function"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_role:{hash_attribute:"id",name:"hdb_role",schema:"system",attributes:[{attribute:"id"},{attribute:"role"},{attribute:"permission"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}],residence:["*"]},hdb_job:{hash_attribute:"id",name:"hdb_job",schema:"system",attributes:[{attribute:"id"},{attribute:"user"},{attribute:"type"},{attribute:"status"},{attribute:"start_datetime"},{attribute:"end_datetime"},{attribute:"message"},{attribute:"created_datetime"},{attribute:"request"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_license:{hash_attribute:"license_key",name:"hdb_license",schema:"system",attributes:[{attribute:"license_key"},{attribute:"company"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_info:{hash_attribute:"info_id",name:"hdb_info",schema:"system",attributes:[{attribute:"info_id"},{attribute:"data_version_num"},{attribute:"hdb_version_num"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_nodes:{hash_attribute:"name",name:"hdb_nodes",schema:"system",attributes:[{attribute:"name"},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"},{attribute:"revoked_certificates"},{attribute:"shard"}]},hdb_certificate:{hash_attribute:"name",name:"hdb_certificate",schema:"system",attributes:[{attribute:"name"},{attribute:"uses"},{attribute:"certificate"},{attribute:"is_authority"},{attribute:"private_key_name"},{attribute:"details"},{attribute:"is_self_signed"},{attribute:"__updatedtime__"}]},hdb_analytics_hostname:{hash_attribute:"id",name:"hdb_analytics_hostname",schema:"system",attributes:[{attribute:"id"},{attribute:"hostname"}]},hdb_analytics:{hash_attribute:"id",name:"hdb_analytics",schema:"system",attributes:[{attribute:"id"},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]},hdb_raw_analytics:{hash_attribute:"id",name:"hdb_raw_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{attribute:"time"},{attribute:"metrics"}]},hdb_temp:{hash_attribute:"id",name:"hdb_temp",schema:"system",attributes:[{attribute:"id"}]},hdb_durable_session:{hash_attribute:"id",name:"hdb_durable_session",schema:"system",attributes:[{attribute:"id"}]},hdb_session_will:{hash_attribute:"id",name:"hdb_session_will",schema:"system",attributes:[{attribute:"id"}]}}});var Ns=M((ewe,QU)=>{var c8=Ro(),{promisify:l8}=require("util"),{getDatabases:JU}=(Le(),v(ft));QU.exports={setSchemaDataToGlobal:jU,getTableSchema:u8,getSystemSchema:d8,setSchemaDataToGlobalAsync:l8(jU)};function jU(e){global.hdb_schema=JU(),e&&e()}o(jU,"setSchemaDataToGlobal");function u8(e,t,r){let n=JU()[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(u8,"getTableSchema");function d8(){return c8}o(d8,"getSystemSchema")});var ux=M((nwe,lx)=>{"use strict";var lb=require("recursive-iterator"),f8=require("alasql"),ub=require("clone"),XU=ie(),{handleHDBError:ZU,hdbErrors:m8}=Ee(),{HDB_ERROR_MSGS:ex,HTTP_STATUS_CODES:tx}=m8,{getDatabases:h8}=(Le(),v(ft)),p8=["DISTINCT_ARRAY"],rx=Symbol("validateTables"),db=Symbol("validateTable"),rwe=Symbol("getAllColumns"),nx=Symbol("validateAllColumns"),v_=Symbol("findColumn"),sx=Symbol("validateOrderBy"),Am=Symbol("validateSegment"),fb=Symbol("validateColumn"),ix=Symbol("setColumnsForTable"),ox=Symbol("checkColumnsForAsterisk"),ax=Symbol("validateGroupBy"),cx=Symbol("hasColumns"),mb=class{static{o(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[rx](),this[ox](),this[nx]()}[rx](){if(this[cx]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[db](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[db](t.table)})}}[cx](){let t=!1,r=new lb(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[db](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=h8();if(!r[t.databaseid])throw ZU(new Error,ex.SCHEMA_NOT_FOUND(t.databaseid),tx.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw ZU(new Error,ex.TABLE_NOT_FOUND(t.databaseid,t.tableid),tx.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=ub(s);i.table=ub(t),this.attributes.push(i)})}[v_](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)}[ox](){let t=new lb(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[ix](r.tableid)}[ix](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new f8.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[nx](){this[Am](this.statement.columns,!1),this[Am](this.statement.joins,!1),this[Am](this.statement.where,!1),this[ax](this.statement.group,!1),this[Am](this.statement.order,!0)}[Am](t,r){if(!t)return;let n=new lb(t),s=[];for(let{node:i,path:a}of n)!XU.isEmpty(i)&&!XU.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[sx](i):s.push(this[fb](i)));return s}[ax](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&p8.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=ub(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[v_](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[v_](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`}[sx](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[fb](t)}[fb](t){let r=this[v_](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]}};lx.exports=mb});var fx=M((iwe,dx)=>{"use strict";var hb=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")}};dx.exports=hb});var hx=M((awe,mx)=>{"use strict";var pb=class{static{o(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};mx.exports=pb});var Ex=M((lwe,px)=>{"use strict";var Eb=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}};px.exports=Eb});var gx=M((dwe,_x)=>{"use strict";var _b=class{static{o(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};_x.exports=_b});var Zc=M((Ewe,Rx)=>{"use strict";var E8=_t(),_8=hx(),g8=Ex(),S8=gx(),Pi=An(),bm=tn().LMDB_ERRORS_ENUM,T8=kt(),yo=(k(),v(K)),R8=ie(),y8=require("uuid"),mwe=require("lmdb"),{handleHDBError:A8,hdbErrors:b8}=Ee(),{OVERFLOW_MARKER:hwe,MAX_SEARCH_KEY_LENGTH:pwe}=T8,Sx=ce();Sx.initSync();var U_=Sx.get(yo.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),gb=yo.TIME_STAMP_NAMES_ENUM.CREATED_TIME,Xc=yo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function I8(e,t,r,n,s=Pi.getNextMonotonicTime()){yb(e,t,r,n),Sb(e,t,r);let i=new _8,a=[],c=[];for(let l=0;l<n.length;l++){let u=n[l];Tx(u,!0,s);let d=N8(e,t,r,u),f=u[t];a.push(d),c.push(f)}return Tb(a,c,n,i,s)}o(I8,"insertRecords");function N8(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){U_&&u.prefetch(l.map(d=>({key:d,value:s})),x_);for(let d=0,f=l.length;d<f;d++)u.put(l[d],s)}}U_&&e.dbis[t].prefetch([s],x_),e.dbis[t].put(s,n,n[Xc])})}o(N8,"insertRecord");function w8(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}o(w8,"removeSkippedRecords");function Tx(e,t,r){let n=r>0;(n||!Number.isInteger(e[Xc]))&&(e[Xc]=r||(r=Pi.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[gb]))&&(e[gb]=r||Pi.getNextMonotonicTime()):delete e[gb]}o(Tx,"setTimestamps");function Sb(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),E8.initializeDBIs(e,t,r)}o(Sb,"initializeTransaction");async function O8(e,t,r,n,s=Pi.getNextMonotonicTime()){yb(e,t,r,n),Sb(e,t,r);let i=new g8,a=[],c=[],l=[];for(let u=0;u<n.length;u++){let d=n[u],f=d[t],m;try{m=Rb(e,t,d,f,i,!0,s)}catch{i.skipped_hashes.push(f),a.push(u);continue}c.push(m),l.push(f)}return Tb(c,l,n,i,s,a)}o(O8,"updateRecords");async function C8(e,t,r,n,s=Pi.getNextMonotonicTime()){try{yb(e,t,r,n)}catch(l){throw A8(l,l.message,b8.HTTP_STATUS_CODES.BAD_REQUEST)}Sb(e,t,r);let i=new S8,a=[],c=[];for(let l=0;l<n.length;l++){let u=n[l],d;R8.isEmpty(u[t])?(d=y8.v4(),u[t]=d):d=u[t];let f=Rb(e,t,u,d,i,!1,s);a.push(f),c.push(d)}return Tb(a,c,n,i,s)}o(C8,"upsertRecords");async function Tb(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(),w8(r,i),n}o(Tb,"finalizeWrite");function Rb(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(Tx(r,!d,a),Number.isInteger(r[Xc])&&u[Xc]>r[Xc])return!1;d&&s.original_records.push(u);let f,m=o(()=>{for(let p in r){if(!r.hasOwnProperty(p)||p===t)continue;let _=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){U_&&g.prefetch(T.map(R=>({key:R,value:n})),x_);for(let R=0,I=T.length;R<I;R++)g.remove(T[R],n)}if(T=Pi.getIndexedValues(_),T){U_&&g.prefetch(T.map(R=>({key:R,value:n})),x_);for(let R=0,I=T.length;R<I;R++)g.put(T[R],n)}}let h={...u,...r};c.put(n,h,h[Xc])},"doPut");return l?f=c.ifVersion(n,l.version,m):f=c.ifNoExists(n,m),f.then(h=>h?!0:Rb(e,t,r,n,s,i,a))}o(Rb,"updateUpsertRecord");function P8(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(P8,"validateBasic");function yb(e,t,r,n){if(P8(e,t,r),!Array.isArray(n))throw n===void 0?new Error(bm.RECORDS_REQUIRED):new Error(bm.RECORDS_MUST_BE_ARRAY)}o(yb,"validateWrite");function x_(){}o(x_,"noop");Rx.exports={insertRecords:I8,updateRecords:O8,upsertRecords:C8}});var Ax=M((gwe,yx)=>{"use strict";var L8=require("uuid"),Ab=class{static{o(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||L8.v4(),this.schema_table=`${this.schema}.${this.table}`}};yx.exports=Ab});var B_=M((Twe,bx)=>{"use strict";var D8=Ax(),bb=class extends D8{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}};bx.exports=bb});var Nx=M((ywe,Ix)=>{"use strict";Ix.exports=v8;var M8="inserted";function v8(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===M8?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}o(v8,"returnObject")});var F_=M((Iwe,Ox)=>{"use strict";var U8=(k(),v(K)),Ib=_t(),x8=Zc(),{getSystemSchemaPath:B8,getSchemaPath:F8}=At(),bwe=Ro(),{validateBySchema:H8}=at(),Im=require("joi"),k8=B_(),q8=Nx(),{handleHDBError:G8,hdbErrors:$8,ClientError:V8}=Ee(),wx=ie(),{HTTP_STATUS_CODES:K8}=$8,Y8="inserted";Ox.exports=W8;async function W8(e){let t=H8(e,Im.object({database:Im.string(),schema:Im.string(),table:Im.string().required(),attribute:Im.string().required()}));if(t)throw new V8(t.message);let r=!e.skip_table_check&&wx.checkGlobalSchemaTable(e.schema,e.table);if(r)throw G8(new Error,r,K8.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=wx.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 k8(e.schema,e.table,e.attribute,e.id);try{let i=await Ib.openEnvironment(F8(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}`);Ib.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let a=await Ib.openEnvironment(B8(),U8.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await x8.insertRecords(a,HDB_TABLE_INFO.hash_attribute,hdbAttributeAttributes,[s]);return q8(Y8,c,{records:[s]},l)}catch(i){throw i}}o(W8,"lmdbCreateAttribute")});var Di=M((wwe,Px)=>{"use strict";var Cx=ie(),z8=(k(),v(K)),Du=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Li=require("joi"),Na={schema_format:{pattern:Du,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},j8=Li.alternatives(Li.string().min(1).max(Na.schema_length.maximum).pattern(Du).messages({"string.pattern.base":"{:#label} "+Na.schema_format.message}),Li.number(),Li.array()).required(),J8=Li.alternatives(Li.string().min(1).max(Na.schema_length.maximum).pattern(Du).messages({"string.pattern.base":"{:#label} "+Na.schema_format.message}),Li.number()),Q8=Li.alternatives(Li.string().min(1).max(Na.schema_length.maximum).pattern(Du).messages({"string.pattern.base":"{:#label} "+Na.schema_format.message}),Li.number()).required();function X8(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`:Du.test(t)?"":`'${property_name}' has illegal characters`:`'${property_name}' must be at least one character`:`'${property_name}' is required`}o(X8,"checkValidTable");function Z8(e,t){return Cx.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}o(Z8,"validateSchemaExists");function e5(e,t){let r=t.state.ancestors[0].schema;return Cx.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}o(e5,"validateTableExists");function t5(e,t){return e.toLowerCase()===z8.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${hdb_terms.SYSTEM_SCHEMA_NAME}' name is reserved`):e}o(t5,"validateSchemaName");Px.exports={commonValidators:Na,schemaRegex:Du,hdbSchemaTable:j8,validateSchemaExists:Z8,validateTableExists:e5,validateSchemaName:t5,checkValidTable:X8,hdbDatabase:J8,hdbTable:Q8}});var wb=M((Cwe,Dx)=>{var{hdbTable:r5,hdbDatabase:Lx}=Di(),n5=at(),Nb=require("joi"),s5={undefined:"undefined",null:"null"},i5=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||s5[a]!==void 0)&&(s===void 0?s=`Invalid attribute name: '${a}'`:s+=`. Invalid attribute name: '${a}'`)}return s?t.message(s):e},"customRecordsVal"),o5=Nb.object({database:Lx,schema:Lx,table:r5,records:Nb.array().items(Nb.object().custom(i5)).required()});Dx.exports=function(e){return n5.validateBySchema(e,o5)}});var Nm=M((Dwe,vx)=>{"use strict";var Ao=ie(),Mx=z(),Lwe=wb(),{getDatabases:a5}=(Le(),v(ft)),{ClientError:el}=Ee();vx.exports=c5;function c5(e){if(Ao.isEmpty(e))throw new el("invalid update parameters defined.");if(Ao.isEmptyOrZeroLength(e.schema))throw new el("invalid schema specified.");if(Ao.isEmptyOrZeroLength(e.table))throw new el("invalid table specified.");if(!Array.isArray(e.records))throw new el("records must be an array");let t=a5()[e.schema]?.[e.table];if(Ao.isEmpty(t))throw new el(`could not retrieve schema:${e.schema} and table ${e.table}`);let r=t.primaryKey,n=new Set,s={},i=!1;return e.operation==="update"&&(i=!0),e.records.forEach(a=>{if(i&&Ao.isEmptyOrZeroLength(a[r]))throw Mx.error("a valid hash attribute must be provided with update record:",a),new el("a valid hash attribute must be provided with update record, check log for more info");if(!Ao.isEmptyOrZeroLength(a[r])&&(a[r]==="null"||a[r]==="undefined"))throw Mx.error(`a valid hash value must be provided with ${e.operation} record:`,a),new el(`Invalid hash value: '${a[r]}' is not a valid hash attribute value, check log for more info`);!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(c5,"insertUpdateValidate")});var H_=M((vwe,xx)=>{"use strict";var Ux=ie(),l5=(k(),v(K)),u5=z(),d5=F_(),f5=B_(),m5=bo(),{SchemaEventMsg:h5}=ti(),p5="already exists in";xx.exports=E5;async function E5(e,t,r){if(Ux.isEmptyOrZeroLength(r))return r;let n=[];Ux.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 _5(e,t.schema,t.name,i)})),s}o(E5,"lmdbCheckForNewAttributes");async function _5(e,t,r,n){let s=new f5(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await g5(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(p5))u5.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}o(_5,"createNewAttribute");async function g5(e){let t;return t=await d5(e),m5.signalSchemaChange(new h5(process.pid,l5.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}o(g5,"createAttribute")});var Mu=M((xwe,Bx)=>{"use strict";var Ob=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}};Bx.exports=Ob});var Hx=M((Fwe,Fx)=>{"use strict";var S5=Mu(),T5=(k(),v(K)).OPERATIONS_ENUM,Cb=class extends S5{static{o(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(T5.INSERT,r,n,s,i),this.records=t}};Fx.exports=Cb});var qx=M((kwe,kx)=>{"use strict";var R5=Mu(),y5=(k(),v(K)).OPERATIONS_ENUM,Pb=class extends R5{static{o(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,a=void 0){super(y5.UPDATE,n,s,i,a),this.records=t,this.original_records=r}};kx.exports=Pb});var $x=M((Gwe,Gx)=>{"use strict";var A5=Mu(),b5=(k(),v(K)).OPERATIONS_ENUM,Lb=class extends A5{static{o(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,a=void 0){super(b5.UPSERT,n,s,i,a),this.records=t,this.original_records=r}};Gx.exports=Lb});var Kx=M((Vwe,Vx)=>{"use strict";var I5=Mu(),N5=(k(),v(K)).OPERATIONS_ENUM,Db=class extends I5{static{o(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(N5.DELETE,n,s,t,i),this.original_records=r}};Vx.exports=Db});var wm=M((Wwe,jx)=>{"use strict";var Ywe=require("path"),Yx=_t(),w5=Hx(),O5=qx(),C5=$x(),P5=Kx(),vu=kt(),Wx=ie(),{CONFIG_PARAMS:L5}=(k(),v(K)),zx=ce();zx.initSync();var k_=(k(),v(K)).OPERATIONS_ENUM,{getTransactionAuditStorePath:D5}=At();jx.exports=M5;async function M5(e,t){if(zx.get(L5.LOGGING_AUDITLOG)===!1)return;let r=D5(e.schema,e.table),n=await Yx.openEnvironment(r,e.table,!0),s=v5(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){Yx.initializeDBIs(n,vu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,vu.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[vu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[vu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),Wx.isEmpty(s.user_name)||n.dbis[vu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let a=0;a<s.hash_values.length;a++)n.dbis[vu.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[a],i)})}}o(M5,"writeTransaction");function v5(e,t){let r=Wx.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===k_.INSERT)return new w5(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===k_.UPDATE)return new O5(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===k_.UPSERT)return new C5(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===k_.DELETE)return new P5(t.deleted,t.original_records,r,t.txn_time,e.__origin)}o(v5,"createTransactionObject")});var Mb=M((Jwe,Jx)=>{"use strict";var U5=Nm(),jwe=Wf(),Om=(k(),v(K)),x5=zf(),B5=Zc().insertRecords,F5=_t(),H5=z(),k5=H_(),{getSchemaPath:q5}=At(),G5=wm();Jx.exports=$5;async function $5(e){try{let{schemaTable:t,attributes:r}=U5(e);x5(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 k5(e.hdb_auth_header,t,r),s=q5(e.schema,e.table),i=await F5.openEnvironment(s,e.table),a=await B5(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await G5(e,a)}catch(c){H5.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($5,"lmdbCreateRecords")});var Zx=M((Xwe,Xx)=>{"use strict";var Qx=(k(),v(K)),V5=Mb(),K5=Wf(),Y5=require("fs-extra"),{getSchemaPath:W5}=At();Xx.exports=z5;async function z5(e){let t=[{name:e.schema,createddate:Date.now()}],r=new K5(Qx.SYSTEM_SCHEMA_NAME,Qx.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await V5(r),await Y5.mkdirp(W5(e.schema))}o(z5,"lmdbCreateSchema")});var t0=M((eOe,e0)=>{"use strict";var vb=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}};e0.exports=vb});var i0=M((iOe,s0)=>{"use strict";var r0=_t(),Ub=An(),xb=tn().LMDB_ERRORS_ENUM,j5=kt(),n0=z(),rOe=ie(),J5=require("lmdb"),Q5=t0(),X5=(k(),v(K)),{OVERFLOW_MARKER:nOe,MAX_SEARCH_KEY_LENGTH:sOe}=j5,Z5=X5.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function e9(e,t,r,n){if(Ub.validateEnv(e),t===void 0)throw new Error(xb.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(xb.IDS_REQUIRED):new Error(xb.IDS_MUST_BE_ITERABLE);try{let s=r0.listDBIs(e);r0.initializeDBIs(e,t,s);let i=new Q5,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[Z5]>n){i.skipped.push(a);continue}let _=e.dbis[t].ifVersion(a,J5.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=Ub.getIndexedValues(R);if(I)for(let P=0,Y=I.length;P<Y;P++)T.remove(I[P],a)}catch{n0.warn(`cannot delete from attribute: ${y}, ${R}:${a}`)}}});c.push(_),l.push(a),i.original_records.push(p)}catch(p){n0.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=Ub.getNextMonotonicTime(),i}catch(s){throw s}}o(e9,"deleteRecords");s0.exports={deleteRecords:e9}});var Cm=M((aOe,a0)=>{"use strict";var Uu=ie(),t9=i0(),r9=_t(),{getSchemaPath:n9}=At(),s9=wm(),i9=z();a0.exports=o9;async function o9(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(Uu.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(Uu.isEmptyOrZeroLength(e.hash_values)&&!Uu.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];Uu.isEmpty(l)||e.hash_values.push(l)}}if(Uu.isEmptyOrZeroLength(e.hash_values))return o0([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(Uu.isEmptyOrZeroLength(e.records)){e.records=[];for(let c=0;c<e.hash_values.length;c++)e.records[c]={[n]:e.hash_values[c]}}let s=n9(e.schema,e.table),i=await r9.openEnvironment(s,e.table),a=await t9.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await s9(e,a)}catch(c){i9.error(`unable to write transaction due to ${c.message}`)}return o0(a.deleted,a.skipped,a.txn_time)}catch(s){throw s}}o(o9,"lmdbDeleteRecords");function o0(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(o0,"createDeleteResponse")});var Fb=M((uOe,c0)=>{"use strict";var a9=(k(),v(K)),lOe=An();function Bb(e,t){let r=Object.create(null);if(t.length===1&&a9.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(Bb,"parseRow");function c9(e,t,r,n){let s=Bb(r,e);n.push(s)}o(c9,"searchAll");function l9(e,t,r,n){let s=Bb(r,e);n[t]=s}o(l9,"searchAllToMap");function u9(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}o(u9,"iterateDBI");function tl(e,t,r,n,s){let i=Object.create(null);i[s]=e;let a;n===s?a=e:(a=t,n!==void 0&&(i[n]=a)),r[0].push(a),r[1].push(i)}o(tl,"pushResults");function d9(e,t,r,n,s,i){t.toString().endsWith(e)&&tl(t,r,n,s,i)}o(d9,"endsWith");function f9(e,t,r,n,s,i){t.toString().includes(e)&&tl(t,r,n,s,i)}o(f9,"contains");function m9(e,t,r,n,s,i){t>e&&tl(t,r,n,s,i)}o(m9,"greaterThanCompare");function h9(e,t,r,n,s,i){t>=e&&tl(t,r,n,s,i)}o(h9,"greaterThanEqualCompare");function p9(e,t,r,n,s,i){t<e&&tl(t,r,n,s,i)}o(p9,"lessThanCompare");function E9(e,t,r,n,s,i){t<=e&&tl(t,r,n,s,i)}o(E9,"lessThanEqualCompare");c0.exports={parseRow:Bb,searchAll:c9,searchAllToMap:l9,iterateDBI:u9,endsWith:d9,contains:f9,greaterThanCompare:m9,greaterThanEqualCompare:h9,lessThanCompare:p9,lessThanEqualCompare:E9,pushResults:tl}});var xu=M((pOe,p0)=>{"use strict";var wa=_t(),fOe=z(),zn=An(),q_=kt(),Qt=tn().LMDB_ERRORS_ENUM,mOe=ie(),_9=(k(),v(K)),G_=Fb(),{parseRow:g9}=G_,hOe=require("lmdb"),{OVERFLOW_MARKER:l0,MAX_SEARCH_KEY_LENGTH:S9}=q_;function u0(e,t,r,n=!1,s=void 0,i=void 0){return rl(e,t,r,(a,c)=>c.getRange({transaction:a,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}))}o(u0,"iterateFullIndex");function Pm(e,t,r,n,s,i=!1,a=void 0,c=void 0,l=!1,u=!1){return rl(e,t,r,(d,f,m,h)=>{let T={transaction:d,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:a,offset:c,inclusiveEnd:i===!0?!l:!u,exclusiveStart:i===!0?u:l};return h===r?(T.values=!1,f.getRange(T).map(R=>({value:R}))):f.getRange(T)})}o(Pm,"iterateRangeBetween");function rl(e,t,r,n){let s=e.database||e,i=wa.openDBI(s,r);i[q_.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(rl,"setupTransaction");function d0(e,t,r,n){let s;return function(i,a){if(typeof i=="string"&&i.endsWith(l0)){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[q_.DBI_DEFINITION_NAME].is_hash_attribute);u++);}i=s.get(a,{transaction:t,lazy:!0})[n]}return i}}o(d0,"getOverflowCheck");function T9(e,t,r,n=!1,s=void 0,i=void 0){if(zn.validateEnv(e),t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);return rl(e,t,t,(a,c,l)=>($_(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=>g9(u.value,r))))}o(T9,"searchAll");function R9(e,t,r,n=!1,s=void 0,i=void 0){if(zn.validateEnv(e),t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);$_(r),r=Lm(e.database||e,r);let a=new Map;for(let{key:c,value:l}of u0(e,t,t,n,s,i))a.set(c,G_.parseRow(l,r));return a}o(R9,"searchAllToMap");function y9(e,t,r=!1,n=void 0,s=void 0){if(zn.validateEnv(e),t===void 0)throw new Error(Qt.ATTRIBUTE_REQUIRED);let i=Object.create(null),a=u0(e,void 0,t,r,n,s),c=a.transaction,l=d0(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(y9,"iterateDBI");function A9(e,t){if(zn.validateEnv(e),t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);return wa.statDBI(e,t).entryCount}o(A9,"countAll");function b9(e,t,r,n,s=!1,i=void 0,a=void 0){return Oa(e,r,n),rl(e,t,r,(c,l,u,d)=>(n=zn.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(b9,"equals");function I9(e,t,r){return Oa(e,t,r),wa.openDBI(e,t).getValuesCount(r)}o(I9,"count");function N9(e,t,r,n,s=!1,i=void 0,a=void 0){return Oa(e,r,n),rl(e,null,r,(c,l)=>{n=zn.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(N9,"startsWith");function w9(e,t,r,n,s=!1,i=void 0,a=void 0){return f0(e,t,r,n,s,i,a,!0)}o(w9,"endsWith");function f0(e,t,r,n,s=!1,i=void 0,a=void 0,c=!1){return Oa(e,r,n),rl(e,null,r,(l,u,d,f)=>{let m=d0(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(l0)?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[q_.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(f0,"contains");function O9(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(O9,"greaterThan");function C9(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(C9,"greaterThanEqual");function P9(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(P9,"lessThan");function L9(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(L9,"lessThanEqual");function D9(e,t,r,n,s,i=!1,a=void 0,c=void 0){if(zn.validateEnv(e),r===void 0)throw new Error(Qt.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(Qt.START_VALUE_REQUIRED);if(s===void 0)throw new Error(Qt.END_VALUE_REQUIRED);if(n=zn.convertKeyValueToWrite(n),s=zn.convertKeyValueToWrite(s),n>s)throw new Error(Qt.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return Pm(e,t,r,n,s,i,a,c)}o(D9,"between");function M9(e,t,r,n){zn.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);if($_(r),r=Lm(s,r),n===void 0)throw new Error(Qt.ID_REQUIRED);let a=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(a=G_.parseRow(c,r)),a}o(M9,"searchByHash");function v9(e,t,r){zn.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Qt.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}o(v9,"checkHashExists");function U9(e,t,r,n,s=[]){return h0(e,t,r,n,s),m0(e,t,r,n,s).map(i=>i[1])}o(U9,"batchSearchByHash");function x9(e,t,r,n,s=[]){h0(e,t,r,n,s);let i=new Map;for(let[a,c]of m0(e,t,r,n,s))i.set(a,c);return i}o(x9,"batchSearchByHashToMap");function m0(e,t,r,n,s=[]){return rl(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,G_.parseRow(d,r)];s.push(u)}).filter(u=>u)})}o(m0,"batchHashSearch");function h0(e,t,r,n,s){if(zn.validateEnv(e),t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);if($_(r),n==null)throw new Error(Qt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(Qt.IDS_MUST_BE_ITERABLE)}o(h0,"initializeBatchSearchByHash");function $_(e){if(!Array.isArray(e))throw e===void 0?new Error(Qt.FETCH_ATTRIBUTES_REQUIRED):new Error(Qt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}o($_,"validateFetchAttributes");function Oa(e,t,r){if(zn.validateEnv(e),t===void 0)throw new Error(Qt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Qt.SEARCH_VALUE_REQUIRED);if(r?.length>S9)throw new Error(Qt.SEARCH_VALUE_TOO_LARGE)}o(Oa,"validateComparisonFunctions");function Lm(e,t){return t.length===1&&_9.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=wa.listDBIs(e)),t}o(Lm,"setGetWholeRowAttributes");p0.exports={searchAll:T9,searchAllToMap:R9,count:I9,countAll:A9,equals:b9,startsWith:N9,endsWith:w9,contains:f0,searchByHash:M9,setGetWholeRowAttributes:Lm,batchSearchByHash:U9,batchSearchByHashToMap:x9,checkHashExists:v9,iterateDBI:y9,greaterThan:O9,greaterThanEqual:C9,lessThan:P9,lessThanEqual:L9,between:D9}});var Bu=M((_Oe,T0)=>{var E0=require("lodash"),_0=at(),$e=require("joi"),B9=ie(),{hdbSchemaTable:Dm,checkValidTable:g0,hdbTable:S0,hdbDatabase:V_}=Di(),{handleHDBError:F9,hdbErrors:H9}=Ee(),{getDatabases:k9}=(Le(),v(ft)),{HTTP_STATUS_CODES:q9}=H9,G9=$e.object({database:V_,schema:V_,table:S0,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)}),$9=$e.object({database:V_,schema:V_,table:S0,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()});T0.exports=function(e,t){let r=null;switch(t){case"value":r=_0.validateBySchema(e,G9);break;case"hashes":let i=function(a){s?s+=". "+a:s=a};var n=i;o(i,"addError");let s;i(g0("database",e.schema)),i(g0("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=_0.validateBySchema(e,$9);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=B9.checkGlobalSchemaTable(e.schema,e.table);if(s)return F9(new Error,s,q9.NOT_FOUND);let a=k9()[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=E0.filter(c,d=>d!=="*"&&!d.startsWith?.("$")&&d.attribute!=="*"&&!Array.isArray(d)&&!d.name&&!E0.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 Hb=M((SOe,R0)=>{"use strict";var V9=_t(),K9=Bu(),{getSchemaPath:Y9}=At();R0.exports=W9;function W9(e){let t=K9(e,"hashes");if(t)throw t;let r=Y9(e.schema,e.table);return V9.openEnvironment(r,e.table)}o(W9,"initialize")});var kb=M((ROe,y0)=>{"use strict";var z9=xu(),j9=Hb();y0.exports=J9;async function J9(e){let t=await j9(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return z9.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}o(J9,"lmdbGetDataByHash")});var Fu=M((AOe,A0)=>{"use strict";var qb=class{static{o(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};A0.exports=qb});var I0=M((NOe,b0)=>{"use strict";var IOe=Fu(),Q9=xu(),X9=Hb();b0.exports=Z9;async function Z9(e){let t=await X9(e),r=global.hdb_schema[e.schema][e.table];return Q9.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}o(Z9,"lmdbSearchByHash")});var ri=M((OOe,N0)=>{"use strict";var Gb=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}};N0.exports=Gb});var K_=M((POe,D0)=>{"use strict";var sn=xu(),e7=_t(),t7=ie(),Ve=kt(),nl=(k(),v(K)),r7=Ro(),w0=tn().LMDB_ERRORS_ENUM,{getSchemaPath:n7}=At(),Io=nl.SEARCH_WILDCARDS;async function s7(e,t,r){let n;e.schema===nl.SYSTEM_SCHEMA_NAME?n=r7[e.table]:n=global.hdb_schema[e.schema][e.table];let s=L0(e,n.hash_attribute,r,t);return C0(e,s,n.hash_attribute,r)}o(s7,"prepSearch");async function C0(e,t,r,n){let s=n7(e.schema,e.table),i=await e7.openEnvironment(s,e.table),a=P0(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(i7(e,r)===!1){let d=e.search_attribute;if(d===r)return n?O0(a,()=>!0):a.map(m=>({[r]:m.key}));let f=o(m=>({[r]:m.value,[d]:m.key}),"toObject");return n?O0(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(C0,"executeSearch");function P0(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(P0,"searchByType");function O0(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}o(O0,"createMapFromIterable");function i7(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(i7,"checkToFetchMore");function L0(e,t,r,n){if(t7.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(w0.UNKNOWN_SEARCH_TYPE)}else switch(n){case nl.VALUE_SEARCH_COMPARATORS.BETWEEN:return Ve.SEARCH_TYPES.BETWEEN;case nl.VALUE_SEARCH_COMPARATORS.GREATER:return Ve.SEARCH_TYPES.GREATER_THAN;case nl.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return Ve.SEARCH_TYPES.GREATER_THAN_EQUAL;case nl.VALUE_SEARCH_COMPARATORS.LESS:return Ve.SEARCH_TYPES.LESS_THAN;case nl.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return Ve.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(w0.UNKNOWN_SEARCH_TYPE)}}o(L0,"createSearchTypeFromSearchObject");D0.exports={executeSearch:C0,createSearchTypeFromSearchObject:L0,prepSearch:s7,searchByType:P0}});var v0=M((MOe,M0)=>{"use strict";var DOe=ri(),o7=Bu(),a7=ie(),c7=(k(),v(K)),l7=K_();M0.exports=u7;function u7(e,t){if(!a7.isEmpty(t)&&c7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=o7(e,"value");if(n)throw n;return l7.prepSearch(e,t,!0)}o(u7,"lmdbGetDataByValue")});var Mm=M((xOe,U0)=>{"use strict";var UOe=ri(),d7=Bu(),f7=ie(),m7=(k(),v(K)),h7=K_();U0.exports=p7;async function p7(e,t){if(!f7.isEmpty(t)&&m7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=d7(e,"value");if(n)throw n;return h7.prepSearch(e,t,!1)}o(p7,"lmdbSearchByValue")});var B0=M((HOe,x0)=>{"use strict";var FOe=kt(),$b=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}},Vb=class{static{o(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},Kb=class{static{o(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};x0.exports={SearchByConditionsObject:$b,SearchCondition:Vb,SortAttribute:Kb}});var G0=M(($Oe,q0)=>{"use strict";var qOe=B0().SearchByConditionsObject,E7=ri(),_7=Bu(),Yb=xu(),Y_=kt(),{Resource:GOe}=(ba(),v(TU)),k0=K_(),g7=Fb(),S7=require("lodash"),{getSchemaPath:T7}=At(),F0=_t(),{handleHDBError:R7,hdbErrors:y7}=Ee(),{HTTP_STATUS_CODES:A7}=y7,b7=1e8;q0.exports=I7;async function I7(e){let t=_7(e,"conditions");if(t)throw R7(t,t.message,A7.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=T7(e.schema,e.table),n=await F0.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let u of e.conditions)F0.openDBI(n,u.search_attribute);let i=S7.sortBy(e.conditions,u=>{if(u.estimated_count===void 0){let d=u.search_type;d===Y_.SEARCH_TYPES.EQUALS?u.estimated_count=Yb.count(n,u.search_attribute,u.search_value):d===Y_.SEARCH_TYPES.CONTAINS||d===Y_.SEARCH_TYPES.ENDS_WITH?u.estimated_count=1/0:u.estimated_count=b7}return u.estimated_count}),a=n.useReadTransaction();a.database=n;let c=await H0(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(k0.filterByType),f=d.length,m=Yb.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=>g7.parseRow(h,m))}else{for(let f=1;f<i.length;f++){let m=i[f],h=await H0(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=Yb.batchSearchByHash(a,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{a.done()},l}o(I7,"lmdbSearchByConditions");async function H0(e,t,r,n){let s=new E7(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===Y_.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,k0.searchByType(e,s,i,n).map(a=>a.value)}o(H0,"executeConditionSearch")});var vm=M((KOe,$0)=>{"use strict";var N7=(k(),v(K)).OPERATIONS_ENUM,Wb=class{static{o(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=N7.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};$0.exports=Wb});var zb=M((WOe,Q0)=>{"use strict";var W0=ri(),z0=vm(),j0=Mm(),J0=Cm(),Pn=(k(),v(K)),V0=ie(),K0=_t(),{getTransactionAuditStorePath:w7,getSchemaPath:O7}=At(),Y0=z();Q0.exports=C7;async function C7(e){try{if(V0.isEmpty(global.hdb_schema[e.schema])||V0.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await P7(e),await L7(e);let t=O7(e.schema,e.table);try{await K0.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")Y0.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=w7(e.schema,e.table);await K0.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")Y0.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}o(C7,"lmdbDropTable");async function P7(e){let t=new W0(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 j0(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 z0(Pn.SYSTEM_SCHEMA_NAME,Pn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await J0(s)}o(P7,"deleteAttributesFromSystem");async function L7(e){let t=new W0(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 j0(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 z0(Pn.SYSTEM_SCHEMA_NAME,Pn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await J0(s)}catch(i){throw i}}o(L7,"dropTableFromSystem")});var Z0=M((jOe,X0)=>{"use strict";var D7=require("fs-extra"),M7=ri(),v7=Fu(),U7=vm(),x7=zb(),B7=Cm(),F7=kb(),H7=Mm(),No=(k(),v(K)),{getSchemaPath:k7}=At(),{handleHDBError:q7,hdbErrors:G7}=Ee(),{HDB_ERROR_MSGS:$7,HTTP_STATUS_CODES:V7}=G7;X0.exports=K7;async function K7(e){let t;try{t=await Y7(e.schema);let r=new M7(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 H7(r));for(let a=0;a<n.length;a++){let c={schema:t,table:n[a].name};try{await x7(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new U7(No.SYSTEM_SCHEMA_NAME,No.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await B7(s);let i=k7(t);await D7.remove(i)}catch(r){throw r}}o(K7,"lmdbDropSchema");async function Y7(e){let t=new v7(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 F7(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw q7(new Error,$7.SCHEMA_NOT_FOUND(e),V7.NOT_FOUND,void 0,void 0,!0);return n}o(Y7,"validateDropSchema")});var Um=M((QOe,eB)=>{"use strict";var jb=class{static{o(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};eB.exports=jb});var Qb=M((eCe,tB)=>{"use strict";var W7=require("fs-extra"),W_=_t(),{getTransactionAuditStorePath:z7}=At(),Jb=kt(),ZOe=Um();tB.exports=j7;async function j7(e){let t;try{let r=z7(e.schema,e.table);await W7.mkdirp(r),t=await W_.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{W_.createDBI(t,Jb.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),W_.createDBI(t,Jb.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),W_.createDBI(t,Jb.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(j7,"createTransactionsAuditEnvironment")});var sB=M((nCe,nB)=>{"use strict";var Xb=(k(),v(K)),rB=_t(),J7=Zc(),{getSystemSchemaPath:Q7,getSchemaPath:X7}=At(),rCe=Ro(),Z7=F_(),Zb=B_(),eee=z(),tee=Qb();nB.exports=ree;async function ree(e,t){let r=X7(t.schema,t.table),n=new Zb(t.schema,t.table,Xb.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new Zb(t.schema,t.table,Xb.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new Zb(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await rB.createEnvironment(r,t.table),e!==void 0){let a=await rB.openEnvironment(Q7(),Xb.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await J7.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 eI(n),await eI(s),await eI(i)}await tee(t)}catch(a){throw a}}o(ree,"lmdbCreateTable");async function eI(e){try{await Z7(e)}catch(t){eee.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}o(eI,"createAttribute")});var oB=M((iCe,iB)=>{"use strict";var nee=Nm(),see=zf(),iee=H_(),xm=(k(),v(K)),oee=Zc().updateRecords,aee=_t(),{getSchemaPath:cee}=At(),lee=wm(),uee=z();iB.exports=dee;async function dee(e){try{let{schemaTable:t,attributes:r}=nee(e);see(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 iee(e.hdb_auth_header,t,r),s=cee(e.schema,e.table),i=await aee.openEnvironment(s,e.table),a=await oee(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await lee(e,a)}catch(c){uee.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(dee,"lmdbUpdateRecords")});var cB=M((aCe,aB)=>{"use strict";var fee=(k(),v(K)).OPERATIONS_ENUM,tI=class{static{o(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=fee.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};aB.exports=tI});var uB=M((uCe,lB)=>{"use strict";var lCe=cB(),mee=Nm(),hee=zf(),pee=H_(),Bm=(k(),v(K)),Eee=Zc().upsertRecords,_ee=_t(),{getSchemaPath:gee}=At(),See=wm(),Tee=z(),{handleHDBError:Ree,hdbErrors:yee}=Ee();lB.exports=Aee;async function Aee(e){let t;try{t=mee(e)}catch(l){throw Ree(l,l.message,yee.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schemaTable:r,attributes:n}=t;hee(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 pee(e.hdb_auth_header,r,n),i=gee(e.schema,e.table),a=await _ee.openEnvironment(i,e.table),c=await Eee(a,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await See(e,c)}catch(l){Tee.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(Aee,"lmdbUpsertRecords")});var fB=M((fCe,dB)=>{"use strict";var rI=class{static{o(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};dB.exports=rI});var hB=M((hCe,mB)=>{"use strict";var nI=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}};mB.exports=nI});var _B=M((_Ce,EB)=>{"use strict";var sI=_t(),{getTransactionAuditStorePath:bee}=At(),ECe=fB(),Fm=kt(),Iee=ie(),pB=hB(),Nee=require("util").promisify,wee=Nee(setTimeout),Oee=1e4,Cee=100;EB.exports=Pee;async function Pee(e){let t=bee(e.schema,e.table),r=await sI.openEnvironment(t,e.table,!0),n=sI.listDBIs(r);sI.initializeDBIs(r,Fm.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new pB;do s=await Lee(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 wee(Cee);while(s.transactions_deleted>0);return i}o(Pee,"deleteAuditLogsBefore");async function Lee(e,t){let r=new pB;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];Iee.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>Oee)break}return await s,r}catch(n){throw n}}o(Lee,"deleteTransactions")});var SB=M((SCe,gB)=>{"use strict";var iI=class{static{o(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};gB.exports=iI});var RB=M((yCe,TB)=>{"use strict";var Dee=ri(),Mee=vm(),RCe=SB(),Mi=(k(),v(K)),vee=ie(),oI=_t(),Uee=Ro(),xee=Mm(),Bee=Cm(),{getSchemaPath:Fee}=At();TB.exports=Hee;async function Hee(e,t=!0){let r;e.schema===Mi.SYSTEM_SCHEMA_NAME?r=Uee[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await qee(e),s=Fee(e.schema,e.table),i=await oI.openEnvironment(s,e.table);return t===!0&&await kee(e,i,r.hash_attribute),oI.dropDBI(i,e.attribute),n}o(Hee,"lmdbDropAttribute");async function kee(e,t,r){let n=oI.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(kee,"removeAttributeFromAllObjects");async function qee(e){let t=new Dee(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 xee(t)).filter(a=>a[Mi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(vee.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 Mee(Mi.SYSTEM_SCHEMA_NAME,Mi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return Bee(i)}o(qee,"dropAttributeFromSystem")});var wB=M((ICe,NB)=>{"use strict";var aI=_t(),Hu=kt(),bCe=An(),cI=(k(),v(K)),yB=ie(),{getTransactionAuditStorePath:Gee}=At(),$ee=xu(),z_=Mu(),Vee=z();NB.exports=Kee;async function Kee(e){let t=Gee(e.schema,e.table),r=await aI.openEnvironment(t,e.table,!0),n=aI.listDBIs(r);aI.initializeDBIs(r,Hu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case cI.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return AB(r,e.search_values);case cI.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,Wee(r,e.search_values,s);case cI.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return Yee(r,e.search_values);default:return AB(r)}}o(Kee,"readAuditLog");function AB(e,t=[0,Date.now()]){yB.isEmpty(t[0])&&(t[0]=0),yB.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[Hu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],n;for(let s of r.getKeys({start:t[1]}))if(s!==t[1]){n=s;break}return r.getRange({start:t[0],end:n}).map(({value:s})=>Object.assign(new z_,s))}o(AB,"searchTransactionsByTimestamp");function Yee(e,t=[]){let r=new Map;for(let n=0;n<t.length;n++){let s=t[n],i=[];for(let a of e.dbis[Hu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(a);r.set(s,IB(e,i))}return Object.fromEntries(r)}o(Yee,"searchTransactionsByUsername");function Wee(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let u=t[c],d=$ee.equals(e,Hu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Hu.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,u);for(let{value:f}of d){let m=Number(f);n.has(m)?n.get(m).push(u.toString()):n.set(m,[u.toString()])}}let s=Array.from(n.keys()),i=IB(e,s),a=new Map;for(let c=0;c<i.length;c++){let l=i[c],u=l.timestamp,d=n.get(u);bB(l,"records",r,d,a),bB(l,"original_records",r,d,a)}return Object.fromEntries(a)}o(Wee,"searchTransactionsByHashValues");function bB(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 z_(e.operation,e.user_name,i,void 0);f[t]=[c],u.push(f)}}else{let u=new z_(e.operation,e.user_name,i,void 0);u[t]=[c],s.set(l,[u])}}}o(bB,"loopRecords");function IB(e,t){let r=[];try{let n=e.dbis[Hu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP];for(let s=0;s<t.length;s++)try{let i=n.get(t[s]);if(i){let a=Object.assign(new z_,i);r.push(a)}}catch(i){Vee.warn(i)}return r}catch(n){throw n}}o(IB,"batchSearchTransactions")});var CB=M((CCe,OB)=>{"use strict";var{getSchemaPath:wCe}=At(),OCe=_t(),{database:zee}=(Le(),v(ft));OB.exports={writeTransaction:jee};async function jee(e,t,r){return zee({database:e,table:t}).transaction(r)}o(jee,"writeTransaction")});var MB=M((LCe,DB)=>{"use strict";var{getSchemaPath:PB}=At(),LB=_t();DB.exports={flush:Jee,resetReadTxn:Qee};async function Jee(e,t){return(await LB.openEnvironment(PB(e,t),t.toString())).flushed}o(Jee,"flush");async function Qee(e,t){try{(await LB.openEnvironment(PB(e,t),t.toString())).resetReadTxn()}catch{}}o(Qee,"resetReadTxn")});var BB=M((MCe,xB)=>{"use strict";var{Readable:Xee}=require("stream"),{getDatabases:Zee}=(Le(),v(ft)),{readSync:ete,openSync:tte,createReadStream:vB}=require("fs"),{open:rte}=require("lmdb"),UB=Tm(),nte=Rm(),{AUDIT_STORE_OPTIONS:ste}=(uo(),v(iU)),{INTERNAL_DBIS_NAME:ite,AUDIT_STORE_NAME:ote}=kt();xB.exports=cte;var lI=32768,ate=100;async function cte(e){let t=e.database||e.schema||"data",r=Zee()[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=rte({noSync:!0,maxDbs:nte.MAX_DBS}),m,h=f.openDB(ite,new UB(!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),_++%ate===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 UB(!P,P);await g(T,Y)}e.include_audit&&await g(ote,{...ste}),await m;let y=vB(f.path);return y.headers=l(),y.on("close",()=>{p.done(),f.close()}),y}let a=r[Object.keys(r)[0]].primaryStore,c=tte(a.path);return a.transaction(()=>{let u=Buffer.alloc(lI);ete(c,u,0,lI),a.resetReadTxn();let d=a.useReadTransaction();d.renew();let f=vB(null,{fd:c,start:lI}),m=new Xee.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(cte,"getBackup")});var kB=M((UCe,HB)=>{"use strict";var lte=z(),{handleHDBError:ute}=Ee(),dte=fx(),fte=F_(),mte=Mb(),hte=Zx(),pte=Cm(),Ete=kb(),_te=I0(),gte=v0(),Ste=Mm(),Tte=G0(),Rte=Z0(),yte=sB(),Ate=oB(),bte=uB(),Ite=_B(),Nte=zb(),wte=RB(),Ote=wB(),Cte=CB(),FB=MB(),Pte=BB(),uI=class extends dte{static{o(this,"LMDBBridge")}async searchByConditions(t){return Tte(t)}async getDataByHash(t){return await Ete(t)}async searchByHash(t){return await _te(t)}async getDataByValue(t,r){return await gte(t,r)}async searchByValue(t){return await Ste(t)}async createSchema(t){return await hte(t)}async dropSchema(t){return await Rte(t)}async createTable(t,r){return await yte(t,r)}async dropTable(t){return await Nte(t)}async createAttribute(t){return await fte(t)}async createRecords(t){return await mte(t)}async updateRecords(t){return await Ate(t)}async upsertRecords(t){try{return await bte(t)}catch(r){throw ute(r,null,null,lte.ERR,r)}}async deleteRecords(t){return await pte(t)}async dropAttribute(t){return await wte(t)}async deleteAuditLogsBefore(t){return await Ite(t)}async readAuditLog(t){return await Ote(t)}writeTransaction(t,r,n){return Cte.writeTransaction(t,r,n)}flush(t,r){return FB.flush(t,r)}resetReadTxn(t,r){return FB.resetReadTxn(t,r)}getBackup(t){return Pte(t)}};HB.exports=uI});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 jn.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 jn.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 jn.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 jn.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 jn.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 jn.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 jn.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 jn.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 jn.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 jn.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 jn.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=dI(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 jn.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?$B:GB);break}c=l}while(c&&c!==GB&&c!==$B)}function VB(e,t,r){if(typeof t=="string"){if(t==="then"||t==="getRecord"||t==="getChanges")return;if(qB[t])return qB[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=dI(s);if(i)return n||(n=Object.create(null),r._setChanges(n)),n[t]=i,i}return s}}function Lte(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 dI(e,t){let r;switch(e.constructor){case Object:return t?(r=t.TrackedObject,r||(t.TrackedObject=r=class extends il{static{o(this,"TrackedObject")}},km(r,t)),new r(e)):new il(e);case Array:let n=new J_(e.length,e);for(let s=0,i=e.length;s<i;s++){let a=e[s];a&&typeof a=="object"&&(a=dI(a,t?.elements)),n[s]=a}return n;default:return e}}function Q_(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=Q_(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=lA[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)Dte.call(e,n)&&(r||(r={...e.getRecord()}),r[n]=e[n]);return r?Object.freeze(r):e.getRecord?e.getRecord():e}function j_(e){let t=e.getRecord?.();if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[sl]||e.length!==t.length)return!0;for(let r=0,n=e.length;r<n;r++){let s=t[r],i=e[r];if(s&&i?.getRecord?.()===s){if(j_(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(j_(s))return!0}else return!0}else return!0}}return!1}var jn,qB,GB,$B,il,Dte,sl,J_,Hm,fI=fe(()=>{jn=w(Ee());KE();Ts();o(Ln,"getChanges");o(km,"assignTrackedAccessors");qB=Object.prototype,GB=new Proxy({},{get:VB}),$B=new Proxy({},{get:VB,set:Lte});o(VB,"getProxiedProperty");o(Lte,"setProxiedProperty");o(dI,"trackObject");il=class{static{o(this,"GenericTrackedObject")}#e;#t;constructor(t){if(t?.getRecord)throw new Error("Can not track an already tracked object, check for circular references");this.#e=t}getRecord(){return this.#e}setRecord(t){this.#e=t}getChanges(){return this.#t}_setChanges(t){this.#t=t}};km(il,{},!0);o(Q_,"collapseData");Dte=Object.prototype.hasOwnProperty;o(Ca,"updateAndFreeze");o(j_,"hasChanges");sl=Symbol.for("has-array-changes"),J_=class extends Array{static{o(this,"TrackedArray")}#e;[sl];constructor(t,r){super(t),this.#e=r}getRecord(){return this.#e}splice(...t){return this[sl]=!0,super.splice(...t)}push(...t){return this[sl]=!0,super.push(...t)}pop(){return this[sl]=!0,super.pop()}unshift(...t){return this[sl]=!0,super.unshift(...t)}shift(){return this[sl]=!0,super.shift()}};J_.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 XB={};Ce(XB,{ResourceBridge:()=>pI});function EI({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 KB(e,t){let r=vi(e),n=EI(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&&Q_(d)}catch(f){d={message:(0,QB.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||vte,r=it()[t];if(!r)throw(0,ni.handleHDBError)(new Error,Mte.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function YB(e,t,r){let n=e.length+t.length,s=n===1?"record":"records";return{message:`${e.length} of ${n} ${s} successfully deleted`,deleted_hashes:e,skipped_hashes:t,txn_time:r}}async function*WB(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 zB,X_,ni,jB,mI,hI,JB,QB,Mte,vte,Ute,xte,pI,ZB=fe(()=>{zB=w(kB()),X_=w(Bu()),ni=w(Ee());Le();jB=w(Nm());k();mI=w(bo()),hI=w(ti()),JB=w(ie());xc();fI();QB=w(z()),{HDB_ERROR_MSGS:Mte}=ni.hdbErrors,vte="data",Ute=1e4,xte=10,pI=class extends zB.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,X_.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:EI(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 ku({database:t.schema,table:null}),mI.signalSchemaChange(new hI.SchemaEventMsg(process.pid,q.CREATE_SCHEMA,t.schema))}async dropSchema(t){await _I(t.schema),mI.signalSchemaChange(new hI.SchemaEventMsg(process.pid,q.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,jB.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=Q_(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 YB(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:NE.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,JB.asyncSetTimeout)(xte),l=[],s=!0},"chunkDelete");for await(let d of n)l.push(d[r.primaryKey]),c++,c%Ute===0&&await u();return l.length>0&&await u(),s?YB(i,a,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,X_.default)(t,"hashes");if(r)throw r;return KB(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of KB(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&Gy[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,X_.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===NE.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:EI(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 wE.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 wE.USERNAME:{let s=t.search_values;for await(let i of WB(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n}default:return WB(r,t.search_values?.[0],t.search_values?.[1],t.limit)}}};o(EI,"getSelect");o(KB,"getRecords");o(vi,"getTable");o(YB,"createDeleteResponse");o(WB,"groupRecordsInHistory")});var Jn=M((YCe,eF)=>{"use strict";var{ResourceBridge:Bte}=(ZB(),v(XB)),Fte=ce();Fte.initSync();var Z_;function Hte(){return Z_||(Z_=new Bte,Z_)}o(Hte,"getBridge");eF.exports=Hte()});var sF=M((zCe,nF)=>{"use strict";var tF=require("lodash"),qm=require("mathjs"),kte=require("jsonata"),rF=ie();nF.exports={distinct_array:o(e=>Array.isArray(e)&&e.length>1?tF.uniqWith(e,tF.isEqual):e,"distinct_array"),searchJSON:qte,mad:Gm.bind(null,qm.mad),mean:Gm.bind(null,qm.mean),mode:Gm.bind(null,qm.mode),prod:Gm.bind(null,qm.prod),median:Gm.bind(null,qm.median)};function Gm(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(Gm,"aggregateFunction");function qte(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(rF.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),rF.isEmpty(this.__ala__.res[r])){let n=kte(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}o(qte,"searchJSON")});var oF=M((JCe,iF)=>{"use strict";var cr=require("moment"),gI="YYYY-MM-DDTHH:mm:ss.SSSZZ";cr.suppressDeprecationWarnings=!0;iF.exports={current_date:o(()=>cr().utc().format("YYYY-MM-DD"),"current_date"),current_time:o(()=>cr().utc().format("HH:mm:ss.SSS"),"current_time"),extract:o((e,t)=>{switch(t.toLowerCase()){case"year":return cr(e).utc().format("YYYY");case"month":return cr(e).utc().format("MM");case"day":return cr(e).utc().format("DD");case"hour":return cr(e).utc().format("HH");case"minute":return cr(e).utc().format("mm");case"second":return cr(e).utc().format("ss");case"millisecond":return cr(e).utc().format("SSS");default:break}},"extract"),date:o(e=>cr(e).utc().format(gI),"date"),date_format:o((e,t)=>cr(e).utc().format(t),"date_format"),date_add:o((e,t,r)=>cr(e).utc().add(t,r).valueOf(),"date_add"),date_sub:o((e,t,r)=>cr(e).utc().subtract(t,r).valueOf(),"date_sub"),date_diff:o((e,t,r)=>{let n=cr(e).utc(),s=cr(t).utc();return r?n.diff(s,r,!0):n.diff(s)},"date_diff"),now:o(()=>cr().utc().valueOf(),"now"),get_server_time:o(()=>cr().format(gI),"get_server_time"),offset_utc:o((e,t)=>cr(e).utc().utcOffset(t).format(gI),"offset_utc")}});var uF=M((XCe,lF)=>{"use strict";var Gte=require("@turf/area"),$te=require("@turf/length"),Vte=require("@turf/circle"),Kte=require("@turf/difference"),Yte=require("@turf/distance"),Wte=require("@turf/boolean-contains"),zte=require("@turf/boolean-equal"),jte=require("@turf/boolean-disjoint"),Jte=require("@turf/helpers"),aF=(k(),v(K)),Ye=ie(),wo=z();lF.exports={geoArea:Qte,geoLength:Xte,geoCircle:Zte,geoDifference:ere,geoDistance:cF,geoNear:tre,geoContains:rre,geoEqual:nre,geoCrosses:sre,geoConvert:ire};function Qte(e){if(Ye.isEmpty(e))return NaN;typeof e=="string"&&(e=Ye.autoCastJSON(e));try{return Gte.default(e)}catch(t){return wo.trace(t,e),NaN}}o(Qte,"geoArea");function Xte(e,t){if(Ye.isEmpty(e))return NaN;typeof e=="string"&&(e=Ye.autoCastJSON(e));try{return $te.default(e,{units:t||"kilometers"})}catch(r){return wo.trace(r,e),NaN}}o(Xte,"geoLength");function Zte(e,t,r){if(Ye.isEmpty(e))return NaN;if(Ye.isEmpty(t))return NaN;typeof e=="string"&&(e=Ye.autoCastJSON(e));try{return Vte.default(e,t,{units:r||"kilometers"})}catch(n){return wo.trace(n,e,t),NaN}}o(Zte,"geoCircle");function ere(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 Kte(e,t)}catch(r){return wo.trace(r,e,t),NaN}}o(ere,"geoDifference");function cF(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 Yte.default(e,t,{units:r||"kilometers"})}catch(n){return wo.trace(n,e,t),NaN}}o(cF,"geoDistance");function tre(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 cF(e,t,n)<=r}catch(s){return wo.trace(s,e,t),!1}}o(tre,"geoNear");function rre(e,t){if(Ye.isEmpty(e)||Ye.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Ye.autoCastJSON(e)),typeof t=="string"&&(t=Ye.autoCastJSON(t));try{return Wte.default(e,t)}catch(r){return wo.trace(r,e,t),!1}}o(rre,"geoContains");function nre(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 zte.default(e,t)}catch(r){return wo.trace(r,e,t),!1}}o(nre,"geoEqual");function sre(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!jte.default(e,t)}catch(r){return wo.trace(r,e,t),!1}}o(sre,"geoCrosses");function ire(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(aF.GEO_CONVERSION_ENUM[t]))throw new Error(`geoType of ${t} is invalid please use one of the following types: ${Object.keys(aF.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Ye.autoCastJSON(e)),Jte[t](e,r)}o(ire,"geoConvert")});var eg=M((ePe,dF)=>{var ol=sF(),Qn=oF(),Ui=uF();dF.exports=e=>{e.aggr.mad=e.aggr.MAD=ol.mad,e.aggr.mean=e.aggr.MEAN=ol.mean,e.aggr.mode=e.aggr.MODE=ol.mode,e.aggr.prod=e.aggr.PROD=ol.prod,e.aggr.median=e.aggr.MEDIAN=ol.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=ol.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=ol.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=Qn.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Qn.current_time,e.fn.extract=e.fn.EXTRACT=Qn.extract,e.fn.date=e.fn.DATE=Qn.date,e.fn.date_format=e.fn.DATE_FORMAT=Qn.date_format,e.fn.date_add=e.fn.DATE_ADD=Qn.date_add,e.fn.date_sub=e.fn.DATE_SUB=Qn.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Qn.date_diff,e.fn.now=e.fn.NOW=Qn.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Qn.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Qn.get_server_time,e.fn.getdate=e.fn.GETDATE=Qn.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Qn.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=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 pF=M((tPe,hF)=>{"use strict";var $m=require("lodash"),Dn=require("alasql");Dn.options.cache=!1;var ore=eg(),fF=require("clone"),tg=require("recursive-iterator"),ke=z(),tt=ie(),qu=Jn(),are=(k(),v(K)),{hdbErrors:cre}=Ee(),{getDatabases:mF}=(Le(),v(ft)),lre="IS NULL",si="There was a problem performing this search. Please check the logs and try again.";ore(Dn);var SI=class{static{o(this,"SQLSearch")}constructor(t,r){if(tt.isEmpty(t))throw ke.error("AST statement for SQL select process cannot be empty"),"statement cannot be null";this.statement=t,this.columns={},this.all_table_attributes=r,this.fetch_attributes=[],this.exact_search_values={},this.comparator_search_values={},this.tables=[],this.data={},this.has_aggregator=!1,this.has_ordinal=!1,this.has_outer_join=!1,this._getColumns(),this._getTables(),this._conditionsToFetchAttributeValues(),this._setAliasesForColumns(),tt.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!tt.isEmptyOrZeroLength(n))return ke.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw ke.error("Error thrown from checkEmptySQL in SQLSearch class method search."),ke.error(n),new Error(si)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw ke.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),ke.error(n),new Error(si)}if(Object.keys(this.data).length===0)return ke.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw ke.error("Error thrown from processJoins in SQLSearch class method search."),ke.error(n),new Error(si)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw ke.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),ke.error(n),new Error(si)}try{return t=await this._finalSQL(),t}catch(n){throw ke.error("Error thrown from finalSQL in SQLSearch class method search."),ke.error(n),new Error(si)}}_getColumns(){let t=new tg(this.statement);for(let{node:r,path:n}of t)r&&r.columnid&&(this.columns[n[0]]||(this.columns[n[0]]=[]),this.columns[n[0]].push(fF(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=mF()[r.databaseid][r.tableid].primaryKey,this.data[n].__mergedData={},this.data[n].__mergedAttributes=[],this.data[n].__mergedAttrMap={}})}_conditionsToFetchAttributeValues(){if(tt.isEmpty(this.statement.where)){ke.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new tg(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!tt.isEmpty(r)&&r.right)if(tt.isNotEmptyAndHasValue(r.right.value)){let n=tt.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new Dn.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=tt.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new Dn.yy.LogicValue({value:i}):n instanceof Dn.yy.StringValue&&tt.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new Dn.yy.NumValue({value:i}))});if(t){ke.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new tg(this.statement.where))if(r&&r.left&&r.right&&(r.left.columnid||r.right.value)&&r.op){let n=new Set,s=r.left.columnid?r.left:r.right,i=this._findColumn(s);if(!i)continue;let a=[i.table.databaseid,i.table.tableid,i.attribute].join("/");if(!tt.isEmpty(are.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(fF(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(lre)>-1&&this.tables.forEach(s=>{let i={columnid:mF()[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 qu.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 qu.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 qu.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 qu.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 tg(this.columns);for(let{node:i}of s)if(i&&i.columnid){let a=this._findColumn(i);if(a){let c=a.table.as?a.table.as:a.table.tableid;(!t[c]||t[c].indexOf(a.attribute)<0)&&n.push(a)}}n=$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 qu.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(cre.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 qu.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)}};hF.exports=SI});var on=M((nPe,EF)=>{"use strict";var ure=ux();EF.exports={searchByConditions:fre,searchByHash:mre,searchByValue:hre,search:pre};var TI=Jn(),{transformReq:RI}=ie(),dre=pF();async function fre(e){return RI(e),TI.searchByConditions(e)}o(fre,"searchByConditions");async function mre(e){RI(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of TI.searchByHash(e))r&&t.push(r);return t}o(mre,"searchByHash");async function hre(e){RI(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of TI.searchByValue(e))t.push(r);return t}o(hre,"searchByValue");function pre(e,t){try{let r=new ure(e);r.validate(),new dre(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}o(pre,"search")});var xi=M((iPe,TF)=>{"use strict";var Vm=require("crypto"),Ere=ce(),{CONFIG_PARAMS:_re}=(k(),v(K)),gF="aes-256-cbc",gre=32,Sre=16,yI=64,SF=32,Tre=yI+SF,_F=new Map;TF.exports={encrypt:Rre,decrypt:yre,createNatsTableStreamName:Are};function Rre(e){let t=Vm.randomBytes(gre),r=Vm.randomBytes(Sre),n=Vm.createCipheriv(gF,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(Rre,"encrypt");function yre(e){let t=e.substr(0,yI),r=e.substr(yI,SF),n=e.substr(Tre,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),a=Vm.createDecipheriv(gF,Buffer.from(t,"hex"),s),c=a.update(i);return c=Buffer.concat([c,a.final()]),c.toString()}o(yre,"decrypt");function Are(e,t){let r=Ere.get(_re.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=_F.get(r);return n||(n=Vm.createHash("md5").update(r).digest("hex"),_F.set(r,n)),n}o(Are,"createNatsTableStreamName")});var Pa=M((cPe,bF)=>{"use strict";var aPe=on(),Km=z(),{validateBySchema:RF}=at(),al=require("joi"),bre=xi(),rg=ie(),{handleHDBError:ng,hdbErrors:Ire,ClientError:yF}=Ee(),{HDB_ERROR_MSGS:sg,HTTP_STATUS_CODES:AI}=Ire,AF=ce();AF.initSync();var{getDatabases:bI}=(Le(),v(ft)),Nre=require("fs-extra"),wre=(k(),v(K));bF.exports={describeAll:Ore,describeTable:ig,describeSchema:Cre};async function Ore(e={}){try{let t=rg.isEmptyOrZeroLength(e),r=!!e.bypass_auth,n,s;!t&&!r&&(n=e.hdb_user?.role?.permission,s=n?.super_user||n?.cluster_user);let i=bI(),a={},c={},l=[],u=e?.exact_count;for(let f in i){a[f]=!0,!t&&!s&&!r&&(c[f]=e.hdb_user?.role?.permission[f]?.describe);let m=i[f];for(let h in m)try{let p;if(t||s||r)p=await ig({schema:f,table:h,exactCount:u});else if(n&&n[f].describe&&n[f].tables[h].describe){let _=n[f].tables[h].attribute_permissions;p=await ig({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),ng(new Error,sg.DESCRIBE_ALL_ERR)}}o(Ore,"describeAll");async function ig(e,t){rg.transformReq(e);let{schema:r,table:n}=e;r=r?.toString(),n=n?.toString();let s=t;e.hdb_user&&!e.hdb_user?.role?.permission?.super_user&&(s=e.hdb_user?.role?.permission[r]?.tables[n]?.attribute_permissions);let i=RF(e,al.object({database:al.string(),table:al.string().required(),exact_count:al.boolean().strict()}));if(i)throw new yF(i.message);let c=bI()[r];if(!c)throw ng(new Error,sg.SCHEMA_NOT_FOUND(e.schema),AI.NOT_FOUND);let l=c[n];if(!l)throw ng(new Error,sg.TABLE_NOT_FOUND(e.schema,e.table),AI.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 Nre.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")),AF.get(wre.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(m.clustering_stream_name=bre.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(ig,"descTable");async function Cre(e){rg.transformReq(e);let t=RF(e,al.object({database:al.string(),exact_count:al.boolean().strict()}));if(t)throw new yF(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=bI()[n];if(!i)throw ng(new Error,sg.SCHEMA_NOT_FOUND(e.schema),AI.NOT_FOUND);let a={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),rg.isEmpty(l)||l.describe){let u=await ig({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);u&&(a[u.name]=u)}}return a}o(Cre,"describeSchema")});var Mn=M((uPe,OF)=>{"use strict";var ag=wb(),$r=ie(),Pre=require("util"),cg=Jn(),Lre=Ns(),IF=z(),{handleHDBError:cl,hdbErrors:Dre}=Ee(),{HTTP_STATUS_CODES:ll}=Dre,Mre=Pre.promisify(Lre.getTableSchema),vre="updated",NF="inserted",wF="upserted";OF.exports={insert:xre,update:Bre,upsert:Fre,validation:Ure,flush:Hre};async function Ure(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 Mre(e.schema,e.table),r=ag(e);if(r)throw r;if(!Array.isArray(e.records))throw new Error("records must be an array");let n=t.hash_attribute,s=new Set,i={},a=!1;return e.operation==="update"&&(a=!0),e.records.forEach(c=>{if(a&&$r.isEmptyOrZeroLength(c[n]))throw IF.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 IF.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(Ure,"validation");async function xre(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=ag(e);if(t)throw cl(new Error,t.message,ll.BAD_REQUEST);$r.transformReq(e);let r=$r.checkSchemaTableExist(e.schema,e.table);if(r)throw cl(new Error,r,ll.BAD_REQUEST);let n=await cg.createRecords(e);return og(NF,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}o(xre,"insertData");async function Bre(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=ag(e);if(t)throw cl(new Error,t.message,ll.BAD_REQUEST);$r.transformReq(e);let r=$r.checkSchemaTableExist(e.schema,e.table);if(r)throw cl(new Error,r,ll.BAD_REQUEST);let n=await cg.updateRecords(e);return $r.isEmpty(n.existing_rows)?og(vre,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):og(n.update_action,[],e,n.hashes,void 0,n.txn_time)}o(Bre,"updateData");async function Fre(e){if(e.operation!=="upsert")throw cl(new Error,"invalid operation, must be upsert",ll.INTERNAL_SERVER_ERROR);let t=ag(e);if(t)throw cl(new Error,t.message,ll.BAD_REQUEST);$r.transformReq(e);let r=$r.checkSchemaTableExist(e.schema,e.table);if(r)throw cl(new Error,r,ll.BAD_REQUEST);let n=await cg.upsertRecords(e);return og(wF,n.written_hashes,e,[],n.new_attributes,n.txn_time)}o(Fre,"upsertData");function og(e,t,r,n,s,i){let a={message:`${e} ${t.length} of ${t.length+n.length} records`,new_attributes:s,txn_time:i};return e===NF?(a.inserted_hashes=t,a.skipped_hashes=n,a):e===wF?(a.upserted_hashes=t,a):(a.update_hashes=t,a.skipped_hashes=n,a)}o(og,"returnObject");function Hre(e){return $r.transformReq(e),cg.flush(e.schema,e.table)}o(Hre,"flush")});var NI=M((fPe,LF)=>{var kre=at(),II=require("joi"),{hdbTable:qre,hdbDatabase:CF}=Di(),PF={schema:CF,database:CF,table:qre},Gre={date:II.date().iso().required()},$re={timestamp:II.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};LF.exports=function(e,t){let r=t==="timestamp"?{...PF,...$re}:{...PF,...Gre},n=II.object(r);return kre.validateBySchema(e,n)}});var vF=M((mPe,MF)=>{var Vre=at(),wI=require("joi"),{hdbTable:Kre,hdbDatabase:DF}=Di(),Yre=wI.object({schema:DF,database:DF,table:Kre,hash_values:wI.array().required(),ids:wI.array()});MF.exports=function(e){return Vre.validateBySchema(e,Yre)}});var LI=M((hPe,UF)=>{"use strict";var OI=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}},CI=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}},PI=class{static{o(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};UF.exports={InsertObject:OI,NoSQLSeachObject:CI,DeleteResponseObject:PI}});var fl=M((EPe,kF)=>{"use strict";var BF=NI(),Wre=vF(),ul=ie(),xF=require("moment"),FF=z(),{promisify:zre,callbackify:jre}=require("util"),dl=(k(),v(K)),Jre=Ns(),DI=zre(Jre.getTableSchema),MI=Jn(),{DeleteResponseObject:Qre}=LI(),{handleHDBError:La,hdbErrors:Xre}=Ee(),{HDB_ERROR_MSGS:lg,HTTP_STATUS_CODES:Da}=Xre,Zre="records successfully deleted",ene=jre(HF);kF.exports={delete:ene,deleteRecord:HF,deleteFilesBefore:tne,deleteAuditLogsBefore:rne};async function tne(e){let t=BF(e,"date");if(t)throw La(t,t.message,Da.BAD_REQUEST,void 0,void 0,!0);if(ul.transformReq(e),!xF(e.date,xF.ISO_8601).isValid())throw La(new Error,lg.INVALID_DATE,Da.BAD_REQUEST,dl.LOG_LEVELS.ERROR,lg.INVALID_DATE,!0);let n=ul.checkSchemaTableExist(e.schema,e.table);if(n)throw La(new Error,n,Da.NOT_FOUND,dl.LOG_LEVELS.ERROR,n,!0);let s=await MI.deleteRecordsBefore(e);if(await DI(e.schema,e.table),FF.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}o(tne,"deleteFilesBefore");async function rne(e){let t=BF(e,"timestamp");if(t)throw La(t,t.message,Da.BAD_REQUEST,void 0,void 0,!0);if(ul.transformReq(e),isNaN(e.timestamp))throw La(new Error,lg.INVALID_VALUE("Timestamp"),Da.BAD_REQUEST,dl.LOG_LEVELS.ERROR,lg.INVALID_VALUE("Timestamp"),!0);let r=ul.checkSchemaTableExist(e.schema,e.table);if(r)throw La(new Error,r,Da.NOT_FOUND,dl.LOG_LEVELS.ERROR,r,!0);let n=await MI.deleteAuditLogsBefore(e);return await DI(e.schema,e.table),FF.info(`Finished deleting audit logs before ${e.timestamp}`),n}o(rne,"deleteAuditLogsBefore");async function HF(e){e.ids&&(e.hash_values=e.ids);let t=Wre(e);if(t)throw La(t,t.message,Da.BAD_REQUEST,void 0,void 0,!0);ul.transformReq(e);let r=ul.checkSchemaTableExist(e.schema,e.table);if(r)throw La(new Error,r,Da.NOT_FOUND,dl.LOG_LEVELS.ERROR,r,!0);try{await DI(e.schema,e.table);let n=await MI.deleteRecords(e);return ul.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${Zre}`),n}catch(n){if(n.message===dl.SEARCH_NOT_FOUND_MESSAGE){let s=new Qre;return s.message=dl.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}o(HF,"deleteRecord")});var ug={};Ce(ug,{HASH_FUNCTION:()=>Mr,hash:()=>xI,validate:()=>BI});function vI(e=Wm){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ";return Array.from(Ym.randomBytes(e)).map(r=>t[r%t.length]).join("")}function xI(e,t=Mr[GF?.toUpperCase()]??Mr.SHA256){return UI[t](e)}function BI(e,t,r=Mr[GF?.toUpperCase()]??Mr.SHA256){return e?nne[r](e,t):!1}var Ym,Gu,qF,GF,Wm,$F,Mr,UI,nne,dg=fe(()=>{Ym=w(require("node:crypto")),Gu=w(require("argon2")),qF=w(ce());k();GF=(0,qF.get)(U.AUTHENTICATION_HASHFUNCTION)?.toLowerCase(),Wm=16,$F=9,Mr={MD5:"md5",SHA256:"sha256",ARGON2ID:"argon2id"};o(vI,"generateSalt");UI={[Mr.MD5]:(e,t=void 0)=>{t=t??vI($F);let r=Ym.createHash(Mr.MD5).update(e+t).digest("hex");return t+r},[Mr.SHA256]:(e,t=void 0)=>{t=t??vI(Wm);let r=Ym.createHash(Mr.SHA256).update(e+t).digest("hex");return t+r},[Mr.ARGON2ID]:async e=>{let t=vI(Wm),r=await Gu.hash(e,{type:Gu.argon2id,salt:Buffer.from(t)});return t+r}},nne={[Mr.MD5]:(e,t)=>{let r=e.slice(0,$F);return e===UI[Mr.MD5](t,r)},[Mr.SHA256]:(e,t)=>{let r=e.slice(0,Wm);return e===UI[Mr.SHA256](t,r)},[Mr.ARGON2ID]:async(e,t)=>await Gu.verify(e.slice(Wm),t)};o(xI,"hash");o(BI,"validate")});var KF=M((TPe,VF)=>{var FI=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 sne(e){return an.password.presence=!0,an.username.presence=!0,an.role.presence=!0,an.active.presence=!0,FI.validateObject(e,an)}o(sne,"addUserValidation");function ine(e){return an.password.presence=!1,an.username.presence=!0,an.role.presence=!1,an.active.presence=!1,FI.validateObject(e,an)}o(ine,"alterUserValidation");function one(e){return an.password.presence=!1,an.username.presence=!0,an.role.presence=!1,an.active.presence=!1,FI.validateObject(e,an)}o(one,"dropUserValidation");VF.exports={addUserValidation:sne,alterUserValidation:ine,dropUserValidation:one}});var It=M((APe,WF)=>{"use strict";var{platform:yPe}=require("os"),ane="nats-server.zip",HI="nats-server",cne=process.platform==="win32"?`${HI}.exe`:HI,lne=/^[^\s.,*>]+$/,YF="__request__",une=o(e=>`${e}.${YF}`,"REQUEST_SUBJECT"),dne={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},fne={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},mne={HUB:"hub.pid",LEAF:"leaf.pid"},hne={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},pne={SUCCESS:"success",ERROR:"error"},Ene={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},_ne={TXN:"txn",MSGID:"msgid"},$u={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},gne={[$u.ERR]:1,[$u.WRN]:2,[$u.INF]:3,[$u.DBG]:4,[$u.TRC]:5},Sne={debug:"-D",trace:"-DVV"};WF.exports={NATS_SERVER_ZIP:ane,NATS_SERVER_NAME:HI,NATS_BINARY_NAME:cne,PID_FILES:mne,NATS_CONFIG_FILES:fne,SERVER_SUFFIX:hne,NATS_TERM_CONSTRAINTS_RX:lne,REQUEST_SUFFIX:YF,UPDATE_REMOTE_RESPONSE_STATUSES:pne,CLUSTER_STATUS_STATUSES:Ene,REQUEST_SUBJECT:une,SUBJECT_PREFIXES:_ne,MSG_HEADERS:dne,LOG_LEVELS:$u,LOG_LEVEL_FLAGS:Sne,LOG_LEVEL_HIERARCHY:gne}});var vn=M((IPe,vr)=>{"use strict";var JF="username is required",QF="nothing to update, must supply active, role or password to update",XF="password cannot be an empty string",ZF="If role is specified, it cannot be empty.",eH="active must be true or false";vr.exports.addUser=One;vr.exports.alterUser=Cne;vr.exports.dropUser=Lne;vr.exports.getSuperUser=xne;vr.exports.userInfo=Dne;vr.exports.listUsers=mg;vr.exports.listUsersExternal=Mne;vr.exports.setUsersWithRolesCache=ml;vr.exports.findAndValidateUser=zI;vr.exports.getClusterUser=Bne;vr.exports.getUsersWithRolesCache=Une;vr.exports.USERNAME_REQUIRED=JF;vr.exports.ALTERUSER_NOTHING_TO_UPDATE=QF;vr.exports.EMPTY_PASSWORD=XF;vr.exports.EMPTY_ROLE=ZF;vr.exports.ACTIVE_BOOLEAN=eH;var tH=Mn(),Tne=fl(),zm=(dg(),v(ug)),rH=KF(),jm=on(),VI=bo(),Bi=ie(),nH=require("validate.js"),KI=z(),{promisify:Rne}=require("util"),YI=xi(),qI=(k(),v(K)),zF=It(),yne=yt(),Ane=ce(),bne=Ro(),{hdbErrors:Ine,ClientError:ii}=Ee(),{HTTP_STATUS_CODES:Oo,AUTHENTICATION_ERROR_MSGS:kI,HDB_ERROR_MSGS:Vu}=Ine,{UserEventMsg:WI}=ti(),GI=require("lodash"),{server:fg}=(Pr(),v(Bf)),Nne=z();fg.getUser=(e,t)=>zI(e,t,t!=null);fg.authenticateUser=(e,t)=>zI(e,t);var sH={username:!0,active:!0,role:!0,password:!0},jF=new Map,wne=Rne(Tne.delete),$I=Ane.get(qI.CONFIG_PARAMS.AUTHENTICATION_HASHFUNCTION)??zm.HASH_FUNCTION.SHA256,Fi;async function One(e){let t=nH.cleanAttributes(e,sH),r=rH.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(Vu.ROLE_NAME_NOT_FOUND(t.role),Oo.NOT_FOUND);if(n.length>1)throw new ii(Vu.DUP_ROLES_FOUND(t.role),Oo.CONFLICT);n[0].permission.cluster_user===!0&&(t.hash=YI.encrypt(t.password)),t.password=await zm.hash(t.password,$I),t.hash_function=$I,t.role=n[0].id;let s=await tH.insert({operation:"insert",schema:"system",table:"hdb_user",records:[t]});if(KI.debug(s),await ml(),s.skipped_hashes.length===1)throw new ii(Vu.USER_ALREADY_EXISTS(t.username),Oo.CONFLICT);return VI.signalUserChange(new WI(process.pid)),`${t.username} successfully added`}o(One,"addUser");async function Cne(e){let t=nH.cleanAttributes(e,sH);if(Bi.isEmptyOrZeroLength(t.username))throw new Error(JF);if(Bi.isEmptyOrZeroLength(t.password)&&Bi.isEmptyOrZeroLength(t.role)&&Bi.isEmptyOrZeroLength(t.active))throw new Error(QF);if(!Bi.isEmpty(t.password)&&Bi.isEmptyOrZeroLength(t.password.trim()))throw new Error(XF);if(!Bi.isEmpty(t.active)&&!Bi.isBoolean(t.active))throw new Error(eH);if(!Bi.isEmpty(t.password)&&!Bi.isEmptyOrZeroLength(t.password.trim())&&(Pne(t.username)&&(t.hash=YI.encrypt(t.password)),t.password=await zm.hash(t.password,$I)),t.role==="")throw new Error(ZF);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(Vu.ALTER_USER_ROLE_NOT_FOUND(t.role),Oo.NOT_FOUND);if(n.length>1)throw new ii(Vu.DUP_ROLES_FOUND(t.role),Oo.CONFLICT);t.role=n[0].id}let r=await tH.update({operation:"update",schema:"system",table:"hdb_user",records:[t]});return await ml(),VI.signalUserChange(new WI(process.pid)),r}o(Cne,"alterUser");function Pne(e){let t=!1,r=Fi.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}o(Pne,"isClusterUser");async function Lne(e){let t=rH.dropUserValidation(e);if(t)throw new ii(t.message);if(Fi.get(e.username)===void 0)throw new ii(Vu.USER_NOT_EXIST(e.username),Oo.NOT_FOUND);let r=await wne({table:"hdb_user",schema:"system",hash_values:[e.username]});return KI.debug(r),await ml(),VI.signalUserChange(new WI(process.pid)),`${e.username} successfully deleted`}o(Lne,"dropUser");async function Dne(e){let t={};if(!e||!e.hdb_user)return"There was no user info in the body";t=GI.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(Dne,"userInfo");async function Mne(){let e=await mg();return e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token,delete t.hash_function}),[...e.values()]}o(Mne,"listUsersExternal");async function mg(){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]=GI.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=GI.cloneDeep(s),s.role=t[s.role],vne(s.role),n.set(s.username,s);return n}o(mg,"listUsers");function vne(e){if(!e){KI.error("invalid user role found.");return}e.permission.system||(e.permission.system={}),e.permission.system.tables||(e.permission.system.tables={});for(let t of Object.keys(bne)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}o(vne,"appendSystemTablesToRole");async function ml(e=void 0){e?Fi=e:Fi=await mg()}o(ml,"setUsersWithRolesCache");async function Une(){return Fi||await ml(),Fi}o(Une,"getUsersWithRolesCache");async function zI(e,t,r=!0){Fi||await ml();let n=Fi.get(e);if(!n){if(!r)return{username:e};throw new ii(kI.GENERIC_AUTH_FAIL,Oo.UNAUTHORIZED)}if(n&&!n.active)throw new ii(kI.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(jF.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)jF.set(t,n.password);else throw new ii(kI.GENERIC_AUTH_FAIL,Oo.UNAUTHORIZED)}}return s}o(zI,"findAndValidateUser");async function xne(){Fi||await ml();for(let[,e]of Fi)if(e.role.role==="super_user")return e}o(xne,"getSuperUser");async function Bne(){let e=await mg(),t=yne.getConfigFromFile(qI.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!(r==null||r?.role?.role!==qI.ROLE_TYPES_ENUM.CLUSTER_USER))return r.decrypt_hash=YI.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+zF.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+zF.SERVER_SUFFIX.ADMIN,r}o(Bne,"getClusterUser");var iH=[];fg.invalidateUser=function(e){for(let t of iH)try{t(e)}catch(r){Nne.error("Error invalidating user",r)}};fg.onInvalidatedUser=function(e){iH.push(e)}});var Qm=M((CPe,lH)=>{"use strict";var hl=z(),Xn=(k(),v(K)),Fne=zU(),wPe=Ns(),OPe=Pa(),Hne=vn(),{validateEvent:oH}=ti(),Jm=Jn(),kne=require("process"),{resetDatabases:qne}=(Le(),v(ft)),Gne={[Xn.ITC_EVENT_TYPES.SCHEMA]:$ne,[Xn.ITC_EVENT_TYPES.USER]:cH};async function $ne(e){let t=oH(e);if(t){hl.error(t);return}hl.trace("ITC schemaHandler received schema event:",e),await Fne(e.message),await Vne(e.message)}o($ne,"schemaHandler");async function Vne(e){try{Jm.resetReadTxn(Xn.SYSTEM_SCHEMA_NAME,Xn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),Jm.resetReadTxn(Xn.SYSTEM_SCHEMA_NAME,Xn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),Jm.resetReadTxn(Xn.SYSTEM_SCHEMA_NAME,Xn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=qne();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){hl.error(t)}}o(Vne,"syncSchemaMetadata");var aH=[];async function cH(e){try{try{Jm.resetReadTxn(Xn.SYSTEM_SCHEMA_NAME,Xn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),Jm.resetReadTxn(Xn.SYSTEM_SCHEMA_NAME,Xn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){hl.warn(r)}let t=oH(e);if(t){hl.error(t);return}hl.trace(`ITC userHandler ${Xn.HDB_ITC_CLIENT_PREFIX}${kne.pid} received user event:`,e),await Hne.setUsersWithRolesCache();for(let r of aH)r()}catch(t){hl.error(t)}}o(cH,"userHandler");cH.addListener=function(e){aH.push(e)};lH.exports=Gne});var ti=M((UPe,dH)=>{"use strict";var LPe=z(),jI=ie(),Kne=(k(),v(K)),{ITC_ERRORS:Xm}=tn(),{parentPort:DPe,threadId:Yne,isMainThread:Wne,workerData:MPe}=require("worker_threads"),{onMessageFromWorkers:zne,broadcast:vPe,broadcastWithAcknowledgement:jne}=st();dH.exports={sendItcEvent:Jne,validateEvent:uH,SchemaEventMsg:Qne,UserEventMsg:Xne};var hg;zne(async(e,t)=>{hg=hg||Qm(),uH(e),hg[e.type]&&await hg[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function Jne(e){return!Wne&&e.message&&(e.message.originator=Yne),jne(e)}o(Jne,"sendItcEvent");function uH(e){if(typeof e!="object")return Xm.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||jI.isEmpty(e.type))return Xm.MISSING_TYPE;if(!e.hasOwnProperty("message")||jI.isEmpty(e.message))return Xm.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||jI.isEmpty(e.message.originator))return Xm.MISSING_ORIGIN;if(Kne.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return Xm.INVALID_EVENT(e.type)}o(uH,"validateEvent");function Qne(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(Qne,"SchemaEventMsg");function Xne(e){this.originator=e}o(Xne,"UserEventMsg")});var bo=M((FPe,pH)=>{"use strict";var fH=(k(),v(K)),BPe=ie(),pg=z(),mH=PU(),Ku,{sendItcEvent:hH}=ti();function Zne(e){try{pg.info("signalSchemaChange called with message:",e),Ku=Ku||Qm();let t=new mH(fH.ITC_EVENT_TYPES.SCHEMA,e);return Ku.schema(t),hH(t)}catch(t){pg.error(t)}}o(Zne,"signalSchemaChange");function ese(e){try{pg.trace("signalUserChange called with message:",e),Ku=Ku||Qm();let t=new mH(fH.ITC_EVENT_TYPES.USER,e);return Ku.user(t),hH(t)}catch(t){pg.error(t)}}o(ese,"signalUserChange");pH.exports={signalSchemaChange:Zne,signalUserChange:ese}});function Eg(){return JI||(JI=et({table:"hdb_analytics_hostname",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"hostname"}]})),JI}function rse(e){return e=e.replace(tse,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 nse(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 XI(e){let t=EH.default.createHash("shake128",{outputLength:4}),r;return(0,_H.isIPv6)(e)?r=rse(e):r=e.toLowerCase(),nse(Uint8Array.from(t.update(r).digest()))}var EH,_H,QI,JI,tse,ZI=fe(()=>{Le();EH=w(require("crypto")),_H=require("node:net"),QI=new Map;o(Eg,"getAnalyticsHostnameTable");tse=/(\d{1,3}\.){3}\d{1,3}$/;o(rse,"normalizeIPv6");o(nse,"nodeHashToNumber");o(XI,"stableNodeId")});var Co,eN=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 Rg={};Ce(Rg,{addAnalyticsListener:()=>th,calculateCPUUtilization:()=>vH,diffResourceUsage:()=>UH,recordAction:()=>gt,recordActionBinary:()=>Kr,recordHostname:()=>nN,setAnalyticsEnabled:()=>sse});function sse(e){CH=e}function ise(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 ose(e,t,r,n,s,i){let a={};if(typeof t=="number")a.total=t,a.values=new Float32Array(4),a.values.index=1,a.values[0]=t,a.total=t;else if(typeof t=="boolean")a.total=t?1:0,a.count=1;else if(typeof t=="function")a.count=1,a.callback=t;else throw new TypeError("Invalid metric value type "+typeof t);a.description={metric:r,path:n,method:s,type:i},Sg.set(e,a)}function gt(e,t,r,n,s){if(!CH)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let a=Sg.get(i);a?ise(e,a):ose(i,e,t,r,n,s),gg||ase()}function Kr(e,t,r,n,s){gt(!!e,t,r,n,s)}function th(e){DH.push(e)}function ase(){gg=performance.now(),setTimeout(async()=>{let e=performance.now()-gg;gg=0;let t=[],r={time:Date.now(),period:e,threadId:pl.threadId,metrics:t};for(let[s,i]of Sg){if(i.values){let a=i.values.subarray(0,i.values.index);a.sort();let c=a.length,l=0,u=[],d;for(let f of MH){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 xH()}let n=process.memoryUsage();t.push({metric:"memory",threadId:pl.threadId,byThread:!0,...n});for(let s of DH)s(t);Sg=new Map,pl.parentPort?pl.parentPort.postMessage({type:LH,report:r}):HH({report:r})},PH).unref()}async function nN(){let e=ve.hostname;Vr.trace?.("recordHostname server.hostname:",e);let t=XI(e);Vr.trace?.("recordHostname nodeId:",t);let r=Eg();if(!await r.get(t)){let s={id:t,hostname:e};Vr.trace?.(`recordHostname storing hostname: ${JSON.stringify(s)}`),r.put(s.id,s)}}function Yu(e,t){let r=ve.hostname,n=QI.get(r);n?Vr.trace?.("storeMetric cached nodeId:",n):(n=XI(r),Vr.trace?.("storeMetric new nodeId:",n),QI.set(r,n));let s={id:[(0,rN.getNextMonotonicTime)(),n],...t};Vr.trace?.(`storing metric ${JSON.stringify(s)}`),e.put(s.id,s)}function vH(e,t){let r=e.userCPUTime+e.systemCPUTime;return Vr.trace?.(`calculateCPUUtilization cpuTime: ${r} period: ${t}`),Math.round(r/t*100)/100}function UH(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 cse(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)}`),Yu(e,l),n+=c}return n}function gH(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s?.getAuditSize();if(!i)return;let a=OH.statSync(s.primaryStore.env.path).size,c=cse(e,r,n),l=a-c,u={metric:Co.DATABASE_SIZE,database:r,size:a,used:c,free:l,audit:i};Yu(e,u),Vr.trace?.(`database ${r} size metric: ${JSON.stringify(u)}`)}catch(s){Vr.warn?.("Error getting DB size metrics",s)}}function SH(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};Yu(e,a),Vr.trace?.(`db ${r} storage volume metrics: ${JSON.stringify(a)}`)}catch(s){Vr.warn?.("Error getting DB volume metrics",s)}}async function lse(e,t=6e4){let r=sN(),n=BH(),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 xH()}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 MH){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,Yu(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-TH,active:p-RH,taskQueueLatency:await s,time:m,...process.memoryUsage()};Yu(n,R)}TH=h,RH=p;let _=process.resourceUsage();_.time=m,_.userCPUTime=_.userCPUTime/1e3,_.systemCPUTime=_.systemCPUTime/1e3,Vr.trace?.(`process.resourceUsage: ${JSON.stringify(_)}`);let g=UH(_g,_);Vr.trace?.(`diffed resourceUsage: ${JSON.stringify(g)}`),g.time=m,g.period=_g.time?m-_g.time:t,g.cpuUtilization=vH(g,g.period);let y={metric:Co.RESOURCE_USAGE,...g};Yu(n,y),_g=_;let T=it();gH(n,T),gH(n,{system:T.system}),SH(n,T),SH(n,{system:T.system})}async function yH(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function sN(){return AH||(AH=et({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function BH(){return bH||(bH=et({table:"hdb_analytics",database:"system",audit:!0,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function fse(){FH=!0;let e=(0,eh.get)(U.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await lse(PH,e),await yH(sN(),use),await yH(BH(),dse)},Math.min(e/2,2147483647)).unref()}function HH(e,t){let r=e.report;r.threadId=t?.threadId||pl.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(IH+=n.mean*n.count);r.totalBytesProcessed=IH,t&&(r.metrics.push({metric:Co.UTILIZATION,...t.performance.eventLoopUtilization(NH.get(t))}),NH.set(t,t.performance.eventLoopUtilization())),r.id=(0,rN.getNextMonotonicTime)(),sN().primaryStore.put(r.id,r),FH||fse(),mse&&(kH=pse(r))}async function pse(e){if(await kH,!Ma){let r=(0,Zm.dirname)((0,Tg.getLogFilePath)());try{Ma=await(0,tN.open)((0,Zm.join)(r,"analytics.log"),"r+")}catch{Ma=await(0,tN.open)((0,Zm.join)(r,"analytics.log"),"w+")}}let t=(await Ma.stat()).size;if(t>hse){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()}});Cv={type:"application/json",serializeStream:Xf,serialize:Zf,deserialize:XZ,q:.5};nn.set("*/*",Cv);nn.set("",Cv);o(XZ,"tryJSONParse");o(tm,"registerContentHandlers");ZZ=(0,wv.default)(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:a,type:c}=jE(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(jE,"findBestSerializer");yv=hA.default.get(U.HTTP_COMPRESSIONTHRESHOLD);o(rm,"serialize");o(ga,"serializeMessage");o(gA,"asyncSerialization");o(SA,"hasAsyncSerialization");o(e6,"streamToBuffer");t6=["ascii","utf8","utf-8","utf16le","utf-16le","ucs2","ucs-2","base64","base64url","latin1","binary","hex"];o(r6,"isBufferEncoding");o(n6,"parseContentType");o(ho,"getDeserializer");o(s6,"deserializerUnknownType");o(i6,"transformIterable");o(zE,"toCsvStream")});var bA={};Ce(bA,{Blob:()=>Ss,blobsWereEncoded:()=>qc,databasePaths:()=>RA,decodeBlobsWithWrites:()=>s_,decodeFromDatabase:()=>Gc,decodeWithBlobCallback:()=>i_,deleteBlob:()=>t_,deleteBlobsInObject:()=>Sa,deleteRootBlobPathsForDB:()=>AA,encodeBlobsAsBuffers:()=>p6,encodeBlobsWithFilePath:()=>n_,findBlobsInObject:()=>gu,getFileId:()=>r_,getFilePathForBlob:()=>kv,getRootBlobPathsForDB:()=>om,setDeletionDelay:()=>l6});function Bv(){}function t_(e){let t=kv(e);t&&setTimeout(()=>{(0,Ze.unlink)(t,r=>{r&&Eo.default.debug?.("Error trying to remove blob file",r)})},Fv)}function l6(e){Fv=e}function Hv(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 d6(t),t.source?TA(e,t.source,t):t.contentBuffer?u6(e,t):TA(e,sm.Readable.from(e.stream()),t),t}function TA(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(a6),h=(0,ZE.createDeflate)(),t.pipe(h).pipe(f)):(m||f.write(o6),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?yA:xv)<<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 r_(e){return bn.get(e)?.fileId}function kv(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=RA.get(e);if(!t){if(!e.databaseName)return Eo.default.warn?.("No database name specified, can not determine blob storage path"),[];let r=(0,e_.get)(U.STORAGE_BLOBPATHS);r?t=r.map(n=>(0,go.join)(n,e.databaseName)):t=[(0,go.join)((0,e_.getHdbBasePath)(),"blobs",e.databaseName)],RA.set(e,t)}return t}async function AA(e){let t=om(e);t&&await Promise.all(t.map(r=>qv(r)))}async function qv(e){if((0,Ze.existsSync)(e)){for(let t of await(0,Js.readdir)(e,{withFileTypes:!0}))if(t.isDirectory())await qv((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 u6(e,t){let r=t.contentBuffer,n=r.length;if(!(n<Uv))return e.size=n,TA(e,sm.Readable.from([r]),t)}function d6(e){let t=om(e.store),r=f6(),n=t?.length>1?m6(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,vv.ensureDirSync)(a),e.filePath=i}function f6(){let e=Mv.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)),Mv.set(In,e)}return Number(Atomics.add(e,0,1n))}function m6(e,t){let r=Date.now();if(!e.frequencyTable){e.lastUpdated=0;let s=new Array(XE);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,h6(e)),e.frequencyTable[t%XE]}async function h6(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(XE),n=t.map(s=>1/s);for(let s=0;s<XE;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 n_(e,t,r){_u=t,In=r,qc=!1;try{return e()}finally{_u=void 0,In=void 0}}function p6(e){qr=[];let t;try{t=e()}catch(n){throw qr=void 0,n}let r=qr.length<2?qr[0]:Promise.all(qr);return qr=void 0,r?r.then(()=>e()):t}function s_(e,t){try{qr=[],kc=t,e()}catch(n){throw kc=void 0,qr=void 0,n}kc=void 0;let r=qr.length<2?qr[0]:Promise.all(qr);return qr=void 0,r}function i_(e,t,r){In=r;try{return kc=t,e()}finally{kc=void 0}}function Gc(e,t){return In=t,e()}function Sa(e){gu(e,t=>{t_(t)})}function gu(e,t){if(e instanceof Ss)t(e);else if(Array.isArray(e))for(let r of e)typeof r=="object"&&r&&gu(r,t);else if(e&&typeof e=="object"&&!e[Symbol.iterator])for(let r in e){let n=e[r];typeof n=="object"&&n&&gu(e[r],t)}}function E6(){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,ZE,sm,vv,e_,go,Eo,Uv,Rr,xv,yA,Lv,o6,a6,Dv,bn,kc,Ss,_u,qr,In,qc,nm,JE,c6,QE,Fv,RA,Mv,XE,Ts=fe(()=>{_o=require("msgpackr"),Js=require("node:fs/promises"),Ze=require("node:fs"),ZE=require("node:zlib"),sm=require("node:stream"),vv=require("fs-extra"),e_=w(ce());k();go=require("path"),Eo=w(Ni());po();Uv=8192,Rr=8,xv=0,yA=1,Lv=255,o6=new Uint8Array([0,xv,255,255,255,255,255,255]),a6=new Uint8Array([0,yA,255,255,255,255,255,255]),Dv=0xffffffffffff,bn=new WeakMap,Ss=global.Blob||E6(),qc=!1,nm=new Uint8Array(8),JE=new DataView(nm.buffer),c6=6e4;o(Bv,"InstanceOfBlobWithNoConstructor");Bv.prototype=Ss.prototype;QE=class e extends Bv{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):(SA()&&gA(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=JE.getBigUint64(0);if(Number(f>>48n)===Lv)throw new Error("Error in blob: "+buffer.subarray(Rr));if(u=Number(f&0xffffffffffffn),u<n&&(u=n),u<Dv&&(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]===yA?new Promise((f,m)=>{(0,ZE.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=JE.getBigUint64(0);if(Number(j>>48n)===Lv)return P(new Error("Error in blob: "+$.subarray(Rr)));if(g=Number(j&0xffffffffffffn),g<Dv&&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(JE.getBigUint64(0)&0xffffffffffffn),g>l){p()?u?d=setTimeout(()=>{P(new Error("File read timed out"))},c6).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 Hv(this).saving??Promise.resolve()}},Fv=500;o(t_,"deleteBlob");o(l6,"setDeletionDelay");global.createBlob=function(e,t){let r=new QE(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(Hv,"saveBlob");o(TA,"writeBlobWithStream");o(r_,"getFileId");o(kv,"getFilePathForBlob");RA=new Map;o(om,"getRootBlobPathsForDB");o(AA,"deleteRootBlobPathsForDB");o(qv,"rimrafSteadily");o(im,"getFilePath");o(u6,"writeBlobWithBuffer");o(d6,"generateFilePath");Mv=new Map;o(f6,"getNextFileId");XE=128;o(m6,"getNextStorageIndex");o(h6,"createFrequencyTableForStoragePaths");o(n_,"encodeBlobsWithFilePath");o(p6,"encodeBlobsAsBuffers");o(s_,"decodeBlobsWithWrites");o(i_,"decodeWithBlobCallback");o(Gc,"decodeFromDatabase");o(Sa,"deleteBlobsInObject");o(gu,"findBlobsInObject");(0,_o.addExtension)({Class:Ss,type:11,unpack:o(function(e){let t=(0,_o.unpack)(e),r=new QE;if(Object.assign(r,t[0]),typeof t[1]!="object"){if(bn.set(r,{storageIndex:t[1],fileId:t[2],store:In}),kc)return kc(r)??r;if(!In)throw new Error("No store specified, cannot load blob from storage")}else bn.set(r,{storageIndex:0,fileId:null,storageBuffer:e,contentBuffer:t[1]}),r.size=t[1]?.length;return r},"unpack"),pack:o(function(e){let t=bn.get(e);if(_u!==void 0&&(qc=!0,t?.recordId!==void 0&&t.recordId!==_u))throw new Error("Cannot use the same blob in two different records");let r={...e};if(e.type&&(r.type=e.type),e.size!==void 0&&(r.size=e.size),t){if(t.storageBuffer)return t.storageBuffer;if(t.contentBuffer?.length<Uv)return r.size=t.contentBuffer.length,(0,_o.pack)([r,t.contentBuffer])}if(_u!==void 0){if(t=Hv(e),!t.fileId)throw new Error("Unable to save blob without file id");return t.recordId=_u,(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(JE.getBigUint64(0)&0xffffffffffffn)===n.length-Rr))return Buffer.concat([(0,_o.pack)([r]),n]);if(qr)qr.push(e.bytes());else throw new Error("Incomplete blob");return Buffer.alloc(0)}catch(n){if(n.code==="ENOENT"&&qr)return qr.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(E6,"polyfillBlob")});var Yv={};Ce(Yv,{onStorageReclamation:()=>am,runReclamationHandlers:()=>OA,setAvailableSpaceRatioGetter:()=>g6});function am(e,t,r){(r||(0,a_.getWorkerIndex)()===(0,a_.getWorkerCount)()-1)&&(o_.has(e)||o_.set(e,[]),o_.get(e).push({priority:0,handler:t}),wA||(wA=setTimeout(OA,$v).unref()))}async function OA(){for(let[e,t]of o_)try{let r=await Kv(e),n=_6/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&&(NA.default.info?.(`Running storage reclamation handler for ${e} with priority ${n}`),await c)}}}catch(r){NA.default.error?.("Error running storage reclamation handlers",r)}wA=setTimeout(OA,$v).unref()}function g6(e){Kv=e??Vv}var IA,a_,NA,c_,Gv,o_,_6,$v,wA,Vv,Kv,l_=fe(()=>{IA=require("node:fs/promises"),a_=w(st()),NA=w(Ni());k();c_=w(ce()),Gv=w(ie());c_.default.initSync();o_=new Map,_6=c_.default.get(U.STORAGE_RECLAMATION_THRESHOLD)??.4,$v=(0,Gv.convertToMS)(c_.default.get(U.STORAGE_RECLAMATION_INTERVAL))||36e5;o(am,"onStorageReclamation");Vv=o(async e=>{if(IA.statfs){let t=await(0,IA.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"),Kv=Vv;o(OA,"runReclamationHandlers");o(g6,"setAvailableSpaceRatioGetter")});var iU={};Ce(iU,{ACTION_32_BIT:()=>h_,ACTION_64_BIT:()=>R6,AUDIT_STORE_OPTIONS:()=>um,Decoder:()=>Vc,HAS_BLOBS:()=>Nn,HAS_CURRENT_RESIDENCY_ID:()=>Kc,HAS_EXPIRATION_EXTENDED_TYPE:()=>mm,HAS_ORIGINATING_OPERATION:()=>fm,HAS_PREVIOUS_RESIDENCY_ID:()=>Yc,REMOTE_SEQUENCE_UPDATE:()=>p_,createAuditEntry:()=>Tu,getLastRemoved:()=>vA,openAuditStore:()=>f_,readAuditEntry:()=>Ut,removeAuditEntry:()=>m_,setAuditRetention:()=>T6,transactionKeyEncoder:()=>tU});function f_(e){let t=e.auditStore=e.openDB(CA.AUDIT_STORE_NAME,{create:!1,...um});t||(t=e.auditStore=e.openDB(CA.AUDIT_STORE_NAME,um),zv(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=LA;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()-PA/(1+i*i)})){try{m=m_(t,p,_)}catch(g){Su.warn("Error removing audit entry",g)}if(h=p,await new Promise(setImmediate),++f>=S6){a=10;break}}await m}finally{f===0?a=Math.min(a<<1,PA/10):(zv(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&&!Wv)for(let l of t.getKeys({reverse:!0,limit:1}))l>Date.now()&&(Wv=!0,Su.error("The current time is before the last recorded entry in the audit log. Time reversal can undermine the integrity of data tracking and certificate validation and the time must be corrected."));return t}function m_(e,t,r){let n=y6(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)===DA){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 zv(e,t){MA[0]=t,e.put(Symbol.for("last-removed"),rU)}function vA(e){let t=e.get(Symbol.for("last-removed"));if(t)return rU.set(t),MA[0]}function T6(e,t=LA){PA=e,LA=t}function Tu(e,t,r,n,s,i,a,c,l,u,d,f,m){let h=nU[a];if(!h)throw new Error(`Invalid audit entry type ${a}`);let p=1;if(n&&(n>1?Ta.setFloat64(0,n):Rs.set(UA),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&Kc&&y(u),l&Yc&&y(d),l&mm&&(Ta.setFloat64(p,f),p+=8),l&fm&&y(sU[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,$c.writeKey)(T,Rs,p);let I=p-R-1;I>127?I>16383?(Su.error("Key or username was too large for audit entry",T),p=R+1,Rs[R]=0):(Rs.copyWithin(R+2,R+1,p),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 y6(e){let t=0;e[0]==66&&(t=8);let r=e[t];if(r<128)return r;let n=e.dataView||(e.dataView=new Vc(e.buffer,e.byteOffset,e.byteLength));return n.position=t,n.readInt()}function Ut(e,t=0,r=void 0){try{let n=e.dataView||(e.dataView=new Vc(e.buffer,e.byteOffset,e.byteLength));n.position=t;let s;e[n.position]==66&&(s=n.readFloat64());let i=n.readInt(),a=n.readInt(),c=n.readInt(),l=n.readInt(),u=n.position,d=n.position+=l,f=n.readFloat64(),m,h,p,_;if(i&Kc&&(m=n.readInt()),i&Yc&&(h=n.readInt()),i&mm&&(p=n.readFloat64()),i&fm){let R=n.readInt();_=sU[R]}l=n.readInt();let g=n.position,y=n.position+=l,T;return{type:nU[i&7],tableId:c,nodeId:a,get recordId(){return(0,$c.readKey)(e,u,d)},getBinaryRecordId(){return e.subarray(u,d)},version:f,previousLocalTime:s,get user(){return y>g?(0,$c.readKey)(e,g,y):void 0},get encoded(){return t?e.subarray(t,r):e},getValue(R,I,P){if(i&u_||i&cm&&!I)return T||(T=Gc(()=>R.decoder.decode(e.subarray(n.position,r)),R.rootStore)),T;if(i&cm&&P)return cA(R.getEntry(this.recordId),P,R)},getBinaryValue(){return i&(u_|cm)?e.subarray(n.position,r):void 0},extendedType:i,residencyId:m,previousResidencyId:h,expiresAt:p,originatingOperation:_}}catch(n){return Su.error("Reading audit entry error",n,e),{}}}var $c,d_,CA,lm,eU,Su,Rs,Ta,tU,um,PA,S6,MA,rU,LA,Wv,u_,cm,jv,DA,Jv,Qv,Xv,Zv,h_,R6,p_,Kc,Yc,fm,mm,Nn,nU,sU,Vc,uo=fe(()=>{$c=require("ordered-binary"),d_=w(ce()),CA=w(kt());k();lm=w(st()),eU=w(ie());Wc();Su=w(z());KE();Ts();l_();(0,d_.initSync)();Rs=Buffer.alloc(2816),Ta=new DataView(Rs.buffer,Rs.byteOffset,2816),tU={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,$c.writeKey)(e,t,r)},readKey(e,t,r){return e[t]===66?(e.dataView||(e.dataView=new DataView(e.buffer,e.byteOffset,e.byteLength))).getFloat64(t):(0,$c.readKey)(e,t,r)}},um={encoding:"binary",keyEncoder:tU},PA=(0,eU.convertToMS)((0,d_.get)(U.LOGGING_AUDITRETENTION))||86400*3,S6=1e3,MA=new Float64Array(1),rU=new Uint8Array(MA.buffer),LA=1e4,Wv=!1;o(f_,"openAuditStore");o(m_,"removeAuditEntry");o(zv,"updateLastRemoved");o(vA,"getLastRemoved");o(T6,"setAuditRetention");u_=16,cm=32,jv=1,DA=2,Jv=3,Qv=4,Xv=5,Zv=6,h_=14,R6=15,p_=11,Kc=512,Yc=1024,fm=2048,mm=4096,Nn=8192,nU={put:jv|u_,[jv]:"put",delete:DA,[DA]:"delete",message:Jv|u_,[Jv]:"message",invalidate:Qv|cm,[Qv]:"invalidate",patch:Xv|cm,[Xv]:"patch",relocate:Zv,[Zv]:"relocate"},sU={insert:1,update:2,upsert:3,1:"insert",2:"update",3:"upsert"};o(Tu,"createAuditEntry");o(y6,"readAction");o(Ut,"readAuditEntry");Vc=class extends DataView{static{o(this,"Decoder")}position=0;readInt(){let t;return t=this.getUint8(this.position++),t>=128?t>=192?t===255?(t=this.getUint32(this.position),this.position+=4,t):(t=this.getUint32(this.position-1)&1073741823,this.position+=3,t):(t=this.getUint16(this.position-1)&32767,this.position++,t):t}readFloat64(){try{let t=this.getFloat64(this.position);return this.position+=8,t}catch(t){throw t.message=`Error reading float64: ${t.message} at position ${this.position}`,t}}}});var uU={};Ce(uU,{ENTRY:()=>b6,HAS_EXPIRATION:()=>g_,HAS_RESIDENCY_ID:()=>qA,HAS_STRUCTURE_UPDATE:()=>S_,LAST_TIMESTAMP_PLACEHOLDER:()=>dm,LOCAL_TIMESTAMP:()=>A6,METADATA:()=>yu,NEW_TIMESTAMP_PLACEHOLDER:()=>aU,NO_TIMESTAMP:()=>xA,PENDING_LOCAL_TIME:()=>GA,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>UA,RecordEncoder:()=>kA,TIMESTAMP_ASSIGN_LAST:()=>N6,TIMESTAMP_ASSIGN_NEW:()=>cU,TIMESTAMP_ASSIGN_PREVIOUS:()=>lU,TIMESTAMP_PLACEHOLDER:()=>E_,TIMESTAMP_RECORD_PREVIOUS:()=>BA,entryMap:()=>Ra,handleLocalTimeForGets:()=>T_,lastMetadata:()=>ct,recordUpdater:()=>$A,removeEntry:()=>jc});function O6(){return Em[0]=Em[0]^64,I6.getFloat64(0)}function T_(e,t){let r=e.getEntry;e.readCount=0,e.cachePuts=!1,e.rootStore=t,e.encoder.rootStore=t,e.getEntry=function(a,c){e.readCount++,ct=null;let l=r.call(this,a,c);return l&&(ct&&(l.metadataFlags=ct[yu],l.localTime=ct.localTime,l.residencyId=ct.residencyId,ct.expiresAt>=0&&(l.expiresAt=ct.expiresAt),ct=null),l.value&&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[yu],l.localTime=ct.localTime,l.residencyId=ct.residencyId,ct.expiresAt>=0&&(l.expiresAt=ct.expiresAt),ct=null),l))};let i=e.useReadTransaction();if(i.done(),!i.done.isTracked){let a=i.constructor,c=i.use,l=i.done;a.prototype.use=function(){this.timerTracked||(this.timerTracked=!0,zc.push(new WeakRef(this))),c.call(this)},a.prototype.done=function(){if(l.call(this),this.isDone)for(let u=0;u<zc.length;u++){let d=zc[u].deref();(!d||d.isDone||d.isCommitted)&&zc.splice(u--,1)}},a.prototype.done.isTracked=!0}return e}function $A(e,t,r){return function(n,s,i,a,c=-1,l,u,d="put",f,m){f||l==null?Ru=i?.localTime?BA|lU:xA:Ru=l?i?.localTime?BA|16384:cU|16384:xA;let h=u?.expiresAt;if(h>=0&&(c|=g_),pm=c,FA=h,i?.version===a&&l===!1)throw new Error("Must retain local time if version is not changed");let p={version:a,instructedWrite:Ru>0},_,g=0;try{let y=i?.residencyId,T=u?.residencyId;T&&(HA=T,pm|=qA,g|=Kc),y!==T&&(g|=Yc,y||(y=0)),c&g_&&(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=n_(()=>e.put(n,s,p),n,e.rootStore),qc&&(g|=Nn)),l){let I=u?.user?.username;if(m&&(n_(()=>e.encoder.encode(m),n,e.rootStore),qc&&(g|=Nn)),e.encoder.hasStructureUpdate&&(g|=S_,e.encoder.hasStructureUpdate=!1),f&&i?.localTime){let P=i?.localTime,Y=r.get(P);if(Y){let te=Ut(Y).previousLocalTime;return R=r.put(P,Tu(a,t,n,te,u?.nodeId??server.replication.getThisNodeId(r)??0,I,d,hm,g,T,y,h),{ifVersion:_}),R}}R=r.put(s===void 0?aU:dm,Tu(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 jc(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 oU,__,E_,dm,UA,aU,A6,yu,b6,Em,I6,xA,cU,N6,lU,BA,g_,qA,GA,S_,Ra,w6,hm,Ru,pm,FA,HA,ct,kA,zc,Wc=fe(()=>{oU=require("msgpackr");uo();__=w(z());Ts();Ts();E_=new Uint8Array([1,1,1,1,4,64,0,0]),dm=new Uint8Array([1,1,1,1,1,0,0,0]),UA=new Uint8Array([1,1,1,1,3,64,0,0]),aU=new Uint8Array([1,1,1,1,0,64,0,0]),A6=Symbol("local-timestamp"),yu=Symbol("metadata"),b6=Symbol("entry"),Em=new Uint8Array(8),I6=new DataView(Em.buffer,0,8),xA=0,cU=0,N6=1,lU=3,BA=4,g_=16,qA=32,GA=1,S_=256,Ra=new WeakMap,Ru=0,pm=-1,FA=-1,HA=0,ct=null,kA=class extends oU.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(Ru||pm>=0){let c=0,l=Ru;l&&(c+=8,Ru=0);let u=pm,d=FA,f=HA;u>=0&&(c+=4,pm=-1,d>=0&&(c+=8,FA=-1),f&&(c+=4,HA=0));let m=w6=n.call(this,i,a|2048|c);hm=m.subarray((m.start||0)+c,m.end);let h=m.start||0;return l&&(E_[4]=l,E_[5]=l>>8,m.set(E_,h),h+=8),qc&&(u|=Nn),u>=0&&((m.dataView||(m.dataView=new DataView(m.buffer,m.byteOffset,m.byteLength))).setUint32(h,u|h_<<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=O6(),i=t[c]}let u,d;i<32&&(i===h_?(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&g_&&(u=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8),a&qA&&(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,[yu]:a,expiresAt:u,residencyId:d},f}return r?.valueAsBuffer?t:Gc(()=>super.decode(t,r),this.rootStore)}catch(c){return __.error("Error decoding record",c,"data: "+t.slice(0,40).toString("hex")),null}}};o(O6,"getTimestamp");o(T_,"handleLocalTimeForGets");zc=[];setInterval(()=>{for(let e=0;e<zc.length;e++){let t=zc[e].deref();!t||t.isDone||t.isCommitted?zc.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(__.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):__.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($A,"recordUpdater");o(jc,"removeEntry")});function YA(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?YA(f.conditions,f.operator,r,n,s,i,a,c):Nu(f,n,f.descending||s.reverse===!0,r,s.allowFullScan,c,i)}o(u,"executeCondition");function d(f,m,h){return f.map((p,_)=>{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=B6(r.primaryStore,p.estimated_count,h)),y}).filter(Boolean)}o(d,"mapConditionsToFilters")}function Nu(e,t,r,n,s,i,a){let c=e[0]??e.attribute,l=e[1]??e.value,u=e.comparator;if(l===void 0&&u!=="sort")throw new Gr.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 Gr.ClientError("Can not directly query a relational attribute, must query an attribute within the target table");let P=I.definition?.tableClass||I.elements?.definition?.tableClass,Y=new Map,te=Nu({attribute:c.length>2?c.slice(1):c[1],value:l,comparator:u},t,r,P,s,Y);if(I.relationship.to){i[c[0]]=Y;let x=!!Ci(P.attributes,I.relationship.to)?.elements;te=M6(te,I,P.primaryStore,x,Y)}if(I.relationship.from){let x=o($=>($?.key!==void 0&&($=$.key),Nu({attribute:I.relationship.from,value:$},t,r,n,s,Y)),"searchEntry");I.elements?(i[c[0]]=Y,te=v6(te,I,P.primaryStore,Y,x)):te=te.flatMap(x)}return te}else if(c.length===1)c=c[0];else throw new Gr.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(WA[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 Gr.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 Gr.ClientError(`"${c}" is not indexed, can not search for this attribute`,404);if(s===!1&&g)throw new Gr.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 Gr.ServerError(`"${c}" is not indexed yet, can not search for this attribute`,503);if(l===null&&f&&!f.indexNulls)throw new Gr.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 Gr.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 M6(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 v6(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()),WA[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 Gr.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&&y_(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=Nu(e,r.transaction.getReadTxn(),!1,t),Y;y.to?Y=P.flatMap(x=>t.primaryStore.get(x)[y.to]):Y=P.map(wu);let te=new Set(Y);y.idFilter=x=>te.has(wu(x)),y.idFilter.idSet=te}return I}return o(y,"recordFilter"),s&&(y.idFilter=f),y}o(u,"attributeComparator")}function y_(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=WA[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=y_(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=L6*So(e.primaryStore)+1;else if(n==="between")r.estimated_count=P6*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=C6*So(e.primaryStore)+1}typeof r.descending=="boolean"&&(r.estimated_count/=2)}return r.estimated_count}return o(t,"estimateConditionForTable"),t}function A_(e,t){if(e)if(To=e,Au.lastIndex=0,U6.test(e))try{if(t&&(t.conditions=[]),Qs=t??new Iu,_m(Qs,""),Lr!==To.length&&qt("Unable to parse query, unexpected end of query"),Qs.parseErrorMessage&&(Qs.parseError=new VA(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 qt(e){let t=`${e} at position ${Lr}`;Qs.parseErrorMessage=Qs.parseErrorMessage?Qs.parseErrorMessage+", "+t:t}function _m(e,t){let r=Au,n,s,i,a,c,l=decodeURIComponent,u;for(;n=r.exec(To);){Lr=r.lastIndex;let[,d,f]=n;a?(d&&qt(`expected operator, but encountered '${d}'`),a=!1,c=!1):c=!0;let m;switch(f){case"=":s!=null?(d.length<=2?i=d:qt(`invalid FIQL operator ${d}`),l=dU):(l=decodeURIComponent,i="equals",d||qt("attribute must be specified before equality comparator"),s=bu(d));break;case"==":case"!=":case"<":case"<=":case">":case">=":case"===":case"!==":i=D6[f],l=KA[i]?dU:decodeURIComponent,d||qt(`attribute must be specified before comparator ${f}`),s=bu(d);break;case"&=":case"|=":case"|":case"&":case"":case void 0:if(s==null)s===void 0&&(t&&qt(`expected '${t}', but encountered ${f[0]?"'"+f[0]+"'":"end of string"}}`),qt(`no comparison specified before ${f?"'"+f+"'":"end of string"}`));else{e.conditions||qt("conditions/comparisons are not allowed in a property list");let p={comparator:i,attribute:s||null,value:l(d)};if(i==="eq"&&fU(p,d),s===""){let _=e.conditions[e.conditions.length-1];_.chainedConditions=_.chainedConditions||[],_.chainedConditions.push(p),_.operator=u}else R_(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?qt("conditions/comparisons are not allowed in a property list"):e.push(bu(d)),s=void 0;break;case"(":Au.lastIndex=Lr;let h=_m(d?[]:new Iu,")");switch(d){case"":R_(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:qt("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":qt("group by is not implemented yet");case"sort":e.sort=mU(h);break;default:qt(`unknown query function call ${d}`)}To[Lr]===","?r.lastIndex=++Lr:a=!0,s=null;break;case"{":e.conditions&&qt("property sets are not allowed in a queries"),d||qt("property sets must have a defined parent property name"),Au.lastIndex=Lr,m=_m([],"}"),m.name=d,e.push(m),To[Lr]===","?r.lastIndex=++Lr:a=!0;break;case"[":if(Au.lastIndex=Lr,d?(m=_m(new Iu,"]"),m.name=d):m=_m(e.conditions?new Iu:[],"]"),e.conditions)if(R_(e,u),To[Lr]==="="){l=decodeURIComponent,i="equals",s=bu(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"&&fU(p,d),R_(e,u),e.conditions.push(p)}else d&&qt("no attribute or comparison specified");else(d||e.length>0&&c)&&e.push(bu(d));return e}else qt(t?`expected '${t}', but encountered '${f[0]}'`:`unexpected token '${f[0]}'`);default:qt(`unexpected operator '${f}'`)}if(t!==")"&&(r=s?x6:Au,r.lastIndex=Lr),Lr===To.length)return e}t&&qt(`expected '${t}', but encountered end of string`)}function R_(e,t){e.conditions.length>0&&(e.operator?e.operator!==t&&qt("Can not mix operators within a condition grouping"):e.operator=t)}function bu(e){return e.indexOf(".")>-1?e.split(".").map(bu):decodeURIComponent(e)}function dU(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 Gr.ClientError(`Unknown type ${t}`)}return decodeURIComponent(e)}function fU(e,t){if(t.indexOf("*")>-1)if(t.endsWith("*"))e.comparator="starts_with",e.value=decodeURIComponent(t.slice(0,-1));else throw new Gr.ClientError("wildcard can only be used at the end of a string")}function mU(e){let t=hU(e[0]);return e.length>1&&(t.next=mU(e.slice(1))),t}function hU(e){if(Array.isArray(e)){let t=hU(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}}qt(`Unknown sort type ${e}`)}function wu(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 B6(e,t,r){return t*r/So(e)}var Gr,ys,Oi,ya,C6,P6,L6,D6,KA,WA,VA,U6,Au,x6,Lr,Qs,To,Iu,b_=fe(()=>{Gr=w(Ee()),ys=w(kt()),Oi=require("ordered-binary"),ya=require("lmdb");Sm();Wc();C6=.3,P6=.1,L6=.05,D6={"<":"lt","<=":"le",">":"gt",">=":"ge","!=":"ne","==":"eq","===":"equals","!==":"not_equal"},KA={lt:!0,le:!0,gt:!0,ge:!0,ne:!0,eq:!0};o(YA,"executeConditions");o(Nu,"searchByIndex");o(Ci,"findAttribute");o(M6,"joinTo");o(v6,"joinFrom");WA={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(y_,"estimateCondition");VA=class extends Gr.Violation{static{o(this,"SyntaxViolation")}},U6=/[()[\]|!<>.]|(=\w*=)/,Au=/([^?&|=<>!([{}\]),]*)([([{}\])|,&]|[=<>!]*)/g,x6=/([^&|=[\]{}]+)([[\]{}]|[&|=]*)/g;o(A_,"parseQuery");o(qt,"recordError");o(_m,"parseBlock");o(R_,"assignOperator");o(bu,"decodeProperty");o(dU,"typedDecoding");o(fU,"wildcardDecoding");o(mU,"toSortObject");o(hU,"toSortEntry");Iu=class{static{o(this,"Query")}constructor(){this.conditions=[]}[Symbol.iterator](){return this.conditions[Symbol.iterator]()}get(t){for(let r=0;r<this.conditions.length;r++){let n=this.conditions[r];if(n.attribute===t)return n.value}}getAll(){let t=[];for(let r=0,n=this.conditions.length;r<n;r++){let s=this.conditions[r];s.attribute&&t.push(s.value)}return t}};o(wu,"flattenKey");o(So,"estimatedEntryCount");o(B6,"intersectionEstimate")});var pU,Xs,I_=fe(()=>{pU=w(zs());ba();Xs=class extends URLSearchParams{static{o(this,"RequestTarget")}#e;pathname;search;id;isCollection;constructor(t){let r,n;if(t&&(r=t.indexOf("?"))>-1){n=t.slice(0,r);let s=t.slice(r+1);super(s),this.search=s}else super(),n=t;this.pathname=n??"",this.#e=t}toString(){return this.#e?this.#e:this.size>0?this.pathname+"?"+super.toString():this.pathname}get url(){return this.toString()}delete(t){super.delete(t),this.conditions&&(this.conditions=this.conditions.filter(r=>r.attribute!==t)),this.#e=void 0}set(t,r){this.delete(t),super.set(t,r),this.conditions?.push({attribute:t,value:r})}append(t,r){super.append(t,r),this.#e=void 0,this.conditions?.push({attribute:t,value:r})}};(0,pU._assignPackageExport)("Resource",Dr)});var TU={};Ce(TU,{MultiPartId:()=>N_,Resource:()=>Dr,contextStorage:()=>Cu,snakeCase:()=>H6,transformForSelect:()=>w_});function H6(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function EU(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 N_;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 Ou.ClientError(`Invalid argument for data, must be an object, but got ${s}`);c===null&&(u=!0)}else i?a=i.getContext?.()||i:s&&typeof s=="object"&&!Array.isArray(s)&&(a=s);if(c===void 0)if(typeof s=="object"&&s){if(l=s,c=s instanceof URLSearchParams?s.toString():s.url,s.conditions)c=s.id;else if(typeof c=="string")if(this.directURLMapping)c=c.slice(1),l.id=c;else{let _=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 Xs,l.id=c,u=!1)))}c===void 0&&(c=s.id??null,c==null&&(u=!0))}else c=s,l=new Xs,l.id=c,c==null&&(u=!0);l||(l=new Xs,l.id=c),u&&(l.isCollection=!0);let f;a||(a=Cu.getStore()??{}),l.ensureLoaded!=null||l.async||u?(f={...t},l.ensureLoaded!=null&&(f.ensureLoaded=l.ensureLoaded),l.async&&(f.async=l.async),u&&(f.isCollection=!0)):f=t;let m=this.loadAsInstance,h=p;if((m===!1?!this.explicitContext:this.explicitContext===!1)&&(h=o(_=>Cu.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 Ou.AccessViolation(a.user);return typeof d?.then=="function"?d.then(T=>e(_,l,a,T)):e(_,l,a,d)});if(!g)throw new Ou.AccessViolation(a.user)}return typeof d?.then=="function"?d.then(g=>e(_,l,a,g)):e(_,l,a,d)}o(p,"authorizeActionOnResource")}}function Kn(e,t){let r=new Ou.ClientError(`The ${e.constructor.name} does not have a ${t} method implemented`,405);r.allow=[],r.method=t;for(let n of["get","put","post","delete","query","move","copy"])typeof e[n]=="function"&&r.allow.push(n);throw r}function zA(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 w_(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):zA(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(zA(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(zA(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]=w_(c.select||c,d)}let u=a(c.name);return l(u)}else return a(c);else return c}}o(i,"handleProperty")}var _U,gU,Ou,SU,Cu,F6,Dr,Jc,N_,ba=fe(()=>{_U=require("crypto");Jf();Eu();gU=w(zs()),Ou=w(Ee());xc();b_();SU=require("async_hooks");I_();Cu=new SU.AsyncLocalStorage,F6={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=w_(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):Kn(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):Kn(t,"patch")},{hasContent:!0,type:"update"});static delete=On(function(t,r,n,s){return t.delete?t.delete(r):Kn(t,"delete")},{hasContent:!1,type:"delete"});static getNewId(){return(0,_U.randomUUID)()}static create(t,r,n){n?n.getContext&&(n=n.getContext()):n=Cu.getStore()??{};let s;return this.loadAsInstance===!1?s=t:t==null?s=r?.[this.primaryKey]??this.getNewId():Array.isArray(t)&&typeof t[0]!="object"?s=r?.[this.primaryKey]??[...t,this.getNewId()]:typeof t!="object"?s=r?.[this.primaryKey]??[t,this.getNewId()]:(s=t?.[this.primaryKey]??this.getNewId(),n=r||{},r=t),vt(n,async()=>{let i=new this(s,n),a=await i.create?i.create(s,r):Kn(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):Kn(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):Kn(t,"connect")},{hasContent:!0,type:"read"});static subscribe=On(function(t,r,n,s){return t.subscribe?t.subscribe(r):Kn(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):Kn(t,"publish")},{hasContent:!0,type:"create"});static search=On(function(t,r,n){let s=t.search?t.search(r):Kn(t,"search"),i=n.select;if(i&&n.hasOwnProperty("select")&&s!=null&&!s.selectApplied){let a=w_(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):Kn(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):Kn(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):Kn(t,"move")},{hasContent:!0,type:"delete"});async post(t){if(this.#r)return(await this.constructor.create(this.#e,t,this.#t)).#e;Kn(this,"post")}static isCollection(t){return t&&t.#r}get isCollection(){return this.#r}static coerceId(t){return t}static parseQuery(t,r){return A_(t,r)}static parsePath(t,r,n){let s=t.indexOf(".");if(s>-1){let a=t.slice(s+1),c=r?.headers&&F6[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:EU(t,this),isCollection:Jc}}let i=EU(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 Vn}connect(t,r){return r?.subscribe!==!1?this.subscribe?.(r):new Vn}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,gU._assignPackageExport)("Resource",Dr);o(H6,"snakeCase");o(EU,"pathToId");N_=class extends Array{static{o(this,"MultiPartId")}toString(){return this.join("/")}};o(On,"transactional");o(Kn,"missingMethod");o(zA,"selectFromObject");o(w_,"transformForSelect")});var Qc,jA=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 AU={};Ce(AU,{Resources:()=>O_,keyArrayToString:()=>Pu,resetResources:()=>k6,resources:()=>As});function k6(){return As=new O_,ve.resources=As,As}function Pu(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var RU,yU,O_,As,Lu=fe(()=>{xc();jA();RU=w(z()),yU=w(Ee());Pr();O_=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 yU.ServerError(`Conflicting paths for ${t}`);RU.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(k6,"resetResources");o(Pu,"keyArrayToString")});function XA(e,t,r,n,s){let i=e.primaryStore.env.path,a=e.primaryStore.tableId,c;s?.crossThreads===!1?(c=IU,q6(e.primaryStore,e.auditStore)):(c=bU,e.primaryStore.env.hasSubscriptionCommitListener||(e.primaryStore.env.hasSubscriptionCommitListener=!0,e.primaryStore.on("committed",()=>{NU(bU[i])})));let l=c[i]||(c[i]=[]);if(l.auditStore=e.auditStore,l.lastTxnTime==null&&(l.lastTxnTime=Date.now()),s?.scope==="full-database")return;let u=l[a];u||(u=l[a]=new Map,u.envs=l,u.tableId=a,u.store=e.primaryStore),t=Pu(t);let d=new QA(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 NU(e){if(!e)return;let t=e.auditStore;t.resetReadTxn(),wU(e.auditStore);let r;for(let{key:n,value:s}of t.getRange({start:e.lastTxnTime,exclusiveStart:!0})){e.lastTxnTime=n;let i=Ut(s),a=e[i.tableId];if(!a)continue;let c=i.recordId,l=Pu(c),u=0;do{let d=a.get(l);if(d){for(let m of d)if(!(u>0&&!(m.includeDescendants&&!(m.onlyChildren&&u>1)))){if(m.startTime>=n){(0,JA.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,JA.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 q6(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=IU[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{NU(l)}finally{r.threadLocalWrites[0]=l.lastTxnTime,r.unlock("thread-local-writes")}},"acquiredLock");r.attemptLock("thread-local-writes",u)&&u()})}}function wU(e){e.nextTransaction?.resolve();let t;e.nextTransaction=new Promise(r=>{t=r}),e.nextTransaction.resolve=t}function OU(e){return e.nextTransaction||(XA({primaryStore:e,auditStore:e},null,null,0,{scope:"full-database"}),wU(e)),e.nextTransaction}var JA,bU,IU,QA,ZA=fe(()=>{JA=w(z());Eu();Lu();uo();bU=Object.create(null),IU=Object.create(null);o(XA,"addSubscription");QA=class extends Vn{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(NU,"notifyFromTransactionData");o(q6,"listenToCommits");o(wU,"nextTransaction");o(OU,"whenNextTransaction")});var PU=M((qNe,CU)=>{"use strict";var eb=class{static{o(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};CU.exports=eb});var DU=M(($Ne,LU)=>{"use strict";var tb=class{static{o(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};LU.exports=tb});var Tm=M((KNe,vU)=>{"use strict";var MU=ce(),G6=(k(),v(K)),{RecordEncoder:$6}=(Wc(),v(uU));MU.initSync();var V6=MU.get(G6.CONFIG_PARAMS.STORAGE_CACHING)!==!1,rb=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=V6&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:$6})}};vU.exports=rb});var Rm=M((WNe,UU)=>{"use strict";var Yn=ce(),bs=(k(),v(K));Yn.initSync();var C_=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=Yn.get(bs.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Yn.get(bs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Yn.get(bs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Yn.get(bs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Yn.get(bs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Yn.get(bs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Yn.get(bs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Yn.get(bs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Yn.get(bs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Yn.get(bs.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Yn.get(bs.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Yn.get(bs.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};UU.exports=C_;C_.MAX_DBS=1e4});var _t=M((jNe,KU)=>{"use strict";var sb=require("lmdb"),Zs=require("fs-extra"),Wn=require("path"),P_=An(),FU=z(),Cn=tn().LMDB_ERRORS_ENUM,L_=DU(),ib=Tm(),HU=Rm(),Ia=kt(),xU=(k(),v(K)),{table:K6,resetDatabases:Y6}=(Le(),v(ft)),BU=ce(),ei=Ia.INTERNAL_DBIS_NAME,kU=Ia.DBI_DEFINITION_NAME,W6="data.mdb",z6="lock.mdb",ym=".mdb",j6="-lock",nb=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 sb.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function D_(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(D_,"pathEnvNameValidation");async function ob(e,t,r=!0){try{await Zs.access(e)}catch(n){throw n.code==="ENOENT"?new Error(Cn.INVALID_BASE_PATH):n}try{let n=Wn.join(e,t+ym);return await Zs.access(n,Zs.constants.R_OK|Zs.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await Zs.access(Wn.join(e,t,W6),Zs.constants.R_OK|Zs.constants.F_OK),Wn.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(ob,"validateEnvironmentPath");function M_(e,t){if(P_.validateEnv(e),t===void 0)throw new Error(Cn.DBI_NAME_REQUIRED)}o(M_,"validateEnvDBIName");async function J6(e,t,r=!1,n=!1){D_(e,t);let s=Wn.basename(e);t=t.toString();let i=BU.get(xU.CONFIG_PARAMS.DATABASES);i||BU.setProperty(xU.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await ob(e,t,n),qU(e,t,r)}catch(a){if(a.message===Cn.INVALID_ENVIRONMENT){let c=Wn.join(e,t);await Zs.mkdirp(n?c:e);let l=new HU(n?c:c+ym,!1),u=sb.open(l);u.dbis=Object.create(null);let d=new ib(!1);u.openDB(ei,d),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let f=ab(e,t,r);return u[Ia.ENVIRONMENT_NAME_KEY]=f,global.lmdb_map[f]=u,u}throw a}}o(J6,"createEnvironment");async function Q6(e,t,r,n=!0){D_(e,t),t=t.toString();let s=Wn.join(e,t);return K6({table:t,database:Wn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}o(Q6,"copyEnvironment");async function qU(e,t,r=!1){D_(e,t),t=t.toString();let n=ab(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 ob(e,t),i=Wn.join(e,t+ym),a=s!=i,c=new HU(s,a),l=sb.open(c);l.dbis=Object.create(null);let u=$U(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(qU,"openEnvironment");async function X6(e,t,r=!1){D_(e,t),t=t.toString();let n=Wn.join(e,t+ym),s=await ob(e,t);if(global.lmdb_map!==void 0){let i=ab(e,t,r);if(global.lmdb_map[i]){let a=global.lmdb_map[i];await GU(a),delete global.lmdb_map[i]}}await Zs.remove(s),await Zs.remove(s===n?s+j6:Wn.join(Wn.dirname(s),z6))}o(X6,"deleteEnvironment");async function GU(e){P_.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(GU,"closeEnvironment");function ab(e,t,r=!1){let s=`${Wn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}o(ab,"getCachedEnvironmentName");function Z6(e){P_.validateEnv(e);let t=Object.create(null),r=Is(e,ei);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==ei)try{t[n]=Object.assign(new L_,s)}catch{FU.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}o(Z6,"listDBIDefinitions");function $U(e){P_.validateEnv(e);let t=[],r=Is(e,ei);for(let{key:n}of r.getRange({start:!1}))n!==ei&&t.push(n);return t}o($U,"listDBIs");function e8(e,t){let n=Is(e,ei).getEntry(t),s=new L_;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{FU.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}o(e8,"getDBIDefinition");function VU(e,t,r,n=!r){if(M_(e,t),t=t.toString(),t===ei)throw new Error(Cn.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return Is(e,t)}catch(s){if(s.message===Cn.DBI_DOES_NOT_EXIST){let i=new ib(r,n===!0),a=e.openDB(t,i),c=new L_(r===!0,n);return a[kU]=c,Is(e,ei).putSync(t,c),e.dbis[t]=a,a}throw s}}o(VU,"createDBI");function Is(e,t){if(M_(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==ei?r=e8(e,t):r=new L_,r===void 0)throw new Error(Cn.DBI_DOES_NOT_EXIST);let n;try{let s=new ib(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[kU]=r,e.dbis[t]=n,n}o(Is,"openDBI");function t8(e,t){M_(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(t8,"statDBI");async function r8(e,t){try{let r=Wn.join(e,t+ym);return(await Zs.stat(r)).size}catch{throw new Error(Cn.INVALID_ENVIRONMENT)}}o(r8,"environmentDataSize");function n8(e,t){if(M_(e,t),t=t.toString(),t===ei)throw new Error(Cn.CANNOT_DROP_INTERNAL_DBIS_NAME);Is(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],Is(e,ei).removeSync(t)}o(n8,"dropDBI");function s8(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)VU(e,i,i!==t,i===t),n=!0;else throw a}}n&&Y6()}o(s8,"initializeDBIs");KU.exports={openDBI:Is,openEnvironment:qU,createEnvironment:J6,listDBIs:$U,listDBIDefinitions:Z6,createDBI:VU,dropDBI:n8,statDBI:t8,deleteEnvironment:X6,initializeDBIs:s8,TransactionCursor:nb,environmentDataSize:r8,copyEnvironment:Q6,closeEnvironment:GU}});var zU=M((QNe,WU)=>{"use strict";var cb=_t(),i8=z(),YU=tn().LMDB_ERRORS_ENUM;WU.exports=o8;async function o8(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 cb.closeEnvironment(global.lmdb_map[a])}catch(c){if(c.message!==YU.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await cb.closeEnvironment(global.lmdb_map[n]),await cb.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==YU.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){i8.error(t)}}o(o8,"cleanLMDBMap")});var Ro=M((ZNe,a8)=>{a8.exports={hdb_user:{hash_attribute:"username",name:"hdb_user",schema:"system",residence:["*"],attributes:[{attribute:"username"},{attribute:"password"},{attribute:"role"},{attribute:"active"},{attribute:"hash"},{attribute:"refresh_token"},{attribute:"hash_function"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_role:{hash_attribute:"id",name:"hdb_role",schema:"system",attributes:[{attribute:"id"},{attribute:"role"},{attribute:"permission"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}],residence:["*"]},hdb_job:{hash_attribute:"id",name:"hdb_job",schema:"system",attributes:[{attribute:"id"},{attribute:"user"},{attribute:"type"},{attribute:"status"},{attribute:"start_datetime"},{attribute:"end_datetime"},{attribute:"message"},{attribute:"created_datetime"},{attribute:"request"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_license:{hash_attribute:"license_key",name:"hdb_license",schema:"system",attributes:[{attribute:"license_key"},{attribute:"company"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_info:{hash_attribute:"info_id",name:"hdb_info",schema:"system",attributes:[{attribute:"info_id"},{attribute:"data_version_num"},{attribute:"hdb_version_num"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_nodes:{hash_attribute:"name",name:"hdb_nodes",schema:"system",attributes:[{attribute:"name"},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"},{attribute:"revoked_certificates"},{attribute:"shard"}]},hdb_certificate:{hash_attribute:"name",name:"hdb_certificate",schema:"system",attributes:[{attribute:"name"},{attribute:"uses"},{attribute:"certificate"},{attribute:"is_authority"},{attribute:"private_key_name"},{attribute:"details"},{attribute:"is_self_signed"},{attribute:"__updatedtime__"}]},hdb_analytics_hostname:{hash_attribute:"id",name:"hdb_analytics_hostname",schema:"system",attributes:[{attribute:"id"},{attribute:"hostname"}]},hdb_analytics:{hash_attribute:"id",name:"hdb_analytics",schema:"system",attributes:[{attribute:"id"},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]},hdb_raw_analytics:{hash_attribute:"id",name:"hdb_raw_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{attribute:"time"},{attribute:"metrics"}]},hdb_temp:{hash_attribute:"id",name:"hdb_temp",schema:"system",attributes:[{attribute:"id"}]},hdb_durable_session:{hash_attribute:"id",name:"hdb_durable_session",schema:"system",attributes:[{attribute:"id"}]},hdb_session_will:{hash_attribute:"id",name:"hdb_session_will",schema:"system",attributes:[{attribute:"id"}]}}});var Ns=M((ewe,QU)=>{var c8=Ro(),{promisify:l8}=require("util"),{getDatabases:JU}=(Le(),v(ft));QU.exports={setSchemaDataToGlobal:jU,getTableSchema:u8,getSystemSchema:d8,setSchemaDataToGlobalAsync:l8(jU)};function jU(e){global.hdb_schema=JU(),e&&e()}o(jU,"setSchemaDataToGlobal");function u8(e,t,r){let n=JU()[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(u8,"getTableSchema");function d8(){return c8}o(d8,"getSystemSchema")});var ux=M((nwe,lx)=>{"use strict";var lb=require("recursive-iterator"),f8=require("alasql"),ub=require("clone"),XU=ie(),{handleHDBError:ZU,hdbErrors:m8}=Ee(),{HDB_ERROR_MSGS:ex,HTTP_STATUS_CODES:tx}=m8,{getDatabases:h8}=(Le(),v(ft)),p8=["DISTINCT_ARRAY"],rx=Symbol("validateTables"),db=Symbol("validateTable"),rwe=Symbol("getAllColumns"),nx=Symbol("validateAllColumns"),v_=Symbol("findColumn"),sx=Symbol("validateOrderBy"),Am=Symbol("validateSegment"),fb=Symbol("validateColumn"),ix=Symbol("setColumnsForTable"),ox=Symbol("checkColumnsForAsterisk"),ax=Symbol("validateGroupBy"),cx=Symbol("hasColumns"),mb=class{static{o(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[rx](),this[ox](),this[nx]()}[rx](){if(this[cx]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[db](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[db](t.table)})}}[cx](){let t=!1,r=new lb(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[db](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=h8();if(!r[t.databaseid])throw ZU(new Error,ex.SCHEMA_NOT_FOUND(t.databaseid),tx.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw ZU(new Error,ex.TABLE_NOT_FOUND(t.databaseid,t.tableid),tx.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=ub(s);i.table=ub(t),this.attributes.push(i)})}[v_](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)}[ox](){let t=new lb(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[ix](r.tableid)}[ix](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new f8.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[nx](){this[Am](this.statement.columns,!1),this[Am](this.statement.joins,!1),this[Am](this.statement.where,!1),this[ax](this.statement.group,!1),this[Am](this.statement.order,!0)}[Am](t,r){if(!t)return;let n=new lb(t),s=[];for(let{node:i,path:a}of n)!XU.isEmpty(i)&&!XU.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[sx](i):s.push(this[fb](i)));return s}[ax](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&p8.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=ub(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[v_](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[v_](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`}[sx](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[fb](t)}[fb](t){let r=this[v_](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]}};lx.exports=mb});var fx=M((iwe,dx)=>{"use strict";var hb=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")}};dx.exports=hb});var hx=M((awe,mx)=>{"use strict";var pb=class{static{o(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};mx.exports=pb});var Ex=M((lwe,px)=>{"use strict";var Eb=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}};px.exports=Eb});var gx=M((dwe,_x)=>{"use strict";var _b=class{static{o(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};_x.exports=_b});var Zc=M((Ewe,Rx)=>{"use strict";var E8=_t(),_8=hx(),g8=Ex(),S8=gx(),Pi=An(),bm=tn().LMDB_ERRORS_ENUM,T8=kt(),yo=(k(),v(K)),R8=ie(),y8=require("uuid"),mwe=require("lmdb"),{handleHDBError:A8,hdbErrors:b8}=Ee(),{OVERFLOW_MARKER:hwe,MAX_SEARCH_KEY_LENGTH:pwe}=T8,Sx=ce();Sx.initSync();var U_=Sx.get(yo.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),gb=yo.TIME_STAMP_NAMES_ENUM.CREATED_TIME,Xc=yo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function I8(e,t,r,n,s=Pi.getNextMonotonicTime()){yb(e,t,r,n),Sb(e,t,r);let i=new _8,a=[],c=[];for(let l=0;l<n.length;l++){let u=n[l];Tx(u,!0,s);let d=N8(e,t,r,u),f=u[t];a.push(d),c.push(f)}return Tb(a,c,n,i,s)}o(I8,"insertRecords");function N8(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){U_&&u.prefetch(l.map(d=>({key:d,value:s})),x_);for(let d=0,f=l.length;d<f;d++)u.put(l[d],s)}}U_&&e.dbis[t].prefetch([s],x_),e.dbis[t].put(s,n,n[Xc])})}o(N8,"insertRecord");function w8(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}o(w8,"removeSkippedRecords");function Tx(e,t,r){let n=r>0;(n||!Number.isInteger(e[Xc]))&&(e[Xc]=r||(r=Pi.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[gb]))&&(e[gb]=r||Pi.getNextMonotonicTime()):delete e[gb]}o(Tx,"setTimestamps");function Sb(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),E8.initializeDBIs(e,t,r)}o(Sb,"initializeTransaction");async function O8(e,t,r,n,s=Pi.getNextMonotonicTime()){yb(e,t,r,n),Sb(e,t,r);let i=new g8,a=[],c=[],l=[];for(let u=0;u<n.length;u++){let d=n[u],f=d[t],m;try{m=Rb(e,t,d,f,i,!0,s)}catch{i.skipped_hashes.push(f),a.push(u);continue}c.push(m),l.push(f)}return Tb(c,l,n,i,s,a)}o(O8,"updateRecords");async function C8(e,t,r,n,s=Pi.getNextMonotonicTime()){try{yb(e,t,r,n)}catch(l){throw A8(l,l.message,b8.HTTP_STATUS_CODES.BAD_REQUEST)}Sb(e,t,r);let i=new S8,a=[],c=[];for(let l=0;l<n.length;l++){let u=n[l],d;R8.isEmpty(u[t])?(d=y8.v4(),u[t]=d):d=u[t];let f=Rb(e,t,u,d,i,!1,s);a.push(f),c.push(d)}return Tb(a,c,n,i,s)}o(C8,"upsertRecords");async function Tb(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(),w8(r,i),n}o(Tb,"finalizeWrite");function Rb(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(Tx(r,!d,a),Number.isInteger(r[Xc])&&u[Xc]>r[Xc])return!1;d&&s.original_records.push(u);let f,m=o(()=>{for(let p in r){if(!r.hasOwnProperty(p)||p===t)continue;let _=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){U_&&g.prefetch(T.map(R=>({key:R,value:n})),x_);for(let R=0,I=T.length;R<I;R++)g.remove(T[R],n)}if(T=Pi.getIndexedValues(_),T){U_&&g.prefetch(T.map(R=>({key:R,value:n})),x_);for(let R=0,I=T.length;R<I;R++)g.put(T[R],n)}}let h={...u,...r};c.put(n,h,h[Xc])},"doPut");return l?f=c.ifVersion(n,l.version,m):f=c.ifNoExists(n,m),f.then(h=>h?!0:Rb(e,t,r,n,s,i,a))}o(Rb,"updateUpsertRecord");function P8(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(P8,"validateBasic");function yb(e,t,r,n){if(P8(e,t,r),!Array.isArray(n))throw n===void 0?new Error(bm.RECORDS_REQUIRED):new Error(bm.RECORDS_MUST_BE_ARRAY)}o(yb,"validateWrite");function x_(){}o(x_,"noop");Rx.exports={insertRecords:I8,updateRecords:O8,upsertRecords:C8}});var Ax=M((gwe,yx)=>{"use strict";var L8=require("uuid"),Ab=class{static{o(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||L8.v4(),this.schema_table=`${this.schema}.${this.table}`}};yx.exports=Ab});var B_=M((Twe,bx)=>{"use strict";var D8=Ax(),bb=class extends D8{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}};bx.exports=bb});var Nx=M((ywe,Ix)=>{"use strict";Ix.exports=v8;var M8="inserted";function v8(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===M8?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}o(v8,"returnObject")});var F_=M((Iwe,Ox)=>{"use strict";var U8=(k(),v(K)),Ib=_t(),x8=Zc(),{getSystemSchemaPath:B8,getSchemaPath:F8}=At(),bwe=Ro(),{validateBySchema:H8}=at(),Im=require("joi"),k8=B_(),q8=Nx(),{handleHDBError:G8,hdbErrors:$8,ClientError:V8}=Ee(),wx=ie(),{HTTP_STATUS_CODES:K8}=$8,Y8="inserted";Ox.exports=W8;async function W8(e){let t=H8(e,Im.object({database:Im.string(),schema:Im.string(),table:Im.string().required(),attribute:Im.string().required()}));if(t)throw new V8(t.message);let r=!e.skip_table_check&&wx.checkGlobalSchemaTable(e.schema,e.table);if(r)throw G8(new Error,r,K8.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=wx.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 k8(e.schema,e.table,e.attribute,e.id);try{let i=await Ib.openEnvironment(F8(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}`);Ib.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let a=await Ib.openEnvironment(B8(),U8.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await x8.insertRecords(a,HDB_TABLE_INFO.hash_attribute,hdbAttributeAttributes,[s]);return q8(Y8,c,{records:[s]},l)}catch(i){throw i}}o(W8,"lmdbCreateAttribute")});var Di=M((wwe,Px)=>{"use strict";var Cx=ie(),z8=(k(),v(K)),Du=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Li=require("joi"),Na={schema_format:{pattern:Du,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},j8=Li.alternatives(Li.string().min(1).max(Na.schema_length.maximum).pattern(Du).messages({"string.pattern.base":"{:#label} "+Na.schema_format.message}),Li.number(),Li.array()).required(),J8=Li.alternatives(Li.string().min(1).max(Na.schema_length.maximum).pattern(Du).messages({"string.pattern.base":"{:#label} "+Na.schema_format.message}),Li.number()),Q8=Li.alternatives(Li.string().min(1).max(Na.schema_length.maximum).pattern(Du).messages({"string.pattern.base":"{:#label} "+Na.schema_format.message}),Li.number()).required();function X8(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`:Du.test(t)?"":`'${property_name}' has illegal characters`:`'${property_name}' must be at least one character`:`'${property_name}' is required`}o(X8,"checkValidTable");function Z8(e,t){return Cx.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}o(Z8,"validateSchemaExists");function e5(e,t){let r=t.state.ancestors[0].schema;return Cx.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}o(e5,"validateTableExists");function t5(e,t){return e.toLowerCase()===z8.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${hdb_terms.SYSTEM_SCHEMA_NAME}' name is reserved`):e}o(t5,"validateSchemaName");Px.exports={commonValidators:Na,schemaRegex:Du,hdbSchemaTable:j8,validateSchemaExists:Z8,validateTableExists:e5,validateSchemaName:t5,checkValidTable:X8,hdbDatabase:J8,hdbTable:Q8}});var wb=M((Cwe,Dx)=>{var{hdbTable:r5,hdbDatabase:Lx}=Di(),n5=at(),Nb=require("joi"),s5={undefined:"undefined",null:"null"},i5=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||s5[a]!==void 0)&&(s===void 0?s=`Invalid attribute name: '${a}'`:s+=`. Invalid attribute name: '${a}'`)}return s?t.message(s):e},"customRecordsVal"),o5=Nb.object({database:Lx,schema:Lx,table:r5,records:Nb.array().items(Nb.object().custom(i5)).required()});Dx.exports=function(e){return n5.validateBySchema(e,o5)}});var Nm=M((Dwe,vx)=>{"use strict";var Ao=ie(),Mx=z(),Lwe=wb(),{getDatabases:a5}=(Le(),v(ft)),{ClientError:el}=Ee();vx.exports=c5;function c5(e){if(Ao.isEmpty(e))throw new el("invalid update parameters defined.");if(Ao.isEmptyOrZeroLength(e.schema))throw new el("invalid schema specified.");if(Ao.isEmptyOrZeroLength(e.table))throw new el("invalid table specified.");if(!Array.isArray(e.records))throw new el("records must be an array");let t=a5()[e.schema]?.[e.table];if(Ao.isEmpty(t))throw new el(`could not retrieve schema:${e.schema} and table ${e.table}`);let r=t.primaryKey,n=new Set,s={},i=!1;return e.operation==="update"&&(i=!0),e.records.forEach(a=>{if(i&&Ao.isEmptyOrZeroLength(a[r]))throw Mx.error("a valid hash attribute must be provided with update record:",a),new el("a valid hash attribute must be provided with update record, check log for more info");if(!Ao.isEmptyOrZeroLength(a[r])&&(a[r]==="null"||a[r]==="undefined"))throw Mx.error(`a valid hash value must be provided with ${e.operation} record:`,a),new el(`Invalid hash value: '${a[r]}' is not a valid hash attribute value, check log for more info`);!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(c5,"insertUpdateValidate")});var H_=M((vwe,xx)=>{"use strict";var Ux=ie(),l5=(k(),v(K)),u5=z(),d5=F_(),f5=B_(),m5=bo(),{SchemaEventMsg:h5}=ti(),p5="already exists in";xx.exports=E5;async function E5(e,t,r){if(Ux.isEmptyOrZeroLength(r))return r;let n=[];Ux.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 _5(e,t.schema,t.name,i)})),s}o(E5,"lmdbCheckForNewAttributes");async function _5(e,t,r,n){let s=new f5(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await g5(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(p5))u5.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}o(_5,"createNewAttribute");async function g5(e){let t;return t=await d5(e),m5.signalSchemaChange(new h5(process.pid,l5.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}o(g5,"createAttribute")});var Mu=M((xwe,Bx)=>{"use strict";var Ob=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}};Bx.exports=Ob});var Hx=M((Fwe,Fx)=>{"use strict";var S5=Mu(),T5=(k(),v(K)).OPERATIONS_ENUM,Cb=class extends S5{static{o(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(T5.INSERT,r,n,s,i),this.records=t}};Fx.exports=Cb});var qx=M((kwe,kx)=>{"use strict";var R5=Mu(),y5=(k(),v(K)).OPERATIONS_ENUM,Pb=class extends R5{static{o(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,a=void 0){super(y5.UPDATE,n,s,i,a),this.records=t,this.original_records=r}};kx.exports=Pb});var $x=M((Gwe,Gx)=>{"use strict";var A5=Mu(),b5=(k(),v(K)).OPERATIONS_ENUM,Lb=class extends A5{static{o(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,a=void 0){super(b5.UPSERT,n,s,i,a),this.records=t,this.original_records=r}};Gx.exports=Lb});var Kx=M((Vwe,Vx)=>{"use strict";var I5=Mu(),N5=(k(),v(K)).OPERATIONS_ENUM,Db=class extends I5{static{o(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(N5.DELETE,n,s,t,i),this.original_records=r}};Vx.exports=Db});var wm=M((Wwe,jx)=>{"use strict";var Ywe=require("path"),Yx=_t(),w5=Hx(),O5=qx(),C5=$x(),P5=Kx(),vu=kt(),Wx=ie(),{CONFIG_PARAMS:L5}=(k(),v(K)),zx=ce();zx.initSync();var k_=(k(),v(K)).OPERATIONS_ENUM,{getTransactionAuditStorePath:D5}=At();jx.exports=M5;async function M5(e,t){if(zx.get(L5.LOGGING_AUDITLOG)===!1)return;let r=D5(e.schema,e.table),n=await Yx.openEnvironment(r,e.table,!0),s=v5(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){Yx.initializeDBIs(n,vu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,vu.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[vu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[vu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),Wx.isEmpty(s.user_name)||n.dbis[vu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let a=0;a<s.hash_values.length;a++)n.dbis[vu.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[a],i)})}}o(M5,"writeTransaction");function v5(e,t){let r=Wx.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===k_.INSERT)return new w5(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===k_.UPDATE)return new O5(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===k_.UPSERT)return new C5(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===k_.DELETE)return new P5(t.deleted,t.original_records,r,t.txn_time,e.__origin)}o(v5,"createTransactionObject")});var Mb=M((Jwe,Jx)=>{"use strict";var U5=Nm(),jwe=Wf(),Om=(k(),v(K)),x5=zf(),B5=Zc().insertRecords,F5=_t(),H5=z(),k5=H_(),{getSchemaPath:q5}=At(),G5=wm();Jx.exports=$5;async function $5(e){try{let{schemaTable:t,attributes:r}=U5(e);x5(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 k5(e.hdb_auth_header,t,r),s=q5(e.schema,e.table),i=await F5.openEnvironment(s,e.table),a=await B5(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await G5(e,a)}catch(c){H5.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($5,"lmdbCreateRecords")});var Zx=M((Xwe,Xx)=>{"use strict";var Qx=(k(),v(K)),V5=Mb(),K5=Wf(),Y5=require("fs-extra"),{getSchemaPath:W5}=At();Xx.exports=z5;async function z5(e){let t=[{name:e.schema,createddate:Date.now()}],r=new K5(Qx.SYSTEM_SCHEMA_NAME,Qx.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await V5(r),await Y5.mkdirp(W5(e.schema))}o(z5,"lmdbCreateSchema")});var t0=M((eOe,e0)=>{"use strict";var vb=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}};e0.exports=vb});var i0=M((iOe,s0)=>{"use strict";var r0=_t(),Ub=An(),xb=tn().LMDB_ERRORS_ENUM,j5=kt(),n0=z(),rOe=ie(),J5=require("lmdb"),Q5=t0(),X5=(k(),v(K)),{OVERFLOW_MARKER:nOe,MAX_SEARCH_KEY_LENGTH:sOe}=j5,Z5=X5.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function e9(e,t,r,n){if(Ub.validateEnv(e),t===void 0)throw new Error(xb.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(xb.IDS_REQUIRED):new Error(xb.IDS_MUST_BE_ITERABLE);try{let s=r0.listDBIs(e);r0.initializeDBIs(e,t,s);let i=new Q5,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[Z5]>n){i.skipped.push(a);continue}let _=e.dbis[t].ifVersion(a,J5.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=Ub.getIndexedValues(R);if(I)for(let P=0,Y=I.length;P<Y;P++)T.remove(I[P],a)}catch{n0.warn(`cannot delete from attribute: ${y}, ${R}:${a}`)}}});c.push(_),l.push(a),i.original_records.push(p)}catch(p){n0.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=Ub.getNextMonotonicTime(),i}catch(s){throw s}}o(e9,"deleteRecords");s0.exports={deleteRecords:e9}});var Cm=M((aOe,a0)=>{"use strict";var Uu=ie(),t9=i0(),r9=_t(),{getSchemaPath:n9}=At(),s9=wm(),i9=z();a0.exports=o9;async function o9(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(Uu.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(Uu.isEmptyOrZeroLength(e.hash_values)&&!Uu.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];Uu.isEmpty(l)||e.hash_values.push(l)}}if(Uu.isEmptyOrZeroLength(e.hash_values))return o0([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(Uu.isEmptyOrZeroLength(e.records)){e.records=[];for(let c=0;c<e.hash_values.length;c++)e.records[c]={[n]:e.hash_values[c]}}let s=n9(e.schema,e.table),i=await r9.openEnvironment(s,e.table),a=await t9.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await s9(e,a)}catch(c){i9.error(`unable to write transaction due to ${c.message}`)}return o0(a.deleted,a.skipped,a.txn_time)}catch(s){throw s}}o(o9,"lmdbDeleteRecords");function o0(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(o0,"createDeleteResponse")});var Fb=M((uOe,c0)=>{"use strict";var a9=(k(),v(K)),lOe=An();function Bb(e,t){let r=Object.create(null);if(t.length===1&&a9.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(Bb,"parseRow");function c9(e,t,r,n){let s=Bb(r,e);n.push(s)}o(c9,"searchAll");function l9(e,t,r,n){let s=Bb(r,e);n[t]=s}o(l9,"searchAllToMap");function u9(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}o(u9,"iterateDBI");function tl(e,t,r,n,s){let i=Object.create(null);i[s]=e;let a;n===s?a=e:(a=t,n!==void 0&&(i[n]=a)),r[0].push(a),r[1].push(i)}o(tl,"pushResults");function d9(e,t,r,n,s,i){t.toString().endsWith(e)&&tl(t,r,n,s,i)}o(d9,"endsWith");function f9(e,t,r,n,s,i){t.toString().includes(e)&&tl(t,r,n,s,i)}o(f9,"contains");function m9(e,t,r,n,s,i){t>e&&tl(t,r,n,s,i)}o(m9,"greaterThanCompare");function h9(e,t,r,n,s,i){t>=e&&tl(t,r,n,s,i)}o(h9,"greaterThanEqualCompare");function p9(e,t,r,n,s,i){t<e&&tl(t,r,n,s,i)}o(p9,"lessThanCompare");function E9(e,t,r,n,s,i){t<=e&&tl(t,r,n,s,i)}o(E9,"lessThanEqualCompare");c0.exports={parseRow:Bb,searchAll:c9,searchAllToMap:l9,iterateDBI:u9,endsWith:d9,contains:f9,greaterThanCompare:m9,greaterThanEqualCompare:h9,lessThanCompare:p9,lessThanEqualCompare:E9,pushResults:tl}});var xu=M((pOe,p0)=>{"use strict";var wa=_t(),fOe=z(),zn=An(),q_=kt(),Qt=tn().LMDB_ERRORS_ENUM,mOe=ie(),_9=(k(),v(K)),G_=Fb(),{parseRow:g9}=G_,hOe=require("lmdb"),{OVERFLOW_MARKER:l0,MAX_SEARCH_KEY_LENGTH:S9}=q_;function u0(e,t,r,n=!1,s=void 0,i=void 0){return rl(e,t,r,(a,c)=>c.getRange({transaction:a,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}))}o(u0,"iterateFullIndex");function Pm(e,t,r,n,s,i=!1,a=void 0,c=void 0,l=!1,u=!1){return rl(e,t,r,(d,f,m,h)=>{let T={transaction:d,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:a,offset:c,inclusiveEnd:i===!0?!l:!u,exclusiveStart:i===!0?u:l};return h===r?(T.values=!1,f.getRange(T).map(R=>({value:R}))):f.getRange(T)})}o(Pm,"iterateRangeBetween");function rl(e,t,r,n){let s=e.database||e,i=wa.openDBI(s,r);i[q_.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(rl,"setupTransaction");function d0(e,t,r,n){let s;return function(i,a){if(typeof i=="string"&&i.endsWith(l0)){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[q_.DBI_DEFINITION_NAME].is_hash_attribute);u++);}i=s.get(a,{transaction:t,lazy:!0})[n]}return i}}o(d0,"getOverflowCheck");function T9(e,t,r,n=!1,s=void 0,i=void 0){if(zn.validateEnv(e),t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);return rl(e,t,t,(a,c,l)=>($_(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=>g9(u.value,r))))}o(T9,"searchAll");function R9(e,t,r,n=!1,s=void 0,i=void 0){if(zn.validateEnv(e),t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);$_(r),r=Lm(e.database||e,r);let a=new Map;for(let{key:c,value:l}of u0(e,t,t,n,s,i))a.set(c,G_.parseRow(l,r));return a}o(R9,"searchAllToMap");function y9(e,t,r=!1,n=void 0,s=void 0){if(zn.validateEnv(e),t===void 0)throw new Error(Qt.ATTRIBUTE_REQUIRED);let i=Object.create(null),a=u0(e,void 0,t,r,n,s),c=a.transaction,l=d0(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(y9,"iterateDBI");function A9(e,t){if(zn.validateEnv(e),t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);return wa.statDBI(e,t).entryCount}o(A9,"countAll");function b9(e,t,r,n,s=!1,i=void 0,a=void 0){return Oa(e,r,n),rl(e,t,r,(c,l,u,d)=>(n=zn.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(b9,"equals");function I9(e,t,r){return Oa(e,t,r),wa.openDBI(e,t).getValuesCount(r)}o(I9,"count");function N9(e,t,r,n,s=!1,i=void 0,a=void 0){return Oa(e,r,n),rl(e,null,r,(c,l)=>{n=zn.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(N9,"startsWith");function w9(e,t,r,n,s=!1,i=void 0,a=void 0){return f0(e,t,r,n,s,i,a,!0)}o(w9,"endsWith");function f0(e,t,r,n,s=!1,i=void 0,a=void 0,c=!1){return Oa(e,r,n),rl(e,null,r,(l,u,d,f)=>{let m=d0(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(l0)?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[q_.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(f0,"contains");function O9(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(O9,"greaterThan");function C9(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(C9,"greaterThanEqual");function P9(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(P9,"lessThan");function L9(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(L9,"lessThanEqual");function D9(e,t,r,n,s,i=!1,a=void 0,c=void 0){if(zn.validateEnv(e),r===void 0)throw new Error(Qt.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(Qt.START_VALUE_REQUIRED);if(s===void 0)throw new Error(Qt.END_VALUE_REQUIRED);if(n=zn.convertKeyValueToWrite(n),s=zn.convertKeyValueToWrite(s),n>s)throw new Error(Qt.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return Pm(e,t,r,n,s,i,a,c)}o(D9,"between");function M9(e,t,r,n){zn.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);if($_(r),r=Lm(s,r),n===void 0)throw new Error(Qt.ID_REQUIRED);let a=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(a=G_.parseRow(c,r)),a}o(M9,"searchByHash");function v9(e,t,r){zn.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Qt.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}o(v9,"checkHashExists");function U9(e,t,r,n,s=[]){return h0(e,t,r,n,s),m0(e,t,r,n,s).map(i=>i[1])}o(U9,"batchSearchByHash");function x9(e,t,r,n,s=[]){h0(e,t,r,n,s);let i=new Map;for(let[a,c]of m0(e,t,r,n,s))i.set(a,c);return i}o(x9,"batchSearchByHashToMap");function m0(e,t,r,n,s=[]){return rl(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,G_.parseRow(d,r)];s.push(u)}).filter(u=>u)})}o(m0,"batchHashSearch");function h0(e,t,r,n,s){if(zn.validateEnv(e),t===void 0)throw new Error(Qt.HASH_ATTRIBUTE_REQUIRED);if($_(r),n==null)throw new Error(Qt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(Qt.IDS_MUST_BE_ITERABLE)}o(h0,"initializeBatchSearchByHash");function $_(e){if(!Array.isArray(e))throw e===void 0?new Error(Qt.FETCH_ATTRIBUTES_REQUIRED):new Error(Qt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}o($_,"validateFetchAttributes");function Oa(e,t,r){if(zn.validateEnv(e),t===void 0)throw new Error(Qt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Qt.SEARCH_VALUE_REQUIRED);if(r?.length>S9)throw new Error(Qt.SEARCH_VALUE_TOO_LARGE)}o(Oa,"validateComparisonFunctions");function Lm(e,t){return t.length===1&&_9.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=wa.listDBIs(e)),t}o(Lm,"setGetWholeRowAttributes");p0.exports={searchAll:T9,searchAllToMap:R9,count:I9,countAll:A9,equals:b9,startsWith:N9,endsWith:w9,contains:f0,searchByHash:M9,setGetWholeRowAttributes:Lm,batchSearchByHash:U9,batchSearchByHashToMap:x9,checkHashExists:v9,iterateDBI:y9,greaterThan:O9,greaterThanEqual:C9,lessThan:P9,lessThanEqual:L9,between:D9}});var Bu=M((_Oe,T0)=>{var E0=require("lodash"),_0=at(),$e=require("joi"),B9=ie(),{hdbSchemaTable:Dm,checkValidTable:g0,hdbTable:S0,hdbDatabase:V_}=Di(),{handleHDBError:F9,hdbErrors:H9}=Ee(),{getDatabases:k9}=(Le(),v(ft)),{HTTP_STATUS_CODES:q9}=H9,G9=$e.object({database:V_,schema:V_,table:S0,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)}),$9=$e.object({database:V_,schema:V_,table:S0,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()});T0.exports=function(e,t){let r=null;switch(t){case"value":r=_0.validateBySchema(e,G9);break;case"hashes":let i=function(a){s?s+=". "+a:s=a};var n=i;o(i,"addError");let s;i(g0("database",e.schema)),i(g0("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=_0.validateBySchema(e,$9);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=B9.checkGlobalSchemaTable(e.schema,e.table);if(s)return F9(new Error,s,q9.NOT_FOUND);let a=k9()[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=E0.filter(c,d=>d!=="*"&&!d.startsWith?.("$")&&d.attribute!=="*"&&!Array.isArray(d)&&!d.name&&!E0.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 Hb=M((SOe,R0)=>{"use strict";var V9=_t(),K9=Bu(),{getSchemaPath:Y9}=At();R0.exports=W9;function W9(e){let t=K9(e,"hashes");if(t)throw t;let r=Y9(e.schema,e.table);return V9.openEnvironment(r,e.table)}o(W9,"initialize")});var kb=M((ROe,y0)=>{"use strict";var z9=xu(),j9=Hb();y0.exports=J9;async function J9(e){let t=await j9(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return z9.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}o(J9,"lmdbGetDataByHash")});var Fu=M((AOe,A0)=>{"use strict";var qb=class{static{o(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};A0.exports=qb});var I0=M((NOe,b0)=>{"use strict";var IOe=Fu(),Q9=xu(),X9=Hb();b0.exports=Z9;async function Z9(e){let t=await X9(e),r=global.hdb_schema[e.schema][e.table];return Q9.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}o(Z9,"lmdbSearchByHash")});var ri=M((OOe,N0)=>{"use strict";var Gb=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}};N0.exports=Gb});var K_=M((POe,D0)=>{"use strict";var sn=xu(),e7=_t(),t7=ie(),Ve=kt(),nl=(k(),v(K)),r7=Ro(),w0=tn().LMDB_ERRORS_ENUM,{getSchemaPath:n7}=At(),Io=nl.SEARCH_WILDCARDS;async function s7(e,t,r){let n;e.schema===nl.SYSTEM_SCHEMA_NAME?n=r7[e.table]:n=global.hdb_schema[e.schema][e.table];let s=L0(e,n.hash_attribute,r,t);return C0(e,s,n.hash_attribute,r)}o(s7,"prepSearch");async function C0(e,t,r,n){let s=n7(e.schema,e.table),i=await e7.openEnvironment(s,e.table),a=P0(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(i7(e,r)===!1){let d=e.search_attribute;if(d===r)return n?O0(a,()=>!0):a.map(m=>({[r]:m.key}));let f=o(m=>({[r]:m.value,[d]:m.key}),"toObject");return n?O0(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(C0,"executeSearch");function P0(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(P0,"searchByType");function O0(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}o(O0,"createMapFromIterable");function i7(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(i7,"checkToFetchMore");function L0(e,t,r,n){if(t7.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(w0.UNKNOWN_SEARCH_TYPE)}else switch(n){case nl.VALUE_SEARCH_COMPARATORS.BETWEEN:return Ve.SEARCH_TYPES.BETWEEN;case nl.VALUE_SEARCH_COMPARATORS.GREATER:return Ve.SEARCH_TYPES.GREATER_THAN;case nl.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return Ve.SEARCH_TYPES.GREATER_THAN_EQUAL;case nl.VALUE_SEARCH_COMPARATORS.LESS:return Ve.SEARCH_TYPES.LESS_THAN;case nl.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return Ve.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(w0.UNKNOWN_SEARCH_TYPE)}}o(L0,"createSearchTypeFromSearchObject");D0.exports={executeSearch:C0,createSearchTypeFromSearchObject:L0,prepSearch:s7,searchByType:P0}});var v0=M((MOe,M0)=>{"use strict";var DOe=ri(),o7=Bu(),a7=ie(),c7=(k(),v(K)),l7=K_();M0.exports=u7;function u7(e,t){if(!a7.isEmpty(t)&&c7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=o7(e,"value");if(n)throw n;return l7.prepSearch(e,t,!0)}o(u7,"lmdbGetDataByValue")});var Mm=M((xOe,U0)=>{"use strict";var UOe=ri(),d7=Bu(),f7=ie(),m7=(k(),v(K)),h7=K_();U0.exports=p7;async function p7(e,t){if(!f7.isEmpty(t)&&m7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=d7(e,"value");if(n)throw n;return h7.prepSearch(e,t,!1)}o(p7,"lmdbSearchByValue")});var B0=M((HOe,x0)=>{"use strict";var FOe=kt(),$b=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}},Vb=class{static{o(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},Kb=class{static{o(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};x0.exports={SearchByConditionsObject:$b,SearchCondition:Vb,SortAttribute:Kb}});var G0=M(($Oe,q0)=>{"use strict";var qOe=B0().SearchByConditionsObject,E7=ri(),_7=Bu(),Yb=xu(),Y_=kt(),{Resource:GOe}=(ba(),v(TU)),k0=K_(),g7=Fb(),S7=require("lodash"),{getSchemaPath:T7}=At(),F0=_t(),{handleHDBError:R7,hdbErrors:y7}=Ee(),{HTTP_STATUS_CODES:A7}=y7,b7=1e8;q0.exports=I7;async function I7(e){let t=_7(e,"conditions");if(t)throw R7(t,t.message,A7.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=T7(e.schema,e.table),n=await F0.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let u of e.conditions)F0.openDBI(n,u.search_attribute);let i=S7.sortBy(e.conditions,u=>{if(u.estimated_count===void 0){let d=u.search_type;d===Y_.SEARCH_TYPES.EQUALS?u.estimated_count=Yb.count(n,u.search_attribute,u.search_value):d===Y_.SEARCH_TYPES.CONTAINS||d===Y_.SEARCH_TYPES.ENDS_WITH?u.estimated_count=1/0:u.estimated_count=b7}return u.estimated_count}),a=n.useReadTransaction();a.database=n;let c=await H0(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(k0.filterByType),f=d.length,m=Yb.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=>g7.parseRow(h,m))}else{for(let f=1;f<i.length;f++){let m=i[f],h=await H0(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=Yb.batchSearchByHash(a,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{a.done()},l}o(I7,"lmdbSearchByConditions");async function H0(e,t,r,n){let s=new E7(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===Y_.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,k0.searchByType(e,s,i,n).map(a=>a.value)}o(H0,"executeConditionSearch")});var vm=M((KOe,$0)=>{"use strict";var N7=(k(),v(K)).OPERATIONS_ENUM,Wb=class{static{o(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=N7.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};$0.exports=Wb});var zb=M((WOe,Q0)=>{"use strict";var W0=ri(),z0=vm(),j0=Mm(),J0=Cm(),Pn=(k(),v(K)),V0=ie(),K0=_t(),{getTransactionAuditStorePath:w7,getSchemaPath:O7}=At(),Y0=z();Q0.exports=C7;async function C7(e){try{if(V0.isEmpty(global.hdb_schema[e.schema])||V0.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await P7(e),await L7(e);let t=O7(e.schema,e.table);try{await K0.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")Y0.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=w7(e.schema,e.table);await K0.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")Y0.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}o(C7,"lmdbDropTable");async function P7(e){let t=new W0(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 j0(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 z0(Pn.SYSTEM_SCHEMA_NAME,Pn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await J0(s)}o(P7,"deleteAttributesFromSystem");async function L7(e){let t=new W0(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 j0(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 z0(Pn.SYSTEM_SCHEMA_NAME,Pn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await J0(s)}catch(i){throw i}}o(L7,"dropTableFromSystem")});var Z0=M((jOe,X0)=>{"use strict";var D7=require("fs-extra"),M7=ri(),v7=Fu(),U7=vm(),x7=zb(),B7=Cm(),F7=kb(),H7=Mm(),No=(k(),v(K)),{getSchemaPath:k7}=At(),{handleHDBError:q7,hdbErrors:G7}=Ee(),{HDB_ERROR_MSGS:$7,HTTP_STATUS_CODES:V7}=G7;X0.exports=K7;async function K7(e){let t;try{t=await Y7(e.schema);let r=new M7(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 H7(r));for(let a=0;a<n.length;a++){let c={schema:t,table:n[a].name};try{await x7(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new U7(No.SYSTEM_SCHEMA_NAME,No.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await B7(s);let i=k7(t);await D7.remove(i)}catch(r){throw r}}o(K7,"lmdbDropSchema");async function Y7(e){let t=new v7(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 F7(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw q7(new Error,$7.SCHEMA_NOT_FOUND(e),V7.NOT_FOUND,void 0,void 0,!0);return n}o(Y7,"validateDropSchema")});var Um=M((QOe,eB)=>{"use strict";var jb=class{static{o(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};eB.exports=jb});var Qb=M((eCe,tB)=>{"use strict";var W7=require("fs-extra"),W_=_t(),{getTransactionAuditStorePath:z7}=At(),Jb=kt(),ZOe=Um();tB.exports=j7;async function j7(e){let t;try{let r=z7(e.schema,e.table);await W7.mkdirp(r),t=await W_.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{W_.createDBI(t,Jb.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),W_.createDBI(t,Jb.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),W_.createDBI(t,Jb.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(j7,"createTransactionsAuditEnvironment")});var sB=M((nCe,nB)=>{"use strict";var Xb=(k(),v(K)),rB=_t(),J7=Zc(),{getSystemSchemaPath:Q7,getSchemaPath:X7}=At(),rCe=Ro(),Z7=F_(),Zb=B_(),eee=z(),tee=Qb();nB.exports=ree;async function ree(e,t){let r=X7(t.schema,t.table),n=new Zb(t.schema,t.table,Xb.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new Zb(t.schema,t.table,Xb.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new Zb(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await rB.createEnvironment(r,t.table),e!==void 0){let a=await rB.openEnvironment(Q7(),Xb.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await J7.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 eI(n),await eI(s),await eI(i)}await tee(t)}catch(a){throw a}}o(ree,"lmdbCreateTable");async function eI(e){try{await Z7(e)}catch(t){eee.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}o(eI,"createAttribute")});var oB=M((iCe,iB)=>{"use strict";var nee=Nm(),see=zf(),iee=H_(),xm=(k(),v(K)),oee=Zc().updateRecords,aee=_t(),{getSchemaPath:cee}=At(),lee=wm(),uee=z();iB.exports=dee;async function dee(e){try{let{schemaTable:t,attributes:r}=nee(e);see(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 iee(e.hdb_auth_header,t,r),s=cee(e.schema,e.table),i=await aee.openEnvironment(s,e.table),a=await oee(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await lee(e,a)}catch(c){uee.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(dee,"lmdbUpdateRecords")});var cB=M((aCe,aB)=>{"use strict";var fee=(k(),v(K)).OPERATIONS_ENUM,tI=class{static{o(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=fee.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};aB.exports=tI});var uB=M((uCe,lB)=>{"use strict";var lCe=cB(),mee=Nm(),hee=zf(),pee=H_(),Bm=(k(),v(K)),Eee=Zc().upsertRecords,_ee=_t(),{getSchemaPath:gee}=At(),See=wm(),Tee=z(),{handleHDBError:Ree,hdbErrors:yee}=Ee();lB.exports=Aee;async function Aee(e){let t;try{t=mee(e)}catch(l){throw Ree(l,l.message,yee.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schemaTable:r,attributes:n}=t;hee(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 pee(e.hdb_auth_header,r,n),i=gee(e.schema,e.table),a=await _ee.openEnvironment(i,e.table),c=await Eee(a,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await See(e,c)}catch(l){Tee.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(Aee,"lmdbUpsertRecords")});var fB=M((fCe,dB)=>{"use strict";var rI=class{static{o(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};dB.exports=rI});var hB=M((hCe,mB)=>{"use strict";var nI=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}};mB.exports=nI});var _B=M((_Ce,EB)=>{"use strict";var sI=_t(),{getTransactionAuditStorePath:bee}=At(),ECe=fB(),Fm=kt(),Iee=ie(),pB=hB(),Nee=require("util").promisify,wee=Nee(setTimeout),Oee=1e4,Cee=100;EB.exports=Pee;async function Pee(e){let t=bee(e.schema,e.table),r=await sI.openEnvironment(t,e.table,!0),n=sI.listDBIs(r);sI.initializeDBIs(r,Fm.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new pB;do s=await Lee(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 wee(Cee);while(s.transactions_deleted>0);return i}o(Pee,"deleteAuditLogsBefore");async function Lee(e,t){let r=new pB;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];Iee.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>Oee)break}return await s,r}catch(n){throw n}}o(Lee,"deleteTransactions")});var SB=M((SCe,gB)=>{"use strict";var iI=class{static{o(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};gB.exports=iI});var RB=M((yCe,TB)=>{"use strict";var Dee=ri(),Mee=vm(),RCe=SB(),Mi=(k(),v(K)),vee=ie(),oI=_t(),Uee=Ro(),xee=Mm(),Bee=Cm(),{getSchemaPath:Fee}=At();TB.exports=Hee;async function Hee(e,t=!0){let r;e.schema===Mi.SYSTEM_SCHEMA_NAME?r=Uee[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await qee(e),s=Fee(e.schema,e.table),i=await oI.openEnvironment(s,e.table);return t===!0&&await kee(e,i,r.hash_attribute),oI.dropDBI(i,e.attribute),n}o(Hee,"lmdbDropAttribute");async function kee(e,t,r){let n=oI.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(kee,"removeAttributeFromAllObjects");async function qee(e){let t=new Dee(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 xee(t)).filter(a=>a[Mi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(vee.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 Mee(Mi.SYSTEM_SCHEMA_NAME,Mi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return Bee(i)}o(qee,"dropAttributeFromSystem")});var wB=M((ICe,NB)=>{"use strict";var aI=_t(),Hu=kt(),bCe=An(),cI=(k(),v(K)),yB=ie(),{getTransactionAuditStorePath:Gee}=At(),$ee=xu(),z_=Mu(),Vee=z();NB.exports=Kee;async function Kee(e){let t=Gee(e.schema,e.table),r=await aI.openEnvironment(t,e.table,!0),n=aI.listDBIs(r);aI.initializeDBIs(r,Hu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case cI.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return AB(r,e.search_values);case cI.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,Wee(r,e.search_values,s);case cI.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return Yee(r,e.search_values);default:return AB(r)}}o(Kee,"readAuditLog");function AB(e,t=[0,Date.now()]){yB.isEmpty(t[0])&&(t[0]=0),yB.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[Hu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],n;for(let s of r.getKeys({start:t[1]}))if(s!==t[1]){n=s;break}return r.getRange({start:t[0],end:n}).map(({value:s})=>Object.assign(new z_,s))}o(AB,"searchTransactionsByTimestamp");function Yee(e,t=[]){let r=new Map;for(let n=0;n<t.length;n++){let s=t[n],i=[];for(let a of e.dbis[Hu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(a);r.set(s,IB(e,i))}return Object.fromEntries(r)}o(Yee,"searchTransactionsByUsername");function Wee(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let u=t[c],d=$ee.equals(e,Hu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Hu.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,u);for(let{value:f}of d){let m=Number(f);n.has(m)?n.get(m).push(u.toString()):n.set(m,[u.toString()])}}let s=Array.from(n.keys()),i=IB(e,s),a=new Map;for(let c=0;c<i.length;c++){let l=i[c],u=l.timestamp,d=n.get(u);bB(l,"records",r,d,a),bB(l,"original_records",r,d,a)}return Object.fromEntries(a)}o(Wee,"searchTransactionsByHashValues");function bB(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 z_(e.operation,e.user_name,i,void 0);f[t]=[c],u.push(f)}}else{let u=new z_(e.operation,e.user_name,i,void 0);u[t]=[c],s.set(l,[u])}}}o(bB,"loopRecords");function IB(e,t){let r=[];try{let n=e.dbis[Hu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP];for(let s=0;s<t.length;s++)try{let i=n.get(t[s]);if(i){let a=Object.assign(new z_,i);r.push(a)}}catch(i){Vee.warn(i)}return r}catch(n){throw n}}o(IB,"batchSearchTransactions")});var CB=M((CCe,OB)=>{"use strict";var{getSchemaPath:wCe}=At(),OCe=_t(),{database:zee}=(Le(),v(ft));OB.exports={writeTransaction:jee};async function jee(e,t,r){return zee({database:e,table:t}).transaction(r)}o(jee,"writeTransaction")});var MB=M((LCe,DB)=>{"use strict";var{getSchemaPath:PB}=At(),LB=_t();DB.exports={flush:Jee,resetReadTxn:Qee};async function Jee(e,t){return(await LB.openEnvironment(PB(e,t),t.toString())).flushed}o(Jee,"flush");async function Qee(e,t){try{(await LB.openEnvironment(PB(e,t),t.toString())).resetReadTxn()}catch{}}o(Qee,"resetReadTxn")});var BB=M((MCe,xB)=>{"use strict";var{Readable:Xee}=require("stream"),{getDatabases:Zee}=(Le(),v(ft)),{readSync:ete,openSync:tte,createReadStream:vB}=require("fs"),{open:rte}=require("lmdb"),UB=Tm(),nte=Rm(),{AUDIT_STORE_OPTIONS:ste}=(uo(),v(iU)),{INTERNAL_DBIS_NAME:ite,AUDIT_STORE_NAME:ote}=kt();xB.exports=cte;var lI=32768,ate=100;async function cte(e){let t=e.database||e.schema||"data",r=Zee()[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=rte({noSync:!0,maxDbs:nte.MAX_DBS}),m,h=f.openDB(ite,new UB(!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),_++%ate===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 UB(!P,P);await g(T,Y)}e.include_audit&&await g(ote,{...ste}),await m;let y=vB(f.path);return y.headers=l(),y.on("close",()=>{p.done(),f.close()}),y}let a=r[Object.keys(r)[0]].primaryStore,c=tte(a.path);return a.transaction(()=>{let u=Buffer.alloc(lI);ete(c,u,0,lI),a.resetReadTxn();let d=a.useReadTransaction();d.renew();let f=vB(null,{fd:c,start:lI}),m=new Xee.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(cte,"getBackup")});var kB=M((UCe,HB)=>{"use strict";var lte=z(),{handleHDBError:ute}=Ee(),dte=fx(),fte=F_(),mte=Mb(),hte=Zx(),pte=Cm(),Ete=kb(),_te=I0(),gte=v0(),Ste=Mm(),Tte=G0(),Rte=Z0(),yte=sB(),Ate=oB(),bte=uB(),Ite=_B(),Nte=zb(),wte=RB(),Ote=wB(),Cte=CB(),FB=MB(),Pte=BB(),uI=class extends dte{static{o(this,"LMDBBridge")}async searchByConditions(t){return Tte(t)}async getDataByHash(t){return await Ete(t)}async searchByHash(t){return await _te(t)}async getDataByValue(t,r){return await gte(t,r)}async searchByValue(t){return await Ste(t)}async createSchema(t){return await hte(t)}async dropSchema(t){return await Rte(t)}async createTable(t,r){return await yte(t,r)}async dropTable(t){return await Nte(t)}async createAttribute(t){return await fte(t)}async createRecords(t){return await mte(t)}async updateRecords(t){return await Ate(t)}async upsertRecords(t){try{return await bte(t)}catch(r){throw ute(r,null,null,lte.ERR,r)}}async deleteRecords(t){return await pte(t)}async dropAttribute(t){return await wte(t)}async deleteAuditLogsBefore(t){return await Ite(t)}async readAuditLog(t){return await Ote(t)}writeTransaction(t,r,n){return Cte.writeTransaction(t,r,n)}flush(t,r){return FB.flush(t,r)}resetReadTxn(t,r){return FB.resetReadTxn(t,r)}getBackup(t){return Pte(t)}};HB.exports=uI});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 jn.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 jn.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 jn.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 jn.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 jn.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 jn.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 jn.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 jn.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 jn.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 jn.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 jn.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=dI(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 jn.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?$B:GB);break}c=l}while(c&&c!==GB&&c!==$B)}function VB(e,t,r){if(typeof t=="string"){if(t==="then"||t==="getRecord"||t==="getChanges")return;if(qB[t])return qB[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=dI(s);if(i)return n||(n=Object.create(null),r._setChanges(n)),n[t]=i,i}return s}}function Lte(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 dI(e,t){let r;switch(e.constructor){case Object:return t?(r=t.TrackedObject,r||(t.TrackedObject=r=class extends il{static{o(this,"TrackedObject")}},km(r,t)),new r(e)):new il(e);case Array:let n=new J_(e.length,e);for(let s=0,i=e.length;s<i;s++){let a=e[s];a&&typeof a=="object"&&(a=dI(a,t?.elements)),n[s]=a}return n;default:return e}}function Q_(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=Q_(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=lA[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)Dte.call(e,n)&&(r||(r={...e.getRecord()}),r[n]=e[n]);return r?Object.freeze(r):e.getRecord?e.getRecord():e}function j_(e){let t=e.getRecord?.();if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[sl]||e.length!==t.length)return!0;for(let r=0,n=e.length;r<n;r++){let s=t[r],i=e[r];if(s&&i?.getRecord?.()===s){if(j_(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(j_(s))return!0}else return!0}else return!0}}return!1}var jn,qB,GB,$B,il,Dte,sl,J_,Hm,fI=fe(()=>{jn=w(Ee());KE();Ts();o(Ln,"getChanges");o(km,"assignTrackedAccessors");qB=Object.prototype,GB=new Proxy({},{get:VB}),$B=new Proxy({},{get:VB,set:Lte});o(VB,"getProxiedProperty");o(Lte,"setProxiedProperty");o(dI,"trackObject");il=class{static{o(this,"GenericTrackedObject")}#e;#t;constructor(t){if(t?.getRecord)throw new Error("Can not track an already tracked object, check for circular references");this.#e=t}getRecord(){return this.#e}setRecord(t){this.#e=t}getChanges(){return this.#t}_setChanges(t){this.#t=t}};km(il,{},!0);o(Q_,"collapseData");Dte=Object.prototype.hasOwnProperty;o(Ca,"updateAndFreeze");o(j_,"hasChanges");sl=Symbol.for("has-array-changes"),J_=class extends Array{static{o(this,"TrackedArray")}#e;[sl];constructor(t,r){super(t),this.#e=r}getRecord(){return this.#e}splice(...t){return this[sl]=!0,super.splice(...t)}push(...t){return this[sl]=!0,super.push(...t)}pop(){return this[sl]=!0,super.pop()}unshift(...t){return this[sl]=!0,super.unshift(...t)}shift(){return this[sl]=!0,super.shift()}};J_.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 XB={};Ce(XB,{ResourceBridge:()=>pI});function EI({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 KB(e,t){let r=vi(e),n=EI(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&&Q_(d)}catch(f){d={message:(0,QB.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||vte,r=it()[t];if(!r)throw(0,ni.handleHDBError)(new Error,Mte.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function YB(e,t,r){let n=e.length+t.length,s=n===1?"record":"records";return{message:`${e.length} of ${n} ${s} successfully deleted`,deleted_hashes:e,skipped_hashes:t,txn_time:r}}async function*WB(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 zB,X_,ni,jB,mI,hI,JB,QB,Mte,vte,Ute,xte,pI,ZB=fe(()=>{zB=w(kB()),X_=w(Bu()),ni=w(Ee());Le();jB=w(Nm());k();mI=w(bo()),hI=w(ti()),JB=w(ie());xc();fI();QB=w(z()),{HDB_ERROR_MSGS:Mte}=ni.hdbErrors,vte="data",Ute=1e4,xte=10,pI=class extends zB.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,X_.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:EI(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 ku({database:t.schema,table:null}),mI.signalSchemaChange(new hI.SchemaEventMsg(process.pid,q.CREATE_SCHEMA,t.schema))}async dropSchema(t){await _I(t.schema),mI.signalSchemaChange(new hI.SchemaEventMsg(process.pid,q.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,jB.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=Q_(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 YB(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:NE.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,JB.asyncSetTimeout)(xte),l=[],s=!0},"chunkDelete");for await(let d of n)l.push(d[r.primaryKey]),c++,c%Ute===0&&await u();return l.length>0&&await u(),s?YB(i,a,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,X_.default)(t,"hashes");if(r)throw r;return KB(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of KB(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&Gy[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,X_.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===NE.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:EI(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 wE.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 wE.USERNAME:{let s=t.search_values;for await(let i of WB(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n}default:return WB(r,t.search_values?.[0],t.search_values?.[1],t.limit)}}};o(EI,"getSelect");o(KB,"getRecords");o(vi,"getTable");o(YB,"createDeleteResponse");o(WB,"groupRecordsInHistory")});var Jn=M((YCe,eF)=>{"use strict";var{ResourceBridge:Bte}=(ZB(),v(XB)),Fte=ce();Fte.initSync();var Z_;function Hte(){return Z_||(Z_=new Bte,Z_)}o(Hte,"getBridge");eF.exports=Hte()});var sF=M((zCe,nF)=>{"use strict";var tF=require("lodash"),qm=require("mathjs"),kte=require("jsonata"),rF=ie();nF.exports={distinct_array:o(e=>Array.isArray(e)&&e.length>1?tF.uniqWith(e,tF.isEqual):e,"distinct_array"),searchJSON:qte,mad:Gm.bind(null,qm.mad),mean:Gm.bind(null,qm.mean),mode:Gm.bind(null,qm.mode),prod:Gm.bind(null,qm.prod),median:Gm.bind(null,qm.median)};function Gm(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(Gm,"aggregateFunction");function qte(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(rF.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),rF.isEmpty(this.__ala__.res[r])){let n=kte(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}o(qte,"searchJSON")});var oF=M((JCe,iF)=>{"use strict";var cr=require("moment"),gI="YYYY-MM-DDTHH:mm:ss.SSSZZ";cr.suppressDeprecationWarnings=!0;iF.exports={current_date:o(()=>cr().utc().format("YYYY-MM-DD"),"current_date"),current_time:o(()=>cr().utc().format("HH:mm:ss.SSS"),"current_time"),extract:o((e,t)=>{switch(t.toLowerCase()){case"year":return cr(e).utc().format("YYYY");case"month":return cr(e).utc().format("MM");case"day":return cr(e).utc().format("DD");case"hour":return cr(e).utc().format("HH");case"minute":return cr(e).utc().format("mm");case"second":return cr(e).utc().format("ss");case"millisecond":return cr(e).utc().format("SSS");default:break}},"extract"),date:o(e=>cr(e).utc().format(gI),"date"),date_format:o((e,t)=>cr(e).utc().format(t),"date_format"),date_add:o((e,t,r)=>cr(e).utc().add(t,r).valueOf(),"date_add"),date_sub:o((e,t,r)=>cr(e).utc().subtract(t,r).valueOf(),"date_sub"),date_diff:o((e,t,r)=>{let n=cr(e).utc(),s=cr(t).utc();return r?n.diff(s,r,!0):n.diff(s)},"date_diff"),now:o(()=>cr().utc().valueOf(),"now"),get_server_time:o(()=>cr().format(gI),"get_server_time"),offset_utc:o((e,t)=>cr(e).utc().utcOffset(t).format(gI),"offset_utc")}});var uF=M((XCe,lF)=>{"use strict";var Gte=require("@turf/area"),$te=require("@turf/length"),Vte=require("@turf/circle"),Kte=require("@turf/difference"),Yte=require("@turf/distance"),Wte=require("@turf/boolean-contains"),zte=require("@turf/boolean-equal"),jte=require("@turf/boolean-disjoint"),Jte=require("@turf/helpers"),aF=(k(),v(K)),Ye=ie(),wo=z();lF.exports={geoArea:Qte,geoLength:Xte,geoCircle:Zte,geoDifference:ere,geoDistance:cF,geoNear:tre,geoContains:rre,geoEqual:nre,geoCrosses:sre,geoConvert:ire};function Qte(e){if(Ye.isEmpty(e))return NaN;typeof e=="string"&&(e=Ye.autoCastJSON(e));try{return Gte.default(e)}catch(t){return wo.trace(t,e),NaN}}o(Qte,"geoArea");function Xte(e,t){if(Ye.isEmpty(e))return NaN;typeof e=="string"&&(e=Ye.autoCastJSON(e));try{return $te.default(e,{units:t||"kilometers"})}catch(r){return wo.trace(r,e),NaN}}o(Xte,"geoLength");function Zte(e,t,r){if(Ye.isEmpty(e))return NaN;if(Ye.isEmpty(t))return NaN;typeof e=="string"&&(e=Ye.autoCastJSON(e));try{return Vte.default(e,t,{units:r||"kilometers"})}catch(n){return wo.trace(n,e,t),NaN}}o(Zte,"geoCircle");function ere(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 Kte(e,t)}catch(r){return wo.trace(r,e,t),NaN}}o(ere,"geoDifference");function cF(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 Yte.default(e,t,{units:r||"kilometers"})}catch(n){return wo.trace(n,e,t),NaN}}o(cF,"geoDistance");function tre(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 cF(e,t,n)<=r}catch(s){return wo.trace(s,e,t),!1}}o(tre,"geoNear");function rre(e,t){if(Ye.isEmpty(e)||Ye.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Ye.autoCastJSON(e)),typeof t=="string"&&(t=Ye.autoCastJSON(t));try{return Wte.default(e,t)}catch(r){return wo.trace(r,e,t),!1}}o(rre,"geoContains");function nre(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 zte.default(e,t)}catch(r){return wo.trace(r,e,t),!1}}o(nre,"geoEqual");function sre(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!jte.default(e,t)}catch(r){return wo.trace(r,e,t),!1}}o(sre,"geoCrosses");function ire(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(aF.GEO_CONVERSION_ENUM[t]))throw new Error(`geoType of ${t} is invalid please use one of the following types: ${Object.keys(aF.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Ye.autoCastJSON(e)),Jte[t](e,r)}o(ire,"geoConvert")});var eg=M((ePe,dF)=>{var ol=sF(),Qn=oF(),Ui=uF();dF.exports=e=>{e.aggr.mad=e.aggr.MAD=ol.mad,e.aggr.mean=e.aggr.MEAN=ol.mean,e.aggr.mode=e.aggr.MODE=ol.mode,e.aggr.prod=e.aggr.PROD=ol.prod,e.aggr.median=e.aggr.MEDIAN=ol.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=ol.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=ol.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=Qn.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Qn.current_time,e.fn.extract=e.fn.EXTRACT=Qn.extract,e.fn.date=e.fn.DATE=Qn.date,e.fn.date_format=e.fn.DATE_FORMAT=Qn.date_format,e.fn.date_add=e.fn.DATE_ADD=Qn.date_add,e.fn.date_sub=e.fn.DATE_SUB=Qn.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Qn.date_diff,e.fn.now=e.fn.NOW=Qn.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Qn.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Qn.get_server_time,e.fn.getdate=e.fn.GETDATE=Qn.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Qn.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=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 pF=M((tPe,hF)=>{"use strict";var $m=require("lodash"),Dn=require("alasql");Dn.options.cache=!1;var ore=eg(),fF=require("clone"),tg=require("recursive-iterator"),ke=z(),tt=ie(),qu=Jn(),are=(k(),v(K)),{hdbErrors:cre}=Ee(),{getDatabases:mF}=(Le(),v(ft)),lre="IS NULL",si="There was a problem performing this search. Please check the logs and try again.";ore(Dn);var SI=class{static{o(this,"SQLSearch")}constructor(t,r){if(tt.isEmpty(t))throw ke.error("AST statement for SQL select process cannot be empty"),"statement cannot be null";this.statement=t,this.columns={},this.all_table_attributes=r,this.fetch_attributes=[],this.exact_search_values={},this.comparator_search_values={},this.tables=[],this.data={},this.has_aggregator=!1,this.has_ordinal=!1,this.has_outer_join=!1,this._getColumns(),this._getTables(),this._conditionsToFetchAttributeValues(),this._setAliasesForColumns(),tt.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!tt.isEmptyOrZeroLength(n))return ke.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw ke.error("Error thrown from checkEmptySQL in SQLSearch class method search."),ke.error(n),new Error(si)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw ke.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),ke.error(n),new Error(si)}if(Object.keys(this.data).length===0)return ke.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw ke.error("Error thrown from processJoins in SQLSearch class method search."),ke.error(n),new Error(si)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw ke.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),ke.error(n),new Error(si)}try{return t=await this._finalSQL(),t}catch(n){throw ke.error("Error thrown from finalSQL in SQLSearch class method search."),ke.error(n),new Error(si)}}_getColumns(){let t=new tg(this.statement);for(let{node:r,path:n}of t)r&&r.columnid&&(this.columns[n[0]]||(this.columns[n[0]]=[]),this.columns[n[0]].push(fF(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=mF()[r.databaseid][r.tableid].primaryKey,this.data[n].__mergedData={},this.data[n].__mergedAttributes=[],this.data[n].__mergedAttrMap={}})}_conditionsToFetchAttributeValues(){if(tt.isEmpty(this.statement.where)){ke.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new tg(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!tt.isEmpty(r)&&r.right)if(tt.isNotEmptyAndHasValue(r.right.value)){let n=tt.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new Dn.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=tt.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new Dn.yy.LogicValue({value:i}):n instanceof Dn.yy.StringValue&&tt.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new Dn.yy.NumValue({value:i}))});if(t){ke.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new tg(this.statement.where))if(r&&r.left&&r.right&&(r.left.columnid||r.right.value)&&r.op){let n=new Set,s=r.left.columnid?r.left:r.right,i=this._findColumn(s);if(!i)continue;let a=[i.table.databaseid,i.table.tableid,i.attribute].join("/");if(!tt.isEmpty(are.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(fF(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(lre)>-1&&this.tables.forEach(s=>{let i={columnid:mF()[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 qu.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 qu.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 qu.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 qu.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 tg(this.columns);for(let{node:i}of s)if(i&&i.columnid){let a=this._findColumn(i);if(a){let c=a.table.as?a.table.as:a.table.tableid;(!t[c]||t[c].indexOf(a.attribute)<0)&&n.push(a)}}n=$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 qu.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(cre.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 qu.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)}};hF.exports=SI});var on=M((nPe,EF)=>{"use strict";var ure=ux();EF.exports={searchByConditions:fre,searchByHash:mre,searchByValue:hre,search:pre};var TI=Jn(),{transformReq:RI}=ie(),dre=pF();async function fre(e){return RI(e),TI.searchByConditions(e)}o(fre,"searchByConditions");async function mre(e){RI(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of TI.searchByHash(e))r&&t.push(r);return t}o(mre,"searchByHash");async function hre(e){RI(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of TI.searchByValue(e))t.push(r);return t}o(hre,"searchByValue");function pre(e,t){try{let r=new ure(e);r.validate(),new dre(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}o(pre,"search")});var xi=M((iPe,TF)=>{"use strict";var Vm=require("crypto"),Ere=ce(),{CONFIG_PARAMS:_re}=(k(),v(K)),gF="aes-256-cbc",gre=32,Sre=16,yI=64,SF=32,Tre=yI+SF,_F=new Map;TF.exports={encrypt:Rre,decrypt:yre,createNatsTableStreamName:Are};function Rre(e){let t=Vm.randomBytes(gre),r=Vm.randomBytes(Sre),n=Vm.createCipheriv(gF,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(Rre,"encrypt");function yre(e){let t=e.substr(0,yI),r=e.substr(yI,SF),n=e.substr(Tre,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),a=Vm.createDecipheriv(gF,Buffer.from(t,"hex"),s),c=a.update(i);return c=Buffer.concat([c,a.final()]),c.toString()}o(yre,"decrypt");function Are(e,t){let r=Ere.get(_re.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=_F.get(r);return n||(n=Vm.createHash("md5").update(r).digest("hex"),_F.set(r,n)),n}o(Are,"createNatsTableStreamName")});var Pa=M((cPe,bF)=>{"use strict";var aPe=on(),Km=z(),{validateBySchema:RF}=at(),al=require("joi"),bre=xi(),rg=ie(),{handleHDBError:ng,hdbErrors:Ire,ClientError:yF}=Ee(),{HDB_ERROR_MSGS:sg,HTTP_STATUS_CODES:AI}=Ire,AF=ce();AF.initSync();var{getDatabases:bI}=(Le(),v(ft)),Nre=require("fs-extra"),wre=(k(),v(K));bF.exports={describeAll:Ore,describeTable:ig,describeSchema:Cre};async function Ore(e={}){try{let t=rg.isEmptyOrZeroLength(e),r=!!e.bypass_auth,n,s;!t&&!r&&(n=e.hdb_user?.role?.permission,s=n?.super_user||n?.cluster_user);let i=bI(),a={},c={},l=[],u=e?.exact_count;for(let f in i){a[f]=!0,!t&&!s&&!r&&(c[f]=e.hdb_user?.role?.permission[f]?.describe);let m=i[f];for(let h in m)try{let p;if(t||s||r)p=await ig({schema:f,table:h,exactCount:u});else if(n&&n[f].describe&&n[f].tables[h].describe){let _=n[f].tables[h].attribute_permissions;p=await ig({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),ng(new Error,sg.DESCRIBE_ALL_ERR)}}o(Ore,"describeAll");async function ig(e,t){rg.transformReq(e);let{schema:r,table:n}=e;r=r?.toString(),n=n?.toString();let s=t;e.hdb_user&&!e.hdb_user?.role?.permission?.super_user&&(s=e.hdb_user?.role?.permission[r]?.tables[n]?.attribute_permissions);let i=RF(e,al.object({database:al.string(),table:al.string().required(),exact_count:al.boolean().strict()}));if(i)throw new yF(i.message);let c=bI()[r];if(!c)throw ng(new Error,sg.SCHEMA_NOT_FOUND(e.schema),AI.NOT_FOUND);let l=c[n];if(!l)throw ng(new Error,sg.TABLE_NOT_FOUND(e.schema,e.table),AI.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 Nre.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")),AF.get(wre.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(m.clustering_stream_name=bre.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(ig,"descTable");async function Cre(e){rg.transformReq(e);let t=RF(e,al.object({database:al.string(),exact_count:al.boolean().strict()}));if(t)throw new yF(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=bI()[n];if(!i)throw ng(new Error,sg.SCHEMA_NOT_FOUND(e.schema),AI.NOT_FOUND);let a={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),rg.isEmpty(l)||l.describe){let u=await ig({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);u&&(a[u.name]=u)}}return a}o(Cre,"describeSchema")});var Mn=M((uPe,OF)=>{"use strict";var ag=wb(),$r=ie(),Pre=require("util"),cg=Jn(),Lre=Ns(),IF=z(),{handleHDBError:cl,hdbErrors:Dre}=Ee(),{HTTP_STATUS_CODES:ll}=Dre,Mre=Pre.promisify(Lre.getTableSchema),vre="updated",NF="inserted",wF="upserted";OF.exports={insert:xre,update:Bre,upsert:Fre,validation:Ure,flush:Hre};async function Ure(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 Mre(e.schema,e.table),r=ag(e);if(r)throw r;if(!Array.isArray(e.records))throw new Error("records must be an array");let n=t.hash_attribute,s=new Set,i={},a=!1;return e.operation==="update"&&(a=!0),e.records.forEach(c=>{if(a&&$r.isEmptyOrZeroLength(c[n]))throw IF.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 IF.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(Ure,"validation");async function xre(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=ag(e);if(t)throw cl(new Error,t.message,ll.BAD_REQUEST);$r.transformReq(e);let r=$r.checkSchemaTableExist(e.schema,e.table);if(r)throw cl(new Error,r,ll.BAD_REQUEST);let n=await cg.createRecords(e);return og(NF,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}o(xre,"insertData");async function Bre(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=ag(e);if(t)throw cl(new Error,t.message,ll.BAD_REQUEST);$r.transformReq(e);let r=$r.checkSchemaTableExist(e.schema,e.table);if(r)throw cl(new Error,r,ll.BAD_REQUEST);let n=await cg.updateRecords(e);return $r.isEmpty(n.existing_rows)?og(vre,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):og(n.update_action,[],e,n.hashes,void 0,n.txn_time)}o(Bre,"updateData");async function Fre(e){if(e.operation!=="upsert")throw cl(new Error,"invalid operation, must be upsert",ll.INTERNAL_SERVER_ERROR);let t=ag(e);if(t)throw cl(new Error,t.message,ll.BAD_REQUEST);$r.transformReq(e);let r=$r.checkSchemaTableExist(e.schema,e.table);if(r)throw cl(new Error,r,ll.BAD_REQUEST);let n=await cg.upsertRecords(e);return og(wF,n.written_hashes,e,[],n.new_attributes,n.txn_time)}o(Fre,"upsertData");function og(e,t,r,n,s,i){let a={message:`${e} ${t.length} of ${t.length+n.length} records`,new_attributes:s,txn_time:i};return e===NF?(a.inserted_hashes=t,a.skipped_hashes=n,a):e===wF?(a.upserted_hashes=t,a):(a.update_hashes=t,a.skipped_hashes=n,a)}o(og,"returnObject");function Hre(e){return $r.transformReq(e),cg.flush(e.schema,e.table)}o(Hre,"flush")});var NI=M((fPe,LF)=>{var kre=at(),II=require("joi"),{hdbTable:qre,hdbDatabase:CF}=Di(),PF={schema:CF,database:CF,table:qre},Gre={date:II.date().iso().required()},$re={timestamp:II.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};LF.exports=function(e,t){let r=t==="timestamp"?{...PF,...$re}:{...PF,...Gre},n=II.object(r);return kre.validateBySchema(e,n)}});var vF=M((mPe,MF)=>{var Vre=at(),wI=require("joi"),{hdbTable:Kre,hdbDatabase:DF}=Di(),Yre=wI.object({schema:DF,database:DF,table:Kre,hash_values:wI.array().required(),ids:wI.array()});MF.exports=function(e){return Vre.validateBySchema(e,Yre)}});var LI=M((hPe,UF)=>{"use strict";var OI=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}},CI=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}},PI=class{static{o(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};UF.exports={InsertObject:OI,NoSQLSeachObject:CI,DeleteResponseObject:PI}});var fl=M((EPe,kF)=>{"use strict";var BF=NI(),Wre=vF(),ul=ie(),xF=require("moment"),FF=z(),{promisify:zre,callbackify:jre}=require("util"),dl=(k(),v(K)),Jre=Ns(),DI=zre(Jre.getTableSchema),MI=Jn(),{DeleteResponseObject:Qre}=LI(),{handleHDBError:La,hdbErrors:Xre}=Ee(),{HDB_ERROR_MSGS:lg,HTTP_STATUS_CODES:Da}=Xre,Zre="records successfully deleted",ene=jre(HF);kF.exports={delete:ene,deleteRecord:HF,deleteFilesBefore:tne,deleteAuditLogsBefore:rne};async function tne(e){let t=BF(e,"date");if(t)throw La(t,t.message,Da.BAD_REQUEST,void 0,void 0,!0);if(ul.transformReq(e),!xF(e.date,xF.ISO_8601).isValid())throw La(new Error,lg.INVALID_DATE,Da.BAD_REQUEST,dl.LOG_LEVELS.ERROR,lg.INVALID_DATE,!0);let n=ul.checkSchemaTableExist(e.schema,e.table);if(n)throw La(new Error,n,Da.NOT_FOUND,dl.LOG_LEVELS.ERROR,n,!0);let s=await MI.deleteRecordsBefore(e);if(await DI(e.schema,e.table),FF.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}o(tne,"deleteFilesBefore");async function rne(e){let t=BF(e,"timestamp");if(t)throw La(t,t.message,Da.BAD_REQUEST,void 0,void 0,!0);if(ul.transformReq(e),isNaN(e.timestamp))throw La(new Error,lg.INVALID_VALUE("Timestamp"),Da.BAD_REQUEST,dl.LOG_LEVELS.ERROR,lg.INVALID_VALUE("Timestamp"),!0);let r=ul.checkSchemaTableExist(e.schema,e.table);if(r)throw La(new Error,r,Da.NOT_FOUND,dl.LOG_LEVELS.ERROR,r,!0);let n=await MI.deleteAuditLogsBefore(e);return await DI(e.schema,e.table),FF.info(`Finished deleting audit logs before ${e.timestamp}`),n}o(rne,"deleteAuditLogsBefore");async function HF(e){e.ids&&(e.hash_values=e.ids);let t=Wre(e);if(t)throw La(t,t.message,Da.BAD_REQUEST,void 0,void 0,!0);ul.transformReq(e);let r=ul.checkSchemaTableExist(e.schema,e.table);if(r)throw La(new Error,r,Da.NOT_FOUND,dl.LOG_LEVELS.ERROR,r,!0);try{await DI(e.schema,e.table);let n=await MI.deleteRecords(e);return ul.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${Zre}`),n}catch(n){if(n.message===dl.SEARCH_NOT_FOUND_MESSAGE){let s=new Qre;return s.message=dl.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}o(HF,"deleteRecord")});var ug={};Ce(ug,{HASH_FUNCTION:()=>Mr,hash:()=>xI,validate:()=>BI});function vI(e=Wm){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ";return Array.from(Ym.randomBytes(e)).map(r=>t[r%t.length]).join("")}function xI(e,t=Mr[GF?.toUpperCase()]??Mr.SHA256){return UI[t](e)}function BI(e,t,r=Mr[GF?.toUpperCase()]??Mr.SHA256){return e?nne[r](e,t):!1}var Ym,Gu,qF,GF,Wm,$F,Mr,UI,nne,dg=fe(()=>{Ym=w(require("node:crypto")),Gu=w(require("argon2")),qF=w(ce());k();GF=(0,qF.get)(U.AUTHENTICATION_HASHFUNCTION)?.toLowerCase(),Wm=16,$F=9,Mr={MD5:"md5",SHA256:"sha256",ARGON2ID:"argon2id"};o(vI,"generateSalt");UI={[Mr.MD5]:(e,t=void 0)=>{t=t??vI($F);let r=Ym.createHash(Mr.MD5).update(e+t).digest("hex");return t+r},[Mr.SHA256]:(e,t=void 0)=>{t=t??vI(Wm);let r=Ym.createHash(Mr.SHA256).update(e+t).digest("hex");return t+r},[Mr.ARGON2ID]:async e=>{let t=vI(Wm),r=await Gu.hash(e,{type:Gu.argon2id,salt:Buffer.from(t)});return t+r}},nne={[Mr.MD5]:(e,t)=>{let r=e.slice(0,$F);return e===UI[Mr.MD5](t,r)},[Mr.SHA256]:(e,t)=>{let r=e.slice(0,Wm);return e===UI[Mr.SHA256](t,r)},[Mr.ARGON2ID]:async(e,t)=>await Gu.verify(e.slice(Wm),t)};o(xI,"hash");o(BI,"validate")});var KF=M((TPe,VF)=>{var FI=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 sne(e){return an.password.presence=!0,an.username.presence=!0,an.role.presence=!0,an.active.presence=!0,FI.validateObject(e,an)}o(sne,"addUserValidation");function ine(e){return an.password.presence=!1,an.username.presence=!0,an.role.presence=!1,an.active.presence=!1,FI.validateObject(e,an)}o(ine,"alterUserValidation");function one(e){return an.password.presence=!1,an.username.presence=!0,an.role.presence=!1,an.active.presence=!1,FI.validateObject(e,an)}o(one,"dropUserValidation");VF.exports={addUserValidation:sne,alterUserValidation:ine,dropUserValidation:one}});var It=M((APe,WF)=>{"use strict";var{platform:yPe}=require("os"),ane="nats-server.zip",HI="nats-server",cne=process.platform==="win32"?`${HI}.exe`:HI,lne=/^[^\s.,*>]+$/,YF="__request__",une=o(e=>`${e}.${YF}`,"REQUEST_SUBJECT"),dne={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},fne={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},mne={HUB:"hub.pid",LEAF:"leaf.pid"},hne={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},pne={SUCCESS:"success",ERROR:"error"},Ene={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},_ne={TXN:"txn",MSGID:"msgid"},$u={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},gne={[$u.ERR]:1,[$u.WRN]:2,[$u.INF]:3,[$u.DBG]:4,[$u.TRC]:5},Sne={debug:"-D",trace:"-DVV"};WF.exports={NATS_SERVER_ZIP:ane,NATS_SERVER_NAME:HI,NATS_BINARY_NAME:cne,PID_FILES:mne,NATS_CONFIG_FILES:fne,SERVER_SUFFIX:hne,NATS_TERM_CONSTRAINTS_RX:lne,REQUEST_SUFFIX:YF,UPDATE_REMOTE_RESPONSE_STATUSES:pne,CLUSTER_STATUS_STATUSES:Ene,REQUEST_SUBJECT:une,SUBJECT_PREFIXES:_ne,MSG_HEADERS:dne,LOG_LEVELS:$u,LOG_LEVEL_FLAGS:Sne,LOG_LEVEL_HIERARCHY:gne}});var vn=M((IPe,vr)=>{"use strict";var JF="username is required",QF="nothing to update, must supply active, role or password to update",XF="password cannot be an empty string",ZF="If role is specified, it cannot be empty.",eH="active must be true or false";vr.exports.addUser=One;vr.exports.alterUser=Cne;vr.exports.dropUser=Lne;vr.exports.getSuperUser=xne;vr.exports.userInfo=Dne;vr.exports.listUsers=mg;vr.exports.listUsersExternal=Mne;vr.exports.setUsersWithRolesCache=ml;vr.exports.findAndValidateUser=zI;vr.exports.getClusterUser=Bne;vr.exports.getUsersWithRolesCache=Une;vr.exports.USERNAME_REQUIRED=JF;vr.exports.ALTERUSER_NOTHING_TO_UPDATE=QF;vr.exports.EMPTY_PASSWORD=XF;vr.exports.EMPTY_ROLE=ZF;vr.exports.ACTIVE_BOOLEAN=eH;var tH=Mn(),Tne=fl(),zm=(dg(),v(ug)),rH=KF(),jm=on(),VI=bo(),Bi=ie(),nH=require("validate.js"),KI=z(),{promisify:Rne}=require("util"),YI=xi(),qI=(k(),v(K)),zF=It(),yne=yt(),Ane=ce(),bne=Ro(),{hdbErrors:Ine,ClientError:ii}=Ee(),{HTTP_STATUS_CODES:Oo,AUTHENTICATION_ERROR_MSGS:kI,HDB_ERROR_MSGS:Vu}=Ine,{UserEventMsg:WI}=ti(),GI=require("lodash"),{server:fg}=(Pr(),v(Bf)),Nne=z();fg.getUser=(e,t)=>zI(e,t,t!=null);fg.authenticateUser=(e,t)=>zI(e,t);var sH={username:!0,active:!0,role:!0,password:!0},jF=new Map,wne=Rne(Tne.delete),$I=Ane.get(qI.CONFIG_PARAMS.AUTHENTICATION_HASHFUNCTION)??zm.HASH_FUNCTION.SHA256,Fi;async function One(e){let t=nH.cleanAttributes(e,sH),r=rH.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(Vu.ROLE_NAME_NOT_FOUND(t.role),Oo.NOT_FOUND);if(n.length>1)throw new ii(Vu.DUP_ROLES_FOUND(t.role),Oo.CONFLICT);n[0].permission.cluster_user===!0&&(t.hash=YI.encrypt(t.password)),t.password=await zm.hash(t.password,$I),t.hash_function=$I,t.role=n[0].id;let s=await tH.insert({operation:"insert",schema:"system",table:"hdb_user",records:[t]});if(KI.debug(s),await ml(),s.skipped_hashes.length===1)throw new ii(Vu.USER_ALREADY_EXISTS(t.username),Oo.CONFLICT);return VI.signalUserChange(new WI(process.pid)),`${t.username} successfully added`}o(One,"addUser");async function Cne(e){let t=nH.cleanAttributes(e,sH);if(Bi.isEmptyOrZeroLength(t.username))throw new Error(JF);if(Bi.isEmptyOrZeroLength(t.password)&&Bi.isEmptyOrZeroLength(t.role)&&Bi.isEmptyOrZeroLength(t.active))throw new Error(QF);if(!Bi.isEmpty(t.password)&&Bi.isEmptyOrZeroLength(t.password.trim()))throw new Error(XF);if(!Bi.isEmpty(t.active)&&!Bi.isBoolean(t.active))throw new Error(eH);if(!Bi.isEmpty(t.password)&&!Bi.isEmptyOrZeroLength(t.password.trim())&&(Pne(t.username)&&(t.hash=YI.encrypt(t.password)),t.password=await zm.hash(t.password,$I)),t.role==="")throw new Error(ZF);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(Vu.ALTER_USER_ROLE_NOT_FOUND(t.role),Oo.NOT_FOUND);if(n.length>1)throw new ii(Vu.DUP_ROLES_FOUND(t.role),Oo.CONFLICT);t.role=n[0].id}let r=await tH.update({operation:"update",schema:"system",table:"hdb_user",records:[t]});return await ml(),VI.signalUserChange(new WI(process.pid)),r}o(Cne,"alterUser");function Pne(e){let t=!1,r=Fi.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}o(Pne,"isClusterUser");async function Lne(e){let t=rH.dropUserValidation(e);if(t)throw new ii(t.message);if(Fi.get(e.username)===void 0)throw new ii(Vu.USER_NOT_EXIST(e.username),Oo.NOT_FOUND);let r=await wne({table:"hdb_user",schema:"system",hash_values:[e.username]});return KI.debug(r),await ml(),VI.signalUserChange(new WI(process.pid)),`${e.username} successfully deleted`}o(Lne,"dropUser");async function Dne(e){let t={};if(!e||!e.hdb_user)return"There was no user info in the body";t=GI.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(Dne,"userInfo");async function Mne(){let e=await mg();return e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token,delete t.hash_function}),[...e.values()]}o(Mne,"listUsersExternal");async function mg(){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]=GI.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=GI.cloneDeep(s),s.role=t[s.role],vne(s.role),n.set(s.username,s);return n}o(mg,"listUsers");function vne(e){if(!e){KI.error("invalid user role found.");return}e.permission.system||(e.permission.system={}),e.permission.system.tables||(e.permission.system.tables={});for(let t of Object.keys(bne)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}o(vne,"appendSystemTablesToRole");async function ml(e=void 0){e?Fi=e:Fi=await mg()}o(ml,"setUsersWithRolesCache");async function Une(){return Fi||await ml(),Fi}o(Une,"getUsersWithRolesCache");async function zI(e,t,r=!0){Fi||await ml();let n=Fi.get(e);if(!n){if(!r)return{username:e};throw new ii(kI.GENERIC_AUTH_FAIL,Oo.UNAUTHORIZED)}if(n&&!n.active)throw new ii(kI.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(jF.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)jF.set(t,n.password);else throw new ii(kI.GENERIC_AUTH_FAIL,Oo.UNAUTHORIZED)}}return s}o(zI,"findAndValidateUser");async function xne(){Fi||await ml();for(let[,e]of Fi)if(e.role.role==="super_user")return e}o(xne,"getSuperUser");async function Bne(){let e=await mg(),t=yne.getConfigFromFile(qI.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!(r==null||r?.role?.role!==qI.ROLE_TYPES_ENUM.CLUSTER_USER))return r.decrypt_hash=YI.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+zF.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+zF.SERVER_SUFFIX.ADMIN,r}o(Bne,"getClusterUser");var iH=[];fg.invalidateUser=function(e){for(let t of iH)try{t(e)}catch(r){Nne.error("Error invalidating user",r)}};fg.onInvalidatedUser=function(e){iH.push(e)}});var Qm=M((CPe,lH)=>{"use strict";var hl=z(),Xn=(k(),v(K)),Fne=zU(),wPe=Ns(),OPe=Pa(),Hne=vn(),{validateEvent:oH}=ti(),Jm=Jn(),kne=require("process"),{resetDatabases:qne}=(Le(),v(ft)),Gne={[Xn.ITC_EVENT_TYPES.SCHEMA]:$ne,[Xn.ITC_EVENT_TYPES.USER]:cH};async function $ne(e){let t=oH(e);if(t){hl.error(t);return}hl.trace("ITC schemaHandler received schema event:",e),await Fne(e.message),await Vne(e.message)}o($ne,"schemaHandler");async function Vne(e){try{Jm.resetReadTxn(Xn.SYSTEM_SCHEMA_NAME,Xn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),Jm.resetReadTxn(Xn.SYSTEM_SCHEMA_NAME,Xn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),Jm.resetReadTxn(Xn.SYSTEM_SCHEMA_NAME,Xn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=qne();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){hl.error(t)}}o(Vne,"syncSchemaMetadata");var aH=[];async function cH(e){try{try{Jm.resetReadTxn(Xn.SYSTEM_SCHEMA_NAME,Xn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),Jm.resetReadTxn(Xn.SYSTEM_SCHEMA_NAME,Xn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){hl.warn(r)}let t=oH(e);if(t){hl.error(t);return}hl.trace(`ITC userHandler ${Xn.HDB_ITC_CLIENT_PREFIX}${kne.pid} received user event:`,e),await Hne.setUsersWithRolesCache();for(let r of aH)r()}catch(t){hl.error(t)}}o(cH,"userHandler");cH.addListener=function(e){aH.push(e)};lH.exports=Gne});var ti=M((UPe,dH)=>{"use strict";var LPe=z(),jI=ie(),Kne=(k(),v(K)),{ITC_ERRORS:Xm}=tn(),{parentPort:DPe,threadId:Yne,isMainThread:Wne,workerData:MPe}=require("worker_threads"),{onMessageFromWorkers:zne,broadcast:vPe,broadcastWithAcknowledgement:jne}=st();dH.exports={sendItcEvent:Jne,validateEvent:uH,SchemaEventMsg:Qne,UserEventMsg:Xne};var hg;zne(async(e,t)=>{hg=hg||Qm(),uH(e),hg[e.type]&&await hg[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function Jne(e){return!Wne&&e.message&&(e.message.originator=Yne),jne(e)}o(Jne,"sendItcEvent");function uH(e){if(typeof e!="object")return Xm.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||jI.isEmpty(e.type))return Xm.MISSING_TYPE;if(!e.hasOwnProperty("message")||jI.isEmpty(e.message))return Xm.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||jI.isEmpty(e.message.originator))return Xm.MISSING_ORIGIN;if(Kne.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return Xm.INVALID_EVENT(e.type)}o(uH,"validateEvent");function Qne(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(Qne,"SchemaEventMsg");function Xne(e){this.originator=e}o(Xne,"UserEventMsg")});var bo=M((FPe,pH)=>{"use strict";var fH=(k(),v(K)),BPe=ie(),pg=z(),mH=PU(),Ku,{sendItcEvent:hH}=ti();function Zne(e){try{pg.info("signalSchemaChange called with message:",e),Ku=Ku||Qm();let t=new mH(fH.ITC_EVENT_TYPES.SCHEMA,e);return Ku.schema(t),hH(t)}catch(t){pg.error(t)}}o(Zne,"signalSchemaChange");function ese(e){try{pg.trace("signalUserChange called with message:",e),Ku=Ku||Qm();let t=new mH(fH.ITC_EVENT_TYPES.USER,e);return Ku.user(t),hH(t)}catch(t){pg.error(t)}}o(ese,"signalUserChange");pH.exports={signalSchemaChange:Zne,signalUserChange:ese}});function Eg(){return JI||(JI=et({table:"hdb_analytics_hostname",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"hostname"}]})),JI}function rse(e){return e=e.replace(tse,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 nse(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 XI(e){let t=EH.default.createHash("shake128",{outputLength:4}),r;return(0,_H.isIPv6)(e)?r=rse(e):r=e.toLowerCase(),nse(Uint8Array.from(t.update(r).digest()))}var EH,_H,QI,JI,tse,ZI=fe(()=>{Le();EH=w(require("crypto")),_H=require("node:net"),QI=new Map;o(Eg,"getAnalyticsHostnameTable");tse=/(\d{1,3}\.){3}\d{1,3}$/;o(rse,"normalizeIPv6");o(nse,"nodeHashToNumber");o(XI,"stableNodeId")});var Co,eN=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 Rg={};Ce(Rg,{addAnalyticsListener:()=>th,calculateCPUUtilization:()=>vH,diffResourceUsage:()=>UH,recordAction:()=>gt,recordActionBinary:()=>Kr,recordHostname:()=>nN,setAnalyticsEnabled:()=>sse});function sse(e){CH=e}function ise(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 ose(e,t,r,n,s,i){let a={};if(typeof t=="number")a.total=t,a.values=new Float32Array(4),a.values.index=1,a.values[0]=t,a.total=t;else if(typeof t=="boolean")a.total=t?1:0,a.count=1;else if(typeof t=="function")a.count=1,a.callback=t;else throw new TypeError("Invalid metric value type "+typeof t);a.description={metric:r,path:n,method:s,type:i},Sg.set(e,a)}function gt(e,t,r,n,s){if(!CH)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let a=Sg.get(i);a?ise(e,a):ose(i,e,t,r,n,s),gg||ase()}function Kr(e,t,r,n,s){gt(!!e,t,r,n,s)}function th(e){DH.push(e)}function ase(){gg=performance.now(),setTimeout(async()=>{let e=performance.now()-gg;gg=0;let t=[],r={time:Date.now(),period:e,threadId:pl.threadId,metrics:t};for(let[s,i]of Sg){if(i.values){let a=i.values.subarray(0,i.values.index);a.sort();let c=a.length,l=0,u=[],d;for(let f of MH){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 xH()}let n=process.memoryUsage();t.push({metric:"memory",threadId:pl.threadId,byThread:!0,...n});for(let s of DH)s(t);Sg=new Map,pl.parentPort?pl.parentPort.postMessage({type:LH,report:r}):HH({report:r})},PH).unref()}async function nN(){let e=ve.hostname;Vr.trace?.("recordHostname server.hostname:",e);let t=XI(e);Vr.trace?.("recordHostname nodeId:",t);let r=Eg();if(!await r.get(t)){let s={id:t,hostname:e};Vr.trace?.(`recordHostname storing hostname: ${JSON.stringify(s)}`),r.put(s.id,s)}}function Yu(e,t){let r=ve.hostname,n=QI.get(r);n?Vr.trace?.("storeMetric cached nodeId:",n):(n=XI(r),Vr.trace?.("storeMetric new nodeId:",n),QI.set(r,n));let s={id:[(0,rN.getNextMonotonicTime)(),n],...t};Vr.trace?.(`storing metric ${JSON.stringify(s)}`),e.put(s.id,s)}function vH(e,t){let r=e.userCPUTime+e.systemCPUTime;return Vr.trace?.(`calculateCPUUtilization cpuTime: ${r} period: ${t}`),Math.round(r/t*100)/100}function UH(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 cse(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)}`),Yu(e,l),n+=c}return n}function gH(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s?.getAuditSize();if(!i)return;let a=OH.statSync(s.primaryStore.env.path).size,c=cse(e,r,n),l=a-c,u={metric:Co.DATABASE_SIZE,database:r,size:a,used:c,free:l,audit:i};Yu(e,u),Vr.trace?.(`database ${r} size metric: ${JSON.stringify(u)}`)}catch(s){Vr.warn?.("Error getting DB size metrics",s)}}function SH(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};Yu(e,a),Vr.trace?.(`db ${r} storage volume metrics: ${JSON.stringify(a)}`)}catch(s){Vr.warn?.("Error getting DB volume metrics",s)}}async function lse(e,t=6e4){let r=sN(),n=BH(),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 xH()}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 MH){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,Yu(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-TH,active:p-RH,taskQueueLatency:await s,time:m,...process.memoryUsage()};Yu(n,R)}TH=h,RH=p;let _=process.resourceUsage();_.time=m,_.userCPUTime=_.userCPUTime/1e3,_.systemCPUTime=_.systemCPUTime/1e3,Vr.trace?.(`process.resourceUsage: ${JSON.stringify(_)}`);let g=UH(_g,_);Vr.trace?.(`diffed resourceUsage: ${JSON.stringify(g)}`),g.time=m,g.period=_g.time?m-_g.time:t,g.cpuUtilization=vH(g,g.period);let y={metric:Co.RESOURCE_USAGE,...g};Yu(n,y),_g=_;let T=it();gH(n,T),gH(n,{system:T.system}),SH(n,T),SH(n,{system:T.system})}async function yH(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function sN(){return AH||(AH=et({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function BH(){return bH||(bH=et({table:"hdb_analytics",database:"system",audit:!0,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function fse(){FH=!0;let e=(0,eh.get)(U.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await lse(PH,e),await yH(sN(),use),await yH(BH(),dse)},Math.min(e/2,2147483647)).unref()}function HH(e,t){let r=e.report;r.threadId=t?.threadId||pl.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(IH+=n.mean*n.count);r.totalBytesProcessed=IH,t&&(r.metrics.push({metric:Co.UTILIZATION,...t.performance.eventLoopUtilization(NH.get(t))}),NH.set(t,t.performance.eventLoopUtilization())),r.id=(0,rN.getNextMonotonicTime)(),sN().primaryStore.put(r.id,r),FH||fse(),mse&&(kH=pse(r))}async function pse(e){if(await kH,!Ma){let r=(0,Zm.dirname)((0,Tg.getLogFilePath)());try{Ma=await(0,tN.open)((0,Zm.join)(r,"analytics.log"),"r+")}catch{Ma=await(0,tN.open)((0,Zm.join)(r,"analytics.log"),"w+")}}let t=(await Ma.stat()).size;if(t>hse){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 pl,wH,Tg,Zm,tN,rN,eh,OH,Vr,Sg,CH,gg,PH,LH,DH,MH,TH,RH,_g,xH,use,dse,AH,bH,FH,IH,NH,mse,kH,Ma,hse,Hi=fe(()=>{pl=require("worker_threads"),wH=w(st());Le();Tg=w(z()),Zm=require("path"),tN=require("fs/promises"),rN=w(An()),eh=w(ce());k();Pr();OH=w(require("node:fs"));ZI();eN();Vr=(0,Tg.forComponent)("analytics").conditional;(0,eh.initSync)();Sg=new Map,CH=(0,eh.get)(U.ANALYTICS_AGGREGATEPERIOD)>-1;o(sse,"setAnalyticsEnabled");o(ise,"recordExistingAction");o(ose,"recordNewAction");o(gt,"recordAction");ve.recordAnalytics=gt;o(Kr,"recordActionBinary");gg=0,PH=1e3,LH="analytics-report",DH=[];o(th,"addAnalyticsListener");MH=[.01,.1,.25,.5,.75,.9,.95,.99,.999,1];o(ase,"sendAnalytics");o(nN,"recordHostname");o(Yu,"storeMetric");o(vH,"calculateCPUUtilization");o(UH,"diffResourceUsage");o(cse,"storeTableSizeMetrics");o(gH,"storeDBSizeMetrics");o(SH,"storeVolumeMetrics");o(lse,"aggregation");TH=0,RH=0,_g={userCPUTime:0,systemCPUTime:0},xH=o(()=>new Promise(setImmediate),"rest");o(yH,"cleanup");use=36e5,dse=31536e6;o(sN,"getRawAnalyticsTable");o(BH,"getAnalyticsTable");(0,wH.setChildListenerByType)(LH,HH);o(fse,"startScheduledTasks");IH=0,NH=new Map,mse=!1;o(HH,"recordAnalytics");hse=1e6;o(pse,"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 qH(e,t){(typeof e.set!="function"||typeof e.has!="function")&&(e=new ws(e));for(let[r,n]of t)e.has(r)?r.toLowerCase()==="set-cookie"&&e.append?.(r,n,!0):e.set(r,n);return e}var ws,nh=fe(()=>{ws=class extends Map{static{o(this,"Headers")}constructor(t){if(t)if(t[Symbol.iterator])super(t);else{super();for(let r in t)this.set(r,t[r])}else super()}set(t,r){return typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r),super.set(t.toLowerCase(),[t,r])}get(t){return typeof t!="string"&&(t=""+t),super.get(t.toLowerCase())?.[1]}has(t){return typeof t!="string"&&(t=""+t),super.has(t.toLowerCase())}setIfNone(t,r){typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r);let n=t.toLowerCase();if(!super.has(n))return super.set(n,[t,r])}append(t,r,n){typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r);let s=t.toLowerCase(),i=super.get(s);if(i){let a=i[1];if(n)r=(typeof a=="string"?a:a.join(", "))+", "+r;else if(typeof a=="string")r=[a,r];else{a.push(r);return}}return super.set(s,[t,r])}[Symbol.iterator](){return super.values()[Symbol.iterator]()}};o(rh,"appendHeader");o(qH,"mergeHeaders")});var XH={};Ce(XH,{EVICTED:()=>Aa,INVALIDATED:()=>wn,coerceType:()=>Ag,makeTable:()=>Ig,setServerUtilities:()=>aN});function Ig(e){let{primaryKey:t,indices:r,tableId:n,tableName:s,primaryStore:i,databasePath:a,databaseName:c,auditStore:l,schemaDefined:u,dbisDB:d,sealed:f,splitSegments:m,replicate:h}=e,{expirationMS:p,evictionMS:_,audit:g,trackDeletes:y}=e;_??=0;let{attributes:T}=e;T||(T=[]);let R=$A(i,n,l),I,P,Y={},te=Promise.resolve(),x,$,j;for(let G of T)(G.assignCreatedTime||G.name==="__createdtime__")&&(x=G),(G.assignUpdatedTime||G.name==="__updatedtime__")&&($=G),G.expiresAt&&(j=G),G.isPrimaryKey&&(Y=G);let V,le=[],re=[],se=1,_e=2,Ne={},Fe={},He=864e5,_r=0,pt,gr,wr,au=!1,cu,Ft,Nf,wf=_l.get(U.REPLICATION_DATABASES);if(Array.isArray(wf)){for(let G of wf)if(G.name===c&&G.replicateTo>=0){Nf=G.replicateTo;break}}let EE=i.getRange({start:!1,end:!1}).constructor,wy=10,_E=6;g&&wc(),am(i.env.path,G=>{if(P)return da(G)});class lu extends il{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?qe[c][L.table]:Me;if(c===vf&&(L.table===du.ROLE_TABLE_NAME||L.table===du.USER_TABLE_NAME)&&(O=!0),L.id===void 0&&(L.id=W[ee.primaryKey],L.id===void 0))throw new Error("Replication message without an id "+JSON.stringify(L));L.source=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,El.getWorkerIndex)(),H):(0,El.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,q.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 Rc(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=Ac(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=Ac(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&&(!Nse(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&&wc(),Me.audit=E}static coerceId(E){return E===""?null:Ag(E,Y)}static async dropTable(){delete qe[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(),oN.default.unlinkSync(i.env.path);ih.signalSchemaChange(new oh.SchemaEventMsg(process.pid,q.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 Rc(C,A,{transaction:b,ensureLoaded:F},!1,L=>{if(A.onlyIfCached){if(!L?.value)throw new lt.ServerError("Entry is not cached",504)}else if(F){let H=Ac(C,L,A);if(H)return N?.disregardReadTxn(),A.loadedFromSource=!0,H.then(W=>W?.value)}return L?.value})})}if(E?.property)return this.getProperty(E.property);if(this.doesExist()||E?.ensureLoaded===!1||this.getContext()?.returnNonexistent)return this}allowRead(E,S){let A=yc(E,S);if(A?.read){if(A.isSuperUser)return!0;let N=A.attribute_permissions,b=S?.select;if(N?.length>0||au&&b){if(S||(S={}),b){let C=N?.length>0&&iN(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=yc(E,A);if(N?.update){let b=N.attribute_permissions;if(b?.length>0){let C=iN(b,"update");for(let O in S)if(!C[O])return!1;for(let O of b){let D=O.attribute_name;!O.update&&!(D in S)&&(S[D]=this.getProperty(D))}}return Nc(this.getContext())}}allowCreate(E,S,A){if(this.isCollection){let N=yc(E,A);if(N?.insert){let b=N.attribute_permissions;if(b?.length>0){let C=iN(b,"insert");for(let O in S)if(!C[O])return!1;return Nc(this.getContext())}else return Nc(this.getContext())}}else return this.allowUpdate(E,{})}allowDelete(E,S){return yc(E,S)?.delete&&Nc(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 lu(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===$H?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(!(Ic(C,O,A?.nodeId)<=0)){S??=null;for(let D in r)S||(S={}),S[D]===void 0&&(S[D]=this.getProperty(D));xe.default.trace?.(`Invalidating entry in ${s} id: ${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(Ic(b,C,S?.nodeId)<=0)return;let O=Me.getResidencyRecord(S.residencyId),D=0,F=null,L=C?.value;if(O&&!O.includes(server.hostname)){for(let H in r)F||(F={}),F[H]=L(H);D=wn}else F=L;xe.default.trace?.(`Relocating entry id: ${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=Oc(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);jc(i,b??i.getEntry(E),A)}}lock(){throw new Error("Not yet implemented")}static operation(E,S){return E.table||=s,E.schema||=c,QH.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?$H:yse;let D={key:E,store:i,entry:O,nodeName:b?.nodeName,validate:o(F=>{S||(S=this.#t),A||S&&j_(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=Ic(F,L,N?.nodeId),ue;if(B<=0){if(g){let ne=L.localTime,he=L.version;xe.default.trace?.("Applying CRDT update to record with id: ",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=Ic(F,{version:he,localTime:ne},N?.nodeId),B===0)return;if(B>0)continue}if(ze.type==="patch")Ae.push(ze),ue=S;else if(ze.type==="put"||ze.type==="delete")return}ne=ze.previousLocalTime}if(!ne){xe.default.debug?.("No further audit history, must drop update",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=VE(ee,ze,A),!ee)return}}else{if(A)return;ee=VE(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=Oc(Me.getResidency(ae,b));if(ne&&!ne.includes(server.hostname))if(ue??=ae,oe=!0,Me.getResidencyById)ae=void 0;else{ae=null;for(let he in r)ae||(ae={}),ae[he]=ue[he]}ge=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)),!(Ic(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()):jc(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||KA[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"?Ese(ne,y_(Me)):ne}o(F,"orderConditions");function L(ne,he){return Array.isArray(ne)?ne.map(Ae=>Ag(Ae,he)):Ag(ne,he)}o(L,"coerceTypedValues");let H=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=>wu(he.attribute)===wu(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=YA(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 EE;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=bc(he,X.attribute,N),ze=bc(Ae,X.attribute,N),kr=ne?(0,gl.compareKeys)(ze,Oe):(0,gl.compareKeys)(Oe,ze);return kr===0?de?.(he,Ae)||0:kr}}o(ae,"createComparator");let ge=ae(A);return{async next(){let X;if(L)if(X=L.next(),X.done){if(W)return O.onDone&&O.onDone(),X}else return{value:await C.call(this,X.value)};D=[],oe&&D.push(oe);do if(X=await H.next(),X.done){if(W=!0,D.length)break;return O.onDone&&O.onDone(),X}else{let de=X.value;if(de?.then&&(de=await de),ee){let ne=bc(de,ee,N);if(ue)ue=!1,B=ne;else if(ne!==B){B=ne,oe=de;break}}D.push(de)}while(!0);return A.isGrouped,D.sort(ge),L=D[Symbol.iterator](),X=L.next(),X.done?(O.onDone&&O.onDone(),X):{value:await C.call(this,X.value)}},return(){O.onDone&&O.onDone(),H.return()},throw(){O.onDone&&O.onDone(),H.throw()}}};let F=o(L=>{if(typeof S=="object"&&Array.isArray(L.attribute))for(let H=0;H<S.length;H++){let W=S[H],ee;if(W.name===L.attribute[0]){for(ee=W.sort||(W.sort={});ee.next;)ee=ee.next;ee.attribute=L.attribute.slice(1),ee.descending=L.descending}else W===L.attribute[0]&&(S[H]=ee={name:W,sort:{attribute:L.attribute.slice(1),descending:L.descending}})}L.next&&F(L.next)},"applySortingOnSelect");F(A)}else O.iterate=(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=Rc(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=Ac(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]:wu(L.key);X=de.get(he),X||(X=[])}else X=de.fromRecord?.(H);else X=ge(H,S,L,!0);let ne=o(he=>{if(ge.directReturn)return ue(he,ae);if(he&&typeof he=="object"){let Ae=ge.definition?.tableClass||Me;D||(D={});let Oe=D[ae]||(D[ae]=Ae.transformEntryForSelect(ae===B?null:B.select||(Array.isArray(B)?B:null),S,A,de,b));if(Array.isArray(he)){let ze=[],kr=Ae.transformToOrderedSelect(he,B.select,typeof B.sort=="object"&&B.sort,S,A,Oe)[this.isSync?Symbol.iterator:Symbol.asyncIterator](),ye=o(Xe=>{for(;!Xe.done;){if(Xe?.then)return Xe.then(ye);ze.push(Xe.value),Xe=kr.next()}ue(ze,ae)},"nextValue"),We=ye(kr.next());We&&(W||(W=[]),W.push(We));return}else if(he=Oe.call(this,he),he?.then){W||(W=[]),W.push(he.then(ze=>ue(ze,ae)));return}}ue(he,ae)},"handleResolvedValue");X?.then?(W||(W=[]),W.push(X.then(ne))):ne(X);return}else X=H[ae],X&&typeof X=="object"&&ae!==B&&(X=Me.transformEntryForSelect(B.select||B,S,A,null)({value:X}));ue(X,ae)},"selectAttribute"),oe;if(typeof 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=XA(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||WH(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>KH&&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||WH(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,gl.MAXIMUM_KEY],versions:!0,snapshot:!1}))if(H&&(b.send({id:L,localTime:ee,value:H,version:W,type:"put"}),b.queue?.length>KH&&await b.waitForDrain()===!1))return}}else{D&&!F&&(F=0);let L=this.#n?.localTime;if(L===GA&&(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 ${Os(b)} in property ${O} must be an object${C.type?" ("+C.type+")":""}`);let D=C.properties;for(let F=0,L=D.length;F<L;F++){let H=D[F];if(H.relationship||H.computed){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 ${Os(b)} in property ${O} must be an integer (from -2147483648 to 2147483647)`);break;case"Long":(typeof b!="number"||!(Math.floor(b)===b&&Math.abs(b)<=9007199254740992))&&(A||(A=[])).push(`Value ${Os(b)} in property ${O} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof b!="number"&&(A||(A=[])).push(`Value ${Os(b)} in property ${O} must be a number`);break;case"ID":typeof b=="string"||b?.length>0&&b.every?.(D=>typeof D=="string")||(A||(A=[])).push(`Value ${Os(b)} in property ${O} must be a string, or an array of strings`);break;case"String":typeof b!="string"&&(A||(A=[])).push(`Value ${Os(b)} in property ${O} must be a string`);break;case"Boolean":typeof b!="boolean"&&(A||(A=[])).push(`Value ${Os(b)} in property ${O} must be a boolean`);break;case"Date":if(!(b instanceof Date)){if(typeof b=="string"||typeof b=="number")return new Date(b);(A||(A=[])).push(`Value ${Os(b)} in property ${O} must be a Date`)}break;case"BigInt":if(typeof b!="bigint"){if(typeof b=="string"||typeof b=="number")return BigInt(b);(A||(A=[])).push(`Value ${Os(b)} in property ${O} must be a bigint`)}break;case"Bytes":if(!(b instanceof Uint8Array)){if(typeof b=="string")return Buffer.from(b);(A||(A=[])).push(`Value ${Os(b)} in property ${O} must be a Buffer or Uint8Array`)}break;case"Blob":if(!(b instanceof Ss)){if(typeof b=="string"&&(b=Buffer.from(b)),b instanceof Buffer)return createBlob(b,{type:"text/plain"});(A||(A=[])).push(`Value ${Os(b)} in property ${O} must be a Blob`)}break;case"array":if(Array.isArray(b)){if(C.elements)for(let D=0,F=b.length;D<F;D++){let L=b[D],H=N(L,C.elements,O+"[*]");H&&(b[D]=H)}}else(A||(A=[])).push(`Value ${Os(b)} in property ${O} must be an Array`);break}C.nullable===!1&&b==null&&(A||(A=[])).push(`Property ${O} is required (and not does not allow null values)`)},"validateValue");for(let b=0,C=T.length;b<C;b++){let O=T[b];if(O.relationship||O.computed){Object.hasOwn(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");_se(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=oN.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)"),au=!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?Nu({attribute:S.to,value:D},Cr(b).getReadTxn(),!1,F,!1).map(L=>L&&L.key!==void 0?L:F.primaryStore.getEntry(L,{transaction:Cr(b).getReadTxn()})).asArray:F.search([{attribute:S.to,value:D}],b).asArray},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(zH)):H.filter(zH):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(lu,this,!0);for(let E of T){let S=E.name;E.resolve&&Object.defineProperty(i.encoder.structPrototype,S,{get(){return E.resolve(this,Cu.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=m_(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=jc(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&&gE(),Me;function oo(G,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(G,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)&&GH){let oe=W.concat(H).map(B=>({key:B,value:G}));b.prefetch(oe,YH)}for(let oe=0,B=W.length;oe<B;oe++)b.remove(W[oe],G)}else H?.length>0&&GH&&b.prefetch(H.map(ee=>({key:ee,value:G})),YH);if(H)for(let ee=0,oe=H.length;ee<oe;ee++)b.put(H[ee],G)}return A}o(oo,"updateIndices");function Or(G){switch(typeof G){case"number":return!0;case"string":if(G.length<659)return!0;if(G.length>VH)throw new Error("Primary key size is too large: "+G.length);break;case"object":if(G===null)throw new Error("Invalid primary key of null");break;case"bigint":if(G<2n**64n&&G>-(2n**64n))return!0;break;default:throw new Error("Invalid primary key type: "+typeof G)}if((0,gl.writeKey)(G,Ase,0)>VH)throw new Error("Primary key size is too large: "+G.length);return!0}o(Or,"checkValidId");function Sr(G){return typeof G=="object"&&G?G.id:G}o(Sr,"requestTargetToId");function Cf(G){return typeof G=="object"&&G&&G.isCollection}o(Cf,"isSearchTarget");function Es(G){}o(Es,"isRequestTarget");function Rc(G,E,S,A,N){if(Me.getResidencyById&&S.ensureLoaded&&E?.replicateFrom!==!1){let C=Oc(Me.getResidencyById(G));if(C&&!C.includes(server.hostname)&&I)return I({key:G,residency:C}).then(N)}let b=o(()=>{if(E?.transaction?.stale&&(E.transaction.stale=!1),S.transaction?.isDone)return N(null,G);let C=i.getEntry(G,S);return C?.residencyId&&C.metadataFlags&wn&&I&&S.ensureLoaded&&E?.replicateFrom!==!1?I(C).then(O=>N(O,G),O=>(xe.default.error?.("Error loading remote record",G,C,S,O),N(null,G))):(C&&E&&(C?.version>(E.lastModified||0)&&(E.lastModified=C.version),C?.localTime&&!E.lastRefreshed&&(E.lastRefreshed=C.localTime)),N(C,G))},"whenPrefetched");return A?b():se>0?(se--,b()):new Promise((C,O)=>{se===0?(se--,i.prefetch([G],()=>{D(),F()})):(le.push(G),re.push(F),le.length>_E&&(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<wy&&_e++}o(D,"prefetch");function F(){try{C(b())}catch(L){O(L)}}o(F,"load")})}o(Rc,"loadLocalRecord");function yc(G,E){let S=E?.checkPermission;if(typeof S!="object"){if(!G?.role)return;S=G.role.permission}if(S.super_user)return bse;let A=S[c],N,b=A?.tables;if(b)return b[s];if(c==="data"&&(N=S[s])&&!N.tables)return N}o(yc,"getTablePermissions");function Ac(G,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=uu(G,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,G)){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(Ac,"ensureLoadedFromSource");function Cr(G){let E=G?.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 GE}o(Cr,"txnForContext");function bc(G,E,S){if(!G)return;let A=(G.deref?G.deref():G.value)??i.getEntry(G.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,G):C?.[F],G=null,b=L?.definition?.tableClass?.propertyResolvers}return C}let N=wr[E];return N?N(A,S,G):A[E]}o(bc,"getAttributeValue");function Pf(G,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||!G.hasEntries){let F=G.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 Rc(L,S,C,!1,D)});return Array.isArray(G)&&(F=F.filter(L=>L!==Ua.SKIP)),F.hasEntries=!0,F}return G}o(Pf,"transformToEntries");function Ic(G,E,S=server.replication?.getThisNodeId(l)){if(G<=E?.version){if(E?.version===G&&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(Ic,"precedesExistingVersion");async function uu(G,E,S){let A=E?.metadataFlags,N=E?.version,b,C;if(!i.attemptLock(G,N,()=>{clearTimeout(C);let L=i.getEntry(G);!L||!L.value||L.metadataFlags&(wn|Aa)?b(uu(G,i.getEntry(G),S)):b(L)}))return new Promise(L=>{b=L,C=setTimeout(()=>{i.unlock(G,N)},Rse)});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(G,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]!==G&&(B[t]=G)}W=!0,L({key:G,version:X,value:B})}catch(X){X.message+=` while resolving record ${G} 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:G,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:G,store:i,entry:E,nodeName:"source",commit:o((X,de)=>{if(de?.version!==N)return;let ne=oo(G,O,B);if(B){Fe.put?.(D,G,B),de&&(S.previousResidency=Me.getResidencyRecord(de.residencyId));let he,Ae=!1,Oe,ze=Oc(Me.getResidency(B,S));if(ze){if(!ze.includes(server.hostname))if(he=B,Ae=!0,Me.getResidencyById)B=void 0;else{B=null;for(let kr in r)B||(B={}),B[kr]=he[kr]}Oe=fa(ze)}xe.default.trace?.(`Writing resolved record from source with id: ${G}, timestamp: ${new Date(X).toISOString()}`),R(G,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,G),xe.default.trace?.(`Deleting resolved record from source with id: ${G}, timestamp: ${new Date(X).toISOString()}`),g||y?R(G,null,de,X,0,g&&ue||null,{user:D?.user},"delete",!!ae):jc(i,de,N))},"commit")})}),()=>{i.unlock(G,N)},ee=>{i.unlock(G,N),W&&xe.default.error?.("Error committing cache update",ee)})})}o(uu,"getFromSource");function Nc(G){if(!G||G.user?.role?.permission?.super_user)return!0;if(G.replicateTo)throw new lt.ClientError("Can not specify replication parameters without super user permissions",403);if(G.replicatedConfirmation)throw new lt.ClientError("Can not specify replication confirmation without super user permissions",403);return!0}o(Nc,"checkContextPermissions");function da(G){let E=!1;if(G&&(G-_r>1&&(E=!0),_r=G),!(He===pt&&!E)&&(pt=He,(0,El.getWorkerIndex)()===(0,El.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)*(_l.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&&gu(ae,de=>{de.size&&(X+=de.size)}),xe.default.trace?.(`shouldEvict adjusted ${ge} ${X}, ${ge*(oe-B)/X} < ${H}`),ge*(oe-B)/X<H}return!1}o(ee,"shouldEvict");try{let oe=0;for(let B of i.getRange({start:!1,snapshot:!1,versions:!0,lazy:!0})){let{key:ue,value:ae,version:ge,expiresAt:X,metadataFlags:de}=B,ne;ae===null&&!g&&ge+Tse<Date.now()?ne=jc(i,B,ge):X!=null&&ee(X,ge,de,ae)&&(ne=Me.evict(ue,ae,ge),oe++),ne&&(await F[L],F[L]=ne.catch(he=>{xe.default.error?.("Cleanup error",he)}),++L>=D&&(L=0)),await 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 wc(){V=l?.addDeleteRemovalCallback(n,i,(G,E)=>{i.remove(G,E)})}o(wc,"addDeleteRemoval");function gE(){(0,El.getWorkerIndex)()===0&&setInterval(async()=>{if(!cu){cu=!0;try{let G=j.name,E=r[G];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[G]<Date.now()&&Me.evict(A,N.value,N.version):i.ifVersion(A,N?.version,()=>E.remove(S,A))}await va()}}catch(G){xe.default.error?.("Error in evicting old records",G)}finally{cu=!1}}},Sse).unref()}o(gE,"runRecordExpirationEviction");function Oc(G){if(G!=null){if(Array.isArray(G))return G;if(typeof G=="number"){if(G>=65536)throw new Error(`Shard id ${G} must be below 65536`);let E=server.shards?.get?.(G);if(E)return xe.default.trace?.(`Shard ${G} mapped to ${E.map(S=>S.name).join(", ")}`),E.map(S=>S.name);throw new Error(`Shard ${G} is not defined`)}throw new Error(`Shard or residency list ${G} is not a valid type, must be a shard number or residency list of node hostnames`)}}o(Oc,"residencyFromFunction");function fa(G){if(G){let E=G.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],G),S)}}o(fa,"getResidencyId")}function iN(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 YH(){}function aN(e){QH=e}function Ag(e,t){let r=t?.type;if(e===null)return e;if(e===""&&r&&r!=="String"&&r!=="Any")return null;try{switch(r){case"Int":case"Long":if(e[0]==="$")return yg(parseInt(e.slice(1),36));if(e==="null")return null;if(!/^-?[0-9]+$/.test(e)&&!(e instanceof Date))throw new SyntaxError;return yg(+e);case"Float":return e==="null"?null:yg(+e);case"BigInt":return e==="null"?null:BigInt(e);case"Boolean":return e==="true"?!0:e==="false"?!1:e;case"Date":if(isNaN(e)){if(e==="null")return null;Ise.test(e)||(e+="Z");let n=new Date(e);return yg(n.getTime()),n}return new Date(+e);case void 0:case"Any":return(0,bg.autoCast)(e);default:return e}}catch(n){throw n.message=`Invalid value for attribute ${t.name}: "${e}", expecting ${r}`,n.statusCode=400,n}}function yg(e){if(isNaN(e))throw new SyntaxError;return e}function WH(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 zH(e){return e!=null}function Os(e){try{return JSON.stringify(e)}catch{return e}}function Nse(e){let t=process.pid;return e.env.readerList().slice(1).some(r=>+r.match(/\d+/)?.[0]!=t)}var Ua,sh,jH,JH,_l,lt,ih,oh,xe,gl,El,bg,oN,Ese,_se,gse,QH,Sse,Tse,GH,Rse,$H,yse,wn,Aa,Ase,VH,KH,bse,hLe,Ise,va,Sm=fe(()=>{k();Ua=require("lmdb"),sh=w(An()),jH=w(require("lodash")),JH=w(zf());ba();Jf();_l=w(ce());ZA();lt=w(Ee()),ih=w(bo()),oh=w(ti());Le();b_();xe=w(Ni());fI();xc();gl=require("ordered-binary"),El=w(st());uo();bg=w(ie());Wc();Hi();KE();nh();oN=w(require("node:fs"));Ts();l_();({sortBy:Ese}=jH.default),{validateAttribute:_se}=JH.default,gse=new Uint8Array(9);gse[8]=192;Sse=6e4,Tse=864e5;_l.initSync();GH=_l.get(U.STORAGE_PREFETCHWRITES),Rse=1e4,$H=1,yse=2,wn=1,Aa=8,Ase=Buffer.allocUnsafeSlow(8192),VH=1978,KH=100,bse={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},hLe=(0,bg.convertToMS)(_l.get(U.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;o(Ig,"makeTable");o(iN,"attributesAsObject");o(YH,"noop");o(aN,"setServerUtilities");Ise=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;o(Ag,"coerceType");o(yg,"rejectNaN");o(WH,"isDescendantId");va=o(()=>new Promise(setImmediate),"rest");o(oi,"when");o(zH,"exists");o(Os,"stringify");o(Nse,"hasOtherProcesses")});function Ng(e,t){if(!Array.isArray(e)||!Array.isArray(t))throw new Error("Euclidean distance comparison requires an array");let r=0,n=Math.max(e.length,t.length);for(let s=0;s<n;s++){let i=e[s]||0,a=t[s]||0,c=i-a;r+=c*c}return r}function wg(e,t){if(!Array.isArray(e)||!Array.isArray(t))throw new Error("Cosine distance comparison requires an array");let r=0,n=0,s=0,i=Math.max(e.length,t.length);for(let a=0;a<i;a++){let c=e[a]||0,l=t[a]||0;r+=c*l,n+=c*c,s+=l*l}return n=Math.sqrt(n),s=Math.sqrt(s),1-r/(n*s||1)}var ZH=fe(()=>{o(Ng,"euclideanDistance");o(wg,"cosineDistance")});var ek,tk,zu,ki,Wu,wse,Ose,Og,rk=fe(()=>{ZH();ek=require("msgpackr"),tk=w(Ni()),zu=w(Ee()),ki=(0,tk.loggerWithTag)("HNSW"),Wu=Symbol.for("entryPoint"),wse=Symbol.for("key"),Ose=10,Og=class{static{o(this,"HierarchicalNavigableSmallWorld")}static useObjectStore=!0;indexStore;M=16;efConstruction=100;efConstructionSearch=50;mL=1/Math.log(this.M);optimizeRouting=.5;nodesVisitedCount=0;idIncrementer;distance;constructor(t,r){this.indexStore=t,t&&(this.indexStore.encoder.useFloat32=ek.FLOAT32_OPTIONS.ALWAYS),this.distance=r?.distance==="euclidean"?Ng:wg,r&&(r.M!==void 0&&(this.M=r.M,this.mL=1/Math.log(this.M)),r.efConstruction!==void 0&&(this.efConstruction=this.efConstructionSearch=r.efConstruction),r.efConstructionSearch!==void 0&&(this.efConstructionSearch=r.efConstructionSearch),r.mL!==void 0&&(this.mL=r.mL),r.optimizeRouting!==void 0&&(this.optimizeRouting=r.optimizeRouting))}index(t,r,n){let s=typeof t=="number"?[wse,t]:t,i=this.indexStore.get(s);if(!i){if(!r)return;if(!this.idIncrementer){let f=0;for(let m of this.indexStore.getKeys({reverse:!0,limit:1,start:1/0,end:0}))typeof m=="number"&&(f=m);this.idIncrementer=new BigInt64Array([BigInt(f)+1n]),this.idIncrementer=new BigInt64Array(this.indexStore.getUserSharedBuffer("next-id",this.idIncrementer.buffer))}i=Number(Atomics.add(this.idIncrementer,0,1n)),this.indexStore.put(s,i)}let a=new Map,c,l=this.indexStore.get(Wu);if(n?c={...this.indexStore.get(i)}:c={},r){let f=l&&this.indexStore.get(l);if(f===void 0){let _=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(Wu,i);return}let m=c.level??Math.min(Math.floor(-Math.log(Math.random())*this.mL),Ose),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(Wu,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(Wu);else{if(typeof l!="number")throw new Error("Invalid nodeId: "+l);ki.debug?.("setting entry point to",l),this.indexStore.put(Wu,l)}}this.indexStore.remove(i)}let u=new Map;if(c.level!==void 0)for(let f=0;f<=c.level;f++){let m=c[f];for(let{id:h}of m){let p=d(h,this.indexStore.get(h));for(let _=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(Wu);if(t===void 0)return;let r=this.indexStore.get(t);return{id:t,...r}}searchLayer(t,r,n,s,i,a=this.distance){let c=new Set([r]),l=[{id:r,distance:this.distance(t,n.vector),node:n}],u=[...l];for(;l.length>0;){l.sort((h,p)=>h.distance-p.distance);let d=l.shift(),f=u[u.length-1].distance;if(d.distance>f)break;let m=d.node;for(let{id:h}of m[i]||[]){if(c.has(h)||h===void 0)continue;c.add(h);let p=this.indexStore.get(h);if(!p)continue;this.nodesVisitedCount++;let _=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 zu.ClientError(`Can not use "${i}" comparator with HNSW`)}if(n)throw new zu.ClientError("Can not use descending sort order with HNSW");let c;if(s==="cosine")c=wg;else if(s==="euclidean")c=Ng;else{if(s)throw new zu.ClientError("Unknown distance function");c=this.distance}if(!t)throw new zu.ClientError("A target vector must be provided for an HNSW query");if(!Array.isArray(t))throw new zu.ClientError("The target vector must be an array");let l=this.getEntryPoint();if(!l)return[];let u=l.id,d=[];for(let f=l.level;f>=0;f--)if(d=this.searchLayer(t,u,l,this.efConstructionSearch,f,c),d.length>0){let m=d[0];l=m.node,u=m.id}return a&&(d=d.filter(f=>f.distance<a)),d.map(f=>({key:f.node.primaryKey,distance:f.distance}))}checkSymmetry(t,r){if(!r)return;let n=0,s;for(;(s=r[n])&&s.length!==0;){for(let{id:i}of s){let a=this.indexStore.get(i);if(!a){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"?Ng:wg);let c=a(s.target,t);return i.set(n,c),c}return t}}});var cN,nk=fe(()=>{rk();cN={HNSW:Og}});var ft={};Ce(ft,{database:()=>ku,databaseEnvs:()=>Po,databases:()=>qe,dropDatabase:()=>_I,dropTableMeta:()=>Mse,getDatabases:()=>it,getDefaultCompression:()=>vg,getTables:()=>Cse,onRemovedDB:()=>fh,onUpdatedTable:()=>Sl,readMetaDb:()=>ah,resetDatabases:()=>ed,table:()=>et,tables:()=>cn});function Cse(){return Dg||it(),cn||{}}function it(){if(Dg)return qe;Dg=!0,Qu=new Map;let e=(0,Gt.getHdbBasePath)()&&(0,xt.join)((0,Gt.getHdbBasePath)(),Lc),t=(0,Gt.get)(U.DATABASES)||{};if(process.env.SCHEMAS_DATA_PATH&&(t.data={path:process.env.SCHEMAS_DATA_PATH}),e=process.env.STORAGE_PATH||(0,Gt.get)(U.STORAGE_PATH)||e&&((0,Zn.existsSync)(e)?e:(0,xt.join)((0,Gt.getHdbBasePath)(),IE)),!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 qe){let s=Qu.get(n);if(s){let i=qe[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 qe[n],n==="data"){for(let i in cn)delete cn[i];delete cn[Mg]}}let r=["hdb_temp","hdb_certificate","hdb_raw_analytics","hdb_session_will","hdb_job","hdb_license","hdb_info"];if((0,Gt.get)(U.ANALYTICS_REPLICATE)===!1?r.push("hdb_analytics"):(qe.system?.hdb_analytics?.enableAuditing(),qe.system?.hdb_analytics_hostname?.enableAuditing()),qe.system)for(let n of r)qe.system[n]&&(qe.system[n].replicate=!1);return Qu=null,qe}function ed(){Dg=!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=qe[t.databaseName];for(let n in r)if(r[n].primaryStore.path===e){delete qe[t.databaseName],lh.forEach(i=>i(t.databaseName));break}}return qe}function ah(e,t,r=dN,n,s){let i=new lN.default(e,!1);try{let a=Po.get(e);a?a.needsDeletion=!1:(a=(0,Xu.open)(i),Po.set(e,a));let c=new Zu.default(!1),l=a.dbisDb||(a.dbisDb=a.openDB(Cg.INTERNAL_DBIS_NAME,c)),u=a.auditStore;u||(n?(0,Zn.existsSync)(n)&&(i.path=n,u=(0,Xu.open)(i),u.isLegacy=!0):u=f_(a));let d=ck(r),f=d[Mg],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,Gt.get)(U.LOGGING_AUDITLOG),te=g.trackDeletes,x=g.expiration,$=g.eviction,j=g.sealed,V=g.splitSegments,le=g.replicate;if(y)T=y.indices,R=y.attributes,y.schemaVersion++;else{I=g.tableId,I?I>=(l.get(ju)||0)&&(l.putSync(ju,I+1),yr.info(`Updating next table id (it was out of sync) to ${I+1} for ${h}`)):(g.tableId=I=l.get(ju),I||(I=1),yr.debug("Table {tableName} missing an id, assigning {tableId}"),l.putSync(ju,I+1),l.putSync(g.key,g));let se=new Zu.default(!g.is_hash_attribute,g.is_hash_attribute);if(se.compression=g.compression,se.compression){let _e=(0,Gt.get)(U.STORAGE_COMPRESSION_THRESHOLD)||ak;se.compression.threshold=_e}P=T_(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=uk(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=lk(d,h,Ig({primaryStore:P,auditStore:u,audit:Y,sealed:j,splitSegments:V,replicate:le,expirationMS:x&&x*1e3,evictionMS:$&&$*1e3,trackDeletes:te,tableName:h,tableId:I,primaryKey:g.name,databasePath:s?r+"/"+h:r,databaseName:r,indices:T,attributes:_,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 ck(e){let t=qe[e];if(t||(e==="data"?t=qe[e]=cn:e==="system"?Object.defineProperty(qe,"system",{value:t=Object.create(null),configurable:!0}):t=qe[e]=Object.create(null)),Qu&&!Qu.has(e)){let r=new Set;t[Mg]=r,Qu.set(e,r)}return t}function lk(e,t,r){return e[t]=r,r}function ku({database:e,table:t}){e||(e=dN),it();let r=ck(e),n=(0,xt.join)((0,Gt.getHdbBasePath)(),Lc),s=(0,Gt.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,Gt.get)(U.STORAGE_PATH)||((0,Zn.existsSync)(n)?n:(0,xt.join)((0,Gt.getHdbBasePath)(),IE));let a=(0,xt.join)(n,(i?t:e)+".mdb"),c=Po.get(a);if(!c||c.status==="closed"){let l=new lN.default(a,!1);c=(0,Xu.open)(l),Po.set(a,c)}return c.auditStore||(c.auditStore=f_(c)),c}async function _I(e){if(!qe[e])throw new Error("Schema does not exist");let t=qe[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=ku({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[Mg]}delete qe[e],lh.forEach(n=>n(e)),await AA(r)}function uk(e,t,r){let n=r.is_hash_attribute||r.indexed.type&&cN[r.indexed.type]?.useObjectStore,s=new Zu.default(!n,n),i=t.openDB(e,s);if(r.indexed.type){let a=cN[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=dN);let p=ku({database:r,table:t}),_=qe[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 Zu.default(!1);for(let V of a)V.attribute&&!V.name?(V.name=V.attribute,V.indexed=!0):V.attribute=V.name,V.expiresAt&&(V.indexed=!0);let P,Y;if(g){if(y=g.primaryKey,g.primaryStore.rootStore.status==="closed")throw new Error(`Can not use a closed data store from ${t} class`);u==null&&(u=g.splitSegments),g.attributes.splice(0,g.attributes.length,...a)}else{let V=p.auditStore;T=a.find(_e=>_e.isPrimaryKey)||{},y=T.name,T.is_hash_attribute=T.isPrimaryKey=!0,T.schemaDefined=m,T.compression=vg(),f&&(T.trackDeletes=!0),c=T.audit=typeof c=="boolean"?c:(0,Gt.get)(U.LOGGING_AUDITLOG),n&&(T.expiration=n),s&&(T.eviction=s),u??=!1,T.splitSegments=u,typeof l=="boolean"&&(T.sealed=l),typeof d=="boolean"&&(T.replicate=d),h&&(T.origins?T.origins.includes(h)||T.origins.push(h):T.origins=[h]),yr.trace(`${t} table loading, opening primary store`);let le=new Zu.default(!1,!0);le.compression=T.compression;let re=t+"/";if(R=p.dbisDb=p.openDB(Cg.INTERNAL_DBIS_NAME,I),j(),R.get(re))return Y&&Y(),ed(),et(e);let se=T_(p.openDB(re,le),p);p.databaseName=r,se.tableId=R.get(ju),yr.trace(`Assigning new table id ${se.tableId} for ${t}`),se.tableId||(se.tableId=1),R.put(ju,se.tableId+1),T.tableId=se.tableId,g=lk(_,t,Ig({primaryStore:se,auditStore:V,audit:c,sealed:l,splitSegments:u,replicate:d,trackDeletes:f,expirationMS:n&&n*1e3,evictionMS:s&&s*1e3,primaryKey:y,tableName:t,tableId:se.tableId,databasePath:r,databaseName:r,indices:{},attributes:a,schemaDefined:m,dbisDB:R})),g.schemaVersion=1,P=!0,R.put(re,T)}let te=g.indices;R=R||(p.dbisDb=p.openDB(Cg.INTERNAL_DBIS_NAME,I)),g.dbisDB=R;let x=[];for(let{key:V,value:le}of R.getRange({start:!0})){let[re,se]=V.toString().split("/");if(se===""&&(se=le.name),se){if(re!==t)continue}else continue;let _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=uk(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=Dse(g,$,x):P&&Pg.signalSchemaChange(new Lg.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 Dse(e,t,r){try{yr.info(`Indexing ${e.tableName} attributes`,t);let n=e.schemaVersion;await Pg.signalSchemaChange(new Lg.SchemaEventMsg(process.pid,"schema-change",e.databaseName,e.tableName));let s;for(let u of r)s=u.drop();let i,a={},c=0,l=t.length;if(await new Promise(u=>setImmediate(u)),l>0){let u;for(let f of t)(0,Xu.compareKeys)(f.lastIndexedKey,u)<0&&(u=f.lastIndexedKey),f.lastIndexedKey==null&&f.dbi.clearAsync();let d=0;for(let{key:f,value:m,version:h}of e.primaryStore.getRange({start:u,lazy:l<4,versions:!0,snapshot:!1}))if(m){if(d++,s=e.primaryStore.ifVersion(f,h,()=>{for(let p=0;p<l;p++){let _=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,sk.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!==ok.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>Pse?await s:d>Lse&&await new Promise(p=>setImmediate(p))}for(let f of t)delete f.lastIndexedKey,delete f.indexingPID,f.dbi.isIndexing=!1,s=e.dbisDB.put(f.key,f)}await s,await Pg.signalSchemaChange(new Lg.SchemaEventMsg(process.pid,"indexing-finished",e.databaseName,e.tableName)),yr.info(`Finished indexing ${e.tableName} attributes`,t)}catch(n){yr.error("Error in indexing",n)}}function Mse({table:e,database:t}){let r=ku({database:t,table:e}),n=[],s=r.dbisDb;for(let i of s.getKeys({start:e+"/",end:e+"0"}))n.push(s.remove(i));return Promise.all(n)}function Sl(e){return 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 vg(){let e=(0,Gt.get)(U.STORAGE_COMPRESSION),t=(0,Gt.get)(U.STORAGE_COMPRESSION_DICTIONARY),r=(0,Gt.get)(U.STORAGE_COMPRESSION_THRESHOLD)||ak,n={startingOffset:32};return t&&(n.dictionary=uh.readFileSync(t)),r&&(n.threshold=r),e&&n}var Gt,Cg,Xu,xt,Zn,Ju,Zu,lN,uh,uN,sk,Pg,Lg,dh,ik,ok,yr,dN,Mg,ak,cn,qe,ju,ch,lh,Dg,Po,Qu,Pse,Lse,Le=fe(()=>{Gt=w(ce()),Cg=w(kt()),Xu=require("lmdb"),xt=require("path"),Zn=require("fs"),Ju=w(At());Sm();Zu=w(Tm()),lN=w(Rm());k();uh=w(require("fs-extra")),uN=w(zs()),sk=w(An()),Pg=w(bo()),Lg=w(ti()),dh=require("worker_threads"),ik=w(z()),ok=w(st());uo();Wc();Ts();nk();yr=(0,ik.forComponent)("storage"),dN="data",Mg=Symbol("defined-tables"),ak=((0,Gt.get)(U.STORAGE_PAGESIZE)||4096)-60;(0,Gt.initSync)();cn=Object.create(null),qe=Object.create(null);(0,uN._assignPackageExport)("databases",qe);(0,uN._assignPackageExport)("tables",cn);ju=Symbol.for("next-table-id"),ch=[],lh=[],Po=new Map;o(Cse,"getTables");o(it,"getDatabases");o(ed,"resetDatabases");o(ah,"readMetaDb");o(ck,"ensureDB");o(lk,"setTable");o(ku,"database");o(_I,"dropDatabase");o(uk,"openIndex");o(et,"table");Pse=1e3,Lse=10;o(Dse,"runIndexing");o(Mse,"dropTableMeta");o(Sl,"onUpdatedTable");o(fh,"onRemovedDB");o(vg,"getDefaultCompression")});var hN={};Ce(hN,{loadGQLSchema:()=>xse,start:()=>mN,startOnMainThread:()=>Use});function mN({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):vse.includes(y.type)||(0,fk.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,fN.dirname)(n),y.tableClass):i.set((0,fN.dirname)(n)+"/"+(y.export.name||y.type),y.tableClass,y.export));function g(y,T,R){return new dk.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 fN,dk,fk,vse,Use,xse,mk=fe(()=>{fN=require("path"),dk=require("node:vm");Le();fk=w(st()),vse=["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(mN,"start");Use=mN,xse=mN({ensureTable:et}).handleFile});var EN={};Ce(EN,{start:()=>Kse});function Bse(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 hk(e){if(typeof e!="object"||e===null)throw new qi("Request body must be an object.");if(!("query"in e))throw new qi("Request body must contain a `query` field.");if(typeof e.query!="string")throw new qi("Request body `query` field must be a string.");if("variables"in e&&(typeof e.variables!="object"||e.variables===null))throw new qi("Request body `variables` field must be an object.");if("operationName"in e&&typeof e.operationName!="string")throw new qi("Request body `operationName` field must be a string.")}function pN(e){return parseInt(e.value,10)}function Ek(e){return parseFloat(e.value)}function _k(e,t,r){let n=r.get(e.name.value);return gk(n)?Sk(n,t):{attribute:t,value:n}}function gk(e){return typeof e=="object"&&e!=null&&!Array.isArray(e)}function Sk(e,t){return t=typeof t=="string"?[t]:t,Object.entries(e).flatMap(([r,n])=>(t=[...t,r],gk(n)?Sk(n,t):{attribute:t,value:n}))}function Fse(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:pN(e.value)};case Be.Kind.FLOAT:return{attribute:t,value:Ek(e.value)};case Be.Kind.BOOLEAN:case Be.Kind.STRING:return{attribute:t,value:e.value.value};case Be.Kind.VARIABLE:return _k(e.value,t,r);case Be.Kind.OBJECT:return Tk(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 Tk(e,t,r){return e.fields.flatMap(n=>Fse(n,t,r))}function Hse(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:pN(e.value)};case Be.Kind.FLOAT:return{attribute:e.name.value,value:Ek(e.value)};case Be.Kind.BOOLEAN:case Be.Kind.STRING:return{attribute:e.name.value,value:e.value.value};case Be.Kind.VARIABLE:return _k(e.value,e.name.value,t);case Be.Kind.OBJECT:return Tk(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 kse(e,t){return e.flatMap(r=>Hse(r,t))}function Ug(e,t){return e.selections.flatMap(r=>{switch(r.kind){case Be.Kind.FIELD:return r;case Be.Kind.FRAGMENT_SPREAD:{let n=r.name.value,s=t.get(n);if(s==null)throw new Ur(`Fragment \`${n}\` not found.`);return Ug(s.selectionSet,t)}case Be.Kind.INLINE_FRAGMENT:return Ug(r.selectionSet,t)}})}function Rk(e,t){return Ug(e,t).map(r=>r.selectionSet?.selections.length>0?{name:r.name.value,select:Rk(r.selectionSet,t)}:r.name.value)}async function qse(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:Rk(e.selectionSet,r),conditions:kse(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 yk(e){switch(e.kind){case Be.Kind.NULL:return null;case Be.Kind.INT:return pN(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]:yk(r.value),...t}),{});case Be.Kind.LIST:case Be.Kind.ENUM:default:throw new Ur(`Value type, ${e.kind}, is not supported.`)}}function Gse(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=yk(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 $se(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=Gse(e.variableDefinitions,t),i=await Promise.all(Ug(e.selectionSet,r).map(c=>qse(c,s,r,n))),a={data:{}};for(let[c,l]of i)a.data[c]=l;return a}async function pk({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(Bse(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 $se(c,t,a,n);return{status:200,headers:{"Content-Type":"application/graphql-response+json; charset=utf-8"},body:JSON.stringify(l)}}async function Vse(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 hk(r),pk(r,e)}case"POST":{let r=await ho(e.headers.get("content-type"),!0)(e._nodeRequest);return hk(r),pk(r,e)}default:throw new qi("Method Not Allowed",405,{Allow:"GET, POST"})}}function Kse(e){e.server.http(async(t,r)=>{if(!t.url.startsWith("/graphql"))return r(t);try{return await Vse(t)}catch(n){logger.error(n);let s=t.headers.get("accept")??"application/graphql-response+json";switch(s){case"application/json":{if(n instanceof qi)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json",...n.headers}};if(n instanceof Be.GraphQLError)return{status:200,body:JSON.stringify({errors:[n]}),headers:{"Content-Type":"application/json"}};if(n instanceof Ur)return{status:200,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json"}};if(n instanceof Error)return{status:500,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json"}};break}default:logger.info(`Unsupported accept header, ${s}, defaulting to application/graphql-response+json`);case"application/graphql-response+json":{if(n instanceof qi)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json",...n.headers}};if(n instanceof Be.GraphQLError)return{status:400,body:JSON.stringify({errors:[n]}),headers:{"Content-Type":"application/graphql-response+json"}};if(n instanceof Ur)return{status:400,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json"}};if(n instanceof Error)return{status:500,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json"}};break}}throw n}},{port:e.port,securePort:e.securePort})}var Be,Ur,qi,Ak=fe(()=>{Be=w(require("graphql"));po();Lu();o(Bse,"assertExecutableDefinitionNode");o(hk,"assertRequestParams");o(pN,"processIntValueNode");o(Ek,"processFloatValueNode");o(_k,"processVariableNode");o(gk,"isObject");o(Sk,"transformObjectIntoQueryCondition");o(Fse,"processObjectFieldNode");o(Tk,"processObjectValueNode");o(Hse,"processArgumentNode");o(kse,"buildConditionsQuery");o(Ug,"fillInFragments");o(Rk,"buildSelectQuery");o(qse,"processFieldNode");o(yk,"processConstValueNode");o(Gse,"resolveVariables");o($se,"executeOperation");o(pk,"resolver");Ur=class extends Error{static{o(this,"GraphQLQueryingError")}},qi=class extends Error{static{o(this,"HTTPError")}statusCode;headers;constructor(t,r=400,n={}){super(t),this.statusCode=r,this.headers=n}};o(Vse,"graphqlQueryingHandler");o(Kse,"start")});var Ck=M((BLe,Ok)=>{var td=require("validate.js"),Ik=at(),rd=(k(),v(K)),{handleHDBError:Yse,hdbErrors:Wse}=Ee(),{HDB_ERROR_MSGS:Xt,HTTP_STATUS_CODES:zse}=Wse,_N=o(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),jse={STRUCTURE_USER:"structure_user"},bk=Object.values(rd.ROLE_TYPES_ENUM),Jse="attribute_permissions",Qse="attribute_name",{PERMS_CRUD_ENUM:nd}=rd,Xse=[Jse,...Object.values(nd)],Nk=[nd.READ,nd.INSERT,nd.UPDATE],Zse=[Qse,...Nk];function eie(e){let t=_N();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,wk(e,t)}o(eie,"addRoleValidation");function tie(e){let t=_N();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,wk(e,t)}o(tie,"alterRoleValidation");function rie(e){let t=_N();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,Ik.validateObject(e,t)}o(rie,"dropRoleValidation");var nie=["operation","role","id","permission","hdb_user","access"];function wk(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let a=0,c=n.length;a<c;a++)nie.includes(n[a])||s.push(n[a]);s.length>0&&lr(Xt.INVALID_ROLE_JSON_KEYS(s),r);let i=Ik.validateObject(e,t);if(i&&i.message.split(",").forEach(a=>{lr(a,r)}),e.permission){let a=sie(e);a&&lr(a,r),bk.forEach(c=>{e.permission[c]&&!td.isBoolean(e.permission[c])&&lr(Xt.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let a in e.permission)if(bk.indexOf(a)<0){if(a===jse.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]||lr(Xt.SCHEMA_NOT_FOUND(f),r)}continue}lr(Xt.STRUCTURE_USER_ROLE_TYPE_ERROR(a),r);continue}let c=e.permission[a];if(!a||!global.hdb_schema[a]){lr(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]){lr(Xt.TABLE_NOT_FOUND(a,l),r);continue}if(Object.keys(u).forEach(d=>{Xse.includes(d)||lr(Xt.INVALID_PERM_KEY(d),r,a,l)}),Object.values(nd).forEach(d=>{td.isDefined(u[d])?td.isBoolean(u[d])||lr(Xt.TABLE_PERM_NOT_BOOLEAN(d),r,a,l):lr(Xt.TABLE_PERM_MISSING(d),r,a,l)}),u.attribute_permissions===void 0){lr(Xt.ATTR_PERMS_ARRAY_MISSING,r,a,l);continue}else if(!(Array.isArray(u.attribute_permissions)||u.attribute_permissions===null)){lr(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(_=>{!Zse.includes(_)&&_!==nd.DELETE&&lr(Xt.INVALID_ATTR_PERM_KEY(_),r,a,l)}),!td.isDefined(h.attribute_name)){lr(Xt.ATTR_PERM_MISSING_NAME,r,a,l);continue}let p=h.attribute_name;if(!d.includes(p)){lr(Xt.INVALID_ATTRIBUTE_IN_PERMS(p),r,a,l);continue}Nk.forEach(_=>{td.isDefined(h[_])?td.isBoolean(h[_])||lr(Xt.ATTR_PERM_NOT_BOOLEAN(_,p),r,a,l):lr(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}`;lr(Xt.MISMATCHED_TABLE_ATTR_PERMS(m),r,a,l)}}}}return iie(r)}o(wk,"customValidate");Ok.exports={addRoleValidation:eie,alterRoleValidation:tie,dropRoleValidation:rie};function sie(e){let{operation:t,permission:r}=e;if(t===rd.OPERATIONS_ENUM.ADD_ROLE||t===rd.OPERATIONS_ENUM.ALTER_ROLE){let n=r.super_user===!0,s=r.cluster_user===!0;if(Object.keys(r).length>1&&(n||s)){if(s&&n)return Xt.SU_CU_ROLE_COMBINED_ERROR;{let a=r.super_user?rd.ROLE_TYPES_ENUM.SUPER_USER:rd.ROLE_TYPES_ENUM.CLUSTER_USER;return Xt.SU_CU_ROLE_NO_PERMS_ALLOWED(a)}}}return null}o(sie,"validateNoSUPerms");function iie(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 Yse(new Error,n,zse.BAD_REQUEST)}else return null}o(iie,"generateRolePermResponse");function lr(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(lr,"addPermError")});var hh=M((kLe,Mk)=>{"use strict";var Pk=Mn(),Lk=on(),oie=fl(),SN=Ck(),TN=bo(),HLe=require("uuid").v4,aie=require("util"),xg=(k(),v(K)),cie=ie(),RN=Lk.searchByValue,lie=Lk.searchByHash,uie=aie.promisify(oie.delete),die=ri(),fie=Fu(),{hdbErrors:mie,handleHDBError:Tl}=Ee(),{HDB_ERROR_MSGS:Dk,HTTP_STATUS_CODES:mh}=mie,{UserEventMsg:yN}=ti();Mk.exports={addRole:hie,alterRole:pie,dropRole:Eie,listRoles:_ie};function gN(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(gN,"scrubRoleDetails");async function hie(e){let t=SN.addRoleValidation(e);if(t)throw t;e=gN(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 RN(r)||[])}catch(i){throw Tl(i)}if(n&&n.length>0)throw Tl(new Error,Dk.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 Pk.insert(s),TN.signalUserChange(new yN(process.pid)),e=gN(e),e}o(hie,"addRole");async function pie(e){let t=SN.alterRoleValidation(e);if(t)throw t;e=gN(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await Pk.update(r)}catch(s){throw Tl(s)}if(n&&n?.message==="updated 0 of 1 records")throw Tl(new Error,"Invalid role id",mh.BAD_REQUEST,void 0,void 0,!0);return await TN.signalUserChange(new yN(process.pid)),e}o(pie,"alterRole");async function Eie(e){let t=SN.dropRoleValidation(e);if(t)throw Tl(new Error,t,mh.BAD_REQUEST,void 0,void 0,!0);let r=new fie(xg.SYSTEM_SCHEMA_NAME,xg.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await lie(r));if(n.length===0)throw Tl(new Error,Dk.ROLE_NOT_FOUND,mh.NOT_FOUND,void 0,void 0,!0);let s=new die(xg.SYSTEM_SCHEMA_NAME,xg.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await RN(s)),a=!1;if(cie.isEmptyOrZeroLength(i)===!1){for(let l=0;l<i.length;l++)if(i[l].active===!0){a=!0;break}}if(a===!0)throw Tl(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,mh.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await uie(c),TN.signalUserChange(new yN(process.pid)),`${n[0].role} successfully deleted`}o(Eie,"dropRole");async function _ie(){return RN({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}o(_ie,"listRoles")});var AN={};Ce(AN,{start:()=>xk,startOnMainThread:()=>Tie});function xk({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r){let n=(0,vk.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(gie.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 Sie(i)}}}async function Sie(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,Uk.isEqual)(i,e)?void 0:(e.id=r.id,(0,Bg.alterRole)(e))}return(0,Bg.addRole)(e)}var Bg,vk,Uk,gie,Tie,Bk=fe(()=>{Le();Bg=w(hh()),vk=require("yaml"),Uk=require("lodash"),gie=["super_user","cluster_user","structure_user"];o(xk,"start");o(Sie,"ensureRole");Tie=xk});async function Fg(e){let t=(0,kk.pathToFileURL)(e).toString();if(Rie)return ph||(ph=yie(bie)),(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 yie(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:Aie,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,Hk.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=qe}};let n=await(0,Fk.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)},"importHook")}),ph}function Aie(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 bie(){return{Resource:Dr,tables:cn}}var Fk,Hk,kk,Rie,ph,bN=fe(()=>{ba();Le();Fk=require("fs/promises"),Hk=require("path"),kk=require("url"),Rie=!1;o(Fg,"secureImport");o(yie,"getCompartment");o(Aie,"secureOnlyFetch");o(bie,"getGlobalVars")});var IN={};Ce(IN,{handleApplication:()=>Iie,suppressHandleApplicationWarning:()=>Nie});function qk(e){return typeof e=="function"&&("get"in e||"put"in e||"post"in e||"delete"in e)}async function Iie(e){e.handleEntry(t=>{if(t.entryType!=="file"){e.logger.warn(`jsResource plugin cannot handle entry type ${t.entryType}. Modify the 'files' option in ${e.configFilePath} to only include files.`);return}if(t.eventType!=="add"){e.requestRestart();return}Fg(t.absolutePath).then(r=>{let n=(0,Hg.dirname)(t.urlPath);qk(r.default)&&(e.resources.set(n,r.default),e.logger.debug(`Registered root resource: ${n}`)),Gk(e,r,n)}).catch(r=>{e.logger.error(`Failed to load resource module ${t.absolutePath}: ${r}`),e.requestRestart()})})}function Gk(e,t,r){for(let n in t){let s=t[n],i=(0,Hg.join)(r,n);qk(s)?(e.resources.set(i,s),e.logger.debug(`Registered resource: ${i}`)):typeof s=="object"&&Gk(e,s,i)}}var Hg,Nie,$k=fe(()=>{bN();Hg=require("path");o(qk,"isResource");o(Iie,"handleApplication");o(Gk,"recurseForResources");Nie=!0});var wN={};Ce(wN,{start:()=>wie});function wie({resources:e}){e.set("login",NN),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var NN,Vk=fe(()=>{ba();o(wie,"start");NN=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 jk(e){let t={openapi:Oie,info:{title:"HarperDB HTTP REST interface",version:zk.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 LN(ON[j.type],j.type)}),t.components.schemas[x.type]=new Wk($)}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 LN(ON[P.type],P.type)}:R==="Any"||R=="ID"?u[I]={format:R}:u[I]=new LN(ON[R],R)}d.push(new DN(I,"query",u[I]))}let f=Object.keys(u),m=new DN(c,"path",{format:"ID"});m.required=!0,m.description="primary key of record";let h=new DN("property","path",{enum:f});h.required=!0,t.components.schemas[i]=new Wk(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 Cie(i,r,"create a new record auto-assigning a primary key")),g&&(t.paths[T]||(t.paths[T]={}),t.paths[T].get=new CN(d,r,{200:new PN({$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 Yk(d,r,"delete all the records that match the provided query",{204:new Kk})),T="/"+s+"/{"+c+"}",g&&(t.paths[T]={},t.paths[T].get=new CN([m],r,{200:new PN({$ref:xa+i})},"retrieve a record by its primary key")),_&&(t.paths[T]||(t.paths[T]={}),t.paths[T].put=new Pie([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 Yk([m],r,"delete a record with the given primary key",{204:new Kk})),g&&h.schema.enum.length>0&&(T="/"+s+"/{"+c+"}.{property}",t.paths[T]={},t.paths[T].get=new CN([m,h],r,{200:new PN({enum:f})},"used to retrieve the specified property of the specified record"))}return t}function Cie(e,t,r){this.description=r,this.requestBody={content:{"application/json":{schema:{$ref:xa+e}}}},this.security=t,this.responses={200:{description:MN,headers:{Location:{description:"primary key of new record",schema:{type:"string",format:"ID"}}},content:{"application/json":{schema:{type:"string",format:"ID"}}}}}}function CN(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.responses=r}function PN(e){this.description=MN,this.content={"application/json":{schema:e}}}function Kk(){this.description="successfully processed request, no content returned to client"}function Pie(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:MN}}}function Yk(e,t,r,n){this.description=r,this.parameters=e,this.security=t,this.responses=n}function Wk(e){this.type="object",this.properties=e}function LN(e,t){this.type=e,this.format=t}function DN(e,t,r){this.name=e,this.in=t,this.schema=r}var zk,Oie,ON,xa,MN,Jk=fe(()=>{zk=w(Rt()),Oie="3.0.3",ON={Int:"integer",Float:"number",Long:"integer",String:"string",Boolean:"boolean",Date:"string",Bytes:"string",BigInt:"integer",array:"array"},xa="#/components/schemas/",MN="successful operation";o(jk,"generateJsonApi");o(Cie,"Post");o(CN,"Get");o(PN,"Response200");o(Kk,"Response204");o(Pie,"Put");o(Yk,"Delete");o(Wk,"ResourceSchema");o(LN,"Type");o(DN,"Parameter")});var Xk={};Ce(Xk,{Request:()=>Ba,createReuseportFd:()=>kg});var Qk,Ba,vN,UN,kg,Eh=fe(()=>{Qk=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 UN(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 vN(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)}},vN=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)}},UN=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,Qk.platform)()!="win32"&&(kg=require("node-unix-socket").createReuseportFd)});var Gg={};Ce(Gg,{parseHeaderValue:()=>BN,start:()=>Mie});async function Die(e,t){let r=e.headers.asObject,n=r.accept==="text/event-stream",s=n?"CONNECT":e.method;e.search&&A_(e);let i=new ws;try{e.responseHeaders=i;let a=e.url.slice(1),c,l;if(a!==Zk){let g=qg.getMatch(a,n?"sse":"rest");if(!g)return t(e);e.handlerPath=g.path,c=new Xs(g.relativeURL),c.async=!0,l=g.Resource}if(l?.isCaching){let g=r["cache-control"];if(g){let y=BN(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=BN(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 sd.ClientError(g,400)}if(e.authorize=!0,a===Zk&&s==="GET"){if(e?.user?.role?.permission?.super_user)return jk(qg);throw new sd.ServerError("Forbidden",403)}switch(c.checkPermission=e.user?.role?.permission??{},s){case"GET":case"HEAD":return l.get(c,e);case"POST":return l.post(c,e.data,e);case"PUT":return l.put(c,e.data,e);case"DELETE":return l.delete(c,e);case"PATCH":return l.patch(c,e.data,e);case"OPTIONS":i.setIfNone("Allow","GET, HEAD, POST, PUT, DELETE, PATCH, OPTIONS, TRACE, QUERY, COPY, MOVE");return;case"CONNECT":return l.connect(c,null,e);case"TRACE":return"HarperDB is the terminating server";case"QUERY":return l.query(c,e.data,e);case"COPY":return l.copy(c,r.destination,e);case"MOVE":return l.move(c,r.destination,e);case"BREW":throw new sd.ClientError("HarperDB is short and stout and can't brew coffee",418);default:throw new sd.ServerError(`Method ${s} is not recognized`,501)}}),m=200,h;if(f==null)m=s==="GET"||s==="HEAD"?404:204,xN.lastModified&&e.lastModified&&i.setIfNone("Last-Modified",new Date(e.lastModified).toUTCString());else if(f.status>0&&f.headers){let g=qH(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){Lie[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),xN.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:rq(a),e,c),c}}function Mie(e){xN=e,!eq&&(eq=!0,e.includeExpensiveRecordCountEstimates&&(Ba.prototype.includeExpensiveRecordCountEstimates=!0),qg=e.resources,e.server.http(async(t,r)=>{if(!t.isWebSocket)return Die(t,r)},e),e.webSocket!==!1&&e.server.ws(async(t,r,n)=>{_h++;let s=new Vn;tq||(tq=!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=qg.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 Xs(u.relativeURL);d.checkPermission=r.user?.role?.permission??{};let f=u.Resource;c=(await vt(r,()=>f.connect(d,s,r)))[Symbol.asyncIterator]();let h;for(;!(h=await c.next()).done;){let p=await 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(vie[l.statusCode]||1011,rq(l))}t.close()},e))}function BN(e){return e.trim().split(",").map(t=>{let r,n=t.trim().split(";"),s;for(;s=n.pop();)if(s.includes("=")){let[i,a]=s.trim().split("=");i=i.trim(),a&&(a=a.trim()),r={name:i.toLowerCase(),value:a,next:r}}else r={name:s.toLowerCase(),next:r};return r})}var ai,sd,rq,Yr,Lie,xN,Zk,eq,qg,tq,_h,vie,nq=fe(()=>{po();Hi();ai=w(z()),sd=w(Ee());b_();Eu();xc();nh();Jk();Eh();I_();({errorToString:rq}=ai),Yr=new Uint8Array(8),Lie=new Float64Array(Yr.buffer,0,1),xN={},Zk="openapi";o(Die,"http");_h=0;o(Mie,"start");vie={401:3e3,403:3003};o(BN,"parseHeaderValue")});var FN=M((fDe,iq)=>{var{recordAction:$g,recordActionBinary:sq}=(Hi(),v(Rg)),Uie=require("fastify-plugin"),xie=200;iq.exports=Uie(function(e,t,r){e.addHook("onResponse",async(n,s)=>{let i=s.elapsedTime}),e.addHook("onSend",async(n,s,i)=>{let a=s.elapsedTime,c=performance.now(),l=s.request.routeOptions,u,d,f;l.config?.isOperation?(u=n.body?.operation,d="operation"):(u=l.url,d="fastify-route",f=l.method),$g(a,"duration",u,f,d),sq(s.raw.statusCode<400,"success",u,f,d),sq(1,"response_"+s.raw.statusCode,u,f,d);let m=xie;i?.pipe?(i.on("data",g=>{m+=g.length}),i.on("end",()=>{$g(performance.now()-c,"transfer",u,f,d),$g(m,"bytes-sent",u,f,d)})):(m+=i?.length||0,$g(m,"bytes-sent",u,f,d));let h=a.toFixed(3),p=s.getHeader("Server-Timing"),_=`db;dur=${h}`;s.header("Server-Timing",p?`${p}, ${_}`:_)}),r()},{name:"hdb-request-time"})});var aq=M((mDe,oq)=>{var Bie=at(),Fie={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};oq.exports=function(e){return Bie.validateObject(e,Fie)}});var Vg=M((hDe,cq)=>{"use strict";var Hie=(k(),v(K)).OPERATIONS_ENUM,HN=class{static{o(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=Hie.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};cq.exports=HN});var Th={};Ce(Th,{createTokens:()=>GN,getJWTRSAKeys:()=>jg,refreshOperationToken:()=>$N,validateOperationToken:()=>VN,validateRefreshToken:()=>Jg});async function jg(){if(Kg)return Kg;try{let e=gh.default.join(Sh.default.getHdbBasePath(),Fy),t=await Yg.default.readFile(gh.default.join(e,Uf.JWT_PASSPHRASE_NAME),"utf8"),r=await Yg.default.readFile(gh.default.join(e,Uf.JWT_PRIVATE_KEY_NAME),"utf8");return Kg={publicKey:await Yg.default.readFile(gh.default.join(e,Uf.JWT_PUBLIC_KEY_NAME),"utf8"),privateKey:r,passphrase:t},Kg}catch(e){throw zg.default.error(e),new ci.ClientError(od.NO_ENCRYPTION_KEYS,id.INTERNAL_SERVER_ERROR)}}async function GN(e){let t=(0,kN.validateBySchema)(e,Gi.default.object({username:Gi.default.string().optional(),password:Gi.default.string().optional(),role:Gi.default.string().optional(),expires_in:Gi.default.alternatives(Gi.default.string(),Gi.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,qN.findAndValidateUser)(e.username,e.password,f)}catch(f){throw zg.default.error(f),new ci.ClientError(od.INVALID_CREDENTIALS,id.UNAUTHORIZED)}if(!r)throw new ci.ClientError(od.INVALID_CREDENTIALS,id.UNAUTHORIZED);let n=!1,s=!1;r.role?.permission&&(n=r.role.permission.super_user===!0,s=r.role.permission.cluster_user===!0);let i={username:e.username,super_user:n,cluster_user:s};e.role&&(i.role=e.role);let a=await jg(),c=await ad.default.sign(i,{key:a.privateKey,passphrase:a.passphrase},{expiresIn:e.expires_in??mq,algorithm:Wg,subject:cd.OPERATION}),l=await ad.default.sign(i,{key:a.privateKey,passphrase:a.passphrase},{expiresIn:kie,algorithm:Wg,subject:cd.REFRESH}),u=xI(l,Mr.SHA256);if((await(0,lq.update)(new uq.default(vf,du.USER_TABLE_NAME,[{username:e.username,refresh_token:u}]))).skipped_hashes.length>0)throw new ci.ClientError(od.REFRESH_TOKEN_SAVE_FAILED,id.INTERNAL_SERVER_ERROR);return dq.default.signalUserChange(new fq.UserEventMsg(process.pid)),{operation_token:c,refresh_token:l}}async function $N(e){let t=(0,kN.validateBySchema)(e,Gi.default.object({refresh_token:Gi.default.string().required()}).required());if(t)throw new ci.ClientError(t.message);let{refresh_token:r}=e;await Jg(r);let n=await jg(),s=await ad.default.decode(r);return{operation_token:await ad.default.sign({username:s.username,super_user:s.super_user,cluster_user:s.cluster_user},{key:n.privateKey,passphrase:n.passphrase},{expiresIn:mq,algorithm:Wg,subject:cd.OPERATION})}}async function VN(e){return hq(e,cd.OPERATION)}async function Jg(e){return hq(e,cd.REFRESH)}async function hq(e,t){try{let r=await jg(),n=await ad.default.verify(e,r.publicKey,{algorithms:Wg,subject:t});if(n.role)throw new Error("Invalid token");let s=await(0,qN.findAndValidateUser)(n.username,void 0,!1);if(t===cd.REFRESH&&!BI(s.refresh_token,e))throw new Error("Invalid token");return s}catch(r){throw zg.default.warn(r),r?.name==="TokenExpiredError"?new ci.ClientError(od.TOKEN_EXPIRED,id.FORBIDDEN):new ci.ClientError(od.INVALID_TOKEN,id.UNAUTHORIZED)}}var ad,Yg,gh,Gi,kN,ci,zg,qN,lq,uq,dq,fq,Sh,id,od,mq,kie,Wg,cd,Kg,ld=fe(()=>{ad=w(require("jsonwebtoken")),Yg=w(require("fs-extra")),gh=w(require("node:path")),Gi=w(require("joi")),kN=w(at());k();ci=w(Ee()),zg=w(z());dg();qN=w(vn()),lq=w(Mn()),uq=w(Vg()),dq=w(bo()),fq=w(ti()),Sh=w(ce()),{HTTP_STATUS_CODES:id,AUTHENTICATION_ERROR_MSGS:od}=ci.hdbErrors;Sh.default.initSync();mq=Sh.default.get(U.AUTHENTICATION_OPERATIONTOKENTIMEOUT)||"1d",kie=Sh.default.get(U.AUTHENTICATION_REFRESHTOKENTIMEOUT)||"30d",Wg="RS256",cd={OPERATION:"operation",REFRESH:"refresh"};o(jg,"getJWTRSAKeys");o(GN,"createTokens");o($N,"refreshOperationToken");o(VN,"validateOperationToken");o(Jg,"validateRefreshToken");o(hq,"validateToken")});var KN=M((SDe,_q)=>{"use strict";var qie=aq(),ud=require("passport"),Gie=require("passport-local").Strategy,$ie=require("passport-http").BasicStrategy,Vie=require("util"),Kie=vn(),Eq=Vie.callbackify(Kie.findAndValidateUser),gDe=tn(),Yie=(k(),v(K)),pq=(ld(),v(Th));ud.use(new Gie(function(e,t,r){Eq(e,t,r)}));ud.use(new $ie(function(e,t,r){Eq(e,t,r)}));ud.serializeUser(function(e,t){t(null,e)});ud.deserializeUser(function(e,t){t(null,e)});function Wie(e,t,r){if(e.raw?.user!==void 0)return r(null,e.raw.user);let n,s;if(e.headers?.authorization){let a=e.headers.authorization.split(" ");n=a[0],s=a[1]}function i(a,c){return a?r(a):c?r(null,c):r("Must login")}switch(o(i,"handleResponse"),n){case"Basic":ud.authenticate("basic",{session:!1},(a,c)=>{i(a,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===Yie.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?pq.validateRefreshToken(s).then(a=>{e.body.refresh_token=s,r(null,a)}).catch(a=>{r(a)}):pq.validateOperationToken(s).then(a=>{r(null,a)}).catch(a=>{r(a)});break;default:ud.authenticate("local",{session:!1},function(a,c){i(a,c)})(e,t,r);break}}o(Wie,"authorize");function zie(e,t){let r=qie(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(zie,"checkPermissions");_q.exports={authorize:Wie,checkPermissions:zie}});var Qg=M((RDe,gq)=>{"use strict";var jie=Jn();gq.exports={writeTransaction:Jie};function Jie(e,t,r){return jie.writeTransaction(e,t,r)}o(Jie,"writeTransaction")});var yq=M((bDe,Rq)=>{"use strict";var Qie=on(),Xie=Ns(),Sq=z(),Zie=Mn(),ADe=Qg(),eoe=require("clone"),WN=require("alasql"),toe=eg(),Tq=require("util"),roe=Tq.promisify(Xie.getTableSchema),noe=Tq.promisify(Qie.search),soe=(k(),v(K)),YN=ie();toe(WN);Rq.exports={update:ooe};var ioe="There was a problem performing this update. Please check the logs and try again.";async function ooe({statement:e,hdb_user:t}){let r=await roe(e.table.databaseid,e.table.tableid),n=aoe(e.columns);YN.backtickASTSchemaItems(e);let{table:s,where:i}=e,a=eoe(s),c=YN.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,u=WN.parse(l).statements[0],d=await noe(u),f=coe(n,d);return loe(a,f,t)}o(ooe,"update");function aoe(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=WN.compile(`SELECT ${r.expression.toString()} AS [${soe.FUNC_VAL}] FROM ?`)}),t}catch(t){throw Sq.error(t),new Error(ioe)}}o(aoe,"createUpdateRecord");function coe(e,t){return YN.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}o(coe,"buildUpdateRecords");async function loe(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await Zie.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){Sq.error(`Error delete new_attributes from update response: ${i}`)}return s}o(loe,"updateRecords")});var bq=M((ODe,Aq)=>{var uoe=require("alasql"),doe=on(),foe=z(),moe=Jn(),jN=require("util"),zN=ie(),hoe=(k(),v(K)),poe=Ns(),NDe=Qg(),wDe=Mn(),Eoe="record",_oe="successfully deleted",goe=jN.callbackify(yoe),Soe=jN.promisify(doe.search),Toe=jN.promisify(poe.getTableSchema);Aq.exports={convertDelete:goe};function Roe(e){return`${e.deleted_hashes.length} ${Eoe}${e.deleted_hashes.length===1?"":"s"} ${_oe}`}o(Roe,"generateReturnMessage");async function yoe({statement:e,hdb_user:t}){let r=await Toe(e.table.databaseid,e.table.tableid);zN.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=zN.isEmpty(s)?"":` WHERE ${s.toString()}`,a=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=uoe.parse(a).statements[0],l={operation:hoe.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await Soe(c);let u=await moe.deleteRecords(l);return zN.isEmptyOrZeroLength(u.message)&&(u.message=Roe(u)),delete u.txn_time,u}catch(u){throw foe.error(u),u.hdb_code?u.message:u}}o(yoe,"convertDelete")});var Cq=M((PDe,Oq)=>{"use strict";var Aoe=Pa(),{hdbErrors:Iq}=Ee(),{getDatabases:Nq}=(Le(),v(ft));Oq.exports={checkSchemaExists:wq,checkSchemaTableExists:boe,schemaDescribe:Aoe};async function wq(e){if(!Nq()[e])return Iq.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}o(wq,"checkSchemaExists");async function boe(e,t){let r=await wq(e);if(r)return r;if(!Nq()[e][t])return Iq.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}o(boe,"checkSchemaTableExists")});var ew=M((UDe,qq)=>{"use strict";var{decode:Ioe}=require("msgpackr"),{isMainThread:DDe,parentPort:MDe,threadId:vDe}=require("worker_threads"),eS=Zt(),dd=It(),XN=(k(),v(K)),ln=z(),QN=ce(),Noe=(k(),v(K)),{onMessageByType:woe}=st(),Mq=xi(),{recordAction:Pq,recordActionBinary:Ooe}=(Hi(),v(Rg)),{publishToStream:Coe}=eS,{ConsumerEvents:Lq}=require("nats"),Poe=on(),{promisify:Loe}=require("util"),{decodeBlobsWithWrites:Doe}=(Ts(),v(bA)),vq=Loe(setTimeout),tS=1e4,rS,Zg,Moe,voe,Uq,Rh=new Map,fd=new Map;qq.exports={initialize:xq,ingestConsumer:ZN,setSubscription:Uoe,setIgnoreOrigin:Foe,getDatabaseSubscriptions:Boe,updateConsumer:Bq};async function xq(){woe(XN.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,async n=>{await Bq(n)}),Uq=!0,ln.notify("Initializing clustering ingest service.");let{connection:e,jsm:t,js:r}=await eS.getNATSReferences();rS=e,Zg=e.info.server_name,Moe=t,voe=r}o(xq,"initialize");async function Bq(e){if(e.status==="start"){let{js:t,jsm:r}=await Fq(e.node_domain_name);ZN(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")),fd.get(e.node_domain_name)==="failed"&&fd.set(e.node_domain_name,"close")}}o(Bq,"updateConsumer");var nS=new Map;function Uoe(e,t,r){let n=nS.get(e);n||nS.set(e,n=new Map),n.set(t,r),Uq||xq().then(xoe)}o(Uoe,"setSubscription");async function xoe(){let e=await Poe.searchByValue({database:"system",table:"hdb_nodes",search_attribute:"name",search_value:"*"});for await(let t of e){let r=t.name+dd.SERVER_SUFFIX.LEAF,n,s;for(let i of t.subscriptions||[])if(i.subscribe===!0){if(!n&&({js:n,jsm:s}=await Fq(r),!n))break;let{schema:a,table:c}=i,l=Mq.createNatsTableStreamName(a,c);ZN(l,n,s,r)}}}o(xoe,"accessConsumers");async function Fq(e){let t,r,n=1;for(;!r;)try{t=await rS.jetstream({domain:e}),r=await rS.jetstreamManager({domain:e,checkAPI:!1})}catch(s){if(fd.get(e)==="close")break;fd.set(e,"failed"),n%10===1&&ln.warn("Nats ingest attempting to connect to:",e,"Nats error:",s.message);let i=n++*100<tS?n++*100:tS;await vq(i)}return{js:t,jsm:r}}o(Fq,"connectToRemoteJS");function Boe(){return nS}o(Boe,"getDatabaseSubscriptions");var Hq;function Foe(e){Hq=e}o(Foe,"setIgnoreOrigin");var kq=100,Dq=new Array(kq),Xg=0;async function ZN(e,t,r,n){let{connection:s}=await eS.getNATSReferences();rS=s,Zg=s.info.server_name;let i,a=1;for(;!i;)try{i=await t.consumers.get(e,Zg),ln.notify("Initializing ingest consumer for node:",n,"stream:",e)}catch(u){if(fd.get(n)==="close")break;a%10===1&&ln.warn("Nats ingest error getting consumer:",n,"stream:",e,"Nats error:",u.message),u.code==="404"&&(ln.notify("Nats ingest creating consumer for node:",n,"stream:",e),i=await eS.createConsumer(r,e,Zg,new Date(Date.now()).toISOString()));let d=a++*100<tS?a++*100:tS;await vq(d)}let c=!1,l;for(;!c;){if(Rh.get(e+n)==="close"||fd.get(n)==="close"){Rh.delete(e+n),c=!0;continue}l=await i.consume({max_messages:QN.get(XN.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===Lq.ConsumerDeleted&&(await l.close(),c=!0),d.type===Lq.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 Dq[Xg],Dq[Xg]=Hoe(d).catch(f=>{ln.error(f)}),++Xg>=kq&&(Xg=0)}catch(d){d.message==="consumer deleted"?(ln.notify("Nats consumer deleted, closing messages for node:",n,"stream:",l.consumer.stream),await l.close(),c=!0):ln.error("Error consuming clustering ingest, restarting consumer",d)}}}o(ZN,"ingestConsumer");async function Hoe(e){let t;await Doe(()=>{t=Ioe(e.data)}),Pq(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=QN.get(XN.CONFIG_PARAMS.CLUSTERING_NODENAME);r.has(dd.MSG_HEADERS.TRANSACTED_NODES)&&r.values(dd.MSG_HEADERS.TRANSACTED_NODES).indexOf(s)>-1&&(n=!0);let i=r.get(dd.MSG_HEADERS.ORIGIN);if(n||(n=i===s&&!Hq),Ooe(n,"echo",e.subject,t.operation,"ingest"),n){e.ack();return}r.append(dd.MSG_HEADERS.TRANSACTED_NODES,s);try{let{operation:a,schema:c,next:l,table:u,records:d,hash_values:f,__origin:m,expiresAt:h}=t;ln.trace("processing message:",a,c,u,(d?"records: "+d.map(P=>P?.id):"")+(f?"ids: "+f:""),"with sequence:",e.seq),ln.trace(`messageProcessor nats msg id: ${e.headers.get(dd.MSG_HEADERS.NATS_MSG_ID)}`);let p;d||(d=f);let _=new Promise(P=>p=P),{timestamp:g,user:y,node_name:T}=m||{},R=nS.get(c)?.get(u);if(!R)throw new Error(`Missing table for replication message: ${u}`);if(a==="define_schema")t.type=a,t.onCommit=p,R.send(t);else if(d.length===1&&!l)R.send({type:JN(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:JN(a),value:Y,expiresAt:h,id:f?.[te],table:u}));for(;l;)P.push({type:JN(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})}QN.get(Noe.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&Coe(e.subject.split(".").slice(0,-1).join("."),Mq.createNatsTableStreamName(c,u),e.headers,e.data),await _;let I=Date.now()-g;g&&Pq(I,"replication-latency",e.subject,a,"ingest")}catch(a){ln.error(a)}e.ack()}o(Hoe,"messageProcessor");function JN(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}o(JN,"convertOperation")});var Zt=M((GDe,sG)=>{"use strict";var xr=ce();xr.initSync();var koe=require("fs-extra"),qoe=require("semver"),bh=require("path"),{monotonicFactory:Goe}=require("ulidx"),$q=Goe(),$oe=require("util"),Vq=require("child_process"),Voe=$oe.promisify(Vq.exec),Koe=Vq.spawn,Wr=It(),Je=(k(),v(K)),{packageJson:Yoe,PACKAGE_ROOT:Woe}=Rt(),sS=ie(),li=z(),iS=xi(),zoe=Qg(),yh=yt(),{broadcast:joe,onMessageByType:Joe,getWorkerIndex:Qoe}=st(),{isMainThread:Kq}=require("worker_threads"),{Encoder:Xoe,decode:sw}=require("msgpackr"),Yq=new Xoe,{isEmpty:bl}=sS,Wq=vn(),BDe=48*36e11;Kq&&Joe(Je.ITC_EVENT_TYPES.RESTART,()=>{un=void 0,Al=void 0});var{connect:Zoe,StorageType:eae,RetentionPolicy:tae,AckPolicy:iw,DeliverPolicy:ow,DiscardPolicy:rae,NatsConnection:FDe,JetStreamManager:HDe,JetStreamClient:kDe,StringCodec:qDe,JSONCodec:nae,createInbox:aw,headers:sae,ErrorCode:Gq}=require("nats"),{recordAction:iae}=(Hi(),v(Rg)),{encodeBlobsAsBuffers:oae}=(Ts(),v(bA)),zq=nae(),aae="clustering",cae=Yoe.engines[Wr.NATS_SERVER_NAME],lae=bh.join(Woe,"dependencies"),nw=bh.join(lae,`${process.platform}-${process.arch}`,Wr.NATS_BINARY_NAME),tw,rw,Ah,Rl,yl;sG.exports={runCommand:jq,checkNATSServerInstalled:uae,createConnection:cw,getConnection:Ih,getJetStreamManager:Nh,getJetStream:Qq,getNATSReferences:$i,getServerList:fae,createLocalStream:lw,listStreams:Xq,deleteLocalStream:mae,getServerConfig:md,listRemoteStreams:hae,viewStream:pae,viewStreamIterator:Eae,publishToStream:_ae,request:Tae,reloadNATS:uw,reloadNATSHub:Rae,reloadNATSLeaf:yae,extractServerName:Sae,requestErrorHandler:Aae,createLocalTableStream:rG,createTableStreams:Nae,purgeTableStream:nG,purgeSchemaTableStreams:wae,getStreamInfo:Oae,updateLocalStreams:Pae,closeConnection:dae,getJsmServerName:oS,addNatsMsgHeader:Zq,clearClientCache:Jq,updateRemoteConsumer:bae,createConsumer:eG,updateConsumerIterator:Iae};async function jq(e,t=void 0){let{stdout:r,stderr:n}=await Voe(e,{cwd:t});if(n)throw new Error(n.replace(`
15
15
  `,""));return r.replace(`
16
16
  `,"")}o(jq,"runCommand");async function uae(){try{await koe.access(nw)}catch{return!1}let e=await jq(`${nw} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return qoe.eq(t,cae)}o(uae,"checkNATSServerInstalled");async function cw(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let a=await Wq.getClusterUser();if(bl(a))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=a.username,r=a.decrypt_hash}li.trace("create nats connection called");let i=await Zoe({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:xr.get(Je.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:xr.get(Je.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:xr.get(Je.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&&Jq()}),i}o(cw,"createConnection");function Jq(){un=void 0,Rl=void 0,yl=void 0,Al=void 0}o(Jq,"clearClientCache");async function dae(){un&&(await un.drain(),un=void 0,Rl=void 0,yl=void 0,Al=void 0)}o(dae,"closeConnection");var un,Al;async function Ih(){return Al||(Al=cw(xr.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),un=await Al),un||Al}o(Ih,"getConnection");async function Nh(){if(Rl)return Rl;bl(un)&&await Ih();let{domain:e}=md(Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(bl(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return Rl=await un.jetstreamManager({domain:e,timeout:6e4}),Rl}o(Nh,"getJetStreamManager");async function Qq(){if(yl)return yl;bl(un)&&await Ih();let{domain:e}=md(Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(bl(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return yl=un.jetstream({domain:e,timeout:6e4}),yl}o(Qq,"getJetStream");async function $i(){let e=un||await Ih(),t=Rl||await Nh(),r=yl||await Qq();return{connection:e,jsm:t,js:r}}o($i,"getNATSReferences");async function fae(e){let t=xr.get(Je.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await Wq.getClusterUser(),s=await cw(t,r,n),i=aw(),a=s.subscribe(i),c=[],l,u=(async()=>{for await(let d of a){let f=zq.decode(d.data);f.response_time=Date.now()-l,c.push(f)}})();return l=Date.now(),await s.publish("$SYS.REQ.SERVER.PING.VARZ",void 0,{reply:i}),await s.publish("$SYS.REQ.SERVER.PING",void 0,{reply:i}),await s.flush(),await sS.asyncSetTimeout(e),await a.drain(),await s.close(),await u,c}o(fae,"getServerList");async function lw(e,t){let{jsm:r}=await $i(),n=xr.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=xr.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=xr.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:eae.File,retention:tae.Limits,subjects:t,discard:rae.Old,maxMsgs:s,maxBytes:i,maxAge:n})}o(lw,"createLocalStream");async function Xq(){let{jsm:e}=await $i(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}o(Xq,"listStreams");async function mae(e){let{jsm:t}=await $i();await t.streams.delete(e)}o(mae,"deleteLocalStream");async function hae(e){let{connection:t}=await $i(),r=[],n=aw(),s=t.subscribe(n),i=(async()=>{for await(let a of s)r.push(zq.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(hae,"listRemoteStreams");async function pae(e,t=void 0,r=void 0){let{jsm:n,js:s}=await $i(),i=$q(),a={durable_name:i,ack_policy:iw.Explicit};t&&(a.deliver_policy=ow.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=sw(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(pae,"viewStream");async function*Eae(e,t=void 0,r=void 0){let{jsm:n,js:s}=await $i(),i=$q(),a={durable_name:i,ack_policy:iw.Explicit};t&&(a.deliver_policy=ow.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=sw(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(Eae,"viewStreamIterator");async function _ae(e,t,r,n){li.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=Zq(n,r);let{js:s}=await $i(),i=await oS(),a=`${e}.${i}`,c=await oae(()=>n instanceof Uint8Array?n:Yq.encode(n));try{li.trace(`publishToStream publishing to subject: ${a}`),iae(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 tG(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 lw(t,[a]),await s.publish(a,c,{headers:r})}else throw l}});throw l}}o(_ae,"publishToStream");function Zq(e,t){t===void 0&&(t=sae());let r=xr.get(Je.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(Wr.MSG_HEADERS.ORIGIN)&&r&&t.append(Wr.MSG_HEADERS.ORIGIN,r),t}o(Zq,"addNatsMsgHeader");function md(e){e=e.toLowerCase();let t=bh.join(xr.get(Je.CONFIG_PARAMS.ROOTPATH),aae);if(e===Je.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return bl(rw)&&(rw={port:yh.getConfigFromFile(Je.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:yh.getConfigFromFile(Je.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}),rw;if(e===Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return bl(tw)&&(tw={port:yh.getConfigFromFile(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:yh.getConfigFromFile(Je.CONFIG_PARAMS.CLUSTERING_NODENAME)+Wr.SERVER_SUFFIX.LEAF,config_file:Wr.NATS_CONFIG_FILES.LEAF_SERVER,domain:yh.getConfigFromFile(Je.CONFIG_PARAMS.CLUSTERING_NODENAME)+Wr.SERVER_SUFFIX.LEAF,pid_file_path:bh.join(t,Wr.PID_FILES.LEAF),hdbNatsPath:t}),tw;li.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}o(md,"getServerConfig");async function eG(e,t,r,n){try{await e.consumers.add(t,{ack_policy:iw.Explicit,durable_name:r,deliver_policy:ow.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}o(eG,"createConsumer");async function gae(e,t,r){await e.consumers.delete(t,r)}o(gae,"removeConsumer");function Sae(e){return e.split(".")[1]}o(Sae,"extractServerName");async function Tae(e,t,r=6e4,n=aw()){if(!sS.isObject(t))throw new Error("data param must be an object");let s=Yq.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 sw(c.data)}o(Tae,"request");function uw(e){return new Promise(async(t,r)=>{let n=Koe(nw,["--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(uw,"reloadNATS");async function Rae(){let{pid_file_path:e}=md(Je.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await uw(e)}o(Rae,"reloadNATSHub");async function yae(){let{pid_file_path:e}=md(Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await uw(e)}o(yae,"reloadNATSLeaf");function Aae(e,t,r){let n;switch(e.code){case Gq.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case Gq.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}o(Aae,"requestErrorHandler");async function bae(e,t){let r=t+Wr.SERVER_SUFFIX.LEAF,{connection:n}=await $i(),{jsm:s}=await Dae(r),{schema:i,table:a}=e,c=iS.createNatsTableStreamName(i,a),l=e.start_time?e.start_time:new Date(Date.now()).toISOString();await tG(async()=>{if(e.subscribe===!0)await eG(s,c,n.info.server_name,l);else try{await gae(s,c,n.info.server_name)}catch(u){li.trace(u)}})}o(bae,"updateRemoteConsumer");async function Iae(e,t,r,n){let s=iS.createNatsTableStreamName(e,t),i=r+Wr.SERVER_SUFFIX.LEAF,a={type:Je.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!Kq&&Qoe()<xr.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=ew();await c(a)}await joe(a),n==="stop"&&await sS.asyncSetTimeout(1e3)}o(Iae,"updateConsumerIterator");function tG(e){return zoe.writeTransaction(Je.SYSTEM_SCHEMA_NAME,Je.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}o(tG,"exclusiveLock");async function rG(e,t){let r=iS.createNatsTableStreamName(e,t),n=await oS(),s=Cae(e,t,n);await lw(r,[s])}o(rG,"createLocalTableStream");async function Nae(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await rG(n,s)}}o(Nae,"createTableStreams");async function nG(e,t,r=void 0){if(xr.get(Je.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=iS.createNatsTableStreamName(e,t),{domain:s}=md(Je.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(nG,"purgeTableStream");async function wae(e,t){if(xr.get(Je.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await nG(e,t[r])}o(wae,"purgeSchemaTableStreams");async function Oae(e){return(await Nh()).streams.info(e)}o(Oae,"getStreamInfo");function Cae(e,t,r){return`${Wr.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}o(Cae,"createSubjectName");async function oS(){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(oS,"getJsmServerName");async function Pae(){let e=await Nh(),t=await oS(),r=await Xq();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let a=Lae(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(Pae,"updateLocalStreams");function Lae(e){let{config:t}=e,r=!1,n=xr.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=xr.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=xr.get(Je.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(Lae,"updateStreamLimits");async function Dae(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(Dae,"connectToRemoteJS")});function dw(e){let t=e.get(aS),r=t?(0,hd.unpack)(t):null;r||(r={remoteNameToId:{}});let n=rt(),s=!1;r.nodeName=rt();let i=r.remoteNameToId;if(i[n]!==0){let a=0,c;for(let l in i){let u=i[l];u===0?c=l:u>a&&(a=u)}if(c){a++,i[c]=a;let l=[Symbol.for("seq"),a];e.rootStore.dbisDb.transactionSync(()=>{e.rootStore.dbisDb.get(l)||e.rootStore.dbisDb.putSync(l,{seqId:Oh(e)??1,nodes:[]})})}i[n]=0,e.putSync(aS,(0,hd.pack)(r))}return r}function wh(e){return dw(e).remoteNameToId}function oG(e,t){let r=dw(t),n=r.remoteNameToId,s=new Map,i=!1;for(let a in e){let c=e[a],l=n[a];if(l==null){let u=0;for(let d in n){let f=n[d];f>u&&(u=f)}l=u+1,n[a]=l,i=!0}s.set(c,l)}return i&&t.putSync(aS,(0,hd.pack)(r)),s}function cS(e,t){let r=dw(t),n=r.remoteNameToId,s=n[e];if(s==null){let i=0;for(let a in n){let c=n[a];c>i&&(i=c)}s=i+1,n[e]=s,t.putSync(aS,(0,hd.pack)(r))}return iG.trace?.("The remote node name map",e,n,s),s}var iG,hd,aS,fw=fe(()=>{iG=w(Ni());es();hd=require("msgpackr"),aS=Symbol.for("remote-ids");o(dw,"getIdMappingRecord");o(wh,"exportIdMapping");o(oG,"remoteToLocalNodeId");o(cS,"getIdOfRemoteNode")});var mw={};Ce(mw,{commitsAwaitingReplication:()=>Ed,getHDBNodeTable:()=>$t,getReplicationSharedStatus:()=>_d,iterateRoutes:()=>Ph,shouldReplicateToNode:()=>Ch,subscribeToNodeUpdates:()=>gd});function $t(){return aG||(aG=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 _d(e,t,r,n){return new Float64Array(e.getUserSharedBuffer(["replicated",t,r],new ArrayBuffer(48),n&&{callback:n}))}function gd(e){$t().subscribe({}).then(async t=>{for await(let r of t){let n=r?.value?.name;dG.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 Mae(){gd(e=>{Fa({},(t,r)=>{let n=e.name,s=cG.get(n);if(s||cG.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=_d(i,r,n,()=>{let c=a[0],l=a.lastTime;for(let{txnTime:u,onConfirm:d}of Ed.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=pd.default.get(U.REPLICATION_SECUREPORT)??(!pd.default.get(U.REPLICATION_PORT)&&pd.default.get(U.OPERATIONSAPI_NETWORK_SECUREPORT)),i;(i=n.match(/:(\d+)$/)?.[1])?n=n.slice(0,-i[0].length-1):t.port?i=t.port:i=s||pd.default.get(U.REPLICATION_PORT)||pd.default.get(U.OPERATIONSAPI_NETWORK_PORT);let a=i?.lastIndexOf?.(":");a>0&&(i=+i.slice(a+1).replace(/[\[\]]/g,"")),r=(s?"wss://":"ws://")+n+":"+i}if(!r){lG.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 lG,uG,pd,dG,aG,cG,Ed,Il=fe(()=>{Le();es();Jf();lG=require("worker_threads"),uG=w(Ee()),pd=w(ce());k();dG=w(Ni());server.nodes=[];o($t,"getHDBNodeTable");o(_d,"getReplicationSharedStatus");o(gd,"subscribeToNodeUpdates");o(Ch,"shouldReplicateToNode");cG=new Map;lv((e,t,r)=>{if(r>server.nodes.length)throw new uG.ClientError(`Cannot confirm replication to more nodes (${r}) than are in the network (${server.nodes.length})`);Ed||(Ed=new Map,Mae());let n=Ed.get(e);return n||(n=[],Ed.set(e,n)),new Promise(s=>{let i=0;n.push({txnTime:t,onConfirm:o(()=>{++i===r&&s()},"onConfirm")})})});o(Mae,"startSubscriptionToReplications");o(Ph,"iterateRoutes")});var pG={};Ce(pG,{connectedToNode:()=>Nl,disconnectedFromNode:()=>Rd,ensureNode:()=>Do,requestClusterStatus:()=>hG,startOnMainThread:()=>pw});async function pw(e){let t=0,r=it();for(let i of Object.getOwnPropertyNames(r)){let a=r[i];for(let c in a){let l=a[c];if(l.auditStore){lS.set(i,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)}gd(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 Sd)if(i.url===m.url){Sd.delete(f);break}Sd.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}];lS.has(f)&&(_.push({replicateByDefault:m,name:rt(),startTime:lS.get(f),endTime:Date.now(),replicates:!0}),lS.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):Td(T)},vae);else{ut.info("Node no longer should be used, unsubscribing from node",{replicates:i.replicates,databaseName:f,node:i,subscriptions:i.subscriptions,hasDatabase:!!u[f],thisReplicates:$t().primaryStore.get(rt())?.replicates}),$t().primaryStore.get(rt())?.replicates||(n=!1,ut.info("Disabling replication, this node name",rt(),$t().primaryStore.get(rt()),f));let T={type:"unsubscribe-from-node",database:f,url:i.url,name:i.name};p?p.postMessage(T):dS(T)}}o(d,"onDatabase")}o(s,"onNodeUpdate"),Rd=o(function(i){try{ut.info("Disconnected from node",i.name,i.url,"finished",!!i.finished);let a=Array.from(Sd.keys()),c=a.sort(),l=c.indexOf(i.name||ui(i.url));if(l===-1){ut.warn("Disconnected node not found in node map",i.name,a);return}let u=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=Sd.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}):Td({database:i.database,nodes:y});return}ut.warn("Unable to find any other node to fail over to",i.name,i.url)}catch(a){ut.error("Error failing over node",a)}},"disconnectedFromNode"),Nl=o(function(i){let a=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}):Td({database:i.database,nodes:u}))}},"connectedToNode"),(0,Vi.onMessageByType)("disconnected-from-node",Rd),(0,Vi.onMessageByType)("connected-to-node",Nl),(0,Vi.onMessageByType)("request-cluster-status",hG)}function hG(e,t){let r=[];for(let[n,s]of Sd)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,hw.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 mG.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&&!fG.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,hw.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,uS,ut,hw,fG,mG,vae,Lo,Rd,Nl,Sd,lS,Lh=fe(()=>{Le();Vi=w(st());es();uS=require("worker_threads");Il();ut=w(z()),hw=require("lodash"),fG=w(ce());k();mG=require("crypto"),vae=200,Lo=new Map,Sd=new Map,lS=new Map;o(pw,"startOnMainThread");o(hG,"requestClusterStatus");uS.parentPort&&(Rd=o(e=>{uS.parentPort.postMessage({type:"disconnected-from-node",...e})},"disconnectedFromNode"),Nl=o(e=>{uS.parentPort.postMessage({type:"connected-to-node",...e})},"connectedToNode"),(0,Vi.onMessageByType)("subscribe-to-node",e=>{Td(e)}),(0,Vi.onMessageByType)("unsubscribe-from-node",e=>{dS(e)}));o(Do,"ensureNode")});var rs=M(Vt=>{"use strict";var ur=require("path"),{watch:Uae}=require("chokidar"),Un=require("fs-extra"),yd=require("node-forge"),RG=require("net"),{generateKeyPair:Ew,X509Certificate:Mo,createPrivateKey:yG}=require("crypto"),xae=require("util");Ew=xae.promisify(Ew);var Nt=yd.pki,di=require("joi"),{v4:AG}=require("uuid"),{validateBySchema:Tw}=at(),{forComponent:Bae}=z(),ts=ce(),Cs=(k(),v(K)),{CONFIG_PARAMS:Ol}=Cs,fi=Ky(),{ClientError:qa}=Ee(),mS=require("node:tls"),{relative:bG,join:Fae}=require("node:path"),{CERT_PREFERENCE_APP:iMe,CERTIFICATE_VALUES:EG}=fi,Hae=Dc(),_w=yt(),{table:kae,getDatabases:qae,databases:fS}=(Le(),v(ft)),{getJWTRSAKeys:_G}=(ld(),v(Th)),mt=Bae("tls");Vt.generateKeys=Aw;Vt.updateConfigCert=DG;Vt.createCsr=zae;Vt.signCertificate=jae;Vt.setCertTable=Ad;Vt.loadCertificates=CG;Vt.reviewSelfSignedCert=Iw;Vt.createTLSSelector=vG;Vt.listCertificates=xG;Vt.addCertificate=tce;Vt.removeCertificate=nce;Vt.createNatsCerts=Xae;Vt.generateCertsKeys=Qae;Vt.getReplicationCert=Mh;Vt.getReplicationCertAuth=Wae;Vt.renewSelfSigned=Zae;Vt.hostnamesFromCert=ww;Vt.getKey=sce;Vt.getHostnamesFromCertificate=ice;Vt.getPrimaryHostName=Nw;var{urlToNodeName:IG,getThisNodeUrl:Gae,getThisNodeName:pS,clearThisNodeName:$ae}=(es(),v(vo)),{readFileSync:Vae,statSync:NG}=require("node:fs"),oMe=ce(),{getTicketKeys:Kae,onMessageFromWorkers:Yae}=st(),ka=z(),{isMainThread:wG}=require("worker_threads"),{TLSSocket:OG,createSecureContext:aMe}=require("node:tls"),Rw=3650,Dh=["127.0.0.1","localhost","::1"],yw=[{name:"countryName",value:"USA"},{name:"stateOrProvinceName",value:"Colorado"},{name:"localityName",value:"Denver"},{name:"organizationName",value:"HarperDB, Inc."}];Yae(async e=>{e.type===Cs.ITC_EVENT_TYPES.RESTART&&(ts.initSync(!0),await Iw())});var zr;function $a(){return zr||(zr=qae().system.hdb_certificate,zr||(zr=kae({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=vG("operations-api"),t={secureContexts:null,setSecureContext:o(s=>{},"setSecureContext")};await e.initialize(t);let r=t.secureContexts.get(pS());if(!r)return;let n=new Mo(r.options.cert);return r.cert_parsed=n,r.issuer=n.issuer,r}o(Mh,"getReplicationCert");async function Wae(){$a();let e=(await Mh()).options.cert,r=new Mo(e).issuer.match(/CN=(.*)/)?.[1];return zr.get(r)}o(Wae,"getReplicationCertAuth");var gG,Ga=new Map;function CG(){if(gG)return;gG=!0;let e=[{configKey:Ol.TLS},{configKey:Ol.OPERATIONSAPI_TLS}];$a();let t=ur.dirname(_w.getConfigFilePath()),r;for(let{configKey:n}of e){let s=_w.getConfigFromFile(n);if(s){Array.isArray(s)||(s=[s]);for(let i of s){let a=i.privateKey,c=a&&bG(Fae(t,"keys"),a);c&&SG(a,l=>{Ga.set(c,l)},"private key");for(let l of[!1,!0]){let u=i[l?"certificateAuthority":"certificate"];if(u&&wG){let d;SG(u,f=>{if(EG.cert===f)return;let m=i.hostname??i.hostnames??i.host??i.hosts;m&&!Array.isArray(m)&&(m=[m]);let h=MG(u),p=new Mo(h),_;try{_=Nw(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(EG.cert)))return;let g=zr.primaryStore.get(_),y=NG(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(CG,"loadCertificates");function SG(e,t,r){let n,s=o((i,a)=>{try{let c=a.mtimeMs;c&&c!==n&&(n&&wG&&mt.warn(`Reloading ${r}:`,i),n=c,t(MG(i)))}catch(c){mt.error(`Error loading ${r}:`,i,c)}},"loadFile");Un.existsSync(e)?s(e,NG(e)):mt.error(`${r} file not found:`,e),Uae(e,{persistent:!1}).on("change",s)}o(SG,"loadAndWatch");function gw(){let e=Gae();if(e==null){let t=Dh[0];return mt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return IG(e)}o(gw,"getHost");function hS(){let e=pS();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(hS,"getCommonName");async function zae(){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:hS()},...yw];mt.info("Creating CSR with subject",s),n.setSubject(s);let i=[{name:"unstructuredName",value:"HarperDB, Inc."},{name:"extensionRequest",extensions:PG()}];return mt.info("Creating CSR with attributes",i),n.setAttributes(i),n.sign(r),yd.pki.certificationRequestToPem(n)}o(zae,"createCsr");function PG(){let e=Dh.includes(hS())?Dh:[...Dh,hS()];return e.includes(gw())||e.push(gw()),[{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=>RG.isIP(t)?{type:7,ip:t}:{type:2,value:t})}]}o(PG,"certExtensions");async function jae(e){let t={},r=ur.join(ts.getHdbBasePath(),Cs.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(Ga.has(d.private_key_name)){n=Ga.get(d.private_key_name),s=d;break}else if(d.private_key_name&&await Un.exists(ur.join(r,d.private_key_name))){n=Un.readFile(ur.join(r,d.private_key_name)),s=d;break}}if(!n){let d=await Sw();s=d.ca,n=d.private_key}n=Nt.privateKeyFromPem(n),t.signingCA=s.certificate;let i=Nt.certificateFromPem(s.certificate);mt.info("Signing CSR with cert named",s.name);let a=Nt.certificationRequestFromPem(e.csr);try{a.verify()}catch(d){return mt.error(d),new Error("Error verifying CSR: "+d.message)}let c=yd.pki.createCertificate();c.serialNumber="0"+Math.random().toString().slice(2,9),c.validity.notBefore=new Date;let l=new Date;c.validity.notAfter=l,c.validity.notAfter.setDate(l.getDate()+Rw),mt.info("sign cert setting validity:",c.validity),mt.info("sign cert setting subject from CSR:",a.subject.attributes),c.setSubject(a.subject.attributes),mt.info("sign cert setting issuer:",i.subject.attributes),c.setIssuer(i.subject.attributes);let u=a.getAttribute({name:"extensionRequest"}).extensions;mt.info("sign cert adding extensions from CSR:",u),c.setExtensions(u),c.publicKey=a.publicKey,c.sign(n,yd.md.sha256.create()),t.certificate=Nt.certificateToPem(c)}else mt.info("Sign cert did not receive a CSR from:",e.url,"only the CA will be returned");return t}o(jae,"signCertificate");async function Jae(e,t){await Ad({name:pS(),uses:["https","wss"],certificate:e,private_key_name:"privateKey.pem",is_authority:!1,is_self_signed:!0}),await Ad({name:t.subject.getField("CN").value,uses:["https","wss"],certificate:Nt.certificateToPem(t),private_key_name:"privateKey.pem",is_authority:!0,is_self_signed:!0})}o(Jae,"createCertificateTable");async function Ad(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(Ad,"setCertTable");async function Aw(){let e=await Ew("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(Aw,"generateKeys");async function bw(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()+Rw);let i=[{name:"commonName",value:hS()},...yw];return n.setSubject(i),n.setIssuer(r.subject.attributes),n.setExtensions(PG()),n.sign(e,yd.md.sha256.create()),Nt.certificateToPem(n)}o(bw,"generateCertificates");async function Sw(){let e=await xG(),t;for(let r of e){if(!r.is_authority)continue;let n=await UG(r.private_key_name);if(r.private_key_name&&n&&new Mo(r.certificate).checkPrivateKey(yG(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(Sw,"getCertAuthority");async function LG(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()+Rw);let i=[{name:"commonName",value:`HarperDB-Certificate-Authority-${ts.get(Ol.REPLICATION_HOSTNAME)??IG(ts.get(Ol.REPLICATION_URL))??AG().split("-")[0]}`},...yw];n.setSubject(i),n.setIssuer(i),n.setExtensions([{name:"basicConstraints",cA:!0,critical:!0},{name:"keyUsage",keyCertSign:!0,critical:!0}]),n.sign(e,yd.md.sha256.create());let a=ur.join(ts.getHdbBasePath(),Cs.LICENSE_KEY_DIR_NAME),c=ur.join(a,fi.PRIVATEKEY_PEM_NAME);return r&&await Un.writeFile(c,Nt.privateKeyToPem(e)),n}o(LG,"generateCertAuthority");async function Qae(){let{privateKey:e,publicKey:t}=await Aw(),r=await LG(e,t),n=await bw(e,t,r);await Jae(n,r),DG()}o(Qae,"generateCertsKeys");async function Xae(){let e=await bw(Nt.privateKeyFromPem(fi.CERTIFICATE_VALUES.key),void 0,Nt.certificateFromPem(fi.CERTIFICATE_VALUES.cert)),t=ur.join(ts.getHdbBasePath(),Cs.LICENSE_KEY_DIR_NAME),r=ur.join(t,fi.NATS_CERTIFICATE_PEM_NAME);await Un.exists(r)||await Un.writeFile(r,e);let n=ur.join(t,fi.NATS_CA_PEM_NAME);await Un.exists(n)||await Un.writeFile(n,fi.CERTIFICATE_VALUES.cert)}o(Xae,"createNatsCerts");async function Zae(){$a();for await(let e of zr.search([{attribute:"is_self_signed",value:!0}]))await zr.delete(e.name);await Iw()}o(Zae,"renewSelfSigned");async function Iw(){$ae(),await CG(),$a();let e=await Sw();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(Un.readFileSync(u)),keyPath:u}}catch(d){return mt.warn(`Failed to parse private key from ${u}:`,d.message),{key:null,keyPath:u}}},"tryToParseKey"),n=ts.get(Ol.TLS),s,i;if(Array.isArray(n)){for(let u of n)if(u.privateKey){let d=r(u.privateKey);if(s=d.key,i=d.keyPath,d.key)break}}else{let u=ts.get(Ol.TLS_PRIVATEKEY),d=r(u);s=d.key,i=d.keyPath}let a=ur.join(ts.getHdbBasePath(),Cs.LICENSE_KEY_DIR_NAME),c=bG(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 Aw(),Un.existsSync(ur.join(a,fi.PRIVATEKEY_PEM_NAME))&&(c=`privateKey${AG().split("-")[0]}.pem`),await Un.writeFile(ur.join(a,c),Nt.privateKeyToPem(s)));let l=await LG(s,Nt.setRsaPublicKey(s.n,s.e),!1);await Ad({name:l.subject.getField("CN").value,uses:["https"],certificate:Nt.certificateToPem(l),private_key_name:c,is_authority:!0,is_self_signed:!0})}if(!await Mh()){let r=pS();mt.notify(`A suitable replication certificate was not found, creating new self singed cert named: ${r}`),e=e??await Sw();let n=Nt.certificateFromPem(e.ca.certificate),s=n.publicKey,i=await bw(Nt.privateKeyFromPem(e.private_key),s,n);await Ad({name:r,uses:["https","operations","wss"],certificate:i,is_authority:!1,private_key_name:e.ca.private_key_name,is_self_signed:!0})}}o(Iw,"reviewSelfSignedCert");function DG(){let e=Hae(Object.keys(Cs.CONFIG_PARAM_MAP),!0),t=ur.join(ts.getHdbBasePath(),Cs.LICENSE_KEY_DIR_NAME),r=ur.join(t,fi.PRIVATEKEY_PEM_NAME),n=ur.join(t,fi.NATS_CERTIFICATE_PEM_NAME),s=ur.join(t,fi.NATS_CA_PEM_NAME),i=Cs.CONFIG_PARAMS,a={[i.TLS_PRIVATEKEY]:e[i.TLS_PRIVATEKEY.toLowerCase()]?e[i.TLS_PRIVATEKEY.toLowerCase()]:r};e[i.TLS_CERTIFICATE.toLowerCase()]&&(a[i.TLS_CERTIFICATE]=e[i.TLS_CERTIFICATE.toLowerCase()]),e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(a[i.TLS_CERTIFICATEAUTHORITY]=e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]&&(a[i.OPERATIONSAPI_TLS_CERTIFICATE]=e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]),e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]&&(a[i.OPERATIONSAPI_TLS_PRIVATEKEY]=e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(a[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY]=e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]),(e[i.CLUSTERING_ENABLED.toLowerCase()]||e.clustering)&&(a[i.CLUSTERING_TLS_CERTIFICATE]=e[i.CLUSTERING_TLS_CERTIFICATE.toLowerCase()]??n,a[i.CLUSTERING_TLS_CERT_AUTH]=e[i.CLUSTERING_TLS_CERT_AUTH.toLowerCase()]??s,a[i.CLUSTERING_TLS_PRIVATEKEY]=e[i.CLUSTERING_TLS_PRIVATEKEY.toLowerCase()]??r),_w.updateConfigValue(void 0,void 0,a,!1,!0)}o(DG,"updateConfigCert");function MG(e){return e.startsWith("-----BEGIN")?e:Vae(e,"utf8")}o(MG,"readPEM");var TG=mS.createSecureContext;mS.createSecureContext=function(e){if(!e.cert||!e.key)return TG(e);let t={...e};delete t.key,delete t.cert;let r=TG(t);return r.context.setCert(e.cert),r.context.setKey(e.key,void 0),r};var ece=OG.prototype._init;OG.prototype._init=function(e,t){ece.call(this,e,t);let r=this;this._handle.oncertcb=function(n){let s=n.servername;r._SNICallback(s,(i,a)=>{this.sni_context=a?.context||a,this.certCbDone()})}};var wl=new Map;function vG(e,t){let r=new Map,n,s=!1;return i.initialize=a=>i.ready?i.ready:(a&&(a.secureContexts=r,a.secureContextsListeners=[]),i.ready=new Promise((c,l)=>{async function u(){try{r.clear(),wl.clear();let d=0;if(fS===void 0){c();return}for await(let f of fS.system.hdb_certificate.search([])){let m=f.certificate,h=new Mo(m);f.is_authority&&(h.asString=m,wl.set(h.subject,m))}for await(let f of fS.system.hdb_certificate.search([]))try{if(f.is_authority)continue;let m=e==="operations-api",h=f.is_self_signed?1:2;m&&f.uses?.includes?.("operations")&&(h+=1);let p=await UG(f.private_key_name),_=f.certificate,g=new Mo(_);if(wl.has(g.issuer)&&(_+=`