harperdb 4.5.31 → 4.5.32
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/bin/harperdb.js +1 -1
- package/bin/lite.js +1 -1
- package/launchServiceScripts/launchNatsIngestService.js +1 -1
- package/launchServiceScripts/launchNatsReplyService.js +1 -1
- package/launchServiceScripts/launchUpdateNodes4-0-0.js +1 -1
- package/npm-shrinkwrap.json +13 -13
- package/package.json +1 -1
- package/server/jobs/jobProcess.js +1 -1
- package/server/threads/threadServer.js +1 -1
- package/studio/build-local/asset-manifest.json +2 -2
- package/studio/build-local/index.html +1 -1
- package/studio/build-local/static/js/{main.fbfcc75d.js → main.64412ce7.js} +2 -2
- package/utility/scripts/restartHdb.js +1 -1
- /package/studio/build-local/static/js/{main.fbfcc75d.js.LICENSE.txt → main.64412ce7.js.LICENSE.txt} +0 -0
|
@@ -16,7 +16,7 @@ Caused by:`));else if(typeof u=="object")try{n+=JSON.stringify(u)}catch{n+="Obje
|
|
|
16
16
|
|
|
17
17
|
`:`data: ${e}
|
|
18
18
|
|
|
19
|
-
`},"serialize"),compressible:!1,q:.8});Yr.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()}});BL={type:"application/json",serializeStream:Df,serialize:Uf,deserialize:d3,q:.5};Yr.set("*/*",BL);Yr.set("",BL);a(d3,"tryJSONParse");a(Bf,"registerContentHandlers");f3=require("fastify-plugin"),_3=f3(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:o,type:c}=Ap(n.raw);s.type(c),s.serializer(function(l){let u;if(typeof l=="object"&&l&&(l[Symbol.iterator]||l[Symbol.asyncIterator])&&o.serializeStream){if(l.mapError){let f=l.getColumns;l=l.mapError(d=>(d.toJSON=()=>({error:d.name,message:d.message,...d.partialObject}),d)),l.getColumns=f}u=o.serializeStream}else u=o.serialize;return u(l,{headers:{set:a((f,d)=>{s.header(f,d)},"set")}})})}),r()},{name:"content-type-negotiation"});a(Ap,"findBestSerializer");LL=sR.default.get(B.HTTP_COMPRESSIONTHRESHOLD);a(Hf,"serialize");a(ua,"serializeMessage");a(rR,"asyncSerialization");a(nR,"hasAsyncSerialization");a(h3,"streamToBuffer");m3=["ascii","utf8","utf-8","utf16le","utf-16le","ucs2","ucs-2","base64","base64url","latin1","binary","hex"];a(p3,"isBufferEncoding");a(E3,"parseContentType");a(lo,"getDeserializer");a(g3,"deserializerUnknownType");a(S3,"transformIterable");a(Tp,"toCsvStream")});var lR={};Ue(lR,{start:()=>I3});function T3(e){if(e.kind!==Me.Kind.OPERATION_DEFINITION&&e.kind!==Me.Kind.FRAGMENT_DEFINITION)throw new Or(`Unexpected non-executable definition type ${e.kind}.`)}function kL(e){if(typeof e!="object"||e===null)throw new bi("Request body must be an object.");if(!("query"in e))throw new bi("Request body must contain a `query` field.");if(typeof e.query!="string")throw new bi("Request body `query` field must be a string.");if("variables"in e&&(typeof e.variables!="object"||e.variables===null))throw new bi("Request body `variables` field must be an object.");if("operationName"in e&&typeof e.operationName!="string")throw new bi("Request body `operationName` field must be a string.")}function cR(e){return parseInt(e.value,10)}function GL(e){return parseFloat(e.value)}function qL(e,t,r){let n=r.get(e.name.value);return $L(n)?VL(n,t):{attribute:t,value:n}}function $L(e){return typeof e=="object"&&e!=null&&!Array.isArray(e)}function VL(e,t){return t=typeof t=="string"?[t]:t,Object.entries(e).flatMap(([r,n])=>(t=[...t,r],$L(n)?VL(n,t):{attribute:t,value:n}))}function A3(e,t,r){switch(t=[...t,e.name.value],e.value.kind){case Me.Kind.NULL:return{attribute:t,value:null};case Me.Kind.INT:return{attribute:t,value:cR(e.value)};case Me.Kind.FLOAT:return{attribute:t,value:GL(e.value)};case Me.Kind.BOOLEAN:case Me.Kind.STRING:return{attribute:t,value:e.value.value};case Me.Kind.VARIABLE:return qL(e.value,t,r);case Me.Kind.OBJECT:return KL(e.value,t,r);case Me.Kind.LIST:case Me.Kind.ENUM:default:throw new Or(`Value type, ${e.value.kind}, is not supported.`)}}function KL(e,t,r){return e.fields.flatMap(n=>A3(n,t,r))}function R3(e,t){switch(e.value.kind){case Me.Kind.NULL:return{attribute:e.name.value,value:null};case Me.Kind.INT:return{attribute:e.name.value,value:cR(e.value)};case Me.Kind.FLOAT:return{attribute:e.name.value,value:GL(e.value)};case Me.Kind.BOOLEAN:case Me.Kind.STRING:return{attribute:e.name.value,value:e.value.value};case Me.Kind.VARIABLE:return qL(e.value,e.name.value,t);case Me.Kind.OBJECT:return KL(e.value,[e.name.value],t);case Me.Kind.LIST:case Me.Kind.ENUM:default:throw new Or(`Argument type, ${e.value.kind}, is not supported.`)}}function y3(e,t){return e.flatMap(r=>R3(r,t))}function Rp(e,t){return e.selections.flatMap(r=>{switch(r.kind){case Me.Kind.FIELD:return r;case Me.Kind.FRAGMENT_SPREAD:{let n=r.name.value,s=t.get(n);if(s==null)throw new Or(`Fragment \`${n}\` not found.`);return Rp(s.selectionSet,t)}case Me.Kind.INLINE_FRAGMENT:return Rp(r.selectionSet,t)}})}function YL(e,t){return Rp(e,t).map(r=>r.selectionSet?.selections.length>0?{name:r.name.value,select:YL(r.selectionSet,t)}:r.name.value)}async function b3(e,t,r,n){let s=_s.getMatch(e.name.value,"graphql");if(s===void 0)throw new Or(`Resource \`${e.name.value}\` not found.`);let i=s.Resource,o={select:YL(e.selectionSet,r),conditions:y3(e.arguments,t)},c=[];n.authorize=!0;for await(let l of i.search(o,n))c.push(l);return[e.name.value,c]}function WL(e){switch(e.kind){case Me.Kind.NULL:return null;case Me.Kind.INT:return cR(e);case Me.Kind.FLOAT:return parseFloat(e.value);case Me.Kind.STRING:case Me.Kind.BOOLEAN:return e.value;case Me.Kind.OBJECT:return e.fields.reduce((t,r)=>({[r.name.value]:WL(r.value),...t}),{});case Me.Kind.LIST:case Me.Kind.ENUM:default:throw new Or(`Value type, ${e.kind}, is not supported.`)}}function O3(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=WL(n.defaultValue)),n.type.kind===Me.Kind.NON_NULL_TYPE&&!(s in t)&&i===void 0)throw new Or(`Variable $${s} is required, but not provided.`);r.set(n.variable.name.value,i??null)}return r}async function N3(e,t,r,n){if(e.operation===Me.OperationTypeNode.SUBSCRIPTION)throw new Or("Subscriptions are not supported.");if(e.operation===Me.OperationTypeNode.MUTATION)throw new Or("Mutations are not supported yet.");let s=O3(e.variableDefinitions,t),i=await Promise.all(Rp(e.selectionSet,r).map(c=>b3(c,s,r,n))),o={data:{}};for(let[c,l]of i)o.data[c]=l;return o}async function FL({query:e,variables:t={},operationName:r},n){let s=Me.parse(e),i=new Map,o=new Map;for(let u of s.definitions)if(T3(u),u.kind===Me.Kind.FRAGMENT_DEFINITION)o.set(u.name.value,u);else{if(u.name===void 0&&s.definitions.length>1)throw new Or("Unnamed operations are only allowed when there is a single operation in the document.");let f=u.name?.value??"Unnamed Query";if(i.has(f))throw new Or(`Duplicate operation definition: ${f}`);i.set(f,u)}let c;if(r==null)if(i.size===1)c=i.entries().next().value[1];else throw new Or("Operation name is required when there are multiple operations in the document.");else if(c=i.get(r),c==null)throw new Or(`Operation \`${r}\` not found.`);let l=await N3(c,t,o,n);return{status:200,headers:{"Content-Type":"application/graphql-response+json; charset=utf-8"},body:JSON.stringify(l)}}async function w3(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 kL(r),FL(r,e)}case"POST":{let r=await lo(e.headers.get("content-type"),!0)(e._nodeRequest);return kL(r),FL(r,e)}default:throw new bi("Method Not Allowed",405,{Allow:"GET, POST"})}}function I3(e){e.server.http(async(t,r)=>{if(!t.url.startsWith("/graphql"))return r(t);try{return await w3(t)}catch(n){logger.error(n);let s=t.headers.get("accept")??"application/graphql-response+json";switch(s){case"application/json":{if(n instanceof bi)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json",...n.headers}};if(n instanceof Me.GraphQLError)return{status:200,body:JSON.stringify({errors:[n]}),headers:{"Content-Type":"application/json"}};if(n instanceof Or)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 bi)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json",...n.headers}};if(n instanceof Me.GraphQLError)return{status:400,body:JSON.stringify({errors:[n]}),headers:{"Content-Type":"application/graphql-response+json"}};if(n instanceof Or)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 Me,Or,bi,zL=Re(()=>{Me=M(require("graphql"));oo();ru();a(T3,"assertExecutableDefinitionNode");a(kL,"assertRequestParams");a(cR,"processIntValueNode");a(GL,"processFloatValueNode");a(qL,"processVariableNode");a($L,"isObject");a(VL,"transformObjectIntoQueryCondition");a(A3,"processObjectFieldNode");a(KL,"processObjectValueNode");a(R3,"processArgumentNode");a(y3,"buildConditionsQuery");a(Rp,"fillInFragments");a(YL,"buildSelectQuery");a(b3,"processFieldNode");a(WL,"processConstValueNode");a(O3,"resolveVariables");a(N3,"executeOperation");a(FL,"resolver");Or=class extends Error{static{a(this,"GraphQLQueryingError")}},bi=class extends Error{static{a(this,"HTTPError")}statusCode;headers;constructor(t,r=400,n={}){super(t),this.statusCode=r,this.headers=n}};a(w3,"graphqlQueryingHandler");a(I3,"start")});var Ni=C((YRe,JL)=>{"use strict";var jL=oe(),QL=(k(),P(q)),cu=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Oi=require("joi"),da={schema_format:{pattern:cu,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},C3=Oi.alternatives(Oi.string().min(1).max(da.schema_length.maximum).pattern(cu).messages({"string.pattern.base":"{:#label} "+da.schema_format.message}),Oi.number(),Oi.array()).required(),P3=Oi.alternatives(Oi.string().min(1).max(da.schema_length.maximum).pattern(cu).messages({"string.pattern.base":"{:#label} "+da.schema_format.message}),Oi.number()),D3=Oi.alternatives(Oi.string().min(1).max(da.schema_length.maximum).pattern(cu).messages({"string.pattern.base":"{:#label} "+da.schema_format.message}),Oi.number()).required();function L3(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>da.schema_length.maximum?`'${e}' maximum of 250 characters`:cu.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(L3,"checkValidTable");function M3(e,t){return jL.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(M3,"validateSchemaExists");function v3(e,t){let r=t.state.ancestors[0].schema;return jL.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(v3,"validateTableExists");function U3(e,t){return e.toLowerCase()===QL.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${QL.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(U3,"validateSchemaName");JL.exports={common_validators:da,schema_regex:cu,hdb_schema_table:C3,validateSchemaExists:M3,validateTableExists:v3,validateSchemaName:U3,checkValidTable:L3,hdb_database:P3,hdb_table:D3}});var dR=C((zRe,ZL)=>{var{hdb_table:x3,hdb_database:XL}=Ni(),B3=st(),uR=require("joi"),H3={undefined:"undefined",null:"null"},k3=a((e,t)=>{let r=Object.keys(e),n=r.length,s;for(let i=0;i<n;i++){let o=r[i];(!o||o.length===0||H3[o]!==void 0)&&(s===void 0?s=`Invalid attribute name: '${o}'`:s+=`. Invalid attribute name: '${o}'`)}return s?t.message(s):e},"custom_records_val"),F3=uR.object({database:XL,schema:XL,table:x3,records:uR.array().items(uR.object().custom(k3)).required()});ZL.exports=function(e){return B3.validateBySchema(e,F3)}});var tM=C((jRe,eM)=>{"use strict";var fR=class{static{a(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")}};eM.exports=fR});var nM=C((XRe,rM)=>{"use strict";var _R=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};rM.exports=_R});var cM={};Ue(cM,{HAS_EXPIRATION:()=>Op,HAS_RESIDENCY_ID:()=>TR,HAS_STRUCTURE_UPDATE:()=>wp,LAST_TIMESTAMP_PLACEHOLDER:()=>qf,LOCAL_TIMESTAMP:()=>G3,METADATA:()=>Ic,NEW_TIMESTAMP_PLACEHOLDER:()=>iM,NO_TIMESTAMP:()=>hR,PENDING_LOCAL_TIME:()=>AR,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>SR,RecordEncoder:()=>gR,TIMESTAMP_ASSIGN_LAST:()=>$3,TIMESTAMP_ASSIGN_NEW:()=>oM,TIMESTAMP_ASSIGN_PREVIOUS:()=>aM,TIMESTAMP_PLACEHOLDER:()=>yp,TIMESTAMP_RECORD_PREVIOUS:()=>mR,handleLocalTimeForGets:()=>Ip,recordUpdater:()=>RR,removeEntry:()=>Pc});function K3(){return Gf[0]=Gf[0]^64,q3.getFloat64(0)}function Ip(e,t){let r=e.getEntry;e.readCount=0,e.cachePuts=!1,e.rootStore=t,e.encoder.rootStore=t,e.getEntry=function(o,c){e.readCount++;let l=r.call(this,o,c),u=l?.value,f=u?.[Ic];return f>=0&&(l.metadataFlags=f,l.localTime=u.localTime,l.value=u.value,l.residencyId=u.residencyId,u.expiresAt>=0&&(l.expiresAt=u.expiresAt)),l&&(l.key=o),l};let n=e.get;e.get=function(o,c){let l=n.call(this,o,c);return l?.[Ic]>=0?l.value:l};let s=e.getRange;e.getRange=function(o){let c=s.call(this,o);return o.valuesForKey?c.map(l=>l?.value):o.values===!1||o.onlyCount?c:c.map(l=>{let u=l.value,f=u[Ic];return f>=0&&(l.metadataFlags=f,l.localTime=u.localTime,l.value=u.value,l.residencyId=u.residencyId,u.expiresAt>=0&&(l.expiresAt=u.expiresAt)),l})};let i=e.useReadTransaction();if(i.done(),!i.done.isTracked){let o=i.constructor,c=i.use,l=i.done;o.prototype.use=function(){this.timerTracked||(this.timerTracked=!0,wc.push(new WeakRef(this))),c.call(this)},o.prototype.done=function(){if(l.call(this),this.isDone)for(let u=0;u<wc.length;u++){let f=wc[u].deref();(!f||f.isDone||f.isCommitted)&&wc.splice(u--,1)}},o.prototype.done.isTracked=!0}return e}function RR(e,t,r){return function(n,s,i,o,c=-1,l,u,f="put",d,_){d||l==null?lu=i?.localTime?mR|aM:hR:lu=l?i?.localTime?mR|16384:oM|16384:hR;let h=u?.expiresAt;if(h>=0&&(c|=Op),Ff=c,pR=h,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let m={version:o,instructedWrite:lu>0},S,g=0;try{let R=i?.residencyId,E=u?.residencyId;E&&(ER=E,Ff|=TR,g|=Dc),R!==E&&(g|=Lc,R||(R=0)),c&Op&&(g|=Vf),u?.originatingOperation&&(g|=$f),d&&(m.ifVersion=S=i?.version??null),i&&i.value&&f!=="message"&&i.metadataFlags&Ur&&(r.getBinaryFast(i.localTime)||la(i.value));let T;if(s!==void 0&&(T=gp(()=>e.put(n,s,m),n,e.rootStore),bc&&(g|=Ur)),l){let N=u?.user?.username;if(_&&(gp(()=>e.encoder.encode(_),n,e.rootStore),bc&&(g|=Ur)),e.encoder.hasStructureUpdate&&(g|=wp,e.encoder.hasStructureUpdate=!1),d&&i?.localTime){let v=i?.localTime,H=r.get(v);if(H){let X=gt(H).previousLocalTime;return T=r.put(v,Cc(o,t,n,X,u?.nodeId??server.replication.getThisNodeId(r)??0,N,f,kf,g,E,R,h),{ifVersion:S}),T}}T=r.put(s===void 0?iM:qf,Cc(o,t,n,i?.localTime?1:0,u?.nodeId??server.replication?.getThisNodeId(r)??0,N,f,kf,g,E,R,h,u?.originatingOperation),{append:f!=="invalidate",instructedWrite:!0,ifVersion:S})}return T}catch(R){throw R.message+=" id: "+n+" options: "+m,R}}}function Pc(e,t,r){if(t)return t.value&&t.metadataFlags&Ur&&!e.auditStore?.getBinaryFast(t.localTime)&&la(t.value),e.remove(t.key,r)}var sM,bp,yp,qf,SR,iM,G3,Ic,Gf,q3,hR,oM,$3,aM,mR,Op,TR,AR,wp,V3,kf,lu,Ff,pR,ER,gR,wc,uu=Re(()=>{sM=require("msgpackr");Ri();bp=M(ee());gn();gn();yp=new Uint8Array([1,1,1,1,4,64,0,0]),qf=new Uint8Array([1,1,1,1,1,0,0,0]),SR=new Uint8Array([1,1,1,1,3,64,0,0]),iM=new Uint8Array([1,1,1,1,0,64,0,0]),G3=Symbol("local-timestamp"),Ic=Symbol("metadata"),Gf=new Uint8Array(8),q3=new DataView(Gf.buffer,0,8),hR=0,oM=0,$3=1,aM=3,mR=4,Op=16,TR=32,AR=1,wp=256,lu=0,Ff=-1,pR=-1,ER=0,gR=class extends sM.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(s,i){if(lu||Ff>=0){let o=0,c=lu;c&&(o+=8,lu=0);let l=Ff,u=pR,f=ER;l>=0&&(o+=4,Ff=-1,u>=0&&(o+=8,pR=-1),f&&(o+=4,ER=0));let d=V3=r.call(this,s,i|2048|o);kf=d.subarray((d.start||0)+o,d.end);let _=d.start||0;return c&&(yp[4]=c,yp[5]=c>>8,d.set(yp,_),_+=8),bc&&(l|=Ur),l>=0&&((d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setUint32(_,l|Np<<24),_+=4,u>=0&&((d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setFloat64(_,u),_+=8),f&&(d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setUint32(_,f)),d}else return kf=r.call(this,s,i),kf};let n=this.saveStructures;this.saveStructures=function(s,i){let o=n.call(this,s,i);return this.hasStructureUpdate=!0,o}}decode(t,r){let n=r?.start||0,s=r>-1?r:r?.end||t.length,i=t[n],o=0;try{if(i<32&&s>2){let c=n,l;if(i===2){if(t.copy)t.copy(Gf,0,c),c+=8;else for(let _=0;_<8;_++)Gf[_]=t[c++];l=K3(),i=t[c]}let u,f;i<32&&(i===Np?(o=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4):(o=i|t[c+1]<<5,c+=2),o&Op&&(u=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8),o&TR&&(f=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4));let d=io(()=>r?.valueAsBuffer?t.subarray(c,s):super.decode(t.subarray(c,s),s-c),this.rootStore);return{localTime:l,value:d,[Ic]:o,expiresAt:u,residencyId:f}}return r?.valueAsBuffer?t:io(()=>super.decode(t,r),this.rootStore)}catch(c){return bp.error("Error decoding record",c,"data: "+t.slice(0,40).toString("hex")),null}}};a(K3,"getTimestamp");a(Ip,"handleLocalTimeForGets");wc=[];setInterval(()=>{for(let e=0;e<wc.length;e++){let t=wc[e].deref();!t||t.isDone||t.isCommitted?wc.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(bp.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):bp.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();a(RR,"recordUpdater");a(Pc,"removeEntry")});var Kf=C((sye,uM)=>{"use strict";var lM=ce(),Y3=(k(),P(q)),{RecordEncoder:W3}=(uu(),P(cM));lM.initSync();var z3=lM.get(Y3.CONFIG_PARAMS.STORAGE_CACHING)!==!1,yR=class{static{a(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=z3&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:W3})}};uM.exports=yR});var Yf=C((oye,dM)=>{"use strict";var Gn=ce(),hs=(k(),P(q));Gn.initSync();var Cp=class{static{a(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=Gn.get(hs.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Gn.get(hs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Gn.get(hs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Gn.get(hs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Gn.get(hs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Gn.get(hs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Gn.get(hs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Gn.get(hs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Gn.get(hs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Gn.get(hs.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Gn.get(hs.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Gn.get(hs.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};dM.exports=Cp;Cp.MAX_DBS=1e4});var _t=C((cye,AM)=>{"use strict";var OR=require("lmdb"),qs=require("fs-extra"),qn=require("path"),Pp=fn(),hM=ee(),Sn=Un().LMDB_ERRORS_ENUM,Dp=nM(),NR=Kf(),mM=Yf(),fa=kt(),fM=(k(),P(q)),{table:Q3,resetDatabases:j3}=(xe(),P(at)),_M=ce(),$s=fa.INTERNAL_DBIS_NAME,pM=fa.DBI_DEFINITION_NAME,J3="data.mdb",X3="lock.mdb",Wf=".mdb",Z3="-lock",bR=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=ms(t,r),this.key_type=this.dbi[fa.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[fa.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new OR.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function Lp(e,t){if(e===void 0)throw new Error(Sn.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(Sn.ENV_NAME_REQUIRED)}a(Lp,"pathEnvNameValidation");async function wR(e,t,r=!0){try{await qs.access(e)}catch(n){throw n.code==="ENOENT"?new Error(Sn.INVALID_BASE_PATH):n}try{let n=qn.join(e,t+Wf);return await qs.access(n,qs.constants.R_OK|qs.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await qs.access(qn.join(e,t,J3),qs.constants.R_OK|qs.constants.F_OK),qn.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(Sn.INVALID_ENVIRONMENT)}else throw new Error(Sn.INVALID_ENVIRONMENT);throw n}}a(wR,"validateEnvironmentPath");function Mp(e,t){if(Pp.validateEnv(e),t===void 0)throw new Error(Sn.DBI_NAME_REQUIRED)}a(Mp,"validateEnvDBIName");async function eX(e,t,r=!1,n=!1){Lp(e,t);let s=qn.basename(e);t=t.toString();let i=_M.get(fM.CONFIG_PARAMS.DATABASES);i||_M.setProperty(fM.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await wR(e,t,n),EM(e,t,r)}catch(o){if(o.message===Sn.INVALID_ENVIRONMENT){let c=qn.join(e,t);await qs.mkdirp(n?c:e);let l=new mM(n?c:c+Wf,!1),u=OR.open(l);u.dbis=Object.create(null);let f=new NR(!1);u.openDB($s,f),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let d=IR(e,t,r);return u[fa.ENVIRONMENT_NAME_KEY]=d,global.lmdb_map[d]=u,u}throw o}}a(eX,"createEnvironment");async function tX(e,t,r,n=!0){Lp(e,t),t=t.toString();let s=qn.join(e,t);return Q3({table:t,database:qn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(tX,"copyEnvironment");async function EM(e,t,r=!1){Lp(e,t),t=t.toString();let n=IR(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 wR(e,t),i=qn.join(e,t+Wf),o=s!=i,c=new mM(s,o),l=OR.open(c);l.dbis=Object.create(null);let u=SM(l);for(let f=0;f<u.length;f++)ms(l,u[f]);return l[fa.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(EM,"openEnvironment");async function rX(e,t,r=!1){Lp(e,t),t=t.toString();let n=qn.join(e,t+Wf),s=await wR(e,t);if(global.lmdb_map!==void 0){let i=IR(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await gM(o),delete global.lmdb_map[i]}}await qs.remove(s),await qs.remove(s===n?s+Z3:qn.join(qn.dirname(s),X3))}a(rX,"deleteEnvironment");async function gM(e){Pp.validateEnv(e);let t=e[fa.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(gM,"closeEnvironment");function IR(e,t,r=!1){let s=`${qn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(IR,"getCachedEnvironmentName");function nX(e){Pp.validateEnv(e);let t=Object.create(null),r=ms(e,$s);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==$s)try{t[n]=Object.assign(new Dp,s)}catch{hM.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(nX,"listDBIDefinitions");function SM(e){Pp.validateEnv(e);let t=[],r=ms(e,$s);for(let{key:n}of r.getRange({start:!1}))n!==$s&&t.push(n);return t}a(SM,"listDBIs");function sX(e,t){let n=ms(e,$s).getEntry(t),s=new Dp;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{hM.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(sX,"getDBIDefinition");function TM(e,t,r,n=!r){if(Mp(e,t),t=t.toString(),t===$s)throw new Error(Sn.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return ms(e,t)}catch(s){if(s.message===Sn.DBI_DOES_NOT_EXIST){let i=new NR(r,n===!0),o=e.openDB(t,i),c=new Dp(r===!0,n);return o[pM]=c,ms(e,$s).putSync(t,c),e.dbis[t]=o,o}throw s}}a(TM,"createDBI");function ms(e,t){if(Mp(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==$s?r=sX(e,t):r=new Dp,r===void 0)throw new Error(Sn.DBI_DOES_NOT_EXIST);let n;try{let s=new NR(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(Sn.DBI_DOES_NOT_EXIST):s}return n[pM]=r,e.dbis[t]=n,n}a(ms,"openDBI");function iX(e,t){Mp(e,t),t=t.toString();let r=ms(e,t),n=r.getStats();return r[fa.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(iX,"statDBI");async function oX(e,t){try{let r=qn.join(e,t+Wf);return(await qs.stat(r)).size}catch{throw new Error(Sn.INVALID_ENVIRONMENT)}}a(oX,"environmentDataSize");function aX(e,t){if(Mp(e,t),t=t.toString(),t===$s)throw new Error(Sn.CANNOT_DROP_INTERNAL_DBIS_NAME);ms(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],ms(e,$s).removeSync(t)}a(aX,"dropDBI");function cX(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{ms(e,i)}catch(o){if(o.message===Sn.DBI_DOES_NOT_EXIST)TM(e,i,i!==t,i===t),n=!0;else throw o}}n&&j3()}a(cX,"initializeDBIs");AM.exports={openDBI:ms,openEnvironment:EM,createEnvironment:eX,listDBIs:SM,listDBIDefinitions:nX,createDBI:TM,dropDBI:aX,statDBI:iX,deleteEnvironment:rX,initializeDBIs:cX,TransactionCursor:bR,environmentDataSize:oX,copyEnvironment:tX,closeEnvironment:gM}});var yM=C((uye,RM)=>{"use strict";var CR=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};RM.exports=CR});var OM=C((fye,bM)=>{"use strict";var PR=class{static{a(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}};bM.exports=PR});var wM=C((hye,NM)=>{"use strict";var DR=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};NM.exports=DR});var vc=C((Sye,PM)=>{"use strict";var lX=_t(),uX=yM(),dX=OM(),fX=wM(),wi=fn(),zf=Un().LMDB_ERRORS_ENUM,_X=kt(),uo=(k(),P(q)),hX=oe(),mX=require("uuid"),pye=require("lmdb"),{handleHDBError:pX,hdb_errors:EX}=me(),{OVERFLOW_MARKER:Eye,MAX_SEARCH_KEY_LENGTH:gye}=_X,IM=ce();IM.initSync();var vp=IM.get(uo.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),LR=uo.TIME_STAMP_NAMES_ENUM.CREATED_TIME,Mc=uo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function gX(e,t,r,n,s=wi.getNextMonotonicTime()){xR(e,t,r,n),MR(e,t,r);let i=new uX,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l];CM(u,!0,s);let f=SX(e,t,r,u),d=u[t];o.push(f),c.push(d)}return vR(o,c,n,i,s)}a(gX,"insertRecords");function SX(e,t,r,n){let s=n[t];return e.dbis[t].ifNoExists(s,()=>{for(let i=0;i<r.length;i++){let o=r[i];if(o===t||n.hasOwnProperty(o)===!1)continue;let c=n[o];if(typeof c=="function"){let f=c([[{}]]);Array.isArray(f)&&(c=f[0][uo.FUNC_VAL],n[o]=c)}let l=wi.getIndexedValues(c),u=e.dbis[o];if(l){vp&&u.prefetch(l.map(f=>({key:f,value:s})),Up);for(let f=0,d=l.length;f<d;f++)u.put(l[f],s)}}vp&&e.dbis[t].prefetch([s],Up),e.dbis[t].put(s,n,n[Mc])})}a(SX,"insertRecord");function TX(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(TX,"removeSkippedRecords");function CM(e,t,r){let n=r>0;(n||!Number.isInteger(e[Mc]))&&(e[Mc]=r||(r=wi.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[LR]))&&(e[LR]=r||wi.getNextMonotonicTime()):delete e[LR]}a(CM,"setTimestamps");function MR(e,t,r){r.indexOf(uo.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(uo.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(uo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(uo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),lX.initializeDBIs(e,t,r)}a(MR,"initializeTransaction");async function AX(e,t,r,n,s=wi.getNextMonotonicTime()){xR(e,t,r,n),MR(e,t,r);let i=new dX,o=[],c=[],l=[];for(let u=0;u<n.length;u++){let f=n[u],d=f[t],_;try{_=UR(e,t,f,d,i,!0,s)}catch{i.skipped_hashes.push(d),o.push(u);continue}c.push(_),l.push(d)}return vR(c,l,n,i,s,o)}a(AX,"updateRecords");async function RX(e,t,r,n,s=wi.getNextMonotonicTime()){try{xR(e,t,r,n)}catch(l){throw pX(l,l.message,EX.HTTP_STATUS_CODES.BAD_REQUEST)}MR(e,t,r);let i=new fX,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l],f;hX.isEmpty(u[t])?(f=mX.v4(),u[t]=f):f=u[t];let d=UR(e,t,u,f,i,!1,s);o.push(d),c.push(f)}return vR(o,c,n,i,s)}a(RX,"upsertRecords");async function vR(e,t,r,n,s,i=[]){let o=await Promise.all(e);for(let c=0,l=o.length;c<l;c++)o[c]===!0?n.written_hashes.push(t[c]):(n.skipped_hashes.push(t[c]),i.push(c));return n.txn_time=s||wi.getNextMonotonicTime(),TX(r,i),n}a(vR,"finalizeWrite");function UR(e,t,r,n,s,i=!1,o){let c=e.dbis[t],l=c.getEntry(n),u=l?.value,f=u;if(!u){if(i)return!1;u={}}if(CM(r,!f,o),Number.isInteger(r[Mc])&&u[Mc]>r[Mc])return!1;f&&s.original_records.push(u);let d,_=a(()=>{for(let m in r){if(!r.hasOwnProperty(m)||m===t)continue;let S=r[m],g=e.dbis[m];if(g===void 0)continue;let R=u[m];if(typeof S=="function"){let T=S([[u]]);Array.isArray(T)&&(S=T[0][uo.FUNC_VAL],r[m]=S)}if(S===R)continue;let E=wi.getIndexedValues(R);if(E){vp&&g.prefetch(E.map(T=>({key:T,value:n})),Up);for(let T=0,N=E.length;T<N;T++)g.remove(E[T],n)}if(E=wi.getIndexedValues(S),E){vp&&g.prefetch(E.map(T=>({key:T,value:n})),Up);for(let T=0,N=E.length;T<N;T++)g.put(E[T],n)}}let h={...u,...r};c.put(n,h,h[Mc])},"do_put");return l?d=c.ifVersion(n,l.version,_):d=c.ifNoExists(n,_),d.then(h=>h?!0:UR(e,t,r,n,s,i,o))}a(UR,"updateUpsertRecord");function yX(e,t,r){if(wi.validateEnv(e),t===void 0)throw new Error(zf.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(zf.WRITE_ATTRIBUTES_REQUIRED):new Error(zf.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(yX,"validateBasic");function xR(e,t,r,n){if(yX(e,t,r),!Array.isArray(n))throw n===void 0?new Error(zf.RECORDS_REQUIRED):new Error(zf.RECORDS_MUST_BE_ARRAY)}a(xR,"validateWrite");function Up(){}a(Up,"noop");PM.exports={insertRecords:gX,updateRecords:AX,upsertRecords:RX}});var fo=C((Aye,bX)=>{bX.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:{hash_attribute:"id",name:"hdb_analytics",schema:"system",audit:!1,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 LM=C((Rye,DM)=>{"use strict";var OX=require("uuid"),BR=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||OX.v4(),this.schema_table=`${this.schema}.${this.table}`}};DM.exports=BR});var xp=C((bye,MM)=>{"use strict";var NX=LM(),HR=class extends NX{static{a(this,"LMDBCreateAttributeObject")}constructor(t,r,n,s,i=!0,o=!1){super(t,r,n,s),this.dup_sort=i,this.is_hash_attribute=o}};MM.exports=HR});var UM=C((Nye,vM)=>{"use strict";vM.exports=IX;var wX="inserted";function IX(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===wX?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(IX,"returnObject")});var Bp=C((Cye,BM)=>{"use strict";var CX=(k(),P(q)),kR=_t(),PX=vc(),{getSystemSchemaPath:DX,getSchemaPath:LX}=Et(),Iye=fo(),{validateBySchema:MX}=st(),Qf=require("joi"),vX=xp(),UX=UM(),{handleHDBError:xX,hdb_errors:BX,ClientError:HX}=me(),xM=oe(),{HTTP_STATUS_CODES:kX}=BX,FX="inserted";BM.exports=GX;async function GX(e){let t=MX(e,Qf.object({database:Qf.string(),schema:Qf.string(),table:Qf.string().required(),attribute:Qf.string().required()}));if(t)throw new HX(t.message);let r=!e.skip_table_check&&xM.checkGlobalSchemaTable(e.schema,e.table);if(r)throw xX(new Error,r,kX.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=xM.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 vX(e.schema,e.table,e.attribute,e.id);try{let i=await kR.openEnvironment(LX(e.schema,e.table),e.table);if(i.dbis[e.attribute]!==void 0)throw new Error(`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`);kR.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await kR.openEnvironment(DX(),CX.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await PX.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_attribute_attributes,[s]);return UX(FX,c,{records:[s]},l)}catch(i){throw i}}a(GX,"lmdbCreateAttribute")});var jf=C((Lye,kM)=>{"use strict";var _o=oe(),HM=ee(),Dye=dR(),{getDatabases:qX}=(xe(),P(at)),{ClientError:Uc}=me();kM.exports=$X;function $X(e){if(_o.isEmpty(e))throw new Uc("invalid update parameters defined.");if(_o.isEmptyOrZeroLength(e.schema))throw new Uc("invalid schema specified.");if(_o.isEmptyOrZeroLength(e.table))throw new Uc("invalid table specified.");if(!Array.isArray(e.records))throw new Uc("records must be an array");let t=qX()[e.schema]?.[e.table];if(_o.isEmpty(t))throw new Uc(`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(o=>{if(i&&_o.isEmptyOrZeroLength(o[r]))throw HM.error("a valid hash attribute must be provided with update record:",o),new Uc("a valid hash attribute must be provided with update record, check log for more info");if(!_o.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw HM.error(`a valid hash value must be provided with ${e.operation} record:`,o),new Uc(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!_o.isEmpty(o[r])&&o[r]!==""&&n.has(_o.autoCast(o[r]))&&(o.skip=!0),n.add(_o.autoCast(o[r]));for(let c in o)s[c]=1}),s[r]=1,{schema_table:t,hashes:Array.from(n),attributes:Object.keys(s)}}a($X,"insertUpdateValidate")});var GM=C((vye,FM)=>{"use strict";var FR=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};FM.exports=FR});var VM=C((xye,$M)=>{"use strict";var GR=_t(),VX=ee(),qM=Un().LMDB_ERRORS_ENUM;$M.exports=KX;async function KX(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 o=t[i];if(o.startsWith(`${e.schema}.`)||o.startsWith(`txn.${e.schema}.`))try{await GR.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==qM.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await GR.closeEnvironment(global.lmdb_map[n]),await GR.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==qM.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){VX.error(t)}}a(KX,"cleanLMDBMap")});var nv=C((kye,rv)=>{"use strict";var qR=require("recursive-iterator"),YX=require("alasql"),$R=require("clone"),KM=oe(),{handleHDBError:YM,hdb_errors:WX}=me(),{HDB_ERROR_MSGS:WM,HTTP_STATUS_CODES:zM}=WX,{getDatabases:zX}=(xe(),P(at)),QX=["DISTINCT_ARRAY"],QM=Symbol("validateTables"),VR=Symbol("validateTable"),Hye=Symbol("getAllColumns"),jM=Symbol("validateAllColumns"),Hp=Symbol("findColumn"),JM=Symbol("validateOrderBy"),Jf=Symbol("validateSegment"),KR=Symbol("validateColumn"),XM=Symbol("setColumnsForTable"),ZM=Symbol("checkColumnsForAsterisk"),ev=Symbol("validateGroupBy"),tv=Symbol("hasColumns"),YR=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[QM](),this[ZM](),this[jM]()}[QM](){if(this[tv]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[VR](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[VR](t.table)})}}[tv](){let t=!1,r=new qR(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[VR](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=zX();if(!r[t.databaseid])throw YM(new Error,WM.SCHEMA_NOT_FOUND(t.databaseid),zM.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw YM(new Error,WM.TABLE_NOT_FOUND(t.databaseid,t.tableid),zM.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=$R(s);i.table=$R(t),this.attributes.push(i)})}[Hp](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)}[ZM](){let t=new qR(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[XM](r.tableid)}[XM](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new YX.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[jM](){this[Jf](this.statement.columns,!1),this[Jf](this.statement.joins,!1),this[Jf](this.statement.where,!1),this[ev](this.statement.group,!1),this[Jf](this.statement.order,!0)}[Jf](t,r){if(!t)return;let n=new qR(t),s=[];for(let{node:i,path:o}of n)!KM.isEmpty(i)&&!KM.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[JM](i):s.push(this[KR](i)));return s}[ev](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&QX.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=$R(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[Hp](n)[0];s&&r.push(s)}}}),this.statement.group.forEach(n=>{let s=null;if(!n.columnid)r.forEach((i,o)=>{if(i.toString()===n.toString()){s=i,r.splice(o,1);return}});else{let i=this[Hp](n);if(!i||i.length===0)throw`unknown column '${n.toString()}' in group by`;if(i.length>1)throw`ambiguously defined column '${n.toString()}' in group by`;r.forEach((o,c)=>{if(o.attribute===i[0].attribute&&o.table.tableid===i[0].table.tableid){s=o,r.splice(c,1);return}})}if(!s)throw`group by column '${n.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`}[JM](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[KR](t)}[KR](t){let r=this[Hp](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]}};rv.exports=YR});var av=C((Gye,ov)=>{"use strict";var sv=require("lodash"),Xf=require("mathjs"),jX=require("jsonata"),iv=oe();ov.exports={distinct_array:a(e=>Array.isArray(e)&&e.length>1?sv.uniqWith(e,sv.isEqual):e,"distinct_array"),searchJSON:JX,mad:Zf.bind(null,Xf.mad),mean:Zf.bind(null,Xf.mean),mode:Zf.bind(null,Xf.mode),prod:Zf.bind(null,Xf.prod),median:Zf.bind(null,Xf.median)};function Zf(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}a(Zf,"aggregateFunction");function JX(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(iv.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),iv.isEmpty(this.__ala__.res[r])){let n=jX(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(JX,"searchJSON")});var lv=C(($ye,cv)=>{"use strict";var rr=require("moment"),WR="YYYY-MM-DDTHH:mm:ss.SSSZZ";rr.suppressDeprecationWarnings=!0;cv.exports={current_date:a(()=>rr().utc().format("YYYY-MM-DD"),"current_date"),current_time:a(()=>rr().utc().format("HH:mm:ss.SSS"),"current_time"),extract:a((e,t)=>{switch(t.toLowerCase()){case"year":return rr(e).utc().format("YYYY");case"month":return rr(e).utc().format("MM");case"day":return rr(e).utc().format("DD");case"hour":return rr(e).utc().format("HH");case"minute":return rr(e).utc().format("mm");case"second":return rr(e).utc().format("ss");case"millisecond":return rr(e).utc().format("SSS");default:break}},"extract"),date:a(e=>rr(e).utc().format(WR),"date"),date_format:a((e,t)=>rr(e).utc().format(t),"date_format"),date_add:a((e,t,r)=>rr(e).utc().add(t,r).valueOf(),"date_add"),date_sub:a((e,t,r)=>rr(e).utc().subtract(t,r).valueOf(),"date_sub"),date_diff:a((e,t,r)=>{let n=rr(e).utc(),s=rr(t).utc();return r?n.diff(s,r,!0):n.diff(s)},"date_diff"),now:a(()=>rr().utc().valueOf(),"now"),get_server_time:a(()=>rr().format(WR),"get_server_time"),offset_utc:a((e,t)=>rr(e).utc().utcOffset(t).format(WR),"offset_utc")}});var _v=C((Kye,fv)=>{"use strict";var XX=require("@turf/area"),ZX=require("@turf/length"),e6=require("@turf/circle"),t6=require("@turf/difference"),r6=require("@turf/distance"),n6=require("@turf/boolean-contains"),s6=require("@turf/boolean-equal"),i6=require("@turf/boolean-disjoint"),o6=require("@turf/helpers"),uv=(k(),P(q)),Ke=oe(),ho=ee();fv.exports={geoArea:a6,geoLength:c6,geoCircle:l6,geoDifference:u6,geoDistance:dv,geoNear:d6,geoContains:f6,geoEqual:_6,geoCrosses:h6,geoConvert:m6};function a6(e){if(Ke.isEmpty(e))return NaN;typeof e=="string"&&(e=Ke.autoCastJSON(e));try{return XX.default(e)}catch(t){return ho.trace(t,e),NaN}}a(a6,"geoArea");function c6(e,t){if(Ke.isEmpty(e))return NaN;typeof e=="string"&&(e=Ke.autoCastJSON(e));try{return ZX.default(e,{units:t||"kilometers"})}catch(r){return ho.trace(r,e),NaN}}a(c6,"geoLength");function l6(e,t,r){if(Ke.isEmpty(e))return NaN;if(Ke.isEmpty(t))return NaN;typeof e=="string"&&(e=Ke.autoCastJSON(e));try{return e6.default(e,t,{units:r||"kilometers"})}catch(n){return ho.trace(n,e,t),NaN}}a(l6,"geoCircle");function u6(e,t){if(Ke.isEmpty(e))return NaN;if(Ke.isEmpty(t))return NaN;typeof e=="string"&&(e=Ke.autoCastJSON(e)),typeof t=="string"&&(t=Ke.autoCastJSON(t));try{return t6(e,t)}catch(r){return ho.trace(r,e,t),NaN}}a(u6,"geoDifference");function dv(e,t,r){if(Ke.isEmpty(e))return NaN;if(Ke.isEmpty(t))return NaN;typeof e=="string"&&(e=Ke.autoCastJSON(e)),typeof t=="string"&&(t=Ke.autoCastJSON(t));try{return r6.default(e,t,{units:r||"kilometers"})}catch(n){return ho.trace(n,e,t),NaN}}a(dv,"geoDistance");function d6(e,t,r,n){if(Ke.isEmpty(e)||Ke.isEmpty(t))return!1;if(Ke.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=Ke.autoCastJSON(e)),typeof t=="string"&&(t=Ke.autoCastJSON(t)),isNaN(r))throw new Error("distance must be a number");try{return dv(e,t,n)<=r}catch(s){return ho.trace(s,e,t),!1}}a(d6,"geoNear");function f6(e,t){if(Ke.isEmpty(e)||Ke.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Ke.autoCastJSON(e)),typeof t=="string"&&(t=Ke.autoCastJSON(t));try{return n6.default(e,t)}catch(r){return ho.trace(r,e,t),!1}}a(f6,"geoContains");function _6(e,t){if(Ke.isEmpty(e)||Ke.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Ke.autoCastJSON(e)),typeof t=="string"&&(t=Ke.autoCastJSON(t));try{return s6.default(e,t)}catch(r){return ho.trace(r,e,t),!1}}a(_6,"geoEqual");function h6(e,t){if(Ke.isEmpty(e)||Ke.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Ke.autoCastJSON(e)),typeof t=="string"&&(t=Ke.autoCastJSON(t));try{return!i6.default(e,t)}catch(r){return ho.trace(r,e,t),!1}}a(h6,"geoCrosses");function m6(e,t,r){if(Ke.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if(Ke.isEmpty(t))throw new Error("geo_type is required");if(Ke.isEmpty(uv.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(uv.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Ke.autoCastJSON(e)),o6[t](e,r)}a(m6,"geoConvert")});var kp=C((Wye,hv)=>{var xc=av(),$n=lv(),Ii=_v();hv.exports=e=>{e.aggr.mad=e.aggr.MAD=xc.mad,e.aggr.mean=e.aggr.MEAN=xc.mean,e.aggr.mode=e.aggr.MODE=xc.mode,e.aggr.prod=e.aggr.PROD=xc.prod,e.aggr.median=e.aggr.MEDIAN=xc.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=xc.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=xc.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=$n.current_date,e.fn.current_time=e.fn.CURRENT_TIME=$n.current_time,e.fn.extract=e.fn.EXTRACT=$n.extract,e.fn.date=e.fn.DATE=$n.date,e.fn.date_format=e.fn.DATE_FORMAT=$n.date_format,e.fn.date_add=e.fn.DATE_ADD=$n.date_add,e.fn.date_sub=e.fn.DATE_SUB=$n.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=$n.date_diff,e.fn.now=e.fn.NOW=$n.now,e.fn.offset_utc=e.fn.OFFSET_UTC=$n.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=$n.get_server_time,e.fn.getdate=e.fn.GETDATE=$n.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=$n.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=Ii.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=Ii.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=Ii.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=Ii.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=Ii.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=Ii.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=Ii.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=Ii.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=Ii.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=Ii.geoNear}});var gv=C((zye,Ev)=>{"use strict";var e_=require("lodash"),Tn=require("alasql");Tn.options.cache=!1;var p6=kp(),mv=require("clone"),Fp=require("recursive-iterator"),ke=ee(),Je=oe(),du=Vn(),E6=(k(),P(q)),{hdb_errors:g6}=me(),{getDatabases:pv}=(xe(),P(at)),S6="IS NULL",Vs="There was a problem performing this search. Please check the logs and try again.";p6(Tn);var zR=class{static{a(this,"SQLSearch")}constructor(t,r){if(Je.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(),Je.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!Je.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(Vs)}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(Vs)}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(Vs)}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(Vs)}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(Vs)}}_getColumns(){let t=new Fp(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(mv(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=e_.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].__hash_name=pv()[r.databaseid][r.tableid].primaryKey,this.data[n].__merged_data={},this.data[n].__merged_attributes=[],this.data[n].__merged_attr_map={}})}_conditionsToFetchAttributeValues(){if(Je.isEmpty(this.statement.where)){ke.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new Fp(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!Je.isEmpty(r)&&r.right)if(Je.isNotEmptyAndHasValue(r.right.value)){let n=Je.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new Tn.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=Je.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new Tn.yy.LogicValue({value:i}):n instanceof Tn.yy.StringValue&&Je.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new Tn.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 Fp(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 o=[i.table.databaseid,i.table.tableid,i.attribute].join("/");if(!Je.isEmpty(E6.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(Je.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(Je.isEmptyOrZeroLength(r.left.columnid)||Je.isEmptyOrZeroLength(r.right.value)){this.comparator_search_values[o].ignore=!0,this.comparator_search_values[o].comparators=[];continue}this.comparator_search_values[o].comparators.push({attribute:r.left.columnid,operation:r.op,search_value:r.right.value})}continue}if(Je.isEmpty(this.exact_search_values[o])&&(this.exact_search_values[o]={ignore:!1,values:new Set}),!this.exact_search_values[o].ignore){let c=!1;switch(r.op){case"=":!Je.isEmpty(r.right.value)||!Je.isEmpty(r.left.value)?n.add(Je.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[o].ignore=c,c?this.exact_search_values[o].values=new Set:this.exact_search_values[o].values=new Set([...this.exact_search_values[o].values,...n])}}}_setAliasesForColumns(){if(Je.isEmptyOrZeroLength(this.all_table_attributes)&&Je.isEmptyOrZeroLength(this.statement.from)&&Je.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&&e_.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(Je.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);Je.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(Je.isEmptyOrZeroLength(this.all_table_attributes)&&!Je.isEmptyOrZeroLength(this.columns.columns))return t;if(Je.isEmptyOrZeroLength(this.all_table_attributes)&&Je.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await Tn.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(mv(n))})}_addColumnToMergedAttributes(t,r){this.data[t].__merged_attributes.push(r),this.data[t].__merged_attr_map[r]=this.data[t].__merged_attributes.length-1}_setMergedHashAttribute(t,r){this.data[t].__merged_data[r].splice(0,1,r)}_updateMergedAttribute(t,r,n,s){let i=this.data[t].__merged_attr_map[n];this.data[t].__merged_data[r].splice(i,1,s)}async _getFetchAttributeValues(){if(Je.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(S6)>-1&&this.tables.forEach(s=>{let i={columnid:pv()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=e_.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 o=`${i.table.databaseid}_${i.table.as?i.table.as:i.table.tableid}`,c=this.data[o].__hash_name;return s[o]||(s[o]=[],s[o].push(null),this._addColumnToMergedAttributes(o,c)),i.attribute!==c&&(s[o].push(null),this._addColumnToMergedAttributes(o,i.attribute)),s},{});for(let s of this.fetch_attributes){let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`,o=this.data[i].__hash_name,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===o&&(l=!0),!Je.isEmpty(this.exact_search_values[u])&&!this.exact_search_values[u].ignore&&!Je.isEmptyOrZeroLength(this.exact_search_values[u].values))if(l)try{c.hash_values=Array.from(this.exact_search_values[u].values);let f=await du.getDataByHash(c);for(let d of c.hash_values)f.get(d)&&!this.data[i].__merged_data[d]&&(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d))}catch(f){throw ke.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),ke.error(f),new Error(Vs)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[u].values).map(async f=>{let d={...c};d.search_value=f;let _=await du.getDataByValue(d);for(let[h,m]of _)this.data[i].__merged_data[h]?this._updateMergedAttribute(i,h,s.attribute,m[s.attribute]):(this.data[i].__merged_data[h]=[...n[i]],this._updateMergedAttribute(i,h,s.attribute,m[s.attribute]),this._setMergedHashAttribute(i,h))}))}catch(f){throw ke.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),ke.error(f),new Error(Vs)}else if(!Je.isEmpty(this.comparator_search_values[u])&&!this.comparator_search_values[u].ignore&&!Je.isEmptyOrZeroLength(this.comparator_search_values[u].comparators))try{let f=this.comparator_search_values[u].comparators;for(let d=0,_=f.length;d<_;d++){let h=f[d];c.search_attribute=h.attribute,c.search_value=h.search_value;let m=await du.getDataByValue(c,h.operation);if(l)for(let[S]of m)this.data[i].__merged_data[S]||(this.data[i].__merged_data[S]=[...n[i]],this._setMergedHashAttribute(i,S));else for(let[S,g]of m)this.data[i].__merged_data[S]?this._updateMergedAttribute(i,S,s.attribute,g[s.attribute]):(this.data[i].__merged_data[S]=[...n[i]],this._updateMergedAttribute(i,S,s.attribute,g[s.attribute]),this._setMergedHashAttribute(i,S))}}catch(f){throw ke.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),ke.error(f),new Error(Vs)}else try{c.search_attribute=s.attribute,c.search_value="*";let f=await du.getDataByValue(c);if(l)for(let[d]of f)this.data[i].__merged_data[d]||(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d));else for(let[d,_]of f)this.data[i].__merged_data[d]?this._updateMergedAttribute(i,d,s.attribute,_[s.attribute]):(this.data[i].__merged_data[d]=[...n[i]],this._updateMergedAttribute(i,d,s.attribute,_[s.attribute]),this._setMergedHashAttribute(i,d))}catch(f){throw ke.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),ke.error(f),new Error(Vs)}}}_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 Tn.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,o=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===o});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 Tn.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new Tn.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 Tn.yy.FuncValue:new Tn.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}`].__merged_data)),this.statement.joins&&this.statement.joins.forEach(h=>{h.joinmode&&h.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(h.table);let m=h.joinmode+" JOIN ? AS "+(h.as?h.as:h.table.tableid);h.on&&(m+=" ON "+h.on.toString()),i.push(m),t.push(Object.values(this.data[`${h.table.databaseid_orig}_${h.table.as?h.table.as_orig:h.table.tableid_orig}`].__merged_data))});let o=[],c={};s.forEach(h=>{let m=this.data[`${h.databaseid_orig}_${h.as?h.as_orig:h.tableid_orig}`].__hash_name,S=h.as?h.as_orig:h.tableid_orig;o.push({key:`'${S}.${m}'`,schema:h.databaseid_orig,table:h.as?h.as_orig:h.tableid_orig,keys:new Set}),r.push(`${h.as?h.as:h.tableid}.\`${m}\` AS "${S}.${m}"`),c[h.as?h.as_orig:h.tableid_orig]=this.data[`${h.databaseid_orig}_${h.as?h.as_orig:h.tableid_orig}`].__merged_attributes});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 f="",d="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(f=this.statement.limit?"LIMIT "+this.statement.limit:"",d=this.statement.offset?"OFFSET "+this.statement.offset:"");let _=[];try{let h=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${l} ${u} ${f} ${d}`,m=this._convertColumnsToIndexes(h,s);_=await Tn.promise(m,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(_&&_.length>0){for(let h=0,m=_.length;h<m;h++){let S=_[h];o.forEach(g=>{S[g.key]!==null&&S[g.key]!==void 0&&g.keys.add(S[g.key])})}o.forEach(h=>{let m=Object.keys(this.data[`${h.schema}_${h.table}`].__merged_data),S=e_.difference(m,[...h.keys].map(g=>g.toString()));for(let g=0,R=S.length;g<R;g++){let E=S[g];delete this.data[`${h.schema}_${h.table}`].__merged_data[E]}})}return{existing_attributes:c,joined_length:_?_.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new Fp(this.columns);for(let{node:i}of s)if(i&&i.columnid){let o=this._findColumn(i);if(o){let c=o.table.as?o.table.as:o.table.tableid;(!t[c]||t[c].indexOf(o.attribute)<0)&&n.push(o)}}n=e_.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(Vs)}}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].__merged_data,o=[];for(let f in i)o.push(i[f][0]);this.data[n].__merged_attributes.push(...s.columns);let c={schema:s.schema,table:s.table,hash_values:o,get_attributes:s.columns},l=await du.getDataByHash(c),u=s.columns.length;for(let f=0,d=o.length;f<d;f++){let _=o[f],h=l.get(_);for(let m=0;m<u;m++){let S=s.columns[m],g=h[S]===void 0?null:h[S];this.data[n].__merged_data[_].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}`].__merged_data)),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}`].__merged_data)),s.table.databaseid="",s.table.tableid="?"}),this.statement.order&&this.statement.order.forEach(s=>{if(s.is_ordinal)return;this.statement.columns.filter(o=>{let c=o.aggregatorid?o.expression:o,l=o.aggregatorid?o.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 Tn.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(g6.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].__merged_attributes.forEach((o,c)=>{let l=s[i],u=new RegExp(`${l}.\`${o}\``,"g"),f=`${l}.[${c}]`;n=n.replace(u,f)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=new RegExp(`\`${o}\``,"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 o=await du.getDataByValue(i);for(let[c,l]of o)this.data[s].__merged_data[c]||(l[n.attribute]===void 0&&(l[n.attribute]=null),this.data[s].__merged_data[c]={...r[s]}),this.data[s].__merged_data[c][t[n.attribute]]=l[n.attribute]??null}catch(o){throw ke.error("There was an error when processing this SQL operation. Check your logs"),ke.error(o),new Error(Vs)}}return Object.values(Object.values(this.data)[0].__merged_data)}};Ev.exports=zR});var Wr=C((jye,Sv)=>{"use strict";var T6=nv();Sv.exports={searchByConditions:R6,searchByHash:y6,searchByValue:b6,search:O6};var QR=Vn(),{transformReq:jR}=oe(),A6=gv();async function R6(e){return jR(e),QR.searchByConditions(e)}a(R6,"searchByConditions");async function y6(e){jR(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of QR.searchByHash(e))r&&t.push(r);return t}a(y6,"searchByHash");async function b6(e){jR(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of QR.searchByValue(e))t.push(r);return t}a(b6,"searchByValue");function O6(e,t){try{let r=new T6(e);r.validate(),new A6(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(O6,"search")});var mo=C((Xye,yv)=>{"use strict";var t_=require("crypto"),N6=ce(),{CONFIG_PARAMS:w6}=(k(),P(q)),Av="aes-256-cbc",I6=32,C6=16,JR=64,Rv=32,P6=JR+Rv,Tv=new Map;yv.exports={encrypt:D6,decrypt:L6,createNatsTableStreamName:M6};function D6(e){let t=t_.randomBytes(I6),r=t_.randomBytes(C6),n=t_.createCipheriv(Av,Buffer.from(t),r),s=n.update(e);s=Buffer.concat([s,n.final()]);let i=t.toString("hex"),o=r.toString("hex"),c=s.toString("hex");return i+o+c}a(D6,"encrypt");function L6(e){let t=e.substr(0,JR),r=e.substr(JR,Rv),n=e.substr(P6,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=t_.createDecipheriv(Av,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(L6,"decrypt");function M6(e,t){let r=N6.get(w6.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=Tv.get(r);return n||(n=t_.createHash("md5").update(r).digest("hex"),Tv.set(r,n)),n}a(M6,"createNatsTableStreamName")});var po=C((tbe,wv)=>{"use strict";var ebe=Wr(),r_=ee(),{validateBySchema:bv}=st(),Bc=require("joi"),v6=mo(),Gp=oe(),{handleHDBError:qp,hdb_errors:U6,ClientError:Ov}=me(),{HDB_ERROR_MSGS:$p,HTTP_STATUS_CODES:XR}=U6,Nv=ce();Nv.initSync();var{getDatabases:ZR}=(xe(),P(at)),x6=require("fs-extra"),B6=(k(),P(q));wv.exports={describeAll:H6,describeTable:Vp,describeSchema:k6};async function H6(e={}){try{let t=Gp.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=ZR(),o={},c={},l=[],u=e?.exact_count;for(let d in i){o[d]=!0,!t&&!s&&!r&&(c[d]=e.hdb_user?.role?.permission[d]?.describe);let _=i[d];for(let h in _)try{let m;if(t||s||r)m=await Vp({schema:d,table:h,exact_count:u});else if(n&&n[d].describe&&n[d].tables[h].describe){let S=n[d].tables[h].attribute_permissions;m=await Vp({schema:d,table:h,exact_count:u},S)}m&&l.push(m)}catch(m){r_.error(m)}}let f={};for(let d in l)t||s||r?(f[l[d].schema]==null&&(f[l[d].schema]={}),f[l[d].schema][l[d].name]=l[d],o[l[d].schema]&&delete o[l[d].schema]):c[l[d].schema]&&(f[l[d].schema]==null&&(f[l[d].schema]={}),f[l[d].schema][l[d].name]=l[d],o[l[d].schema]&&delete o[l[d].schema]);for(let d in o)t||s||r?f[d]={}:c[d]&&(f[d]={});return f}catch(t){return r_.error("Got an error in describeAll"),r_.error(t),qp(new Error,$p.DESCRIBE_ALL_ERR)}}a(H6,"describeAll");async function Vp(e,t){Gp.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=bv(e,Bc.object({database:Bc.string(),table:Bc.string().required(),exact_count:Bc.boolean().strict()}));if(i)throw new Ov(i.message);let c=ZR()[r];if(!c)throw qp(new Error,$p.SCHEMA_NOT_FOUND(e.schema),XR.NOT_FOUND);let l=c[n];if(!l)throw qp(new Error,$p.TABLE_NOT_FOUND(e.schema,e.table),XR.NOT_FOUND);function u(h){f.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(m=>({type:m.type,name:m.name})):void 0})}a(u,"pushAtt");let f=[];if(s){let h={};s.forEach(m=>{m.describe&&(h[m.attribute_name]=!0)}),l.attributes.forEach(m=>{h[m.name]&&u(m)})}else l.attributes?.forEach(h=>u(h));let d;try{d=(await x6.stat(l.primaryStore.env.path)).size}catch(h){r_.warn("unable to get database size",h)}let _={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:f,db_size:d};l.replicate!==void 0&&(_.replicate=l.replicate),l.expirationMS!==void 0&&(_.expiration=l.expirationMS/1e3+"s"),l.sealed!==void 0&&(_.sealed=l.sealed),l.sources?.length>0&&(_.sources=l.sources.map(h=>h.name).filter(h=>h&&h!=="NATSReplicator"&&h!=="Replicator")),Nv.get(B6.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(_.clustering_stream_name=v6.createNatsTableStreamName(_.schema,_.name));try{let h=await l.getRecordCount({exactCount:!!e.exact_count});_.record_count=h.recordCount,_.table_size=l.getSize(),_.db_audit_size=l.getAuditSize(),_.estimated_record_range=h.estimatedRange;let m=l.auditStore;if(m)for(let S of m.getKeys({reverse:!0,limit:1}))_.last_updated_record=S[0];if(!_.last_updated_record&&l.indices.__updatedtime__)for(let S of l.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))_.last_updated_record=S}catch(h){r_.warn(`unable to stat table dbi due to ${h}`)}return _}a(Vp,"descTable");async function k6(e){Gp.transformReq(e);let t=bv(e,Bc.object({database:Bc.string(),exact_count:Bc.boolean().strict()}));if(t)throw new Ov(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=ZR()[n];if(!i)throw qp(new Error,$p.SCHEMA_NOT_FOUND(e.schema),XR.NOT_FOUND);let o={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),Gp.isEmpty(l)||l.describe){let u=await Vp({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);u&&(o[u.name]=u)}}return o}a(k6,"describeSchema")});var ps=C((ibe,Lv)=>{var F6=fo(),{callbackify:Cv,promisify:G6}=require("util"),{getDatabases:Pv}=(xe(),P(at));Lv.exports={setSchemaDataToGlobal:Iv,getTableSchema:q6,getSystemSchema:$6,setSchemaDataToGlobalAsync:G6(Iv)};var Dv=po(),nbe=Cv(Dv.describeAll),sbe=Cv(Dv.describeTable);function Iv(e){global.hdb_schema=Pv(),e&&e()}a(Iv,"setSchemaDataToGlobal");function q6(e,t,r){let n=Pv()[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`)}a(q6,"getTableSchema");function $6(){return F6}a($6,"getSystemSchema")});var ty=C((abe,Uv)=>{var V6=st(),ey=require("joi"),{hdb_table:K6,hdb_database:Mv}=Ni(),vv={schema:Mv,database:Mv,table:K6},Y6={date:ey.date().iso().required()},W6={timestamp:ey.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};Uv.exports=function(e,t){let r=t==="timestamp"?{...vv,...W6}:{...vv,...Y6},n=ey.object(r);return V6.validateBySchema(e,n)}});var Hv=C((cbe,Bv)=>{var z6=st(),ry=require("joi"),{hdb_table:Q6,hdb_database:xv}=Ni(),j6=ry.object({schema:xv,database:xv,table:Q6,hash_values:ry.array().required(),ids:ry.array()});Bv.exports=function(e){return z6.validateBySchema(e,j6)}});var oy=C((lbe,kv)=>{"use strict";var ny=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i){this.operation=t,this.schema=r,this.table=n,this.hash_attribute=s,this.records=i}},sy=class{static{a(this,"NoSQLSeachObject")}constructor(t,r,n,s,i,o){this.schema=t,this.table=r,this.search_attribute=n,this.hash_attribute=s,this.get_attributes=i,this.search_value=o}},iy=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};kv.exports={InsertObject:ny,NoSQLSeachObject:sy,DeleteResponseObject:iy}});var Fc=C((dbe,Vv)=>{"use strict";var Gv=ty(),J6=Hv(),Hc=oe(),Fv=require("moment"),qv=ee(),{promisify:X6,callbackify:Z6}=require("util"),kc=(k(),P(q)),eZ=ps(),ay=X6(eZ.getTableSchema),cy=Vn(),{DeleteResponseObject:tZ}=oy(),{handleHDBError:_a,hdb_errors:rZ}=me(),{HDB_ERROR_MSGS:Kp,HTTP_STATUS_CODES:ha}=rZ,nZ="records successfully deleted",sZ=Z6($v);Vv.exports={delete:sZ,deleteRecord:$v,deleteFilesBefore:iZ,deleteAuditLogsBefore:oZ};async function iZ(e){let t=Gv(e,"date");if(t)throw _a(t,t.message,ha.BAD_REQUEST,void 0,void 0,!0);if(Hc.transformReq(e),!Fv(e.date,Fv.ISO_8601).isValid())throw _a(new Error,Kp.INVALID_DATE,ha.BAD_REQUEST,kc.LOG_LEVELS.ERROR,Kp.INVALID_DATE,!0);let n=Hc.checkSchemaTableExist(e.schema,e.table);if(n)throw _a(new Error,n,ha.NOT_FOUND,kc.LOG_LEVELS.ERROR,n,!0);let s=await cy.deleteRecordsBefore(e);if(await ay(e.schema,e.table),qv.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(iZ,"deleteFilesBefore");async function oZ(e){let t=Gv(e,"timestamp");if(t)throw _a(t,t.message,ha.BAD_REQUEST,void 0,void 0,!0);if(Hc.transformReq(e),isNaN(e.timestamp))throw _a(new Error,Kp.INVALID_VALUE("Timestamp"),ha.BAD_REQUEST,kc.LOG_LEVELS.ERROR,Kp.INVALID_VALUE("Timestamp"),!0);let r=Hc.checkSchemaTableExist(e.schema,e.table);if(r)throw _a(new Error,r,ha.NOT_FOUND,kc.LOG_LEVELS.ERROR,r,!0);let n=await cy.deleteAuditLogsBefore(e);return await ay(e.schema,e.table),qv.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(oZ,"deleteAuditLogsBefore");async function $v(e){e.ids&&(e.hash_values=e.ids);let t=J6(e);if(t)throw _a(t,t.message,ha.BAD_REQUEST,void 0,void 0,!0);Hc.transformReq(e);let r=Hc.checkSchemaTableExist(e.schema,e.table);if(r)throw _a(new Error,r,ha.NOT_FOUND,kc.LOG_LEVELS.ERROR,r,!0);try{await ay(e.schema,e.table);let n=await cy.deleteRecords(e);return Hc.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${nZ}`),n}catch(n){if(n.message===kc.SEARCH_NOT_FOUND_MESSAGE){let s=new tZ;return s.message=kc.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a($v,"deleteRecord")});var Yp={};Ue(Yp,{HASH_FUNCTION:()=>i_,hash:()=>dy,validate:()=>fy});function ly(e=s_){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ";return Array.from(n_.randomBytes(e)).map(r=>t[r%t.length]).join("")}function dy(e,t=i_[Yv?.toUpperCase()]??"sha256"){return uy[t](e)}function fy(e,t,r=i_[Yv?.toUpperCase()]??"sha256"){return e?aZ[r](e,t):!1}var n_,fu,Kv,Yv,s_,Wv,i_,uy,aZ,Wp=Re(()=>{n_=M(require("node:crypto")),fu=M(require("argon2")),Kv=M(ce());k();Yv=(0,Kv.get)(B.AUTHENTICATION_HASHFUNCTION)?.toLowerCase(),s_=16,Wv=9,i_=(n=>(n.MD5="md5",n.SHA256="sha256",n.ARGON2ID="argon2id",n))(i_||{});a(ly,"generateSalt");uy={md5:a((e,t=void 0)=>{t=t??ly(Wv);let r=n_.createHash("md5").update(e+t).digest("hex");return t+r},"md5"),sha256:a((e,t=void 0)=>{t=t??ly(s_);let r=n_.createHash("sha256").update(e+t).digest("hex");return t+r},"sha256"),argon2id:a(async e=>{let t=ly(s_),r=await fu.hash(e,{type:fu.argon2id,salt:Buffer.from(t)});return t+r},"argon2id")},aZ={md5:a((e,t)=>{let r=e.slice(0,Wv);return e===uy.md5(t,r)},"md5"),sha256:a((e,t)=>{let r=e.slice(0,s_);return e===uy.sha256(t,r)},"sha256"),argon2id:a(async(e,t)=>await fu.verify(e.slice(s_),t),"argon2id")};a(dy,"hash");a(fy,"validate")});var Qv=C((mbe,zv)=>{var _y=st(),zr={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 cZ(e){return zr.password.presence=!0,zr.username.presence=!0,zr.role.presence=!0,zr.active.presence=!0,_y.validateObject(e,zr)}a(cZ,"addUserValidation");function lZ(e){return zr.password.presence=!1,zr.username.presence=!0,zr.role.presence=!1,zr.active.presence=!1,_y.validateObject(e,zr)}a(lZ,"alterUserValidation");function uZ(e){return zr.password.presence=!1,zr.username.presence=!0,zr.role.presence=!1,zr.active.presence=!1,_y.validateObject(e,zr)}a(uZ,"dropUserValidation");zv.exports={addUserValidation:cZ,alterUserValidation:lZ,dropUserValidation:uZ}});var Pt=C((gbe,Jv)=>{"use strict";var{platform:Ebe}=require("os"),dZ="nats-server.zip",hy="nats-server",fZ=process.platform==="win32"?`${hy}.exe`:hy,_Z=/^[^\s.,*>]+$/,jv="__request__",hZ=a(e=>`${e}.${jv}`,"REQUEST_SUBJECT"),mZ={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},pZ={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},EZ={HUB:"hub.pid",LEAF:"leaf.pid"},gZ={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},SZ={SUCCESS:"success",ERROR:"error"},TZ={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},AZ={TXN:"txn",MSGID:"msgid"},_u={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},RZ={[_u.ERR]:1,[_u.WRN]:2,[_u.INF]:3,[_u.DBG]:4,[_u.TRC]:5},yZ={debug:"-D",trace:"-DVV"};Jv.exports={NATS_SERVER_ZIP:dZ,NATS_SERVER_NAME:hy,NATS_BINARY_NAME:fZ,PID_FILES:EZ,NATS_CONFIG_FILES:pZ,SERVER_SUFFIX:gZ,NATS_TERM_CONSTRAINTS_RX:_Z,REQUEST_SUFFIX:jv,UPDATE_REMOTE_RESPONSE_STATUSES:SZ,CLUSTER_STATUS_STATUSES:TZ,REQUEST_SUBJECT:hZ,SUBJECT_PREFIXES:AZ,MSG_HEADERS:mZ,LOG_LEVELS:_u,LOG_LEVEL_FLAGS:yZ,LOG_LEVEL_HIERARCHY:RZ}});var Kn=C((Tbe,Nr)=>{"use strict";var eU="username is required",tU="nothing to update, must supply active, role or password to update",rU="password cannot be an empty string",nU="If role is specified, it cannot be empty.",sU="active must be true or false";Nr.exports.addUser=LZ;Nr.exports.alterUser=MZ;Nr.exports.dropUser=UZ;Nr.exports.getSuperUser=FZ;Nr.exports.userInfo=xZ;Nr.exports.listUsers=Qp;Nr.exports.listUsersExternal=BZ;Nr.exports.setUsersWithRolesCache=Gc;Nr.exports.findAndValidateUser=yy;Nr.exports.getClusterUser=GZ;Nr.exports.getUsersWithRolesCache=kZ;Nr.exports.USERNAME_REQUIRED=eU;Nr.exports.ALTERUSER_NOTHING_TO_UPDATE=tU;Nr.exports.EMPTY_PASSWORD=rU;Nr.exports.EMPTY_ROLE=nU;Nr.exports.ACTIVE_BOOLEAN=sU;var iU=An(),bZ=Fc(),o_=(Wp(),P(Yp)),oU=Qv(),a_=Wr(),Sy=go(),Ci=oe(),aU=require("validate.js"),Ty=ee(),{promisify:OZ}=require("util"),Ay=mo(),py=(k(),P(q)),Xv=Pt(),NZ=It(),wZ=ce(),IZ=fo(),{hdb_errors:CZ,ClientError:Ks}=me(),{HTTP_STATUS_CODES:Eo,AUTHENTICATION_ERROR_MSGS:my,HDB_ERROR_MSGS:hu}=CZ,{UserEventMsg:Ry}=Ys(),Ey=require("lodash"),{server:zp}=(Mr(),P(Wl)),PZ=ee();zp.getUser=(e,t)=>yy(e,t,t!=null);zp.authenticateUser=(e,t)=>yy(e,t);var cU={username:!0,active:!0,role:!0,password:!0},Zv=new Map,DZ=OZ(bZ.delete),gy=wZ.get(py.CONFIG_PARAMS.AUTHENTICATION_HASHFUNCTION)??o_.HASH_FUNCTION.SHA256,Pi;async function LZ(e){let t=aU.cleanAttributes(e,cU),r=oU.addUserValidation(t);if(r)throw new Ks(r.message);let n=await a_.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 Ks(hu.ROLE_NAME_NOT_FOUND(t.role),Eo.NOT_FOUND);if(n.length>1)throw new Ks(hu.DUP_ROLES_FOUND(t.role),Eo.CONFLICT);n[0].permission.cluster_user===!0&&(t.hash=Ay.encrypt(t.password)),t.password=await o_.hash(t.password,gy),t.hash_function=gy,t.role=n[0].id;let s=await iU.insert({operation:"insert",schema:"system",table:"hdb_user",records:[t]});if(Ty.debug(s),await Gc(),s.skipped_hashes.length===1)throw new Ks(hu.USER_ALREADY_EXISTS(t.username),Eo.CONFLICT);return Sy.signalUserChange(new Ry(process.pid)),`${t.username} successfully added`}a(LZ,"addUser");async function MZ(e){let t=aU.cleanAttributes(e,cU);if(Ci.isEmptyOrZeroLength(t.username))throw new Error(eU);if(Ci.isEmptyOrZeroLength(t.password)&&Ci.isEmptyOrZeroLength(t.role)&&Ci.isEmptyOrZeroLength(t.active))throw new Error(tU);if(!Ci.isEmpty(t.password)&&Ci.isEmptyOrZeroLength(t.password.trim()))throw new Error(rU);if(!Ci.isEmpty(t.active)&&!Ci.isBoolean(t.active))throw new Error(sU);if(!Ci.isEmpty(t.password)&&!Ci.isEmptyOrZeroLength(t.password.trim())&&(vZ(t.username)&&(t.hash=Ay.encrypt(t.password)),t.password=await o_.hash(t.password,gy)),t.role==="")throw new Error(nU);if(t.role){let n=await a_.searchByValue({schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]});if(!n||n.length===0)throw new Ks(hu.ALTER_USER_ROLE_NOT_FOUND(t.role),Eo.NOT_FOUND);if(n.length>1)throw new Ks(hu.DUP_ROLES_FOUND(t.role),Eo.CONFLICT);t.role=n[0].id}let r=await iU.update({operation:"update",schema:"system",table:"hdb_user",records:[t]});return await Gc(),Sy.signalUserChange(new Ry(process.pid)),r}a(MZ,"alterUser");function vZ(e){let t=!1,r=Pi.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(vZ,"isClusterUser");async function UZ(e){let t=oU.dropUserValidation(e);if(t)throw new Ks(t.message);if(Pi.get(e.username)===void 0)throw new Ks(hu.USER_NOT_EXIST(e.username),Eo.NOT_FOUND);let r=await DZ({table:"hdb_user",schema:"system",hash_values:[e.username]});return Ty.debug(r),await Gc(),Sy.signalUserChange(new Ry(process.pid)),`${e.username} successfully deleted`}a(UZ,"dropUser");async function xZ(e){let t={};if(!e||!e.hdb_user)return"There was no user info in the body";t=Ey.cloneDeep(e.hdb_user);let r=await a_.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}a(xZ,"userInfo");async function BZ(){let e=await Qp();return e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token,delete t.hash_function}),[...e.values()]}a(BZ,"listUsersExternal");async function Qp(){let e=await a_.searchByValue({schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]}),t={};for(let s of e)t[s.id]=Ey.cloneDeep(s);if(Object.keys(t).length===0)return null;let r=await a_.searchByValue({schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]}),n=new Map;for(let s of r)s=Ey.cloneDeep(s),s.role=t[s.role],HZ(s.role),n.set(s.username,s);return n}a(Qp,"listUsers");function HZ(e){if(!e){Ty.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(IZ)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}a(HZ,"appendSystemTablesToRole");async function Gc(e=void 0){e?Pi=e:Pi=await Qp()}a(Gc,"setUsersWithRolesCache");async function kZ(){return Pi||await Gc(),Pi}a(kZ,"getUsersWithRolesCache");async function yy(e,t,r=!0){Pi||await Gc();let n=Pi.get(e);if(!n){if(!r)return{username:e};throw new Ks(my.GENERIC_AUTH_FAIL,Eo.UNAUTHORIZED)}if(n&&!n.active)throw new Ks(my.USER_INACTIVE,Eo.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(Zv.get(t)===n.password)return s;{let i=o_.validate(n.password,t,n.hash_function||o_.HASH_FUNCTION.MD5);if(i?.then&&(i=await i),i===!0)Zv.set(t,n.password);else throw new Ks(my.GENERIC_AUTH_FAIL,Eo.UNAUTHORIZED)}}return s}a(yy,"findAndValidateUser");async function FZ(){Pi||await Gc();for(let[,e]of Pi)if(e.role.role==="super_user")return e}a(FZ,"getSuperUser");async function GZ(){let e=await Qp(),t=NZ.getConfigFromFile(py.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!(r==null||r?.role?.role!==py.ROLE_TYPES_ENUM.CLUSTER_USER))return r.decrypt_hash=Ay.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+Xv.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+Xv.SERVER_SUFFIX.ADMIN,r}a(GZ,"getClusterUser");var lU=[];zp.invalidateUser=function(e){for(let t of lU)try{t(e)}catch(r){PZ.error("Error invalidating user",r)}};zp.onInvalidatedUser=function(e){lU.push(e)}});var l_=C((bbe,_U)=>{"use strict";var qc=ee(),Yn=(k(),P(q)),qZ=VM(),Rbe=ps(),ybe=po(),$Z=Kn(),{validateEvent:uU}=Ys(),c_=Vn(),VZ=require("process"),{resetDatabases:KZ}=(xe(),P(at)),YZ={[Yn.ITC_EVENT_TYPES.SCHEMA]:WZ,[Yn.ITC_EVENT_TYPES.USER]:fU};async function WZ(e){let t=uU(e);if(t){qc.error(t);return}qc.trace("ITC schemaHandler received schema event:",e),await qZ(e.message),await zZ(e.message)}a(WZ,"schemaHandler");async function zZ(e){try{c_.resetReadTxn(Yn.SYSTEM_SCHEMA_NAME,Yn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),c_.resetReadTxn(Yn.SYSTEM_SCHEMA_NAME,Yn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),c_.resetReadTxn(Yn.SYSTEM_SCHEMA_NAME,Yn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=KZ();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){qc.error(t)}}a(zZ,"syncSchemaMetadata");var dU=[];async function fU(e){try{try{c_.resetReadTxn(Yn.SYSTEM_SCHEMA_NAME,Yn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),c_.resetReadTxn(Yn.SYSTEM_SCHEMA_NAME,Yn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){qc.warn(r)}let t=uU(e);if(t){qc.error(t);return}qc.trace(`ITC userHandler ${Yn.HDB_ITC_CLIENT_PREFIX}${VZ.pid} received user event:`,e),await $Z.setUsersWithRolesCache();for(let r of dU)r()}catch(t){qc.error(t)}}a(fU,"userHandler");fU.addListener=function(e){dU.push(e)};_U.exports=YZ});var Ys=C((Pbe,mU)=>{"use strict";var Nbe=ee(),by=oe(),QZ=(k(),P(q)),{ITC_ERRORS:u_}=Un(),{parentPort:wbe,threadId:jZ,isMainThread:JZ,workerData:Ibe}=require("worker_threads"),{onMessageFromWorkers:XZ,broadcast:Cbe,broadcastWithAcknowledgement:ZZ}=it();mU.exports={sendItcEvent:e8,validateEvent:hU,SchemaEventMsg:t8,UserEventMsg:r8};var jp;XZ(async(e,t)=>{jp=jp||l_(),hU(e),jp[e.type]&&await jp[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function e8(e){return!JZ&&e.message&&(e.message.originator=jZ),ZZ(e)}a(e8,"sendItcEvent");function hU(e){if(typeof e!="object")return u_.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||by.isEmpty(e.type))return u_.MISSING_TYPE;if(!e.hasOwnProperty("message")||by.isEmpty(e.message))return u_.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||by.isEmpty(e.message.originator))return u_.MISSING_ORIGIN;if(QZ.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return u_.INVALID_EVENT(e.type)}a(hU,"validateEvent");function t8(e,t,r,n=void 0,s=void 0){this.originator=e,this.operation=t,this.schema=r,this.table=n,this.attribute=s}a(t8,"SchemaEventMsg");function r8(e){this.originator=e}a(r8,"UserEventMsg")});var go=C((Mbe,SU)=>{"use strict";var pU=(k(),P(q)),Lbe=oe(),Jp=ee(),EU=GM(),mu,{sendItcEvent:gU}=Ys();function n8(e){try{Jp.info("signalSchemaChange called with message:",e),mu=mu||l_();let t=new EU(pU.ITC_EVENT_TYPES.SCHEMA,e);return mu.schema(t),gU(t)}catch(t){Jp.error(t)}}a(n8,"signalSchemaChange");function s8(e){try{Jp.trace("signalUserChange called with message:",e),mu=mu||l_();let t=new EU(pU.ITC_EVENT_TYPES.USER,e);return mu.user(t),gU(t)}catch(t){Jp.error(t)}}a(s8,"signalUserChange");SU.exports={signalSchemaChange:n8,signalUserChange:s8}});var Xp=C((Ube,AU)=>{"use strict";var TU=oe(),i8=(k(),P(q)),o8=ee(),a8=Bp(),c8=xp(),l8=go(),{SchemaEventMsg:u8}=Ys(),d8="already exists in";AU.exports=f8;async function f8(e,t,r){if(TU.isEmptyOrZeroLength(r))return r;let n=[];TU.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 _8(e,t.schema,t.name,i)})),s}a(f8,"lmdbCheckForNewAttributes");async function _8(e,t,r,n){let s=new c8(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await h8(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(d8))o8.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(_8,"createNewAttribute");async function h8(e){let t;return t=await a8(e),l8.signalSchemaChange(new u8(process.pid,i8.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(h8,"createAttribute")});var pu=C((Bbe,RU)=>{"use strict";var Oy=class{static{a(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}};RU.exports=Oy});var bU=C((kbe,yU)=>{"use strict";var m8=pu(),p8=(k(),P(q)).OPERATIONS_ENUM,Ny=class extends m8{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(p8.INSERT,r,n,s,i),this.records=t}};yU.exports=Ny});var NU=C((Gbe,OU)=>{"use strict";var E8=pu(),g8=(k(),P(q)).OPERATIONS_ENUM,wy=class extends E8{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(g8.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};OU.exports=wy});var IU=C(($be,wU)=>{"use strict";var S8=pu(),T8=(k(),P(q)).OPERATIONS_ENUM,Iy=class extends S8{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(T8.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};wU.exports=Iy});var PU=C((Kbe,CU)=>{"use strict";var A8=pu(),R8=(k(),P(q)).OPERATIONS_ENUM,Cy=class extends A8{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(R8.DELETE,n,s,t,i),this.original_records=r}};CU.exports=Cy});var d_=C((zbe,vU)=>{"use strict";var Wbe=require("path"),DU=_t(),y8=bU(),b8=NU(),O8=IU(),N8=PU(),Eu=kt(),LU=oe(),{CONFIG_PARAMS:w8}=(k(),P(q)),MU=ce();MU.initSync();var Zp=(k(),P(q)).OPERATIONS_ENUM,{getTransactionAuditStorePath:I8}=Et();vU.exports=C8;async function C8(e,t){if(MU.get(w8.LOGGING_AUDITLOG)===!1)return;let r=I8(e.schema,e.table),n=await DU.openEnvironment(r,e.table,!0),s=P8(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){DU.initializeDBIs(n,Eu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Eu.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[Eu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[Eu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),LU.isEmpty(s.user_name)||n.dbis[Eu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[Eu.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(C8,"writeTransaction");function P8(e,t){let r=LU.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===Zp.INSERT)return new y8(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Zp.UPDATE)return new b8(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Zp.UPSERT)return new O8(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Zp.DELETE)return new N8(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(P8,"createTransactionObject")});var Py=C((Jbe,UU)=>{"use strict";var D8=jf(),jbe=yf(),f_=(k(),P(q)),L8=bf(),M8=vc().insertRecords,v8=_t(),U8=ee(),x8=Xp(),{getSchemaPath:B8}=Et(),H8=d_();UU.exports=k8;async function k8(e){try{let{schema_table:t,attributes:r}=D8(e);L8(e,r,t.hash_attribute),e.schema!==f_.SYSTEM_SCHEMA_NAME&&(r.includes(f_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(f_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(f_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(f_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await x8(e.hdb_auth_header,t,r),s=B8(e.schema,e.table),i=await v8.openEnvironment(s,e.table),o=await M8(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await H8(e,o)}catch(c){U8.error(`unable to write transaction due to ${c.message}`)}return{written_hashes:o.written_hashes,skipped_hashes:o.skipped_hashes,schema_table:t,new_attributes:n,txn_time:o.txn_time}}catch(t){throw t}}a(k8,"lmdbCreateRecords")});var HU=C((Zbe,BU)=>{"use strict";var xU=(k(),P(q)),F8=Py(),G8=yf(),q8=require("fs-extra"),{getSchemaPath:$8}=Et();BU.exports=V8;async function V8(e){let t=[{name:e.schema,createddate:Date.now()}],r=new G8(xU.SYSTEM_SCHEMA_NAME,xU.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await F8(r),await q8.mkdirp($8(e.schema))}a(V8,"lmdbCreateSchema")});var FU=C((tOe,kU)=>{"use strict";var Dy=class{static{a(this,"DeleteRecordsResponseObject")}constructor(t=[],r=[],n=void 0,s=[]){this.deleted=t,this.skipped=r,this.txn_time=n,this.original_records=s}};kU.exports=Dy});var VU=C((oOe,$U)=>{"use strict";var GU=_t(),Ly=fn(),My=Un().LMDB_ERRORS_ENUM,K8=kt(),qU=ee(),nOe=oe(),Y8=require("lmdb"),W8=FU(),z8=(k(),P(q)),{OVERFLOW_MARKER:sOe,MAX_SEARCH_KEY_LENGTH:iOe}=K8,Q8=z8.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function j8(e,t,r,n){if(Ly.validateEnv(e),t===void 0)throw new Error(My.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(My.IDS_REQUIRED):new Error(My.IDS_MUST_BE_ITERABLE);try{let s=GU.listDBIs(e);GU.initializeDBIs(e,t,s);let i=new W8,o,c=[],l=[];for(let _=0,h=r.length;_<h;_++)try{o=r[_];let m=e.dbis[t].get(o);if(!m||n&&m[Q8]>n){i.skipped.push(o);continue}let S=e.dbis[t].ifVersion(o,Y8.IF_EXISTS,()=>{e.dbis[t].remove(o);for(let g=0;g<s.length;g++){let R=s[g];if(!m.hasOwnProperty(R)||R===t)continue;let E=e.dbis[R],T=m[R];if(T!=null)try{let N=Ly.getIndexedValues(T);if(N)for(let v=0,H=N.length;v<H;v++)E.remove(N[v],o)}catch{qU.warn(`cannot delete from attribute: ${R}, ${T}:${o}`)}}});c.push(S),l.push(o),i.original_records.push(m)}catch(m){qU.warn(m),i.skipped.push(o)}let u=[],f=await Promise.all(c);for(let _=0,h=f.length;_<h;_++)f[_]===!0?i.deleted.push(l[_]):(i.skipped.push(l[_]),u.push(_));let d=0;for(let _=0;_<u.length;_++){let h=u[_];i.original_records.splice(h-d,1),d++}return i.txn_time=Ly.getNextMonotonicTime(),i}catch(s){throw s}}a(j8,"deleteRecords");$U.exports={deleteRecords:j8}});var __=C((cOe,YU)=>{"use strict";var gu=oe(),J8=VU(),X8=_t(),{getSchemaPath:Z8}=Et(),e5=d_(),t5=ee();YU.exports=r5;async function r5(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(gu.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(gu.isEmptyOrZeroLength(e.hash_values)&&!gu.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];gu.isEmpty(l)||e.hash_values.push(l)}}if(gu.isEmptyOrZeroLength(e.hash_values))return KU([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(gu.isEmptyOrZeroLength(e.records)){e.records=[];for(let c=0;c<e.hash_values.length;c++)e.records[c]={[n]:e.hash_values[c]}}let s=Z8(e.schema,e.table),i=await X8.openEnvironment(s,e.table),o=await J8.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await e5(e,o)}catch(c){t5.error(`unable to write transaction due to ${c.message}`)}return KU(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(r5,"lmdbDeleteRecords");function KU(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}}a(KU,"createDeleteResponse")});var Uy=C((dOe,WU)=>{"use strict";var n5=(k(),P(q)),uOe=fn();function vy(e,t){let r=Object.create(null);if(t.length===1&&n5.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}a(vy,"parseRow");function s5(e,t,r,n){let s=vy(r,e);n.push(s)}a(s5,"searchAll");function i5(e,t,r,n){let s=vy(r,e);n[t]=s}a(i5,"searchAllToMap");function o5(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(o5,"iterateDBI");function $c(e,t,r,n,s){let i=Object.create(null);i[s]=e;let o;n===s?o=e:(o=t,n!==void 0&&(i[n]=o)),r[0].push(o),r[1].push(i)}a($c,"pushResults");function a5(e,t,r,n,s,i){t.toString().endsWith(e)&&$c(t,r,n,s,i)}a(a5,"endsWith");function c5(e,t,r,n,s,i){t.toString().includes(e)&&$c(t,r,n,s,i)}a(c5,"contains");function l5(e,t,r,n,s,i){t>e&&$c(t,r,n,s,i)}a(l5,"greaterThanCompare");function u5(e,t,r,n,s,i){t>=e&&$c(t,r,n,s,i)}a(u5,"greaterThanEqualCompare");function d5(e,t,r,n,s,i){t<e&&$c(t,r,n,s,i)}a(d5,"lessThanCompare");function f5(e,t,r,n,s,i){t<=e&&$c(t,r,n,s,i)}a(f5,"lessThanEqualCompare");WU.exports={parseRow:vy,searchAll:s5,searchAllToMap:i5,iterateDBI:o5,endsWith:a5,contains:c5,greaterThanCompare:l5,greaterThanEqualCompare:u5,lessThanCompare:d5,lessThanEqualCompare:f5,pushResults:$c}});var Su=C((pOe,e0)=>{"use strict";var ma=_t(),_Oe=ee(),Wn=fn(),eE=kt(),zt=Un().LMDB_ERRORS_ENUM,hOe=oe(),_5=(k(),P(q)),tE=Uy(),{parseRow:h5}=tE,mOe=require("lmdb"),{OVERFLOW_MARKER:zU,MAX_SEARCH_KEY_LENGTH:m5}=eE;function QU(e,t,r,n=!1,s=void 0,i=void 0){return Vc(e,t,r,(o,c)=>c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}))}a(QU,"iterateFullIndex");function h_(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,u=!1){return Vc(e,t,r,(f,d,_,h)=>{let E={transaction:f,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!l:!u,exclusiveStart:i===!0?u:l};return h===r?(E.values=!1,d.getRange(E).map(T=>({value:T}))):d.getRange(E)})}a(h_,"iterateRangeBetween");function Vc(e,t,r,n){let s=e.database||e,i=ma.openDBI(s,r);i[eE.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&ma.openDBI(s,t);let o;e.database?o=e:(o=e.useReadTransaction(),o.database=e);let c=n(o,i,s,t);return c.transaction=o,e.database||(c.onDone=()=>{o.done()}),c}a(Vc,"setupTransaction");function jU(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(zU)){if(!s)if(r)s=ma.openDBI(e,r);else{let l=ma.listDBIs(e);for(let u=0,f=l.length;u<f&&(s=ma.openDBI(e,l[u]),!s[eE.DBI_DEFINITION_NAME].is_hash_attribute);u++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(jU,"getOverflowCheck");function p5(e,t,r,n=!1,s=void 0,i=void 0){if(Wn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);return Vc(e,t,t,(o,c,l)=>(rE(r),r=m_(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(u=>h5(u.value,r))))}a(p5,"searchAll");function E5(e,t,r,n=!1,s=void 0,i=void 0){if(Wn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);rE(r),r=m_(e.database||e,r);let o=new Map;for(let{key:c,value:l}of QU(e,t,t,n,s,i))o.set(c,tE.parseRow(l,r));return o}a(E5,"searchAllToMap");function g5(e,t,r=!1,n=void 0,s=void 0){if(Wn.validateEnv(e),t===void 0)throw new Error(zt.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=QU(e,void 0,t,r,n,s),c=o.transaction,l=jU(c.database,c,void 0,t);for(let{key:u,value:f}of o){let d=l(u,f);i[d]===void 0&&(i[d]=[]),i[d].push(f)}return i}a(g5,"iterateDBI");function S5(e,t){if(Wn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);return ma.statDBI(e,t).entryCount}a(S5,"countAll");function T5(e,t,r,n,s=!1,i=void 0,o=void 0){return pa(e,r,n),Vc(e,t,r,(c,l,u,f)=>(n=Wn.convertKeyValueToWrite(n),f===r?l.get(n,{transaction:c,lazy:!0})===void 0?[]:[{key:n,value:n}]:l.getValues(n,{transaction:c,reverse:s,limit:i,offset:o}).map(d=>({key:n,value:d}))))}a(T5,"equals");function A5(e,t,r){return pa(e,t,r),ma.openDBI(e,t).getValuesCount(r)}a(A5,"count");function R5(e,t,r,n,s=!1,i=void 0,o=void 0){return pa(e,r,n),Vc(e,null,r,(c,l)=>{n=Wn.convertKeyValueToWrite(n);let u=!0;typeof n=="number"&&(u=!1);let f;if(s===!0){let d;for(let _ of l.getKeys({transaction:c,start:n}))if(!_.startsWith(n)){d=_;break}return d!==void 0&&(Number.isInteger(o)?o++:i++),f=l.getRange({transaction:c,start:d,end:void 0,reverse:s,limit:i,offset:o}).map(_=>{let{key:h}=_;if(h!==d){if(h.toString().startsWith(n))return _;if(u===!0)return f.DONE}}),f.filter(_=>_)}else return f=l.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(d=>{if(d.key.toString().startsWith(n))return d;if(u===!0)return f.DONE}),u?f:f.filter(d=>d)})}a(R5,"startsWith");function y5(e,t,r,n,s=!1,i=void 0,o=void 0){return JU(e,t,r,n,s,i,o,!0)}a(y5,"endsWith");function JU(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return pa(e,r,n),Vc(e,null,r,(l,u,f,d)=>{let _=jU(f,l,d,r);return o=Number.isInteger(o)?o:0,u.getKeys({transaction:l,end:s?!1:void 0,reverse:s}).flatMap(h=>{let m=h.toString();return m.endsWith(zU)?u.getValues(h,{transaction:l}).map(S=>{let g=_(h,S);if(c?g.endsWith(n):g.includes(n))return{key:g,value:S}}).filter(S=>S):(c?m.endsWith(n):m.includes(n))?u[eE.DBI_DEFINITION_NAME].is_hash_attribute?{key:h,value:h}:u.getValues(h,{transaction:l}).map(S=>({key:h,value:S})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a(JU,"contains");function b5(e,t,r,n,s=!1,i=void 0,o=void 0){pa(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),h_(e,t,r,n,l,s,i,o,!0,!1)}a(b5,"greaterThan");function O5(e,t,r,n,s=!1,i=void 0,o=void 0){pa(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),h_(e,t,r,n,l,s,i,o,!1,!1)}a(O5,"greaterThanEqual");function N5(e,t,r,n,s=!1,i=void 0,o=void 0){pa(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),h_(e,t,r,l,n,s,i,o,!1,!0)}a(N5,"lessThan");function w5(e,t,r,n,s=!1,i=void 0,o=void 0){pa(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),h_(e,t,r,l,n,s,i,o,!1,!1)}a(w5,"lessThanEqual");function I5(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(Wn.validateEnv(e),r===void 0)throw new Error(zt.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(zt.START_VALUE_REQUIRED);if(s===void 0)throw new Error(zt.END_VALUE_REQUIRED);if(n=Wn.convertKeyValueToWrite(n),s=Wn.convertKeyValueToWrite(s),n>s)throw new Error(zt.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return h_(e,t,r,n,s,i,o,c)}a(I5,"between");function C5(e,t,r,n){Wn.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);if(rE(r),r=m_(s,r),n===void 0)throw new Error(zt.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=tE.parseRow(c,r)),o}a(C5,"searchByHash");function P5(e,t,r){Wn.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(zt.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(P5,"checkHashExists");function D5(e,t,r,n,s=[]){return ZU(e,t,r,n,s),XU(e,t,r,n,s).map(i=>i[1])}a(D5,"batchSearchByHash");function L5(e,t,r,n,s=[]){ZU(e,t,r,n,s);let i=new Map;for(let[o,c]of XU(e,t,r,n,s))i.set(o,c);return i}a(L5,"batchSearchByHashToMap");function XU(e,t,r,n,s=[]){return Vc(e,t,t,(i,o,c)=>{r=m_(c,r);let l=r.length<3;return n.map(u=>{let f=c.dbis[t].get(u,{transaction:i,lazy:l});if(f)return[u,tE.parseRow(f,r)];s.push(u)}).filter(u=>u)})}a(XU,"batchHashSearch");function ZU(e,t,r,n,s){if(Wn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);if(rE(r),n==null)throw new Error(zt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(zt.IDS_MUST_BE_ITERABLE)}a(ZU,"initializeBatchSearchByHash");function rE(e){if(!Array.isArray(e))throw e===void 0?new Error(zt.FETCH_ATTRIBUTES_REQUIRED):new Error(zt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(rE,"validateFetchAttributes");function pa(e,t,r){if(Wn.validateEnv(e),t===void 0)throw new Error(zt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(zt.SEARCH_VALUE_REQUIRED);if(r?.length>m5)throw new Error(zt.SEARCH_VALUE_TOO_LARGE)}a(pa,"validateComparisonFunctions");function m_(e,t){return t.length===1&&_5.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=ma.listDBIs(e)),t}a(m_,"setGetWholeRowAttributes");e0.exports={searchAll:p5,searchAllToMap:E5,count:A5,countAll:S5,equals:T5,startsWith:R5,endsWith:y5,contains:JU,searchByHash:C5,setGetWholeRowAttributes:m_,batchSearchByHash:D5,batchSearchByHashToMap:L5,checkHashExists:P5,iterateDBI:g5,greaterThan:b5,greaterThanEqual:O5,lessThan:N5,lessThanEqual:w5,between:I5}});var Tu=C((gOe,i0)=>{var t0=require("lodash"),r0=st(),qe=require("joi"),M5=oe(),{hdb_schema_table:p_,checkValidTable:n0,hdb_table:s0,hdb_database:nE}=Ni(),{handleHDBError:v5,hdb_errors:U5}=me(),{getDatabases:x5}=(xe(),P(at)),{HTTP_STATUS_CODES:B5}=U5,H5=qe.object({database:nE,schema:nE,table:s0,search_attribute:p_,search_value:qe.any().required(),get_attributes:qe.array().min(1).items(qe.alternatives(p_,qe.object())).optional(),desc:qe.bool(),limit:qe.number().integer().min(1),offset:qe.number().integer().min(0)}),k5=qe.object({database:nE,schema:nE,table:s0,operator:qe.string().valid("and","or").default("and").lowercase(),offset:qe.number().integer().min(0),limit:qe.number().integer().min(1),get_attributes:qe.array().min(1).items(qe.alternatives(p_,qe.object())).optional(),sort:qe.object({attribute:qe.alternatives(p_,qe.array().min(1)),descending:qe.bool().optional()}).optional(),conditions:qe.array().min(1).items(qe.alternatives(qe.object({operator:qe.string().valid("and","or").default("and").lowercase(),conditions:qe.array()}),qe.object({search_attribute:qe.alternatives(p_,qe.array().min(1)),search_type:qe.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:qe.when("search_type",{switch:[{is:"equals",then:qe.any()},{is:"between",then:qe.array().items(qe.alternatives([qe.string(),qe.number()])).length(2)}],otherwise:qe.alternatives(qe.string(),qe.number())}).required()}))).required()});i0.exports=function(e,t){let r=null;switch(t){case"value":r=r0.validateBySchema(e,H5);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(n0("database",e.schema)),i(n0("table",e.table)),e.hash_values?Array.isArray(e.hash_values)?e.hash_values.every(o=>typeof o=="string"||typeof o=="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(o=>typeof o=="string"||typeof o=="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=r0.validateBySchema(e,k5);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=M5.checkGlobalSchemaTable(e.schema,e.table);if(s)return v5(new Error,s,B5.NOT_FOUND);let o=x5()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let l=a(f=>{for(let d=0,_=f.conditions.length;d<_;d++){let h=f.conditions[d];h.conditions?l(h):c.push(h.search_attribute)}},"addConditions");t==="conditions"&&l(e);let u=t0.filter(c,f=>f!=="*"&&!f.startsWith?.("$")&&f.attribute!=="*"&&!Array.isArray(f)&&!f.name&&!t0.some(o,d=>d===f||d.attribute===f||d.attribute===f.attribute));if(u&&u.length>0){let f=u.join(", ");return f=f.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${f}'`)}}return r}});var xy=C((TOe,o0)=>{"use strict";var F5=_t(),G5=Tu(),{getSchemaPath:q5}=Et();o0.exports=$5;function $5(e){let t=G5(e,"hashes");if(t)throw t;let r=q5(e.schema,e.table);return F5.openEnvironment(r,e.table)}a($5,"initialize")});var By=C((ROe,a0)=>{"use strict";var V5=Su(),K5=xy();a0.exports=Y5;async function Y5(e){let t=await K5(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return V5.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(Y5,"lmdbGetDataByHash")});var Au=C((bOe,c0)=>{"use strict";var Hy=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};c0.exports=Hy});var u0=C((wOe,l0)=>{"use strict";var NOe=Au(),W5=Su(),z5=xy();l0.exports=Q5;async function Q5(e){let t=await z5(e),r=global.hdb_schema[e.schema][e.table];return W5.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(Q5,"lmdbSearchByHash")});var Ws=C((COe,d0)=>{"use strict";var ky=class{static{a(this,"SearchObject")}constructor(t,r,n,s,i,o,c,l=!1,u=void 0,f=void 0){this.schema=t,this.table=r,this.search_attribute=n,this.search_value=s,this.hash_attribute=i,this.get_attributes=o,this.end_value=c,this.reverse=l,this.limit=u,this.offset=f}};d0.exports=ky});var sE=C((DOe,E0)=>{"use strict";var Qr=Su(),j5=_t(),J5=oe(),$e=kt(),Kc=(k(),P(q)),X5=fo(),f0=Un().LMDB_ERRORS_ENUM,{getSchemaPath:Z5}=Et(),So=Kc.SEARCH_WILDCARDS;async function e9(e,t,r){let n;e.schema===Kc.SYSTEM_SCHEMA_NAME?n=X5[e.table]:n=global.hdb_schema[e.schema][e.table];let s=p0(e,n.hash_attribute,r,t);return h0(e,s,n.hash_attribute,r)}a(e9,"prepSearch");async function h0(e,t,r,n){let s=Z5(e.schema,e.table),i=await j5.openEnvironment(s,e.table),o=m0(i,e,t,r),c=o.transaction||i;if([$e.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,$e.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,$e.SEARCH_TYPES.SEARCH_ALL,$e.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(t9(e,r)===!1){let f=e.search_attribute;if(f===r)return n?_0(o,()=>!0):o.map(_=>({[r]:_.key}));let d=a(_=>({[r]:_.value,[f]:_.key}),"toObject");return n?_0(o,d):o.map(d)}let u=e.search_attribute===r?o.map(f=>f.key):o.map(f=>f.value);return n===!0?Qr.batchSearchByHashToMap(c,r,e.get_attributes,u):Qr.batchSearchByHash(c,r,e.get_attributes,u)}a(h0,"executeSearch");function m0(e,t,r,n){let s,i=n;t.get_attributes.indexOf(n)<0&&(i=void 0);let{reverse:o,limit:c,offset:l}=t;switch(o=typeof o=="boolean"?o:!1,c=Number.isInteger(c)?c:void 0,l=Number.isInteger(l)?l:void 0,r){case $e.SEARCH_TYPES.EQUALS:s=Qr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.CONTAINS:s=Qr.contains(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.ENDS_WITH:case $e.SEARCH_TYPES._ENDS_WITH:s=Qr.endsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.STARTS_WITH:case $e.SEARCH_TYPES._STARTS_WITH:s=Qr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return Qr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case $e.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return Qr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case $e.SEARCH_TYPES.SEARCH_ALL:return Qr.searchAll(e,n,t.get_attributes,o,c,l);case $e.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return Qr.searchAllToMap(e,n,t.get_attributes,o,c,l);case $e.SEARCH_TYPES.BETWEEN:s=Qr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,l);break;case $e.SEARCH_TYPES.GREATER_THAN:case $e.SEARCH_TYPES._GREATER_THAN:s=Qr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.GREATER_THAN_EQUAL:case $e.SEARCH_TYPES._GREATER_THAN_EQUAL:s=Qr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.LESS_THAN:case $e.SEARCH_TYPES._LESS_THAN:s=Qr.lessThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.LESS_THAN_EQUAL:case $e.SEARCH_TYPES._LESS_THAN_EQUAL:s=Qr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;default:return Object.create(null)}return s}a(m0,"searchByType");function _0(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(_0,"createMapFromIterable");function t9(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}a(t9,"checkToFetchMore");function p0(e,t,r,n){if(J5.isEmpty(n)){let s=e.search_value;typeof s=="object"?s=JSON.stringify(s):s=s.toString();let i=s.charAt(0),o=s.charAt(s.length-1),c=!1;if(e.search_attribute===t&&(c=!0),So.indexOf(s)>-1)return r===!0?$e.SEARCH_TYPES.SEARCH_ALL_TO_MAP:$e.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(So[0])<0&&s.indexOf(So[1])<0)return c===!0?r===!0?$e.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:$e.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:$e.SEARCH_TYPES.EQUALS;if(So.indexOf(i)>=0&&So.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),$e.SEARCH_TYPES.CONTAINS;if(So.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),$e.SEARCH_TYPES.ENDS_WITH;if(So.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),$e.SEARCH_TYPES.STARTS_WITH;if(s.includes(So[0])||s.includes(So[1]))return $e.SEARCH_TYPES.EQUALS;throw new Error(f0.UNKNOWN_SEARCH_TYPE)}else switch(n){case Kc.VALUE_SEARCH_COMPARATORS.BETWEEN:return $e.SEARCH_TYPES.BETWEEN;case Kc.VALUE_SEARCH_COMPARATORS.GREATER:return $e.SEARCH_TYPES.GREATER_THAN;case Kc.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return $e.SEARCH_TYPES.GREATER_THAN_EQUAL;case Kc.VALUE_SEARCH_COMPARATORS.LESS:return $e.SEARCH_TYPES.LESS_THAN;case Kc.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return $e.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(f0.UNKNOWN_SEARCH_TYPE)}}a(p0,"createSearchTypeFromSearchObject");E0.exports={executeSearch:h0,createSearchTypeFromSearchObject:p0,prepSearch:e9,searchByType:m0}});var S0=C((vOe,g0)=>{"use strict";var MOe=Ws(),r9=Tu(),n9=oe(),s9=(k(),P(q)),i9=sE();g0.exports=o9;function o9(e,t){if(!n9.isEmpty(t)&&s9.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=r9(e,"value");if(n)throw n;return i9.prepSearch(e,t,!0)}a(o9,"lmdbGetDataByValue")});var E_=C((BOe,T0)=>{"use strict";var xOe=Ws(),a9=Tu(),c9=oe(),l9=(k(),P(q)),u9=sE();T0.exports=d9;async function d9(e,t){if(!c9.isEmpty(t)&&l9.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=a9(e,"value");if(n)throw n;return u9.prepSearch(e,t,!1)}a(d9,"lmdbSearchByValue")});var R0=C((FOe,A0)=>{"use strict";var kOe=kt(),Fy=class{static{a(this,"SearchByConditionsObject")}constructor(t,r,n,s,i=void 0,o=void 0,c="and"){this.schema=t,this.table=r,this.get_attributes=n,this.limit=i,this.offset=o,this.conditions=s,this.operator=c}},Gy=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},qy=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};A0.exports={SearchByConditionsObject:Fy,SearchCondition:Gy,SortAttribute:qy}});var w0=C((VOe,N0)=>{"use strict";var qOe=R0().SearchByConditionsObject,f9=Ws(),_9=Tu(),$y=Su(),iE=kt(),{Resource:$Oe}=(oa(),P(GA)),O0=sE(),h9=Uy(),m9=require("lodash"),{getSchemaPath:p9}=Et(),y0=_t(),{handleHDBError:E9,hdb_errors:g9}=me(),{HTTP_STATUS_CODES:S9}=g9,T9=1e8;N0.exports=A9;async function A9(e){let t=_9(e,"conditions");if(t)throw E9(t,t.message,S9.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=p9(e.schema,e.table),n=await y0.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let u of e.conditions)y0.openDBI(n,u.search_attribute);let i=m9.sortBy(e.conditions,u=>{if(u.estimated_count===void 0){let f=u.search_type;f===iE.SEARCH_TYPES.EQUALS?u.estimated_count=$y.count(n,u.search_attribute,u.search_value):f===iE.SEARCH_TYPES.CONTAINS||f===iE.SEARCH_TYPES.ENDS_WITH?u.estimated_count=1/0:u.estimated_count=T9}return u.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await b0(o,e,i[0],s.hash_attribute),l;if(!e.operator||e.operator.toLowerCase()==="and"){let u=n.dbis[s.hash_attribute],f=i.slice(1).map(O0.filterByType),d=f.length,_=$y.setGetWholeRowAttributes(n,e.get_attributes);l=c.map(h=>u.get(h,{transaction:o,lazy:!0})),d>0&&(l=l.filter(h=>{for(let m=0;m<d;m++)if(!f[m](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=>h9.parseRow(h,_))}else{for(let d=1;d<i.length;d++){let _=i[d],h=await b0(o,e,_,s.hash_attribute);c=c.concat(h)}let u=new Set,f=e.offset||0;c=c.filter(d=>u.has(d)?!1:(u.add(d),!0)).slice(f,e.limit&&e.limit+f),l=$y.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(A9,"lmdbSearchByConditions");async function b0(e,t,r,n){let s=new f9(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===iE.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,O0.searchByType(e,s,i,n).map(o=>o.value)}a(b0,"executeConditionSearch")});var g_=C((YOe,I0)=>{"use strict";var R9=(k(),P(q)).OPERATIONS_ENUM,Vy=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=R9.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};I0.exports=Vy});var Ky=C((zOe,x0)=>{"use strict";var L0=Ws(),M0=g_(),v0=E_(),U0=__(),Rn=(k(),P(q)),C0=oe(),P0=_t(),{getTransactionAuditStorePath:y9,getSchemaPath:b9}=Et(),D0=ee();x0.exports=O9;async function O9(e){try{if(C0.isEmpty(global.hdb_schema[e.schema])||C0.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await N9(e),await w9(e);let t=b9(e.schema,e.table);try{await P0.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")D0.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=y9(e.schema,e.table);await P0.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")D0.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(O9,"lmdbDropTable");async function N9(e){let t=new L0(Rn.SYSTEM_SCHEMA_NAME,Rn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Rn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Rn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await v0(t)),n=[];for(let i=0;i<r.length;i++){let o=r[i];n.push(o.id)}if(n.length===0)return;let s=new M0(Rn.SYSTEM_SCHEMA_NAME,Rn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await U0(s)}a(N9,"deleteAttributesFromSystem");async function w9(e){let t=new L0(Rn.SYSTEM_SCHEMA_NAME,Rn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Rn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[Rn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,Rn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,Rn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await v0(t))}catch(i){throw i}for(let i=0;i<r.length;i++){let o=r[i];o.name===e.table&&o.schema===e.schema&&(n=o)}if(!n)throw new Error(`${e.schema}.${e.table} was not found`);let s=new M0(Rn.SYSTEM_SCHEMA_NAME,Rn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await U0(s)}catch(i){throw i}}a(w9,"dropTableFromSystem")});var H0=C((jOe,B0)=>{"use strict";var I9=require("fs-extra"),C9=Ws(),P9=Au(),D9=g_(),L9=Ky(),M9=__(),v9=By(),U9=E_(),To=(k(),P(q)),{getSchemaPath:x9}=Et(),{handleHDBError:B9,hdb_errors:H9}=me(),{HDB_ERROR_MSGS:k9,HTTP_STATUS_CODES:F9}=H9;B0.exports=G9;async function G9(e){let t;try{t=await q9(e.schema);let r=new C9(To.SYSTEM_SCHEMA_NAME,To.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,To.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[To.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await U9(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await L9(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new D9(To.SYSTEM_SCHEMA_NAME,To.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await M9(s);let i=x9(t);await I9.remove(i)}catch(r){throw r}}a(G9,"lmdbDropSchema");async function q9(e){let t=new P9(To.SYSTEM_SCHEMA_NAME,To.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[To.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await v9(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw B9(new Error,k9.SCHEMA_NOT_FOUND(e),F9.NOT_FOUND,void 0,void 0,!0);return n}a(q9,"validateDropSchema")});var S_=C((XOe,k0)=>{"use strict";var Yy=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};k0.exports=Yy});var zy=C((tNe,F0)=>{"use strict";var $9=require("fs-extra"),oE=_t(),{getTransactionAuditStorePath:V9}=Et(),Wy=kt(),eNe=S_();F0.exports=K9;async function K9(e){let t;try{let r=V9(e.schema,e.table);await $9.mkdirp(r),t=await oE.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{oE.createDBI(t,Wy.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),oE.createDBI(t,Wy.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),oE.createDBI(t,Wy.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}a(K9,"createTransactionsAuditEnvironment")});var $0=C((sNe,q0)=>{"use strict";var Qy=(k(),P(q)),G0=_t(),Y9=vc(),{getSystemSchemaPath:W9,getSchemaPath:z9}=Et(),nNe=fo(),Q9=Bp(),jy=xp(),j9=ee(),J9=zy();q0.exports=X9;async function X9(e,t){let r=z9(t.schema,t.table),n=new jy(t.schema,t.table,Qy.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new jy(t.schema,t.table,Qy.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new jy(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await G0.createEnvironment(r,t.table),e!==void 0){let o=await G0.openEnvironment(W9(),Qy.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await Y9.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_table_attributes,[e]),n.skip_table_check=!0,s.skip_table_check=!0,i.skip_table_check=!0,await Jy(n),await Jy(s),await Jy(i)}await J9(t)}catch(o){throw o}}a(X9,"lmdbCreateTable");async function Jy(e){try{await Q9(e)}catch(t){j9.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(Jy,"createAttribute")});var K0=C((oNe,V0)=>{"use strict";var Z9=jf(),e7=bf(),t7=Xp(),T_=(k(),P(q)),r7=vc().updateRecords,n7=_t(),{getSchemaPath:s7}=Et(),i7=d_(),o7=ee();V0.exports=a7;async function a7(e){try{let{schema_table:t,attributes:r}=Z9(e);e7(e,r,t.hash_attribute),e.schema!==T_.SYSTEM_SCHEMA_NAME&&(r.includes(T_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(T_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(T_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(T_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await t7(e.hdb_auth_header,t,r),s=s7(e.schema,e.table),i=await n7.openEnvironment(s,e.table),o=await r7(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await i7(e,o)}catch(c){o7.error(`unable to write transaction due to ${c.message}`)}return{written_hashes:o.written_hashes,skipped_hashes:o.skipped_hashes,schema_table:t,new_attributes:n,txn_time:o.txn_time}}catch(t){throw t}}a(a7,"lmdbUpdateRecords")});var W0=C((cNe,Y0)=>{"use strict";var c7=(k(),P(q)).OPERATIONS_ENUM,Xy=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=c7.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};Y0.exports=Xy});var Q0=C((dNe,z0)=>{"use strict";var uNe=W0(),l7=jf(),u7=bf(),d7=Xp(),A_=(k(),P(q)),f7=vc().upsertRecords,_7=_t(),{getSchemaPath:h7}=Et(),m7=d_(),p7=ee(),{handleHDBError:E7,hdb_errors:g7}=me();z0.exports=S7;async function S7(e){let t;try{t=l7(e)}catch(l){throw E7(l,l.message,g7.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;u7(e,n,r.hash_attribute),e.schema!==A_.SYSTEM_SCHEMA_NAME&&(n.includes(A_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(A_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(A_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(A_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await d7(e.hdb_auth_header,r,n),i=h7(e.schema,e.table),o=await _7.openEnvironment(i,e.table),c=await f7(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await m7(e,c)}catch(l){p7.error(`unable to write transaction due to ${l.message}`)}return{written_hashes:c.written_hashes,schema_table:r,new_attributes:s,txn_time:c.txn_time}}a(S7,"lmdbUpsertRecords")});var J0=C((_Ne,j0)=>{"use strict";var Zy=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};j0.exports=Zy});var Z0=C((mNe,X0)=>{"use strict";var eb=class{static{a(this,"DeleteAuditLogsBeforeResults")}constructor(t=void 0,r=void 0,n=0){this.start_timestamp=t,this.end_timestamp=r,this.transactions_deleted=n}};X0.exports=eb});var rx=C((gNe,tx)=>{"use strict";var tb=_t(),{getTransactionAuditStorePath:T7}=Et(),ENe=J0(),R_=kt(),A7=oe(),ex=Z0(),R7=require("util").promisify,y7=R7(setTimeout),b7=1e4,O7=100;tx.exports=N7;async function N7(e){let t=T7(e.schema,e.table),r=await tb.openEnvironment(t,e.table,!0),n=tb.listDBIs(r);tb.initializeDBIs(r,R_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new ex;do s=await w7(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 y7(O7);while(s.transactions_deleted>0);return i}a(N7,"deleteAuditLogsBefore");async function w7(e,t){let r=new ex;try{let n=e.dbis[R_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],s;for(let{key:i,value:o}of n.getRange({start:!1})){if(i>=t)break;r.start_timestamp===void 0&&(r.start_timestamp=i),s=n.remove(i);let c=o[R_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];A7.isEmpty(c)||(s=e.dbis[R_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[R_.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>b7)break}return await s,r}catch(n){throw n}}a(w7,"deleteTransactions")});var sx=C((TNe,nx)=>{"use strict";var rb=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};nx.exports=rb});var ox=C((yNe,ix)=>{"use strict";var I7=Ws(),C7=g_(),RNe=sx(),Di=(k(),P(q)),P7=oe(),nb=_t(),D7=fo(),L7=E_(),M7=__(),{getSchemaPath:v7}=Et();ix.exports=U7;async function U7(e,t=!0){let r;e.schema===Di.SYSTEM_SCHEMA_NAME?r=D7[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await B7(e),s=v7(e.schema,e.table),i=await nb.openEnvironment(s,e.table);return t===!0&&await x7(e,i,r.hash_attribute),nb.dropDBI(i,e.attribute),n}a(U7,"lmdbDropAttribute");async function x7(e,t,r){let n=nb.openDBI(t,r),s,i=e.attribute;for(let{key:o,value:c,version:l}of n.getRange({start:!1,versions:!0})){let u={};for(let f in c)f!==i&&(u[f]=c[f]);s=t.dbis[r].put(o,u,l)}await s}a(x7,"removeAttributeFromAllObjects");async function B7(e){let t=new I7(Di.SYSTEM_SCHEMA_NAME,Di.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Di.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Di.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,Di.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await L7(t)).filter(o=>o[Di.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(P7.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[Di.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new C7(Di.SYSTEM_SCHEMA_NAME,Di.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return M7(i)}a(B7,"dropAttributeFromSystem")});var fx=C((NNe,dx)=>{"use strict";var sb=_t(),Ru=kt(),ONe=fn(),ib=(k(),P(q)),ax=oe(),{getTransactionAuditStorePath:H7}=Et(),k7=Su(),aE=pu(),F7=ee();dx.exports=G7;async function G7(e){let t=H7(e.schema,e.table),r=await sb.openEnvironment(t,e.table,!0),n=sb.listDBIs(r);sb.initializeDBIs(r,Ru.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case ib.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return cx(r,e.search_values);case ib.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,$7(r,e.search_values,s);case ib.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return q7(r,e.search_values);default:return cx(r)}}a(G7,"readAuditLog");function cx(e,t=[0,Date.now()]){ax.isEmpty(t[0])&&(t[0]=0),ax.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[Ru.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 aE,s))}a(cx,"searchTransactionsByTimestamp");function q7(e,t=[]){let r=new Map;for(let n=0;n<t.length;n++){let s=t[n],i=[];for(let o of e.dbis[Ru.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,ux(e,i))}return Object.fromEntries(r)}a(q7,"searchTransactionsByUsername");function $7(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let u=t[c],f=k7.equals(e,Ru.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Ru.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,u);for(let{value:d}of f){let _=Number(d);n.has(_)?n.get(_).push(u.toString()):n.set(_,[u.toString()])}}let s=Array.from(n.keys()),i=ux(e,s),o=new Map;for(let c=0;c<i.length;c++){let l=i[c],u=l.timestamp,f=n.get(u);lx(l,"records",r,f,o),lx(l,"original_records",r,f,o)}return Object.fromEntries(o)}a($7,"searchTransactionsByHashValues");function lx(e,t,r,n,s){let i=e.timestamp;if(e[t])for(let o=0;o<e[t].length;o++){let c=e[t][o],l=c[r].toString();if(n.indexOf(l)>=0)if(s.has(l)){let u=s.get(l),f=u[u.length-1];if(f.timestamp===i)f[t]=[c];else{let d=new aE(e.operation,e.user_name,i,void 0);d[t]=[c],u.push(d)}}else{let u=new aE(e.operation,e.user_name,i,void 0);u[t]=[c],s.set(l,[u])}}}a(lx,"loopRecords");function ux(e,t){let r=[];try{let n=e.dbis[Ru.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP];for(let s=0;s<t.length;s++)try{let i=n.get(t[s]);if(i){let o=Object.assign(new aE,i);r.push(o)}}catch(i){F7.warn(i)}return r}catch(n){throw n}}a(ux,"batchSearchTransactions")});var hx=C((PNe,_x)=>{"use strict";var{getSchemaPath:INe}=Et(),CNe=_t(),{database:V7}=(xe(),P(at));_x.exports={writeTransaction:K7};async function K7(e,t,r){return V7({database:e,table:t}).transaction(r)}a(K7,"writeTransaction")});var gx=C((LNe,Ex)=>{"use strict";var{getSchemaPath:mx}=Et(),px=_t();Ex.exports={flush:Y7,resetReadTxn:W7};async function Y7(e,t){return(await px.openEnvironment(mx(e,t),t.toString())).flushed}a(Y7,"flush");async function W7(e,t){try{(await px.openEnvironment(mx(e,t),t.toString())).resetReadTxn()}catch{}}a(W7,"resetReadTxn")});var Rx=C((vNe,Ax)=>{"use strict";var{Readable:z7}=require("stream"),{getDatabases:Q7}=(xe(),P(at)),{readSync:j7,openSync:J7,createReadStream:Sx}=require("fs"),{open:X7}=require("lmdb"),Tx=Kf(),Z7=Yf(),{AUDIT_STORE_OPTIONS:eee}=(Ri(),P(yx)),{INTERNAL_DBIS_NAME:tee,AUDIT_STORE_NAME:ree}=kt();Ax.exports=see;var ob=32768,nee=100;async function see(e){let t=e.database||e.schema||"data",r=Q7()[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 f=u.dbisDB,d=X7({noSync:!0,maxDbs:Z7.MAX_DBS}),_,h=d.openDB(tee,new Tx(!1)),m=f.useReadTransaction(),S=0,g=a(async function(E,T){T.encoding="binary",T.encoder=void 0;let N=d.openDB(E,T),v=f.openDB(E,T);for(let{key:H,version:X,value:W}of v.getRange({start:null,transaction:m,versions:v.useVersions}))_=N.put(H,W,X),S++%nee===0&&(await new Promise($=>setTimeout($,20)),m.openTimer&&(m.openTimer=0))},"copyDatabase");for(let{key:E,value:T}of f.getRange({transaction:m,start:!1}))if(s.some(N=>E.startsWith?.(N+"/"))){h.put(E,T);let[,N]=E.split("/"),v=!N,H=new Tx(!v,v);await g(E,H)}e.include_audit&&await g(ree,{...eee}),await _;let R=Sx(d.path);return R.headers=l(),R.on("close",()=>{m.done(),d.close()}),R}let o=r[Object.keys(r)[0]].primaryStore,c=J7(o.path);return o.transaction(()=>{let u=Buffer.alloc(ob);j7(c,u,0,ob),o.resetReadTxn();let f=o.useReadTransaction();f.renew();let d=Sx(null,{fd:c,start:ob}),_=new z7.from(async function*(){yield u;for await(let h of d)f.openTimer&&(f.openTimer=0),yield h;f.done()}());return _.headers=l(),_});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}}a(see,"getBackup")});var Nx=C((xNe,Ox)=>{"use strict";var iee=ee(),{handleHDBError:oee}=me(),aee=tM(),cee=Bp(),lee=Py(),uee=HU(),dee=__(),fee=By(),_ee=u0(),hee=S0(),mee=E_(),pee=w0(),Eee=H0(),gee=$0(),See=K0(),Tee=Q0(),Aee=rx(),Ree=Ky(),yee=ox(),bee=fx(),Oee=hx(),bx=gx(),Nee=Rx(),ab=class extends aee{static{a(this,"LMDBBridge")}async searchByConditions(t){return pee(t)}async getDataByHash(t){return await fee(t)}async searchByHash(t){return await _ee(t)}async getDataByValue(t,r){return await hee(t,r)}async searchByValue(t){return await mee(t)}async createSchema(t){return await uee(t)}async dropSchema(t){return await Eee(t)}async createTable(t,r){return await gee(t,r)}async dropTable(t){return await Ree(t)}async createAttribute(t){return await cee(t)}async createRecords(t){return await lee(t)}async updateRecords(t){return await See(t)}async upsertRecords(t){try{return await Tee(t)}catch(r){throw oee(r,null,null,iee.ERR,r)}}async deleteRecords(t){return await dee(t)}async dropAttribute(t){return await yee(t)}async deleteAuditLogsBefore(t){return await Aee(t)}async readAuditLog(t){return await bee(t)}writeTransaction(t,r,n){return Oee.writeTransaction(t,r,n)}flush(t,r){return bx.flush(t,r)}resetReadTxn(t,r){return bx.resetReadTxn(t,r)}getBackup(t){return Nee(t)}};Ox.exports=ab});var lb={};Ue(lb,{add:()=>cE,applyReverse:()=>wx,getRecordAtTime:()=>cb,rebuildUpdateBefore:()=>lE});function cE(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n+BigInt(r.value):isNaN(e[t])?e[t]=r.value:e[t]=n+r.value}function lE(e,t,r){let n=null;for(let s in e)if(s in t){let i=t[s];if(i?.__op__){let o=e[s];if(o?.__op__)if(o.__op__===i.__op__)n||(n={}),n[s]=o;else throw new Error("Can not merge updates with different operations");else n||(n={}),n[s]=o,cE(n,s,i)}else r&&(n||(n={}),n[s]=i)}else n||(n={}),n[s]=e[s];return n}function wx(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=wee[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=Ix}}function cb(e,t,r){let n=r.rootStore.auditStore,s={...e.value},i=e.localTime;for(;i>t;){let l=n.get(i),u=gt(l);switch(u.type){case"put":s=u.getValue(r);break;case"patch":wx(s,u.getValue(r));break;case"delete":s=null}i=u.previousLocalTime}let o={},c=0;for(let l in s)s[l]===Ix&&(o[l]=!0,c++);for(;c>0&&i>0;){let l=n.get(i),u=gt(l),f;switch(u.type){case"put":f=u.getValue(r);break;case"patch":f=u.getValue(r);break}for(let d in f)o[d]&&(s[d]=f[d],o[d]=!1,c--);i=u.previousLocalTime}if(c>0)for(let l in o)s[l]=null;return s}var wee,Ix,uE=Re(()=>{Ri();a(cE,"add");cE.reverse=function(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n-BigInt(r.value):isNaN(e[t])||(e[t]=n-r.value)};wee={add:cE};a(lE,"rebuildUpdateBefore");a(wx,"applyReverse");Ix={};a(cb,"getRecordAtTime")});function yn(e){let t=e.getChanges();return t||(t=Object.create(null),e._setChanges(t)),t}function hE(e,t){let r=e.prototype,n={},s=t.attributes||t.properties||[];for(let c of s){let l=c.name,u,f;if(c.resolve)f={get(){return c.resolve(this,this.getContext?.())},set(d){return c.set(this,d)},configurable:!0};else{switch(c.type){case"String":u=a(function(d){if(!(typeof d=="string"||d==null&&c.nullable!==!1))throw new zn.ClientError(`${l} must be a string, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"ID":u=a(function(d){if(!(typeof d=="string"||d?.length>0&&d.every?.(_=>typeof _=="string")||d==null&&c.nullable!==!1))throw new zn.ClientError(`${l} must be a string, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"Float":case"Number":u=a(function(d){let _=d?.__op__?d.value:d;if(!(typeof _=="number"||d==null&&c.nullable!==!1))throw new zn.ClientError(`${l} must be a number, attempt to assign ${_}`);yn(this)[l]=d},"set");break;case"Int":u=a(function(d){let _=d?.__op__?d.value:d;if(!(_>>0===_||d==null&&c.nullable!==!1))if(typeof _=="number"&&Math.abs((_>>0)-_)<=1)_=Math.round(_),d?.__op__?d.value=_:d=_;else throw new zn.ClientError(`${l} must be an integer between -2147483648 and 2147483647, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"Long":u=a(function(d){let _=d?.__op__?d.value:d;if(!(Math.round(_)===d&&Math.abs(_)<=9007199254740992||d==null&&c.nullable!==!1))if(typeof _=="number"&&Math.abs(_)<=9007199254740992)_=Math.round(_),d?.__op__?d.value=_:d=_;else throw new zn.ClientError(`${l} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"BigInt":u=a(function(d){let _=d?.__op__?d.value:d;if(!(typeof _=="bigint"||d==null&&c.nullable!==!1))if(typeof _=="string"||typeof _=="number")_=BigInt(_),d?.__op__?d.value=_:d=_;else throw new zn.ClientError(`${l} must be a number, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"Boolean":u=a(function(d){if(!(typeof d=="boolean"||d==null&&c.nullable!==!1))throw new zn.ClientError(`${l} must be a boolean, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"Date":u=a(function(d){if(!(d instanceof Date||d==null&&c.nullable!==!1))if(typeof d=="string"||typeof d=="number")d=new Date(d);else throw new zn.ClientError(`${l} must be a Date, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"Bytes":u=a(function(d){if(!(d instanceof Uint8Array||d==null&&c.nullable!==!1))throw new zn.ClientError(`${l} must be a Buffer or Uint8Array, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"Blob":u=a(function(d){if(!(d instanceof Ai||d==null&&c.nullable!==!1))throw new zn.ClientError(`${l} must be a Blob, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"Any":case void 0:u=a(function(d){yn(this)[l]=d},"set");break;default:u=a(function(d){if(!(typeof d=="object"||d==null&&c.nullable!==!1))throw new zn.ClientError(`${l} must be an object, attempt to assign ${d}`);yn(this)[l]=d},"set")}f={get(){let d=this.getChanges?.();if(d&&l in d){let h=d[l];if(h?.__op__){let m=this.getRecord()?.[l];return h.update(m)}return h}let _=this.getRecord()?.[l];if(_&&typeof _=="object"){let h=ub(_,c);if(h)return d||this._setChanges(d=Object.create(null)),d[l]=h}return _},set:u,enumerable:!0,configurable:!0}}f.get.isAttribute=!0,n[l]=f,(!(l in r)||Object.getOwnPropertyDescriptor(r,l)?.get?.isAttribute)&&Object.defineProperty(r,l,f)}i("getProperty",function(c){let l=n[c];if(l)return l.get.call(this);let u=this.getChanges();return u?.[c]!==void 0?u[c]:this.getRecord()?.[c]}),i("set",function(c,l){let u=n[c];if(u)return u.set.call(this,l);if(t.sealed)throw new zn.ClientError("Can not add a property to a sealed table schema");yn(this)[c]=l}),i("deleteProperty",function(c){yn(this)[c]=void 0}),i("toJSON",function(){let c=this.getChanges?.(),l;for(let f in c){l||(l={...this.getRecord()});let d=c[f];if(d?.__op__){let _=l[f];d=d.update(_)}l[f]=d}return Object.keys(this).length>0&&(l||(l={...this.getRecord()}),Object.assign(l,this)),l||this.getRecord()}),r.get||i("get",r.getProperty),r.delete||i("delete",r.deleteProperty),r.then||i("then",null);function i(c,l){Object.defineProperty(r,c,{value:l,configurable:!0})}a(i,"setMethod");let o=r;do{let c=Object.getPrototypeOf(o);if(c===Object.prototype){Object.setPrototypeOf(o,Px);break}o=c}while(o&&o!==Px)}function ub(e,t){let r;switch(e.constructor){case Object:return t?(r=t.TrackedObject,r||(t.TrackedObject=r=class extends y_{static{a(this,"TrackedObject")}},hE(r,t)),new r(e)):new y_(e);case Array:let n=new fE(e.length,e);for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=ub(o,t?.elements)),n[s]=o}return n;default:return e}}function mE(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 o=r[s];i=i.update(o)}else i=mE(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 yu(e,t=e.getChanges?.()){let r;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 o=yu(i);o!==i&&r===e&&(r=e.slice(0)),i=o}r[n]=i}return Object.freeze(r)}for(let n in t){r||(r={...e.getRecord?.()});let s=t[n];if(s&&typeof s=="object")if(s.__op__){let i=lb[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=yu(s);r[n]=s}if(!Array.isArray(e))for(let n in e)Iee.call(e,n)&&(r||(r={...e.getRecord?.()}),r[n]=e[n]);return r?Object.freeze(r):e.getRecord?.()??e}function dE(e){let t=e.getRecord?.();if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[Yc]||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(dE(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(dE(s))return!0}else return!0}else return!0}}return!1}var zn,Cx,Px,y_,Iee,Yc,fE,_E,db=Re(()=>{zn=M(me());uE();gn();a(yn,"getChanges");a(hE,"assignTrackedAccessors");Cx=Object.prototype,Px=new Proxy({},{get(e,t,r){if(typeof t=="string"){if(t==="then"||t==="getRecord"||t==="getChanges")return;if(Cx[t])return Cx[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=ub(s);if(i)return n||(n=Object.create(null),r._setChanges(n)),n[t]=i,i}return s}}});a(ub,"trackObject");y_=class{static{a(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}};hE(y_,{});a(mE,"collapseData");Iee=Object.prototype.hasOwnProperty;a(yu,"updateAndFreeze");a(dE,"hasChanges");Yc=Symbol.for("has-array-changes"),fE=class extends Array{static{a(this,"TrackedArray")}#e;[Yc];constructor(t,r){super(t),this.#e=r}getRecord(){return this.#e}splice(...t){return this[Yc]=!0,super.splice(...t)}push(...t){return this[Yc]=!0,super.push(...t)}pop(){return this[Yc]=!0,super.pop()}unshift(...t){return this[Yc]=!0,super.unshift(...t)}shift(){return this[Yc]=!0,super.shift()}};fE.prototype.constructor=Array;_E=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var Hx={};Ue(Hx,{ResourceBridge:()=>hb});function mb({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 Lx(e,t){let r=Li(e),n=mb(e,r);if(!r)throw new zs.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},o;Ct(i,()=>new Promise(u=>o=u));let c=e.ids||e.hash_values,l=0;return{[Symbol.asyncIterator](){return{async next(){if(l<c.length){let u=c[l++],f;try{f=await r.get({id:u,lazy:s,select:n},i),f=f&&mE(f)}catch(d){f={message:d.toString()}}return t?{value:{key:u,value:f}}:{value:f}}else return o(),{done:!0}},return(u){return o(),{value:u,done:!0}},throw(u){return o(),{done:!0}}}}}}function Li(e){let t=e.database||e.schema||Pee,r=Xe()[t];if(!r)throw(0,zs.handleHDBError)(new Error,Cee.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function Mx(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*vx(e,t,r,n){let s,i=0;for await(let o of e.getHistory(t,r)){let c=o.operation??o.type;c==="put"&&(c="upsert");let{id:l,version:u,value:f}=o;if(s?.timestamp===u)s.hash_values.push(l),s.records.push(f);else{if(s&&(yield s,i++,n&&n<=i)){s=void 0;break}s={operation:c,user_name:o.user,timestamp:u,hash_values:[l],records:[f]}}}s&&(yield s)}var Ux,pE,zs,xx,fb,_b,Bx,Cee,Pee,Dee,Lee,Dx,hb,kx=Re(()=>{"use strict";Ux=M(Nx()),pE=M(Tu()),zs=M(me());xe();xx=M(jf());k();fb=M(go()),_b=M(Ys()),Bx=M(oe());gc();db();({HDB_ERROR_MSGS:Cee}=zs.hdb_errors),Pee="data",Dee=1e4,Lee=10,hb=class extends Ux.default{static{a(this,"ResourceBridge")}constructor(t){super(t),Dx=this}async searchByConditions(t){t.select!==void 0&&(t.get_attributes=t.select);for(let o of t.conditions||[])o?.attribute!==void 0&&(o.search_attribute=o.attribute),o?.comparator!==void 0&&(o.search_type=o.comparator),o?.value!==void 0&&(o.search_value=o.value);let r=(0,pE.default)(t,"conditions");if(r)throw(0,zs.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=Li(t);if(!n)throw new zs.ClientError(`Table ${t.table} not found`);let s=t.conditions.map(i);function i(o){return o.conditions?(o.conditions=o.conditions.map(i),o):{attribute:o.search_attribute??o.attribute,comparator:o.search_type??o.comparator,value:o.search_value!==void 0?o.search_value:o.value}}return a(i,"mapCondition"),n.search({conditions:s,operator:t.operator?t.operator.toLowerCase():void 0,limit:t.limit,offset:t.offset,reverse:t.reverse,select:mb(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 o of n)o.is_primary_key?(o.isPrimaryKey=!0,delete o.is_primary_key):o.name===i&&i&&(o.isPrimaryKey=!0);else{if(!i)throw new zs.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}]}ft({database:r.database??r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration,audit:r.audit})}async createAttribute(t){return await Li(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=Li(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=a((o,c,l)=>(c={...c},delete c[n],r.primaryStore.ifVersion(o,l,()=>r.primaryStore.put(o,c,l)).then(u=>{if(!u){let{value:f,version:d}=r.primaryStore.getEntry(o);return i(o,f,d)}})),"deleteRecord");for(let{key:o,value:c,version:l}of r.primaryStore.getRange({start:!0,versions:!0}))s=i(o,c,l),await new Promise(u=>setImmediate(u));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){Li(t).dropTable()}createSchema(t){return bu({database:t.schema,table:null}),fb.signalSchemaChange(new _b.SchemaEventMsg(process.pid,Yt.CREATE_SCHEMA,t.schema))}async dropSchema(t){await pb(t.schema),fb.signalSchemaChange(new _b.SchemaEventMsg(process.pid,Yt.DROP_SCHEMA,t.schema))}async updateRecords(t){return t.requires_existing=!0,this.upsertRecords(t)}async createRecords(t){return t.requires_no_existing=!0,Dx.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,xx.default)(t),s,i=Xe()[t.schema][t.table],o={user:t.hdb_user,expiresAt:t.expiresAt,originatingOperation:t.operation};return t.replicateTo&&(o.replicateTo=t.replicateTo),t.replicatedConfirmation&&(o.replicatedConfirmation=t.replicatedConfirmation),Ct(o,async c=>{if(!i.schemaDefined){s=[];for(let f of n)i.attributes.find(_=>_.name==f)||s.push(f);s.length>0&&await i.addAttributes(s.map(f=>({name:f,indexed:!0})))}let l=[],u=[];for(let f of t.records){let d=f[i.primaryKey],_=d!=null&&await i.get(d,o);if(t.requires_existing&&!_||t.requires_no_existing&&_){u.push(f[i.primaryKey]);continue}_&&(_=mE(_));for(let h in f)if(Object.prototype.hasOwnProperty.call(f,h)){let m=f[h];if(typeof m=="function")try{let S=m([[_]]);Array.isArray(S)&&(m=S[0].func_val,f[h]=m)}catch(S){throw S.message+="Trying to set key "+h+" on object"+JSON.stringify(f),S}}if(_)for(let h in _)Object.prototype.hasOwnProperty.call(f,h)||(f[h]=_[h]);await(d==null?i.create(f,o):i.put(f,o)),l.push(f[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:l,new_attributes:s,skipped_hashes:u}})}async deleteRecords(t){let r=Xe()[t.schema][t.table],n={user:t.hdb_user};return t.replicateTo&&(n.replicateTo=t.replicateTo),t.replicatedConfirmation&&(n.replicatedConfirmation=t.replicatedConfirmation),Ct(n,async s=>{let i=t.hash_values||t.records.map(l=>l[r.primaryKey]),o=[],c=[];for(let l of i)await r.delete(l,n)?o.push(l):c.push(l);return Mx(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=Xe()[t.schema][t.table];if(!r.createdTimeProperty)throw new zs.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:Um.LESS}]}),s=!1,i=[],o=[],c=0,l=[],u=a(async()=>{let f=await this.deleteRecords({schema:t.schema,table:t.table,hash_values:l});i.push(...f.deleted_hashes),o.push(...f.skipped_hashes),await(0,Bx.async_set_timeout)(Lee),l=[],s=!0},"chunkDelete");for await(let f of n)l.push(f[r.primaryKey]),c++,c%Dee===0&&await u();return l.length>0&&await u(),s?Mx(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,pE.default)(t,"hashes");if(r)throw r;return Lx(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of Lx(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&fA[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=condition.attribute),t.value!==void 0&&(t.search_value=condition.value);let n=(0,pE.default)(t,"value");if(n)throw n;let s=Li(t);if(!s)throw new zs.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===Um.BETWEEN&&(i=[i,t.end_value]);let o=i==="*"?[]:[{attribute:t.search_attribute,value:i,comparator:r}];return s.search({conditions:o,allowFullScan:!0,limit:t.limit,offset:t.offset,reverse:t.reverse,sort:t.sort,select:mb(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async getDataByValue(t,r){let n=new Map,s=Li(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){Li({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return Li(t).deleteHistory(t.timestamp,t.cleanup_deleted_records)}async readAuditLog(t){let r=Li(t),n={};switch(t.search_type){case xm.HASH_VALUE:for(let i of t.search_values)n[i]=(await r.getHistoryOfRecord(i)).map(o=>{let c=o.operation??o.type;return c==="put"&&(c="upsert"),{operation:c,timestamp:o.version,user_name:o.user,hash_values:[i],records:[o.value]}});return n;case xm.USERNAME:let s=t.search_values;for await(let i of vx(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return vx(r,t.search_values?.[0],t.search_values?.[1],t.limit)}}};a(mb,"getSelect");a(Lx,"getRecords");a(Li,"getTable");a(Mx,"createDeleteResponse");a(vx,"groupRecordsInHistory")});var Vn=C((QNe,Fx)=>{"use strict";var{ResourceBridge:Mee}=(kx(),P(Hx)),vee=ce();vee.initSync();var EE;function Uee(){return EE||(EE=new Mee,EE)}a(Uee,"getBridge");Fx.exports=Uee()});var An=C((JNe,Vx)=>{"use strict";var SE=dR(),xr=oe(),xee=require("util"),TE=Vn(),Bee=ps(),Gx=ee(),{handleHDBError:Wc,hdb_errors:Hee}=me(),{HTTP_STATUS_CODES:zc}=Hee,kee=xee.promisify(Bee.getTableSchema),Fee="updated",qx="inserted",$x="upserted";Vx.exports={insert:qee,update:$ee,upsert:Vee,validation:Gee,flush:Kee};async function Gee(e){if(xr.isEmpty(e))throw new Error("invalid update parameters defined.");if(xr.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if(xr.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await kee(e.schema,e.table),r=SE(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={},o=!1;return e.operation==="update"&&(o=!0),e.records.forEach(c=>{if(o&&xr.isEmptyOrZeroLength(c[n]))throw Gx.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(!xr.isEmptyOrZeroLength(c[n])&&(c[n]==="null"||c[n]==="undefined"))throw Gx.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[n]}" is not a valid hash attribute value`);!xr.isEmpty(c[n])&&c[n]!==""&&s.has(xr.autoCast(c[n]))&&(c.skip=!0),s.add(xr.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)}}a(Gee,"validation");async function qee(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=SE(e);if(t)throw Wc(new Error,t.message,zc.BAD_REQUEST);xr.transformReq(e);let r=xr.checkSchemaTableExist(e.schema,e.table);if(r)throw Wc(new Error,r,zc.BAD_REQUEST);let n=await TE.createRecords(e);return gE(qx,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(qee,"insertData");async function $ee(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=SE(e);if(t)throw Wc(new Error,t.message,zc.BAD_REQUEST);xr.transformReq(e);let r=xr.checkSchemaTableExist(e.schema,e.table);if(r)throw Wc(new Error,r,zc.BAD_REQUEST);let n=await TE.updateRecords(e);return xr.isEmpty(n.existing_rows)?gE(Fee,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):gE(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a($ee,"updateData");async function Vee(e){if(e.operation!=="upsert")throw Wc(new Error,"invalid operation, must be upsert",zc.INTERNAL_SERVER_ERROR);let t=SE(e);if(t)throw Wc(new Error,t.message,zc.BAD_REQUEST);xr.transformReq(e);let r=xr.checkSchemaTableExist(e.schema,e.table);if(r)throw Wc(new Error,r,zc.BAD_REQUEST);let n=await TE.upsertRecords(e);return gE($x,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(Vee,"upsertData");function gE(e,t,r,n,s,i){let o={message:`${e} ${t.length} of ${t.length+n.length} records`,new_attributes:s,txn_time:i};return e===qx?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===$x?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(gE,"returnObject");function Kee(e){return xr.transformReq(e),TE.flush(e.schema,e.table)}a(Kee,"flush")});var jx=C((ZNe,Qx)=>{var Ou=require("validate.js"),Yx=st(),Nu=(k(),P(q)),{handleHDBError:Yee,hdb_errors:Wee}=me(),{HDB_ERROR_MSGS:Qt,HTTP_STATUS_CODES:zee}=Wee,Eb=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),Qee={STRUCTURE_USER:"structure_user"},Kx=Object.values(Nu.ROLE_TYPES_ENUM),jee="attribute_permissions",Jee="attribute_name",{PERMS_CRUD_ENUM:wu}=Nu,Xee=[jee,...Object.values(wu)],Wx=[wu.READ,wu.INSERT,wu.UPDATE],Zee=[Jee,...Wx];function ete(e){let t=Eb();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,zx(e,t)}a(ete,"addRoleValidation");function tte(e){let t=Eb();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,zx(e,t)}a(tte,"alterRoleValidation");function rte(e){let t=Eb();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,Yx.validateObject(e,t)}a(rte,"dropRoleValidation");var nte=["operation","role","id","permission","hdb_user","access"];function zx(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)nte.includes(n[o])||s.push(n[o]);s.length>0&&nr(Qt.INVALID_ROLE_JSON_KEYS(s),r);let i=Yx.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{nr(o,r)}),e.permission){let o=ste(e);o&&nr(o,r),Kx.forEach(c=>{e.permission[c]&&!Ou.isBoolean(e.permission[c])&&nr(Qt.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(Kx.indexOf(o)<0){if(o===Qee.STRUCTURE_USER){let l=e.permission[o];if(typeof l=="boolean")continue;if(Array.isArray(l)){for(let u=0,f=l.length;u<f;u++){let d=l[u];global.hdb_schema[d]||nr(Qt.SCHEMA_NOT_FOUND(d),r)}continue}nr(Qt.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){nr(Qt.SCHEMA_NOT_FOUND(o),r);continue}if(c.tables)for(let l in c.tables){let u=c.tables[l];if(!l||!global.hdb_schema[o][l]){nr(Qt.TABLE_NOT_FOUND(o,l),r);continue}if(Object.keys(u).forEach(f=>{Xee.includes(f)||nr(Qt.INVALID_PERM_KEY(f),r,o,l)}),Object.values(wu).forEach(f=>{Ou.isDefined(u[f])?Ou.isBoolean(u[f])||nr(Qt.TABLE_PERM_NOT_BOOLEAN(f),r,o,l):nr(Qt.TABLE_PERM_MISSING(f),r,o,l)}),u.attribute_permissions===void 0){nr(Qt.ATTR_PERMS_ARRAY_MISSING,r,o,l);continue}else if(!(Array.isArray(u.attribute_permissions)||u.attribute_permissions===null)){nr(Qt.ATTR_PERMS_NOT_ARRAY,r,o,l);continue}if(u.attribute_permissions){let f=global.hdb_schema[o][l].attributes.map(({attribute:_})=>_),d={read:!1,insert:!1,update:!1};for(let _ in u.attribute_permissions){let h=u.attribute_permissions[_];if(Object.keys(h).forEach(S=>{!Zee.includes(S)&&S!==wu.DELETE&&nr(Qt.INVALID_ATTR_PERM_KEY(S),r,o,l)}),!Ou.isDefined(h.attribute_name)){nr(Qt.ATTR_PERM_MISSING_NAME,r,o,l);continue}let m=h.attribute_name;if(!f.includes(m)){nr(Qt.INVALID_ATTRIBUTE_IN_PERMS(m),r,o,l);continue}Wx.forEach(S=>{Ou.isDefined(h[S])?Ou.isBoolean(h[S])||nr(Qt.ATTR_PERM_NOT_BOOLEAN(S,m),r,o,l):nr(Qt.ATTR_PERM_MISSING(S,m),r,o,l)}),!d.read&&h.read===!0&&(d.read=!0),!d.insert&&h.insert===!0&&(d.insert=!0),!d.update&&h.update===!0&&(d.update=!0)}if(u.read===!1&&d.read===!0||u.insert===!1&&d.insert===!0||u.update===!1&&d.update===!0){let _=`${o}.${l}`;nr(Qt.MISMATCHED_TABLE_ATTR_PERMS(_),r,o,l)}}}}return ite(r)}a(zx,"customValidate");Qx.exports={addRoleValidation:ete,alterRoleValidation:tte,dropRoleValidation:rte};function ste(e){let{operation:t,permission:r}=e;if(t===Nu.OPERATIONS_ENUM.ADD_ROLE||t===Nu.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 Qt.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?Nu.ROLE_TYPES_ENUM.SUPER_USER:Nu.ROLE_TYPES_ENUM.CLUSTER_USER;return Qt.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(ste,"validateNoSUPerms");function ite(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:Qt.ROLE_PERMS_ERROR,...e};return Yee(new Error,n,zee.BAD_REQUEST)}else return null}a(ite,"generateRolePermResponse");function nr(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]}}a(nr,"addPermError")});var O_=C((rwe,eB)=>{"use strict";var Jx=An(),Xx=Wr(),ote=Fc(),Sb=jx(),Tb=go(),twe=require("uuid").v4,ate=require("util"),AE=(k(),P(q)),cte=oe(),Ab=Xx.searchByValue,lte=Xx.searchByHash,ute=ate.promisify(ote.delete),dte=Ws(),fte=Au(),{hdb_errors:_te,handleHDBError:Qc}=me(),{HDB_ERROR_MSGS:Zx,HTTP_STATUS_CODES:b_}=_te,{UserEventMsg:Rb}=Ys();eB.exports={addRole:hte,alterRole:mte,dropRole:pte,listRoles:Ete};function gb(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}a(gb,"scrubRoleDetails");async function hte(e){let t=Sb.addRoleValidation(e);if(t)throw t;e=gb(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 Ab(r)||[])}catch(i){throw Qc(i)}if(n&&n.length>0)throw Qc(new Error,Zx.ROLE_ALREADY_EXISTS(e.role),b_.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 Jx.insert(s),Tb.signalUserChange(new Rb(process.pid)),e=gb(e),e}a(hte,"addRole");async function mte(e){let t=Sb.alterRoleValidation(e);if(t)throw t;e=gb(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await Jx.update(r)}catch(s){throw Qc(s)}if(n&&n?.message==="updated 0 of 1 records")throw Qc(new Error,"Invalid role id",b_.BAD_REQUEST,void 0,void 0,!0);return await Tb.signalUserChange(new Rb(process.pid)),e}a(mte,"alterRole");async function pte(e){let t=Sb.dropRoleValidation(e);if(t)throw Qc(new Error,t,b_.BAD_REQUEST,void 0,void 0,!0);let r=new fte(AE.SYSTEM_SCHEMA_NAME,AE.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await lte(r));if(n.length===0)throw Qc(new Error,Zx.ROLE_NOT_FOUND,b_.NOT_FOUND,void 0,void 0,!0);let s=new dte(AE.SYSTEM_SCHEMA_NAME,AE.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await Ab(s)),o=!1;if(cte.isEmptyOrZeroLength(i)===!1){for(let l=0;l<i.length;l++)if(i[l].active===!0){o=!0;break}}if(o===!0)throw Qc(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,b_.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await ute(c),Tb.signalUserChange(new Rb(process.pid)),`${n[0].role} successfully deleted`}a(pte,"dropRole");async function Ete(){return Ab({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(Ete,"listRoles")});var yb={};Ue(yb,{start:()=>nB,startOnMainThread:()=>Tte});function nB({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r){let n=(0,tB.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 o in i.permission){if(gte.includes(o))continue;let c=i.permission[o];c.tables||(i.permission[o]=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 f=[];for(let d in u.attributes){let _=u.attributes[d];_.attribute_name=d,f.push(_)}u.attribute_permissions=f,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 f of u.attribute_permissions)f.read=!!f.read,f.insert=!!f.insert,f.update=!!f.update}else u.attribute_permissions=null}}i.role=i.id=s,await Ste(i)}}}async function Ste(e){let t=Xe().system.hdb_role;for await(let r of t.search([{attribute:"role",value:e.role}])){let{__createdtime__:n,__updatedtime__:s,...i}=r;return(0,rB.isEqual)(i,e)?void 0:(e.id=r.id,(0,RE.alterRole)(e))}return(0,RE.addRole)(e)}var RE,tB,rB,gte,Tte,sB=Re(()=>{xe();RE=M(O_()),tB=require("yaml"),rB=require("lodash"),gte=["super_user","cluster_user","structure_user"];a(nB,"start");a(Ste,"ensureRole");Tte=nB});async function yE(e){let t=(0,aB.pathToFileURL)(e).toString();if(Ate)return N_||(N_=Rte(bte)),(await(await N_).import(t)).namespace;try{return await import(t)}catch(r){try{(await import("internal/util")).default.decorateErrorStack(r)}catch{}throw r}}async function Rte(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),N_=new Compartment({console,Math,Date,fetch:yte,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,oB.extname)(r)||(r+=".js"),r)},importHook:a(async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){Object.assign(s,{Resource:Kr,tables:Qn,databases:We})}};let n=await(0,iB.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)},"importHook")}),N_}function yte(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 bte(){return{Resource:Kr,tables:Qn}}var iB,oB,aB,Ate,N_,bb=Re(()=>{oa();xe();iB=require("fs/promises"),oB=require("path"),aB=require("url"),Ate=!1;a(yE,"secureImport");a(Rte,"getCompartment");a(yte,"secureOnlyFetch");a(bte,"getGlobalVars")});var Nb={};Ue(Nb,{handleFile:()=>Ote});async function Ote(e,t,r,n){let s=new Map,i=await yE(r);c(i.default)&&n.set((0,Ob.dirname)(t),i.default),o(i,(0,Ob.dirname)(t));function o(l,u){for(let f in l){let d=l[f];c(d)?n.set(u+"/"+f,d):typeof d=="object"&&o(d,u+"/"+f)}}a(o,"recurseForResources");function c(l){return typeof l=="function"&&(l.get||l.put||l.post||l.delete)}return a(c,"isResource"),s}var Ob,cB=Re(()=>{bb();Ob=require("path");a(Ote,"handleFile")});var Ib={};Ue(Ib,{start:()=>Nte});function Nte({resources:e}){e.set("login",wb),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var wb,lB=Re(()=>{oa();a(Nte,"start");wb=class extends Kr{static{a(this,"Login")}static async get(t,r,n){}static async post(t,r,n){let{username:s,password:i,redirect:o}=r;return{data:await n.login(s,i)}}}});var L_={};Ue(L_,{addAnalyticsListener:()=>D_,calculateCPUUtilization:()=>IB,diffResourceUsage:()=>CB,recordAction:()=>Dt,recordActionBinary:()=>jn,setAnalyticsEnabled:()=>wte});function wte(e){yB=e}function Ite(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 Cte(e,t,r,n,s,i){let o={};if(typeof t=="number")o.total=t,o.values=new Float32Array(4),o.values.index=1,o.values[0]=t,o.total=t;else if(typeof t=="boolean")o.total=t?1:0,o.count=1;else if(typeof t=="function")o.count=1,o.callback=t;else throw new TypeError("Invalid metric value type "+typeof t);o.description={metric:r,path:n,method:s,type:i},OE.set(e,o)}function Dt(e,t,r,n,s){if(!yB)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=OE.get(i);o?Ite(e,o):Cte(i,e,t,r,n,s),bE||Pte()}function jn(e,t,r,n,s){Dt(!!e,t,r,n,s)}function D_(e){NB.push(e)}function Pte(){bE=performance.now(),setTimeout(async()=>{let e=performance.now()-bE;bE=0;let t=[],r={time:Date.now(),period:e,threadId:jc.threadId,metrics:t};for(let[s,i]of OE){if(i.values){let o=i.values.subarray(0,i.values.index);o.sort();let c=o.length,l=0,u=[],f;for(let d of wB){let _=Math.floor(c*d),h=o[_-1];if(_>l){let m=_-l;if(h===f){let S=u[u.length-1];typeof S=="number"?u[u.length-1]={value:S,count:1+m}:S.count+=m}else u.push(m>1?{value:h,count:m}:h),f=h;l=_}}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 PB()}let n=process.memoryUsage();t.push({metric:"memory",threadId:jc.threadId,byThread:!0,...n});for(let s of NB)s(t);OE=new Map,jc.parentPort?jc.parentPort.postMessage({type:OB,report:r}):MB({report:r})},bB).unref()}function NE(e,t,r){let n={id:(0,C_.getNextMonotonicTime)(),metric:t,...r};e.primaryStore.put(n.id,n,{append:!0}).then(s=>{s||e.primaryStore.put(n.id,n)})}function IB(e,t){let r=e.userCPUTime+e.systemCPUTime;return Math.round(r/t*100)/100}function CB(e,t){return{userCPUTime:t.userCPUTime/1e3-(e?.userCPUTime??0),systemCPUTime:t.systemCPUTime/1e3-(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 Dte(e,t,r){let n=0;for(let[s,i]of Object.entries(r)){let o=`${t}.${s}`,c=i.getSize(),l={database:t,table:s,size:c};NE(e,"table-size",l),Jc.trace?.(`table ${o} size metric: ${JSON.stringify(l)}`),n+=c}return n}function uB(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s?.getAuditSize();if(!i)return;let o=RB.default.statSync(s.primaryStore.env.path).size,c=Dte(e,r,n),l=o-c,u={database:r,size:o,used:c,free:l,audit:i};NE(e,"database-size",u),Jc.trace?.(`database ${r} size metric: ${JSON.stringify(u)}`)}catch(s){Jc.warn?.("Error getting DB size metrics",s)}}function dB(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s?.getStorageStats();if(!i)return;let o={database:r,...i};NE(e,"storage-volume",o),Jc.trace?.(`db ${r} storage volume metrics: ${JSON.stringify(o)}`)}catch(s){Jc.warn?.("Error getting DB volume metrics",s)}}async function Lte(e,t=6e4){let r=Pb(),n=DB(),s=new Promise(E=>{let T=performance.now();setImmediate(()=>{let N=performance.now();N-T>5e3&&Jc.warn?.("Unusually high event queue latency on the main thread of "+Math.round(N-T)+"ms"),T=performance.now()}),n.primaryStore.prefetch([1],()=>{let N=performance.now();N-T>5e3&&Jc.warn?.("Unusually high task queue latency on the main thread of "+Math.round(N-T)+"ms"),E(N-T)})}),i;for(let E of n.primaryStore.getRange({start:1/0,end:!1,reverse:!0}))if(E.value?.time){i=E.value.time;break}if(Date.now()-t<i)return;let o,c=new Map,l=new Map,u=[],f;for(let{key:E,value:T}of r.primaryStore.getRange({start:i||!1,exclusiveStart:!0,end:1/0})){if(!T)continue;if(o){if(E>o+t)break}else o=E;f=E;let{metrics:N,threadId:v}=T;for(let H of N||[]){let{path:X,method:W,type:$,metric:ie,count:z,total:de,distribution:le,threads:Z,...Ae}=H;z||(z=1);let pe=ie+(X?"-"+X:"");W!==void 0&&(pe+="-"+W),$!==void 0&&(pe+="-"+$);let ye=c.get(pe);if(ye){if(ye.threads){let ut=ye.threads[v];if(ut)ye=ut;else{ye.threads[v]={...Ae};continue}}ye.count||(ye.count=1);let xt=ye.count;for(let ut in Ae){let Ln=Ae[ut];typeof Ln=="number"&&(ye[ut]=(ye[ut]*xt+Ln*z)/(xt+z))}ye.count+=z,de>=0&&(ye.total+=de,ye.ratio=ye.total/ye.count)}else ye={period:t,...H},delete ye.distribution,c.set(pe,ye),ye.byThread&&(ye.threads=[],ye.threads[v]={...Ae},u.push(ye));if(le){le=le.map(ut=>typeof ut=="number"?{value:ut,count:1}:ut);let xt=l.get(pe);xt?xt.push(...le):l.set(pe,le)}}await PB()}for(let E of u){let{path:T,method:N,type:v,metric:H,count:X,total:W,distribution:$,threads:ie,...z}=E;ie=ie.filter(de=>de);for(let de in z){if(typeof E[de]!="number")continue;let le=0;for(let Z of ie){let Ae=Z[de];typeof Ae=="number"&&(le+=Ae)}E[de]=le}E.count=ie.length,delete E.threads,delete E.byThread}for(let[E,T]of l){let N=c.get(E);T.sort((ut,Ln)=>ut.value>Ln.value?1:-1);let v=N.count-1,H=[],X=0,W=0,$;for(let ut of wB){let Ln=v*ut;for(;X<Ln;)$=T[W++],X+=$.count,W===1&&X--;let an=T[W>1?W-2:0];$||($=T[0]),H.push($.value-($.value-an.value)*(X-Ln)/$.count)}let[ie,z,de,le,Z,Ae,pe,ye,xt]=H;Object.assign(N,{p1:ie,p10:z,p25:de,median:le,p75:Z,p90:Ae,p95:pe,p99:ye,p999:xt})}let d;for(let[E,T]of c)T.id=(0,C_.getNextMonotonicTime)(),T.time=f,n.primaryStore.put(T.id,T,{append:!0}).then(N=>{N||n.primaryStore.put(T.id,T)}),d=!0;let _=Date.now(),{idle:h,active:m}=performance.eventLoopUtilization();if(d||m*10>h){let E=(0,C_.getNextMonotonicTime)(),T={id:E,metric:"main-thread-utilization",idle:h-fB,active:m-_B,taskQueueLatency:await s,time:_,...process.memoryUsage()};n.primaryStore.put(E,T,{append:!0}).then(N=>{N||n.primaryStore.put(E,T)})}fB=h,_B=m;let S=process.resourceUsage(),g=CB(w_,S);g.time=_,g.period=w_.time?_-w_.time:t,g.cpuUtilization=IB(w_,g.period),NE(n,"resource-usage",g),w_=g;let R=Xe();uB(n,R),uB(n,{system:R.system}),dB(n,R),dB(n,{system:R.system})}async function hB(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function Pb(){return mB||(mB=ft({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function DB(){return pB||(pB=ft({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function Ute(){LB=!0;let e=(0,P_.get)(B.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await Lte(bB,e),await hB(Pb(),Mte),await hB(DB(),vte)},Math.min(e/2,2147483647)).unref()}function MB(e,t){let r=e.report;r.threadId=t?.threadId||jc.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(EB+=n.mean*n.count);r.totalBytesProcessed=EB,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(gB.get(t))}),gB.set(t,t.performance.eventLoopUtilization())),r.id=(0,C_.getNextMonotonicTime)(),Pb().primaryStore.put(r.id,r),LB||Ute(),xte&&(vB=Hte(r))}async function Hte(e){if(await vB,!Ea){let r=(0,I_.dirname)((0,TB.getLogFilePath)());try{Ea=await(0,Cb.open)((0,I_.join)(r,"analytics.log"),"r+")}catch{Ea=await(0,Cb.open)((0,I_.join)(r,"analytics.log"),"w+")}}let t=(await Ea.stat()).size;if(t>Bte){let r=Buffer.alloc(t);await Ea.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await Ea.write(r,{position:0}),await Ea.truncate(r.length),t=r.length}await Ea.write(JSON.stringify(e)+`
|
|
19
|
+
`},"serialize"),compressible:!1,q:.8});Yr.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()}});BL={type:"application/json",serializeStream:Df,serialize:Uf,deserialize:d3,q:.5};Yr.set("*/*",BL);Yr.set("",BL);a(d3,"tryJSONParse");a(Bf,"registerContentHandlers");f3=require("fastify-plugin"),_3=f3(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:o,type:c}=Ap(n.raw);s.type(c),s.serializer(function(l){let u;if(typeof l=="object"&&l&&(l[Symbol.iterator]||l[Symbol.asyncIterator])&&o.serializeStream){if(l.mapError){let f=l.getColumns;l=l.mapError(d=>(d.toJSON=()=>({error:d.name,message:d.message,...d.partialObject}),d)),l.getColumns=f}u=o.serializeStream}else u=o.serialize;return u(l,{headers:{set:a((f,d)=>{s.header(f,d)},"set")}})})}),r()},{name:"content-type-negotiation"});a(Ap,"findBestSerializer");LL=sR.default.get(B.HTTP_COMPRESSIONTHRESHOLD);a(Hf,"serialize");a(ua,"serializeMessage");a(rR,"asyncSerialization");a(nR,"hasAsyncSerialization");a(h3,"streamToBuffer");m3=["ascii","utf8","utf-8","utf16le","utf-16le","ucs2","ucs-2","base64","base64url","latin1","binary","hex"];a(p3,"isBufferEncoding");a(E3,"parseContentType");a(lo,"getDeserializer");a(g3,"deserializerUnknownType");a(S3,"transformIterable");a(Tp,"toCsvStream")});var lR={};Ue(lR,{start:()=>I3});function T3(e){if(e.kind!==Me.Kind.OPERATION_DEFINITION&&e.kind!==Me.Kind.FRAGMENT_DEFINITION)throw new Or(`Unexpected non-executable definition type ${e.kind}.`)}function kL(e){if(typeof e!="object"||e===null)throw new bi("Request body must be an object.");if(!("query"in e))throw new bi("Request body must contain a `query` field.");if(typeof e.query!="string")throw new bi("Request body `query` field must be a string.");if("variables"in e&&(typeof e.variables!="object"||e.variables===null))throw new bi("Request body `variables` field must be an object.");if("operationName"in e&&typeof e.operationName!="string")throw new bi("Request body `operationName` field must be a string.")}function cR(e){return parseInt(e.value,10)}function GL(e){return parseFloat(e.value)}function qL(e,t,r){let n=r.get(e.name.value);return $L(n)?VL(n,t):{attribute:t,value:n}}function $L(e){return typeof e=="object"&&e!=null&&!Array.isArray(e)}function VL(e,t){return t=typeof t=="string"?[t]:t,Object.entries(e).flatMap(([r,n])=>(t=[...t,r],$L(n)?VL(n,t):{attribute:t,value:n}))}function A3(e,t,r){switch(t=[...t,e.name.value],e.value.kind){case Me.Kind.NULL:return{attribute:t,value:null};case Me.Kind.INT:return{attribute:t,value:cR(e.value)};case Me.Kind.FLOAT:return{attribute:t,value:GL(e.value)};case Me.Kind.BOOLEAN:case Me.Kind.STRING:return{attribute:t,value:e.value.value};case Me.Kind.VARIABLE:return qL(e.value,t,r);case Me.Kind.OBJECT:return KL(e.value,t,r);case Me.Kind.LIST:case Me.Kind.ENUM:default:throw new Or(`Value type, ${e.value.kind}, is not supported.`)}}function KL(e,t,r){return e.fields.flatMap(n=>A3(n,t,r))}function R3(e,t){switch(e.value.kind){case Me.Kind.NULL:return{attribute:e.name.value,value:null};case Me.Kind.INT:return{attribute:e.name.value,value:cR(e.value)};case Me.Kind.FLOAT:return{attribute:e.name.value,value:GL(e.value)};case Me.Kind.BOOLEAN:case Me.Kind.STRING:return{attribute:e.name.value,value:e.value.value};case Me.Kind.VARIABLE:return qL(e.value,e.name.value,t);case Me.Kind.OBJECT:return KL(e.value,[e.name.value],t);case Me.Kind.LIST:case Me.Kind.ENUM:default:throw new Or(`Argument type, ${e.value.kind}, is not supported.`)}}function y3(e,t){return e.flatMap(r=>R3(r,t))}function Rp(e,t){return e.selections.flatMap(r=>{switch(r.kind){case Me.Kind.FIELD:return r;case Me.Kind.FRAGMENT_SPREAD:{let n=r.name.value,s=t.get(n);if(s==null)throw new Or(`Fragment \`${n}\` not found.`);return Rp(s.selectionSet,t)}case Me.Kind.INLINE_FRAGMENT:return Rp(r.selectionSet,t)}})}function YL(e,t){return Rp(e,t).map(r=>r.selectionSet?.selections.length>0?{name:r.name.value,select:YL(r.selectionSet,t)}:r.name.value)}async function b3(e,t,r,n){let s=_s.getMatch(e.name.value,"graphql");if(s===void 0)throw new Or(`Resource \`${e.name.value}\` not found.`);let i=s.Resource,o={select:YL(e.selectionSet,r),conditions:y3(e.arguments,t)},c=[];n.authorize=!0;for await(let l of i.search(o,n))c.push(l);return[e.name.value,c]}function WL(e){switch(e.kind){case Me.Kind.NULL:return null;case Me.Kind.INT:return cR(e);case Me.Kind.FLOAT:return parseFloat(e.value);case Me.Kind.STRING:case Me.Kind.BOOLEAN:return e.value;case Me.Kind.OBJECT:return e.fields.reduce((t,r)=>({[r.name.value]:WL(r.value),...t}),{});case Me.Kind.LIST:case Me.Kind.ENUM:default:throw new Or(`Value type, ${e.kind}, is not supported.`)}}function O3(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=WL(n.defaultValue)),n.type.kind===Me.Kind.NON_NULL_TYPE&&!(s in t)&&i===void 0)throw new Or(`Variable $${s} is required, but not provided.`);r.set(n.variable.name.value,i??null)}return r}async function N3(e,t,r,n){if(e.operation===Me.OperationTypeNode.SUBSCRIPTION)throw new Or("Subscriptions are not supported.");if(e.operation===Me.OperationTypeNode.MUTATION)throw new Or("Mutations are not supported yet.");let s=O3(e.variableDefinitions,t),i=await Promise.all(Rp(e.selectionSet,r).map(c=>b3(c,s,r,n))),o={data:{}};for(let[c,l]of i)o.data[c]=l;return o}async function FL({query:e,variables:t={},operationName:r},n){let s=Me.parse(e),i=new Map,o=new Map;for(let u of s.definitions)if(T3(u),u.kind===Me.Kind.FRAGMENT_DEFINITION)o.set(u.name.value,u);else{if(u.name===void 0&&s.definitions.length>1)throw new Or("Unnamed operations are only allowed when there is a single operation in the document.");let f=u.name?.value??"Unnamed Query";if(i.has(f))throw new Or(`Duplicate operation definition: ${f}`);i.set(f,u)}let c;if(r==null)if(i.size===1)c=i.entries().next().value[1];else throw new Or("Operation name is required when there are multiple operations in the document.");else if(c=i.get(r),c==null)throw new Or(`Operation \`${r}\` not found.`);let l=await N3(c,t,o,n);return{status:200,headers:{"Content-Type":"application/graphql-response+json; charset=utf-8"},body:JSON.stringify(l)}}async function w3(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 kL(r),FL(r,e)}case"POST":{let r=await lo(e.headers.get("content-type"),!0)(e._nodeRequest);return kL(r),FL(r,e)}default:throw new bi("Method Not Allowed",405,{Allow:"GET, POST"})}}function I3(e){e.server.http(async(t,r)=>{if(!t.url.startsWith("/graphql"))return r(t);try{return await w3(t)}catch(n){logger.error(n);let s=t.headers.get("accept")??"application/graphql-response+json";switch(s){case"application/json":{if(n instanceof bi)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json",...n.headers}};if(n instanceof Me.GraphQLError)return{status:200,body:JSON.stringify({errors:[n]}),headers:{"Content-Type":"application/json"}};if(n instanceof Or)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 bi)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json",...n.headers}};if(n instanceof Me.GraphQLError)return{status:400,body:JSON.stringify({errors:[n]}),headers:{"Content-Type":"application/graphql-response+json"}};if(n instanceof Or)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 Me,Or,bi,zL=Re(()=>{Me=M(require("graphql"));oo();ru();a(T3,"assertExecutableDefinitionNode");a(kL,"assertRequestParams");a(cR,"processIntValueNode");a(GL,"processFloatValueNode");a(qL,"processVariableNode");a($L,"isObject");a(VL,"transformObjectIntoQueryCondition");a(A3,"processObjectFieldNode");a(KL,"processObjectValueNode");a(R3,"processArgumentNode");a(y3,"buildConditionsQuery");a(Rp,"fillInFragments");a(YL,"buildSelectQuery");a(b3,"processFieldNode");a(WL,"processConstValueNode");a(O3,"resolveVariables");a(N3,"executeOperation");a(FL,"resolver");Or=class extends Error{static{a(this,"GraphQLQueryingError")}},bi=class extends Error{static{a(this,"HTTPError")}statusCode;headers;constructor(t,r=400,n={}){super(t),this.statusCode=r,this.headers=n}};a(w3,"graphqlQueryingHandler");a(I3,"start")});var Ni=C((YRe,JL)=>{"use strict";var jL=oe(),QL=(k(),P(q)),cu=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Oi=require("joi"),da={schema_format:{pattern:cu,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},C3=Oi.alternatives(Oi.string().min(1).max(da.schema_length.maximum).pattern(cu).messages({"string.pattern.base":"{:#label} "+da.schema_format.message}),Oi.number(),Oi.array()).required(),P3=Oi.alternatives(Oi.string().min(1).max(da.schema_length.maximum).pattern(cu).messages({"string.pattern.base":"{:#label} "+da.schema_format.message}),Oi.number()),D3=Oi.alternatives(Oi.string().min(1).max(da.schema_length.maximum).pattern(cu).messages({"string.pattern.base":"{:#label} "+da.schema_format.message}),Oi.number()).required();function L3(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>da.schema_length.maximum?`'${e}' maximum of 250 characters`:cu.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(L3,"checkValidTable");function M3(e,t){return jL.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(M3,"validateSchemaExists");function v3(e,t){let r=t.state.ancestors[0].schema;return jL.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(v3,"validateTableExists");function U3(e,t){return e.toLowerCase()===QL.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${QL.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(U3,"validateSchemaName");JL.exports={common_validators:da,schema_regex:cu,hdb_schema_table:C3,validateSchemaExists:M3,validateTableExists:v3,validateSchemaName:U3,checkValidTable:L3,hdb_database:P3,hdb_table:D3}});var dR=C((zRe,ZL)=>{var{hdb_table:x3,hdb_database:XL}=Ni(),B3=st(),uR=require("joi"),H3={undefined:"undefined",null:"null"},k3=a((e,t)=>{let r=Object.keys(e),n=r.length,s;for(let i=0;i<n;i++){let o=r[i];(!o||o.length===0||H3[o]!==void 0)&&(s===void 0?s=`Invalid attribute name: '${o}'`:s+=`. Invalid attribute name: '${o}'`)}return s?t.message(s):e},"custom_records_val"),F3=uR.object({database:XL,schema:XL,table:x3,records:uR.array().items(uR.object().custom(k3)).required()});ZL.exports=function(e){return B3.validateBySchema(e,F3)}});var tM=C((jRe,eM)=>{"use strict";var fR=class{static{a(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")}};eM.exports=fR});var nM=C((XRe,rM)=>{"use strict";var _R=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};rM.exports=_R});var cM={};Ue(cM,{HAS_EXPIRATION:()=>Op,HAS_RESIDENCY_ID:()=>TR,HAS_STRUCTURE_UPDATE:()=>wp,LAST_TIMESTAMP_PLACEHOLDER:()=>qf,LOCAL_TIMESTAMP:()=>G3,METADATA:()=>Ic,NEW_TIMESTAMP_PLACEHOLDER:()=>iM,NO_TIMESTAMP:()=>hR,PENDING_LOCAL_TIME:()=>AR,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>SR,RecordEncoder:()=>gR,TIMESTAMP_ASSIGN_LAST:()=>$3,TIMESTAMP_ASSIGN_NEW:()=>oM,TIMESTAMP_ASSIGN_PREVIOUS:()=>aM,TIMESTAMP_PLACEHOLDER:()=>yp,TIMESTAMP_RECORD_PREVIOUS:()=>mR,handleLocalTimeForGets:()=>Ip,recordUpdater:()=>RR,removeEntry:()=>Pc});function K3(){return Gf[0]=Gf[0]^64,q3.getFloat64(0)}function Ip(e,t){let r=e.getEntry;e.readCount=0,e.cachePuts=!1,e.rootStore=t,e.encoder.rootStore=t,e.getEntry=function(o,c){e.readCount++;let l=r.call(this,o,c),u=l?.value,f=u?.[Ic];return f>=0&&(l.metadataFlags=f,l.localTime=u.localTime,l.value=u.value,l.residencyId=u.residencyId,u.expiresAt>=0&&(l.expiresAt=u.expiresAt)),l&&(l.key=o),l};let n=e.get;e.get=function(o,c){let l=n.call(this,o,c);return l?.[Ic]>=0?l.value:l};let s=e.getRange;e.getRange=function(o){let c=s.call(this,o);return o.valuesForKey?c.map(l=>l?.value):o.values===!1||o.onlyCount?c:c.map(l=>{let u=l.value,f=u[Ic];return f>=0&&(l.metadataFlags=f,l.localTime=u.localTime,l.value=u.value,l.residencyId=u.residencyId,u.expiresAt>=0&&(l.expiresAt=u.expiresAt)),l})};let i=e.useReadTransaction();if(i.done(),!i.done.isTracked){let o=i.constructor,c=i.use,l=i.done;o.prototype.use=function(){this.timerTracked||(this.timerTracked=!0,wc.push(new WeakRef(this))),c.call(this)},o.prototype.done=function(){if(l.call(this),this.isDone)for(let u=0;u<wc.length;u++){let f=wc[u].deref();(!f||f.isDone||f.isCommitted)&&wc.splice(u--,1)}},o.prototype.done.isTracked=!0}return e}function RR(e,t,r){return function(n,s,i,o,c=-1,l,u,f="put",d,_){d||l==null?lu=i?.localTime?mR|aM:hR:lu=l?i?.localTime?mR|16384:oM|16384:hR;let h=u?.expiresAt;if(h>=0&&(c|=Op),Ff=c,pR=h,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let m={version:o,instructedWrite:lu>0},S,g=0;try{let R=i?.residencyId,E=u?.residencyId;E&&(ER=E,Ff|=TR,g|=Dc),R!==E&&(g|=Lc,R||(R=0)),c&Op&&(g|=Vf),u?.originatingOperation&&(g|=$f),d&&(m.ifVersion=S=i?.version??null),i&&i.value&&f!=="message"&&i.metadataFlags&Ur&&(r.getBinaryFast(i.localTime)||la(i.value));let T;if(s!==void 0&&(T=gp(()=>e.put(n,s,m),n,e.rootStore),bc&&(g|=Ur)),l){let N=u?.user?.username;if(_&&(gp(()=>e.encoder.encode(_),n,e.rootStore),bc&&(g|=Ur)),e.encoder.hasStructureUpdate&&(g|=wp,e.encoder.hasStructureUpdate=!1),d&&i?.localTime){let v=i?.localTime,H=r.get(v);if(H){let X=gt(H).previousLocalTime;return T=r.put(v,Cc(o,t,n,X,u?.nodeId??server.replication.getThisNodeId(r)??0,N,f,kf,g,E,R,h),{ifVersion:S}),T}}T=r.put(s===void 0?iM:qf,Cc(o,t,n,i?.localTime?1:0,u?.nodeId??server.replication?.getThisNodeId(r)??0,N,f,kf,g,E,R,h,u?.originatingOperation),{instructedWrite:!0,ifVersion:S})}return T}catch(R){throw R.message+=" id: "+n+" options: "+m,R}}}function Pc(e,t,r){if(t)return t.value&&t.metadataFlags&Ur&&!e.auditStore?.getBinaryFast(t.localTime)&&la(t.value),e.remove(t.key,r)}var sM,bp,yp,qf,SR,iM,G3,Ic,Gf,q3,hR,oM,$3,aM,mR,Op,TR,AR,wp,V3,kf,lu,Ff,pR,ER,gR,wc,uu=Re(()=>{sM=require("msgpackr");Ri();bp=M(ee());gn();gn();yp=new Uint8Array([1,1,1,1,4,64,0,0]),qf=new Uint8Array([1,1,1,1,1,0,0,0]),SR=new Uint8Array([1,1,1,1,3,64,0,0]),iM=new Uint8Array([1,1,1,1,0,64,0,0]),G3=Symbol("local-timestamp"),Ic=Symbol("metadata"),Gf=new Uint8Array(8),q3=new DataView(Gf.buffer,0,8),hR=0,oM=0,$3=1,aM=3,mR=4,Op=16,TR=32,AR=1,wp=256,lu=0,Ff=-1,pR=-1,ER=0,gR=class extends sM.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(s,i){if(lu||Ff>=0){let o=0,c=lu;c&&(o+=8,lu=0);let l=Ff,u=pR,f=ER;l>=0&&(o+=4,Ff=-1,u>=0&&(o+=8,pR=-1),f&&(o+=4,ER=0));let d=V3=r.call(this,s,i|2048|o);kf=d.subarray((d.start||0)+o,d.end);let _=d.start||0;return c&&(yp[4]=c,yp[5]=c>>8,d.set(yp,_),_+=8),bc&&(l|=Ur),l>=0&&((d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setUint32(_,l|Np<<24),_+=4,u>=0&&((d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setFloat64(_,u),_+=8),f&&(d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setUint32(_,f)),d}else return kf=r.call(this,s,i),kf};let n=this.saveStructures;this.saveStructures=function(s,i){let o=n.call(this,s,i);return this.hasStructureUpdate=!0,o}}decode(t,r){let n=r?.start||0,s=r>-1?r:r?.end||t.length,i=t[n],o=0;try{if(i<32&&s>2){let c=n,l;if(i===2){if(t.copy)t.copy(Gf,0,c),c+=8;else for(let _=0;_<8;_++)Gf[_]=t[c++];l=K3(),i=t[c]}let u,f;i<32&&(i===Np?(o=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4):(o=i|t[c+1]<<5,c+=2),o&Op&&(u=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8),o&TR&&(f=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4));let d=io(()=>r?.valueAsBuffer?t.subarray(c,s):super.decode(t.subarray(c,s),s-c),this.rootStore);return{localTime:l,value:d,[Ic]:o,expiresAt:u,residencyId:f}}return r?.valueAsBuffer?t:io(()=>super.decode(t,r),this.rootStore)}catch(c){return bp.error("Error decoding record",c,"data: "+t.slice(0,40).toString("hex")),null}}};a(K3,"getTimestamp");a(Ip,"handleLocalTimeForGets");wc=[];setInterval(()=>{for(let e=0;e<wc.length;e++){let t=wc[e].deref();!t||t.isDone||t.isCommitted?wc.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(bp.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):bp.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();a(RR,"recordUpdater");a(Pc,"removeEntry")});var Kf=C((sye,uM)=>{"use strict";var lM=ce(),Y3=(k(),P(q)),{RecordEncoder:W3}=(uu(),P(cM));lM.initSync();var z3=lM.get(Y3.CONFIG_PARAMS.STORAGE_CACHING)!==!1,yR=class{static{a(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=z3&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:W3})}};uM.exports=yR});var Yf=C((oye,dM)=>{"use strict";var Gn=ce(),hs=(k(),P(q));Gn.initSync();var Cp=class{static{a(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=Gn.get(hs.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Gn.get(hs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Gn.get(hs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Gn.get(hs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Gn.get(hs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Gn.get(hs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Gn.get(hs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Gn.get(hs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Gn.get(hs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Gn.get(hs.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Gn.get(hs.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Gn.get(hs.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};dM.exports=Cp;Cp.MAX_DBS=1e4});var _t=C((cye,AM)=>{"use strict";var OR=require("lmdb"),qs=require("fs-extra"),qn=require("path"),Pp=fn(),hM=ee(),Sn=Un().LMDB_ERRORS_ENUM,Dp=nM(),NR=Kf(),mM=Yf(),fa=kt(),fM=(k(),P(q)),{table:Q3,resetDatabases:j3}=(xe(),P(at)),_M=ce(),$s=fa.INTERNAL_DBIS_NAME,pM=fa.DBI_DEFINITION_NAME,J3="data.mdb",X3="lock.mdb",Wf=".mdb",Z3="-lock",bR=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=ms(t,r),this.key_type=this.dbi[fa.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[fa.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new OR.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function Lp(e,t){if(e===void 0)throw new Error(Sn.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(Sn.ENV_NAME_REQUIRED)}a(Lp,"pathEnvNameValidation");async function wR(e,t,r=!0){try{await qs.access(e)}catch(n){throw n.code==="ENOENT"?new Error(Sn.INVALID_BASE_PATH):n}try{let n=qn.join(e,t+Wf);return await qs.access(n,qs.constants.R_OK|qs.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await qs.access(qn.join(e,t,J3),qs.constants.R_OK|qs.constants.F_OK),qn.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(Sn.INVALID_ENVIRONMENT)}else throw new Error(Sn.INVALID_ENVIRONMENT);throw n}}a(wR,"validateEnvironmentPath");function Mp(e,t){if(Pp.validateEnv(e),t===void 0)throw new Error(Sn.DBI_NAME_REQUIRED)}a(Mp,"validateEnvDBIName");async function eX(e,t,r=!1,n=!1){Lp(e,t);let s=qn.basename(e);t=t.toString();let i=_M.get(fM.CONFIG_PARAMS.DATABASES);i||_M.setProperty(fM.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await wR(e,t,n),EM(e,t,r)}catch(o){if(o.message===Sn.INVALID_ENVIRONMENT){let c=qn.join(e,t);await qs.mkdirp(n?c:e);let l=new mM(n?c:c+Wf,!1),u=OR.open(l);u.dbis=Object.create(null);let f=new NR(!1);u.openDB($s,f),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let d=IR(e,t,r);return u[fa.ENVIRONMENT_NAME_KEY]=d,global.lmdb_map[d]=u,u}throw o}}a(eX,"createEnvironment");async function tX(e,t,r,n=!0){Lp(e,t),t=t.toString();let s=qn.join(e,t);return Q3({table:t,database:qn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(tX,"copyEnvironment");async function EM(e,t,r=!1){Lp(e,t),t=t.toString();let n=IR(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 wR(e,t),i=qn.join(e,t+Wf),o=s!=i,c=new mM(s,o),l=OR.open(c);l.dbis=Object.create(null);let u=SM(l);for(let f=0;f<u.length;f++)ms(l,u[f]);return l[fa.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(EM,"openEnvironment");async function rX(e,t,r=!1){Lp(e,t),t=t.toString();let n=qn.join(e,t+Wf),s=await wR(e,t);if(global.lmdb_map!==void 0){let i=IR(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await gM(o),delete global.lmdb_map[i]}}await qs.remove(s),await qs.remove(s===n?s+Z3:qn.join(qn.dirname(s),X3))}a(rX,"deleteEnvironment");async function gM(e){Pp.validateEnv(e);let t=e[fa.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(gM,"closeEnvironment");function IR(e,t,r=!1){let s=`${qn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(IR,"getCachedEnvironmentName");function nX(e){Pp.validateEnv(e);let t=Object.create(null),r=ms(e,$s);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==$s)try{t[n]=Object.assign(new Dp,s)}catch{hM.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(nX,"listDBIDefinitions");function SM(e){Pp.validateEnv(e);let t=[],r=ms(e,$s);for(let{key:n}of r.getRange({start:!1}))n!==$s&&t.push(n);return t}a(SM,"listDBIs");function sX(e,t){let n=ms(e,$s).getEntry(t),s=new Dp;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{hM.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(sX,"getDBIDefinition");function TM(e,t,r,n=!r){if(Mp(e,t),t=t.toString(),t===$s)throw new Error(Sn.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return ms(e,t)}catch(s){if(s.message===Sn.DBI_DOES_NOT_EXIST){let i=new NR(r,n===!0),o=e.openDB(t,i),c=new Dp(r===!0,n);return o[pM]=c,ms(e,$s).putSync(t,c),e.dbis[t]=o,o}throw s}}a(TM,"createDBI");function ms(e,t){if(Mp(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==$s?r=sX(e,t):r=new Dp,r===void 0)throw new Error(Sn.DBI_DOES_NOT_EXIST);let n;try{let s=new NR(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(Sn.DBI_DOES_NOT_EXIST):s}return n[pM]=r,e.dbis[t]=n,n}a(ms,"openDBI");function iX(e,t){Mp(e,t),t=t.toString();let r=ms(e,t),n=r.getStats();return r[fa.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(iX,"statDBI");async function oX(e,t){try{let r=qn.join(e,t+Wf);return(await qs.stat(r)).size}catch{throw new Error(Sn.INVALID_ENVIRONMENT)}}a(oX,"environmentDataSize");function aX(e,t){if(Mp(e,t),t=t.toString(),t===$s)throw new Error(Sn.CANNOT_DROP_INTERNAL_DBIS_NAME);ms(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],ms(e,$s).removeSync(t)}a(aX,"dropDBI");function cX(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{ms(e,i)}catch(o){if(o.message===Sn.DBI_DOES_NOT_EXIST)TM(e,i,i!==t,i===t),n=!0;else throw o}}n&&j3()}a(cX,"initializeDBIs");AM.exports={openDBI:ms,openEnvironment:EM,createEnvironment:eX,listDBIs:SM,listDBIDefinitions:nX,createDBI:TM,dropDBI:aX,statDBI:iX,deleteEnvironment:rX,initializeDBIs:cX,TransactionCursor:bR,environmentDataSize:oX,copyEnvironment:tX,closeEnvironment:gM}});var yM=C((uye,RM)=>{"use strict";var CR=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};RM.exports=CR});var OM=C((fye,bM)=>{"use strict";var PR=class{static{a(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}};bM.exports=PR});var wM=C((hye,NM)=>{"use strict";var DR=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};NM.exports=DR});var vc=C((Sye,PM)=>{"use strict";var lX=_t(),uX=yM(),dX=OM(),fX=wM(),wi=fn(),zf=Un().LMDB_ERRORS_ENUM,_X=kt(),uo=(k(),P(q)),hX=oe(),mX=require("uuid"),pye=require("lmdb"),{handleHDBError:pX,hdb_errors:EX}=me(),{OVERFLOW_MARKER:Eye,MAX_SEARCH_KEY_LENGTH:gye}=_X,IM=ce();IM.initSync();var vp=IM.get(uo.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),LR=uo.TIME_STAMP_NAMES_ENUM.CREATED_TIME,Mc=uo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function gX(e,t,r,n,s=wi.getNextMonotonicTime()){xR(e,t,r,n),MR(e,t,r);let i=new uX,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l];CM(u,!0,s);let f=SX(e,t,r,u),d=u[t];o.push(f),c.push(d)}return vR(o,c,n,i,s)}a(gX,"insertRecords");function SX(e,t,r,n){let s=n[t];return e.dbis[t].ifNoExists(s,()=>{for(let i=0;i<r.length;i++){let o=r[i];if(o===t||n.hasOwnProperty(o)===!1)continue;let c=n[o];if(typeof c=="function"){let f=c([[{}]]);Array.isArray(f)&&(c=f[0][uo.FUNC_VAL],n[o]=c)}let l=wi.getIndexedValues(c),u=e.dbis[o];if(l){vp&&u.prefetch(l.map(f=>({key:f,value:s})),Up);for(let f=0,d=l.length;f<d;f++)u.put(l[f],s)}}vp&&e.dbis[t].prefetch([s],Up),e.dbis[t].put(s,n,n[Mc])})}a(SX,"insertRecord");function TX(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(TX,"removeSkippedRecords");function CM(e,t,r){let n=r>0;(n||!Number.isInteger(e[Mc]))&&(e[Mc]=r||(r=wi.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[LR]))&&(e[LR]=r||wi.getNextMonotonicTime()):delete e[LR]}a(CM,"setTimestamps");function MR(e,t,r){r.indexOf(uo.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(uo.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(uo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(uo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),lX.initializeDBIs(e,t,r)}a(MR,"initializeTransaction");async function AX(e,t,r,n,s=wi.getNextMonotonicTime()){xR(e,t,r,n),MR(e,t,r);let i=new dX,o=[],c=[],l=[];for(let u=0;u<n.length;u++){let f=n[u],d=f[t],_;try{_=UR(e,t,f,d,i,!0,s)}catch{i.skipped_hashes.push(d),o.push(u);continue}c.push(_),l.push(d)}return vR(c,l,n,i,s,o)}a(AX,"updateRecords");async function RX(e,t,r,n,s=wi.getNextMonotonicTime()){try{xR(e,t,r,n)}catch(l){throw pX(l,l.message,EX.HTTP_STATUS_CODES.BAD_REQUEST)}MR(e,t,r);let i=new fX,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l],f;hX.isEmpty(u[t])?(f=mX.v4(),u[t]=f):f=u[t];let d=UR(e,t,u,f,i,!1,s);o.push(d),c.push(f)}return vR(o,c,n,i,s)}a(RX,"upsertRecords");async function vR(e,t,r,n,s,i=[]){let o=await Promise.all(e);for(let c=0,l=o.length;c<l;c++)o[c]===!0?n.written_hashes.push(t[c]):(n.skipped_hashes.push(t[c]),i.push(c));return n.txn_time=s||wi.getNextMonotonicTime(),TX(r,i),n}a(vR,"finalizeWrite");function UR(e,t,r,n,s,i=!1,o){let c=e.dbis[t],l=c.getEntry(n),u=l?.value,f=u;if(!u){if(i)return!1;u={}}if(CM(r,!f,o),Number.isInteger(r[Mc])&&u[Mc]>r[Mc])return!1;f&&s.original_records.push(u);let d,_=a(()=>{for(let m in r){if(!r.hasOwnProperty(m)||m===t)continue;let S=r[m],g=e.dbis[m];if(g===void 0)continue;let R=u[m];if(typeof S=="function"){let T=S([[u]]);Array.isArray(T)&&(S=T[0][uo.FUNC_VAL],r[m]=S)}if(S===R)continue;let E=wi.getIndexedValues(R);if(E){vp&&g.prefetch(E.map(T=>({key:T,value:n})),Up);for(let T=0,N=E.length;T<N;T++)g.remove(E[T],n)}if(E=wi.getIndexedValues(S),E){vp&&g.prefetch(E.map(T=>({key:T,value:n})),Up);for(let T=0,N=E.length;T<N;T++)g.put(E[T],n)}}let h={...u,...r};c.put(n,h,h[Mc])},"do_put");return l?d=c.ifVersion(n,l.version,_):d=c.ifNoExists(n,_),d.then(h=>h?!0:UR(e,t,r,n,s,i,o))}a(UR,"updateUpsertRecord");function yX(e,t,r){if(wi.validateEnv(e),t===void 0)throw new Error(zf.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(zf.WRITE_ATTRIBUTES_REQUIRED):new Error(zf.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(yX,"validateBasic");function xR(e,t,r,n){if(yX(e,t,r),!Array.isArray(n))throw n===void 0?new Error(zf.RECORDS_REQUIRED):new Error(zf.RECORDS_MUST_BE_ARRAY)}a(xR,"validateWrite");function Up(){}a(Up,"noop");PM.exports={insertRecords:gX,updateRecords:AX,upsertRecords:RX}});var fo=C((Aye,bX)=>{bX.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:{hash_attribute:"id",name:"hdb_analytics",schema:"system",audit:!1,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 LM=C((Rye,DM)=>{"use strict";var OX=require("uuid"),BR=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||OX.v4(),this.schema_table=`${this.schema}.${this.table}`}};DM.exports=BR});var xp=C((bye,MM)=>{"use strict";var NX=LM(),HR=class extends NX{static{a(this,"LMDBCreateAttributeObject")}constructor(t,r,n,s,i=!0,o=!1){super(t,r,n,s),this.dup_sort=i,this.is_hash_attribute=o}};MM.exports=HR});var UM=C((Nye,vM)=>{"use strict";vM.exports=IX;var wX="inserted";function IX(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===wX?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(IX,"returnObject")});var Bp=C((Cye,BM)=>{"use strict";var CX=(k(),P(q)),kR=_t(),PX=vc(),{getSystemSchemaPath:DX,getSchemaPath:LX}=Et(),Iye=fo(),{validateBySchema:MX}=st(),Qf=require("joi"),vX=xp(),UX=UM(),{handleHDBError:xX,hdb_errors:BX,ClientError:HX}=me(),xM=oe(),{HTTP_STATUS_CODES:kX}=BX,FX="inserted";BM.exports=GX;async function GX(e){let t=MX(e,Qf.object({database:Qf.string(),schema:Qf.string(),table:Qf.string().required(),attribute:Qf.string().required()}));if(t)throw new HX(t.message);let r=!e.skip_table_check&&xM.checkGlobalSchemaTable(e.schema,e.table);if(r)throw xX(new Error,r,kX.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=xM.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 vX(e.schema,e.table,e.attribute,e.id);try{let i=await kR.openEnvironment(LX(e.schema,e.table),e.table);if(i.dbis[e.attribute]!==void 0)throw new Error(`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`);kR.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await kR.openEnvironment(DX(),CX.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await PX.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_attribute_attributes,[s]);return UX(FX,c,{records:[s]},l)}catch(i){throw i}}a(GX,"lmdbCreateAttribute")});var jf=C((Lye,kM)=>{"use strict";var _o=oe(),HM=ee(),Dye=dR(),{getDatabases:qX}=(xe(),P(at)),{ClientError:Uc}=me();kM.exports=$X;function $X(e){if(_o.isEmpty(e))throw new Uc("invalid update parameters defined.");if(_o.isEmptyOrZeroLength(e.schema))throw new Uc("invalid schema specified.");if(_o.isEmptyOrZeroLength(e.table))throw new Uc("invalid table specified.");if(!Array.isArray(e.records))throw new Uc("records must be an array");let t=qX()[e.schema]?.[e.table];if(_o.isEmpty(t))throw new Uc(`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(o=>{if(i&&_o.isEmptyOrZeroLength(o[r]))throw HM.error("a valid hash attribute must be provided with update record:",o),new Uc("a valid hash attribute must be provided with update record, check log for more info");if(!_o.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw HM.error(`a valid hash value must be provided with ${e.operation} record:`,o),new Uc(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!_o.isEmpty(o[r])&&o[r]!==""&&n.has(_o.autoCast(o[r]))&&(o.skip=!0),n.add(_o.autoCast(o[r]));for(let c in o)s[c]=1}),s[r]=1,{schema_table:t,hashes:Array.from(n),attributes:Object.keys(s)}}a($X,"insertUpdateValidate")});var GM=C((vye,FM)=>{"use strict";var FR=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};FM.exports=FR});var VM=C((xye,$M)=>{"use strict";var GR=_t(),VX=ee(),qM=Un().LMDB_ERRORS_ENUM;$M.exports=KX;async function KX(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 o=t[i];if(o.startsWith(`${e.schema}.`)||o.startsWith(`txn.${e.schema}.`))try{await GR.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==qM.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await GR.closeEnvironment(global.lmdb_map[n]),await GR.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==qM.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){VX.error(t)}}a(KX,"cleanLMDBMap")});var nv=C((kye,rv)=>{"use strict";var qR=require("recursive-iterator"),YX=require("alasql"),$R=require("clone"),KM=oe(),{handleHDBError:YM,hdb_errors:WX}=me(),{HDB_ERROR_MSGS:WM,HTTP_STATUS_CODES:zM}=WX,{getDatabases:zX}=(xe(),P(at)),QX=["DISTINCT_ARRAY"],QM=Symbol("validateTables"),VR=Symbol("validateTable"),Hye=Symbol("getAllColumns"),jM=Symbol("validateAllColumns"),Hp=Symbol("findColumn"),JM=Symbol("validateOrderBy"),Jf=Symbol("validateSegment"),KR=Symbol("validateColumn"),XM=Symbol("setColumnsForTable"),ZM=Symbol("checkColumnsForAsterisk"),ev=Symbol("validateGroupBy"),tv=Symbol("hasColumns"),YR=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[QM](),this[ZM](),this[jM]()}[QM](){if(this[tv]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[VR](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[VR](t.table)})}}[tv](){let t=!1,r=new qR(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[VR](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=zX();if(!r[t.databaseid])throw YM(new Error,WM.SCHEMA_NOT_FOUND(t.databaseid),zM.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw YM(new Error,WM.TABLE_NOT_FOUND(t.databaseid,t.tableid),zM.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=$R(s);i.table=$R(t),this.attributes.push(i)})}[Hp](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)}[ZM](){let t=new qR(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[XM](r.tableid)}[XM](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new YX.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[jM](){this[Jf](this.statement.columns,!1),this[Jf](this.statement.joins,!1),this[Jf](this.statement.where,!1),this[ev](this.statement.group,!1),this[Jf](this.statement.order,!0)}[Jf](t,r){if(!t)return;let n=new qR(t),s=[];for(let{node:i,path:o}of n)!KM.isEmpty(i)&&!KM.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[JM](i):s.push(this[KR](i)));return s}[ev](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&QX.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=$R(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[Hp](n)[0];s&&r.push(s)}}}),this.statement.group.forEach(n=>{let s=null;if(!n.columnid)r.forEach((i,o)=>{if(i.toString()===n.toString()){s=i,r.splice(o,1);return}});else{let i=this[Hp](n);if(!i||i.length===0)throw`unknown column '${n.toString()}' in group by`;if(i.length>1)throw`ambiguously defined column '${n.toString()}' in group by`;r.forEach((o,c)=>{if(o.attribute===i[0].attribute&&o.table.tableid===i[0].table.tableid){s=o,r.splice(c,1);return}})}if(!s)throw`group by column '${n.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`}[JM](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[KR](t)}[KR](t){let r=this[Hp](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]}};rv.exports=YR});var av=C((Gye,ov)=>{"use strict";var sv=require("lodash"),Xf=require("mathjs"),jX=require("jsonata"),iv=oe();ov.exports={distinct_array:a(e=>Array.isArray(e)&&e.length>1?sv.uniqWith(e,sv.isEqual):e,"distinct_array"),searchJSON:JX,mad:Zf.bind(null,Xf.mad),mean:Zf.bind(null,Xf.mean),mode:Zf.bind(null,Xf.mode),prod:Zf.bind(null,Xf.prod),median:Zf.bind(null,Xf.median)};function Zf(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}a(Zf,"aggregateFunction");function JX(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(iv.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),iv.isEmpty(this.__ala__.res[r])){let n=jX(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(JX,"searchJSON")});var lv=C(($ye,cv)=>{"use strict";var rr=require("moment"),WR="YYYY-MM-DDTHH:mm:ss.SSSZZ";rr.suppressDeprecationWarnings=!0;cv.exports={current_date:a(()=>rr().utc().format("YYYY-MM-DD"),"current_date"),current_time:a(()=>rr().utc().format("HH:mm:ss.SSS"),"current_time"),extract:a((e,t)=>{switch(t.toLowerCase()){case"year":return rr(e).utc().format("YYYY");case"month":return rr(e).utc().format("MM");case"day":return rr(e).utc().format("DD");case"hour":return rr(e).utc().format("HH");case"minute":return rr(e).utc().format("mm");case"second":return rr(e).utc().format("ss");case"millisecond":return rr(e).utc().format("SSS");default:break}},"extract"),date:a(e=>rr(e).utc().format(WR),"date"),date_format:a((e,t)=>rr(e).utc().format(t),"date_format"),date_add:a((e,t,r)=>rr(e).utc().add(t,r).valueOf(),"date_add"),date_sub:a((e,t,r)=>rr(e).utc().subtract(t,r).valueOf(),"date_sub"),date_diff:a((e,t,r)=>{let n=rr(e).utc(),s=rr(t).utc();return r?n.diff(s,r,!0):n.diff(s)},"date_diff"),now:a(()=>rr().utc().valueOf(),"now"),get_server_time:a(()=>rr().format(WR),"get_server_time"),offset_utc:a((e,t)=>rr(e).utc().utcOffset(t).format(WR),"offset_utc")}});var _v=C((Kye,fv)=>{"use strict";var XX=require("@turf/area"),ZX=require("@turf/length"),e6=require("@turf/circle"),t6=require("@turf/difference"),r6=require("@turf/distance"),n6=require("@turf/boolean-contains"),s6=require("@turf/boolean-equal"),i6=require("@turf/boolean-disjoint"),o6=require("@turf/helpers"),uv=(k(),P(q)),Ke=oe(),ho=ee();fv.exports={geoArea:a6,geoLength:c6,geoCircle:l6,geoDifference:u6,geoDistance:dv,geoNear:d6,geoContains:f6,geoEqual:_6,geoCrosses:h6,geoConvert:m6};function a6(e){if(Ke.isEmpty(e))return NaN;typeof e=="string"&&(e=Ke.autoCastJSON(e));try{return XX.default(e)}catch(t){return ho.trace(t,e),NaN}}a(a6,"geoArea");function c6(e,t){if(Ke.isEmpty(e))return NaN;typeof e=="string"&&(e=Ke.autoCastJSON(e));try{return ZX.default(e,{units:t||"kilometers"})}catch(r){return ho.trace(r,e),NaN}}a(c6,"geoLength");function l6(e,t,r){if(Ke.isEmpty(e))return NaN;if(Ke.isEmpty(t))return NaN;typeof e=="string"&&(e=Ke.autoCastJSON(e));try{return e6.default(e,t,{units:r||"kilometers"})}catch(n){return ho.trace(n,e,t),NaN}}a(l6,"geoCircle");function u6(e,t){if(Ke.isEmpty(e))return NaN;if(Ke.isEmpty(t))return NaN;typeof e=="string"&&(e=Ke.autoCastJSON(e)),typeof t=="string"&&(t=Ke.autoCastJSON(t));try{return t6(e,t)}catch(r){return ho.trace(r,e,t),NaN}}a(u6,"geoDifference");function dv(e,t,r){if(Ke.isEmpty(e))return NaN;if(Ke.isEmpty(t))return NaN;typeof e=="string"&&(e=Ke.autoCastJSON(e)),typeof t=="string"&&(t=Ke.autoCastJSON(t));try{return r6.default(e,t,{units:r||"kilometers"})}catch(n){return ho.trace(n,e,t),NaN}}a(dv,"geoDistance");function d6(e,t,r,n){if(Ke.isEmpty(e)||Ke.isEmpty(t))return!1;if(Ke.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=Ke.autoCastJSON(e)),typeof t=="string"&&(t=Ke.autoCastJSON(t)),isNaN(r))throw new Error("distance must be a number");try{return dv(e,t,n)<=r}catch(s){return ho.trace(s,e,t),!1}}a(d6,"geoNear");function f6(e,t){if(Ke.isEmpty(e)||Ke.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Ke.autoCastJSON(e)),typeof t=="string"&&(t=Ke.autoCastJSON(t));try{return n6.default(e,t)}catch(r){return ho.trace(r,e,t),!1}}a(f6,"geoContains");function _6(e,t){if(Ke.isEmpty(e)||Ke.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Ke.autoCastJSON(e)),typeof t=="string"&&(t=Ke.autoCastJSON(t));try{return s6.default(e,t)}catch(r){return ho.trace(r,e,t),!1}}a(_6,"geoEqual");function h6(e,t){if(Ke.isEmpty(e)||Ke.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Ke.autoCastJSON(e)),typeof t=="string"&&(t=Ke.autoCastJSON(t));try{return!i6.default(e,t)}catch(r){return ho.trace(r,e,t),!1}}a(h6,"geoCrosses");function m6(e,t,r){if(Ke.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if(Ke.isEmpty(t))throw new Error("geo_type is required");if(Ke.isEmpty(uv.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(uv.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Ke.autoCastJSON(e)),o6[t](e,r)}a(m6,"geoConvert")});var kp=C((Wye,hv)=>{var xc=av(),$n=lv(),Ii=_v();hv.exports=e=>{e.aggr.mad=e.aggr.MAD=xc.mad,e.aggr.mean=e.aggr.MEAN=xc.mean,e.aggr.mode=e.aggr.MODE=xc.mode,e.aggr.prod=e.aggr.PROD=xc.prod,e.aggr.median=e.aggr.MEDIAN=xc.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=xc.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=xc.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=$n.current_date,e.fn.current_time=e.fn.CURRENT_TIME=$n.current_time,e.fn.extract=e.fn.EXTRACT=$n.extract,e.fn.date=e.fn.DATE=$n.date,e.fn.date_format=e.fn.DATE_FORMAT=$n.date_format,e.fn.date_add=e.fn.DATE_ADD=$n.date_add,e.fn.date_sub=e.fn.DATE_SUB=$n.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=$n.date_diff,e.fn.now=e.fn.NOW=$n.now,e.fn.offset_utc=e.fn.OFFSET_UTC=$n.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=$n.get_server_time,e.fn.getdate=e.fn.GETDATE=$n.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=$n.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=Ii.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=Ii.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=Ii.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=Ii.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=Ii.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=Ii.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=Ii.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=Ii.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=Ii.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=Ii.geoNear}});var gv=C((zye,Ev)=>{"use strict";var e_=require("lodash"),Tn=require("alasql");Tn.options.cache=!1;var p6=kp(),mv=require("clone"),Fp=require("recursive-iterator"),ke=ee(),Je=oe(),du=Vn(),E6=(k(),P(q)),{hdb_errors:g6}=me(),{getDatabases:pv}=(xe(),P(at)),S6="IS NULL",Vs="There was a problem performing this search. Please check the logs and try again.";p6(Tn);var zR=class{static{a(this,"SQLSearch")}constructor(t,r){if(Je.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(),Je.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!Je.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(Vs)}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(Vs)}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(Vs)}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(Vs)}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(Vs)}}_getColumns(){let t=new Fp(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(mv(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=e_.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].__hash_name=pv()[r.databaseid][r.tableid].primaryKey,this.data[n].__merged_data={},this.data[n].__merged_attributes=[],this.data[n].__merged_attr_map={}})}_conditionsToFetchAttributeValues(){if(Je.isEmpty(this.statement.where)){ke.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new Fp(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!Je.isEmpty(r)&&r.right)if(Je.isNotEmptyAndHasValue(r.right.value)){let n=Je.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new Tn.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=Je.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new Tn.yy.LogicValue({value:i}):n instanceof Tn.yy.StringValue&&Je.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new Tn.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 Fp(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 o=[i.table.databaseid,i.table.tableid,i.attribute].join("/");if(!Je.isEmpty(E6.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(Je.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(Je.isEmptyOrZeroLength(r.left.columnid)||Je.isEmptyOrZeroLength(r.right.value)){this.comparator_search_values[o].ignore=!0,this.comparator_search_values[o].comparators=[];continue}this.comparator_search_values[o].comparators.push({attribute:r.left.columnid,operation:r.op,search_value:r.right.value})}continue}if(Je.isEmpty(this.exact_search_values[o])&&(this.exact_search_values[o]={ignore:!1,values:new Set}),!this.exact_search_values[o].ignore){let c=!1;switch(r.op){case"=":!Je.isEmpty(r.right.value)||!Je.isEmpty(r.left.value)?n.add(Je.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[o].ignore=c,c?this.exact_search_values[o].values=new Set:this.exact_search_values[o].values=new Set([...this.exact_search_values[o].values,...n])}}}_setAliasesForColumns(){if(Je.isEmptyOrZeroLength(this.all_table_attributes)&&Je.isEmptyOrZeroLength(this.statement.from)&&Je.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&&e_.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(Je.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);Je.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(Je.isEmptyOrZeroLength(this.all_table_attributes)&&!Je.isEmptyOrZeroLength(this.columns.columns))return t;if(Je.isEmptyOrZeroLength(this.all_table_attributes)&&Je.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await Tn.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(mv(n))})}_addColumnToMergedAttributes(t,r){this.data[t].__merged_attributes.push(r),this.data[t].__merged_attr_map[r]=this.data[t].__merged_attributes.length-1}_setMergedHashAttribute(t,r){this.data[t].__merged_data[r].splice(0,1,r)}_updateMergedAttribute(t,r,n,s){let i=this.data[t].__merged_attr_map[n];this.data[t].__merged_data[r].splice(i,1,s)}async _getFetchAttributeValues(){if(Je.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(S6)>-1&&this.tables.forEach(s=>{let i={columnid:pv()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=e_.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 o=`${i.table.databaseid}_${i.table.as?i.table.as:i.table.tableid}`,c=this.data[o].__hash_name;return s[o]||(s[o]=[],s[o].push(null),this._addColumnToMergedAttributes(o,c)),i.attribute!==c&&(s[o].push(null),this._addColumnToMergedAttributes(o,i.attribute)),s},{});for(let s of this.fetch_attributes){let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`,o=this.data[i].__hash_name,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===o&&(l=!0),!Je.isEmpty(this.exact_search_values[u])&&!this.exact_search_values[u].ignore&&!Je.isEmptyOrZeroLength(this.exact_search_values[u].values))if(l)try{c.hash_values=Array.from(this.exact_search_values[u].values);let f=await du.getDataByHash(c);for(let d of c.hash_values)f.get(d)&&!this.data[i].__merged_data[d]&&(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d))}catch(f){throw ke.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),ke.error(f),new Error(Vs)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[u].values).map(async f=>{let d={...c};d.search_value=f;let _=await du.getDataByValue(d);for(let[h,m]of _)this.data[i].__merged_data[h]?this._updateMergedAttribute(i,h,s.attribute,m[s.attribute]):(this.data[i].__merged_data[h]=[...n[i]],this._updateMergedAttribute(i,h,s.attribute,m[s.attribute]),this._setMergedHashAttribute(i,h))}))}catch(f){throw ke.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),ke.error(f),new Error(Vs)}else if(!Je.isEmpty(this.comparator_search_values[u])&&!this.comparator_search_values[u].ignore&&!Je.isEmptyOrZeroLength(this.comparator_search_values[u].comparators))try{let f=this.comparator_search_values[u].comparators;for(let d=0,_=f.length;d<_;d++){let h=f[d];c.search_attribute=h.attribute,c.search_value=h.search_value;let m=await du.getDataByValue(c,h.operation);if(l)for(let[S]of m)this.data[i].__merged_data[S]||(this.data[i].__merged_data[S]=[...n[i]],this._setMergedHashAttribute(i,S));else for(let[S,g]of m)this.data[i].__merged_data[S]?this._updateMergedAttribute(i,S,s.attribute,g[s.attribute]):(this.data[i].__merged_data[S]=[...n[i]],this._updateMergedAttribute(i,S,s.attribute,g[s.attribute]),this._setMergedHashAttribute(i,S))}}catch(f){throw ke.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),ke.error(f),new Error(Vs)}else try{c.search_attribute=s.attribute,c.search_value="*";let f=await du.getDataByValue(c);if(l)for(let[d]of f)this.data[i].__merged_data[d]||(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d));else for(let[d,_]of f)this.data[i].__merged_data[d]?this._updateMergedAttribute(i,d,s.attribute,_[s.attribute]):(this.data[i].__merged_data[d]=[...n[i]],this._updateMergedAttribute(i,d,s.attribute,_[s.attribute]),this._setMergedHashAttribute(i,d))}catch(f){throw ke.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),ke.error(f),new Error(Vs)}}}_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 Tn.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,o=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===o});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 Tn.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new Tn.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 Tn.yy.FuncValue:new Tn.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}`].__merged_data)),this.statement.joins&&this.statement.joins.forEach(h=>{h.joinmode&&h.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(h.table);let m=h.joinmode+" JOIN ? AS "+(h.as?h.as:h.table.tableid);h.on&&(m+=" ON "+h.on.toString()),i.push(m),t.push(Object.values(this.data[`${h.table.databaseid_orig}_${h.table.as?h.table.as_orig:h.table.tableid_orig}`].__merged_data))});let o=[],c={};s.forEach(h=>{let m=this.data[`${h.databaseid_orig}_${h.as?h.as_orig:h.tableid_orig}`].__hash_name,S=h.as?h.as_orig:h.tableid_orig;o.push({key:`'${S}.${m}'`,schema:h.databaseid_orig,table:h.as?h.as_orig:h.tableid_orig,keys:new Set}),r.push(`${h.as?h.as:h.tableid}.\`${m}\` AS "${S}.${m}"`),c[h.as?h.as_orig:h.tableid_orig]=this.data[`${h.databaseid_orig}_${h.as?h.as_orig:h.tableid_orig}`].__merged_attributes});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 f="",d="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(f=this.statement.limit?"LIMIT "+this.statement.limit:"",d=this.statement.offset?"OFFSET "+this.statement.offset:"");let _=[];try{let h=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${l} ${u} ${f} ${d}`,m=this._convertColumnsToIndexes(h,s);_=await Tn.promise(m,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(_&&_.length>0){for(let h=0,m=_.length;h<m;h++){let S=_[h];o.forEach(g=>{S[g.key]!==null&&S[g.key]!==void 0&&g.keys.add(S[g.key])})}o.forEach(h=>{let m=Object.keys(this.data[`${h.schema}_${h.table}`].__merged_data),S=e_.difference(m,[...h.keys].map(g=>g.toString()));for(let g=0,R=S.length;g<R;g++){let E=S[g];delete this.data[`${h.schema}_${h.table}`].__merged_data[E]}})}return{existing_attributes:c,joined_length:_?_.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new Fp(this.columns);for(let{node:i}of s)if(i&&i.columnid){let o=this._findColumn(i);if(o){let c=o.table.as?o.table.as:o.table.tableid;(!t[c]||t[c].indexOf(o.attribute)<0)&&n.push(o)}}n=e_.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(Vs)}}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].__merged_data,o=[];for(let f in i)o.push(i[f][0]);this.data[n].__merged_attributes.push(...s.columns);let c={schema:s.schema,table:s.table,hash_values:o,get_attributes:s.columns},l=await du.getDataByHash(c),u=s.columns.length;for(let f=0,d=o.length;f<d;f++){let _=o[f],h=l.get(_);for(let m=0;m<u;m++){let S=s.columns[m],g=h[S]===void 0?null:h[S];this.data[n].__merged_data[_].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}`].__merged_data)),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}`].__merged_data)),s.table.databaseid="",s.table.tableid="?"}),this.statement.order&&this.statement.order.forEach(s=>{if(s.is_ordinal)return;this.statement.columns.filter(o=>{let c=o.aggregatorid?o.expression:o,l=o.aggregatorid?o.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 Tn.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(g6.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].__merged_attributes.forEach((o,c)=>{let l=s[i],u=new RegExp(`${l}.\`${o}\``,"g"),f=`${l}.[${c}]`;n=n.replace(u,f)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=new RegExp(`\`${o}\``,"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 o=await du.getDataByValue(i);for(let[c,l]of o)this.data[s].__merged_data[c]||(l[n.attribute]===void 0&&(l[n.attribute]=null),this.data[s].__merged_data[c]={...r[s]}),this.data[s].__merged_data[c][t[n.attribute]]=l[n.attribute]??null}catch(o){throw ke.error("There was an error when processing this SQL operation. Check your logs"),ke.error(o),new Error(Vs)}}return Object.values(Object.values(this.data)[0].__merged_data)}};Ev.exports=zR});var Wr=C((jye,Sv)=>{"use strict";var T6=nv();Sv.exports={searchByConditions:R6,searchByHash:y6,searchByValue:b6,search:O6};var QR=Vn(),{transformReq:jR}=oe(),A6=gv();async function R6(e){return jR(e),QR.searchByConditions(e)}a(R6,"searchByConditions");async function y6(e){jR(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of QR.searchByHash(e))r&&t.push(r);return t}a(y6,"searchByHash");async function b6(e){jR(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of QR.searchByValue(e))t.push(r);return t}a(b6,"searchByValue");function O6(e,t){try{let r=new T6(e);r.validate(),new A6(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(O6,"search")});var mo=C((Xye,yv)=>{"use strict";var t_=require("crypto"),N6=ce(),{CONFIG_PARAMS:w6}=(k(),P(q)),Av="aes-256-cbc",I6=32,C6=16,JR=64,Rv=32,P6=JR+Rv,Tv=new Map;yv.exports={encrypt:D6,decrypt:L6,createNatsTableStreamName:M6};function D6(e){let t=t_.randomBytes(I6),r=t_.randomBytes(C6),n=t_.createCipheriv(Av,Buffer.from(t),r),s=n.update(e);s=Buffer.concat([s,n.final()]);let i=t.toString("hex"),o=r.toString("hex"),c=s.toString("hex");return i+o+c}a(D6,"encrypt");function L6(e){let t=e.substr(0,JR),r=e.substr(JR,Rv),n=e.substr(P6,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=t_.createDecipheriv(Av,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(L6,"decrypt");function M6(e,t){let r=N6.get(w6.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=Tv.get(r);return n||(n=t_.createHash("md5").update(r).digest("hex"),Tv.set(r,n)),n}a(M6,"createNatsTableStreamName")});var po=C((tbe,wv)=>{"use strict";var ebe=Wr(),r_=ee(),{validateBySchema:bv}=st(),Bc=require("joi"),v6=mo(),Gp=oe(),{handleHDBError:qp,hdb_errors:U6,ClientError:Ov}=me(),{HDB_ERROR_MSGS:$p,HTTP_STATUS_CODES:XR}=U6,Nv=ce();Nv.initSync();var{getDatabases:ZR}=(xe(),P(at)),x6=require("fs-extra"),B6=(k(),P(q));wv.exports={describeAll:H6,describeTable:Vp,describeSchema:k6};async function H6(e={}){try{let t=Gp.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=ZR(),o={},c={},l=[],u=e?.exact_count;for(let d in i){o[d]=!0,!t&&!s&&!r&&(c[d]=e.hdb_user?.role?.permission[d]?.describe);let _=i[d];for(let h in _)try{let m;if(t||s||r)m=await Vp({schema:d,table:h,exact_count:u});else if(n&&n[d].describe&&n[d].tables[h].describe){let S=n[d].tables[h].attribute_permissions;m=await Vp({schema:d,table:h,exact_count:u},S)}m&&l.push(m)}catch(m){r_.error(m)}}let f={};for(let d in l)t||s||r?(f[l[d].schema]==null&&(f[l[d].schema]={}),f[l[d].schema][l[d].name]=l[d],o[l[d].schema]&&delete o[l[d].schema]):c[l[d].schema]&&(f[l[d].schema]==null&&(f[l[d].schema]={}),f[l[d].schema][l[d].name]=l[d],o[l[d].schema]&&delete o[l[d].schema]);for(let d in o)t||s||r?f[d]={}:c[d]&&(f[d]={});return f}catch(t){return r_.error("Got an error in describeAll"),r_.error(t),qp(new Error,$p.DESCRIBE_ALL_ERR)}}a(H6,"describeAll");async function Vp(e,t){Gp.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=bv(e,Bc.object({database:Bc.string(),table:Bc.string().required(),exact_count:Bc.boolean().strict()}));if(i)throw new Ov(i.message);let c=ZR()[r];if(!c)throw qp(new Error,$p.SCHEMA_NOT_FOUND(e.schema),XR.NOT_FOUND);let l=c[n];if(!l)throw qp(new Error,$p.TABLE_NOT_FOUND(e.schema,e.table),XR.NOT_FOUND);function u(h){f.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(m=>({type:m.type,name:m.name})):void 0})}a(u,"pushAtt");let f=[];if(s){let h={};s.forEach(m=>{m.describe&&(h[m.attribute_name]=!0)}),l.attributes.forEach(m=>{h[m.name]&&u(m)})}else l.attributes?.forEach(h=>u(h));let d;try{d=(await x6.stat(l.primaryStore.env.path)).size}catch(h){r_.warn("unable to get database size",h)}let _={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:f,db_size:d};l.replicate!==void 0&&(_.replicate=l.replicate),l.expirationMS!==void 0&&(_.expiration=l.expirationMS/1e3+"s"),l.sealed!==void 0&&(_.sealed=l.sealed),l.sources?.length>0&&(_.sources=l.sources.map(h=>h.name).filter(h=>h&&h!=="NATSReplicator"&&h!=="Replicator")),Nv.get(B6.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(_.clustering_stream_name=v6.createNatsTableStreamName(_.schema,_.name));try{let h=await l.getRecordCount({exactCount:!!e.exact_count});_.record_count=h.recordCount,_.table_size=l.getSize(),_.db_audit_size=l.getAuditSize(),_.estimated_record_range=h.estimatedRange;let m=l.auditStore;if(m)for(let S of m.getKeys({reverse:!0,limit:1}))_.last_updated_record=S[0];if(!_.last_updated_record&&l.indices.__updatedtime__)for(let S of l.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))_.last_updated_record=S}catch(h){r_.warn(`unable to stat table dbi due to ${h}`)}return _}a(Vp,"descTable");async function k6(e){Gp.transformReq(e);let t=bv(e,Bc.object({database:Bc.string(),exact_count:Bc.boolean().strict()}));if(t)throw new Ov(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=ZR()[n];if(!i)throw qp(new Error,$p.SCHEMA_NOT_FOUND(e.schema),XR.NOT_FOUND);let o={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),Gp.isEmpty(l)||l.describe){let u=await Vp({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);u&&(o[u.name]=u)}}return o}a(k6,"describeSchema")});var ps=C((ibe,Lv)=>{var F6=fo(),{callbackify:Cv,promisify:G6}=require("util"),{getDatabases:Pv}=(xe(),P(at));Lv.exports={setSchemaDataToGlobal:Iv,getTableSchema:q6,getSystemSchema:$6,setSchemaDataToGlobalAsync:G6(Iv)};var Dv=po(),nbe=Cv(Dv.describeAll),sbe=Cv(Dv.describeTable);function Iv(e){global.hdb_schema=Pv(),e&&e()}a(Iv,"setSchemaDataToGlobal");function q6(e,t,r){let n=Pv()[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`)}a(q6,"getTableSchema");function $6(){return F6}a($6,"getSystemSchema")});var ty=C((abe,Uv)=>{var V6=st(),ey=require("joi"),{hdb_table:K6,hdb_database:Mv}=Ni(),vv={schema:Mv,database:Mv,table:K6},Y6={date:ey.date().iso().required()},W6={timestamp:ey.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};Uv.exports=function(e,t){let r=t==="timestamp"?{...vv,...W6}:{...vv,...Y6},n=ey.object(r);return V6.validateBySchema(e,n)}});var Hv=C((cbe,Bv)=>{var z6=st(),ry=require("joi"),{hdb_table:Q6,hdb_database:xv}=Ni(),j6=ry.object({schema:xv,database:xv,table:Q6,hash_values:ry.array().required(),ids:ry.array()});Bv.exports=function(e){return z6.validateBySchema(e,j6)}});var oy=C((lbe,kv)=>{"use strict";var ny=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i){this.operation=t,this.schema=r,this.table=n,this.hash_attribute=s,this.records=i}},sy=class{static{a(this,"NoSQLSeachObject")}constructor(t,r,n,s,i,o){this.schema=t,this.table=r,this.search_attribute=n,this.hash_attribute=s,this.get_attributes=i,this.search_value=o}},iy=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};kv.exports={InsertObject:ny,NoSQLSeachObject:sy,DeleteResponseObject:iy}});var Fc=C((dbe,Vv)=>{"use strict";var Gv=ty(),J6=Hv(),Hc=oe(),Fv=require("moment"),qv=ee(),{promisify:X6,callbackify:Z6}=require("util"),kc=(k(),P(q)),eZ=ps(),ay=X6(eZ.getTableSchema),cy=Vn(),{DeleteResponseObject:tZ}=oy(),{handleHDBError:_a,hdb_errors:rZ}=me(),{HDB_ERROR_MSGS:Kp,HTTP_STATUS_CODES:ha}=rZ,nZ="records successfully deleted",sZ=Z6($v);Vv.exports={delete:sZ,deleteRecord:$v,deleteFilesBefore:iZ,deleteAuditLogsBefore:oZ};async function iZ(e){let t=Gv(e,"date");if(t)throw _a(t,t.message,ha.BAD_REQUEST,void 0,void 0,!0);if(Hc.transformReq(e),!Fv(e.date,Fv.ISO_8601).isValid())throw _a(new Error,Kp.INVALID_DATE,ha.BAD_REQUEST,kc.LOG_LEVELS.ERROR,Kp.INVALID_DATE,!0);let n=Hc.checkSchemaTableExist(e.schema,e.table);if(n)throw _a(new Error,n,ha.NOT_FOUND,kc.LOG_LEVELS.ERROR,n,!0);let s=await cy.deleteRecordsBefore(e);if(await ay(e.schema,e.table),qv.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(iZ,"deleteFilesBefore");async function oZ(e){let t=Gv(e,"timestamp");if(t)throw _a(t,t.message,ha.BAD_REQUEST,void 0,void 0,!0);if(Hc.transformReq(e),isNaN(e.timestamp))throw _a(new Error,Kp.INVALID_VALUE("Timestamp"),ha.BAD_REQUEST,kc.LOG_LEVELS.ERROR,Kp.INVALID_VALUE("Timestamp"),!0);let r=Hc.checkSchemaTableExist(e.schema,e.table);if(r)throw _a(new Error,r,ha.NOT_FOUND,kc.LOG_LEVELS.ERROR,r,!0);let n=await cy.deleteAuditLogsBefore(e);return await ay(e.schema,e.table),qv.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(oZ,"deleteAuditLogsBefore");async function $v(e){e.ids&&(e.hash_values=e.ids);let t=J6(e);if(t)throw _a(t,t.message,ha.BAD_REQUEST,void 0,void 0,!0);Hc.transformReq(e);let r=Hc.checkSchemaTableExist(e.schema,e.table);if(r)throw _a(new Error,r,ha.NOT_FOUND,kc.LOG_LEVELS.ERROR,r,!0);try{await ay(e.schema,e.table);let n=await cy.deleteRecords(e);return Hc.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${nZ}`),n}catch(n){if(n.message===kc.SEARCH_NOT_FOUND_MESSAGE){let s=new tZ;return s.message=kc.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a($v,"deleteRecord")});var Yp={};Ue(Yp,{HASH_FUNCTION:()=>i_,hash:()=>dy,validate:()=>fy});function ly(e=s_){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ";return Array.from(n_.randomBytes(e)).map(r=>t[r%t.length]).join("")}function dy(e,t=i_[Yv?.toUpperCase()]??"sha256"){return uy[t](e)}function fy(e,t,r=i_[Yv?.toUpperCase()]??"sha256"){return e?aZ[r](e,t):!1}var n_,fu,Kv,Yv,s_,Wv,i_,uy,aZ,Wp=Re(()=>{n_=M(require("node:crypto")),fu=M(require("argon2")),Kv=M(ce());k();Yv=(0,Kv.get)(B.AUTHENTICATION_HASHFUNCTION)?.toLowerCase(),s_=16,Wv=9,i_=(n=>(n.MD5="md5",n.SHA256="sha256",n.ARGON2ID="argon2id",n))(i_||{});a(ly,"generateSalt");uy={md5:a((e,t=void 0)=>{t=t??ly(Wv);let r=n_.createHash("md5").update(e+t).digest("hex");return t+r},"md5"),sha256:a((e,t=void 0)=>{t=t??ly(s_);let r=n_.createHash("sha256").update(e+t).digest("hex");return t+r},"sha256"),argon2id:a(async e=>{let t=ly(s_),r=await fu.hash(e,{type:fu.argon2id,salt:Buffer.from(t)});return t+r},"argon2id")},aZ={md5:a((e,t)=>{let r=e.slice(0,Wv);return e===uy.md5(t,r)},"md5"),sha256:a((e,t)=>{let r=e.slice(0,s_);return e===uy.sha256(t,r)},"sha256"),argon2id:a(async(e,t)=>await fu.verify(e.slice(s_),t),"argon2id")};a(dy,"hash");a(fy,"validate")});var Qv=C((mbe,zv)=>{var _y=st(),zr={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 cZ(e){return zr.password.presence=!0,zr.username.presence=!0,zr.role.presence=!0,zr.active.presence=!0,_y.validateObject(e,zr)}a(cZ,"addUserValidation");function lZ(e){return zr.password.presence=!1,zr.username.presence=!0,zr.role.presence=!1,zr.active.presence=!1,_y.validateObject(e,zr)}a(lZ,"alterUserValidation");function uZ(e){return zr.password.presence=!1,zr.username.presence=!0,zr.role.presence=!1,zr.active.presence=!1,_y.validateObject(e,zr)}a(uZ,"dropUserValidation");zv.exports={addUserValidation:cZ,alterUserValidation:lZ,dropUserValidation:uZ}});var Pt=C((gbe,Jv)=>{"use strict";var{platform:Ebe}=require("os"),dZ="nats-server.zip",hy="nats-server",fZ=process.platform==="win32"?`${hy}.exe`:hy,_Z=/^[^\s.,*>]+$/,jv="__request__",hZ=a(e=>`${e}.${jv}`,"REQUEST_SUBJECT"),mZ={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},pZ={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},EZ={HUB:"hub.pid",LEAF:"leaf.pid"},gZ={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},SZ={SUCCESS:"success",ERROR:"error"},TZ={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},AZ={TXN:"txn",MSGID:"msgid"},_u={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},RZ={[_u.ERR]:1,[_u.WRN]:2,[_u.INF]:3,[_u.DBG]:4,[_u.TRC]:5},yZ={debug:"-D",trace:"-DVV"};Jv.exports={NATS_SERVER_ZIP:dZ,NATS_SERVER_NAME:hy,NATS_BINARY_NAME:fZ,PID_FILES:EZ,NATS_CONFIG_FILES:pZ,SERVER_SUFFIX:gZ,NATS_TERM_CONSTRAINTS_RX:_Z,REQUEST_SUFFIX:jv,UPDATE_REMOTE_RESPONSE_STATUSES:SZ,CLUSTER_STATUS_STATUSES:TZ,REQUEST_SUBJECT:hZ,SUBJECT_PREFIXES:AZ,MSG_HEADERS:mZ,LOG_LEVELS:_u,LOG_LEVEL_FLAGS:yZ,LOG_LEVEL_HIERARCHY:RZ}});var Kn=C((Tbe,Nr)=>{"use strict";var eU="username is required",tU="nothing to update, must supply active, role or password to update",rU="password cannot be an empty string",nU="If role is specified, it cannot be empty.",sU="active must be true or false";Nr.exports.addUser=LZ;Nr.exports.alterUser=MZ;Nr.exports.dropUser=UZ;Nr.exports.getSuperUser=FZ;Nr.exports.userInfo=xZ;Nr.exports.listUsers=Qp;Nr.exports.listUsersExternal=BZ;Nr.exports.setUsersWithRolesCache=Gc;Nr.exports.findAndValidateUser=yy;Nr.exports.getClusterUser=GZ;Nr.exports.getUsersWithRolesCache=kZ;Nr.exports.USERNAME_REQUIRED=eU;Nr.exports.ALTERUSER_NOTHING_TO_UPDATE=tU;Nr.exports.EMPTY_PASSWORD=rU;Nr.exports.EMPTY_ROLE=nU;Nr.exports.ACTIVE_BOOLEAN=sU;var iU=An(),bZ=Fc(),o_=(Wp(),P(Yp)),oU=Qv(),a_=Wr(),Sy=go(),Ci=oe(),aU=require("validate.js"),Ty=ee(),{promisify:OZ}=require("util"),Ay=mo(),py=(k(),P(q)),Xv=Pt(),NZ=It(),wZ=ce(),IZ=fo(),{hdb_errors:CZ,ClientError:Ks}=me(),{HTTP_STATUS_CODES:Eo,AUTHENTICATION_ERROR_MSGS:my,HDB_ERROR_MSGS:hu}=CZ,{UserEventMsg:Ry}=Ys(),Ey=require("lodash"),{server:zp}=(Mr(),P(Wl)),PZ=ee();zp.getUser=(e,t)=>yy(e,t,t!=null);zp.authenticateUser=(e,t)=>yy(e,t);var cU={username:!0,active:!0,role:!0,password:!0},Zv=new Map,DZ=OZ(bZ.delete),gy=wZ.get(py.CONFIG_PARAMS.AUTHENTICATION_HASHFUNCTION)??o_.HASH_FUNCTION.SHA256,Pi;async function LZ(e){let t=aU.cleanAttributes(e,cU),r=oU.addUserValidation(t);if(r)throw new Ks(r.message);let n=await a_.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 Ks(hu.ROLE_NAME_NOT_FOUND(t.role),Eo.NOT_FOUND);if(n.length>1)throw new Ks(hu.DUP_ROLES_FOUND(t.role),Eo.CONFLICT);n[0].permission.cluster_user===!0&&(t.hash=Ay.encrypt(t.password)),t.password=await o_.hash(t.password,gy),t.hash_function=gy,t.role=n[0].id;let s=await iU.insert({operation:"insert",schema:"system",table:"hdb_user",records:[t]});if(Ty.debug(s),await Gc(),s.skipped_hashes.length===1)throw new Ks(hu.USER_ALREADY_EXISTS(t.username),Eo.CONFLICT);return Sy.signalUserChange(new Ry(process.pid)),`${t.username} successfully added`}a(LZ,"addUser");async function MZ(e){let t=aU.cleanAttributes(e,cU);if(Ci.isEmptyOrZeroLength(t.username))throw new Error(eU);if(Ci.isEmptyOrZeroLength(t.password)&&Ci.isEmptyOrZeroLength(t.role)&&Ci.isEmptyOrZeroLength(t.active))throw new Error(tU);if(!Ci.isEmpty(t.password)&&Ci.isEmptyOrZeroLength(t.password.trim()))throw new Error(rU);if(!Ci.isEmpty(t.active)&&!Ci.isBoolean(t.active))throw new Error(sU);if(!Ci.isEmpty(t.password)&&!Ci.isEmptyOrZeroLength(t.password.trim())&&(vZ(t.username)&&(t.hash=Ay.encrypt(t.password)),t.password=await o_.hash(t.password,gy)),t.role==="")throw new Error(nU);if(t.role){let n=await a_.searchByValue({schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]});if(!n||n.length===0)throw new Ks(hu.ALTER_USER_ROLE_NOT_FOUND(t.role),Eo.NOT_FOUND);if(n.length>1)throw new Ks(hu.DUP_ROLES_FOUND(t.role),Eo.CONFLICT);t.role=n[0].id}let r=await iU.update({operation:"update",schema:"system",table:"hdb_user",records:[t]});return await Gc(),Sy.signalUserChange(new Ry(process.pid)),r}a(MZ,"alterUser");function vZ(e){let t=!1,r=Pi.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(vZ,"isClusterUser");async function UZ(e){let t=oU.dropUserValidation(e);if(t)throw new Ks(t.message);if(Pi.get(e.username)===void 0)throw new Ks(hu.USER_NOT_EXIST(e.username),Eo.NOT_FOUND);let r=await DZ({table:"hdb_user",schema:"system",hash_values:[e.username]});return Ty.debug(r),await Gc(),Sy.signalUserChange(new Ry(process.pid)),`${e.username} successfully deleted`}a(UZ,"dropUser");async function xZ(e){let t={};if(!e||!e.hdb_user)return"There was no user info in the body";t=Ey.cloneDeep(e.hdb_user);let r=await a_.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}a(xZ,"userInfo");async function BZ(){let e=await Qp();return e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token,delete t.hash_function}),[...e.values()]}a(BZ,"listUsersExternal");async function Qp(){let e=await a_.searchByValue({schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]}),t={};for(let s of e)t[s.id]=Ey.cloneDeep(s);if(Object.keys(t).length===0)return null;let r=await a_.searchByValue({schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]}),n=new Map;for(let s of r)s=Ey.cloneDeep(s),s.role=t[s.role],HZ(s.role),n.set(s.username,s);return n}a(Qp,"listUsers");function HZ(e){if(!e){Ty.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(IZ)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}a(HZ,"appendSystemTablesToRole");async function Gc(e=void 0){e?Pi=e:Pi=await Qp()}a(Gc,"setUsersWithRolesCache");async function kZ(){return Pi||await Gc(),Pi}a(kZ,"getUsersWithRolesCache");async function yy(e,t,r=!0){Pi||await Gc();let n=Pi.get(e);if(!n){if(!r)return{username:e};throw new Ks(my.GENERIC_AUTH_FAIL,Eo.UNAUTHORIZED)}if(n&&!n.active)throw new Ks(my.USER_INACTIVE,Eo.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(Zv.get(t)===n.password)return s;{let i=o_.validate(n.password,t,n.hash_function||o_.HASH_FUNCTION.MD5);if(i?.then&&(i=await i),i===!0)Zv.set(t,n.password);else throw new Ks(my.GENERIC_AUTH_FAIL,Eo.UNAUTHORIZED)}}return s}a(yy,"findAndValidateUser");async function FZ(){Pi||await Gc();for(let[,e]of Pi)if(e.role.role==="super_user")return e}a(FZ,"getSuperUser");async function GZ(){let e=await Qp(),t=NZ.getConfigFromFile(py.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!(r==null||r?.role?.role!==py.ROLE_TYPES_ENUM.CLUSTER_USER))return r.decrypt_hash=Ay.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+Xv.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+Xv.SERVER_SUFFIX.ADMIN,r}a(GZ,"getClusterUser");var lU=[];zp.invalidateUser=function(e){for(let t of lU)try{t(e)}catch(r){PZ.error("Error invalidating user",r)}};zp.onInvalidatedUser=function(e){lU.push(e)}});var l_=C((bbe,_U)=>{"use strict";var qc=ee(),Yn=(k(),P(q)),qZ=VM(),Rbe=ps(),ybe=po(),$Z=Kn(),{validateEvent:uU}=Ys(),c_=Vn(),VZ=require("process"),{resetDatabases:KZ}=(xe(),P(at)),YZ={[Yn.ITC_EVENT_TYPES.SCHEMA]:WZ,[Yn.ITC_EVENT_TYPES.USER]:fU};async function WZ(e){let t=uU(e);if(t){qc.error(t);return}qc.trace("ITC schemaHandler received schema event:",e),await qZ(e.message),await zZ(e.message)}a(WZ,"schemaHandler");async function zZ(e){try{c_.resetReadTxn(Yn.SYSTEM_SCHEMA_NAME,Yn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),c_.resetReadTxn(Yn.SYSTEM_SCHEMA_NAME,Yn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),c_.resetReadTxn(Yn.SYSTEM_SCHEMA_NAME,Yn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=KZ();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){qc.error(t)}}a(zZ,"syncSchemaMetadata");var dU=[];async function fU(e){try{try{c_.resetReadTxn(Yn.SYSTEM_SCHEMA_NAME,Yn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),c_.resetReadTxn(Yn.SYSTEM_SCHEMA_NAME,Yn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){qc.warn(r)}let t=uU(e);if(t){qc.error(t);return}qc.trace(`ITC userHandler ${Yn.HDB_ITC_CLIENT_PREFIX}${VZ.pid} received user event:`,e),await $Z.setUsersWithRolesCache();for(let r of dU)r()}catch(t){qc.error(t)}}a(fU,"userHandler");fU.addListener=function(e){dU.push(e)};_U.exports=YZ});var Ys=C((Pbe,mU)=>{"use strict";var Nbe=ee(),by=oe(),QZ=(k(),P(q)),{ITC_ERRORS:u_}=Un(),{parentPort:wbe,threadId:jZ,isMainThread:JZ,workerData:Ibe}=require("worker_threads"),{onMessageFromWorkers:XZ,broadcast:Cbe,broadcastWithAcknowledgement:ZZ}=it();mU.exports={sendItcEvent:e8,validateEvent:hU,SchemaEventMsg:t8,UserEventMsg:r8};var jp;XZ(async(e,t)=>{jp=jp||l_(),hU(e),jp[e.type]&&await jp[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function e8(e){return!JZ&&e.message&&(e.message.originator=jZ),ZZ(e)}a(e8,"sendItcEvent");function hU(e){if(typeof e!="object")return u_.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||by.isEmpty(e.type))return u_.MISSING_TYPE;if(!e.hasOwnProperty("message")||by.isEmpty(e.message))return u_.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||by.isEmpty(e.message.originator))return u_.MISSING_ORIGIN;if(QZ.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return u_.INVALID_EVENT(e.type)}a(hU,"validateEvent");function t8(e,t,r,n=void 0,s=void 0){this.originator=e,this.operation=t,this.schema=r,this.table=n,this.attribute=s}a(t8,"SchemaEventMsg");function r8(e){this.originator=e}a(r8,"UserEventMsg")});var go=C((Mbe,SU)=>{"use strict";var pU=(k(),P(q)),Lbe=oe(),Jp=ee(),EU=GM(),mu,{sendItcEvent:gU}=Ys();function n8(e){try{Jp.info("signalSchemaChange called with message:",e),mu=mu||l_();let t=new EU(pU.ITC_EVENT_TYPES.SCHEMA,e);return mu.schema(t),gU(t)}catch(t){Jp.error(t)}}a(n8,"signalSchemaChange");function s8(e){try{Jp.trace("signalUserChange called with message:",e),mu=mu||l_();let t=new EU(pU.ITC_EVENT_TYPES.USER,e);return mu.user(t),gU(t)}catch(t){Jp.error(t)}}a(s8,"signalUserChange");SU.exports={signalSchemaChange:n8,signalUserChange:s8}});var Xp=C((Ube,AU)=>{"use strict";var TU=oe(),i8=(k(),P(q)),o8=ee(),a8=Bp(),c8=xp(),l8=go(),{SchemaEventMsg:u8}=Ys(),d8="already exists in";AU.exports=f8;async function f8(e,t,r){if(TU.isEmptyOrZeroLength(r))return r;let n=[];TU.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 _8(e,t.schema,t.name,i)})),s}a(f8,"lmdbCheckForNewAttributes");async function _8(e,t,r,n){let s=new c8(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await h8(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(d8))o8.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(_8,"createNewAttribute");async function h8(e){let t;return t=await a8(e),l8.signalSchemaChange(new u8(process.pid,i8.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(h8,"createAttribute")});var pu=C((Bbe,RU)=>{"use strict";var Oy=class{static{a(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}};RU.exports=Oy});var bU=C((kbe,yU)=>{"use strict";var m8=pu(),p8=(k(),P(q)).OPERATIONS_ENUM,Ny=class extends m8{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(p8.INSERT,r,n,s,i),this.records=t}};yU.exports=Ny});var NU=C((Gbe,OU)=>{"use strict";var E8=pu(),g8=(k(),P(q)).OPERATIONS_ENUM,wy=class extends E8{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(g8.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};OU.exports=wy});var IU=C(($be,wU)=>{"use strict";var S8=pu(),T8=(k(),P(q)).OPERATIONS_ENUM,Iy=class extends S8{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(T8.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};wU.exports=Iy});var PU=C((Kbe,CU)=>{"use strict";var A8=pu(),R8=(k(),P(q)).OPERATIONS_ENUM,Cy=class extends A8{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(R8.DELETE,n,s,t,i),this.original_records=r}};CU.exports=Cy});var d_=C((zbe,vU)=>{"use strict";var Wbe=require("path"),DU=_t(),y8=bU(),b8=NU(),O8=IU(),N8=PU(),Eu=kt(),LU=oe(),{CONFIG_PARAMS:w8}=(k(),P(q)),MU=ce();MU.initSync();var Zp=(k(),P(q)).OPERATIONS_ENUM,{getTransactionAuditStorePath:I8}=Et();vU.exports=C8;async function C8(e,t){if(MU.get(w8.LOGGING_AUDITLOG)===!1)return;let r=I8(e.schema,e.table),n=await DU.openEnvironment(r,e.table,!0),s=P8(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){DU.initializeDBIs(n,Eu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Eu.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[Eu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[Eu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),LU.isEmpty(s.user_name)||n.dbis[Eu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[Eu.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(C8,"writeTransaction");function P8(e,t){let r=LU.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===Zp.INSERT)return new y8(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Zp.UPDATE)return new b8(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Zp.UPSERT)return new O8(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Zp.DELETE)return new N8(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(P8,"createTransactionObject")});var Py=C((Jbe,UU)=>{"use strict";var D8=jf(),jbe=yf(),f_=(k(),P(q)),L8=bf(),M8=vc().insertRecords,v8=_t(),U8=ee(),x8=Xp(),{getSchemaPath:B8}=Et(),H8=d_();UU.exports=k8;async function k8(e){try{let{schema_table:t,attributes:r}=D8(e);L8(e,r,t.hash_attribute),e.schema!==f_.SYSTEM_SCHEMA_NAME&&(r.includes(f_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(f_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(f_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(f_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await x8(e.hdb_auth_header,t,r),s=B8(e.schema,e.table),i=await v8.openEnvironment(s,e.table),o=await M8(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await H8(e,o)}catch(c){U8.error(`unable to write transaction due to ${c.message}`)}return{written_hashes:o.written_hashes,skipped_hashes:o.skipped_hashes,schema_table:t,new_attributes:n,txn_time:o.txn_time}}catch(t){throw t}}a(k8,"lmdbCreateRecords")});var HU=C((Zbe,BU)=>{"use strict";var xU=(k(),P(q)),F8=Py(),G8=yf(),q8=require("fs-extra"),{getSchemaPath:$8}=Et();BU.exports=V8;async function V8(e){let t=[{name:e.schema,createddate:Date.now()}],r=new G8(xU.SYSTEM_SCHEMA_NAME,xU.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await F8(r),await q8.mkdirp($8(e.schema))}a(V8,"lmdbCreateSchema")});var FU=C((tOe,kU)=>{"use strict";var Dy=class{static{a(this,"DeleteRecordsResponseObject")}constructor(t=[],r=[],n=void 0,s=[]){this.deleted=t,this.skipped=r,this.txn_time=n,this.original_records=s}};kU.exports=Dy});var VU=C((oOe,$U)=>{"use strict";var GU=_t(),Ly=fn(),My=Un().LMDB_ERRORS_ENUM,K8=kt(),qU=ee(),nOe=oe(),Y8=require("lmdb"),W8=FU(),z8=(k(),P(q)),{OVERFLOW_MARKER:sOe,MAX_SEARCH_KEY_LENGTH:iOe}=K8,Q8=z8.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function j8(e,t,r,n){if(Ly.validateEnv(e),t===void 0)throw new Error(My.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(My.IDS_REQUIRED):new Error(My.IDS_MUST_BE_ITERABLE);try{let s=GU.listDBIs(e);GU.initializeDBIs(e,t,s);let i=new W8,o,c=[],l=[];for(let _=0,h=r.length;_<h;_++)try{o=r[_];let m=e.dbis[t].get(o);if(!m||n&&m[Q8]>n){i.skipped.push(o);continue}let S=e.dbis[t].ifVersion(o,Y8.IF_EXISTS,()=>{e.dbis[t].remove(o);for(let g=0;g<s.length;g++){let R=s[g];if(!m.hasOwnProperty(R)||R===t)continue;let E=e.dbis[R],T=m[R];if(T!=null)try{let N=Ly.getIndexedValues(T);if(N)for(let v=0,H=N.length;v<H;v++)E.remove(N[v],o)}catch{qU.warn(`cannot delete from attribute: ${R}, ${T}:${o}`)}}});c.push(S),l.push(o),i.original_records.push(m)}catch(m){qU.warn(m),i.skipped.push(o)}let u=[],f=await Promise.all(c);for(let _=0,h=f.length;_<h;_++)f[_]===!0?i.deleted.push(l[_]):(i.skipped.push(l[_]),u.push(_));let d=0;for(let _=0;_<u.length;_++){let h=u[_];i.original_records.splice(h-d,1),d++}return i.txn_time=Ly.getNextMonotonicTime(),i}catch(s){throw s}}a(j8,"deleteRecords");$U.exports={deleteRecords:j8}});var __=C((cOe,YU)=>{"use strict";var gu=oe(),J8=VU(),X8=_t(),{getSchemaPath:Z8}=Et(),e5=d_(),t5=ee();YU.exports=r5;async function r5(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(gu.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(gu.isEmptyOrZeroLength(e.hash_values)&&!gu.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];gu.isEmpty(l)||e.hash_values.push(l)}}if(gu.isEmptyOrZeroLength(e.hash_values))return KU([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(gu.isEmptyOrZeroLength(e.records)){e.records=[];for(let c=0;c<e.hash_values.length;c++)e.records[c]={[n]:e.hash_values[c]}}let s=Z8(e.schema,e.table),i=await X8.openEnvironment(s,e.table),o=await J8.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await e5(e,o)}catch(c){t5.error(`unable to write transaction due to ${c.message}`)}return KU(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(r5,"lmdbDeleteRecords");function KU(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}}a(KU,"createDeleteResponse")});var Uy=C((dOe,WU)=>{"use strict";var n5=(k(),P(q)),uOe=fn();function vy(e,t){let r=Object.create(null);if(t.length===1&&n5.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}a(vy,"parseRow");function s5(e,t,r,n){let s=vy(r,e);n.push(s)}a(s5,"searchAll");function i5(e,t,r,n){let s=vy(r,e);n[t]=s}a(i5,"searchAllToMap");function o5(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(o5,"iterateDBI");function $c(e,t,r,n,s){let i=Object.create(null);i[s]=e;let o;n===s?o=e:(o=t,n!==void 0&&(i[n]=o)),r[0].push(o),r[1].push(i)}a($c,"pushResults");function a5(e,t,r,n,s,i){t.toString().endsWith(e)&&$c(t,r,n,s,i)}a(a5,"endsWith");function c5(e,t,r,n,s,i){t.toString().includes(e)&&$c(t,r,n,s,i)}a(c5,"contains");function l5(e,t,r,n,s,i){t>e&&$c(t,r,n,s,i)}a(l5,"greaterThanCompare");function u5(e,t,r,n,s,i){t>=e&&$c(t,r,n,s,i)}a(u5,"greaterThanEqualCompare");function d5(e,t,r,n,s,i){t<e&&$c(t,r,n,s,i)}a(d5,"lessThanCompare");function f5(e,t,r,n,s,i){t<=e&&$c(t,r,n,s,i)}a(f5,"lessThanEqualCompare");WU.exports={parseRow:vy,searchAll:s5,searchAllToMap:i5,iterateDBI:o5,endsWith:a5,contains:c5,greaterThanCompare:l5,greaterThanEqualCompare:u5,lessThanCompare:d5,lessThanEqualCompare:f5,pushResults:$c}});var Su=C((pOe,e0)=>{"use strict";var ma=_t(),_Oe=ee(),Wn=fn(),eE=kt(),zt=Un().LMDB_ERRORS_ENUM,hOe=oe(),_5=(k(),P(q)),tE=Uy(),{parseRow:h5}=tE,mOe=require("lmdb"),{OVERFLOW_MARKER:zU,MAX_SEARCH_KEY_LENGTH:m5}=eE;function QU(e,t,r,n=!1,s=void 0,i=void 0){return Vc(e,t,r,(o,c)=>c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}))}a(QU,"iterateFullIndex");function h_(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,u=!1){return Vc(e,t,r,(f,d,_,h)=>{let E={transaction:f,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!l:!u,exclusiveStart:i===!0?u:l};return h===r?(E.values=!1,d.getRange(E).map(T=>({value:T}))):d.getRange(E)})}a(h_,"iterateRangeBetween");function Vc(e,t,r,n){let s=e.database||e,i=ma.openDBI(s,r);i[eE.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&ma.openDBI(s,t);let o;e.database?o=e:(o=e.useReadTransaction(),o.database=e);let c=n(o,i,s,t);return c.transaction=o,e.database||(c.onDone=()=>{o.done()}),c}a(Vc,"setupTransaction");function jU(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(zU)){if(!s)if(r)s=ma.openDBI(e,r);else{let l=ma.listDBIs(e);for(let u=0,f=l.length;u<f&&(s=ma.openDBI(e,l[u]),!s[eE.DBI_DEFINITION_NAME].is_hash_attribute);u++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(jU,"getOverflowCheck");function p5(e,t,r,n=!1,s=void 0,i=void 0){if(Wn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);return Vc(e,t,t,(o,c,l)=>(rE(r),r=m_(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(u=>h5(u.value,r))))}a(p5,"searchAll");function E5(e,t,r,n=!1,s=void 0,i=void 0){if(Wn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);rE(r),r=m_(e.database||e,r);let o=new Map;for(let{key:c,value:l}of QU(e,t,t,n,s,i))o.set(c,tE.parseRow(l,r));return o}a(E5,"searchAllToMap");function g5(e,t,r=!1,n=void 0,s=void 0){if(Wn.validateEnv(e),t===void 0)throw new Error(zt.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=QU(e,void 0,t,r,n,s),c=o.transaction,l=jU(c.database,c,void 0,t);for(let{key:u,value:f}of o){let d=l(u,f);i[d]===void 0&&(i[d]=[]),i[d].push(f)}return i}a(g5,"iterateDBI");function S5(e,t){if(Wn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);return ma.statDBI(e,t).entryCount}a(S5,"countAll");function T5(e,t,r,n,s=!1,i=void 0,o=void 0){return pa(e,r,n),Vc(e,t,r,(c,l,u,f)=>(n=Wn.convertKeyValueToWrite(n),f===r?l.get(n,{transaction:c,lazy:!0})===void 0?[]:[{key:n,value:n}]:l.getValues(n,{transaction:c,reverse:s,limit:i,offset:o}).map(d=>({key:n,value:d}))))}a(T5,"equals");function A5(e,t,r){return pa(e,t,r),ma.openDBI(e,t).getValuesCount(r)}a(A5,"count");function R5(e,t,r,n,s=!1,i=void 0,o=void 0){return pa(e,r,n),Vc(e,null,r,(c,l)=>{n=Wn.convertKeyValueToWrite(n);let u=!0;typeof n=="number"&&(u=!1);let f;if(s===!0){let d;for(let _ of l.getKeys({transaction:c,start:n}))if(!_.startsWith(n)){d=_;break}return d!==void 0&&(Number.isInteger(o)?o++:i++),f=l.getRange({transaction:c,start:d,end:void 0,reverse:s,limit:i,offset:o}).map(_=>{let{key:h}=_;if(h!==d){if(h.toString().startsWith(n))return _;if(u===!0)return f.DONE}}),f.filter(_=>_)}else return f=l.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(d=>{if(d.key.toString().startsWith(n))return d;if(u===!0)return f.DONE}),u?f:f.filter(d=>d)})}a(R5,"startsWith");function y5(e,t,r,n,s=!1,i=void 0,o=void 0){return JU(e,t,r,n,s,i,o,!0)}a(y5,"endsWith");function JU(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return pa(e,r,n),Vc(e,null,r,(l,u,f,d)=>{let _=jU(f,l,d,r);return o=Number.isInteger(o)?o:0,u.getKeys({transaction:l,end:s?!1:void 0,reverse:s}).flatMap(h=>{let m=h.toString();return m.endsWith(zU)?u.getValues(h,{transaction:l}).map(S=>{let g=_(h,S);if(c?g.endsWith(n):g.includes(n))return{key:g,value:S}}).filter(S=>S):(c?m.endsWith(n):m.includes(n))?u[eE.DBI_DEFINITION_NAME].is_hash_attribute?{key:h,value:h}:u.getValues(h,{transaction:l}).map(S=>({key:h,value:S})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a(JU,"contains");function b5(e,t,r,n,s=!1,i=void 0,o=void 0){pa(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),h_(e,t,r,n,l,s,i,o,!0,!1)}a(b5,"greaterThan");function O5(e,t,r,n,s=!1,i=void 0,o=void 0){pa(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),h_(e,t,r,n,l,s,i,o,!1,!1)}a(O5,"greaterThanEqual");function N5(e,t,r,n,s=!1,i=void 0,o=void 0){pa(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),h_(e,t,r,l,n,s,i,o,!1,!0)}a(N5,"lessThan");function w5(e,t,r,n,s=!1,i=void 0,o=void 0){pa(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),h_(e,t,r,l,n,s,i,o,!1,!1)}a(w5,"lessThanEqual");function I5(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(Wn.validateEnv(e),r===void 0)throw new Error(zt.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(zt.START_VALUE_REQUIRED);if(s===void 0)throw new Error(zt.END_VALUE_REQUIRED);if(n=Wn.convertKeyValueToWrite(n),s=Wn.convertKeyValueToWrite(s),n>s)throw new Error(zt.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return h_(e,t,r,n,s,i,o,c)}a(I5,"between");function C5(e,t,r,n){Wn.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);if(rE(r),r=m_(s,r),n===void 0)throw new Error(zt.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=tE.parseRow(c,r)),o}a(C5,"searchByHash");function P5(e,t,r){Wn.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(zt.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(P5,"checkHashExists");function D5(e,t,r,n,s=[]){return ZU(e,t,r,n,s),XU(e,t,r,n,s).map(i=>i[1])}a(D5,"batchSearchByHash");function L5(e,t,r,n,s=[]){ZU(e,t,r,n,s);let i=new Map;for(let[o,c]of XU(e,t,r,n,s))i.set(o,c);return i}a(L5,"batchSearchByHashToMap");function XU(e,t,r,n,s=[]){return Vc(e,t,t,(i,o,c)=>{r=m_(c,r);let l=r.length<3;return n.map(u=>{let f=c.dbis[t].get(u,{transaction:i,lazy:l});if(f)return[u,tE.parseRow(f,r)];s.push(u)}).filter(u=>u)})}a(XU,"batchHashSearch");function ZU(e,t,r,n,s){if(Wn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);if(rE(r),n==null)throw new Error(zt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(zt.IDS_MUST_BE_ITERABLE)}a(ZU,"initializeBatchSearchByHash");function rE(e){if(!Array.isArray(e))throw e===void 0?new Error(zt.FETCH_ATTRIBUTES_REQUIRED):new Error(zt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(rE,"validateFetchAttributes");function pa(e,t,r){if(Wn.validateEnv(e),t===void 0)throw new Error(zt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(zt.SEARCH_VALUE_REQUIRED);if(r?.length>m5)throw new Error(zt.SEARCH_VALUE_TOO_LARGE)}a(pa,"validateComparisonFunctions");function m_(e,t){return t.length===1&&_5.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=ma.listDBIs(e)),t}a(m_,"setGetWholeRowAttributes");e0.exports={searchAll:p5,searchAllToMap:E5,count:A5,countAll:S5,equals:T5,startsWith:R5,endsWith:y5,contains:JU,searchByHash:C5,setGetWholeRowAttributes:m_,batchSearchByHash:D5,batchSearchByHashToMap:L5,checkHashExists:P5,iterateDBI:g5,greaterThan:b5,greaterThanEqual:O5,lessThan:N5,lessThanEqual:w5,between:I5}});var Tu=C((gOe,i0)=>{var t0=require("lodash"),r0=st(),qe=require("joi"),M5=oe(),{hdb_schema_table:p_,checkValidTable:n0,hdb_table:s0,hdb_database:nE}=Ni(),{handleHDBError:v5,hdb_errors:U5}=me(),{getDatabases:x5}=(xe(),P(at)),{HTTP_STATUS_CODES:B5}=U5,H5=qe.object({database:nE,schema:nE,table:s0,search_attribute:p_,search_value:qe.any().required(),get_attributes:qe.array().min(1).items(qe.alternatives(p_,qe.object())).optional(),desc:qe.bool(),limit:qe.number().integer().min(1),offset:qe.number().integer().min(0)}),k5=qe.object({database:nE,schema:nE,table:s0,operator:qe.string().valid("and","or").default("and").lowercase(),offset:qe.number().integer().min(0),limit:qe.number().integer().min(1),get_attributes:qe.array().min(1).items(qe.alternatives(p_,qe.object())).optional(),sort:qe.object({attribute:qe.alternatives(p_,qe.array().min(1)),descending:qe.bool().optional()}).optional(),conditions:qe.array().min(1).items(qe.alternatives(qe.object({operator:qe.string().valid("and","or").default("and").lowercase(),conditions:qe.array()}),qe.object({search_attribute:qe.alternatives(p_,qe.array().min(1)),search_type:qe.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:qe.when("search_type",{switch:[{is:"equals",then:qe.any()},{is:"between",then:qe.array().items(qe.alternatives([qe.string(),qe.number()])).length(2)}],otherwise:qe.alternatives(qe.string(),qe.number())}).required()}))).required()});i0.exports=function(e,t){let r=null;switch(t){case"value":r=r0.validateBySchema(e,H5);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(n0("database",e.schema)),i(n0("table",e.table)),e.hash_values?Array.isArray(e.hash_values)?e.hash_values.every(o=>typeof o=="string"||typeof o=="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(o=>typeof o=="string"||typeof o=="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=r0.validateBySchema(e,k5);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=M5.checkGlobalSchemaTable(e.schema,e.table);if(s)return v5(new Error,s,B5.NOT_FOUND);let o=x5()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let l=a(f=>{for(let d=0,_=f.conditions.length;d<_;d++){let h=f.conditions[d];h.conditions?l(h):c.push(h.search_attribute)}},"addConditions");t==="conditions"&&l(e);let u=t0.filter(c,f=>f!=="*"&&!f.startsWith?.("$")&&f.attribute!=="*"&&!Array.isArray(f)&&!f.name&&!t0.some(o,d=>d===f||d.attribute===f||d.attribute===f.attribute));if(u&&u.length>0){let f=u.join(", ");return f=f.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${f}'`)}}return r}});var xy=C((TOe,o0)=>{"use strict";var F5=_t(),G5=Tu(),{getSchemaPath:q5}=Et();o0.exports=$5;function $5(e){let t=G5(e,"hashes");if(t)throw t;let r=q5(e.schema,e.table);return F5.openEnvironment(r,e.table)}a($5,"initialize")});var By=C((ROe,a0)=>{"use strict";var V5=Su(),K5=xy();a0.exports=Y5;async function Y5(e){let t=await K5(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return V5.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(Y5,"lmdbGetDataByHash")});var Au=C((bOe,c0)=>{"use strict";var Hy=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};c0.exports=Hy});var u0=C((wOe,l0)=>{"use strict";var NOe=Au(),W5=Su(),z5=xy();l0.exports=Q5;async function Q5(e){let t=await z5(e),r=global.hdb_schema[e.schema][e.table];return W5.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(Q5,"lmdbSearchByHash")});var Ws=C((COe,d0)=>{"use strict";var ky=class{static{a(this,"SearchObject")}constructor(t,r,n,s,i,o,c,l=!1,u=void 0,f=void 0){this.schema=t,this.table=r,this.search_attribute=n,this.search_value=s,this.hash_attribute=i,this.get_attributes=o,this.end_value=c,this.reverse=l,this.limit=u,this.offset=f}};d0.exports=ky});var sE=C((DOe,E0)=>{"use strict";var Qr=Su(),j5=_t(),J5=oe(),$e=kt(),Kc=(k(),P(q)),X5=fo(),f0=Un().LMDB_ERRORS_ENUM,{getSchemaPath:Z5}=Et(),So=Kc.SEARCH_WILDCARDS;async function e9(e,t,r){let n;e.schema===Kc.SYSTEM_SCHEMA_NAME?n=X5[e.table]:n=global.hdb_schema[e.schema][e.table];let s=p0(e,n.hash_attribute,r,t);return h0(e,s,n.hash_attribute,r)}a(e9,"prepSearch");async function h0(e,t,r,n){let s=Z5(e.schema,e.table),i=await j5.openEnvironment(s,e.table),o=m0(i,e,t,r),c=o.transaction||i;if([$e.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,$e.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,$e.SEARCH_TYPES.SEARCH_ALL,$e.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(t9(e,r)===!1){let f=e.search_attribute;if(f===r)return n?_0(o,()=>!0):o.map(_=>({[r]:_.key}));let d=a(_=>({[r]:_.value,[f]:_.key}),"toObject");return n?_0(o,d):o.map(d)}let u=e.search_attribute===r?o.map(f=>f.key):o.map(f=>f.value);return n===!0?Qr.batchSearchByHashToMap(c,r,e.get_attributes,u):Qr.batchSearchByHash(c,r,e.get_attributes,u)}a(h0,"executeSearch");function m0(e,t,r,n){let s,i=n;t.get_attributes.indexOf(n)<0&&(i=void 0);let{reverse:o,limit:c,offset:l}=t;switch(o=typeof o=="boolean"?o:!1,c=Number.isInteger(c)?c:void 0,l=Number.isInteger(l)?l:void 0,r){case $e.SEARCH_TYPES.EQUALS:s=Qr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.CONTAINS:s=Qr.contains(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.ENDS_WITH:case $e.SEARCH_TYPES._ENDS_WITH:s=Qr.endsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.STARTS_WITH:case $e.SEARCH_TYPES._STARTS_WITH:s=Qr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return Qr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case $e.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return Qr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case $e.SEARCH_TYPES.SEARCH_ALL:return Qr.searchAll(e,n,t.get_attributes,o,c,l);case $e.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return Qr.searchAllToMap(e,n,t.get_attributes,o,c,l);case $e.SEARCH_TYPES.BETWEEN:s=Qr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,l);break;case $e.SEARCH_TYPES.GREATER_THAN:case $e.SEARCH_TYPES._GREATER_THAN:s=Qr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.GREATER_THAN_EQUAL:case $e.SEARCH_TYPES._GREATER_THAN_EQUAL:s=Qr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.LESS_THAN:case $e.SEARCH_TYPES._LESS_THAN:s=Qr.lessThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.LESS_THAN_EQUAL:case $e.SEARCH_TYPES._LESS_THAN_EQUAL:s=Qr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;default:return Object.create(null)}return s}a(m0,"searchByType");function _0(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(_0,"createMapFromIterable");function t9(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}a(t9,"checkToFetchMore");function p0(e,t,r,n){if(J5.isEmpty(n)){let s=e.search_value;typeof s=="object"?s=JSON.stringify(s):s=s.toString();let i=s.charAt(0),o=s.charAt(s.length-1),c=!1;if(e.search_attribute===t&&(c=!0),So.indexOf(s)>-1)return r===!0?$e.SEARCH_TYPES.SEARCH_ALL_TO_MAP:$e.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(So[0])<0&&s.indexOf(So[1])<0)return c===!0?r===!0?$e.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:$e.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:$e.SEARCH_TYPES.EQUALS;if(So.indexOf(i)>=0&&So.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),$e.SEARCH_TYPES.CONTAINS;if(So.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),$e.SEARCH_TYPES.ENDS_WITH;if(So.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),$e.SEARCH_TYPES.STARTS_WITH;if(s.includes(So[0])||s.includes(So[1]))return $e.SEARCH_TYPES.EQUALS;throw new Error(f0.UNKNOWN_SEARCH_TYPE)}else switch(n){case Kc.VALUE_SEARCH_COMPARATORS.BETWEEN:return $e.SEARCH_TYPES.BETWEEN;case Kc.VALUE_SEARCH_COMPARATORS.GREATER:return $e.SEARCH_TYPES.GREATER_THAN;case Kc.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return $e.SEARCH_TYPES.GREATER_THAN_EQUAL;case Kc.VALUE_SEARCH_COMPARATORS.LESS:return $e.SEARCH_TYPES.LESS_THAN;case Kc.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return $e.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(f0.UNKNOWN_SEARCH_TYPE)}}a(p0,"createSearchTypeFromSearchObject");E0.exports={executeSearch:h0,createSearchTypeFromSearchObject:p0,prepSearch:e9,searchByType:m0}});var S0=C((vOe,g0)=>{"use strict";var MOe=Ws(),r9=Tu(),n9=oe(),s9=(k(),P(q)),i9=sE();g0.exports=o9;function o9(e,t){if(!n9.isEmpty(t)&&s9.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=r9(e,"value");if(n)throw n;return i9.prepSearch(e,t,!0)}a(o9,"lmdbGetDataByValue")});var E_=C((BOe,T0)=>{"use strict";var xOe=Ws(),a9=Tu(),c9=oe(),l9=(k(),P(q)),u9=sE();T0.exports=d9;async function d9(e,t){if(!c9.isEmpty(t)&&l9.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=a9(e,"value");if(n)throw n;return u9.prepSearch(e,t,!1)}a(d9,"lmdbSearchByValue")});var R0=C((FOe,A0)=>{"use strict";var kOe=kt(),Fy=class{static{a(this,"SearchByConditionsObject")}constructor(t,r,n,s,i=void 0,o=void 0,c="and"){this.schema=t,this.table=r,this.get_attributes=n,this.limit=i,this.offset=o,this.conditions=s,this.operator=c}},Gy=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},qy=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};A0.exports={SearchByConditionsObject:Fy,SearchCondition:Gy,SortAttribute:qy}});var w0=C((VOe,N0)=>{"use strict";var qOe=R0().SearchByConditionsObject,f9=Ws(),_9=Tu(),$y=Su(),iE=kt(),{Resource:$Oe}=(oa(),P(GA)),O0=sE(),h9=Uy(),m9=require("lodash"),{getSchemaPath:p9}=Et(),y0=_t(),{handleHDBError:E9,hdb_errors:g9}=me(),{HTTP_STATUS_CODES:S9}=g9,T9=1e8;N0.exports=A9;async function A9(e){let t=_9(e,"conditions");if(t)throw E9(t,t.message,S9.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=p9(e.schema,e.table),n=await y0.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let u of e.conditions)y0.openDBI(n,u.search_attribute);let i=m9.sortBy(e.conditions,u=>{if(u.estimated_count===void 0){let f=u.search_type;f===iE.SEARCH_TYPES.EQUALS?u.estimated_count=$y.count(n,u.search_attribute,u.search_value):f===iE.SEARCH_TYPES.CONTAINS||f===iE.SEARCH_TYPES.ENDS_WITH?u.estimated_count=1/0:u.estimated_count=T9}return u.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await b0(o,e,i[0],s.hash_attribute),l;if(!e.operator||e.operator.toLowerCase()==="and"){let u=n.dbis[s.hash_attribute],f=i.slice(1).map(O0.filterByType),d=f.length,_=$y.setGetWholeRowAttributes(n,e.get_attributes);l=c.map(h=>u.get(h,{transaction:o,lazy:!0})),d>0&&(l=l.filter(h=>{for(let m=0;m<d;m++)if(!f[m](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=>h9.parseRow(h,_))}else{for(let d=1;d<i.length;d++){let _=i[d],h=await b0(o,e,_,s.hash_attribute);c=c.concat(h)}let u=new Set,f=e.offset||0;c=c.filter(d=>u.has(d)?!1:(u.add(d),!0)).slice(f,e.limit&&e.limit+f),l=$y.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(A9,"lmdbSearchByConditions");async function b0(e,t,r,n){let s=new f9(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===iE.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,O0.searchByType(e,s,i,n).map(o=>o.value)}a(b0,"executeConditionSearch")});var g_=C((YOe,I0)=>{"use strict";var R9=(k(),P(q)).OPERATIONS_ENUM,Vy=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=R9.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};I0.exports=Vy});var Ky=C((zOe,x0)=>{"use strict";var L0=Ws(),M0=g_(),v0=E_(),U0=__(),Rn=(k(),P(q)),C0=oe(),P0=_t(),{getTransactionAuditStorePath:y9,getSchemaPath:b9}=Et(),D0=ee();x0.exports=O9;async function O9(e){try{if(C0.isEmpty(global.hdb_schema[e.schema])||C0.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await N9(e),await w9(e);let t=b9(e.schema,e.table);try{await P0.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")D0.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=y9(e.schema,e.table);await P0.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")D0.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(O9,"lmdbDropTable");async function N9(e){let t=new L0(Rn.SYSTEM_SCHEMA_NAME,Rn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Rn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Rn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await v0(t)),n=[];for(let i=0;i<r.length;i++){let o=r[i];n.push(o.id)}if(n.length===0)return;let s=new M0(Rn.SYSTEM_SCHEMA_NAME,Rn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await U0(s)}a(N9,"deleteAttributesFromSystem");async function w9(e){let t=new L0(Rn.SYSTEM_SCHEMA_NAME,Rn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Rn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[Rn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,Rn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,Rn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await v0(t))}catch(i){throw i}for(let i=0;i<r.length;i++){let o=r[i];o.name===e.table&&o.schema===e.schema&&(n=o)}if(!n)throw new Error(`${e.schema}.${e.table} was not found`);let s=new M0(Rn.SYSTEM_SCHEMA_NAME,Rn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await U0(s)}catch(i){throw i}}a(w9,"dropTableFromSystem")});var H0=C((jOe,B0)=>{"use strict";var I9=require("fs-extra"),C9=Ws(),P9=Au(),D9=g_(),L9=Ky(),M9=__(),v9=By(),U9=E_(),To=(k(),P(q)),{getSchemaPath:x9}=Et(),{handleHDBError:B9,hdb_errors:H9}=me(),{HDB_ERROR_MSGS:k9,HTTP_STATUS_CODES:F9}=H9;B0.exports=G9;async function G9(e){let t;try{t=await q9(e.schema);let r=new C9(To.SYSTEM_SCHEMA_NAME,To.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,To.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[To.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await U9(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await L9(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new D9(To.SYSTEM_SCHEMA_NAME,To.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await M9(s);let i=x9(t);await I9.remove(i)}catch(r){throw r}}a(G9,"lmdbDropSchema");async function q9(e){let t=new P9(To.SYSTEM_SCHEMA_NAME,To.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[To.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await v9(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw B9(new Error,k9.SCHEMA_NOT_FOUND(e),F9.NOT_FOUND,void 0,void 0,!0);return n}a(q9,"validateDropSchema")});var S_=C((XOe,k0)=>{"use strict";var Yy=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};k0.exports=Yy});var zy=C((tNe,F0)=>{"use strict";var $9=require("fs-extra"),oE=_t(),{getTransactionAuditStorePath:V9}=Et(),Wy=kt(),eNe=S_();F0.exports=K9;async function K9(e){let t;try{let r=V9(e.schema,e.table);await $9.mkdirp(r),t=await oE.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{oE.createDBI(t,Wy.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),oE.createDBI(t,Wy.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),oE.createDBI(t,Wy.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}a(K9,"createTransactionsAuditEnvironment")});var $0=C((sNe,q0)=>{"use strict";var Qy=(k(),P(q)),G0=_t(),Y9=vc(),{getSystemSchemaPath:W9,getSchemaPath:z9}=Et(),nNe=fo(),Q9=Bp(),jy=xp(),j9=ee(),J9=zy();q0.exports=X9;async function X9(e,t){let r=z9(t.schema,t.table),n=new jy(t.schema,t.table,Qy.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new jy(t.schema,t.table,Qy.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new jy(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await G0.createEnvironment(r,t.table),e!==void 0){let o=await G0.openEnvironment(W9(),Qy.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await Y9.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_table_attributes,[e]),n.skip_table_check=!0,s.skip_table_check=!0,i.skip_table_check=!0,await Jy(n),await Jy(s),await Jy(i)}await J9(t)}catch(o){throw o}}a(X9,"lmdbCreateTable");async function Jy(e){try{await Q9(e)}catch(t){j9.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(Jy,"createAttribute")});var K0=C((oNe,V0)=>{"use strict";var Z9=jf(),e7=bf(),t7=Xp(),T_=(k(),P(q)),r7=vc().updateRecords,n7=_t(),{getSchemaPath:s7}=Et(),i7=d_(),o7=ee();V0.exports=a7;async function a7(e){try{let{schema_table:t,attributes:r}=Z9(e);e7(e,r,t.hash_attribute),e.schema!==T_.SYSTEM_SCHEMA_NAME&&(r.includes(T_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(T_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(T_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(T_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await t7(e.hdb_auth_header,t,r),s=s7(e.schema,e.table),i=await n7.openEnvironment(s,e.table),o=await r7(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await i7(e,o)}catch(c){o7.error(`unable to write transaction due to ${c.message}`)}return{written_hashes:o.written_hashes,skipped_hashes:o.skipped_hashes,schema_table:t,new_attributes:n,txn_time:o.txn_time}}catch(t){throw t}}a(a7,"lmdbUpdateRecords")});var W0=C((cNe,Y0)=>{"use strict";var c7=(k(),P(q)).OPERATIONS_ENUM,Xy=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=c7.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};Y0.exports=Xy});var Q0=C((dNe,z0)=>{"use strict";var uNe=W0(),l7=jf(),u7=bf(),d7=Xp(),A_=(k(),P(q)),f7=vc().upsertRecords,_7=_t(),{getSchemaPath:h7}=Et(),m7=d_(),p7=ee(),{handleHDBError:E7,hdb_errors:g7}=me();z0.exports=S7;async function S7(e){let t;try{t=l7(e)}catch(l){throw E7(l,l.message,g7.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;u7(e,n,r.hash_attribute),e.schema!==A_.SYSTEM_SCHEMA_NAME&&(n.includes(A_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(A_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(A_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(A_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await d7(e.hdb_auth_header,r,n),i=h7(e.schema,e.table),o=await _7.openEnvironment(i,e.table),c=await f7(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await m7(e,c)}catch(l){p7.error(`unable to write transaction due to ${l.message}`)}return{written_hashes:c.written_hashes,schema_table:r,new_attributes:s,txn_time:c.txn_time}}a(S7,"lmdbUpsertRecords")});var J0=C((_Ne,j0)=>{"use strict";var Zy=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};j0.exports=Zy});var Z0=C((mNe,X0)=>{"use strict";var eb=class{static{a(this,"DeleteAuditLogsBeforeResults")}constructor(t=void 0,r=void 0,n=0){this.start_timestamp=t,this.end_timestamp=r,this.transactions_deleted=n}};X0.exports=eb});var rx=C((gNe,tx)=>{"use strict";var tb=_t(),{getTransactionAuditStorePath:T7}=Et(),ENe=J0(),R_=kt(),A7=oe(),ex=Z0(),R7=require("util").promisify,y7=R7(setTimeout),b7=1e4,O7=100;tx.exports=N7;async function N7(e){let t=T7(e.schema,e.table),r=await tb.openEnvironment(t,e.table,!0),n=tb.listDBIs(r);tb.initializeDBIs(r,R_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new ex;do s=await w7(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 y7(O7);while(s.transactions_deleted>0);return i}a(N7,"deleteAuditLogsBefore");async function w7(e,t){let r=new ex;try{let n=e.dbis[R_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],s;for(let{key:i,value:o}of n.getRange({start:!1})){if(i>=t)break;r.start_timestamp===void 0&&(r.start_timestamp=i),s=n.remove(i);let c=o[R_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];A7.isEmpty(c)||(s=e.dbis[R_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[R_.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>b7)break}return await s,r}catch(n){throw n}}a(w7,"deleteTransactions")});var sx=C((TNe,nx)=>{"use strict";var rb=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};nx.exports=rb});var ox=C((yNe,ix)=>{"use strict";var I7=Ws(),C7=g_(),RNe=sx(),Di=(k(),P(q)),P7=oe(),nb=_t(),D7=fo(),L7=E_(),M7=__(),{getSchemaPath:v7}=Et();ix.exports=U7;async function U7(e,t=!0){let r;e.schema===Di.SYSTEM_SCHEMA_NAME?r=D7[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await B7(e),s=v7(e.schema,e.table),i=await nb.openEnvironment(s,e.table);return t===!0&&await x7(e,i,r.hash_attribute),nb.dropDBI(i,e.attribute),n}a(U7,"lmdbDropAttribute");async function x7(e,t,r){let n=nb.openDBI(t,r),s,i=e.attribute;for(let{key:o,value:c,version:l}of n.getRange({start:!1,versions:!0})){let u={};for(let f in c)f!==i&&(u[f]=c[f]);s=t.dbis[r].put(o,u,l)}await s}a(x7,"removeAttributeFromAllObjects");async function B7(e){let t=new I7(Di.SYSTEM_SCHEMA_NAME,Di.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Di.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Di.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,Di.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await L7(t)).filter(o=>o[Di.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(P7.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[Di.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new C7(Di.SYSTEM_SCHEMA_NAME,Di.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return M7(i)}a(B7,"dropAttributeFromSystem")});var fx=C((NNe,dx)=>{"use strict";var sb=_t(),Ru=kt(),ONe=fn(),ib=(k(),P(q)),ax=oe(),{getTransactionAuditStorePath:H7}=Et(),k7=Su(),aE=pu(),F7=ee();dx.exports=G7;async function G7(e){let t=H7(e.schema,e.table),r=await sb.openEnvironment(t,e.table,!0),n=sb.listDBIs(r);sb.initializeDBIs(r,Ru.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case ib.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return cx(r,e.search_values);case ib.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,$7(r,e.search_values,s);case ib.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return q7(r,e.search_values);default:return cx(r)}}a(G7,"readAuditLog");function cx(e,t=[0,Date.now()]){ax.isEmpty(t[0])&&(t[0]=0),ax.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[Ru.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 aE,s))}a(cx,"searchTransactionsByTimestamp");function q7(e,t=[]){let r=new Map;for(let n=0;n<t.length;n++){let s=t[n],i=[];for(let o of e.dbis[Ru.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,ux(e,i))}return Object.fromEntries(r)}a(q7,"searchTransactionsByUsername");function $7(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let u=t[c],f=k7.equals(e,Ru.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Ru.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,u);for(let{value:d}of f){let _=Number(d);n.has(_)?n.get(_).push(u.toString()):n.set(_,[u.toString()])}}let s=Array.from(n.keys()),i=ux(e,s),o=new Map;for(let c=0;c<i.length;c++){let l=i[c],u=l.timestamp,f=n.get(u);lx(l,"records",r,f,o),lx(l,"original_records",r,f,o)}return Object.fromEntries(o)}a($7,"searchTransactionsByHashValues");function lx(e,t,r,n,s){let i=e.timestamp;if(e[t])for(let o=0;o<e[t].length;o++){let c=e[t][o],l=c[r].toString();if(n.indexOf(l)>=0)if(s.has(l)){let u=s.get(l),f=u[u.length-1];if(f.timestamp===i)f[t]=[c];else{let d=new aE(e.operation,e.user_name,i,void 0);d[t]=[c],u.push(d)}}else{let u=new aE(e.operation,e.user_name,i,void 0);u[t]=[c],s.set(l,[u])}}}a(lx,"loopRecords");function ux(e,t){let r=[];try{let n=e.dbis[Ru.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP];for(let s=0;s<t.length;s++)try{let i=n.get(t[s]);if(i){let o=Object.assign(new aE,i);r.push(o)}}catch(i){F7.warn(i)}return r}catch(n){throw n}}a(ux,"batchSearchTransactions")});var hx=C((PNe,_x)=>{"use strict";var{getSchemaPath:INe}=Et(),CNe=_t(),{database:V7}=(xe(),P(at));_x.exports={writeTransaction:K7};async function K7(e,t,r){return V7({database:e,table:t}).transaction(r)}a(K7,"writeTransaction")});var gx=C((LNe,Ex)=>{"use strict";var{getSchemaPath:mx}=Et(),px=_t();Ex.exports={flush:Y7,resetReadTxn:W7};async function Y7(e,t){return(await px.openEnvironment(mx(e,t),t.toString())).flushed}a(Y7,"flush");async function W7(e,t){try{(await px.openEnvironment(mx(e,t),t.toString())).resetReadTxn()}catch{}}a(W7,"resetReadTxn")});var Rx=C((vNe,Ax)=>{"use strict";var{Readable:z7}=require("stream"),{getDatabases:Q7}=(xe(),P(at)),{readSync:j7,openSync:J7,createReadStream:Sx}=require("fs"),{open:X7}=require("lmdb"),Tx=Kf(),Z7=Yf(),{AUDIT_STORE_OPTIONS:eee}=(Ri(),P(yx)),{INTERNAL_DBIS_NAME:tee,AUDIT_STORE_NAME:ree}=kt();Ax.exports=see;var ob=32768,nee=100;async function see(e){let t=e.database||e.schema||"data",r=Q7()[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 f=u.dbisDB,d=X7({noSync:!0,maxDbs:Z7.MAX_DBS}),_,h=d.openDB(tee,new Tx(!1)),m=f.useReadTransaction(),S=0,g=a(async function(E,T){T.encoding="binary",T.encoder=void 0;let N=d.openDB(E,T),v=f.openDB(E,T);for(let{key:H,version:X,value:W}of v.getRange({start:null,transaction:m,versions:v.useVersions}))_=N.put(H,W,X),S++%nee===0&&(await new Promise($=>setTimeout($,20)),m.openTimer&&(m.openTimer=0))},"copyDatabase");for(let{key:E,value:T}of f.getRange({transaction:m,start:!1}))if(s.some(N=>E.startsWith?.(N+"/"))){h.put(E,T);let[,N]=E.split("/"),v=!N,H=new Tx(!v,v);await g(E,H)}e.include_audit&&await g(ree,{...eee}),await _;let R=Sx(d.path);return R.headers=l(),R.on("close",()=>{m.done(),d.close()}),R}let o=r[Object.keys(r)[0]].primaryStore,c=J7(o.path);return o.transaction(()=>{let u=Buffer.alloc(ob);j7(c,u,0,ob),o.resetReadTxn();let f=o.useReadTransaction();f.renew();let d=Sx(null,{fd:c,start:ob}),_=new z7.from(async function*(){yield u;for await(let h of d)f.openTimer&&(f.openTimer=0),yield h;f.done()}());return _.headers=l(),_});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}}a(see,"getBackup")});var Nx=C((xNe,Ox)=>{"use strict";var iee=ee(),{handleHDBError:oee}=me(),aee=tM(),cee=Bp(),lee=Py(),uee=HU(),dee=__(),fee=By(),_ee=u0(),hee=S0(),mee=E_(),pee=w0(),Eee=H0(),gee=$0(),See=K0(),Tee=Q0(),Aee=rx(),Ree=Ky(),yee=ox(),bee=fx(),Oee=hx(),bx=gx(),Nee=Rx(),ab=class extends aee{static{a(this,"LMDBBridge")}async searchByConditions(t){return pee(t)}async getDataByHash(t){return await fee(t)}async searchByHash(t){return await _ee(t)}async getDataByValue(t,r){return await hee(t,r)}async searchByValue(t){return await mee(t)}async createSchema(t){return await uee(t)}async dropSchema(t){return await Eee(t)}async createTable(t,r){return await gee(t,r)}async dropTable(t){return await Ree(t)}async createAttribute(t){return await cee(t)}async createRecords(t){return await lee(t)}async updateRecords(t){return await See(t)}async upsertRecords(t){try{return await Tee(t)}catch(r){throw oee(r,null,null,iee.ERR,r)}}async deleteRecords(t){return await dee(t)}async dropAttribute(t){return await yee(t)}async deleteAuditLogsBefore(t){return await Aee(t)}async readAuditLog(t){return await bee(t)}writeTransaction(t,r,n){return Oee.writeTransaction(t,r,n)}flush(t,r){return bx.flush(t,r)}resetReadTxn(t,r){return bx.resetReadTxn(t,r)}getBackup(t){return Nee(t)}};Ox.exports=ab});var lb={};Ue(lb,{add:()=>cE,applyReverse:()=>wx,getRecordAtTime:()=>cb,rebuildUpdateBefore:()=>lE});function cE(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n+BigInt(r.value):isNaN(e[t])?e[t]=r.value:e[t]=n+r.value}function lE(e,t,r){let n=null;for(let s in e)if(s in t){let i=t[s];if(i?.__op__){let o=e[s];if(o?.__op__)if(o.__op__===i.__op__)n||(n={}),n[s]=o;else throw new Error("Can not merge updates with different operations");else n||(n={}),n[s]=o,cE(n,s,i)}else r&&(n||(n={}),n[s]=i)}else n||(n={}),n[s]=e[s];return n}function wx(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=wee[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=Ix}}function cb(e,t,r){let n=r.rootStore.auditStore,s={...e.value},i=e.localTime;for(;i>t;){let l=n.get(i),u=gt(l);switch(u.type){case"put":s=u.getValue(r);break;case"patch":wx(s,u.getValue(r));break;case"delete":s=null}i=u.previousLocalTime}let o={},c=0;for(let l in s)s[l]===Ix&&(o[l]=!0,c++);for(;c>0&&i>0;){let l=n.get(i),u=gt(l),f;switch(u.type){case"put":f=u.getValue(r);break;case"patch":f=u.getValue(r);break}for(let d in f)o[d]&&(s[d]=f[d],o[d]=!1,c--);i=u.previousLocalTime}if(c>0)for(let l in o)s[l]=null;return s}var wee,Ix,uE=Re(()=>{Ri();a(cE,"add");cE.reverse=function(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n-BigInt(r.value):isNaN(e[t])||(e[t]=n-r.value)};wee={add:cE};a(lE,"rebuildUpdateBefore");a(wx,"applyReverse");Ix={};a(cb,"getRecordAtTime")});function yn(e){let t=e.getChanges();return t||(t=Object.create(null),e._setChanges(t)),t}function hE(e,t){let r=e.prototype,n={},s=t.attributes||t.properties||[];for(let c of s){let l=c.name,u,f;if(c.resolve)f={get(){return c.resolve(this,this.getContext?.())},set(d){return c.set(this,d)},configurable:!0};else{switch(c.type){case"String":u=a(function(d){if(!(typeof d=="string"||d==null&&c.nullable!==!1))throw new zn.ClientError(`${l} must be a string, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"ID":u=a(function(d){if(!(typeof d=="string"||d?.length>0&&d.every?.(_=>typeof _=="string")||d==null&&c.nullable!==!1))throw new zn.ClientError(`${l} must be a string, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"Float":case"Number":u=a(function(d){let _=d?.__op__?d.value:d;if(!(typeof _=="number"||d==null&&c.nullable!==!1))throw new zn.ClientError(`${l} must be a number, attempt to assign ${_}`);yn(this)[l]=d},"set");break;case"Int":u=a(function(d){let _=d?.__op__?d.value:d;if(!(_>>0===_||d==null&&c.nullable!==!1))if(typeof _=="number"&&Math.abs((_>>0)-_)<=1)_=Math.round(_),d?.__op__?d.value=_:d=_;else throw new zn.ClientError(`${l} must be an integer between -2147483648 and 2147483647, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"Long":u=a(function(d){let _=d?.__op__?d.value:d;if(!(Math.round(_)===d&&Math.abs(_)<=9007199254740992||d==null&&c.nullable!==!1))if(typeof _=="number"&&Math.abs(_)<=9007199254740992)_=Math.round(_),d?.__op__?d.value=_:d=_;else throw new zn.ClientError(`${l} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"BigInt":u=a(function(d){let _=d?.__op__?d.value:d;if(!(typeof _=="bigint"||d==null&&c.nullable!==!1))if(typeof _=="string"||typeof _=="number")_=BigInt(_),d?.__op__?d.value=_:d=_;else throw new zn.ClientError(`${l} must be a number, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"Boolean":u=a(function(d){if(!(typeof d=="boolean"||d==null&&c.nullable!==!1))throw new zn.ClientError(`${l} must be a boolean, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"Date":u=a(function(d){if(!(d instanceof Date||d==null&&c.nullable!==!1))if(typeof d=="string"||typeof d=="number")d=new Date(d);else throw new zn.ClientError(`${l} must be a Date, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"Bytes":u=a(function(d){if(!(d instanceof Uint8Array||d==null&&c.nullable!==!1))throw new zn.ClientError(`${l} must be a Buffer or Uint8Array, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"Blob":u=a(function(d){if(!(d instanceof Ai||d==null&&c.nullable!==!1))throw new zn.ClientError(`${l} must be a Blob, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"Any":case void 0:u=a(function(d){yn(this)[l]=d},"set");break;default:u=a(function(d){if(!(typeof d=="object"||d==null&&c.nullable!==!1))throw new zn.ClientError(`${l} must be an object, attempt to assign ${d}`);yn(this)[l]=d},"set")}f={get(){let d=this.getChanges?.();if(d&&l in d){let h=d[l];if(h?.__op__){let m=this.getRecord()?.[l];return h.update(m)}return h}let _=this.getRecord()?.[l];if(_&&typeof _=="object"){let h=ub(_,c);if(h)return d||this._setChanges(d=Object.create(null)),d[l]=h}return _},set:u,enumerable:!0,configurable:!0}}f.get.isAttribute=!0,n[l]=f,(!(l in r)||Object.getOwnPropertyDescriptor(r,l)?.get?.isAttribute)&&Object.defineProperty(r,l,f)}i("getProperty",function(c){let l=n[c];if(l)return l.get.call(this);let u=this.getChanges();return u?.[c]!==void 0?u[c]:this.getRecord()?.[c]}),i("set",function(c,l){let u=n[c];if(u)return u.set.call(this,l);if(t.sealed)throw new zn.ClientError("Can not add a property to a sealed table schema");yn(this)[c]=l}),i("deleteProperty",function(c){yn(this)[c]=void 0}),i("toJSON",function(){let c=this.getChanges?.(),l;for(let f in c){l||(l={...this.getRecord()});let d=c[f];if(d?.__op__){let _=l[f];d=d.update(_)}l[f]=d}return Object.keys(this).length>0&&(l||(l={...this.getRecord()}),Object.assign(l,this)),l||this.getRecord()}),r.get||i("get",r.getProperty),r.delete||i("delete",r.deleteProperty),r.then||i("then",null);function i(c,l){Object.defineProperty(r,c,{value:l,configurable:!0})}a(i,"setMethod");let o=r;do{let c=Object.getPrototypeOf(o);if(c===Object.prototype){Object.setPrototypeOf(o,Px);break}o=c}while(o&&o!==Px)}function ub(e,t){let r;switch(e.constructor){case Object:return t?(r=t.TrackedObject,r||(t.TrackedObject=r=class extends y_{static{a(this,"TrackedObject")}},hE(r,t)),new r(e)):new y_(e);case Array:let n=new fE(e.length,e);for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=ub(o,t?.elements)),n[s]=o}return n;default:return e}}function mE(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 o=r[s];i=i.update(o)}else i=mE(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 yu(e,t=e.getChanges?.()){let r;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 o=yu(i);o!==i&&r===e&&(r=e.slice(0)),i=o}r[n]=i}return Object.freeze(r)}for(let n in t){r||(r={...e.getRecord?.()});let s=t[n];if(s&&typeof s=="object")if(s.__op__){let i=lb[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=yu(s);r[n]=s}if(!Array.isArray(e))for(let n in e)Iee.call(e,n)&&(r||(r={...e.getRecord?.()}),r[n]=e[n]);return r?Object.freeze(r):e.getRecord?.()??e}function dE(e){let t=e.getRecord?.();if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[Yc]||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(dE(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(dE(s))return!0}else return!0}else return!0}}return!1}var zn,Cx,Px,y_,Iee,Yc,fE,_E,db=Re(()=>{zn=M(me());uE();gn();a(yn,"getChanges");a(hE,"assignTrackedAccessors");Cx=Object.prototype,Px=new Proxy({},{get(e,t,r){if(typeof t=="string"){if(t==="then"||t==="getRecord"||t==="getChanges")return;if(Cx[t])return Cx[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=ub(s);if(i)return n||(n=Object.create(null),r._setChanges(n)),n[t]=i,i}return s}}});a(ub,"trackObject");y_=class{static{a(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}};hE(y_,{});a(mE,"collapseData");Iee=Object.prototype.hasOwnProperty;a(yu,"updateAndFreeze");a(dE,"hasChanges");Yc=Symbol.for("has-array-changes"),fE=class extends Array{static{a(this,"TrackedArray")}#e;[Yc];constructor(t,r){super(t),this.#e=r}getRecord(){return this.#e}splice(...t){return this[Yc]=!0,super.splice(...t)}push(...t){return this[Yc]=!0,super.push(...t)}pop(){return this[Yc]=!0,super.pop()}unshift(...t){return this[Yc]=!0,super.unshift(...t)}shift(){return this[Yc]=!0,super.shift()}};fE.prototype.constructor=Array;_E=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var Hx={};Ue(Hx,{ResourceBridge:()=>hb});function mb({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 Lx(e,t){let r=Li(e),n=mb(e,r);if(!r)throw new zs.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},o;Ct(i,()=>new Promise(u=>o=u));let c=e.ids||e.hash_values,l=0;return{[Symbol.asyncIterator](){return{async next(){if(l<c.length){let u=c[l++],f;try{f=await r.get({id:u,lazy:s,select:n},i),f=f&&mE(f)}catch(d){f={message:d.toString()}}return t?{value:{key:u,value:f}}:{value:f}}else return o(),{done:!0}},return(u){return o(),{value:u,done:!0}},throw(u){return o(),{done:!0}}}}}}function Li(e){let t=e.database||e.schema||Pee,r=Xe()[t];if(!r)throw(0,zs.handleHDBError)(new Error,Cee.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function Mx(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*vx(e,t,r,n){let s,i=0;for await(let o of e.getHistory(t,r)){let c=o.operation??o.type;c==="put"&&(c="upsert");let{id:l,version:u,value:f}=o;if(s?.timestamp===u)s.hash_values.push(l),s.records.push(f);else{if(s&&(yield s,i++,n&&n<=i)){s=void 0;break}s={operation:c,user_name:o.user,timestamp:u,hash_values:[l],records:[f]}}}s&&(yield s)}var Ux,pE,zs,xx,fb,_b,Bx,Cee,Pee,Dee,Lee,Dx,hb,kx=Re(()=>{"use strict";Ux=M(Nx()),pE=M(Tu()),zs=M(me());xe();xx=M(jf());k();fb=M(go()),_b=M(Ys()),Bx=M(oe());gc();db();({HDB_ERROR_MSGS:Cee}=zs.hdb_errors),Pee="data",Dee=1e4,Lee=10,hb=class extends Ux.default{static{a(this,"ResourceBridge")}constructor(t){super(t),Dx=this}async searchByConditions(t){t.select!==void 0&&(t.get_attributes=t.select);for(let o of t.conditions||[])o?.attribute!==void 0&&(o.search_attribute=o.attribute),o?.comparator!==void 0&&(o.search_type=o.comparator),o?.value!==void 0&&(o.search_value=o.value);let r=(0,pE.default)(t,"conditions");if(r)throw(0,zs.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=Li(t);if(!n)throw new zs.ClientError(`Table ${t.table} not found`);let s=t.conditions.map(i);function i(o){return o.conditions?(o.conditions=o.conditions.map(i),o):{attribute:o.search_attribute??o.attribute,comparator:o.search_type??o.comparator,value:o.search_value!==void 0?o.search_value:o.value}}return a(i,"mapCondition"),n.search({conditions:s,operator:t.operator?t.operator.toLowerCase():void 0,limit:t.limit,offset:t.offset,reverse:t.reverse,select:mb(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 o of n)o.is_primary_key?(o.isPrimaryKey=!0,delete o.is_primary_key):o.name===i&&i&&(o.isPrimaryKey=!0);else{if(!i)throw new zs.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}]}ft({database:r.database??r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration,audit:r.audit})}async createAttribute(t){return await Li(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=Li(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=a((o,c,l)=>(c={...c},delete c[n],r.primaryStore.ifVersion(o,l,()=>r.primaryStore.put(o,c,l)).then(u=>{if(!u){let{value:f,version:d}=r.primaryStore.getEntry(o);return i(o,f,d)}})),"deleteRecord");for(let{key:o,value:c,version:l}of r.primaryStore.getRange({start:!0,versions:!0}))s=i(o,c,l),await new Promise(u=>setImmediate(u));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){Li(t).dropTable()}createSchema(t){return bu({database:t.schema,table:null}),fb.signalSchemaChange(new _b.SchemaEventMsg(process.pid,Yt.CREATE_SCHEMA,t.schema))}async dropSchema(t){await pb(t.schema),fb.signalSchemaChange(new _b.SchemaEventMsg(process.pid,Yt.DROP_SCHEMA,t.schema))}async updateRecords(t){return t.requires_existing=!0,this.upsertRecords(t)}async createRecords(t){return t.requires_no_existing=!0,Dx.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,xx.default)(t),s,i=Xe()[t.schema][t.table],o={user:t.hdb_user,expiresAt:t.expiresAt,originatingOperation:t.operation};return t.replicateTo&&(o.replicateTo=t.replicateTo),t.replicatedConfirmation&&(o.replicatedConfirmation=t.replicatedConfirmation),Ct(o,async c=>{if(!i.schemaDefined){s=[];for(let f of n)i.attributes.find(_=>_.name==f)||s.push(f);s.length>0&&await i.addAttributes(s.map(f=>({name:f,indexed:!0})))}let l=[],u=[];for(let f of t.records){let d=f[i.primaryKey],_=d!=null&&await i.get(d,o);if(t.requires_existing&&!_||t.requires_no_existing&&_){u.push(f[i.primaryKey]);continue}_&&(_=mE(_));for(let h in f)if(Object.prototype.hasOwnProperty.call(f,h)){let m=f[h];if(typeof m=="function")try{let S=m([[_]]);Array.isArray(S)&&(m=S[0].func_val,f[h]=m)}catch(S){throw S.message+="Trying to set key "+h+" on object"+JSON.stringify(f),S}}if(_)for(let h in _)Object.prototype.hasOwnProperty.call(f,h)||(f[h]=_[h]);await(d==null?i.create(f,o):i.put(f,o)),l.push(f[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:l,new_attributes:s,skipped_hashes:u}})}async deleteRecords(t){let r=Xe()[t.schema][t.table],n={user:t.hdb_user};return t.replicateTo&&(n.replicateTo=t.replicateTo),t.replicatedConfirmation&&(n.replicatedConfirmation=t.replicatedConfirmation),Ct(n,async s=>{let i=t.hash_values||t.records.map(l=>l[r.primaryKey]),o=[],c=[];for(let l of i)await r.delete(l,n)?o.push(l):c.push(l);return Mx(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=Xe()[t.schema][t.table];if(!r.createdTimeProperty)throw new zs.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:Um.LESS}]}),s=!1,i=[],o=[],c=0,l=[],u=a(async()=>{let f=await this.deleteRecords({schema:t.schema,table:t.table,hash_values:l});i.push(...f.deleted_hashes),o.push(...f.skipped_hashes),await(0,Bx.async_set_timeout)(Lee),l=[],s=!0},"chunkDelete");for await(let f of n)l.push(f[r.primaryKey]),c++,c%Dee===0&&await u();return l.length>0&&await u(),s?Mx(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,pE.default)(t,"hashes");if(r)throw r;return Lx(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of Lx(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&fA[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=condition.attribute),t.value!==void 0&&(t.search_value=condition.value);let n=(0,pE.default)(t,"value");if(n)throw n;let s=Li(t);if(!s)throw new zs.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===Um.BETWEEN&&(i=[i,t.end_value]);let o=i==="*"?[]:[{attribute:t.search_attribute,value:i,comparator:r}];return s.search({conditions:o,allowFullScan:!0,limit:t.limit,offset:t.offset,reverse:t.reverse,sort:t.sort,select:mb(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async getDataByValue(t,r){let n=new Map,s=Li(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){Li({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return Li(t).deleteHistory(t.timestamp,t.cleanup_deleted_records)}async readAuditLog(t){let r=Li(t),n={};switch(t.search_type){case xm.HASH_VALUE:for(let i of t.search_values)n[i]=(await r.getHistoryOfRecord(i)).map(o=>{let c=o.operation??o.type;return c==="put"&&(c="upsert"),{operation:c,timestamp:o.version,user_name:o.user,hash_values:[i],records:[o.value]}});return n;case xm.USERNAME:let s=t.search_values;for await(let i of vx(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return vx(r,t.search_values?.[0],t.search_values?.[1],t.limit)}}};a(mb,"getSelect");a(Lx,"getRecords");a(Li,"getTable");a(Mx,"createDeleteResponse");a(vx,"groupRecordsInHistory")});var Vn=C((QNe,Fx)=>{"use strict";var{ResourceBridge:Mee}=(kx(),P(Hx)),vee=ce();vee.initSync();var EE;function Uee(){return EE||(EE=new Mee,EE)}a(Uee,"getBridge");Fx.exports=Uee()});var An=C((JNe,Vx)=>{"use strict";var SE=dR(),xr=oe(),xee=require("util"),TE=Vn(),Bee=ps(),Gx=ee(),{handleHDBError:Wc,hdb_errors:Hee}=me(),{HTTP_STATUS_CODES:zc}=Hee,kee=xee.promisify(Bee.getTableSchema),Fee="updated",qx="inserted",$x="upserted";Vx.exports={insert:qee,update:$ee,upsert:Vee,validation:Gee,flush:Kee};async function Gee(e){if(xr.isEmpty(e))throw new Error("invalid update parameters defined.");if(xr.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if(xr.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await kee(e.schema,e.table),r=SE(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={},o=!1;return e.operation==="update"&&(o=!0),e.records.forEach(c=>{if(o&&xr.isEmptyOrZeroLength(c[n]))throw Gx.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(!xr.isEmptyOrZeroLength(c[n])&&(c[n]==="null"||c[n]==="undefined"))throw Gx.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[n]}" is not a valid hash attribute value`);!xr.isEmpty(c[n])&&c[n]!==""&&s.has(xr.autoCast(c[n]))&&(c.skip=!0),s.add(xr.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)}}a(Gee,"validation");async function qee(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=SE(e);if(t)throw Wc(new Error,t.message,zc.BAD_REQUEST);xr.transformReq(e);let r=xr.checkSchemaTableExist(e.schema,e.table);if(r)throw Wc(new Error,r,zc.BAD_REQUEST);let n=await TE.createRecords(e);return gE(qx,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(qee,"insertData");async function $ee(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=SE(e);if(t)throw Wc(new Error,t.message,zc.BAD_REQUEST);xr.transformReq(e);let r=xr.checkSchemaTableExist(e.schema,e.table);if(r)throw Wc(new Error,r,zc.BAD_REQUEST);let n=await TE.updateRecords(e);return xr.isEmpty(n.existing_rows)?gE(Fee,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):gE(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a($ee,"updateData");async function Vee(e){if(e.operation!=="upsert")throw Wc(new Error,"invalid operation, must be upsert",zc.INTERNAL_SERVER_ERROR);let t=SE(e);if(t)throw Wc(new Error,t.message,zc.BAD_REQUEST);xr.transformReq(e);let r=xr.checkSchemaTableExist(e.schema,e.table);if(r)throw Wc(new Error,r,zc.BAD_REQUEST);let n=await TE.upsertRecords(e);return gE($x,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(Vee,"upsertData");function gE(e,t,r,n,s,i){let o={message:`${e} ${t.length} of ${t.length+n.length} records`,new_attributes:s,txn_time:i};return e===qx?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===$x?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(gE,"returnObject");function Kee(e){return xr.transformReq(e),TE.flush(e.schema,e.table)}a(Kee,"flush")});var jx=C((ZNe,Qx)=>{var Ou=require("validate.js"),Yx=st(),Nu=(k(),P(q)),{handleHDBError:Yee,hdb_errors:Wee}=me(),{HDB_ERROR_MSGS:Qt,HTTP_STATUS_CODES:zee}=Wee,Eb=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),Qee={STRUCTURE_USER:"structure_user"},Kx=Object.values(Nu.ROLE_TYPES_ENUM),jee="attribute_permissions",Jee="attribute_name",{PERMS_CRUD_ENUM:wu}=Nu,Xee=[jee,...Object.values(wu)],Wx=[wu.READ,wu.INSERT,wu.UPDATE],Zee=[Jee,...Wx];function ete(e){let t=Eb();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,zx(e,t)}a(ete,"addRoleValidation");function tte(e){let t=Eb();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,zx(e,t)}a(tte,"alterRoleValidation");function rte(e){let t=Eb();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,Yx.validateObject(e,t)}a(rte,"dropRoleValidation");var nte=["operation","role","id","permission","hdb_user","access"];function zx(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)nte.includes(n[o])||s.push(n[o]);s.length>0&&nr(Qt.INVALID_ROLE_JSON_KEYS(s),r);let i=Yx.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{nr(o,r)}),e.permission){let o=ste(e);o&&nr(o,r),Kx.forEach(c=>{e.permission[c]&&!Ou.isBoolean(e.permission[c])&&nr(Qt.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(Kx.indexOf(o)<0){if(o===Qee.STRUCTURE_USER){let l=e.permission[o];if(typeof l=="boolean")continue;if(Array.isArray(l)){for(let u=0,f=l.length;u<f;u++){let d=l[u];global.hdb_schema[d]||nr(Qt.SCHEMA_NOT_FOUND(d),r)}continue}nr(Qt.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){nr(Qt.SCHEMA_NOT_FOUND(o),r);continue}if(c.tables)for(let l in c.tables){let u=c.tables[l];if(!l||!global.hdb_schema[o][l]){nr(Qt.TABLE_NOT_FOUND(o,l),r);continue}if(Object.keys(u).forEach(f=>{Xee.includes(f)||nr(Qt.INVALID_PERM_KEY(f),r,o,l)}),Object.values(wu).forEach(f=>{Ou.isDefined(u[f])?Ou.isBoolean(u[f])||nr(Qt.TABLE_PERM_NOT_BOOLEAN(f),r,o,l):nr(Qt.TABLE_PERM_MISSING(f),r,o,l)}),u.attribute_permissions===void 0){nr(Qt.ATTR_PERMS_ARRAY_MISSING,r,o,l);continue}else if(!(Array.isArray(u.attribute_permissions)||u.attribute_permissions===null)){nr(Qt.ATTR_PERMS_NOT_ARRAY,r,o,l);continue}if(u.attribute_permissions){let f=global.hdb_schema[o][l].attributes.map(({attribute:_})=>_),d={read:!1,insert:!1,update:!1};for(let _ in u.attribute_permissions){let h=u.attribute_permissions[_];if(Object.keys(h).forEach(S=>{!Zee.includes(S)&&S!==wu.DELETE&&nr(Qt.INVALID_ATTR_PERM_KEY(S),r,o,l)}),!Ou.isDefined(h.attribute_name)){nr(Qt.ATTR_PERM_MISSING_NAME,r,o,l);continue}let m=h.attribute_name;if(!f.includes(m)){nr(Qt.INVALID_ATTRIBUTE_IN_PERMS(m),r,o,l);continue}Wx.forEach(S=>{Ou.isDefined(h[S])?Ou.isBoolean(h[S])||nr(Qt.ATTR_PERM_NOT_BOOLEAN(S,m),r,o,l):nr(Qt.ATTR_PERM_MISSING(S,m),r,o,l)}),!d.read&&h.read===!0&&(d.read=!0),!d.insert&&h.insert===!0&&(d.insert=!0),!d.update&&h.update===!0&&(d.update=!0)}if(u.read===!1&&d.read===!0||u.insert===!1&&d.insert===!0||u.update===!1&&d.update===!0){let _=`${o}.${l}`;nr(Qt.MISMATCHED_TABLE_ATTR_PERMS(_),r,o,l)}}}}return ite(r)}a(zx,"customValidate");Qx.exports={addRoleValidation:ete,alterRoleValidation:tte,dropRoleValidation:rte};function ste(e){let{operation:t,permission:r}=e;if(t===Nu.OPERATIONS_ENUM.ADD_ROLE||t===Nu.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 Qt.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?Nu.ROLE_TYPES_ENUM.SUPER_USER:Nu.ROLE_TYPES_ENUM.CLUSTER_USER;return Qt.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(ste,"validateNoSUPerms");function ite(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:Qt.ROLE_PERMS_ERROR,...e};return Yee(new Error,n,zee.BAD_REQUEST)}else return null}a(ite,"generateRolePermResponse");function nr(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]}}a(nr,"addPermError")});var O_=C((rwe,eB)=>{"use strict";var Jx=An(),Xx=Wr(),ote=Fc(),Sb=jx(),Tb=go(),twe=require("uuid").v4,ate=require("util"),AE=(k(),P(q)),cte=oe(),Ab=Xx.searchByValue,lte=Xx.searchByHash,ute=ate.promisify(ote.delete),dte=Ws(),fte=Au(),{hdb_errors:_te,handleHDBError:Qc}=me(),{HDB_ERROR_MSGS:Zx,HTTP_STATUS_CODES:b_}=_te,{UserEventMsg:Rb}=Ys();eB.exports={addRole:hte,alterRole:mte,dropRole:pte,listRoles:Ete};function gb(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}a(gb,"scrubRoleDetails");async function hte(e){let t=Sb.addRoleValidation(e);if(t)throw t;e=gb(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 Ab(r)||[])}catch(i){throw Qc(i)}if(n&&n.length>0)throw Qc(new Error,Zx.ROLE_ALREADY_EXISTS(e.role),b_.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 Jx.insert(s),Tb.signalUserChange(new Rb(process.pid)),e=gb(e),e}a(hte,"addRole");async function mte(e){let t=Sb.alterRoleValidation(e);if(t)throw t;e=gb(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await Jx.update(r)}catch(s){throw Qc(s)}if(n&&n?.message==="updated 0 of 1 records")throw Qc(new Error,"Invalid role id",b_.BAD_REQUEST,void 0,void 0,!0);return await Tb.signalUserChange(new Rb(process.pid)),e}a(mte,"alterRole");async function pte(e){let t=Sb.dropRoleValidation(e);if(t)throw Qc(new Error,t,b_.BAD_REQUEST,void 0,void 0,!0);let r=new fte(AE.SYSTEM_SCHEMA_NAME,AE.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await lte(r));if(n.length===0)throw Qc(new Error,Zx.ROLE_NOT_FOUND,b_.NOT_FOUND,void 0,void 0,!0);let s=new dte(AE.SYSTEM_SCHEMA_NAME,AE.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await Ab(s)),o=!1;if(cte.isEmptyOrZeroLength(i)===!1){for(let l=0;l<i.length;l++)if(i[l].active===!0){o=!0;break}}if(o===!0)throw Qc(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,b_.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await ute(c),Tb.signalUserChange(new Rb(process.pid)),`${n[0].role} successfully deleted`}a(pte,"dropRole");async function Ete(){return Ab({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(Ete,"listRoles")});var yb={};Ue(yb,{start:()=>nB,startOnMainThread:()=>Tte});function nB({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r){let n=(0,tB.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 o in i.permission){if(gte.includes(o))continue;let c=i.permission[o];c.tables||(i.permission[o]=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 f=[];for(let d in u.attributes){let _=u.attributes[d];_.attribute_name=d,f.push(_)}u.attribute_permissions=f,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 f of u.attribute_permissions)f.read=!!f.read,f.insert=!!f.insert,f.update=!!f.update}else u.attribute_permissions=null}}i.role=i.id=s,await Ste(i)}}}async function Ste(e){let t=Xe().system.hdb_role;for await(let r of t.search([{attribute:"role",value:e.role}])){let{__createdtime__:n,__updatedtime__:s,...i}=r;return(0,rB.isEqual)(i,e)?void 0:(e.id=r.id,(0,RE.alterRole)(e))}return(0,RE.addRole)(e)}var RE,tB,rB,gte,Tte,sB=Re(()=>{xe();RE=M(O_()),tB=require("yaml"),rB=require("lodash"),gte=["super_user","cluster_user","structure_user"];a(nB,"start");a(Ste,"ensureRole");Tte=nB});async function yE(e){let t=(0,aB.pathToFileURL)(e).toString();if(Ate)return N_||(N_=Rte(bte)),(await(await N_).import(t)).namespace;try{return await import(t)}catch(r){try{(await import("internal/util")).default.decorateErrorStack(r)}catch{}throw r}}async function Rte(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),N_=new Compartment({console,Math,Date,fetch:yte,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,oB.extname)(r)||(r+=".js"),r)},importHook:a(async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){Object.assign(s,{Resource:Kr,tables:Qn,databases:We})}};let n=await(0,iB.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)},"importHook")}),N_}function yte(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 bte(){return{Resource:Kr,tables:Qn}}var iB,oB,aB,Ate,N_,bb=Re(()=>{oa();xe();iB=require("fs/promises"),oB=require("path"),aB=require("url"),Ate=!1;a(yE,"secureImport");a(Rte,"getCompartment");a(yte,"secureOnlyFetch");a(bte,"getGlobalVars")});var Nb={};Ue(Nb,{handleFile:()=>Ote});async function Ote(e,t,r,n){let s=new Map,i=await yE(r);c(i.default)&&n.set((0,Ob.dirname)(t),i.default),o(i,(0,Ob.dirname)(t));function o(l,u){for(let f in l){let d=l[f];c(d)?n.set(u+"/"+f,d):typeof d=="object"&&o(d,u+"/"+f)}}a(o,"recurseForResources");function c(l){return typeof l=="function"&&(l.get||l.put||l.post||l.delete)}return a(c,"isResource"),s}var Ob,cB=Re(()=>{bb();Ob=require("path");a(Ote,"handleFile")});var Ib={};Ue(Ib,{start:()=>Nte});function Nte({resources:e}){e.set("login",wb),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var wb,lB=Re(()=>{oa();a(Nte,"start");wb=class extends Kr{static{a(this,"Login")}static async get(t,r,n){}static async post(t,r,n){let{username:s,password:i,redirect:o}=r;return{data:await n.login(s,i)}}}});var L_={};Ue(L_,{addAnalyticsListener:()=>D_,calculateCPUUtilization:()=>IB,diffResourceUsage:()=>CB,recordAction:()=>Dt,recordActionBinary:()=>jn,setAnalyticsEnabled:()=>wte});function wte(e){yB=e}function Ite(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 Cte(e,t,r,n,s,i){let o={};if(typeof t=="number")o.total=t,o.values=new Float32Array(4),o.values.index=1,o.values[0]=t,o.total=t;else if(typeof t=="boolean")o.total=t?1:0,o.count=1;else if(typeof t=="function")o.count=1,o.callback=t;else throw new TypeError("Invalid metric value type "+typeof t);o.description={metric:r,path:n,method:s,type:i},OE.set(e,o)}function Dt(e,t,r,n,s){if(!yB)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=OE.get(i);o?Ite(e,o):Cte(i,e,t,r,n,s),bE||Pte()}function jn(e,t,r,n,s){Dt(!!e,t,r,n,s)}function D_(e){NB.push(e)}function Pte(){bE=performance.now(),setTimeout(async()=>{let e=performance.now()-bE;bE=0;let t=[],r={time:Date.now(),period:e,threadId:jc.threadId,metrics:t};for(let[s,i]of OE){if(i.values){let o=i.values.subarray(0,i.values.index);o.sort();let c=o.length,l=0,u=[],f;for(let d of wB){let _=Math.floor(c*d),h=o[_-1];if(_>l){let m=_-l;if(h===f){let S=u[u.length-1];typeof S=="number"?u[u.length-1]={value:S,count:1+m}:S.count+=m}else u.push(m>1?{value:h,count:m}:h),f=h;l=_}}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 PB()}let n=process.memoryUsage();t.push({metric:"memory",threadId:jc.threadId,byThread:!0,...n});for(let s of NB)s(t);OE=new Map,jc.parentPort?jc.parentPort.postMessage({type:OB,report:r}):MB({report:r})},bB).unref()}function NE(e,t,r){let n={id:(0,C_.getNextMonotonicTime)(),metric:t,...r};e.primaryStore.put(n.id,n,{append:!0}).then(s=>{s||e.primaryStore.put(n.id,n)})}function IB(e,t){let r=e.userCPUTime+e.systemCPUTime;return Math.round(r/t*100)/100}function CB(e,t){return{userCPUTime:t.userCPUTime/1e3-(e?.userCPUTime??0),systemCPUTime:t.systemCPUTime/1e3-(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 Dte(e,t,r){let n=0;for(let[s,i]of Object.entries(r)){let o=`${t}.${s}`,c=i.getSize(),l={database:t,table:s,size:c};NE(e,"table-size",l),Jc.trace?.(`table ${o} size metric: ${JSON.stringify(l)}`),n+=c}return n}function uB(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s?.getAuditSize();if(!i)return;let o=RB.default.statSync(s.primaryStore.env.path).size,c=Dte(e,r,n),l=o-c,u={database:r,size:o,used:c,free:l,audit:i};NE(e,"database-size",u),Jc.trace?.(`database ${r} size metric: ${JSON.stringify(u)}`)}catch(s){Jc.warn?.("Error getting DB size metrics",s)}}function dB(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s?.getStorageStats();if(!i)return;let o={database:r,...i};NE(e,"storage-volume",o),Jc.trace?.(`db ${r} storage volume metrics: ${JSON.stringify(o)}`)}catch(s){Jc.warn?.("Error getting DB volume metrics",s)}}async function Lte(e,t=6e4){let r=Pb(),n=DB(),s=new Promise(E=>{let T=performance.now();setImmediate(()=>{let N=performance.now();N-T>5e3&&Jc.warn?.("Unusually high event queue latency on the main thread of "+Math.round(N-T)+"ms"),T=performance.now()}),n.primaryStore.prefetch([1],()=>{let N=performance.now();N-T>5e3&&Jc.warn?.("Unusually high task queue latency on the main thread of "+Math.round(N-T)+"ms"),E(N-T)})}),i;for(let E of n.primaryStore.getRange({start:1/0,end:!1,reverse:!0}))if(E.value?.time){i=E.value.time;break}if(Date.now()-t<i)return;let o,c=new Map,l=new Map,u=[],f;for(let{key:E,value:T}of r.primaryStore.getRange({start:i||!1,exclusiveStart:!0,end:1/0})){if(!T)continue;if(o){if(E>o+t)break}else o=E;f=E;let{metrics:N,threadId:v}=T;for(let H of N||[]){let{path:X,method:W,type:$,metric:ie,count:z,total:de,distribution:le,threads:Z,...Ae}=H;z||(z=1);let pe=ie+(X?"-"+X:"");W!==void 0&&(pe+="-"+W),$!==void 0&&(pe+="-"+$);let ye=c.get(pe);if(ye){if(ye.threads){let ut=ye.threads[v];if(ut)ye=ut;else{ye.threads[v]={...Ae};continue}}ye.count||(ye.count=1);let xt=ye.count;for(let ut in Ae){let Ln=Ae[ut];typeof Ln=="number"&&(ye[ut]=(ye[ut]*xt+Ln*z)/(xt+z))}ye.count+=z,de>=0&&(ye.total+=de,ye.ratio=ye.total/ye.count)}else ye={period:t,...H},delete ye.distribution,c.set(pe,ye),ye.byThread&&(ye.threads=[],ye.threads[v]={...Ae},u.push(ye));if(le){le=le.map(ut=>typeof ut=="number"?{value:ut,count:1}:ut);let xt=l.get(pe);xt?xt.push(...le):l.set(pe,le)}}await PB()}for(let E of u){let{path:T,method:N,type:v,metric:H,count:X,total:W,distribution:$,threads:ie,...z}=E;ie=ie.filter(de=>de);for(let de in z){if(typeof E[de]!="number")continue;let le=0;for(let Z of ie){let Ae=Z[de];typeof Ae=="number"&&(le+=Ae)}E[de]=le}E.count=ie.length,delete E.threads,delete E.byThread}for(let[E,T]of l){let N=c.get(E);T.sort((ut,Ln)=>ut.value>Ln.value?1:-1);let v=N.count-1,H=[],X=0,W=0,$;for(let ut of wB){let Ln=v*ut;for(;X<Ln;)$=T[W++],X+=$.count,W===1&&X--;let an=T[W>1?W-2:0];$||($=T[0]),H.push($.value-($.value-an.value)*(X-Ln)/$.count)}let[ie,z,de,le,Z,Ae,pe,ye,xt]=H;Object.assign(N,{p1:ie,p10:z,p25:de,median:le,p75:Z,p90:Ae,p95:pe,p99:ye,p999:xt})}let d;for(let[E,T]of c)T.id=(0,C_.getNextMonotonicTime)(),T.time=f,n.primaryStore.put(T.id,T,{append:!0}).then(N=>{N||n.primaryStore.put(T.id,T)}),d=!0;let _=Date.now(),{idle:h,active:m}=performance.eventLoopUtilization();if(d||m*10>h){let E=(0,C_.getNextMonotonicTime)(),T={id:E,metric:"main-thread-utilization",idle:h-fB,active:m-_B,taskQueueLatency:await s,time:_,...process.memoryUsage()};n.primaryStore.put(E,T,{append:!0}).then(N=>{N||n.primaryStore.put(E,T)})}fB=h,_B=m;let S=process.resourceUsage(),g=CB(w_,S);g.time=_,g.period=w_.time?_-w_.time:t,g.cpuUtilization=IB(w_,g.period),NE(n,"resource-usage",g),w_=g;let R=Xe();uB(n,R),uB(n,{system:R.system}),dB(n,R),dB(n,{system:R.system})}async function hB(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function Pb(){return mB||(mB=ft({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function DB(){return pB||(pB=ft({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function Ute(){LB=!0;let e=(0,P_.get)(B.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await Lte(bB,e),await hB(Pb(),Mte),await hB(DB(),vte)},Math.min(e/2,2147483647)).unref()}function MB(e,t){let r=e.report;r.threadId=t?.threadId||jc.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(EB+=n.mean*n.count);r.totalBytesProcessed=EB,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(gB.get(t))}),gB.set(t,t.performance.eventLoopUtilization())),r.id=(0,C_.getNextMonotonicTime)(),Pb().primaryStore.put(r.id,r),LB||Ute(),xte&&(vB=Hte(r))}async function Hte(e){if(await vB,!Ea){let r=(0,I_.dirname)((0,TB.getLogFilePath)());try{Ea=await(0,Cb.open)((0,I_.join)(r,"analytics.log"),"r+")}catch{Ea=await(0,Cb.open)((0,I_.join)(r,"analytics.log"),"w+")}}let t=(await Ea.stat()).size;if(t>Bte){let r=Buffer.alloc(t);await Ea.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await Ea.write(r,{position:0}),await Ea.truncate(r.length),t=r.length}await Ea.write(JSON.stringify(e)+`
|
|
20
20
|
`,t)}var jc,SB,TB,AB,I_,Cb,C_,P_,RB,Jc,OE,yB,bE,bB,OB,NB,wB,fB,_B,w_,PB,Mte,vte,mB,pB,LB,EB,gB,xte,vB,Ea,Bte,Mi=Re(()=>{jc=require("worker_threads"),SB=M(it());xe();TB=M(ee()),AB=M(Gs()),I_=require("path"),Cb=require("fs/promises"),C_=M(fn()),P_=M(ce());k();Mr();RB=M(require("node:fs")),Jc=(0,AB.loggerWithTag)("analytics");(0,P_.initSync)();OE=new Map,yB=(0,P_.get)(B.ANALYTICS_AGGREGATEPERIOD)>-1;a(wte,"setAnalyticsEnabled");a(Ite,"recordExistingAction");a(Cte,"recordNewAction");a(Dt,"recordAction");Ye.recordAnalytics=Dt;a(jn,"recordActionBinary");bE=0,bB=1e3,OB="analytics-report",NB=[];a(D_,"addAnalyticsListener");wB=[.01,.1,.25,.5,.75,.9,.95,.99,.999,1];a(Pte,"sendAnalytics");a(NE,"storeMetric");a(IB,"calculateCPUUtilization");a(CB,"diffResourceUsage");a(Dte,"storeTableSizeMetrics");a(uB,"storeDBSizeMetrics");a(dB,"storeVolumeMetrics");a(Lte,"aggregation");fB=0,_B=0,w_={},PB=a(()=>new Promise(setImmediate),"rest");a(hB,"cleanup");Mte=36e5,vte=31536e6;a(Pb,"getRawAnalyticsTable");a(DB,"getAnalyticsTable");(0,SB.setChildListenerByType)(OB,MB);a(Ute,"startScheduledTasks");EB=0,gB=new Map,xte=!1;a(MB,"recordAnalytics");Bte=1e6;a(Hte,"logAnalytics")});var UB={};Ue(UB,{Headers:()=>Ao,appendHeader:()=>wE,mergeHeaders:()=>Db});function wE(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 Db(e,t){(typeof e.set!="function"||typeof e.has!="function")&&(e=new Ao(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 Ao,M_=Re(()=>{Ao=class extends Map{static{a(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 o=i[1];if(n)r=(typeof o=="string"?o:o.join(", "))+", "+r;else if(typeof o=="string")r=[o,r];else{o.push(r);return}}return super.set(s,[t,r])}[Symbol.iterator](){return super.values()[Symbol.iterator]()}};a(wE,"appendHeader");a(Db,"mergeHeaders")});function FB(e){let t={openapi:kte,info:{title:"HarperDB HTTP REST interface",version:kB.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:o,primaryKey:c,prototype:l}=n.Resource;if(c=c??"id",!c)continue;let u={},f=[];if(o)for(let{type:T,name:N,elements:v,relationship:H,definition:X}of o){if(H)T==="array"?u[N]={type:"array",items:{$ref:ga+v.type}}:u[N]={$ref:ga+T};else{let W=X??v?.definition;if(W){if(!t.components.schemas[W.type]){let $={};W.properties.forEach(ie=>{$[ie.name]=new Ub(Lb[ie.type],ie.type)}),t.components.schemas[W.type]=new HB($)}T==="array"?u[N]={type:"array",items:{$ref:ga+W.type}}:u[N]={$ref:ga+W.type}}else T==="array"?v.type==="Any"||v.type=="ID"?u[N]={type:"array",items:{format:v.type}}:u[N]={type:"array",items:new Ub(Lb[v.type],v.type)}:T==="Any"||T=="ID"?u[N]={format:T}:u[N]=new Ub(Lb[T],T)}f.push(new xb(N,"query",u[N]))}let d=Object.keys(u),_=new xb(c,"path",{format:"ID"});_.required=!0,_.description="primary key of record";let h=new xb("property","path",{enum:d});h.required=!0,t.components.schemas[i]=new HB(u);let m=l.post!==Resource.prototype.post||l.update,S=typeof l.put=="function",g=typeof l.get=="function",R=typeof l.delete=="function",E="/"+s+"/";m&&(t.paths[E]={},t.paths[E].post=new Fte(i,r,"create a new record auto-assigning a primary key")),g&&(t.paths[E]||(t.paths[E]={}),t.paths[E].get=new Mb(f,r,{200:new vb({$ref:ga+i})},"search for records by the specified property name and value pairs")),R&&(t.paths[E]||(t.paths[E]={}),t.paths[E].delete=new BB(f,r,"delete all the records that match the provided query",{204:new xB})),E="/"+s+"/{"+c+"}",g&&(t.paths[E]={},t.paths[E].get=new Mb([_],r,{200:new vb({$ref:ga+i})},"retrieve a record by its primary key")),S&&(t.paths[E]||(t.paths[E]={}),t.paths[E].put=new Gte([_],r,i,"create or update the record with the URL path that maps to the record's primary key")),R&&(t.paths[E]||(t.paths[E]={}),t.paths[E].delete=new BB([_],r,"delete a record with the given primary key",{204:new xB})),g&&h.schema.enum.length>0&&(E="/"+s+"/{"+c+"}.{property}",t.paths[E]={},t.paths[E].get=new Mb([_,h],r,{200:new vb({enum:d})},"used to retrieve the specified property of the specified record"))}return t}function Fte(e,t,r){this.description=r,this.requestBody={content:{"application/json":{schema:{$ref:ga+e}}}},this.security=t,this.responses={200:{description:Bb,headers:{Location:{description:"primary key of new record",schema:{type:"string",format:"ID"}}},content:{"application/json":{schema:{type:"string",format:"ID"}}}}}}function Mb(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.responses=r}function vb(e){this.description=Bb,this.content={"application/json":{schema:e}}}function xB(){this.description="successfully processed request, no content returned to client"}function Gte(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.requestBody={content:{"application/json":{schema:{$ref:ga+r}}}},this.responses={200:{description:Bb}}}function BB(e,t,r,n){this.description=r,this.parameters=e,this.security=t,this.responses=n}function HB(e){this.type="object",this.properties=e}function Ub(e,t){this.type=e,this.format=t}function xb(e,t,r){this.name=e,this.in=t,this.schema=r}var kB,kte,Lb,ga,Bb,GB=Re(()=>{kB=M(pt()),kte="3.0.3",Lb={Int:"integer",Float:"number",Long:"integer",String:"string",Boolean:"boolean",Date:"string",Bytes:"string",BigInt:"integer",array:"array"},ga="#/components/schemas/",Bb="successful operation";a(FB,"generateJsonApi");a(Fte,"Post");a(Mb,"Get");a(vb,"Response200");a(xB,"Response204");a(Gte,"Put");a(BB,"Delete");a(HB,"ResourceSchema");a(Ub,"Type");a(xb,"Parameter")});var $B={};Ue($B,{Request:()=>v_,createReuseportFd:()=>IE});var qB,v_,Hb,kb,IE,CE=Re(()=>{qB=require("os"),v_=class{static{a(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 kb(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 Hb(this._nodeRequest))}get host(){return this._nodeRequest.authority||this._nodeRequest.headers.host}get isAborted(){return!1}sendEarlyHints(t,r={}){r.link=t,this._nodeResponse.writeEarlyHints(r)}},Hb=class{static{a(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)}},kb=class{constructor(t){this.asObject=t}static{a(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,qB.platform)()!="win32"&&(IE=require("node-unix-socket").createReuseportFd)});var DE={};Ue(DE,{parseHeaderValue:()=>Gb,start:()=>Vte});async function $te(e,t){let r=e.headers.asObject,n=r.accept==="text/event-stream",s=n?"CONNECT":e.method;e.search&&ip(e);let i=new Ao;try{e.responseHeaders=i;let o=e.url.slice(1),c,l;if(o!==VB){let g=PE.getMatch(o,n?"sse":"rest");if(!g)return t(e);e.handlerPath=g.path,c=new Sc(g.relativeURL),c.async=!0,l=g.Resource}if(l?.isCaching){let g=r["cache-control"];if(g){let R=Gb(g);for(let E of R)switch(E.name){case"max-age":e.expiresAt=E.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=Gb(u).map(R=>(R.next?.name==="confirm"&&R.next.value>=0&&(e.replicatedConfirmation=+R.next.value),R.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 d=await Ct(e,()=>{if(r["content-length"]||r["transfer-encoding"])try{e.data=lo(r["content-type"],!0)(e.body,e.headers)}catch(g){throw new Iu.ClientError(g,400)}if(e.authorize=!0,o===VB&&s==="GET"){if(e?.user?.role?.permission?.super_user)return FB(PE);throw new Iu.ServerError("Forbidden",403)}switch(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 Iu.ClientError("HarperDB is short and stout and can't brew coffee",418);default:throw new Iu.ServerError(`Method ${s} is not recognized`,501)}}),_=200,h;if(d==null)_=s==="GET"||s==="HEAD"?404:204,Fb.lastModified&&e.lastModified&&i.setIfNone("Last-Modified",new Date(e.lastModified).toUTCString());else if(d.status>0&&d.headers){let g=Db(d.headers,i);return d.headers!==g&&(d.headers=g),d.data!==void 0&&(d.body=Hf(d.data,e,d)),d}else if(h=e.lastModified){qte[0]=h;let g=String.fromCharCode(34,(Br[0]&63)+62,(Br[0]>>6)+(Br[1]<<2&63)+62,(Br[1]>>4)+(Br[2]<<4&63)+62,(Br[2]>>2)+62,(Br[3]&63)+62,(Br[3]>>6)+(Br[4]<<2&63)+62,(Br[4]>>4)+(Br[5]<<4&63)+62,(Br[5]>>2)+62,(Br[6]&63)+62,(Br[6]>>6)+(Br[7]<<2&63)+62,34),R=r["if-none-match"];R&&g==R?(d?.onDone&&d.onDone(),_=304,d=void 0):i.setIfNone("ETag",g),Fb.lastModified&&i.setIfNone("Last-Modified",new Date(h).toUTCString())}e.createdResource&&(_=201),e.newLocation&&i.setIfNone("Location",e.newLocation);let m={status:_,headers:i,body:void 0},S=d?.wasLoadedFromSource?.();return S!==void 0&&(m.wasCacheMiss=S,!S&&h&&i.setIfNone("Age",Math.round((Date.now()-(e.lastRefreshed||h))/1e3))),d!==void 0&&(m.body=Hf(d,e,m),s==="HEAD"&&(m.body=void 0)),m}catch(o){o.statusCode?o.statusCode===500?vi.warn(o):vi.info(o):vi.error(o),o.statusCode===405&&(o.method&&(o.message+=` to handle HTTP method ${o.method.toUpperCase()||""}`),o.allow&&(o.allow.push("trace","head","options"),i.setIfNone("Allow",o.allow.map(l=>l.toUpperCase()).join(", "))));let c={status:o.statusCode||500,headers:i,body:void 0};return c.body=Hf(o.contentType?o:o.toString(),e,c),c}}function Vte(e){Fb=e,e.includeExpensiveRecordCountEstimates&&(v_.prototype.includeExpensiveRecordCountEstimates=!0),!KB&&(KB=!0,PE=e.resources,e.server.http(async(t,r)=>{if(!t.isWebSocket)return $te(t,r)},e),e.webSocket!==!1&&e.server.ws(async(t,r,n)=>{U_++;let s=new Hn;YB||(YB=!0,D_(l=>{U_>0&&l.push({metric:"ws-connections",connections:U_,byThread:!0})}));let i;t.on("error",l=>{i=!0,vi.warn(l)});let o;t.on("message",a(function(u){o||(o=lo(r.requestedContentType??r.headers.asObject["content-type"],!1));let f=o(u);Dt(u.length,"bytes-received",r.handlerPath,"message","ws"),s.push(f)},"message"));let c;t.on("close",()=>{U_--,jn(!i,"connection","ws","disconnect"),s.emit("close"),c&&c.return()});try{await n;let l=r.url.slice(1),u=PE.getMatch(l,"ws");if(jn(!!u,"connection","ws","connect"),u){r.handlerPath=u.path,Dt(m=>({count:m.count,total:U_}),"connections",r.handlerPath,"connect","ws"),r.authorize=!0;let f=new Sc(u.relativeURL),d=u.Resource;c=(await Ct(r,()=>d.connect(f,s,r)))[Symbol.asyncIterator]();let h;for(;!(h=await c.next()).done;){let m=await ua(h.value,r);t.send(m),Dt(m.length,"bytes-sent",r.handlerPath,"message","ws"),t._socket.writableNeedDrain&&await new Promise(S=>t._socket.once("drain",S))}}else return t.close(1011,`No resource was found to handle ${r.pathname}`)}catch(l){l.statusCode?l.statusCode===500?vi.warn(l):vi.info(l):vi.error(l),t.close(Kte[l.statusCode]||1011,l.toString())}t.close()},e))}function Gb(e){return e.trim().split(",").map(t=>{let r,n=t.trim().split(";"),s;for(;s=n.pop();)if(s.includes("=")){let[i,o]=s.trim().split("=");i=i.trim(),o&&(o=o.trim()),r={name:i.toLowerCase(),value:o,next:r}}else r={name:s.toLowerCase(),next:r};return r})}var vi,Iu,Br,qte,Fb,VB,KB,PE,YB,U_,Kte,WB=Re(()=>{oo();Mi();vi=M(ee()),Iu=M(me());Cf();jl();gc();M_();GB();Cf();CE();Br=new Uint8Array(8),qte=new Float64Array(Br.buffer,0,1),Fb={},VB="openapi";a($te,"http");U_=0;a(Vte,"start");Kte={401:3e3,403:3003};a(Gb,"parseHeaderValue")});var qb=C((Mwe,QB)=>{var{recordAction:LE,recordActionBinary:zB}=(Mi(),P(L_)),Yte=require("fastify-plugin"),Wte=200;QB.exports=Yte(function(e,t,r){e.addHook("onResponse",async(n,s)=>{let i=s.elapsedTime}),e.addHook("onSend",async(n,s,i)=>{let o=s.elapsedTime,c=performance.now(),l=s.request.routeOptions,u,f,d;l.config?.isOperation?(u=n.body?.operation,f="operation"):(u=l.url,f="fastify-route",d=l.method),LE(o,"duration",u,d,f),zB(s.raw.statusCode<400,"success",u,d,f),zB(1,"response_"+s.raw.statusCode,u,d,f);let _=Wte;i?.pipe?(i.on("data",g=>{_+=g.length}),i.on("end",()=>{LE(performance.now()-c,"transfer",u,d,f),LE(_,"bytes-sent",u,d,f)})):(_+=i?.length||0,LE(_,"bytes-sent",u,d,f));let h=o.toFixed(3),m=s.getHeader("Server-Timing"),S=`db;dur=${h}`;s.header("Server-Timing",m?`${m}, ${S}`:S)}),r()},{name:"hdb-request-time"})});var JB=C((vwe,jB)=>{var zte=st(),Qte={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};jB.exports=function(e){return zte.validateObject(e,Qte)}});var ME=C((Uwe,XB)=>{"use strict";var jte=(k(),P(q)).OPERATIONS_ENUM,$b=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=jte.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};XB.exports=$b});var H_={};Ue(H_,{createTokens:()=>Xte,getJWTRSAKeys:()=>HE,refreshOperationToken:()=>Zte,validateOperationToken:()=>Yb,validateRefreshToken:()=>kE});async function HE(){if(vE)return vE;try{let e=x_.default.join(B_.default.getHdbBasePath(),lA),t=await UE.default.readFile(x_.default.join(e,lf.JWT_PASSPHRASE_NAME),"utf8"),r=await UE.default.readFile(x_.default.join(e,lf.JWT_PRIVATE_KEY_NAME),"utf8");return vE={publicKey:await UE.default.readFile(x_.default.join(e,lf.JWT_PUBLIC_KEY_NAME),"utf8"),privateKey:r,passphrase:t},vE}catch(e){throw BE.default.error(e),new Qs.ClientError(Pu.NO_ENCRYPTION_KEYS,Cu.INTERNAL_SERVER_ERROR)}}async function Xte(e){let t=(0,Vb.validateBySchema)(e,Ui.default.object({username:Ui.default.string().optional(),password:Ui.default.string().optional(),role:Ui.default.string().optional(),expires_in:Ui.default.alternatives(Ui.default.string(),Ui.default.number()).optional()}));if(t)throw new Qs.ClientError(t.message);let r;try{let d=e.bypass_auth!==!0;!e.username&&!e.password&&(e.username=e.hdb_user?.username,d=!1),r=await(0,Kb.findAndValidateUser)(e.username,e.password,d)}catch(d){throw BE.default.error(d),new Qs.ClientError(Pu.INVALID_CREDENTIALS,Cu.UNAUTHORIZED)}if(!r)throw new Qs.ClientError(Pu.INVALID_CREDENTIALS,Cu.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 o=await HE(),c=await Du.default.sign(i,{key:o.privateKey,passphrase:o.passphrase},{expiresIn:e.expires_in??nH,algorithm:xE,subject:"operation"}),l=await Du.default.sign(i,{key:o.privateKey,passphrase:o.passphrase},{expiresIn:Jte,algorithm:xE,subject:"refresh"}),u=dy(l,"sha256");if((await(0,ZB.update)(new eH.default(cf,Kl.USER_TABLE_NAME,[{username:e.username,refresh_token:u}]))).skipped_hashes.length>0)throw new Qs.ClientError(Pu.REFRESH_TOKEN_SAVE_FAILED,Cu.INTERNAL_SERVER_ERROR);return tH.default.signalUserChange(new rH.UserEventMsg(process.pid)),{operation_token:c,refresh_token:l}}async function Zte(e){let t=(0,Vb.validateBySchema)(e,Ui.default.object({refresh_token:Ui.default.string().required()}).required());if(t)throw new Qs.ClientError(t.message);let{refresh_token:r}=e;await kE(r);let n=await HE(),s=await Du.default.decode(r);return{operation_token:await Du.default.sign({username:s.username,super_user:s.super_user,cluster_user:s.cluster_user},{key:n.privateKey,passphrase:n.passphrase},{expiresIn:nH,algorithm:xE,subject:"operation"})}}async function Yb(e){return sH(e,"operation")}async function kE(e){return sH(e,"refresh")}async function sH(e,t){try{let r=await HE(),n=await Du.default.verify(e,r.publicKey,{algorithms:xE,subject:t});if(n.role)throw new Error("Invalid token");let s=await(0,Kb.findAndValidateUser)(n.username,void 0,!1);if(t==="refresh"&&!fy(s.refresh_token,e))throw new Error("Invalid token");return s}catch(r){throw BE.default.warn(r),r?.name==="TokenExpiredError"?new Qs.ClientError(Pu.TOKEN_EXPIRED,Cu.FORBIDDEN):new Qs.ClientError(Pu.INVALID_TOKEN,Cu.UNAUTHORIZED)}}var Du,UE,x_,Ui,Vb,Qs,BE,Kb,ZB,eH,tH,rH,B_,Cu,Pu,nH,Jte,xE,vE,Lu=Re(()=>{Du=M(require("jsonwebtoken")),UE=M(require("fs-extra")),x_=M(require("node:path")),Ui=M(require("joi")),Vb=M(st());k();Qs=M(me()),BE=M(ee());Wp();Kb=M(Kn()),ZB=M(An()),eH=M(ME()),tH=M(go()),rH=M(Ys()),B_=M(ce()),{HTTP_STATUS_CODES:Cu,AUTHENTICATION_ERROR_MSGS:Pu}=Qs.hdb_errors;B_.default.initSync();nH=B_.default.get(B.AUTHENTICATION_OPERATIONTOKENTIMEOUT)||"1d",Jte=B_.default.get(B.AUTHENTICATION_REFRESHTOKENTIMEOUT)||"30d",xE="RS256";a(HE,"getJWTRSAKeys");a(Xte,"createTokens");a(Zte,"refreshOperationToken");a(Yb,"validateOperationToken");a(kE,"validateRefreshToken");a(sH,"validateToken")});var Wb=C((Fwe,aH)=>{"use strict";var ere=JB(),Mu=require("passport"),tre=require("passport-local").Strategy,rre=require("passport-http").BasicStrategy,nre=require("util"),sre=Kn(),oH=nre.callbackify(sre.findAndValidateUser),kwe=Un(),ire=(k(),P(q)),iH=(Lu(),P(H_));Mu.use(new tre(function(e,t,r){oH(e,t,r)}));Mu.use(new rre(function(e,t,r){oH(e,t,r)}));Mu.serializeUser(function(e,t){t(null,e)});Mu.deserializeUser(function(e,t){t(null,e)});function ore(e,t,r){if(e.raw?.user!==void 0)return r(null,e.raw.user);let n,s;if(e.headers?.authorization){let o=e.headers.authorization.split(" ");n=o[0],s=o[1]}function i(o,c){return o?r(o):c?r(null,c):r("Must login")}switch(a(i,"handleResponse"),n){case"Basic":Mu.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===ire.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?iH.validateRefreshToken(s).then(o=>{e.body.refresh_token=s,r(null,o)}).catch(o=>{r(o)}):iH.validateOperationToken(s).then(o=>{r(null,o)}).catch(o=>{r(o)});break;default:Mu.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(ore,"authorize");function are(e,t){let r=ere(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 o=i[e.schema].tables[e.table].attribute_permissions;for(let c in o)e.attributes.indexOf(o[c].attribute_name)>-1&&!o[c][e.operation]&&(n.authorized=!1,n.messages.push(`Not authorized to ${e.operation} ${o[c].attribute_name} `))}return t(null,n)}a(are,"checkPermissions");aH.exports={authorize:ore,checkPermissions:are}});var FE=C((qwe,cH)=>{"use strict";var cre=Vn();cH.exports={writeTransaction:lre};function lre(e,t,r){return cre.writeTransaction(e,t,r)}a(lre,"writeTransaction")});var fH=C((Kwe,dH)=>{"use strict";var ure=Wr(),dre=ps(),lH=ee(),fre=An(),Vwe=FE(),_re=require("clone"),Qb=require("alasql"),hre=kp(),uH=require("util"),mre=uH.promisify(dre.getTableSchema),pre=uH.promisify(ure.search),Ere=(k(),P(q)),zb=oe();hre(Qb);dH.exports={update:Sre};var gre="There was a problem performing this update. Please check the logs and try again.";async function Sre({statement:e,hdb_user:t}){let r=await mre(e.table.databaseid,e.table.tableid),n=Tre(e.columns);zb.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=_re(s),c=zb.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,u=Qb.parse(l).statements[0],f=await pre(u),d=Are(n,f);return Rre(o,d,t)}a(Sre,"update");function Tre(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=Qb.compile(`SELECT ${r.expression.toString()} AS [${Ere.FUNC_VAL}] FROM ?`)}),t}catch(t){throw lH.error(t),new Error(gre)}}a(Tre,"createUpdateRecord");function Are(e,t){return zb.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(Are,"buildUpdateRecords");async function Rre(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await fre.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){lH.error(`Error delete new_attributes from update response: ${i}`)}return s}a(Rre,"updateRecords")});var hH=C((Qwe,_H)=>{var yre=require("alasql"),bre=Wr(),Ore=ee(),Nre=Vn(),Jb=require("util"),jb=oe(),wre=(k(),P(q)),Ire=ps(),Wwe=FE(),zwe=An(),Cre="record",Pre="successfully deleted",Dre=Jb.callbackify(Ure),Lre=Jb.promisify(bre.search),Mre=Jb.promisify(Ire.getTableSchema);_H.exports={convertDelete:Dre};function vre(e){return`${e.deleted_hashes.length} ${Cre}${e.deleted_hashes.length===1?"":"s"} ${Pre}`}a(vre,"generateReturnMessage");async function Ure({statement:e,hdb_user:t}){let r=await Mre(e.table.databaseid,e.table.tableid);jb.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=jb.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=yre.parse(o).statements[0],l={operation:wre.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await Lre(c);let u=await Nre.deleteRecords(l);return jb.isEmptyOrZeroLength(u.message)&&(u.message=vre(u)),delete u.txn_time,u}catch(u){throw Ore.error(u),u.hdb_code?u.message:u}}a(Ure,"convertDelete")});var SH=C((Jwe,gH)=>{"use strict";var xre=po(),{hdb_errors:mH}=me(),{getDatabases:pH}=(xe(),P(at));gH.exports={checkSchemaExists:EH,checkSchemaTableExists:Bre,schema_describe:xre};async function EH(e){if(!pH()[e])return mH.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(EH,"checkSchemaExists");async function Bre(e,t){let r=await EH(e);if(r)return r;if(!pH()[e][t])return mH.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(Bre,"checkSchemaTableExists")});var rO=C((rIe,DH)=>{"use strict";var{decode:Hre}=require("msgpackr"),{isMainThread:Zwe,parentPort:eIe,threadId:tIe}=require("worker_threads"),$E=Er(),vu=Pt(),eO=(k(),P(q)),jr=ee(),Zb=ce(),kre=(k(),P(q)),{onMessageByType:Fre}=it(),yH=mo(),{recordAction:TH,recordActionBinary:Gre}=(Mi(),P(L_)),{publishToStream:qre}=$E,{ConsumerEvents:AH}=require("nats"),$re=Wr(),{promisify:Vre}=require("util"),{decodeBlobsWithWrites:Kre}=(gn(),P(au)),bH=Vre(setTimeout),VE=1e4,KE,qE,Yre,Wre,OH,k_=new Map,Uu=new Map;DH.exports={initialize:NH,ingestConsumer:tO,setSubscription:zre,setIgnoreOrigin:Jre,getDatabaseSubscriptions:jre,updateConsumer:wH};async function NH(){Fre(eO.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,async n=>{await wH(n)}),OH=!0,jr.notify("Initializing clustering ingest service.");let{connection:e,jsm:t,js:r}=await $E.getNATSReferences();KE=e,qE=e.info.server_name,Yre=t,Wre=r}a(NH,"initialize");async function wH(e){if(e.status==="start"){let{js:t,jsm:r}=await IH(e.node_domain_name);tO(e.stream_name,t,r,e.node_domain_name)}else if(e.status==="stop"){let t=k_.get(e.stream_name+e.node_domain_name);t&&(jr.notify("Closing ingest consumer for node:",e.node_domain_name,"stream:",e.stream_name),await t.close?.(),k_.set(e.stream_name+e.node_domain_name,"close")),Uu.get(e.node_domain_name)==="failed"&&Uu.set(e.node_domain_name,"close")}}a(wH,"updateConsumer");var YE=new Map;function zre(e,t,r){let n=YE.get(e);n||YE.set(e,n=new Map),n.set(t,r),OH||NH().then(Qre)}a(zre,"setSubscription");async function Qre(){let e=await $re.searchByValue({database:"system",table:"hdb_nodes",search_attribute:"name",search_value:"*"});for await(let t of e){let r=t.name+vu.SERVER_SUFFIX.LEAF,n,s;for(let i of t.subscriptions||[])if(i.subscribe===!0){if(!n&&({js:n,jsm:s}=await IH(r),!n))break;let{schema:o,table:c}=i,l=yH.createNatsTableStreamName(o,c);tO(l,n,s,r)}}}a(Qre,"accessConsumers");async function IH(e){let t,r,n=1;for(;!r;)try{t=await KE.jetstream({domain:e}),r=await KE.jetstreamManager({domain:e,checkAPI:!1})}catch(s){if(Uu.get(e)==="close")break;Uu.set(e,"failed"),n%10===1&&jr.warn("Nats ingest attempting to connect to:",e,"Nats error:",s.message);let i=n++*100<VE?n++*100:VE;await bH(i)}return{js:t,jsm:r}}a(IH,"connectToRemoteJS");function jre(){return YE}a(jre,"getDatabaseSubscriptions");var CH;function Jre(e){CH=e}a(Jre,"setIgnoreOrigin");var PH=100,RH=new Array(PH),GE=0;async function tO(e,t,r,n){let{connection:s}=await $E.getNATSReferences();KE=s,qE=s.info.server_name;let i,o=1;for(;!i;)try{i=await t.consumers.get(e,qE),jr.notify("Initializing ingest consumer for node:",n,"stream:",e)}catch(u){if(Uu.get(n)==="close")break;o%10===1&&jr.warn("Nats ingest error getting consumer:",n,"stream:",e,"Nats error:",u.message),u.code==="404"&&(jr.notify("Nats ingest creating consumer for node:",n,"stream:",e),i=await $E.createConsumer(r,e,qE,new Date(Date.now()).toISOString()));let f=o++*100<VE?o++*100:VE;await bH(f)}let c=!1,l;for(;!c;){if(k_.get(e+n)==="close"||Uu.get(n)==="close"){k_.delete(e+n),c=!0;continue}l=await i.consume({max_messages:Zb.get(eO.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS)??100,bind:!0}),k_.set(e+n,l);let u=!1;(async()=>{for await(let f of await l.status())if(f.type===AH.ConsumerDeleted&&(await l.close(),c=!0),f.type===AH.HeartbeatsMissed){let d=f.data;jr.trace(`${d} clustering ingest consumer heartbeats missed, node: ${n} stream: ${l.consumer.stream}`),d===100&&(jr.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 f of l)await RH[GE],RH[GE]=Xre(f).catch(d=>{jr.error(d)}),++GE>=PH&&(GE=0)}catch(f){f.message==="consumer deleted"?(jr.notify("Nats consumer deleted, closing messages for node:",n,"stream:",l.consumer.stream),await l.close(),c=!0):jr.error("Error consuming clustering ingest, restarting consumer",f)}}}a(tO,"ingestConsumer");async function Xre(e){let t;await Kre(()=>{t=Hre(e.data)}),TH(e.data.length,"bytes-received",e.subject,t.operation,"ingest"),jr.trace("Nats message processor message size:",e?.msg?._msg?.size,"bytes");let r=e.headers,n=!1,s=Zb.get(eO.CONFIG_PARAMS.CLUSTERING_NODENAME);r.has(vu.MSG_HEADERS.TRANSACTED_NODES)&&r.values(vu.MSG_HEADERS.TRANSACTED_NODES).indexOf(s)>-1&&(n=!0);let i=r.get(vu.MSG_HEADERS.ORIGIN);if(n||(n=i===s&&!CH),Gre(n,"echo",e.subject,t.operation,"ingest"),n){e.ack();return}r.append(vu.MSG_HEADERS.TRANSACTED_NODES,s);try{let{operation:o,schema:c,next:l,table:u,records:f,hash_values:d,__origin:_,expiresAt:h}=t;jr.trace("processing message:",o,c,u,(f?"records: "+f.map(v=>v?.id):"")+(d?"ids: "+d:""),"with sequence:",e.seq),jr.trace(`messageProcessor nats msg id: ${e.headers.get(vu.MSG_HEADERS.NATS_MSG_ID)}`);let m;f||(f=d);let S=new Promise(v=>m=v),{timestamp:g,user:R,node_name:E}=_||{},T=YE.get(c)?.get(u);if(!T)throw new Error(`Missing table for replication message: ${u}`);if(o==="define_schema")t.type=o,t.onCommit=m,T.send(t);else if(f.length===1&&!l)T.send({type:Xb(o),value:f[0],id:d?.[0],expiresAt:h,timestamp:g,table:u,onCommit:m,user:R,nodeName:E});else{let v=f.map((H,X)=>({type:Xb(o),value:H,expiresAt:h,id:d?.[X],table:u}));for(;l;)v.push({type:Xb(l.operation),value:l.record,expiresAt:l.expiresAt,id:l.id,table:l.table}),l=l.next;T.send({type:"transaction",writes:v,table:u,timestamp:g,onCommit:m,user:R,nodeName:E})}Zb.get(kre.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&qre(e.subject.split(".").slice(0,-1).join("."),yH.createNatsTableStreamName(c,u),e.headers,e.data),await S;let N=Date.now()-g;g&&TH(N,"replication-latency",e.subject,o,"ingest")}catch(o){jr.error(o)}e.ack()}a(Xre,"messageProcessor");function Xb(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}a(Xb,"convertOperation")});var Er=C((lIe,zH)=>{"use strict";var wr=ce();wr.initSync();var Zre=require("fs-extra"),ene=require("semver"),q_=require("path"),{monotonicFactory:tne}=require("ulidx"),MH=tne(),rne=require("util"),vH=require("child_process"),nne=rne.promisify(vH.exec),sne=vH.spawn,Hr=Pt(),Qe=(k(),P(q)),{packageJson:ine,PACKAGE_ROOT:one}=pt(),WE=oe(),js=ee(),zE=mo(),ane=FE(),F_=It(),{broadcast:cne,onMessageByType:lne,getWorkerIndex:une}=it(),{isMainThread:UH}=require("worker_threads"),{Encoder:dne,decode:oO}=require("msgpackr"),xH=new dne,{isEmpty:tl}=WE,BH=Kn(),sIe=48*36e11;UH&&lne(Qe.ITC_EVENT_TYPES.RESTART,()=>{Jr=void 0,el=void 0});var{connect:fne,StorageType:_ne,RetentionPolicy:hne,AckPolicy:aO,DeliverPolicy:cO,DiscardPolicy:mne,NatsConnection:iIe,JetStreamManager:oIe,JetStreamClient:aIe,StringCodec:cIe,JSONCodec:pne,createInbox:lO,headers:Ene,ErrorCode:LH}=require("nats"),{recordAction:gne}=(Mi(),P(L_)),{encodeBlobsAsBuffers:Sne}=(gn(),P(au)),HH=pne(),Tne="clustering",Ane=ine.engines[Hr.NATS_SERVER_NAME],Rne=q_.join(one,"dependencies"),iO=q_.join(Rne,`${process.platform}-${process.arch}`,Hr.NATS_BINARY_NAME),nO,sO,G_,Xc,Zc;zH.exports={runCommand:kH,checkNATSServerInstalled:yne,createConnection:uO,getConnection:$_,getJetStreamManager:V_,getJetStream:GH,getNATSReferences:xi,getServerList:One,createLocalStream:dO,listStreams:qH,deleteLocalStream:Nne,getServerConfig:xu,listRemoteStreams:wne,viewStream:Ine,viewStreamIterator:Cne,publishToStream:Pne,request:Mne,reloadNATS:fO,reloadNATSHub:vne,reloadNATSLeaf:Une,extractServerName:Lne,requestErrorHandler:xne,createLocalTableStream:YH,createTableStreams:kne,purgeTableStream:WH,purgeSchemaTableStreams:Fne,getStreamInfo:Gne,updateLocalStreams:$ne,closeConnection:bne,getJsmServerName:QE,addNatsMsgHeader:$H,clearClientCache:FH,updateRemoteConsumer:Bne,createConsumer:VH,updateConsumerIterator:Hne};async function kH(e,t=void 0){let{stdout:r,stderr:n}=await nne(e,{cwd:t});if(n)throw new Error(n.replace(`
|
|
21
21
|
`,""));return r.replace(`
|
|
22
22
|
`,"")}a(kH,"runCommand");async function yne(){try{await Zre.access(iO)}catch{return!1}let e=await kH(`${iO} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return ene.eq(t,Ane)}a(yne,"checkNATSServerInstalled");async function uO(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let o=await BH.getClusterUser();if(tl(o))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=o.username,r=o.decrypt_hash}js.trace("create nats connection called");let i=await fne({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:wr.get(Qe.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:wr.get(Qe.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:wr.get(Qe.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),js.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(o=>{o&&js.error("Error with Nats client connection, connection closed",o),i===Jr&&FH()}),i}a(uO,"createConnection");function FH(){Jr=void 0,Xc=void 0,Zc=void 0,el=void 0}a(FH,"clearClientCache");async function bne(){Jr&&(await Jr.drain(),Jr=void 0,Xc=void 0,Zc=void 0,el=void 0)}a(bne,"closeConnection");var Jr,el;async function $_(){return el||(el=uO(wr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),Jr=await el),Jr||el}a($_,"getConnection");async function V_(){if(Xc)return Xc;tl(Jr)&&await $_();let{domain:e}=xu(Qe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(tl(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return Xc=await Jr.jetstreamManager({domain:e,timeout:6e4}),Xc}a(V_,"getJetStreamManager");async function GH(){if(Zc)return Zc;tl(Jr)&&await $_();let{domain:e}=xu(Qe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(tl(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return Zc=Jr.jetstream({domain:e,timeout:6e4}),Zc}a(GH,"getJetStream");async function xi(){let e=Jr||await $_(),t=Xc||await V_(),r=Zc||await GH();return{connection:e,jsm:t,js:r}}a(xi,"getNATSReferences");async function One(e){let t=wr.get(Qe.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await BH.getClusterUser(),s=await uO(t,r,n),i=lO(),o=s.subscribe(i),c=[],l,u=(async()=>{for await(let f of o){let d=HH.decode(f.data);d.response_time=Date.now()-l,c.push(d)}})();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 WE.async_set_timeout(e),await o.drain(),await s.close(),await u,c}a(One,"getServerList");async function dO(e,t){let{jsm:r}=await xi(),n=wr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=wr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=wr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:_ne.File,retention:hne.Limits,subjects:t,discard:mne.Old,max_msgs:s,max_bytes:i,max_age:n})}a(dO,"createLocalStream");async function qH(){let{jsm:e}=await xi(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}a(qH,"listStreams");async function Nne(e){let{jsm:t}=await xi();await t.streams.delete(e)}a(Nne,"deleteLocalStream");async function wne(e){let{connection:t}=await xi(),r=[],n=lO(),s=t.subscribe(n),i=(async()=>{for await(let o of s)r.push(HH.decode(o.data))})();return await t.publish(`$JS.${e}.API.STREAM.LIST`,void 0,{reply:n}),await t.flush(),await s.drain(),await i,r}a(wne,"listRemoteStreams");async function Ine(e,t=void 0,r=void 0){let{jsm:n,js:s}=await xi(),i=MH(),o={durable_name:i,ack_policy:aO.Explicit};t&&(o.deliver_policy=cO.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);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 f of l){let d=oO(f.data),_={nats_timestamp:f.info.timestampNanos,nats_sequence:f.info.streamSequence,entry:d};if(f.headers&&(_.origin=f.headers.get(Hr.MSG_HEADERS.ORIGIN)),u.push(_),f.ack(),f.info.pending===0)break}return await c.delete(),u}a(Ine,"viewStream");async function*Cne(e,t=void 0,r=void 0){let{jsm:n,js:s}=await xi(),i=MH(),o={durable_name:i,ack_policy:aO.Explicit};t&&(o.deliver_policy=cO.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);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 f=oO(u.data);f[0]||(f=[f]);for(let d of f){let _={nats_timestamp:u.info.timestampNanos,nats_sequence:u.info.streamSequence,entry:d};u.headers&&(_.origin=u.headers.get(Hr.MSG_HEADERS.ORIGIN)),yield _}if(u.ack(),u.info.pending===0)break}await c.delete()}a(Cne,"viewStreamIterator");async function Pne(e,t,r,n){js.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=$H(n,r);let{js:s}=await xi(),i=await QE(),o=`${e}.${i}`,c=await Sne(()=>n instanceof Uint8Array?n:xH.encode(n));try{js.trace(`publishToStream publishing to subject: ${o}`),gne(c.length,"bytes-sent",e,n.operation,"replication"),await s.publish(o,c,{headers:r})}catch(l){if(l.code&&l.code.toString()==="503")return KH(async()=>{try{await s.publish(o,c,{headers:r})}catch{if(l.code&&l.code.toString()==="503"){js.trace(`publishToStream creating stream: ${t}`);let f=o.split(".");f[2]="*",await dO(t,[o]),await s.publish(o,c,{headers:r})}else throw l}});throw l}}a(Pne,"publishToStream");function $H(e,t){t===void 0&&(t=Ene());let r=wr.get(Qe.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(Hr.MSG_HEADERS.ORIGIN)&&r&&t.append(Hr.MSG_HEADERS.ORIGIN,r),t}a($H,"addNatsMsgHeader");function xu(e){e=e.toLowerCase();let t=q_.join(wr.get(Qe.CONFIG_PARAMS.ROOTPATH),Tne);if(e===Qe.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return tl(sO)&&(sO={port:F_.getConfigFromFile(Qe.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:F_.getConfigFromFile(Qe.CONFIG_PARAMS.CLUSTERING_NODENAME)+Hr.SERVER_SUFFIX.HUB,config_file:Hr.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:q_.join(t,Hr.PID_FILES.HUB),hdb_nats_path:t}),sO;if(e===Qe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return tl(nO)&&(nO={port:F_.getConfigFromFile(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:F_.getConfigFromFile(Qe.CONFIG_PARAMS.CLUSTERING_NODENAME)+Hr.SERVER_SUFFIX.LEAF,config_file:Hr.NATS_CONFIG_FILES.LEAF_SERVER,domain:F_.getConfigFromFile(Qe.CONFIG_PARAMS.CLUSTERING_NODENAME)+Hr.SERVER_SUFFIX.LEAF,pid_file_path:q_.join(t,Hr.PID_FILES.LEAF),hdb_nats_path:t}),nO;js.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(xu,"getServerConfig");async function VH(e,t,r,n){try{await e.consumers.add(t,{ack_policy:aO.Explicit,durable_name:r,deliver_policy:cO.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}a(VH,"createConsumer");async function Dne(e,t,r){await e.consumers.delete(t,r)}a(Dne,"removeConsumer");function Lne(e){return e.split(".")[1]}a(Lne,"extractServerName");async function Mne(e,t,r=6e4,n=lO()){if(!WE.isObject(t))throw new Error("data param must be an object");let s=xH.encode(t),{connection:i}=await xi(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return oO(c.data)}a(Mne,"request");function fO(e){return new Promise(async(t,r)=>{let n=sne(iO,["--signal",`reload=${e}`],{cwd:__dirname}),s,i;n.on("error",o=>{r(o)}),n.stdout.on("data",o=>{i+=o.toString()}),n.stderr.on("data",o=>{s+=o.toString()}),n.stderr.on("close",o=>{s&&r(s),t(i)})})}a(fO,"reloadNATS");async function vne(){let{pid_file_path:e}=xu(Qe.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await fO(e)}a(vne,"reloadNATSHub");async function Une(){let{pid_file_path:e}=xu(Qe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await fO(e)}a(Une,"reloadNATSLeaf");function xne(e,t,r){let n;switch(e.code){case LH.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case LH.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}a(xne,"requestErrorHandler");async function Bne(e,t){let r=t+Hr.SERVER_SUFFIX.LEAF,{connection:n}=await xi(),{jsm:s}=await Kne(r),{schema:i,table:o}=e,c=zE.createNatsTableStreamName(i,o),l=e.start_time?e.start_time:new Date(Date.now()).toISOString();await KH(async()=>{if(e.subscribe===!0)await VH(s,c,n.info.server_name,l);else try{await Dne(s,c,n.info.server_name)}catch(u){js.trace(u)}})}a(Bne,"updateRemoteConsumer");async function Hne(e,t,r,n){let s=zE.createNatsTableStreamName(e,t),i=r+Hr.SERVER_SUFFIX.LEAF,o={type:Qe.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!UH&&une()<wr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=rO();await c(o)}await cne(o),n==="stop"&&await WE.async_set_timeout(1e3)}a(Hne,"updateConsumerIterator");function KH(e){return ane.writeTransaction(Qe.SYSTEM_SCHEMA_NAME,Qe.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(KH,"exclusiveLock");async function YH(e,t){let r=zE.createNatsTableStreamName(e,t),n=await QE(),s=qne(e,t,n);await dO(r,[s])}a(YH,"createLocalTableStream");async function kne(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await YH(n,s)}}a(kne,"createTableStreams");async function WH(e,t,r=void 0){if(wr.get(Qe.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=zE.createNatsTableStreamName(e,t),{domain:s}=xu(Qe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await $_()).jetstreamManager({domain:s,timeout:24e4})).streams.purge(n,r)}catch(n){if(n.message==="stream not found")js.warn(n);else throw n}}a(WH,"purgeTableStream");async function Fne(e,t){if(wr.get(Qe.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await WH(e,t[r])}a(Fne,"purgeSchemaTableStreams");async function Gne(e){return(await V_()).streams.info(e)}a(Gne,"getStreamInfo");function qne(e,t,r){return`${Hr.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}a(qne,"createSubjectName");async function QE(){if(G_)return G_;if(G_=(await V_())?.nc?.info?.server_name,G_===void 0)throw new Error("Unable to get jetstream manager server name");return G_}a(QE,"getJsmServerName");async function $ne(){let e=await V_(),t=await QE(),r=await qH();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let o=Vne(n),c=i.split(".");if(c[c.length-1]===t&&!o||s.name==="__HARPERDB_WORK_QUEUE__")continue;let u=i.split(".");u[u.length-1]=t;let f=u.join(".");js.trace(`Updating stream subject name from: ${i} to: ${f}`),s.subjects[0]=f,await e.streams.update(s.name,s)}}a($ne,"updateLocalStreams");function Vne(e){let{config:t}=e,r=!1,n=wr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=wr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=wr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);return i=i===null?-1:i,n!==t.max_age&&(t.max_age=n,r=!0),s!==t.max_bytes&&(t.max_bytes=s,r=!0),i!==t.max_msgs&&(t.max_msgs=i,r=!0),r}a(Vne,"updateStreamLimits");async function Kne(e){let t,r;try{t=await Jr.jetstream({domain:e}),r=await Jr.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw js.error("Unable to connect to:",e),n}return{js:t,jsm:r}}a(Kne,"connectToRemoteJS")});function _O(e){let t=e.get(jE),r=t?(0,Bu.unpack)(t):null;r||(r={remoteNameToId:{}});let n=et(),s=!1;r.nodeName=et();let i=r.remoteNameToId;if(i[n]!==0){let o=0,c;for(let l in i){let u=i[l];u===0?c=l:u>o&&(o=u)}if(c){o++,i[c]=o;let l=[Symbol.for("seq"),o];e.rootStore.dbisDb.transactionSync(()=>{e.rootStore.dbisDb.get(l)||e.rootStore.dbisDb.putSync(l,{seqId:Y_(e)??1,nodes:[]})})}i[n]=0,e.putSync(jE,(0,Bu.pack)(r))}return r}function K_(e){return _O(e).remoteNameToId}function jH(e,t){let r=_O(t),n=r.remoteNameToId,s=new Map,i=!1;for(let o in e){let c=e[o],l=n[o];if(l==null){let u=0;for(let f in n){let d=n[f];d>u&&(u=d)}l=u+1,n[o]=l,i=!0}s.set(c,l)}return i&&t.putSync(jE,(0,Bu.pack)(r)),s}function JE(e,t){let r=_O(t),n=r.remoteNameToId,s=n[e];if(s==null){let i=0;for(let o in n){let c=n[o];c>i&&(i=c)}s=i+1,n[e]=s,t.putSync(jE,(0,Bu.pack)(r))}return QH.trace?.("The remote node name map",e,n,s),s}var QH,Bu,jE,hO=Re(()=>{QH=M(Gs());Es();Bu=require("msgpackr"),jE=Symbol.for("remote-ids");a(_O,"getIdMappingRecord");a(K_,"exportIdMapping");a(jH,"remoteToLocalNodeId");a(JE,"getIdOfRemoteNode")});var mO={};Ue(mO,{commits_awaiting_replication:()=>ku,getHDBNodeTable:()=>sr,getReplicationSharedStatus:()=>XE,iterateRoutes:()=>z_,shouldReplicateToNode:()=>W_,subscribeToNodeUpdates:()=>Fu});function sr(){return JH||(JH=ft({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 XE(e,t,r,n){return new Float64Array(e.getUserSharedBuffer(["replicated",t,r],new ArrayBuffer(48),n&&{callback:n}))}function Fu(e){sr().subscribe({}).then(async t=>{for await(let r of t){let n=r?.value?.name;tk.debug?.("adding node",n,"on node",et()," on process",process.pid),server.nodes=server.nodes.filter(i=>i.name!==n),r.type==="put"&&n!==et()&&(r.value?server.nodes.push(r.value):console.error("Invalid node update event",r));let s=new Map;for await(let i of sr().search({}))if(i.shard!=null){let o=s.get(i.shard);o||s.set(i.shard,o=[]),o.push(i)}server.shards=s,(r.type==="put"||r.type==="delete")&&e(r.value,r.id)}})}function W_(e,t){return(e.replicates===!0||e.replicates?.sends)&&databases[t]&&sr().primaryStore.get(et())?.replicates||e.subscriptions?.some(r=>(r.database||r.schema)===t&&r.subscribe)}function Yne(){Fu(e=>{Sa({},(t,r)=>{let n=e.name,s=XH.get(n);if(s||XH.set(n,s=new Map),s.has(r))return;let i;for(let o in t)if(i=t[o].auditStore,i)break;if(i){let o=XE(i,r,n,()=>{let c=o[0],l=o.lastTime;for(let{txnTime:u,onConfirm:f}of ku.get(r)||[])u>l&&u<=c&&f();o.lastTime=c});o.lastTime=0,s.set(r,o)}})})}function*z_(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=Hu.default.get(B.REPLICATION_SECUREPORT)??(!Hu.default.get(B.REPLICATION_PORT)&&Hu.default.get(B.OPERATIONSAPI_NETWORK_SECUREPORT)),i;(i=n.match(/:(\d+)$/)?.[1])?n=n.slice(0,-i[0].length-1):t.port?i=t.port:i=s||Hu.default.get(B.REPLICATION_PORT)||Hu.default.get(B.OPERATIONSAPI_NETWORK_PORT);let o=i?.lastIndexOf?.(":");o>0&&(i=+i.slice(o+1).replace(/[\[\]]/g,"")),r=(s?"wss://":"ws://")+n+":"+i}if(!r){ZH.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,start_time:t.startTime,revoked_certificates:t.revokedCertificates}}}var ZH,ek,Hu,tk,JH,XH,ku,rl=Re(()=>{xe();Es();rp();ZH=require("worker_threads"),ek=M(me()),Hu=M(ce());k();tk=M(Gs());server.nodes=[];a(sr,"getHDBNodeTable");a(XE,"getReplicationSharedStatus");a(Fu,"subscribeToNodeUpdates");a(W_,"shouldReplicateToNode");XH=new Map;JD((e,t,r)=>{if(r>server.nodes.length)throw new ek.ClientError(`Cannot confirm replication to more nodes (${r}) than are in the network (${server.nodes.length})`);ku||(ku=new Map,Yne());let n=ku.get(e);return n||(n=[],ku.set(e,n)),new Promise(s=>{let i=0;n.push({txnTime:t,onConfirm:a(()=>{++i===r&&s()},"onConfirm")})})});a(Yne,"startSubscriptionToReplications");a(z_,"iterateRoutes")});var sk={};Ue(sk,{connectedToNode:()=>nl,disconnectedFromNode:()=>qu,ensureNode:()=>Ro,requestClusterStatus:()=>nk,startOnMainThread:()=>gO});async function gO(e){let t=0,r=Xe();for(let i of Object.getOwnPropertyNames(r)){let o=r[i];for(let c in o){let l=o[c];if(l.auditStore){ZE.set(i,Y_(l.auditStore));break}}}Hi.whenThreadsStarted.then(async()=>{let i=[];for await(let o of r.system.hdb_nodes?.search([])||[])i.push(o);for(let o of z_(e))try{let c=!o.subscriptions;if(c){let u=et(),f=sr().primaryStore.get(u);if(f!==null){let d=e.url??Ta();(f===void 0||f.url!==d||f.shard!==e.shard)&&await Ro(u,{name:u,url:d,shard:e.shard,replicates:!0})}}let l=o.trusted!==!1;if(c&&o.replicates==null&&(o.replicates=!0),i.find(u=>u.url===o.url))continue;s(o)}catch(c){console.error(c)}Fu(s)});let n;function s(i,o=i?.name){let c=et()&&o===et()||Ta()&&i?.url===Ta();if(c){let d=!!i?.replicates;if(n!==void 0&&n!==d)for(let _ of sr().search([]))_.replicates&&_.name!==o&&s(_,_.name);n=d}if(rt.trace("Setting up node replication for",i),!i){for(let[d,_]of Bi){let h;for(let[m,{worker:S,nodes:g}]of _){let R=g[0];if(R&&R.name==o){h=!0;for(let[E,{worker:T}]of _)_.delete(E),rt.warn("Node was deleted, unsubscribing from node",o,E,d),T?.postMessage({type:"unsubscribe-from-node",node:o,database:E,url:d});break}}if(h){Bi.get(d).iterator.remove(),Bi.delete(d);return}}return}if(c)return;if(!i.url){rt.info(`Node ${i.name} is missing url`);return}let l=Bi.get(i.url);if(l&&l.iterator.remove(),!(i.replicates===!0||i.replicates?.sends)&&!i.subscriptions?.length&&!l)return;if(rt.info(`Added node ${i.name} at ${i.url} for process ${et()}`),i.replicates&&i.subscriptions&&(i={...i,subscriptions:null}),i.name){for(let[d,_]of Gu)if(i.url===_.url){Gu.delete(d);break}Gu.set(i.name,i)}let u=Xe();if(l||(l=new Map,Bi.set(i.url,l)),l.iterator=Sa(e,(d,_,h)=>{h?f(_,!0):f(_,!1)}),i.subscriptions)for(let d of i.subscriptions){let _=d.database||d.schema;u[_]||(rt.warn(`Database ${_} not found for node ${i.name}, making a subscription anyway`),f(_,!1))}function f(d,_){rt.trace("Setting up replication for database",d,"on node",i.name);let h=l.get(d),m,S=[{replicateByDefault:_,...i}];ZE.has(d)&&(S.push({replicateByDefault:_,name:et(),start_time:ZE.get(d),end_time:Date.now(),replicates:!0}),ZE.delete(d));let g=W_(i,d),R=Hi.workers.filter(E=>E.name==="http");if(h?(m=h.worker,h.nodes=S):g&&(t=t%R.length,m=R[t++],l.set(d,{worker:m,nodes:S,url:i.url}),m?.on("exit",()=>{l.get(d)?.worker===m&&(l.delete(d),f(d,_))})),g)setTimeout(()=>{let E={type:"subscribe-to-node",database:d,nodes:S};m?m.postMessage(E):Q_(E)},Wne);else{rt.info("Node no longer should be used, unsubscribing from node",i.replicates,!!u[d],sr().primaryStore.get(et())?.replicates),sr().primaryStore.get(et())?.replicates||(n=!1);let E={type:"unsubscribe-from-node",database:d,url:i.url,name:i.name};m?m.postMessage(E):tg(E)}}a(f,"onDatabase")}a(s,"onNodeUpdate"),qu=a(function(i){try{rt.info("Disconnected from node",i.name,i.url,"finished",!!i.finished);let o=Array.from(Gu.keys()),c=o.sort(),l=c.indexOf(i.name||Js(i.url));if(l===-1){rt.warn("Disconnected node not found in node map",i.name,o);return}let u=Bi.get(i.url),f=u?.get(i.database);if(!f){rt.warn("Disconnected node not found in replication map",i.database,u);return}if(f.connected=!1,i.finished||!EO.default.get(B.REPLICATION_FAILOVER))return;let d=f.nodes[0];if(!(d.replicates===!0||d.replicates?.sends||d.subscriptions?.length))return;let _=d.shard,h=(l+1)%c.length;for(;l!==h;){let m=c[h],S=Gu.get(m);u=Bi.get(S.url);let g=u?.get(i.database);if(!g||g.connected===!1||g.nodes[0].shard!==_){h=(h+1)%c.length;continue}let{worker:R,nodes:E}=g,T=!1;for(let N of f.nodes){if(E.some(v=>v.name===N.name)){rt.info(`Disconnected node is already failing over to ${m} for ${i.database}`);continue}N.end_time<Date.now()||(E.push(N),T=!0)}if(f.nodes=[f.nodes[0]],!T){rt.info(`Disconnected node ${i.name} has no nodes to fail over to ${m}`);return}rt.info(`Failing over ${i.database} from ${i.name} to ${m}`),R?R.postMessage({type:"subscribe-to-node",database:i.database,nodes:E}):Q_({database:i.database,nodes:E});return}rt.warn("Unable to find any other node to fail over to",i.name,i.url)}catch(o){rt.error("Error failing over node",o)}},"disconnectedFromNode"),nl=a(function(i){let o=Bi.get(i.url),c=o?.get(i.database);if(!c){rt.warn("Connected node not found in replication map, this may be because the node is being removed",i.database,o);return}c.connected=!0,c.latency=i.latency;let l=c.nodes[0];if(!l){rt.info("Connected node has no nodes",i.database,c);return}if(!l.name){rt.debug("Connected node is not named yet",i.database,c);return}c.nodes=[l];let u=!1;for(let f of Bi.values()){let d=f.get(i.database);if(!d||d==c)continue;let{worker:_,nodes:h,connected:m}=d;if(h)if(m===!1&&h[0].shard===l.shard)u=!0,c.nodes.push(h[0]);else{let S=h.filter(g=>g.name!==l.name);S.length<h.length&&(d.nodes=S,_.postMessage({type:"subscribe-to-node",database:i.database,nodes:h}))}}u&&c.worker&&c.worker.postMessage({type:"subscribe-to-node",database:i.database,nodes:c.nodes})},"connectedToNode"),(0,Hi.onMessageByType)("disconnected-from-node",qu),(0,Hi.onMessageByType)("connected-to-node",nl),(0,Hi.onMessageByType)("request-cluster-status",nk)}function nk(e,t){let r=[];for(let[n,s]of Gu)try{let i=Bi.get(s.url);rt.info("Getting cluster status for",n,s.url,"has dbs",i?.size);let o=[];if(i){for(let[l,{worker:u,connected:f,nodes:d,latency:_}]of i)o.push({database:l,connected:f,latency:_,thread_id:u?.threadId,nodes:d.filter(h=>!(h.end_time<Date.now())).map(h=>h.name)});let c=(0,pO.cloneDeep)(s);c.database_sockets=o,delete c.ca,delete c.node_name,delete c.__updatedtime__,delete c.__createdtime__,r.push(c)}}catch(i){rt.warn("Error getting cluster status for",s?.url,i)}return t?.postMessage({type:"cluster-status",connections:r}),{connections:r}}async function Ro(e,t){let r=sr();e=e??Js(t.url),t.name=e;try{if(t.ca){let s=new rk.X509Certificate(t.ca);t.ca_info={issuer:s.issuer.replace(/\n/g," "),subject:s.subject.replace(/\n/g," "),subject_alt_name:s.subjectAltName,serial_number:s.serialNumber,valid_from:s.validFrom,valid_to:s.validTo}}}catch(s){rt.error("Error parsing replication CA info for hdb_nodes table",s.message)}let n=r.primaryStore.get(e);if(rt.debug(`Ensuring node ${e} at ${t.url}, existing record:`,n,"new record:",t),!n)await r.patch(t);else{t.replicates&&!EO.default.get(B.CLUSTERING_ENABLED)&&(t.subscriptions=null);for(let s in t)if(n[s]!==t[s]&&s==="subscriptions"&&t[s]&&n[s]){let i=[],o=(0,pO.cloneDeep)(n[s]);for(let c of t[s]){let l=!1;for(let u of o)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=[...o,...i];break}if(Array.isArray(t.revoked_certificates)){let s=n.revoked_certificates||[];t.revoked_certificates=[...new Set([...s,...t.revoked_certificates])]}rt.info(`Updating node ${e} at ${t.url}`),await r.patch(t)}}var Hi,eg,rt,pO,EO,rk,Wne,Bi,qu,nl,Gu,ZE,j_=Re(()=>{xe();Hi=M(it());Es();eg=require("worker_threads");rl();rt=M(ee()),pO=require("lodash"),EO=M(ce());k();rk=require("crypto"),Wne=200,Bi=new Map,Gu=new Map,ZE=new Map;a(gO,"startOnMainThread");a(nk,"requestClusterStatus");eg.parentPort&&(qu=a(e=>{eg.parentPort.postMessage({type:"disconnected-from-node",...e})},"disconnectedFromNode"),nl=a(e=>{eg.parentPort.postMessage({type:"connected-to-node",...e})},"connectedToNode"),(0,Hi.onMessageByType)("subscribe-to-node",e=>{Q_(e)}),(0,Hi.onMessageByType)("unsubscribe-from-node",e=>{tg(e)}));a(Ro,"ensureNode")});var ei=C(wk=>{"use strict";var ir=require("path"),{watch:zne}=require("chokidar"),bn=require("fs-extra"),$u=require("node-forge"),uk=require("net"),{generateKeyPair:TO,X509Certificate:yo,createPrivateKey:dk}=require("crypto"),Qne=require("util");TO=Qne.promisify(TO);var yt=$u.pki,Xs=require("joi"),{v4:fk}=require("uuid"),{validateBySchema:bO}=st(),St=ee(),Jn=ce(),gs=(k(),P(q)),{CONFIG_PARAMS:il}=gs,Zs=yA(),{ClientError:Ra}=me(),rg=require("node:tls"),{relative:_k,join:jne}=require("node:path"),{CERT_PREFERENCE_APP:NIe,CERTIFICATE_VALUES:ik}=Zs,Jne=_c(),AO=It(),{table:Xne,getDatabases:Zne,databases:SO}=(xe(),P(at)),{getJWTRSAKeys:ok}=(Lu(),P(H_));Object.assign(wk,{generateKeys:wO,updateConfigCert:Ak,createCsr:ose,signCertificate:ase,setCertTable:Vu,loadCertificates:gk,reviewSelfSignedCert:CO,createTLSSelector:yk,listCertificates:Ok,addCertificate:_se,removeCertificate:mse,createNatsCerts:use,generateCertsKeys:lse,getReplicationCert:X_,getReplicationCertAuth:ise,renewSelfSigned:dse,hostnamesFromCert:PO,getKey:pse});var{urlToNodeName:hk,getThisNodeUrl:ese,getThisNodeName:sg,clearThisNodeName:tse}=(Es(),P(Oa)),{readFileSync:rse,statSync:mk}=require("node:fs"),wIe=ce(),{getTicketKeys:nse,onMessageFromWorkers:sse}=it(),Aa=ee(),{isMainThread:pk}=require("worker_threads"),{TLSSocket:Ek,createSecureContext:IIe}=require("node:tls"),OO=3650,J_=["127.0.0.1","localhost","::1"],NO=[{name:"countryName",value:"USA"},{name:"stateOrProvinceName",value:"Colorado"},{name:"localityName",value:"Denver"},{name:"organizationName",value:"HarperDB, Inc."}];sse(async e=>{e.type===gs.ITC_EVENT_TYPES.RESTART&&(Jn.initSync(!0),await CO())});var kr;function ba(){return kr||(kr=Zne().system.hdb_certificate,kr||(kr=Xne({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__"}]}))),kr}a(ba,"getCertTable");async function X_(){let e=yk("operations-api"),t={secureContexts:null,setSecureContext:a(s=>{},"setSecureContext")};await e.initialize(t);let r=t.secureContexts.get(sg());if(!r)return;let n=new yo(r.options.cert);return r.cert_parsed=n,r.issuer=n.issuer,r}a(X_,"getReplicationCert");async function ise(){ba();let e=(await X_()).options.cert,r=new yo(e).issuer.match(/CN=(.*)/)?.[1];return kr.get(r)}a(ise,"getReplicationCertAuth");var ak,ya=new Map;function gk(){if(ak)return;ak=!0;let e=[{configKey:il.TLS},{configKey:il.OPERATIONSAPI_TLS}];ba();let t=ir.dirname(AO.getConfigFilePath()),r;for(let{configKey:n}of e){let s=AO.getConfigFromFile(n);if(s){Array.isArray(s)||(s=[s]);for(let i of s){let o=i.privateKey,c=o&&_k(jne(t,"keys"),o);c&&ck(o,l=>{ya.set(c,l)},"private key");for(let l of[!1,!0]){let u=i[l?"certificateAuthority":"certificate"];if(u&&pk){let f;ck(u,d=>{if(ik.cert===d)return;let _=i.hostname??i.hostnames??i.host??i.hosts;_&&!Array.isArray(_)&&(_=[_]);let h=Rk(u),m=new yo(h),S;try{S=Nk(m)}catch(T){logger.error("error extracting host name from certificate",T);return}if(S==null){logger.error("No host name found on certificate");return}if(m.checkIssued(new yo(ik.cert)))return;let g=kr.primaryStore.get(S),R=mk(u).mtimeMs,E=!g||g.is_self_signed?1:g.file_timestamp??g.__updatedtime__;if(g&&R<=E){R<E&&St.info(`Certificate ${S} at ${u} is older (${new Date(R)}) than the certificate in the database (${E>1?new Date(E):"only self signed certificate available"})`);return}r=kr.put({name:S,uses:["https",...n.includes("operations")?["operations"]:[]],ciphers:i.ciphers,certificate:h,private_key_name:c,is_authority:l,hostnames:_,file_timestamp:R,details:{issuer:m.issuer.replace(/\n/g," "),subject:m.subject?.replace(/\n/g," "),subject_alt_name:m.subjectAltName,serial_number:m.serialNumber,valid_from:m.validFrom,valid_to:m.validTo}})},l?"certificate authority":"certificate")}}}}}return r}a(gk,"loadCertificates");function ck(e,t,r){let n,s=a((i,o)=>{try{let c=o.mtimeMs;c&&c!==n&&(n&&pk&&St.warn(`Reloading ${r}:`,i),n=c,t(Rk(i)))}catch(c){St.error(`Error loading ${r}:`,i,c)}},"loadFile");bn.existsSync(e)?s(e,mk(e)):St.error(`${r} file not found:`,e),zne(e,{persistent:!1}).on("change",s)}a(ck,"loadAndWatch");function RO(){let e=ese();if(e==null){let t=J_[0];return St.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return hk(e)}a(RO,"getHost");function ng(){let e=sg();if(e==null){let t=J_[0];return St.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return e}a(ng,"getCommonName");async function ose(){let e=await X_(),t=yt.certificateFromPem(e.options.cert),r=yt.privateKeyFromPem(e.options.key);St.info("Creating CSR with cert named:",e.name);let n=yt.createCertificationRequest();n.publicKey=t.publicKey;let s=[{name:"commonName",value:ng()},...NO];St.info("Creating CSR with subject",s),n.setSubject(s);let i=[{name:"unstructuredName",value:"HarperDB, Inc."},{name:"extensionRequest",extensions:Sk()}];return St.info("Creating CSR with attributes",i),n.setAttributes(i),n.sign(r),$u.pki.certificationRequestToPem(n)}a(ose,"createCsr");function Sk(){let e=J_.includes(ng())?J_:[...J_,ng()];return e.includes(RO())||e.push(RO()),[{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=>uk.isIP(t)?{type:7,ip:t}:{type:2,value:t})}]}a(Sk,"certExtensions");async function ase(e){let t={},r=ir.join(Jn.getHdbBasePath(),gs.LICENSE_KEY_DIR_NAME);if(e.csr){let n,s;ba();for await(let f of kr.search([]))if(f.is_authority&&!f.details.issuer.includes("HarperDB-Certificate-Authority")){if(ya.has(f.private_key_name)){n=ya.get(f.private_key_name),s=f;break}else if(f.private_key_name&&await bn.exists(ir.join(r,f.private_key_name))){n=bn.readFile(ir.join(r,f.private_key_name)),s=f;break}}if(!n){let f=await yO();s=f.ca,n=f.private_key}n=yt.privateKeyFromPem(n),t.signingCA=s.certificate;let i=yt.certificateFromPem(s.certificate);St.info("Signing CSR with cert named",s.name);let o=yt.certificationRequestFromPem(e.csr);try{o.verify()}catch(f){return St.error(f),new Error("Error verifying CSR: "+f.message)}let c=$u.pki.createCertificate();c.serialNumber=Math.random().toString().slice(2,10),c.validity.notBefore=new Date;let l=new Date;c.validity.notAfter=l,c.validity.notAfter.setDate(l.getDate()+OO),St.info("sign cert setting validity:",c.validity),St.info("sign cert setting subject from CSR:",o.subject.attributes),c.setSubject(o.subject.attributes),St.info("sign cert setting issuer:",i.subject.attributes),c.setIssuer(i.subject.attributes);let u=o.getAttribute({name:"extensionRequest"}).extensions;St.info("sign cert adding extensions from CSR:",u),c.setExtensions(u),c.publicKey=o.publicKey,c.sign(n,$u.md.sha256.create()),t.certificate=yt.certificateToPem(c)}else St.info("Sign cert did not receive a CSR from:",e.url,"only the CA will be returned");return t}a(ase,"signCertificate");async function cse(e,t){await Vu({name:sg(),uses:["https","wss"],certificate:e,private_key_name:"privateKey.pem",is_authority:!1,is_self_signed:!0}),await Vu({name:t.subject.getField("CN").value,uses:["https","wss"],certificate:yt.certificateToPem(t),private_key_name:"privateKey.pem",is_authority:!0,is_self_signed:!0})}a(cse,"createCertificateTable");async function Vu(e){let t=new yo(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},ba(),await kr.patch(e)}a(Vu,"setCertTable");async function wO(){let e=await TO("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}});return{public_key:yt.publicKeyFromPem(e.publicKey),private_key:yt.privateKeyFromPem(e.privateKey)}}a(wO,"generateKeys");async function IO(e,t,r){let n=yt.createCertificate();if(!t){let o=await X_();t=yt.certificateFromPem(o.options.cert).publicKey}n.publicKey=t,n.serialNumber=Math.random().toString().slice(2,10),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+OO);let i=[{name:"commonName",value:ng()},...NO];return n.setSubject(i),n.setIssuer(r.subject.attributes),n.setExtensions(Sk()),n.sign(e,$u.md.sha256.create()),yt.certificateToPem(n)}a(IO,"generateCertificates");async function yO(){let e=await Ok(),t;for(let r of e){if(!r.is_authority)continue;let n=await bk(r.private_key_name);if(r.private_key_name&&n&&new yo(r.certificate).checkPrivateKey(dk(n))){St.trace(`CA named: ${r.name} found with matching private key`),t={ca:r,private_key:n};break}}if(t)return t;St.trace("No CA found with matching private key")}a(yO,"getCertAuthority");async function Tk(e,t,r=!0){let n=yt.createCertificate();n.publicKey=t,n.serialNumber=Math.random().toString().slice(2,10),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+OO);let i=[{name:"commonName",value:`HarperDB-Certificate-Authority-${Jn.get(il.REPLICATION_HOSTNAME)??hk(Jn.get(il.REPLICATION_URL))??fk().split("-")[0]}`},...NO];n.setSubject(i),n.setIssuer(i),n.setExtensions([{name:"basicConstraints",cA:!0,critical:!0},{name:"keyUsage",keyCertSign:!0,critical:!0}]),n.sign(e,$u.md.sha256.create());let o=ir.join(Jn.getHdbBasePath(),gs.LICENSE_KEY_DIR_NAME),c=ir.join(o,Zs.PRIVATEKEY_PEM_NAME);return r&&await bn.writeFile(c,yt.privateKeyToPem(e)),n}a(Tk,"generateCertAuthority");async function lse(){let{private_key:e,public_key:t}=await wO(),r=await Tk(e,t),n=await IO(e,t,r);await cse(n,r),Ak()}a(lse,"generateCertsKeys");async function use(){let e=await IO(yt.privateKeyFromPem(Zs.CERTIFICATE_VALUES.key),void 0,yt.certificateFromPem(Zs.CERTIFICATE_VALUES.cert)),t=ir.join(Jn.getHdbBasePath(),gs.LICENSE_KEY_DIR_NAME),r=ir.join(t,Zs.NATS_CERTIFICATE_PEM_NAME);await bn.exists(r)||await bn.writeFile(r,e);let n=ir.join(t,Zs.NATS_CA_PEM_NAME);await bn.exists(n)||await bn.writeFile(n,Zs.CERTIFICATE_VALUES.cert)}a(use,"createNatsCerts");async function dse(){ba();for await(let e of kr.search([{attribute:"is_self_signed",value:!0}]))await kr.delete(e.name);await CO()}a(dse,"renewSelfSigned");async function CO(){tse(),await gk(),ba();let e=await yO();if(!e){St.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=a(u=>{try{return{key:yt.privateKeyFromPem(bn.readFileSync(u)),keyPath:u}}catch(f){return St.warn(`Failed to parse private key from ${u}:`,f.message),{key:null,keyPath:u}}},"tryToParseKey"),n=Jn.get(il.TLS),s,i;if(Array.isArray(n)){for(let u of n)if(u.privateKey){let f=r(u.privateKey);if(s=f.key,i=f.keyPath,f.key)break}}else{let u=Jn.get(il.TLS_PRIVATEKEY),f=r(u);s=f.key,i=f.keyPath}let o=ir.join(Jn.getHdbBasePath(),gs.LICENSE_KEY_DIR_NAME),c=_k(o,i);s||(St.warn("Unable to parse the TLS key",i,"A new key will be generated and used to create Certificate Authority"),{private_key:s}=await wO(),bn.existsSync(ir.join(o,Zs.PRIVATEKEY_PEM_NAME))&&(c=`privateKey${fk().split("-")[0]}.pem`),await bn.writeFile(ir.join(o,c),yt.privateKeyToPem(s)));let l=await Tk(s,yt.setRsaPublicKey(s.n,s.e),!1);await Vu({name:l.subject.getField("CN").value,uses:["https"],certificate:yt.certificateToPem(l),private_key_name:c,is_authority:!0,is_self_signed:!0})}if(!await X_()){let r=sg();St.notify(`A suitable replication certificate was not found, creating new self singed cert named: ${r}`),e=e??await yO();let n=yt.certificateFromPem(e.ca.certificate),s=n.publicKey,i=await IO(yt.privateKeyFromPem(e.private_key),s,n);await Vu({name:r,uses:["https","operations","wss"],certificate:i,is_authority:!1,private_key_name:e.ca.private_key_name,is_self_signed:!0})}}a(CO,"reviewSelfSignedCert");function Ak(){let e=Jne(Object.keys(gs.CONFIG_PARAM_MAP),!0),t=ir.join(Jn.getHdbBasePath(),gs.LICENSE_KEY_DIR_NAME),r=ir.join(t,Zs.PRIVATEKEY_PEM_NAME),n=ir.join(t,Zs.NATS_CERTIFICATE_PEM_NAME),s=ir.join(t,Zs.NATS_CA_PEM_NAME),i=gs.CONFIG_PARAMS,o={[i.TLS_PRIVATEKEY]:e[i.TLS_PRIVATEKEY.toLowerCase()]?e[i.TLS_PRIVATEKEY.toLowerCase()]:r};e[i.TLS_CERTIFICATE.toLowerCase()]&&(o[i.TLS_CERTIFICATE]=e[i.TLS_CERTIFICATE.toLowerCase()]),e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(o[i.TLS_CERTIFICATEAUTHORITY]=e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_CERTIFICATE]=e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]),e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_PRIVATEKEY]=e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY]=e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]),(e[i.CLUSTERING_ENABLED.toLowerCase()]||e.clustering)&&(o[i.CLUSTERING_TLS_CERTIFICATE]=e[i.CLUSTERING_TLS_CERTIFICATE.toLowerCase()]??n,o[i.CLUSTERING_TLS_CERT_AUTH]=e[i.CLUSTERING_TLS_CERT_AUTH.toLowerCase()]??s,o[i.CLUSTERING_TLS_PRIVATEKEY]=e[i.CLUSTERING_TLS_PRIVATEKEY.toLowerCase()]??r),AO.updateConfigValue(void 0,void 0,o,!1,!0)}a(Ak,"updateConfigCert");function Rk(e){return e.startsWith("-----BEGIN")?e:rse(e,"utf8")}a(Rk,"readPEM");var lk=rg.createSecureContext;rg.createSecureContext=function(e){if(!e.cert||!e.key)return lk(e);let t={...e};delete t.key,delete t.cert;let r=lk(t);return r.context.setCert(e.cert),r.context.setKey(e.key,void 0),r};var fse=Ek.prototype._init;Ek.prototype._init=function(e,t){fse.call(this,e,t);let r=this;this._handle.oncertcb=function(n){let s=n.servername;r._SNICallback(s,(i,o)=>{this.sni_context=o?.context||o,this.certCbDone()})}};var sl=new Map;function yk(e,t){let r=new Map,n,s=!1;return i.initialize=o=>i.ready?i.ready:(o&&(o.secureContexts=r,o.secureContextsListeners=[]),i.ready=new Promise((c,l)=>{async function u(){try{r.clear(),sl.clear();let f=0;for await(let d of SO.system.hdb_certificate.search([])){let _=d.certificate,h=new yo(_);d.is_authority&&(h.asString=_,sl.set(h.subject,_))}for await(let d of SO.system.hdb_certificate.search([]))try{if(d.is_authority)continue;let _=e==="operations-api",h=d.is_self_signed?1:2;_&&d.uses?.includes?.("operations")&&(h+=1);let m=await bk(d.private_key_name),S=d.certificate,g=new yo(S);if(sl.has(g.issuer)&&(S+=`
|