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()}});kL={type:"application/json",serializeStream:Pf,serialize:vf,deserialize:_3,q:.5};Yr.set("*/*",kL);Yr.set("",kL);a(_3,"tryJSONParse");a(xf,"registerContentHandlers");h3=require("fastify-plugin"),m3=h3(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");vL=aR.default.get(B.HTTP_COMPRESSIONTHRESHOLD);a(Bf,"serialize");a(la,"serializeMessage");a(iR,"asyncSerialization");a(oR,"hasAsyncSerialization");a(p3,"streamToBuffer");E3=["ascii","utf8","utf-8","utf16le","utf-16le","ucs2","ucs-2","base64","base64url","latin1","binary","hex"];a(g3,"isBufferEncoding");a(S3,"parseContentType");a(ao,"getDeserializer");a(T3,"deserializerUnknownType");a(A3,"transformIterable");a(Tp,"toCsvStream")});var fR={};Ue(fR,{start:()=>P3});function R3(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 GL(e){if(typeof e!="object"||e===null)throw new yi("Request body must be an object.");if(!("query"in e))throw new yi("Request body must contain a `query` field.");if(typeof e.query!="string")throw new yi("Request body `query` field must be a string.");if("variables"in e&&(typeof e.variables!="object"||e.variables===null))throw new yi("Request body `variables` field must be an object.");if("operationName"in e&&typeof e.operationName!="string")throw new yi("Request body `operationName` field must be a string.")}function dR(e){return parseInt(e.value,10)}function $L(e){return parseFloat(e.value)}function VL(e,t,r){let n=r.get(e.name.value);return KL(n)?YL(n,t):{attribute:t,value:n}}function KL(e){return typeof e=="object"&&e!=null&&!Array.isArray(e)}function YL(e,t){return t=typeof t=="string"?[t]:t,Object.entries(e).flatMap(([r,n])=>(t=[...t,r],KL(n)?YL(n,t):{attribute:t,value:n}))}function y3(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:dR(e.value)};case Me.Kind.FLOAT:return{attribute:t,value:$L(e.value)};case Me.Kind.BOOLEAN:case Me.Kind.STRING:return{attribute:t,value:e.value.value};case Me.Kind.VARIABLE:return VL(e.value,t,r);case Me.Kind.OBJECT:return WL(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 WL(e,t,r){return e.fields.flatMap(n=>y3(n,t,r))}function b3(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:dR(e.value)};case Me.Kind.FLOAT:return{attribute:e.name.value,value:$L(e.value)};case Me.Kind.BOOLEAN:case Me.Kind.STRING:return{attribute:e.name.value,value:e.value.value};case Me.Kind.VARIABLE:return VL(e.value,e.name.value,t);case Me.Kind.OBJECT:return WL(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 O3(e,t){return e.flatMap(r=>b3(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 zL(e,t){return Rp(e,t).map(r=>r.selectionSet?.selections.length>0?{name:r.name.value,select:zL(r.selectionSet,t)}:r.name.value)}async function N3(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:zL(e.selectionSet,r),conditions:O3(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 jL(e){switch(e.kind){case Me.Kind.NULL:return null;case Me.Kind.INT:return dR(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]:jL(r.value),...t}),{});case Me.Kind.LIST:case Me.Kind.ENUM:default:throw new Or(`Value type, ${e.kind}, is not supported.`)}}function w3(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=jL(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 I3(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=w3(e.variableDefinitions,t),i=await Promise.all(Rp(e.selectionSet,r).map(c=>N3(c,s,r,n))),o={data:{}};for(let[c,l]of i)o.data[c]=l;return o}async function qL({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(R3(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 I3(c,t,o,n);return{status:200,headers:{"Content-Type":"application/graphql-response+json; charset=utf-8"},body:JSON.stringify(l)}}async function C3(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 GL(r),qL(r,e)}case"POST":{let r=await ao(e.headers.get("content-type"),!0)(e._nodeRequest);return GL(r),qL(r,e)}default:throw new yi("Method Not Allowed",405,{Allow:"GET, POST"})}}function P3(e){e.server.http(async(t,r)=>{if(!t.url.startsWith("/graphql"))return r(t);try{return await C3(t)}catch(n){logger.error(n);let s=t.headers.get("accept")??"application/graphql-response+json";switch(s){case"application/json":{if(n instanceof yi)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 yi)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,yi,QL=Re(()=>{Me=M(require("graphql"));so();ru();a(R3,"assertExecutableDefinitionNode");a(GL,"assertRequestParams");a(dR,"processIntValueNode");a($L,"processFloatValueNode");a(VL,"processVariableNode");a(KL,"isObject");a(YL,"transformObjectIntoQueryCondition");a(y3,"processObjectFieldNode");a(WL,"processObjectValueNode");a(b3,"processArgumentNode");a(O3,"buildConditionsQuery");a(Rp,"fillInFragments");a(zL,"buildSelectQuery");a(N3,"processFieldNode");a(jL,"processConstValueNode");a(w3,"resolveVariables");a(I3,"executeOperation");a(qL,"resolver");Or=class extends Error{static{a(this,"GraphQLQueryingError")}},yi=class extends Error{static{a(this,"HTTPError")}statusCode;headers;constructor(t,r=400,n={}){super(t),this.statusCode=r,this.headers=n}};a(C3,"graphqlQueryingHandler");a(P3,"start")});var Oi=C(($Re,ZL)=>{"use strict";var XL=oe(),JL=(k(),P(q)),cu=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,bi=require("joi"),ua={schema_format:{pattern:cu,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},D3=bi.alternatives(bi.string().min(1).max(ua.schema_length.maximum).pattern(cu).messages({"string.pattern.base":"{:#label} "+ua.schema_format.message}),bi.number(),bi.array()).required(),L3=bi.alternatives(bi.string().min(1).max(ua.schema_length.maximum).pattern(cu).messages({"string.pattern.base":"{:#label} "+ua.schema_format.message}),bi.number()),M3=bi.alternatives(bi.string().min(1).max(ua.schema_length.maximum).pattern(cu).messages({"string.pattern.base":"{:#label} "+ua.schema_format.message}),bi.number()).required();function v3(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>ua.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(v3,"checkValidTable");function U3(e,t){return XL.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(U3,"validateSchemaExists");function x3(e,t){let r=t.state.ancestors[0].schema;return XL.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(x3,"validateTableExists");function B3(e,t){return e.toLowerCase()===JL.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${JL.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(B3,"validateSchemaName");ZL.exports={common_validators:ua,schema_regex:cu,hdb_schema_table:D3,validateSchemaExists:U3,validateTableExists:x3,validateSchemaName:B3,checkValidTable:v3,hdb_database:L3,hdb_table:M3}});var hR=C((KRe,tM)=>{var{hdb_table:H3,hdb_database:eM}=Oi(),k3=st(),_R=require("joi"),F3={undefined:"undefined",null:"null"},G3=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||F3[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"),q3=_R.object({database:eM,schema:eM,table:H3,records:_R.array().items(_R.object().custom(G3)).required()});tM.exports=function(e){return k3.validateBySchema(e,q3)}});var nM=C((WRe,rM)=>{"use strict";var mR=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")}};rM.exports=mR});var iM=C((jRe,sM)=>{"use strict";var pR=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};sM.exports=pR});var uM={};Ue(uM,{HAS_EXPIRATION:()=>Op,HAS_RESIDENCY_ID:()=>yR,HAS_STRUCTURE_UPDATE:()=>wp,LAST_TIMESTAMP_PLACEHOLDER:()=>Gf,LOCAL_TIMESTAMP:()=>$3,METADATA:()=>Ic,NEW_TIMESTAMP_PLACEHOLDER:()=>aM,NO_TIMESTAMP:()=>ER,PENDING_LOCAL_TIME:()=>bR,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>RR,RecordEncoder:()=>AR,TIMESTAMP_ASSIGN_LAST:()=>K3,TIMESTAMP_ASSIGN_NEW:()=>cM,TIMESTAMP_ASSIGN_PREVIOUS:()=>lM,TIMESTAMP_PLACEHOLDER:()=>yp,TIMESTAMP_RECORD_PREVIOUS:()=>gR,handleLocalTimeForGets:()=>Ip,recordUpdater:()=>OR,removeEntry:()=>Pc});function W3(){return Ff[0]=Ff[0]^64,V3.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 OR(e,t,r){return function(n,s,i,o,c=-1,l,u,f="put",d,_){d||l==null?lu=i?.localTime?gR|lM:ER:lu=l?i?.localTime?gR|16384:cM|16384:ER;let h=u?.expiresAt;if(h>=0&&(c|=Op),kf=c,SR=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&&(TR=E,kf|=yR,g|=Dc),R!==E&&(g|=Lc,R||(R=0)),c&Op&&(g|=$f),u?.originatingOperation&&(g|=qf),d&&(m.ifVersion=S=i?.version??null),i&&i.value&&f!=="message"&&i.metadataFlags&Ur&&(r.getBinaryFast(i.localTime)||ca(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,Hf,g,E,R,h),{ifVersion:S}),T}}T=r.put(s===void 0?aM:Gf,Cc(o,t,n,i?.localTime?1:0,u?.nodeId??server.replication?.getThisNodeId(r)??0,N,f,Hf,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)&&ca(t.value),e.remove(t.key,r)}var oM,bp,yp,Gf,RR,aM,$3,Ic,Ff,V3,ER,cM,K3,lM,gR,Op,yR,bR,wp,Y3,Hf,lu,kf,SR,TR,AR,wc,uu=Re(()=>{oM=require("msgpackr");Ai();bp=M(ee());gn();gn();yp=new Uint8Array([1,1,1,1,4,64,0,0]),Gf=new Uint8Array([1,1,1,1,1,0,0,0]),RR=new Uint8Array([1,1,1,1,3,64,0,0]),aM=new Uint8Array([1,1,1,1,0,64,0,0]),$3=Symbol("local-timestamp"),Ic=Symbol("metadata"),Ff=new Uint8Array(8),V3=new DataView(Ff.buffer,0,8),ER=0,cM=0,K3=1,lM=3,gR=4,Op=16,yR=32,bR=1,wp=256,lu=0,kf=-1,SR=-1,TR=0,AR=class extends oM.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(s,i){if(lu||kf>=0){let o=0,c=lu;c&&(o+=8,lu=0);let l=kf,u=SR,f=TR;l>=0&&(o+=4,kf=-1,u>=0&&(o+=8,SR=-1),f&&(o+=4,TR=0));let d=Y3=r.call(this,s,i|2048|o);Hf=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 Hf=r.call(this,s,i),Hf};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(Ff,0,c),c+=8;else for(let _=0;_<8;_++)Ff[_]=t[c++];l=W3(),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&yR&&(f=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4));let d=no(()=>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:no(()=>super.decode(t,r),this.rootStore)}catch(c){return bp.error("Error decoding record",c,"data: "+t.slice(0,40).toString("hex")),null}}};a(W3,"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(OR,"recordUpdater");a(Pc,"removeEntry")});var Vf=C((tye,fM)=>{"use strict";var dM=ce(),z3=(k(),P(q)),{RecordEncoder:j3}=(uu(),P(uM));dM.initSync();var Q3=dM.get(z3.CONFIG_PARAMS.STORAGE_CACHING)!==!1,NR=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=Q3&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:j3})}};fM.exports=NR});var Kf=C((nye,_M)=>{"use strict";var qn=ce(),hs=(k(),P(q));qn.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=qn.get(hs.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||qn.get(hs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||qn.get(hs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",qn.get(hs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=qn.get(hs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),qn.get(hs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=qn.get(hs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),qn.get(hs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=qn.get(hs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),qn.get(hs.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=qn.get(hs.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=qn.get(hs.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};_M.exports=Cp;Cp.MAX_DBS=1e4});var _t=C((iye,yM)=>{"use strict";var IR=require("lmdb"),qs=require("fs-extra"),$n=require("path"),Pp=fn(),pM=ee(),Sn=xn().LMDB_ERRORS_ENUM,Dp=iM(),CR=Vf(),EM=Kf(),da=kt(),hM=(k(),P(q)),{table:J3,resetDatabases:X3}=(xe(),P(at)),mM=ce(),$s=da.INTERNAL_DBIS_NAME,gM=da.DBI_DEFINITION_NAME,Z3="data.mdb",eX="lock.mdb",Yf=".mdb",tX="-lock",wR=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=ms(t,r),this.key_type=this.dbi[da.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[da.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new IR.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 PR(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=$n.join(e,t+Yf);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($n.join(e,t,Z3),qs.constants.R_OK|qs.constants.F_OK),$n.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(PR,"validateEnvironmentPath");function Mp(e,t){if(Pp.validateEnv(e),t===void 0)throw new Error(Sn.DBI_NAME_REQUIRED)}a(Mp,"validateEnvDBIName");async function rX(e,t,r=!1,n=!1){Lp(e,t);let s=$n.basename(e);t=t.toString();let i=mM.get(hM.CONFIG_PARAMS.DATABASES);i||mM.setProperty(hM.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await PR(e,t,n),SM(e,t,r)}catch(o){if(o.message===Sn.INVALID_ENVIRONMENT){let c=$n.join(e,t);await qs.mkdirp(n?c:e);let l=new EM(n?c:c+Yf,!1),u=IR.open(l);u.dbis=Object.create(null);let f=new CR(!1);u.openDB($s,f),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let d=DR(e,t,r);return u[da.ENVIRONMENT_NAME_KEY]=d,global.lmdb_map[d]=u,u}throw o}}a(rX,"createEnvironment");async function nX(e,t,r,n=!0){Lp(e,t),t=t.toString();let s=$n.join(e,t);return J3({table:t,database:$n.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(nX,"copyEnvironment");async function SM(e,t,r=!1){Lp(e,t),t=t.toString();let n=DR(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 PR(e,t),i=$n.join(e,t+Yf),o=s!=i,c=new EM(s,o),l=IR.open(c);l.dbis=Object.create(null);let u=AM(l);for(let f=0;f<u.length;f++)ms(l,u[f]);return l[da.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(SM,"openEnvironment");async function sX(e,t,r=!1){Lp(e,t),t=t.toString();let n=$n.join(e,t+Yf),s=await PR(e,t);if(global.lmdb_map!==void 0){let i=DR(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await TM(o),delete global.lmdb_map[i]}}await qs.remove(s),await qs.remove(s===n?s+tX:$n.join($n.dirname(s),eX))}a(sX,"deleteEnvironment");async function TM(e){Pp.validateEnv(e);let t=e[da.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(TM,"closeEnvironment");function DR(e,t,r=!1){let s=`${$n.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(DR,"getCachedEnvironmentName");function iX(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{pM.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(iX,"listDBIDefinitions");function AM(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(AM,"listDBIs");function oX(e,t){let n=ms(e,$s).getEntry(t),s=new Dp;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{pM.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(oX,"getDBIDefinition");function RM(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 CR(r,n===!0),o=e.openDB(t,i),c=new Dp(r===!0,n);return o[gM]=c,ms(e,$s).putSync(t,c),e.dbis[t]=o,o}throw s}}a(RM,"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=oX(e,t):r=new Dp,r===void 0)throw new Error(Sn.DBI_DOES_NOT_EXIST);let n;try{let s=new CR(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[gM]=r,e.dbis[t]=n,n}a(ms,"openDBI");function aX(e,t){Mp(e,t),t=t.toString();let r=ms(e,t),n=r.getStats();return r[da.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(aX,"statDBI");async function cX(e,t){try{let r=$n.join(e,t+Yf);return(await qs.stat(r)).size}catch{throw new Error(Sn.INVALID_ENVIRONMENT)}}a(cX,"environmentDataSize");function lX(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(lX,"dropDBI");function uX(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)RM(e,i,i!==t,i===t),n=!0;else throw o}}n&&X3()}a(uX,"initializeDBIs");yM.exports={openDBI:ms,openEnvironment:SM,createEnvironment:rX,listDBIs:AM,listDBIDefinitions:iX,createDBI:RM,dropDBI:lX,statDBI:aX,deleteEnvironment:sX,initializeDBIs:uX,TransactionCursor:wR,environmentDataSize:cX,copyEnvironment:nX,closeEnvironment:TM}});var OM=C((aye,bM)=>{"use strict";var LR=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};bM.exports=LR});var wM=C((lye,NM)=>{"use strict";var MR=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}};NM.exports=MR});var CM=C((dye,IM)=>{"use strict";var vR=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};IM.exports=vR});var vc=C((pye,LM)=>{"use strict";var dX=_t(),fX=OM(),_X=wM(),hX=CM(),Ni=fn(),Wf=xn().LMDB_ERRORS_ENUM,mX=kt(),co=(k(),P(q)),pX=oe(),EX=require("uuid"),_ye=require("lmdb"),{handleHDBError:gX,hdb_errors:SX}=me(),{OVERFLOW_MARKER:hye,MAX_SEARCH_KEY_LENGTH:mye}=mX,PM=ce();PM.initSync();var vp=PM.get(co.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),UR=co.TIME_STAMP_NAMES_ENUM.CREATED_TIME,Mc=co.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function TX(e,t,r,n,s=Ni.getNextMonotonicTime()){kR(e,t,r,n),xR(e,t,r);let i=new fX,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l];DM(u,!0,s);let f=AX(e,t,r,u),d=u[t];o.push(f),c.push(d)}return BR(o,c,n,i,s)}a(TX,"insertRecords");function AX(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][co.FUNC_VAL],n[o]=c)}let l=Ni.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(AX,"insertRecord");function RX(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(RX,"removeSkippedRecords");function DM(e,t,r){let n=r>0;(n||!Number.isInteger(e[Mc]))&&(e[Mc]=r||(r=Ni.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[UR]))&&(e[UR]=r||Ni.getNextMonotonicTime()):delete e[UR]}a(DM,"setTimestamps");function xR(e,t,r){r.indexOf(co.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(co.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(co.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(co.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),dX.initializeDBIs(e,t,r)}a(xR,"initializeTransaction");async function yX(e,t,r,n,s=Ni.getNextMonotonicTime()){kR(e,t,r,n),xR(e,t,r);let i=new _X,o=[],c=[],l=[];for(let u=0;u<n.length;u++){let f=n[u],d=f[t],_;try{_=HR(e,t,f,d,i,!0,s)}catch{i.skipped_hashes.push(d),o.push(u);continue}c.push(_),l.push(d)}return BR(c,l,n,i,s,o)}a(yX,"updateRecords");async function bX(e,t,r,n,s=Ni.getNextMonotonicTime()){try{kR(e,t,r,n)}catch(l){throw gX(l,l.message,SX.HTTP_STATUS_CODES.BAD_REQUEST)}xR(e,t,r);let i=new hX,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l],f;pX.isEmpty(u[t])?(f=EX.v4(),u[t]=f):f=u[t];let d=HR(e,t,u,f,i,!1,s);o.push(d),c.push(f)}return BR(o,c,n,i,s)}a(bX,"upsertRecords");async function BR(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||Ni.getNextMonotonicTime(),RX(r,i),n}a(BR,"finalizeWrite");function HR(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(DM(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][co.FUNC_VAL],r[m]=S)}if(S===R)continue;let E=Ni.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=Ni.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:HR(e,t,r,n,s,i,o))}a(HR,"updateUpsertRecord");function OX(e,t,r){if(Ni.validateEnv(e),t===void 0)throw new Error(Wf.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(Wf.WRITE_ATTRIBUTES_REQUIRED):new Error(Wf.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(OX,"validateBasic");function kR(e,t,r,n){if(OX(e,t,r),!Array.isArray(n))throw n===void 0?new Error(Wf.RECORDS_REQUIRED):new Error(Wf.RECORDS_MUST_BE_ARRAY)}a(kR,"validateWrite");function Up(){}a(Up,"noop");LM.exports={insertRecords:TX,updateRecords:yX,upsertRecords:bX}});var lo=C((gye,NX)=>{NX.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 vM=C((Sye,MM)=>{"use strict";var wX=require("uuid"),FR=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||wX.v4(),this.schema_table=`${this.schema}.${this.table}`}};MM.exports=FR});var xp=C((Aye,UM)=>{"use strict";var IX=vM(),GR=class extends IX{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}};UM.exports=GR});var BM=C((yye,xM)=>{"use strict";xM.exports=PX;var CX="inserted";function PX(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===CX?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(PX,"returnObject")});var Bp=C((Nye,kM)=>{"use strict";var DX=(k(),P(q)),qR=_t(),LX=vc(),{getSystemSchemaPath:MX,getSchemaPath:vX}=Et(),Oye=lo(),{validateBySchema:UX}=st(),zf=require("joi"),xX=xp(),BX=BM(),{handleHDBError:HX,hdb_errors:kX,ClientError:FX}=me(),HM=oe(),{HTTP_STATUS_CODES:GX}=kX,qX="inserted";kM.exports=$X;async function $X(e){let t=UX(e,zf.object({database:zf.string(),schema:zf.string(),table:zf.string().required(),attribute:zf.string().required()}));if(t)throw new FX(t.message);let r=!e.skip_table_check&&HM.checkGlobalSchemaTable(e.schema,e.table);if(r)throw HX(new Error,r,GX.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=HM.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 xX(e.schema,e.table,e.attribute,e.id);try{let i=await qR.openEnvironment(vX(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}`);qR.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await qR.openEnvironment(MX(),DX.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await LX.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_attribute_attributes,[s]);return BX(qX,c,{records:[s]},l)}catch(i){throw i}}a($X,"lmdbCreateAttribute")});var jf=C((Cye,GM)=>{"use strict";var uo=oe(),FM=ee(),Iye=hR(),{getDatabases:VX}=(xe(),P(at)),{ClientError:Uc}=me();GM.exports=KX;function KX(e){if(uo.isEmpty(e))throw new Uc("invalid update parameters defined.");if(uo.isEmptyOrZeroLength(e.schema))throw new Uc("invalid schema specified.");if(uo.isEmptyOrZeroLength(e.table))throw new Uc("invalid table specified.");if(!Array.isArray(e.records))throw new Uc("records must be an array");let t=VX()[e.schema]?.[e.table];if(uo.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&&uo.isEmptyOrZeroLength(o[r]))throw FM.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(!uo.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw FM.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`);!uo.isEmpty(o[r])&&o[r]!==""&&n.has(uo.autoCast(o[r]))&&(o.skip=!0),n.add(uo.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(KX,"insertUpdateValidate")});var $M=C((Dye,qM)=>{"use strict";var $R=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};qM.exports=$R});var YM=C((Mye,KM)=>{"use strict";var VR=_t(),YX=ee(),VM=xn().LMDB_ERRORS_ENUM;KM.exports=WX;async function WX(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 VR.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==VM.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await VR.closeEnvironment(global.lmdb_map[n]),await VR.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==VM.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){YX.error(t)}}a(WX,"cleanLMDBMap")});var iv=C((xye,sv)=>{"use strict";var KR=require("recursive-iterator"),zX=require("alasql"),YR=require("clone"),WM=oe(),{handleHDBError:zM,hdb_errors:jX}=me(),{HDB_ERROR_MSGS:jM,HTTP_STATUS_CODES:QM}=jX,{getDatabases:QX}=(xe(),P(at)),JX=["DISTINCT_ARRAY"],JM=Symbol("validateTables"),WR=Symbol("validateTable"),Uye=Symbol("getAllColumns"),XM=Symbol("validateAllColumns"),Hp=Symbol("findColumn"),ZM=Symbol("validateOrderBy"),Qf=Symbol("validateSegment"),zR=Symbol("validateColumn"),ev=Symbol("setColumnsForTable"),tv=Symbol("checkColumnsForAsterisk"),rv=Symbol("validateGroupBy"),nv=Symbol("hasColumns"),jR=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[JM](),this[tv](),this[XM]()}[JM](){if(this[nv]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[WR](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[WR](t.table)})}}[nv](){let t=!1,r=new KR(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[WR](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=QX();if(!r[t.databaseid])throw zM(new Error,jM.SCHEMA_NOT_FOUND(t.databaseid),QM.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw zM(new Error,jM.TABLE_NOT_FOUND(t.databaseid,t.tableid),QM.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=YR(s);i.table=YR(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)}[tv](){let t=new KR(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[ev](r.tableid)}[ev](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new zX.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[XM](){this[Qf](this.statement.columns,!1),this[Qf](this.statement.joins,!1),this[Qf](this.statement.where,!1),this[rv](this.statement.group,!1),this[Qf](this.statement.order,!0)}[Qf](t,r){if(!t)return;let n=new KR(t),s=[];for(let{node:i,path:o}of n)!WM.isEmpty(i)&&!WM.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[ZM](i):s.push(this[zR](i)));return s}[rv](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&JX.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=YR(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`}[ZM](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[zR](t)}[zR](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]}};sv.exports=jR});var lv=C((Hye,cv)=>{"use strict";var ov=require("lodash"),Jf=require("mathjs"),XX=require("jsonata"),av=oe();cv.exports={distinct_array:a(e=>Array.isArray(e)&&e.length>1?ov.uniqWith(e,ov.isEqual):e,"distinct_array"),searchJSON:ZX,mad:Xf.bind(null,Jf.mad),mean:Xf.bind(null,Jf.mean),mode:Xf.bind(null,Jf.mode),prod:Xf.bind(null,Jf.prod),median:Xf.bind(null,Jf.median)};function Xf(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(Xf,"aggregateFunction");function ZX(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(av.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),av.isEmpty(this.__ala__.res[r])){let n=XX(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(ZX,"searchJSON")});var dv=C((Fye,uv)=>{"use strict";var rr=require("moment"),QR="YYYY-MM-DDTHH:mm:ss.SSSZZ";rr.suppressDeprecationWarnings=!0;uv.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(QR),"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(QR),"get_server_time"),offset_utc:a((e,t)=>rr(e).utc().utcOffset(t).format(QR),"offset_utc")}});var mv=C((qye,hv)=>{"use strict";var e6=require("@turf/area"),t6=require("@turf/length"),r6=require("@turf/circle"),n6=require("@turf/difference"),s6=require("@turf/distance"),i6=require("@turf/boolean-contains"),o6=require("@turf/boolean-equal"),a6=require("@turf/boolean-disjoint"),c6=require("@turf/helpers"),fv=(k(),P(q)),Ke=oe(),fo=ee();hv.exports={geoArea:l6,geoLength:u6,geoCircle:d6,geoDifference:f6,geoDistance:_v,geoNear:_6,geoContains:h6,geoEqual:m6,geoCrosses:p6,geoConvert:E6};function l6(e){if(Ke.isEmpty(e))return NaN;typeof e=="string"&&(e=Ke.autoCastJSON(e));try{return e6.default(e)}catch(t){return fo.trace(t,e),NaN}}a(l6,"geoArea");function u6(e,t){if(Ke.isEmpty(e))return NaN;typeof e=="string"&&(e=Ke.autoCastJSON(e));try{return t6.default(e,{units:t||"kilometers"})}catch(r){return fo.trace(r,e),NaN}}a(u6,"geoLength");function d6(e,t,r){if(Ke.isEmpty(e))return NaN;if(Ke.isEmpty(t))return NaN;typeof e=="string"&&(e=Ke.autoCastJSON(e));try{return r6.default(e,t,{units:r||"kilometers"})}catch(n){return fo.trace(n,e,t),NaN}}a(d6,"geoCircle");function f6(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 n6(e,t)}catch(r){return fo.trace(r,e,t),NaN}}a(f6,"geoDifference");function _v(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 s6.default(e,t,{units:r||"kilometers"})}catch(n){return fo.trace(n,e,t),NaN}}a(_v,"geoDistance");function _6(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 _v(e,t,n)<=r}catch(s){return fo.trace(s,e,t),!1}}a(_6,"geoNear");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 fo.trace(r,e,t),!1}}a(h6,"geoContains");function m6(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 o6.default(e,t)}catch(r){return fo.trace(r,e,t),!1}}a(m6,"geoEqual");function p6(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!a6.default(e,t)}catch(r){return fo.trace(r,e,t),!1}}a(p6,"geoCrosses");function E6(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(fv.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(fv.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Ke.autoCastJSON(e)),c6[t](e,r)}a(E6,"geoConvert")});var kp=C((Vye,pv)=>{var xc=lv(),Vn=dv(),wi=mv();pv.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=Vn.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Vn.current_time,e.fn.extract=e.fn.EXTRACT=Vn.extract,e.fn.date=e.fn.DATE=Vn.date,e.fn.date_format=e.fn.DATE_FORMAT=Vn.date_format,e.fn.date_add=e.fn.DATE_ADD=Vn.date_add,e.fn.date_sub=e.fn.DATE_SUB=Vn.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Vn.date_diff,e.fn.now=e.fn.NOW=Vn.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Vn.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Vn.get_server_time,e.fn.getdate=e.fn.GETDATE=Vn.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Vn.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=wi.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=wi.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=wi.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=wi.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=wi.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=wi.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=wi.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=wi.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=wi.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=wi.geoNear}});var Tv=C((Kye,Sv)=>{"use strict";var Zf=require("lodash"),Tn=require("alasql");Tn.options.cache=!1;var g6=kp(),Ev=require("clone"),Fp=require("recursive-iterator"),ke=ee(),Je=oe(),du=Kn(),S6=(k(),P(q)),{hdb_errors:T6}=me(),{getDatabases:gv}=(xe(),P(at)),A6="IS NULL",Vs="There was a problem performing this search. Please check the logs and try again.";g6(Tn);var JR=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(Ev(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=Zf.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=gv()[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(S6.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&&Zf.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(Ev(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(A6)>-1&&this.tables.forEach(s=>{let i={columnid:gv()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=Zf.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=Zf.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=Zf.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(T6.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)}};Sv.exports=JR});var Wr=C((Wye,Av)=>{"use strict";var R6=iv();Av.exports={searchByConditions:b6,searchByHash:O6,searchByValue:N6,search:w6};var XR=Kn(),{transformReq:ZR}=oe(),y6=Tv();async function b6(e){return ZR(e),XR.searchByConditions(e)}a(b6,"searchByConditions");async function O6(e){ZR(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of XR.searchByHash(e))r&&t.push(r);return t}a(O6,"searchByHash");async function N6(e){ZR(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of XR.searchByValue(e))t.push(r);return t}a(N6,"searchByValue");function w6(e,t){try{let r=new R6(e);r.validate(),new y6(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(w6,"search")});var _o=C((jye,Ov)=>{"use strict";var e_=require("crypto"),I6=ce(),{CONFIG_PARAMS:C6}=(k(),P(q)),yv="aes-256-cbc",P6=32,D6=16,ey=64,bv=32,L6=ey+bv,Rv=new Map;Ov.exports={encrypt:M6,decrypt:v6,createNatsTableStreamName:U6};function M6(e){let t=e_.randomBytes(P6),r=e_.randomBytes(D6),n=e_.createCipheriv(yv,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(M6,"encrypt");function v6(e){let t=e.substr(0,ey),r=e.substr(ey,bv),n=e.substr(L6,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=e_.createDecipheriv(yv,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(v6,"decrypt");function U6(e,t){let r=I6.get(C6.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=Rv.get(r);return n||(n=e_.createHash("md5").update(r).digest("hex"),Rv.set(r,n)),n}a(U6,"createNatsTableStreamName")});var ho=C((Xye,Cv)=>{"use strict";var Jye=Wr(),t_=ee(),{validateBySchema:Nv}=st(),Bc=require("joi"),x6=_o(),Gp=oe(),{handleHDBError:qp,hdb_errors:B6,ClientError:wv}=me(),{HDB_ERROR_MSGS:$p,HTTP_STATUS_CODES:ty}=B6,Iv=ce();Iv.initSync();var{getDatabases:ry}=(xe(),P(at)),H6=require("fs-extra"),k6=(k(),P(q));Cv.exports={describeAll:F6,describeTable:Vp,describeSchema:G6};async function F6(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=ry(),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){t_.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 t_.error("Got an error in describeAll"),t_.error(t),qp(new Error,$p.DESCRIBE_ALL_ERR)}}a(F6,"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=Nv(e,Bc.object({database:Bc.string(),table:Bc.string().required(),exact_count:Bc.boolean().strict()}));if(i)throw new wv(i.message);let c=ry()[r];if(!c)throw qp(new Error,$p.SCHEMA_NOT_FOUND(e.schema),ty.NOT_FOUND);let l=c[n];if(!l)throw qp(new Error,$p.TABLE_NOT_FOUND(e.schema,e.table),ty.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 H6.stat(l.primaryStore.env.path)).size}catch(h){t_.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")),Iv.get(k6.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(_.clustering_stream_name=x6.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){t_.warn(`unable to stat table dbi due to ${h}`)}return _}a(Vp,"descTable");async function G6(e){Gp.transformReq(e);let t=Nv(e,Bc.object({database:Bc.string(),exact_count:Bc.boolean().strict()}));if(t)throw new wv(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=ry()[n];if(!i)throw qp(new Error,$p.SCHEMA_NOT_FOUND(e.schema),ty.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(G6,"describeSchema")});var ps=C((rbe,vv)=>{var q6=lo(),{callbackify:Dv,promisify:$6}=require("util"),{getDatabases:Lv}=(xe(),P(at));vv.exports={setSchemaDataToGlobal:Pv,getTableSchema:V6,getSystemSchema:K6,setSchemaDataToGlobalAsync:$6(Pv)};var Mv=ho(),ebe=Dv(Mv.describeAll),tbe=Dv(Mv.describeTable);function Pv(e){global.hdb_schema=Lv(),e&&e()}a(Pv,"setSchemaDataToGlobal");function V6(e,t,r){let n=Lv()[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(V6,"getTableSchema");function K6(){return q6}a(K6,"getSystemSchema")});var sy=C((sbe,Bv)=>{var Y6=st(),ny=require("joi"),{hdb_table:W6,hdb_database:Uv}=Oi(),xv={schema:Uv,database:Uv,table:W6},z6={date:ny.date().iso().required()},j6={timestamp:ny.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};Bv.exports=function(e,t){let r=t==="timestamp"?{...xv,...j6}:{...xv,...z6},n=ny.object(r);return Y6.validateBySchema(e,n)}});var Fv=C((ibe,kv)=>{var Q6=st(),iy=require("joi"),{hdb_table:J6,hdb_database:Hv}=Oi(),X6=iy.object({schema:Hv,database:Hv,table:J6,hash_values:iy.array().required(),ids:iy.array()});kv.exports=function(e){return Q6.validateBySchema(e,X6)}});var ly=C((obe,Gv)=>{"use strict";var oy=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}},ay=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}},cy=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};Gv.exports={InsertObject:oy,NoSQLSeachObject:ay,DeleteResponseObject:cy}});var Fc=C((cbe,Yv)=>{"use strict";var $v=sy(),Z6=Fv(),Hc=oe(),qv=require("moment"),Vv=ee(),{promisify:eZ,callbackify:tZ}=require("util"),kc=(k(),P(q)),rZ=ps(),uy=eZ(rZ.getTableSchema),dy=Kn(),{DeleteResponseObject:nZ}=ly(),{handleHDBError:fa,hdb_errors:sZ}=me(),{HDB_ERROR_MSGS:Kp,HTTP_STATUS_CODES:_a}=sZ,iZ="records successfully deleted",oZ=tZ(Kv);Yv.exports={delete:oZ,deleteRecord:Kv,deleteFilesBefore:aZ,deleteAuditLogsBefore:cZ};async function aZ(e){let t=$v(e,"date");if(t)throw fa(t,t.message,_a.BAD_REQUEST,void 0,void 0,!0);if(Hc.transformReq(e),!qv(e.date,qv.ISO_8601).isValid())throw fa(new Error,Kp.INVALID_DATE,_a.BAD_REQUEST,kc.LOG_LEVELS.ERROR,Kp.INVALID_DATE,!0);let n=Hc.checkSchemaTableExist(e.schema,e.table);if(n)throw fa(new Error,n,_a.NOT_FOUND,kc.LOG_LEVELS.ERROR,n,!0);let s=await dy.deleteRecordsBefore(e);if(await uy(e.schema,e.table),Vv.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(aZ,"deleteFilesBefore");async function cZ(e){let t=$v(e,"timestamp");if(t)throw fa(t,t.message,_a.BAD_REQUEST,void 0,void 0,!0);if(Hc.transformReq(e),isNaN(e.timestamp))throw fa(new Error,Kp.INVALID_VALUE("Timestamp"),_a.BAD_REQUEST,kc.LOG_LEVELS.ERROR,Kp.INVALID_VALUE("Timestamp"),!0);let r=Hc.checkSchemaTableExist(e.schema,e.table);if(r)throw fa(new Error,r,_a.NOT_FOUND,kc.LOG_LEVELS.ERROR,r,!0);let n=await dy.deleteAuditLogsBefore(e);return await uy(e.schema,e.table),Vv.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(cZ,"deleteAuditLogsBefore");async function Kv(e){e.ids&&(e.hash_values=e.ids);let t=Z6(e);if(t)throw fa(t,t.message,_a.BAD_REQUEST,void 0,void 0,!0);Hc.transformReq(e);let r=Hc.checkSchemaTableExist(e.schema,e.table);if(r)throw fa(new Error,r,_a.NOT_FOUND,kc.LOG_LEVELS.ERROR,r,!0);try{await uy(e.schema,e.table);let n=await dy.deleteRecords(e);return Hc.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${iZ}`),n}catch(n){if(n.message===kc.SEARCH_NOT_FOUND_MESSAGE){let s=new nZ;return s.message=kc.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(Kv,"deleteRecord")});var Yp={};Ue(Yp,{HASH_FUNCTION:()=>s_,hash:()=>hy,validate:()=>my});function fy(e=n_){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ";return Array.from(r_.randomBytes(e)).map(r=>t[r%t.length]).join("")}function hy(e,t=s_[zv?.toUpperCase()]??"sha256"){return _y[t](e)}function my(e,t,r=s_[zv?.toUpperCase()]??"sha256"){return e?lZ[r](e,t):!1}var r_,fu,Wv,zv,n_,jv,s_,_y,lZ,Wp=Re(()=>{r_=M(require("node:crypto")),fu=M(require("argon2")),Wv=M(ce());k();zv=(0,Wv.get)(B.AUTHENTICATION_HASHFUNCTION)?.toLowerCase(),n_=16,jv=9,s_=(n=>(n.MD5="md5",n.SHA256="sha256",n.ARGON2ID="argon2id",n))(s_||{});a(fy,"generateSalt");_y={md5:a((e,t=void 0)=>{t=t??fy(jv);let r=r_.createHash("md5").update(e+t).digest("hex");return t+r},"md5"),sha256:a((e,t=void 0)=>{t=t??fy(n_);let r=r_.createHash("sha256").update(e+t).digest("hex");return t+r},"sha256"),argon2id:a(async e=>{let t=fy(n_),r=await fu.hash(e,{type:fu.argon2id,salt:Buffer.from(t)});return t+r},"argon2id")},lZ={md5:a((e,t)=>{let r=e.slice(0,jv);return e===_y.md5(t,r)},"md5"),sha256:a((e,t)=>{let r=e.slice(0,n_);return e===_y.sha256(t,r)},"sha256"),argon2id:a(async(e,t)=>await fu.verify(e.slice(n_),t),"argon2id")};a(hy,"hash");a(my,"validate")});var Jv=C((fbe,Qv)=>{var py=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 uZ(e){return zr.password.presence=!0,zr.username.presence=!0,zr.role.presence=!0,zr.active.presence=!0,py.validateObject(e,zr)}a(uZ,"addUserValidation");function dZ(e){return zr.password.presence=!1,zr.username.presence=!0,zr.role.presence=!1,zr.active.presence=!1,py.validateObject(e,zr)}a(dZ,"alterUserValidation");function fZ(e){return zr.password.presence=!1,zr.username.presence=!0,zr.role.presence=!1,zr.active.presence=!1,py.validateObject(e,zr)}a(fZ,"dropUserValidation");Qv.exports={addUserValidation:uZ,alterUserValidation:dZ,dropUserValidation:fZ}});var Pt=C((mbe,Zv)=>{"use strict";var{platform:hbe}=require("os"),_Z="nats-server.zip",Ey="nats-server",hZ=process.platform==="win32"?`${Ey}.exe`:Ey,mZ=/^[^\s.,*>]+$/,Xv="__request__",pZ=a(e=>`${e}.${Xv}`,"REQUEST_SUBJECT"),EZ={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},gZ={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},SZ={HUB:"hub.pid",LEAF:"leaf.pid"},TZ={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},AZ={SUCCESS:"success",ERROR:"error"},RZ={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},yZ={TXN:"txn",MSGID:"msgid"},_u={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},bZ={[_u.ERR]:1,[_u.WRN]:2,[_u.INF]:3,[_u.DBG]:4,[_u.TRC]:5},OZ={debug:"-D",trace:"-DVV"};Zv.exports={NATS_SERVER_ZIP:_Z,NATS_SERVER_NAME:Ey,NATS_BINARY_NAME:hZ,PID_FILES:SZ,NATS_CONFIG_FILES:gZ,SERVER_SUFFIX:TZ,NATS_TERM_CONSTRAINTS_RX:mZ,REQUEST_SUFFIX:Xv,UPDATE_REMOTE_RESPONSE_STATUSES:AZ,CLUSTER_STATUS_STATUSES:RZ,REQUEST_SUBJECT:pZ,SUBJECT_PREFIXES:yZ,MSG_HEADERS:EZ,LOG_LEVELS:_u,LOG_LEVEL_FLAGS:OZ,LOG_LEVEL_HIERARCHY:bZ}});var An=C((Ebe,Nr)=>{"use strict";var rU="username is required",nU="nothing to update, must supply active, role or password to update",sU="password cannot be an empty string",iU="If role is specified, it cannot be empty.",oU="active must be true or false";Nr.exports.addUser=vZ;Nr.exports.alterUser=UZ;Nr.exports.dropUser=BZ;Nr.exports.getSuperUser=qZ;Nr.exports.userInfo=HZ;Nr.exports.listUsers=jp;Nr.exports.listUsersExternal=kZ;Nr.exports.setUsersWithRolesCache=Gc;Nr.exports.findAndValidateUser=Ny;Nr.exports.getClusterUser=$Z;Nr.exports.getUsersWithRolesCache=GZ;Nr.exports.USERNAME_REQUIRED=rU;Nr.exports.ALTERUSER_NOTHING_TO_UPDATE=nU;Nr.exports.EMPTY_PASSWORD=sU;Nr.exports.EMPTY_ROLE=iU;Nr.exports.ACTIVE_BOOLEAN=oU;var aU=Rn(),NZ=Fc(),i_=(Wp(),P(Yp)),cU=Jv(),o_=Wr(),Ry=po(),Ii=oe(),lU=require("validate.js"),yy=ee(),{promisify:wZ}=require("util"),by=_o(),Sy=(k(),P(q)),eU=Pt(),IZ=It(),CZ=ce(),PZ=lo(),{hdb_errors:DZ,ClientError:Ks}=me(),{HTTP_STATUS_CODES:mo,AUTHENTICATION_ERROR_MSGS:gy,HDB_ERROR_MSGS:hu}=DZ,{UserEventMsg:Oy}=Ys(),Ty=require("lodash"),{server:zp}=(Mr(),P(Wl)),LZ=ee();zp.getUser=(e,t)=>Ny(e,t,t!=null);zp.authenticateUser=(e,t)=>Ny(e,t);var uU={username:!0,active:!0,role:!0,password:!0},tU=new Map,MZ=wZ(NZ.delete),Ay=CZ.get(Sy.CONFIG_PARAMS.AUTHENTICATION_HASHFUNCTION)??i_.HASH_FUNCTION.SHA256,Ci;async function vZ(e){let t=lU.cleanAttributes(e,uU),r=cU.addUserValidation(t);if(r)throw new Ks(r.message);let n=await o_.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),mo.NOT_FOUND);if(n.length>1)throw new Ks(hu.DUP_ROLES_FOUND(t.role),mo.CONFLICT);n[0].permission.cluster_user===!0&&(t.hash=by.encrypt(t.password)),t.password=await i_.hash(t.password,Ay),t.hash_function=Ay,t.role=n[0].id;let s=await aU.insert({operation:"insert",schema:"system",table:"hdb_user",records:[t]});if(yy.debug(s),await Gc(),s.skipped_hashes.length===1)throw new Ks(hu.USER_ALREADY_EXISTS(t.username),mo.CONFLICT);return Ry.signalUserChange(new Oy(process.pid)),`${t.username} successfully added`}a(vZ,"addUser");async function UZ(e){let t=lU.cleanAttributes(e,uU);if(Ii.isEmptyOrZeroLength(t.username))throw new Error(rU);if(Ii.isEmptyOrZeroLength(t.password)&&Ii.isEmptyOrZeroLength(t.role)&&Ii.isEmptyOrZeroLength(t.active))throw new Error(nU);if(!Ii.isEmpty(t.password)&&Ii.isEmptyOrZeroLength(t.password.trim()))throw new Error(sU);if(!Ii.isEmpty(t.active)&&!Ii.isBoolean(t.active))throw new Error(oU);if(!Ii.isEmpty(t.password)&&!Ii.isEmptyOrZeroLength(t.password.trim())&&(xZ(t.username)&&(t.hash=by.encrypt(t.password)),t.password=await i_.hash(t.password,Ay)),t.role==="")throw new Error(iU);if(t.role){let n=await o_.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),mo.NOT_FOUND);if(n.length>1)throw new Ks(hu.DUP_ROLES_FOUND(t.role),mo.CONFLICT);t.role=n[0].id}let r=await aU.update({operation:"update",schema:"system",table:"hdb_user",records:[t]});return await Gc(),Ry.signalUserChange(new Oy(process.pid)),r}a(UZ,"alterUser");function xZ(e){let t=!1,r=Ci.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(xZ,"isClusterUser");async function BZ(e){let t=cU.dropUserValidation(e);if(t)throw new Ks(t.message);if(Ci.get(e.username)===void 0)throw new Ks(hu.USER_NOT_EXIST(e.username),mo.NOT_FOUND);let r=await MZ({table:"hdb_user",schema:"system",hash_values:[e.username]});return yy.debug(r),await Gc(),Ry.signalUserChange(new Oy(process.pid)),`${e.username} successfully deleted`}a(BZ,"dropUser");async function HZ(e){let t={};if(!e||!e.hdb_user)return"There was no user info in the body";t=Ty.cloneDeep(e.hdb_user);let r=await o_.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(HZ,"userInfo");async function kZ(){let e=await jp();return e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token,delete t.hash_function}),[...e.values()]}a(kZ,"listUsersExternal");async function jp(){let e=await o_.searchByValue({schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]}),t={};for(let s of e)t[s.id]=Ty.cloneDeep(s);if(Object.keys(t).length===0)return null;let r=await o_.searchByValue({schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]}),n=new Map;for(let s of r)s=Ty.cloneDeep(s),s.role=t[s.role],FZ(s.role),n.set(s.username,s);return n}a(jp,"listUsers");function FZ(e){if(!e){yy.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(PZ)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}a(FZ,"appendSystemTablesToRole");async function Gc(e=void 0){e?Ci=e:Ci=await jp()}a(Gc,"setUsersWithRolesCache");async function GZ(){return Ci||await Gc(),Ci}a(GZ,"getUsersWithRolesCache");async function Ny(e,t,r=!0){Ci||await Gc();let n=Ci.get(e);if(!n){if(!r)return{username:e};throw new Ks(gy.GENERIC_AUTH_FAIL,mo.UNAUTHORIZED)}if(n&&!n.active)throw new Ks(gy.USER_INACTIVE,mo.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(tU.get(t)===n.password)return s;{let i=i_.validate(n.password,t,n.hash_function||i_.HASH_FUNCTION.MD5);if(i?.then&&(i=await i),i===!0)tU.set(t,n.password);else throw new Ks(gy.GENERIC_AUTH_FAIL,mo.UNAUTHORIZED)}}return s}a(Ny,"findAndValidateUser");async function qZ(){Ci||await Gc();for(let[,e]of Ci)if(e.role.role==="super_user")return e}a(qZ,"getSuperUser");async function $Z(){let e=await jp(),t=IZ.getConfigFromFile(Sy.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!(r==null||r?.role?.role!==Sy.ROLE_TYPES_ENUM.CLUSTER_USER))return r.decrypt_hash=by.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+eU.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+eU.SERVER_SUFFIX.ADMIN,r}a($Z,"getClusterUser");var dU=[];zp.invalidateUser=function(e){for(let t of dU)try{t(e)}catch(r){LZ.error("Error invalidating user",r)}};zp.onInvalidatedUser=function(e){dU.push(e)}});var c_=C((Abe,mU)=>{"use strict";var qc=ee(),Yn=(k(),P(q)),VZ=YM(),Sbe=ps(),Tbe=ho(),KZ=An(),{validateEvent:fU}=Ys(),a_=Kn(),YZ=require("process"),{resetDatabases:WZ}=(xe(),P(at)),zZ={[Yn.ITC_EVENT_TYPES.SCHEMA]:jZ,[Yn.ITC_EVENT_TYPES.USER]:hU};async function jZ(e){let t=fU(e);if(t){qc.error(t);return}qc.trace("ITC schemaHandler received schema event:",e),await VZ(e.message),await QZ(e.message)}a(jZ,"schemaHandler");async function QZ(e){try{a_.resetReadTxn(Yn.SYSTEM_SCHEMA_NAME,Yn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),a_.resetReadTxn(Yn.SYSTEM_SCHEMA_NAME,Yn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),a_.resetReadTxn(Yn.SYSTEM_SCHEMA_NAME,Yn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=WZ();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){qc.error(t)}}a(QZ,"syncSchemaMetadata");var _U=[];async function hU(e){try{try{a_.resetReadTxn(Yn.SYSTEM_SCHEMA_NAME,Yn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),a_.resetReadTxn(Yn.SYSTEM_SCHEMA_NAME,Yn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){qc.warn(r)}let t=fU(e);if(t){qc.error(t);return}qc.trace(`ITC userHandler ${Yn.HDB_ITC_CLIENT_PREFIX}${YZ.pid} received user event:`,e),await KZ.setUsersWithRolesCache();for(let r of _U)r()}catch(t){qc.error(t)}}a(hU,"userHandler");hU.addListener=function(e){_U.push(e)};mU.exports=zZ});var Ys=C((wbe,EU)=>{"use strict";var ybe=ee(),wy=oe(),JZ=(k(),P(q)),{ITC_ERRORS:l_}=xn(),{parentPort:bbe,threadId:XZ,isMainThread:ZZ,workerData:Obe}=require("worker_threads"),{onMessageFromWorkers:e8,broadcast:Nbe,broadcastWithAcknowledgement:t8}=it();EU.exports={sendItcEvent:r8,validateEvent:pU,SchemaEventMsg:n8,UserEventMsg:s8};var Qp;e8(async(e,t)=>{Qp=Qp||c_(),pU(e),Qp[e.type]&&await Qp[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function r8(e){return!ZZ&&e.message&&(e.message.originator=XZ),t8(e)}a(r8,"sendItcEvent");function pU(e){if(typeof e!="object")return l_.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||wy.isEmpty(e.type))return l_.MISSING_TYPE;if(!e.hasOwnProperty("message")||wy.isEmpty(e.message))return l_.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||wy.isEmpty(e.message.originator))return l_.MISSING_ORIGIN;if(JZ.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return l_.INVALID_EVENT(e.type)}a(pU,"validateEvent");function n8(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(n8,"SchemaEventMsg");function s8(e){this.originator=e}a(s8,"UserEventMsg")});var po=C((Pbe,AU)=>{"use strict";var gU=(k(),P(q)),Cbe=oe(),Jp=ee(),SU=$M(),mu,{sendItcEvent:TU}=Ys();function i8(e){try{Jp.info("signalSchemaChange called with message:",e),mu=mu||c_();let t=new SU(gU.ITC_EVENT_TYPES.SCHEMA,e);return mu.schema(t),TU(t)}catch(t){Jp.error(t)}}a(i8,"signalSchemaChange");function o8(e){try{Jp.trace("signalUserChange called with message:",e),mu=mu||c_();let t=new SU(gU.ITC_EVENT_TYPES.USER,e);return mu.user(t),TU(t)}catch(t){Jp.error(t)}}a(o8,"signalUserChange");AU.exports={signalSchemaChange:i8,signalUserChange:o8}});var Xp=C((Lbe,yU)=>{"use strict";var RU=oe(),a8=(k(),P(q)),c8=ee(),l8=Bp(),u8=xp(),d8=po(),{SchemaEventMsg:f8}=Ys(),_8="already exists in";yU.exports=h8;async function h8(e,t,r){if(RU.isEmptyOrZeroLength(r))return r;let n=[];RU.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 m8(e,t.schema,t.name,i)})),s}a(h8,"lmdbCheckForNewAttributes");async function m8(e,t,r,n){let s=new u8(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await p8(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(_8))c8.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(m8,"createNewAttribute");async function p8(e){let t;return t=await l8(e),d8.signalSchemaChange(new f8(process.pid,a8.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(p8,"createAttribute")});var pu=C((vbe,bU)=>{"use strict";var Iy=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}};bU.exports=Iy});var NU=C((xbe,OU)=>{"use strict";var E8=pu(),g8=(k(),P(q)).OPERATIONS_ENUM,Cy=class extends E8{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(g8.INSERT,r,n,s,i),this.records=t}};OU.exports=Cy});var IU=C((Hbe,wU)=>{"use strict";var S8=pu(),T8=(k(),P(q)).OPERATIONS_ENUM,Py=class extends S8{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(T8.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};wU.exports=Py});var PU=C((Fbe,CU)=>{"use strict";var A8=pu(),R8=(k(),P(q)).OPERATIONS_ENUM,Dy=class extends A8{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(R8.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};CU.exports=Dy});var LU=C((qbe,DU)=>{"use strict";var y8=pu(),b8=(k(),P(q)).OPERATIONS_ENUM,Ly=class extends y8{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(b8.DELETE,n,s,t,i),this.original_records=r}};DU.exports=Ly});var u_=C((Kbe,xU)=>{"use strict";var Vbe=require("path"),MU=_t(),O8=NU(),N8=IU(),w8=PU(),I8=LU(),Eu=kt(),vU=oe(),{CONFIG_PARAMS:C8}=(k(),P(q)),UU=ce();UU.initSync();var Zp=(k(),P(q)).OPERATIONS_ENUM,{getTransactionAuditStorePath:P8}=Et();xU.exports=D8;async function D8(e,t){if(UU.get(C8.LOGGING_AUDITLOG)===!1)return;let r=P8(e.schema,e.table),n=await MU.openEnvironment(r,e.table,!0),s=L8(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){MU.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),vU.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(D8,"writeTransaction");function L8(e,t){let r=vU.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===Zp.INSERT)return new O8(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Zp.UPDATE)return new N8(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Zp.UPSERT)return new w8(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Zp.DELETE)return new I8(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(L8,"createTransactionObject")});var My=C((zbe,BU)=>{"use strict";var M8=jf(),Wbe=Rf(),d_=(k(),P(q)),v8=yf(),U8=vc().insertRecords,x8=_t(),B8=ee(),H8=Xp(),{getSchemaPath:k8}=Et(),F8=u_();BU.exports=G8;async function G8(e){try{let{schema_table:t,attributes:r}=M8(e);v8(e,r,t.hash_attribute),e.schema!==d_.SYSTEM_SCHEMA_NAME&&(r.includes(d_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(d_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(d_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(d_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await H8(e.hdb_auth_header,t,r),s=k8(e.schema,e.table),i=await x8.openEnvironment(s,e.table),o=await U8(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await F8(e,o)}catch(c){B8.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(G8,"lmdbCreateRecords")});var FU=C((Qbe,kU)=>{"use strict";var HU=(k(),P(q)),q8=My(),$8=Rf(),V8=require("fs-extra"),{getSchemaPath:K8}=Et();kU.exports=Y8;async function Y8(e){let t=[{name:e.schema,createddate:Date.now()}],r=new $8(HU.SYSTEM_SCHEMA_NAME,HU.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await q8(r),await V8.mkdirp(K8(e.schema))}a(Y8,"lmdbCreateSchema")});var qU=C((Xbe,GU)=>{"use strict";var vy=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}};GU.exports=vy});var YU=C((nOe,KU)=>{"use strict";var $U=_t(),Uy=fn(),xy=xn().LMDB_ERRORS_ENUM,W8=kt(),VU=ee(),eOe=oe(),z8=require("lmdb"),j8=qU(),Q8=(k(),P(q)),{OVERFLOW_MARKER:tOe,MAX_SEARCH_KEY_LENGTH:rOe}=W8,J8=Q8.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function X8(e,t,r,n){if(Uy.validateEnv(e),t===void 0)throw new Error(xy.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(xy.IDS_REQUIRED):new Error(xy.IDS_MUST_BE_ITERABLE);try{let s=$U.listDBIs(e);$U.initializeDBIs(e,t,s);let i=new j8,o,c=[],l=[];for(let _=0,h=r.length;_<h;_++)try{o=r[_];let m=e.dbis[t].get(o);if(!m||n&&m[J8]>n){i.skipped.push(o);continue}let S=e.dbis[t].ifVersion(o,z8.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=Uy.getIndexedValues(T);if(N)for(let v=0,H=N.length;v<H;v++)E.remove(N[v],o)}catch{VU.warn(`cannot delete from attribute: ${R}, ${T}:${o}`)}}});c.push(S),l.push(o),i.original_records.push(m)}catch(m){VU.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=Uy.getNextMonotonicTime(),i}catch(s){throw s}}a(X8,"deleteRecords");KU.exports={deleteRecords:X8}});var f_=C((iOe,zU)=>{"use strict";var gu=oe(),Z8=YU(),e5=_t(),{getSchemaPath:t5}=Et(),r5=u_(),n5=ee();zU.exports=s5;async function s5(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 WU([],[]);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=t5(e.schema,e.table),i=await e5.openEnvironment(s,e.table),o=await Z8.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await r5(e,o)}catch(c){n5.error(`unable to write transaction due to ${c.message}`)}return WU(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(s5,"lmdbDeleteRecords");function WU(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(WU,"createDeleteResponse")});var Hy=C((cOe,jU)=>{"use strict";var i5=(k(),P(q)),aOe=fn();function By(e,t){let r=Object.create(null);if(t.length===1&&i5.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(By,"parseRow");function o5(e,t,r,n){let s=By(r,e);n.push(s)}a(o5,"searchAll");function a5(e,t,r,n){let s=By(r,e);n[t]=s}a(a5,"searchAllToMap");function c5(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(c5,"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 l5(e,t,r,n,s,i){t.toString().endsWith(e)&&$c(t,r,n,s,i)}a(l5,"endsWith");function u5(e,t,r,n,s,i){t.toString().includes(e)&&$c(t,r,n,s,i)}a(u5,"contains");function d5(e,t,r,n,s,i){t>e&&$c(t,r,n,s,i)}a(d5,"greaterThanCompare");function f5(e,t,r,n,s,i){t>=e&&$c(t,r,n,s,i)}a(f5,"greaterThanEqualCompare");function _5(e,t,r,n,s,i){t<e&&$c(t,r,n,s,i)}a(_5,"lessThanCompare");function h5(e,t,r,n,s,i){t<=e&&$c(t,r,n,s,i)}a(h5,"lessThanEqualCompare");jU.exports={parseRow:By,searchAll:o5,searchAllToMap:a5,iterateDBI:c5,endsWith:l5,contains:u5,greaterThanCompare:d5,greaterThanEqualCompare:f5,lessThanCompare:_5,lessThanEqualCompare:h5,pushResults:$c}});var Su=C((_Oe,r0)=>{"use strict";var ha=_t(),uOe=ee(),Wn=fn(),eE=kt(),zt=xn().LMDB_ERRORS_ENUM,dOe=oe(),m5=(k(),P(q)),tE=Hy(),{parseRow:p5}=tE,fOe=require("lmdb"),{OVERFLOW_MARKER:QU,MAX_SEARCH_KEY_LENGTH:E5}=eE;function JU(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(JU,"iterateFullIndex");function __(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(__,"iterateRangeBetween");function Vc(e,t,r,n){let s=e.database||e,i=ha.openDBI(s,r);i[eE.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&ha.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 XU(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(QU)){if(!s)if(r)s=ha.openDBI(e,r);else{let l=ha.listDBIs(e);for(let u=0,f=l.length;u<f&&(s=ha.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(XU,"getOverflowCheck");function g5(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=h_(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(u=>p5(u.value,r))))}a(g5,"searchAll");function S5(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=h_(e.database||e,r);let o=new Map;for(let{key:c,value:l}of JU(e,t,t,n,s,i))o.set(c,tE.parseRow(l,r));return o}a(S5,"searchAllToMap");function T5(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=JU(e,void 0,t,r,n,s),c=o.transaction,l=XU(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(T5,"iterateDBI");function A5(e,t){if(Wn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);return ha.statDBI(e,t).entryCount}a(A5,"countAll");function R5(e,t,r,n,s=!1,i=void 0,o=void 0){return ma(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(R5,"equals");function y5(e,t,r){return ma(e,t,r),ha.openDBI(e,t).getValuesCount(r)}a(y5,"count");function b5(e,t,r,n,s=!1,i=void 0,o=void 0){return ma(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(b5,"startsWith");function O5(e,t,r,n,s=!1,i=void 0,o=void 0){return ZU(e,t,r,n,s,i,o,!0)}a(O5,"endsWith");function ZU(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return ma(e,r,n),Vc(e,null,r,(l,u,f,d)=>{let _=XU(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(QU)?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(ZU,"contains");function N5(e,t,r,n,s=!1,i=void 0,o=void 0){ma(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),__(e,t,r,n,l,s,i,o,!0,!1)}a(N5,"greaterThan");function w5(e,t,r,n,s=!1,i=void 0,o=void 0){ma(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),__(e,t,r,n,l,s,i,o,!1,!1)}a(w5,"greaterThanEqual");function I5(e,t,r,n,s=!1,i=void 0,o=void 0){ma(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),__(e,t,r,l,n,s,i,o,!1,!0)}a(I5,"lessThan");function C5(e,t,r,n,s=!1,i=void 0,o=void 0){ma(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),__(e,t,r,l,n,s,i,o,!1,!1)}a(C5,"lessThanEqual");function P5(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 __(e,t,r,n,s,i,o,c)}a(P5,"between");function D5(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=h_(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(D5,"searchByHash");function L5(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(L5,"checkHashExists");function M5(e,t,r,n,s=[]){return t0(e,t,r,n,s),e0(e,t,r,n,s).map(i=>i[1])}a(M5,"batchSearchByHash");function v5(e,t,r,n,s=[]){t0(e,t,r,n,s);let i=new Map;for(let[o,c]of e0(e,t,r,n,s))i.set(o,c);return i}a(v5,"batchSearchByHashToMap");function e0(e,t,r,n,s=[]){return Vc(e,t,t,(i,o,c)=>{r=h_(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(e0,"batchHashSearch");function t0(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(t0,"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 ma(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>E5)throw new Error(zt.SEARCH_VALUE_TOO_LARGE)}a(ma,"validateComparisonFunctions");function h_(e,t){return t.length===1&&m5.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=ha.listDBIs(e)),t}a(h_,"setGetWholeRowAttributes");r0.exports={searchAll:g5,searchAllToMap:S5,count:y5,countAll:A5,equals:R5,startsWith:b5,endsWith:O5,contains:ZU,searchByHash:D5,setGetWholeRowAttributes:h_,batchSearchByHash:M5,batchSearchByHashToMap:v5,checkHashExists:L5,iterateDBI:T5,greaterThan:N5,greaterThanEqual:w5,lessThan:I5,lessThanEqual:C5,between:P5}});var Tu=C((mOe,a0)=>{var n0=require("lodash"),s0=st(),qe=require("joi"),U5=oe(),{hdb_schema_table:m_,checkValidTable:i0,hdb_table:o0,hdb_database:nE}=Oi(),{handleHDBError:x5,hdb_errors:B5}=me(),{getDatabases:H5}=(xe(),P(at)),{HTTP_STATUS_CODES:k5}=B5,F5=qe.object({database:nE,schema:nE,table:o0,search_attribute:m_,search_value:qe.any().required(),get_attributes:qe.array().min(1).items(qe.alternatives(m_,qe.object())).optional(),desc:qe.bool(),limit:qe.number().integer().min(1),offset:qe.number().integer().min(0)}),G5=qe.object({database:nE,schema:nE,table:o0,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(m_,qe.object())).optional(),sort:qe.object({attribute:qe.alternatives(m_,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(m_,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()});a0.exports=function(e,t){let r=null;switch(t){case"value":r=s0.validateBySchema(e,F5);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(i0("database",e.schema)),i(i0("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=s0.validateBySchema(e,G5);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=U5.checkGlobalSchemaTable(e.schema,e.table);if(s)return x5(new Error,s,k5.NOT_FOUND);let o=H5()[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=n0.filter(c,f=>f!=="*"&&!f.startsWith?.("$")&&f.attribute!=="*"&&!Array.isArray(f)&&!f.name&&!n0.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 ky=C((EOe,c0)=>{"use strict";var q5=_t(),$5=Tu(),{getSchemaPath:V5}=Et();c0.exports=K5;function K5(e){let t=$5(e,"hashes");if(t)throw t;let r=V5(e.schema,e.table);return q5.openEnvironment(r,e.table)}a(K5,"initialize")});var Fy=C((SOe,l0)=>{"use strict";var Y5=Su(),W5=ky();l0.exports=z5;async function z5(e){let t=await W5(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return Y5.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(z5,"lmdbGetDataByHash")});var Au=C((AOe,u0)=>{"use strict";var Gy=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};u0.exports=Gy});var f0=C((bOe,d0)=>{"use strict";var yOe=Au(),j5=Su(),Q5=ky();d0.exports=J5;async function J5(e){let t=await Q5(e),r=global.hdb_schema[e.schema][e.table];return j5.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(J5,"lmdbSearchByHash")});var Ws=C((NOe,_0)=>{"use strict";var qy=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}};_0.exports=qy});var sE=C((IOe,S0)=>{"use strict";var jr=Su(),X5=_t(),Z5=oe(),$e=kt(),Kc=(k(),P(q)),e9=lo(),h0=xn().LMDB_ERRORS_ENUM,{getSchemaPath:t9}=Et(),Eo=Kc.SEARCH_WILDCARDS;async function r9(e,t,r){let n;e.schema===Kc.SYSTEM_SCHEMA_NAME?n=e9[e.table]:n=global.hdb_schema[e.schema][e.table];let s=g0(e,n.hash_attribute,r,t);return p0(e,s,n.hash_attribute,r)}a(r9,"prepSearch");async function p0(e,t,r,n){let s=t9(e.schema,e.table),i=await X5.openEnvironment(s,e.table),o=E0(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(n9(e,r)===!1){let f=e.search_attribute;if(f===r)return n?m0(o,()=>!0):o.map(_=>({[r]:_.key}));let d=a(_=>({[r]:_.value,[f]:_.key}),"toObject");return n?m0(o,d):o.map(d)}let u=e.search_attribute===r?o.map(f=>f.key):o.map(f=>f.value);return n===!0?jr.batchSearchByHashToMap(c,r,e.get_attributes,u):jr.batchSearchByHash(c,r,e.get_attributes,u)}a(p0,"executeSearch");function E0(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=jr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.CONTAINS:s=jr.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=jr.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=jr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return jr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case $e.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return jr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case $e.SEARCH_TYPES.SEARCH_ALL:return jr.searchAll(e,n,t.get_attributes,o,c,l);case $e.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return jr.searchAllToMap(e,n,t.get_attributes,o,c,l);case $e.SEARCH_TYPES.BETWEEN:s=jr.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=jr.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=jr.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=jr.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=jr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;default:return Object.create(null)}return s}a(E0,"searchByType");function m0(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(m0,"createMapFromIterable");function n9(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(n9,"checkToFetchMore");function g0(e,t,r,n){if(Z5.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),Eo.indexOf(s)>-1)return r===!0?$e.SEARCH_TYPES.SEARCH_ALL_TO_MAP:$e.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(Eo[0])<0&&s.indexOf(Eo[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(Eo.indexOf(i)>=0&&Eo.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),$e.SEARCH_TYPES.CONTAINS;if(Eo.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),$e.SEARCH_TYPES.ENDS_WITH;if(Eo.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),$e.SEARCH_TYPES.STARTS_WITH;if(s.includes(Eo[0])||s.includes(Eo[1]))return $e.SEARCH_TYPES.EQUALS;throw new Error(h0.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(h0.UNKNOWN_SEARCH_TYPE)}}a(g0,"createSearchTypeFromSearchObject");S0.exports={executeSearch:p0,createSearchTypeFromSearchObject:g0,prepSearch:r9,searchByType:E0}});var A0=C((DOe,T0)=>{"use strict";var POe=Ws(),s9=Tu(),i9=oe(),o9=(k(),P(q)),a9=sE();T0.exports=c9;function c9(e,t){if(!i9.isEmpty(t)&&o9.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=s9(e,"value");if(n)throw n;return a9.prepSearch(e,t,!0)}a(c9,"lmdbGetDataByValue")});var p_=C((vOe,R0)=>{"use strict";var MOe=Ws(),l9=Tu(),u9=oe(),d9=(k(),P(q)),f9=sE();R0.exports=_9;async function _9(e,t){if(!u9.isEmpty(t)&&d9.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=l9(e,"value");if(n)throw n;return f9.prepSearch(e,t,!1)}a(_9,"lmdbSearchByValue")});var b0=C((BOe,y0)=>{"use strict";var xOe=kt(),$y=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}},Vy=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},Ky=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};y0.exports={SearchByConditionsObject:$y,SearchCondition:Vy,SortAttribute:Ky}});var C0=C((GOe,I0)=>{"use strict";var kOe=b0().SearchByConditionsObject,h9=Ws(),m9=Tu(),Yy=Su(),iE=kt(),{Resource:FOe}=(ia(),P(KA)),w0=sE(),p9=Hy(),E9=require("lodash"),{getSchemaPath:g9}=Et(),O0=_t(),{handleHDBError:S9,hdb_errors:T9}=me(),{HTTP_STATUS_CODES:A9}=T9,R9=1e8;I0.exports=y9;async function y9(e){let t=m9(e,"conditions");if(t)throw S9(t,t.message,A9.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=g9(e.schema,e.table),n=await O0.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let u of e.conditions)O0.openDBI(n,u.search_attribute);let i=E9.sortBy(e.conditions,u=>{if(u.estimated_count===void 0){let f=u.search_type;f===iE.SEARCH_TYPES.EQUALS?u.estimated_count=Yy.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=R9}return u.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await N0(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(w0.filterByType),d=f.length,_=Yy.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=>p9.parseRow(h,_))}else{for(let d=1;d<i.length;d++){let _=i[d],h=await N0(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=Yy.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(y9,"lmdbSearchByConditions");async function N0(e,t,r,n){let s=new h9(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,w0.searchByType(e,s,i,n).map(o=>o.value)}a(N0,"executeConditionSearch")});var E_=C(($Oe,P0)=>{"use strict";var b9=(k(),P(q)).OPERATIONS_ENUM,Wy=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=b9.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};P0.exports=Wy});var zy=C((KOe,H0)=>{"use strict";var v0=Ws(),U0=E_(),x0=p_(),B0=f_(),yn=(k(),P(q)),D0=oe(),L0=_t(),{getTransactionAuditStorePath:O9,getSchemaPath:N9}=Et(),M0=ee();H0.exports=w9;async function w9(e){try{if(D0.isEmpty(global.hdb_schema[e.schema])||D0.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await I9(e),await C9(e);let t=N9(e.schema,e.table);try{await L0.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")M0.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=O9(e.schema,e.table);await L0.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")M0.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(w9,"lmdbDropTable");async function I9(e){let t=new v0(yn.SYSTEM_SCHEMA_NAME,yn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,yn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[yn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await x0(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 U0(yn.SYSTEM_SCHEMA_NAME,yn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await B0(s)}a(I9,"deleteAttributesFromSystem");async function C9(e){let t=new v0(yn.SYSTEM_SCHEMA_NAME,yn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,yn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[yn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,yn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,yn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await x0(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 U0(yn.SYSTEM_SCHEMA_NAME,yn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await B0(s)}catch(i){throw i}}a(C9,"dropTableFromSystem")});var F0=C((WOe,k0)=>{"use strict";var P9=require("fs-extra"),D9=Ws(),L9=Au(),M9=E_(),v9=zy(),U9=f_(),x9=Fy(),B9=p_(),go=(k(),P(q)),{getSchemaPath:H9}=Et(),{handleHDBError:k9,hdb_errors:F9}=me(),{HDB_ERROR_MSGS:G9,HTTP_STATUS_CODES:q9}=F9;k0.exports=$9;async function $9(e){let t;try{t=await V9(e.schema);let r=new D9(go.SYSTEM_SCHEMA_NAME,go.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,go.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[go.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await B9(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await v9(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new M9(go.SYSTEM_SCHEMA_NAME,go.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await U9(s);let i=H9(t);await P9.remove(i)}catch(r){throw r}}a($9,"lmdbDropSchema");async function V9(e){let t=new L9(go.SYSTEM_SCHEMA_NAME,go.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[go.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await x9(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw k9(new Error,G9.SCHEMA_NOT_FOUND(e),q9.NOT_FOUND,void 0,void 0,!0);return n}a(V9,"validateDropSchema")});var g_=C((jOe,G0)=>{"use strict";var jy=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};G0.exports=jy});var Jy=C((XOe,q0)=>{"use strict";var K9=require("fs-extra"),oE=_t(),{getTransactionAuditStorePath:Y9}=Et(),Qy=kt(),JOe=g_();q0.exports=W9;async function W9(e){let t;try{let r=Y9(e.schema,e.table);await K9.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,Qy.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),oE.createDBI(t,Qy.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),oE.createDBI(t,Qy.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(W9,"createTransactionsAuditEnvironment")});var K0=C((tNe,V0)=>{"use strict";var Xy=(k(),P(q)),$0=_t(),z9=vc(),{getSystemSchemaPath:j9,getSchemaPath:Q9}=Et(),eNe=lo(),J9=Bp(),Zy=xp(),X9=ee(),Z9=Jy();V0.exports=e7;async function e7(e,t){let r=Q9(t.schema,t.table),n=new Zy(t.schema,t.table,Xy.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new Zy(t.schema,t.table,Xy.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new Zy(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await $0.createEnvironment(r,t.table),e!==void 0){let o=await $0.openEnvironment(j9(),Xy.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await z9.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 eb(n),await eb(s),await eb(i)}await Z9(t)}catch(o){throw o}}a(e7,"lmdbCreateTable");async function eb(e){try{await J9(e)}catch(t){X9.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(eb,"createAttribute")});var W0=C((nNe,Y0)=>{"use strict";var t7=jf(),r7=yf(),n7=Xp(),S_=(k(),P(q)),s7=vc().updateRecords,i7=_t(),{getSchemaPath:o7}=Et(),a7=u_(),c7=ee();Y0.exports=l7;async function l7(e){try{let{schema_table:t,attributes:r}=t7(e);r7(e,r,t.hash_attribute),e.schema!==S_.SYSTEM_SCHEMA_NAME&&(r.includes(S_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(S_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(S_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(S_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await n7(e.hdb_auth_header,t,r),s=o7(e.schema,e.table),i=await i7.openEnvironment(s,e.table),o=await s7(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await a7(e,o)}catch(c){c7.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(l7,"lmdbUpdateRecords")});var j0=C((iNe,z0)=>{"use strict";var u7=(k(),P(q)).OPERATIONS_ENUM,tb=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=u7.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};z0.exports=tb});var J0=C((cNe,Q0)=>{"use strict";var aNe=j0(),d7=jf(),f7=yf(),_7=Xp(),T_=(k(),P(q)),h7=vc().upsertRecords,m7=_t(),{getSchemaPath:p7}=Et(),E7=u_(),g7=ee(),{handleHDBError:S7,hdb_errors:T7}=me();Q0.exports=A7;async function A7(e){let t;try{t=d7(e)}catch(l){throw S7(l,l.message,T7.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;f7(e,n,r.hash_attribute),e.schema!==T_.SYSTEM_SCHEMA_NAME&&(n.includes(T_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(T_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(T_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(T_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await _7(e.hdb_auth_header,r,n),i=p7(e.schema,e.table),o=await m7.openEnvironment(i,e.table),c=await h7(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await E7(e,c)}catch(l){g7.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(A7,"lmdbUpsertRecords")});var Z0=C((uNe,X0)=>{"use strict";var rb=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};X0.exports=rb});var tx=C((fNe,ex)=>{"use strict";var nb=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}};ex.exports=nb});var sx=C((mNe,nx)=>{"use strict";var sb=_t(),{getTransactionAuditStorePath:R7}=Et(),hNe=Z0(),A_=kt(),y7=oe(),rx=tx(),b7=require("util").promisify,O7=b7(setTimeout),N7=1e4,w7=100;nx.exports=I7;async function I7(e){let t=R7(e.schema,e.table),r=await sb.openEnvironment(t,e.table,!0),n=sb.listDBIs(r);sb.initializeDBIs(r,A_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new rx;do s=await C7(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 O7(w7);while(s.transactions_deleted>0);return i}a(I7,"deleteAuditLogsBefore");async function C7(e,t){let r=new rx;try{let n=e.dbis[A_.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[A_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];y7.isEmpty(c)||(s=e.dbis[A_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[A_.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>N7)break}return await s,r}catch(n){throw n}}a(C7,"deleteTransactions")});var ox=C((ENe,ix)=>{"use strict";var ib=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};ix.exports=ib});var cx=C((TNe,ax)=>{"use strict";var P7=Ws(),D7=E_(),SNe=ox(),Pi=(k(),P(q)),L7=oe(),ob=_t(),M7=lo(),v7=p_(),U7=f_(),{getSchemaPath:x7}=Et();ax.exports=B7;async function B7(e,t=!0){let r;e.schema===Pi.SYSTEM_SCHEMA_NAME?r=M7[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await k7(e),s=x7(e.schema,e.table),i=await ob.openEnvironment(s,e.table);return t===!0&&await H7(e,i,r.hash_attribute),ob.dropDBI(i,e.attribute),n}a(B7,"lmdbDropAttribute");async function H7(e,t,r){let n=ob.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(H7,"removeAttributeFromAllObjects");async function k7(e){let t=new P7(Pi.SYSTEM_SCHEMA_NAME,Pi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Pi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Pi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,Pi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await v7(t)).filter(o=>o[Pi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(L7.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[Pi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new D7(Pi.SYSTEM_SCHEMA_NAME,Pi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return U7(i)}a(k7,"dropAttributeFromSystem")});var hx=C((yNe,_x)=>{"use strict";var ab=_t(),Ru=kt(),RNe=fn(),cb=(k(),P(q)),lx=oe(),{getTransactionAuditStorePath:F7}=Et(),G7=Su(),aE=pu(),q7=ee();_x.exports=$7;async function $7(e){let t=F7(e.schema,e.table),r=await ab.openEnvironment(t,e.table,!0),n=ab.listDBIs(r);ab.initializeDBIs(r,Ru.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case cb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return ux(r,e.search_values);case cb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,K7(r,e.search_values,s);case cb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return V7(r,e.search_values);default:return ux(r)}}a($7,"readAuditLog");function ux(e,t=[0,Date.now()]){lx.isEmpty(t[0])&&(t[0]=0),lx.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(ux,"searchTransactionsByTimestamp");function V7(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,fx(e,i))}return Object.fromEntries(r)}a(V7,"searchTransactionsByUsername");function K7(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let u=t[c],f=G7.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=fx(e,s),o=new Map;for(let c=0;c<i.length;c++){let l=i[c],u=l.timestamp,f=n.get(u);dx(l,"records",r,f,o),dx(l,"original_records",r,f,o)}return Object.fromEntries(o)}a(K7,"searchTransactionsByHashValues");function dx(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(dx,"loopRecords");function fx(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){q7.warn(i)}return r}catch(n){throw n}}a(fx,"batchSearchTransactions")});var px=C((wNe,mx)=>{"use strict";var{getSchemaPath:ONe}=Et(),NNe=_t(),{database:Y7}=(xe(),P(at));mx.exports={writeTransaction:W7};async function W7(e,t,r){return Y7({database:e,table:t}).transaction(r)}a(W7,"writeTransaction")});var Tx=C((CNe,Sx)=>{"use strict";var{getSchemaPath:Ex}=Et(),gx=_t();Sx.exports={flush:z7,resetReadTxn:j7};async function z7(e,t){return(await gx.openEnvironment(Ex(e,t),t.toString())).flushed}a(z7,"flush");async function j7(e,t){try{(await gx.openEnvironment(Ex(e,t),t.toString())).resetReadTxn()}catch{}}a(j7,"resetReadTxn")});var bx=C((DNe,yx)=>{"use strict";var{Readable:Q7}=require("stream"),{getDatabases:J7}=(xe(),P(at)),{readSync:X7,openSync:Z7,createReadStream:Ax}=require("fs"),{open:eee}=require("lmdb"),Rx=Vf(),tee=Kf(),{AUDIT_STORE_OPTIONS:ree}=(Ai(),P(Ox)),{INTERNAL_DBIS_NAME:nee,AUDIT_STORE_NAME:see}=kt();yx.exports=oee;var lb=32768,iee=100;async function oee(e){let t=e.database||e.schema||"data",r=J7()[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=eee({noSync:!0,maxDbs:tee.MAX_DBS}),_,h=d.openDB(nee,new Rx(!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++%iee===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 Rx(!v,v);await g(E,H)}e.include_audit&&await g(see,{...ree}),await _;let R=Ax(d.path);return R.headers=l(),R.on("close",()=>{m.done(),d.close()}),R}let o=r[Object.keys(r)[0]].primaryStore,c=Z7(o.path);return o.transaction(()=>{let u=Buffer.alloc(lb);X7(c,u,0,lb),o.resetReadTxn();let f=o.useReadTransaction();f.renew();let d=Ax(null,{fd:c,start:lb}),_=new Q7.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(oee,"getBackup")});var Ix=C((MNe,wx)=>{"use strict";var aee=ee(),{handleHDBError:cee}=me(),lee=nM(),uee=Bp(),dee=My(),fee=FU(),_ee=f_(),hee=Fy(),mee=f0(),pee=A0(),Eee=p_(),gee=C0(),See=F0(),Tee=K0(),Aee=W0(),Ree=J0(),yee=sx(),bee=zy(),Oee=cx(),Nee=hx(),wee=px(),Nx=Tx(),Iee=bx(),ub=class extends lee{static{a(this,"LMDBBridge")}async searchByConditions(t){return gee(t)}async getDataByHash(t){return await hee(t)}async searchByHash(t){return await mee(t)}async getDataByValue(t,r){return await pee(t,r)}async searchByValue(t){return await Eee(t)}async createSchema(t){return await fee(t)}async dropSchema(t){return await See(t)}async createTable(t,r){return await Tee(t,r)}async dropTable(t){return await bee(t)}async createAttribute(t){return await uee(t)}async createRecords(t){return await dee(t)}async updateRecords(t){return await Aee(t)}async upsertRecords(t){try{return await Ree(t)}catch(r){throw cee(r,null,null,aee.ERR,r)}}async deleteRecords(t){return await _ee(t)}async dropAttribute(t){return await Oee(t)}async deleteAuditLogsBefore(t){return await yee(t)}async readAuditLog(t){return await Nee(t)}writeTransaction(t,r,n){return wee.writeTransaction(t,r,n)}flush(t,r){return Nx.flush(t,r)}resetReadTxn(t,r){return Nx.resetReadTxn(t,r)}getBackup(t){return Iee(t)}};wx.exports=ub});var fb={};Ue(fb,{add:()=>cE,applyReverse:()=>Cx,getRecordAtTime:()=>db,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 Cx(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=Cee[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=Px}}function db(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":Cx(s,u.getValue(r));break;case"delete":s=null}i=u.previousLocalTime}let o={},c=0;for(let l in s)s[l]===Px&&(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 Cee,Px,uE=Re(()=>{Ai();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)};Cee={add:cE};a(lE,"rebuildUpdateBefore");a(Cx,"applyReverse");Px={};a(db,"getRecordAtTime")});function bn(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}`);bn(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}`);bn(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 ${_}`);bn(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}`);bn(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}`);bn(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}`);bn(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}`);bn(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}`);bn(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}`);bn(this)[l]=d},"set");break;case"Blob":u=a(function(d){if(!(d instanceof Ti||d==null&&c.nullable!==!1))throw new zn.ClientError(`${l} must be a Blob, attempt to assign ${d}`);bn(this)[l]=d},"set");break;case"Any":case void 0:u=a(function(d){bn(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}`);bn(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=_b(_,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");bn(this)[c]=l}),i("deleteProperty",function(c){bn(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,Lx);break}o=c}while(o&&o!==Lx)}function _b(e,t){let r;switch(e.constructor){case Object:return t?(r=t.TrackedObject,r||(t.TrackedObject=r=class extends R_{static{a(this,"TrackedObject")}},hE(r,t)),new r(e)):new R_(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=_b(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=fb[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)Pee.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,Dx,Lx,R_,Pee,Yc,fE,_E,hb=Re(()=>{zn=M(me());uE();gn();a(bn,"getChanges");a(hE,"assignTrackedAccessors");Dx=Object.prototype,Lx=new Proxy({},{get(e,t,r){if(typeof t=="string"){if(t==="then"||t==="getRecord"||t==="getChanges")return;if(Dx[t])return Dx[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=_b(s);if(i)return n||(n=Object.create(null),r._setChanges(n)),n[t]=i,i}return s}}});a(_b,"trackObject");R_=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(R_,{});a(mE,"collapseData");Pee=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 Fx={};Ue(Fx,{ResourceBridge:()=>Eb});function gb({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 vx(e,t){let r=Di(e),n=gb(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 Di(e){let t=e.database||e.schema||Lee,r=Xe()[t];if(!r)throw(0,zs.handleHDBError)(new Error,Dee.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function Ux(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*xx(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 Bx,pE,zs,Hx,mb,pb,kx,Dee,Lee,Mee,vee,Mx,Eb,Gx=Re(()=>{"use strict";Bx=M(Ix()),pE=M(Tu()),zs=M(me());xe();Hx=M(jf());k();mb=M(po()),pb=M(Ys()),kx=M(oe());gc();hb();({HDB_ERROR_MSGS:Dee}=zs.hdb_errors),Lee="data",Mee=1e4,vee=10,Eb=class extends Bx.default{static{a(this,"ResourceBridge")}constructor(t){super(t),Mx=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=Di(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:gb(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 Di(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=Di(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){Di(t).dropTable()}createSchema(t){return bu({database:t.schema,table:null}),mb.signalSchemaChange(new pb.SchemaEventMsg(process.pid,Yt.CREATE_SCHEMA,t.schema))}async dropSchema(t){await Sb(t.schema),mb.signalSchemaChange(new pb.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,Mx.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,Hx.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 Ux(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,kx.async_set_timeout)(vee),l=[],s=!0},"chunkDelete");for await(let f of n)l.push(f[r.primaryKey]),c++,c%Mee===0&&await u();return l.length>0&&await u(),s?Ux(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 vx(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of vx(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&pA[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=Di(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:gb(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async getDataByValue(t,r){let n=new Map,s=Di(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){Di({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return Di(t).deleteHistory(t.timestamp,t.cleanup_deleted_records)}async readAuditLog(t){let r=Di(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 xx(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return xx(r,t.search_values?.[0],t.search_values?.[1],t.limit)}}};a(gb,"getSelect");a(vx,"getRecords");a(Di,"getTable");a(Ux,"createDeleteResponse");a(xx,"groupRecordsInHistory")});var Kn=C((YNe,qx)=>{"use strict";var{ResourceBridge:Uee}=(Gx(),P(Fx)),xee=ce();xee.initSync();var EE;function Bee(){return EE||(EE=new Uee,EE)}a(Bee,"getBridge");qx.exports=Bee()});var Rn=C((zNe,Yx)=>{"use strict";var SE=hR(),xr=oe(),Hee=require("util"),TE=Kn(),kee=ps(),$x=ee(),{handleHDBError:Wc,hdb_errors:Fee}=me(),{HTTP_STATUS_CODES:zc}=Fee,Gee=Hee.promisify(kee.getTableSchema),qee="updated",Vx="inserted",Kx="upserted";Yx.exports={insert:Vee,update:Kee,upsert:Yee,validation:$ee,flush:Wee};async function $ee(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 Gee(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 $x.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 $x.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($ee,"validation");async function Vee(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(Vx,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(Vee,"insertData");async function Kee(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(qee,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(Kee,"updateData");async function Yee(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(Kx,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(Yee,"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===Vx?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===Kx?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(gE,"returnObject");function Wee(e){return xr.transformReq(e),TE.flush(e.schema,e.table)}a(Wee,"flush")});var Xx=C((QNe,Jx)=>{var Ou=require("validate.js"),zx=st(),Nu=(k(),P(q)),{handleHDBError:zee,hdb_errors:jee}=me(),{HDB_ERROR_MSGS:jt,HTTP_STATUS_CODES:Qee}=jee,Tb=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),Jee={STRUCTURE_USER:"structure_user"},Wx=Object.values(Nu.ROLE_TYPES_ENUM),Xee="attribute_permissions",Zee="attribute_name",{PERMS_CRUD_ENUM:wu}=Nu,ete=[Xee,...Object.values(wu)],jx=[wu.READ,wu.INSERT,wu.UPDATE],tte=[Zee,...jx];function rte(e){let t=Tb();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,Qx(e,t)}a(rte,"addRoleValidation");function nte(e){let t=Tb();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,Qx(e,t)}a(nte,"alterRoleValidation");function ste(e){let t=Tb();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,zx.validateObject(e,t)}a(ste,"dropRoleValidation");var ite=["operation","role","id","permission","hdb_user","access"];function Qx(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)ite.includes(n[o])||s.push(n[o]);s.length>0&&nr(jt.INVALID_ROLE_JSON_KEYS(s),r);let i=zx.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{nr(o,r)}),e.permission){let o=ote(e);o&&nr(o,r),Wx.forEach(c=>{e.permission[c]&&!Ou.isBoolean(e.permission[c])&&nr(jt.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(Wx.indexOf(o)<0){if(o===Jee.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(jt.SCHEMA_NOT_FOUND(d),r)}continue}nr(jt.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){nr(jt.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(jt.TABLE_NOT_FOUND(o,l),r);continue}if(Object.keys(u).forEach(f=>{ete.includes(f)||nr(jt.INVALID_PERM_KEY(f),r,o,l)}),Object.values(wu).forEach(f=>{Ou.isDefined(u[f])?Ou.isBoolean(u[f])||nr(jt.TABLE_PERM_NOT_BOOLEAN(f),r,o,l):nr(jt.TABLE_PERM_MISSING(f),r,o,l)}),u.attribute_permissions===void 0){nr(jt.ATTR_PERMS_ARRAY_MISSING,r,o,l);continue}else if(!(Array.isArray(u.attribute_permissions)||u.attribute_permissions===null)){nr(jt.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=>{!tte.includes(S)&&S!==wu.DELETE&&nr(jt.INVALID_ATTR_PERM_KEY(S),r,o,l)}),!Ou.isDefined(h.attribute_name)){nr(jt.ATTR_PERM_MISSING_NAME,r,o,l);continue}let m=h.attribute_name;if(!f.includes(m)){nr(jt.INVALID_ATTRIBUTE_IN_PERMS(m),r,o,l);continue}jx.forEach(S=>{Ou.isDefined(h[S])?Ou.isBoolean(h[S])||nr(jt.ATTR_PERM_NOT_BOOLEAN(S,m),r,o,l):nr(jt.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(jt.MISMATCHED_TABLE_ATTR_PERMS(_),r,o,l)}}}}return ate(r)}a(Qx,"customValidate");Jx.exports={addRoleValidation:rte,alterRoleValidation:nte,dropRoleValidation:ste};function ote(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 jt.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?Nu.ROLE_TYPES_ENUM.SUPER_USER:Nu.ROLE_TYPES_ENUM.CLUSTER_USER;return jt.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(ote,"validateNoSUPerms");function ate(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:jt.ROLE_PERMS_ERROR,...e};return zee(new Error,n,Qee.BAD_REQUEST)}else return null}a(ate,"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 b_=C((ZNe,rB)=>{"use strict";var Zx=Rn(),eB=Wr(),cte=Fc(),Rb=Xx(),yb=po(),XNe=require("uuid").v4,lte=require("util"),AE=(k(),P(q)),ute=oe(),bb=eB.searchByValue,dte=eB.searchByHash,fte=lte.promisify(cte.delete),_te=Ws(),hte=Au(),{hdb_errors:mte,handleHDBError:jc}=me(),{HDB_ERROR_MSGS:tB,HTTP_STATUS_CODES:y_}=mte,{UserEventMsg:Ob}=Ys();rB.exports={addRole:pte,alterRole:Ete,dropRole:gte,listRoles:Ste};function Ab(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(Ab,"scrubRoleDetails");async function pte(e){let t=Rb.addRoleValidation(e);if(t)throw t;e=Ab(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 bb(r)||[])}catch(i){throw jc(i)}if(n&&n.length>0)throw jc(new Error,tB.ROLE_ALREADY_EXISTS(e.role),y_.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 Zx.insert(s),yb.signalUserChange(new Ob(process.pid)),e=Ab(e),e}a(pte,"addRole");async function Ete(e){let t=Rb.alterRoleValidation(e);if(t)throw t;e=Ab(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await Zx.update(r)}catch(s){throw jc(s)}if(n&&n?.message==="updated 0 of 1 records")throw jc(new Error,"Invalid role id",y_.BAD_REQUEST,void 0,void 0,!0);return await yb.signalUserChange(new Ob(process.pid)),e}a(Ete,"alterRole");async function gte(e){let t=Rb.dropRoleValidation(e);if(t)throw jc(new Error,t,y_.BAD_REQUEST,void 0,void 0,!0);let r=new hte(AE.SYSTEM_SCHEMA_NAME,AE.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await dte(r));if(n.length===0)throw jc(new Error,tB.ROLE_NOT_FOUND,y_.NOT_FOUND,void 0,void 0,!0);let s=new _te(AE.SYSTEM_SCHEMA_NAME,AE.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await bb(s)),o=!1;if(ute.isEmptyOrZeroLength(i)===!1){for(let l=0;l<i.length;l++)if(i[l].active===!0){o=!0;break}}if(o===!0)throw jc(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,y_.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await fte(c),yb.signalUserChange(new Ob(process.pid)),`${n[0].role} successfully deleted`}a(gte,"dropRole");async function Ste(){return bb({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(Ste,"listRoles")});var Nb={};Ue(Nb,{start:()=>iB,startOnMainThread:()=>Rte});function iB({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r){let n=(0,nB.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(Tte.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 Ate(i)}}}async function Ate(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,sB.isEqual)(i,e)?void 0:(e.id=r.id,(0,RE.alterRole)(e))}return(0,RE.addRole)(e)}var RE,nB,sB,Tte,Rte,oB=Re(()=>{xe();RE=M(b_()),nB=require("yaml"),sB=require("lodash"),Tte=["super_user","cluster_user","structure_user"];a(iB,"start");a(Ate,"ensureRole");Rte=iB});async function yE(e){let t=(0,lB.pathToFileURL)(e).toString();if(yte)return O_||(O_=bte(Nte)),(await(await O_).import(t)).namespace;try{return await import(t)}catch(r){try{(await import("internal/util")).default.decorateErrorStack(r)}catch{}throw r}}async function bte(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),O_=new Compartment({console,Math,Date,fetch:Ote,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,cB.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:jn,databases:We})}};let n=await(0,aB.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)},"importHook")}),O_}function Ote(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 Nte(){return{Resource:Kr,tables:jn}}var aB,cB,lB,yte,O_,wb=Re(()=>{ia();xe();aB=require("fs/promises"),cB=require("path"),lB=require("url"),yte=!1;a(yE,"secureImport");a(bte,"getCompartment");a(Ote,"secureOnlyFetch");a(Nte,"getGlobalVars")});var Cb={};Ue(Cb,{handleFile:()=>wte});async function wte(e,t,r,n){let s=new Map,i=await yE(r);c(i.default)&&n.set((0,Ib.dirname)(t),i.default),o(i,(0,Ib.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 Ib,uB=Re(()=>{wb();Ib=require("path");a(wte,"handleFile")});var Db={};Ue(Db,{start:()=>Ite});function Ite({resources:e}){e.set("login",Pb),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var Pb,dB=Re(()=>{ia();a(Ite,"start");Pb=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 D_={};Ue(D_,{addAnalyticsListener:()=>P_,calculateCPUUtilization:()=>PB,diffResourceUsage:()=>DB,recordAction:()=>Dt,recordActionBinary:()=>Qn,setAnalyticsEnabled:()=>Cte});function Cte(e){OB=e}function Pte(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 Dte(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(!OB)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=OE.get(i);o?Pte(e,o):Dte(i,e,t,r,n,s),bE||Lte()}function Qn(e,t,r,n,s){Dt(!!e,t,r,n,s)}function P_(e){IB.push(e)}function Lte(){bE=performance.now(),setTimeout(async()=>{let e=performance.now()-bE;bE=0;let t=[],r={time:Date.now(),period:e,threadId:Qc.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 CB){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 LB()}let n=process.memoryUsage();t.push({metric:"memory",threadId:Qc.threadId,byThread:!0,...n});for(let s of IB)s(t);OE=new Map,Qc.parentPort?Qc.parentPort.postMessage({type:wB,report:r}):UB({report:r})},NB).unref()}function NE(e,t,r){let n={id:(0,I_.getNextMonotonicTime)(),metric:t,...r};e.primaryStore.put(n.id,n,{append:!0}).then(s=>{s||e.primaryStore.put(n.id,n)})}function PB(e,t){let r=e.userCPUTime+e.systemCPUTime;return Math.round(r/t*100)/100}function DB(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 Mte(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 fB(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s?.getAuditSize();if(!i)return;let o=bB.default.statSync(s.primaryStore.env.path).size,c=Mte(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 _B(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 vte(e,t=6e4){let r=Mb(),n=MB(),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 Mn=Ae[ut];typeof Mn=="number"&&(ye[ut]=(ye[ut]*xt+Mn*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 LB()}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,Mn)=>ut.value>Mn.value?1:-1);let v=N.count-1,H=[],X=0,W=0,$;for(let ut of CB){let Mn=v*ut;for(;X<Mn;)$=T[W++],X+=$.count,W===1&&X--;let an=T[W>1?W-2:0];$||($=T[0]),H.push($.value-($.value-an.value)*(X-Mn)/$.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,I_.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,I_.getNextMonotonicTime)(),T={id:E,metric:"main-thread-utilization",idle:h-hB,active:m-mB,taskQueueLatency:await s,time:_,...process.memoryUsage()};n.primaryStore.put(E,T,{append:!0}).then(N=>{N||n.primaryStore.put(E,T)})}hB=h,mB=m;let S=process.resourceUsage(),g=DB(N_,S);g.time=_,g.period=N_.time?_-N_.time:t,g.cpuUtilization=PB(N_,g.period),NE(n,"resource-usage",g),N_=g;let R=Xe();fB(n,R),fB(n,{system:R.system}),_B(n,R),_B(n,{system:R.system})}async function pB(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function Mb(){return EB||(EB=ft({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function MB(){return gB||(gB=ft({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function Bte(){vB=!0;let e=(0,C_.get)(B.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await vte(NB,e),await pB(Mb(),Ute),await pB(MB(),xte)},Math.min(e/2,2147483647)).unref()}function UB(e,t){let r=e.report;r.threadId=t?.threadId||Qc.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(SB+=n.mean*n.count);r.totalBytesProcessed=SB,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(TB.get(t))}),TB.set(t,t.performance.eventLoopUtilization())),r.id=(0,I_.getNextMonotonicTime)(),Mb().primaryStore.put(r.id,r),vB||Bte(),Hte&&(xB=Fte(r))}async function Fte(e){if(await xB,!pa){let r=(0,w_.dirname)((0,RB.getLogFilePath)());try{pa=await(0,Lb.open)((0,w_.join)(r,"analytics.log"),"r+")}catch{pa=await(0,Lb.open)((0,w_.join)(r,"analytics.log"),"w+")}}let t=(await pa.stat()).size;if(t>kte){let r=Buffer.alloc(t);await pa.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await pa.write(r,{position:0}),await pa.truncate(r.length),t=r.length}await pa.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()}});kL={type:"application/json",serializeStream:Pf,serialize:vf,deserialize:_3,q:.5};Yr.set("*/*",kL);Yr.set("",kL);a(_3,"tryJSONParse");a(xf,"registerContentHandlers");h3=require("fastify-plugin"),m3=h3(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");vL=aR.default.get(B.HTTP_COMPRESSIONTHRESHOLD);a(Bf,"serialize");a(la,"serializeMessage");a(iR,"asyncSerialization");a(oR,"hasAsyncSerialization");a(p3,"streamToBuffer");E3=["ascii","utf8","utf-8","utf16le","utf-16le","ucs2","ucs-2","base64","base64url","latin1","binary","hex"];a(g3,"isBufferEncoding");a(S3,"parseContentType");a(ao,"getDeserializer");a(T3,"deserializerUnknownType");a(A3,"transformIterable");a(Tp,"toCsvStream")});var fR={};Ue(fR,{start:()=>P3});function R3(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 GL(e){if(typeof e!="object"||e===null)throw new yi("Request body must be an object.");if(!("query"in e))throw new yi("Request body must contain a `query` field.");if(typeof e.query!="string")throw new yi("Request body `query` field must be a string.");if("variables"in e&&(typeof e.variables!="object"||e.variables===null))throw new yi("Request body `variables` field must be an object.");if("operationName"in e&&typeof e.operationName!="string")throw new yi("Request body `operationName` field must be a string.")}function dR(e){return parseInt(e.value,10)}function $L(e){return parseFloat(e.value)}function VL(e,t,r){let n=r.get(e.name.value);return KL(n)?YL(n,t):{attribute:t,value:n}}function KL(e){return typeof e=="object"&&e!=null&&!Array.isArray(e)}function YL(e,t){return t=typeof t=="string"?[t]:t,Object.entries(e).flatMap(([r,n])=>(t=[...t,r],KL(n)?YL(n,t):{attribute:t,value:n}))}function y3(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:dR(e.value)};case Me.Kind.FLOAT:return{attribute:t,value:$L(e.value)};case Me.Kind.BOOLEAN:case Me.Kind.STRING:return{attribute:t,value:e.value.value};case Me.Kind.VARIABLE:return VL(e.value,t,r);case Me.Kind.OBJECT:return WL(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 WL(e,t,r){return e.fields.flatMap(n=>y3(n,t,r))}function b3(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:dR(e.value)};case Me.Kind.FLOAT:return{attribute:e.name.value,value:$L(e.value)};case Me.Kind.BOOLEAN:case Me.Kind.STRING:return{attribute:e.name.value,value:e.value.value};case Me.Kind.VARIABLE:return VL(e.value,e.name.value,t);case Me.Kind.OBJECT:return WL(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 O3(e,t){return e.flatMap(r=>b3(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 zL(e,t){return Rp(e,t).map(r=>r.selectionSet?.selections.length>0?{name:r.name.value,select:zL(r.selectionSet,t)}:r.name.value)}async function N3(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:zL(e.selectionSet,r),conditions:O3(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 jL(e){switch(e.kind){case Me.Kind.NULL:return null;case Me.Kind.INT:return dR(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]:jL(r.value),...t}),{});case Me.Kind.LIST:case Me.Kind.ENUM:default:throw new Or(`Value type, ${e.kind}, is not supported.`)}}function w3(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=jL(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 I3(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=w3(e.variableDefinitions,t),i=await Promise.all(Rp(e.selectionSet,r).map(c=>N3(c,s,r,n))),o={data:{}};for(let[c,l]of i)o.data[c]=l;return o}async function qL({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(R3(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 I3(c,t,o,n);return{status:200,headers:{"Content-Type":"application/graphql-response+json; charset=utf-8"},body:JSON.stringify(l)}}async function C3(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 GL(r),qL(r,e)}case"POST":{let r=await ao(e.headers.get("content-type"),!0)(e._nodeRequest);return GL(r),qL(r,e)}default:throw new yi("Method Not Allowed",405,{Allow:"GET, POST"})}}function P3(e){e.server.http(async(t,r)=>{if(!t.url.startsWith("/graphql"))return r(t);try{return await C3(t)}catch(n){logger.error(n);let s=t.headers.get("accept")??"application/graphql-response+json";switch(s){case"application/json":{if(n instanceof yi)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 yi)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,yi,QL=Re(()=>{Me=M(require("graphql"));so();ru();a(R3,"assertExecutableDefinitionNode");a(GL,"assertRequestParams");a(dR,"processIntValueNode");a($L,"processFloatValueNode");a(VL,"processVariableNode");a(KL,"isObject");a(YL,"transformObjectIntoQueryCondition");a(y3,"processObjectFieldNode");a(WL,"processObjectValueNode");a(b3,"processArgumentNode");a(O3,"buildConditionsQuery");a(Rp,"fillInFragments");a(zL,"buildSelectQuery");a(N3,"processFieldNode");a(jL,"processConstValueNode");a(w3,"resolveVariables");a(I3,"executeOperation");a(qL,"resolver");Or=class extends Error{static{a(this,"GraphQLQueryingError")}},yi=class extends Error{static{a(this,"HTTPError")}statusCode;headers;constructor(t,r=400,n={}){super(t),this.statusCode=r,this.headers=n}};a(C3,"graphqlQueryingHandler");a(P3,"start")});var Oi=C(($Re,ZL)=>{"use strict";var XL=oe(),JL=(k(),P(q)),cu=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,bi=require("joi"),ua={schema_format:{pattern:cu,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},D3=bi.alternatives(bi.string().min(1).max(ua.schema_length.maximum).pattern(cu).messages({"string.pattern.base":"{:#label} "+ua.schema_format.message}),bi.number(),bi.array()).required(),L3=bi.alternatives(bi.string().min(1).max(ua.schema_length.maximum).pattern(cu).messages({"string.pattern.base":"{:#label} "+ua.schema_format.message}),bi.number()),M3=bi.alternatives(bi.string().min(1).max(ua.schema_length.maximum).pattern(cu).messages({"string.pattern.base":"{:#label} "+ua.schema_format.message}),bi.number()).required();function v3(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>ua.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(v3,"checkValidTable");function U3(e,t){return XL.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(U3,"validateSchemaExists");function x3(e,t){let r=t.state.ancestors[0].schema;return XL.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(x3,"validateTableExists");function B3(e,t){return e.toLowerCase()===JL.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${JL.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(B3,"validateSchemaName");ZL.exports={common_validators:ua,schema_regex:cu,hdb_schema_table:D3,validateSchemaExists:U3,validateTableExists:x3,validateSchemaName:B3,checkValidTable:v3,hdb_database:L3,hdb_table:M3}});var hR=C((KRe,tM)=>{var{hdb_table:H3,hdb_database:eM}=Oi(),k3=st(),_R=require("joi"),F3={undefined:"undefined",null:"null"},G3=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||F3[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"),q3=_R.object({database:eM,schema:eM,table:H3,records:_R.array().items(_R.object().custom(G3)).required()});tM.exports=function(e){return k3.validateBySchema(e,q3)}});var nM=C((WRe,rM)=>{"use strict";var mR=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")}};rM.exports=mR});var iM=C((jRe,sM)=>{"use strict";var pR=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};sM.exports=pR});var uM={};Ue(uM,{HAS_EXPIRATION:()=>Op,HAS_RESIDENCY_ID:()=>yR,HAS_STRUCTURE_UPDATE:()=>wp,LAST_TIMESTAMP_PLACEHOLDER:()=>Gf,LOCAL_TIMESTAMP:()=>$3,METADATA:()=>Ic,NEW_TIMESTAMP_PLACEHOLDER:()=>aM,NO_TIMESTAMP:()=>ER,PENDING_LOCAL_TIME:()=>bR,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>RR,RecordEncoder:()=>AR,TIMESTAMP_ASSIGN_LAST:()=>K3,TIMESTAMP_ASSIGN_NEW:()=>cM,TIMESTAMP_ASSIGN_PREVIOUS:()=>lM,TIMESTAMP_PLACEHOLDER:()=>yp,TIMESTAMP_RECORD_PREVIOUS:()=>gR,handleLocalTimeForGets:()=>Ip,recordUpdater:()=>OR,removeEntry:()=>Pc});function W3(){return Ff[0]=Ff[0]^64,V3.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 OR(e,t,r){return function(n,s,i,o,c=-1,l,u,f="put",d,_){d||l==null?lu=i?.localTime?gR|lM:ER:lu=l?i?.localTime?gR|16384:cM|16384:ER;let h=u?.expiresAt;if(h>=0&&(c|=Op),kf=c,SR=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&&(TR=E,kf|=yR,g|=Dc),R!==E&&(g|=Lc,R||(R=0)),c&Op&&(g|=$f),u?.originatingOperation&&(g|=qf),d&&(m.ifVersion=S=i?.version??null),i&&i.value&&f!=="message"&&i.metadataFlags&Ur&&(r.getBinaryFast(i.localTime)||ca(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,Hf,g,E,R,h),{ifVersion:S}),T}}T=r.put(s===void 0?aM:Gf,Cc(o,t,n,i?.localTime?1:0,u?.nodeId??server.replication?.getThisNodeId(r)??0,N,f,Hf,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)&&ca(t.value),e.remove(t.key,r)}var oM,bp,yp,Gf,RR,aM,$3,Ic,Ff,V3,ER,cM,K3,lM,gR,Op,yR,bR,wp,Y3,Hf,lu,kf,SR,TR,AR,wc,uu=Re(()=>{oM=require("msgpackr");Ai();bp=M(ee());gn();gn();yp=new Uint8Array([1,1,1,1,4,64,0,0]),Gf=new Uint8Array([1,1,1,1,1,0,0,0]),RR=new Uint8Array([1,1,1,1,3,64,0,0]),aM=new Uint8Array([1,1,1,1,0,64,0,0]),$3=Symbol("local-timestamp"),Ic=Symbol("metadata"),Ff=new Uint8Array(8),V3=new DataView(Ff.buffer,0,8),ER=0,cM=0,K3=1,lM=3,gR=4,Op=16,yR=32,bR=1,wp=256,lu=0,kf=-1,SR=-1,TR=0,AR=class extends oM.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(s,i){if(lu||kf>=0){let o=0,c=lu;c&&(o+=8,lu=0);let l=kf,u=SR,f=TR;l>=0&&(o+=4,kf=-1,u>=0&&(o+=8,SR=-1),f&&(o+=4,TR=0));let d=Y3=r.call(this,s,i|2048|o);Hf=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 Hf=r.call(this,s,i),Hf};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(Ff,0,c),c+=8;else for(let _=0;_<8;_++)Ff[_]=t[c++];l=W3(),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&yR&&(f=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4));let d=no(()=>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:no(()=>super.decode(t,r),this.rootStore)}catch(c){return bp.error("Error decoding record",c,"data: "+t.slice(0,40).toString("hex")),null}}};a(W3,"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(OR,"recordUpdater");a(Pc,"removeEntry")});var Vf=C((tye,fM)=>{"use strict";var dM=ce(),z3=(k(),P(q)),{RecordEncoder:j3}=(uu(),P(uM));dM.initSync();var Q3=dM.get(z3.CONFIG_PARAMS.STORAGE_CACHING)!==!1,NR=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=Q3&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:j3})}};fM.exports=NR});var Kf=C((nye,_M)=>{"use strict";var qn=ce(),hs=(k(),P(q));qn.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=qn.get(hs.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||qn.get(hs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||qn.get(hs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",qn.get(hs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=qn.get(hs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),qn.get(hs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=qn.get(hs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),qn.get(hs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=qn.get(hs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),qn.get(hs.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=qn.get(hs.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=qn.get(hs.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};_M.exports=Cp;Cp.MAX_DBS=1e4});var _t=C((iye,yM)=>{"use strict";var IR=require("lmdb"),qs=require("fs-extra"),$n=require("path"),Pp=fn(),pM=ee(),Sn=xn().LMDB_ERRORS_ENUM,Dp=iM(),CR=Vf(),EM=Kf(),da=kt(),hM=(k(),P(q)),{table:J3,resetDatabases:X3}=(xe(),P(at)),mM=ce(),$s=da.INTERNAL_DBIS_NAME,gM=da.DBI_DEFINITION_NAME,Z3="data.mdb",eX="lock.mdb",Yf=".mdb",tX="-lock",wR=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=ms(t,r),this.key_type=this.dbi[da.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[da.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new IR.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 PR(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=$n.join(e,t+Yf);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($n.join(e,t,Z3),qs.constants.R_OK|qs.constants.F_OK),$n.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(PR,"validateEnvironmentPath");function Mp(e,t){if(Pp.validateEnv(e),t===void 0)throw new Error(Sn.DBI_NAME_REQUIRED)}a(Mp,"validateEnvDBIName");async function rX(e,t,r=!1,n=!1){Lp(e,t);let s=$n.basename(e);t=t.toString();let i=mM.get(hM.CONFIG_PARAMS.DATABASES);i||mM.setProperty(hM.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await PR(e,t,n),SM(e,t,r)}catch(o){if(o.message===Sn.INVALID_ENVIRONMENT){let c=$n.join(e,t);await qs.mkdirp(n?c:e);let l=new EM(n?c:c+Yf,!1),u=IR.open(l);u.dbis=Object.create(null);let f=new CR(!1);u.openDB($s,f),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let d=DR(e,t,r);return u[da.ENVIRONMENT_NAME_KEY]=d,global.lmdb_map[d]=u,u}throw o}}a(rX,"createEnvironment");async function nX(e,t,r,n=!0){Lp(e,t),t=t.toString();let s=$n.join(e,t);return J3({table:t,database:$n.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(nX,"copyEnvironment");async function SM(e,t,r=!1){Lp(e,t),t=t.toString();let n=DR(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 PR(e,t),i=$n.join(e,t+Yf),o=s!=i,c=new EM(s,o),l=IR.open(c);l.dbis=Object.create(null);let u=AM(l);for(let f=0;f<u.length;f++)ms(l,u[f]);return l[da.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(SM,"openEnvironment");async function sX(e,t,r=!1){Lp(e,t),t=t.toString();let n=$n.join(e,t+Yf),s=await PR(e,t);if(global.lmdb_map!==void 0){let i=DR(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await TM(o),delete global.lmdb_map[i]}}await qs.remove(s),await qs.remove(s===n?s+tX:$n.join($n.dirname(s),eX))}a(sX,"deleteEnvironment");async function TM(e){Pp.validateEnv(e);let t=e[da.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(TM,"closeEnvironment");function DR(e,t,r=!1){let s=`${$n.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(DR,"getCachedEnvironmentName");function iX(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{pM.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(iX,"listDBIDefinitions");function AM(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(AM,"listDBIs");function oX(e,t){let n=ms(e,$s).getEntry(t),s=new Dp;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{pM.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(oX,"getDBIDefinition");function RM(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 CR(r,n===!0),o=e.openDB(t,i),c=new Dp(r===!0,n);return o[gM]=c,ms(e,$s).putSync(t,c),e.dbis[t]=o,o}throw s}}a(RM,"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=oX(e,t):r=new Dp,r===void 0)throw new Error(Sn.DBI_DOES_NOT_EXIST);let n;try{let s=new CR(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[gM]=r,e.dbis[t]=n,n}a(ms,"openDBI");function aX(e,t){Mp(e,t),t=t.toString();let r=ms(e,t),n=r.getStats();return r[da.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(aX,"statDBI");async function cX(e,t){try{let r=$n.join(e,t+Yf);return(await qs.stat(r)).size}catch{throw new Error(Sn.INVALID_ENVIRONMENT)}}a(cX,"environmentDataSize");function lX(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(lX,"dropDBI");function uX(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)RM(e,i,i!==t,i===t),n=!0;else throw o}}n&&X3()}a(uX,"initializeDBIs");yM.exports={openDBI:ms,openEnvironment:SM,createEnvironment:rX,listDBIs:AM,listDBIDefinitions:iX,createDBI:RM,dropDBI:lX,statDBI:aX,deleteEnvironment:sX,initializeDBIs:uX,TransactionCursor:wR,environmentDataSize:cX,copyEnvironment:nX,closeEnvironment:TM}});var OM=C((aye,bM)=>{"use strict";var LR=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};bM.exports=LR});var wM=C((lye,NM)=>{"use strict";var MR=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}};NM.exports=MR});var CM=C((dye,IM)=>{"use strict";var vR=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};IM.exports=vR});var vc=C((pye,LM)=>{"use strict";var dX=_t(),fX=OM(),_X=wM(),hX=CM(),Ni=fn(),Wf=xn().LMDB_ERRORS_ENUM,mX=kt(),co=(k(),P(q)),pX=oe(),EX=require("uuid"),_ye=require("lmdb"),{handleHDBError:gX,hdb_errors:SX}=me(),{OVERFLOW_MARKER:hye,MAX_SEARCH_KEY_LENGTH:mye}=mX,PM=ce();PM.initSync();var vp=PM.get(co.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),UR=co.TIME_STAMP_NAMES_ENUM.CREATED_TIME,Mc=co.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function TX(e,t,r,n,s=Ni.getNextMonotonicTime()){kR(e,t,r,n),xR(e,t,r);let i=new fX,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l];DM(u,!0,s);let f=AX(e,t,r,u),d=u[t];o.push(f),c.push(d)}return BR(o,c,n,i,s)}a(TX,"insertRecords");function AX(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][co.FUNC_VAL],n[o]=c)}let l=Ni.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(AX,"insertRecord");function RX(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(RX,"removeSkippedRecords");function DM(e,t,r){let n=r>0;(n||!Number.isInteger(e[Mc]))&&(e[Mc]=r||(r=Ni.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[UR]))&&(e[UR]=r||Ni.getNextMonotonicTime()):delete e[UR]}a(DM,"setTimestamps");function xR(e,t,r){r.indexOf(co.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(co.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(co.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(co.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),dX.initializeDBIs(e,t,r)}a(xR,"initializeTransaction");async function yX(e,t,r,n,s=Ni.getNextMonotonicTime()){kR(e,t,r,n),xR(e,t,r);let i=new _X,o=[],c=[],l=[];for(let u=0;u<n.length;u++){let f=n[u],d=f[t],_;try{_=HR(e,t,f,d,i,!0,s)}catch{i.skipped_hashes.push(d),o.push(u);continue}c.push(_),l.push(d)}return BR(c,l,n,i,s,o)}a(yX,"updateRecords");async function bX(e,t,r,n,s=Ni.getNextMonotonicTime()){try{kR(e,t,r,n)}catch(l){throw gX(l,l.message,SX.HTTP_STATUS_CODES.BAD_REQUEST)}xR(e,t,r);let i=new hX,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l],f;pX.isEmpty(u[t])?(f=EX.v4(),u[t]=f):f=u[t];let d=HR(e,t,u,f,i,!1,s);o.push(d),c.push(f)}return BR(o,c,n,i,s)}a(bX,"upsertRecords");async function BR(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||Ni.getNextMonotonicTime(),RX(r,i),n}a(BR,"finalizeWrite");function HR(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(DM(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][co.FUNC_VAL],r[m]=S)}if(S===R)continue;let E=Ni.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=Ni.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:HR(e,t,r,n,s,i,o))}a(HR,"updateUpsertRecord");function OX(e,t,r){if(Ni.validateEnv(e),t===void 0)throw new Error(Wf.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(Wf.WRITE_ATTRIBUTES_REQUIRED):new Error(Wf.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(OX,"validateBasic");function kR(e,t,r,n){if(OX(e,t,r),!Array.isArray(n))throw n===void 0?new Error(Wf.RECORDS_REQUIRED):new Error(Wf.RECORDS_MUST_BE_ARRAY)}a(kR,"validateWrite");function Up(){}a(Up,"noop");LM.exports={insertRecords:TX,updateRecords:yX,upsertRecords:bX}});var lo=C((gye,NX)=>{NX.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 vM=C((Sye,MM)=>{"use strict";var wX=require("uuid"),FR=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||wX.v4(),this.schema_table=`${this.schema}.${this.table}`}};MM.exports=FR});var xp=C((Aye,UM)=>{"use strict";var IX=vM(),GR=class extends IX{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}};UM.exports=GR});var BM=C((yye,xM)=>{"use strict";xM.exports=PX;var CX="inserted";function PX(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===CX?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(PX,"returnObject")});var Bp=C((Nye,kM)=>{"use strict";var DX=(k(),P(q)),qR=_t(),LX=vc(),{getSystemSchemaPath:MX,getSchemaPath:vX}=Et(),Oye=lo(),{validateBySchema:UX}=st(),zf=require("joi"),xX=xp(),BX=BM(),{handleHDBError:HX,hdb_errors:kX,ClientError:FX}=me(),HM=oe(),{HTTP_STATUS_CODES:GX}=kX,qX="inserted";kM.exports=$X;async function $X(e){let t=UX(e,zf.object({database:zf.string(),schema:zf.string(),table:zf.string().required(),attribute:zf.string().required()}));if(t)throw new FX(t.message);let r=!e.skip_table_check&&HM.checkGlobalSchemaTable(e.schema,e.table);if(r)throw HX(new Error,r,GX.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=HM.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 xX(e.schema,e.table,e.attribute,e.id);try{let i=await qR.openEnvironment(vX(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}`);qR.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await qR.openEnvironment(MX(),DX.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await LX.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_attribute_attributes,[s]);return BX(qX,c,{records:[s]},l)}catch(i){throw i}}a($X,"lmdbCreateAttribute")});var jf=C((Cye,GM)=>{"use strict";var uo=oe(),FM=ee(),Iye=hR(),{getDatabases:VX}=(xe(),P(at)),{ClientError:Uc}=me();GM.exports=KX;function KX(e){if(uo.isEmpty(e))throw new Uc("invalid update parameters defined.");if(uo.isEmptyOrZeroLength(e.schema))throw new Uc("invalid schema specified.");if(uo.isEmptyOrZeroLength(e.table))throw new Uc("invalid table specified.");if(!Array.isArray(e.records))throw new Uc("records must be an array");let t=VX()[e.schema]?.[e.table];if(uo.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&&uo.isEmptyOrZeroLength(o[r]))throw FM.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(!uo.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw FM.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`);!uo.isEmpty(o[r])&&o[r]!==""&&n.has(uo.autoCast(o[r]))&&(o.skip=!0),n.add(uo.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(KX,"insertUpdateValidate")});var $M=C((Dye,qM)=>{"use strict";var $R=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};qM.exports=$R});var YM=C((Mye,KM)=>{"use strict";var VR=_t(),YX=ee(),VM=xn().LMDB_ERRORS_ENUM;KM.exports=WX;async function WX(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 VR.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==VM.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await VR.closeEnvironment(global.lmdb_map[n]),await VR.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==VM.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){YX.error(t)}}a(WX,"cleanLMDBMap")});var iv=C((xye,sv)=>{"use strict";var KR=require("recursive-iterator"),zX=require("alasql"),YR=require("clone"),WM=oe(),{handleHDBError:zM,hdb_errors:jX}=me(),{HDB_ERROR_MSGS:jM,HTTP_STATUS_CODES:QM}=jX,{getDatabases:QX}=(xe(),P(at)),JX=["DISTINCT_ARRAY"],JM=Symbol("validateTables"),WR=Symbol("validateTable"),Uye=Symbol("getAllColumns"),XM=Symbol("validateAllColumns"),Hp=Symbol("findColumn"),ZM=Symbol("validateOrderBy"),Qf=Symbol("validateSegment"),zR=Symbol("validateColumn"),ev=Symbol("setColumnsForTable"),tv=Symbol("checkColumnsForAsterisk"),rv=Symbol("validateGroupBy"),nv=Symbol("hasColumns"),jR=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[JM](),this[tv](),this[XM]()}[JM](){if(this[nv]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[WR](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[WR](t.table)})}}[nv](){let t=!1,r=new KR(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[WR](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=QX();if(!r[t.databaseid])throw zM(new Error,jM.SCHEMA_NOT_FOUND(t.databaseid),QM.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw zM(new Error,jM.TABLE_NOT_FOUND(t.databaseid,t.tableid),QM.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=YR(s);i.table=YR(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)}[tv](){let t=new KR(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[ev](r.tableid)}[ev](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new zX.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[XM](){this[Qf](this.statement.columns,!1),this[Qf](this.statement.joins,!1),this[Qf](this.statement.where,!1),this[rv](this.statement.group,!1),this[Qf](this.statement.order,!0)}[Qf](t,r){if(!t)return;let n=new KR(t),s=[];for(let{node:i,path:o}of n)!WM.isEmpty(i)&&!WM.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[ZM](i):s.push(this[zR](i)));return s}[rv](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&JX.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=YR(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`}[ZM](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[zR](t)}[zR](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]}};sv.exports=jR});var lv=C((Hye,cv)=>{"use strict";var ov=require("lodash"),Jf=require("mathjs"),XX=require("jsonata"),av=oe();cv.exports={distinct_array:a(e=>Array.isArray(e)&&e.length>1?ov.uniqWith(e,ov.isEqual):e,"distinct_array"),searchJSON:ZX,mad:Xf.bind(null,Jf.mad),mean:Xf.bind(null,Jf.mean),mode:Xf.bind(null,Jf.mode),prod:Xf.bind(null,Jf.prod),median:Xf.bind(null,Jf.median)};function Xf(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(Xf,"aggregateFunction");function ZX(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(av.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),av.isEmpty(this.__ala__.res[r])){let n=XX(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(ZX,"searchJSON")});var dv=C((Fye,uv)=>{"use strict";var rr=require("moment"),QR="YYYY-MM-DDTHH:mm:ss.SSSZZ";rr.suppressDeprecationWarnings=!0;uv.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(QR),"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(QR),"get_server_time"),offset_utc:a((e,t)=>rr(e).utc().utcOffset(t).format(QR),"offset_utc")}});var mv=C((qye,hv)=>{"use strict";var e6=require("@turf/area"),t6=require("@turf/length"),r6=require("@turf/circle"),n6=require("@turf/difference"),s6=require("@turf/distance"),i6=require("@turf/boolean-contains"),o6=require("@turf/boolean-equal"),a6=require("@turf/boolean-disjoint"),c6=require("@turf/helpers"),fv=(k(),P(q)),Ke=oe(),fo=ee();hv.exports={geoArea:l6,geoLength:u6,geoCircle:d6,geoDifference:f6,geoDistance:_v,geoNear:_6,geoContains:h6,geoEqual:m6,geoCrosses:p6,geoConvert:E6};function l6(e){if(Ke.isEmpty(e))return NaN;typeof e=="string"&&(e=Ke.autoCastJSON(e));try{return e6.default(e)}catch(t){return fo.trace(t,e),NaN}}a(l6,"geoArea");function u6(e,t){if(Ke.isEmpty(e))return NaN;typeof e=="string"&&(e=Ke.autoCastJSON(e));try{return t6.default(e,{units:t||"kilometers"})}catch(r){return fo.trace(r,e),NaN}}a(u6,"geoLength");function d6(e,t,r){if(Ke.isEmpty(e))return NaN;if(Ke.isEmpty(t))return NaN;typeof e=="string"&&(e=Ke.autoCastJSON(e));try{return r6.default(e,t,{units:r||"kilometers"})}catch(n){return fo.trace(n,e,t),NaN}}a(d6,"geoCircle");function f6(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 n6(e,t)}catch(r){return fo.trace(r,e,t),NaN}}a(f6,"geoDifference");function _v(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 s6.default(e,t,{units:r||"kilometers"})}catch(n){return fo.trace(n,e,t),NaN}}a(_v,"geoDistance");function _6(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 _v(e,t,n)<=r}catch(s){return fo.trace(s,e,t),!1}}a(_6,"geoNear");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 fo.trace(r,e,t),!1}}a(h6,"geoContains");function m6(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 o6.default(e,t)}catch(r){return fo.trace(r,e,t),!1}}a(m6,"geoEqual");function p6(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!a6.default(e,t)}catch(r){return fo.trace(r,e,t),!1}}a(p6,"geoCrosses");function E6(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(fv.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(fv.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Ke.autoCastJSON(e)),c6[t](e,r)}a(E6,"geoConvert")});var kp=C((Vye,pv)=>{var xc=lv(),Vn=dv(),wi=mv();pv.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=Vn.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Vn.current_time,e.fn.extract=e.fn.EXTRACT=Vn.extract,e.fn.date=e.fn.DATE=Vn.date,e.fn.date_format=e.fn.DATE_FORMAT=Vn.date_format,e.fn.date_add=e.fn.DATE_ADD=Vn.date_add,e.fn.date_sub=e.fn.DATE_SUB=Vn.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Vn.date_diff,e.fn.now=e.fn.NOW=Vn.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Vn.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Vn.get_server_time,e.fn.getdate=e.fn.GETDATE=Vn.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Vn.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=wi.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=wi.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=wi.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=wi.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=wi.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=wi.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=wi.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=wi.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=wi.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=wi.geoNear}});var Tv=C((Kye,Sv)=>{"use strict";var Zf=require("lodash"),Tn=require("alasql");Tn.options.cache=!1;var g6=kp(),Ev=require("clone"),Fp=require("recursive-iterator"),ke=ee(),Je=oe(),du=Kn(),S6=(k(),P(q)),{hdb_errors:T6}=me(),{getDatabases:gv}=(xe(),P(at)),A6="IS NULL",Vs="There was a problem performing this search. Please check the logs and try again.";g6(Tn);var JR=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(Ev(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=Zf.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=gv()[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(S6.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&&Zf.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(Ev(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(A6)>-1&&this.tables.forEach(s=>{let i={columnid:gv()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=Zf.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=Zf.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=Zf.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(T6.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)}};Sv.exports=JR});var Wr=C((Wye,Av)=>{"use strict";var R6=iv();Av.exports={searchByConditions:b6,searchByHash:O6,searchByValue:N6,search:w6};var XR=Kn(),{transformReq:ZR}=oe(),y6=Tv();async function b6(e){return ZR(e),XR.searchByConditions(e)}a(b6,"searchByConditions");async function O6(e){ZR(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of XR.searchByHash(e))r&&t.push(r);return t}a(O6,"searchByHash");async function N6(e){ZR(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of XR.searchByValue(e))t.push(r);return t}a(N6,"searchByValue");function w6(e,t){try{let r=new R6(e);r.validate(),new y6(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(w6,"search")});var _o=C((jye,Ov)=>{"use strict";var e_=require("crypto"),I6=ce(),{CONFIG_PARAMS:C6}=(k(),P(q)),yv="aes-256-cbc",P6=32,D6=16,ey=64,bv=32,L6=ey+bv,Rv=new Map;Ov.exports={encrypt:M6,decrypt:v6,createNatsTableStreamName:U6};function M6(e){let t=e_.randomBytes(P6),r=e_.randomBytes(D6),n=e_.createCipheriv(yv,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(M6,"encrypt");function v6(e){let t=e.substr(0,ey),r=e.substr(ey,bv),n=e.substr(L6,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=e_.createDecipheriv(yv,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(v6,"decrypt");function U6(e,t){let r=I6.get(C6.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=Rv.get(r);return n||(n=e_.createHash("md5").update(r).digest("hex"),Rv.set(r,n)),n}a(U6,"createNatsTableStreamName")});var ho=C((Xye,Cv)=>{"use strict";var Jye=Wr(),t_=ee(),{validateBySchema:Nv}=st(),Bc=require("joi"),x6=_o(),Gp=oe(),{handleHDBError:qp,hdb_errors:B6,ClientError:wv}=me(),{HDB_ERROR_MSGS:$p,HTTP_STATUS_CODES:ty}=B6,Iv=ce();Iv.initSync();var{getDatabases:ry}=(xe(),P(at)),H6=require("fs-extra"),k6=(k(),P(q));Cv.exports={describeAll:F6,describeTable:Vp,describeSchema:G6};async function F6(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=ry(),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){t_.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 t_.error("Got an error in describeAll"),t_.error(t),qp(new Error,$p.DESCRIBE_ALL_ERR)}}a(F6,"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=Nv(e,Bc.object({database:Bc.string(),table:Bc.string().required(),exact_count:Bc.boolean().strict()}));if(i)throw new wv(i.message);let c=ry()[r];if(!c)throw qp(new Error,$p.SCHEMA_NOT_FOUND(e.schema),ty.NOT_FOUND);let l=c[n];if(!l)throw qp(new Error,$p.TABLE_NOT_FOUND(e.schema,e.table),ty.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 H6.stat(l.primaryStore.env.path)).size}catch(h){t_.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")),Iv.get(k6.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(_.clustering_stream_name=x6.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){t_.warn(`unable to stat table dbi due to ${h}`)}return _}a(Vp,"descTable");async function G6(e){Gp.transformReq(e);let t=Nv(e,Bc.object({database:Bc.string(),exact_count:Bc.boolean().strict()}));if(t)throw new wv(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=ry()[n];if(!i)throw qp(new Error,$p.SCHEMA_NOT_FOUND(e.schema),ty.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(G6,"describeSchema")});var ps=C((rbe,vv)=>{var q6=lo(),{callbackify:Dv,promisify:$6}=require("util"),{getDatabases:Lv}=(xe(),P(at));vv.exports={setSchemaDataToGlobal:Pv,getTableSchema:V6,getSystemSchema:K6,setSchemaDataToGlobalAsync:$6(Pv)};var Mv=ho(),ebe=Dv(Mv.describeAll),tbe=Dv(Mv.describeTable);function Pv(e){global.hdb_schema=Lv(),e&&e()}a(Pv,"setSchemaDataToGlobal");function V6(e,t,r){let n=Lv()[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(V6,"getTableSchema");function K6(){return q6}a(K6,"getSystemSchema")});var sy=C((sbe,Bv)=>{var Y6=st(),ny=require("joi"),{hdb_table:W6,hdb_database:Uv}=Oi(),xv={schema:Uv,database:Uv,table:W6},z6={date:ny.date().iso().required()},j6={timestamp:ny.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};Bv.exports=function(e,t){let r=t==="timestamp"?{...xv,...j6}:{...xv,...z6},n=ny.object(r);return Y6.validateBySchema(e,n)}});var Fv=C((ibe,kv)=>{var Q6=st(),iy=require("joi"),{hdb_table:J6,hdb_database:Hv}=Oi(),X6=iy.object({schema:Hv,database:Hv,table:J6,hash_values:iy.array().required(),ids:iy.array()});kv.exports=function(e){return Q6.validateBySchema(e,X6)}});var ly=C((obe,Gv)=>{"use strict";var oy=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}},ay=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}},cy=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};Gv.exports={InsertObject:oy,NoSQLSeachObject:ay,DeleteResponseObject:cy}});var Fc=C((cbe,Yv)=>{"use strict";var $v=sy(),Z6=Fv(),Hc=oe(),qv=require("moment"),Vv=ee(),{promisify:eZ,callbackify:tZ}=require("util"),kc=(k(),P(q)),rZ=ps(),uy=eZ(rZ.getTableSchema),dy=Kn(),{DeleteResponseObject:nZ}=ly(),{handleHDBError:fa,hdb_errors:sZ}=me(),{HDB_ERROR_MSGS:Kp,HTTP_STATUS_CODES:_a}=sZ,iZ="records successfully deleted",oZ=tZ(Kv);Yv.exports={delete:oZ,deleteRecord:Kv,deleteFilesBefore:aZ,deleteAuditLogsBefore:cZ};async function aZ(e){let t=$v(e,"date");if(t)throw fa(t,t.message,_a.BAD_REQUEST,void 0,void 0,!0);if(Hc.transformReq(e),!qv(e.date,qv.ISO_8601).isValid())throw fa(new Error,Kp.INVALID_DATE,_a.BAD_REQUEST,kc.LOG_LEVELS.ERROR,Kp.INVALID_DATE,!0);let n=Hc.checkSchemaTableExist(e.schema,e.table);if(n)throw fa(new Error,n,_a.NOT_FOUND,kc.LOG_LEVELS.ERROR,n,!0);let s=await dy.deleteRecordsBefore(e);if(await uy(e.schema,e.table),Vv.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(aZ,"deleteFilesBefore");async function cZ(e){let t=$v(e,"timestamp");if(t)throw fa(t,t.message,_a.BAD_REQUEST,void 0,void 0,!0);if(Hc.transformReq(e),isNaN(e.timestamp))throw fa(new Error,Kp.INVALID_VALUE("Timestamp"),_a.BAD_REQUEST,kc.LOG_LEVELS.ERROR,Kp.INVALID_VALUE("Timestamp"),!0);let r=Hc.checkSchemaTableExist(e.schema,e.table);if(r)throw fa(new Error,r,_a.NOT_FOUND,kc.LOG_LEVELS.ERROR,r,!0);let n=await dy.deleteAuditLogsBefore(e);return await uy(e.schema,e.table),Vv.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(cZ,"deleteAuditLogsBefore");async function Kv(e){e.ids&&(e.hash_values=e.ids);let t=Z6(e);if(t)throw fa(t,t.message,_a.BAD_REQUEST,void 0,void 0,!0);Hc.transformReq(e);let r=Hc.checkSchemaTableExist(e.schema,e.table);if(r)throw fa(new Error,r,_a.NOT_FOUND,kc.LOG_LEVELS.ERROR,r,!0);try{await uy(e.schema,e.table);let n=await dy.deleteRecords(e);return Hc.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${iZ}`),n}catch(n){if(n.message===kc.SEARCH_NOT_FOUND_MESSAGE){let s=new nZ;return s.message=kc.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(Kv,"deleteRecord")});var Yp={};Ue(Yp,{HASH_FUNCTION:()=>s_,hash:()=>hy,validate:()=>my});function fy(e=n_){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ";return Array.from(r_.randomBytes(e)).map(r=>t[r%t.length]).join("")}function hy(e,t=s_[zv?.toUpperCase()]??"sha256"){return _y[t](e)}function my(e,t,r=s_[zv?.toUpperCase()]??"sha256"){return e?lZ[r](e,t):!1}var r_,fu,Wv,zv,n_,jv,s_,_y,lZ,Wp=Re(()=>{r_=M(require("node:crypto")),fu=M(require("argon2")),Wv=M(ce());k();zv=(0,Wv.get)(B.AUTHENTICATION_HASHFUNCTION)?.toLowerCase(),n_=16,jv=9,s_=(n=>(n.MD5="md5",n.SHA256="sha256",n.ARGON2ID="argon2id",n))(s_||{});a(fy,"generateSalt");_y={md5:a((e,t=void 0)=>{t=t??fy(jv);let r=r_.createHash("md5").update(e+t).digest("hex");return t+r},"md5"),sha256:a((e,t=void 0)=>{t=t??fy(n_);let r=r_.createHash("sha256").update(e+t).digest("hex");return t+r},"sha256"),argon2id:a(async e=>{let t=fy(n_),r=await fu.hash(e,{type:fu.argon2id,salt:Buffer.from(t)});return t+r},"argon2id")},lZ={md5:a((e,t)=>{let r=e.slice(0,jv);return e===_y.md5(t,r)},"md5"),sha256:a((e,t)=>{let r=e.slice(0,n_);return e===_y.sha256(t,r)},"sha256"),argon2id:a(async(e,t)=>await fu.verify(e.slice(n_),t),"argon2id")};a(hy,"hash");a(my,"validate")});var Jv=C((fbe,Qv)=>{var py=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 uZ(e){return zr.password.presence=!0,zr.username.presence=!0,zr.role.presence=!0,zr.active.presence=!0,py.validateObject(e,zr)}a(uZ,"addUserValidation");function dZ(e){return zr.password.presence=!1,zr.username.presence=!0,zr.role.presence=!1,zr.active.presence=!1,py.validateObject(e,zr)}a(dZ,"alterUserValidation");function fZ(e){return zr.password.presence=!1,zr.username.presence=!0,zr.role.presence=!1,zr.active.presence=!1,py.validateObject(e,zr)}a(fZ,"dropUserValidation");Qv.exports={addUserValidation:uZ,alterUserValidation:dZ,dropUserValidation:fZ}});var Pt=C((mbe,Zv)=>{"use strict";var{platform:hbe}=require("os"),_Z="nats-server.zip",Ey="nats-server",hZ=process.platform==="win32"?`${Ey}.exe`:Ey,mZ=/^[^\s.,*>]+$/,Xv="__request__",pZ=a(e=>`${e}.${Xv}`,"REQUEST_SUBJECT"),EZ={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},gZ={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},SZ={HUB:"hub.pid",LEAF:"leaf.pid"},TZ={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},AZ={SUCCESS:"success",ERROR:"error"},RZ={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},yZ={TXN:"txn",MSGID:"msgid"},_u={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},bZ={[_u.ERR]:1,[_u.WRN]:2,[_u.INF]:3,[_u.DBG]:4,[_u.TRC]:5},OZ={debug:"-D",trace:"-DVV"};Zv.exports={NATS_SERVER_ZIP:_Z,NATS_SERVER_NAME:Ey,NATS_BINARY_NAME:hZ,PID_FILES:SZ,NATS_CONFIG_FILES:gZ,SERVER_SUFFIX:TZ,NATS_TERM_CONSTRAINTS_RX:mZ,REQUEST_SUFFIX:Xv,UPDATE_REMOTE_RESPONSE_STATUSES:AZ,CLUSTER_STATUS_STATUSES:RZ,REQUEST_SUBJECT:pZ,SUBJECT_PREFIXES:yZ,MSG_HEADERS:EZ,LOG_LEVELS:_u,LOG_LEVEL_FLAGS:OZ,LOG_LEVEL_HIERARCHY:bZ}});var An=C((Ebe,Nr)=>{"use strict";var rU="username is required",nU="nothing to update, must supply active, role or password to update",sU="password cannot be an empty string",iU="If role is specified, it cannot be empty.",oU="active must be true or false";Nr.exports.addUser=vZ;Nr.exports.alterUser=UZ;Nr.exports.dropUser=BZ;Nr.exports.getSuperUser=qZ;Nr.exports.userInfo=HZ;Nr.exports.listUsers=jp;Nr.exports.listUsersExternal=kZ;Nr.exports.setUsersWithRolesCache=Gc;Nr.exports.findAndValidateUser=Ny;Nr.exports.getClusterUser=$Z;Nr.exports.getUsersWithRolesCache=GZ;Nr.exports.USERNAME_REQUIRED=rU;Nr.exports.ALTERUSER_NOTHING_TO_UPDATE=nU;Nr.exports.EMPTY_PASSWORD=sU;Nr.exports.EMPTY_ROLE=iU;Nr.exports.ACTIVE_BOOLEAN=oU;var aU=Rn(),NZ=Fc(),i_=(Wp(),P(Yp)),cU=Jv(),o_=Wr(),Ry=po(),Ii=oe(),lU=require("validate.js"),yy=ee(),{promisify:wZ}=require("util"),by=_o(),Sy=(k(),P(q)),eU=Pt(),IZ=It(),CZ=ce(),PZ=lo(),{hdb_errors:DZ,ClientError:Ks}=me(),{HTTP_STATUS_CODES:mo,AUTHENTICATION_ERROR_MSGS:gy,HDB_ERROR_MSGS:hu}=DZ,{UserEventMsg:Oy}=Ys(),Ty=require("lodash"),{server:zp}=(Mr(),P(Wl)),LZ=ee();zp.getUser=(e,t)=>Ny(e,t,t!=null);zp.authenticateUser=(e,t)=>Ny(e,t);var uU={username:!0,active:!0,role:!0,password:!0},tU=new Map,MZ=wZ(NZ.delete),Ay=CZ.get(Sy.CONFIG_PARAMS.AUTHENTICATION_HASHFUNCTION)??i_.HASH_FUNCTION.SHA256,Ci;async function vZ(e){let t=lU.cleanAttributes(e,uU),r=cU.addUserValidation(t);if(r)throw new Ks(r.message);let n=await o_.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),mo.NOT_FOUND);if(n.length>1)throw new Ks(hu.DUP_ROLES_FOUND(t.role),mo.CONFLICT);n[0].permission.cluster_user===!0&&(t.hash=by.encrypt(t.password)),t.password=await i_.hash(t.password,Ay),t.hash_function=Ay,t.role=n[0].id;let s=await aU.insert({operation:"insert",schema:"system",table:"hdb_user",records:[t]});if(yy.debug(s),await Gc(),s.skipped_hashes.length===1)throw new Ks(hu.USER_ALREADY_EXISTS(t.username),mo.CONFLICT);return Ry.signalUserChange(new Oy(process.pid)),`${t.username} successfully added`}a(vZ,"addUser");async function UZ(e){let t=lU.cleanAttributes(e,uU);if(Ii.isEmptyOrZeroLength(t.username))throw new Error(rU);if(Ii.isEmptyOrZeroLength(t.password)&&Ii.isEmptyOrZeroLength(t.role)&&Ii.isEmptyOrZeroLength(t.active))throw new Error(nU);if(!Ii.isEmpty(t.password)&&Ii.isEmptyOrZeroLength(t.password.trim()))throw new Error(sU);if(!Ii.isEmpty(t.active)&&!Ii.isBoolean(t.active))throw new Error(oU);if(!Ii.isEmpty(t.password)&&!Ii.isEmptyOrZeroLength(t.password.trim())&&(xZ(t.username)&&(t.hash=by.encrypt(t.password)),t.password=await i_.hash(t.password,Ay)),t.role==="")throw new Error(iU);if(t.role){let n=await o_.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),mo.NOT_FOUND);if(n.length>1)throw new Ks(hu.DUP_ROLES_FOUND(t.role),mo.CONFLICT);t.role=n[0].id}let r=await aU.update({operation:"update",schema:"system",table:"hdb_user",records:[t]});return await Gc(),Ry.signalUserChange(new Oy(process.pid)),r}a(UZ,"alterUser");function xZ(e){let t=!1,r=Ci.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(xZ,"isClusterUser");async function BZ(e){let t=cU.dropUserValidation(e);if(t)throw new Ks(t.message);if(Ci.get(e.username)===void 0)throw new Ks(hu.USER_NOT_EXIST(e.username),mo.NOT_FOUND);let r=await MZ({table:"hdb_user",schema:"system",hash_values:[e.username]});return yy.debug(r),await Gc(),Ry.signalUserChange(new Oy(process.pid)),`${e.username} successfully deleted`}a(BZ,"dropUser");async function HZ(e){let t={};if(!e||!e.hdb_user)return"There was no user info in the body";t=Ty.cloneDeep(e.hdb_user);let r=await o_.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(HZ,"userInfo");async function kZ(){let e=await jp();return e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token,delete t.hash_function}),[...e.values()]}a(kZ,"listUsersExternal");async function jp(){let e=await o_.searchByValue({schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]}),t={};for(let s of e)t[s.id]=Ty.cloneDeep(s);if(Object.keys(t).length===0)return null;let r=await o_.searchByValue({schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]}),n=new Map;for(let s of r)s=Ty.cloneDeep(s),s.role=t[s.role],FZ(s.role),n.set(s.username,s);return n}a(jp,"listUsers");function FZ(e){if(!e){yy.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(PZ)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}a(FZ,"appendSystemTablesToRole");async function Gc(e=void 0){e?Ci=e:Ci=await jp()}a(Gc,"setUsersWithRolesCache");async function GZ(){return Ci||await Gc(),Ci}a(GZ,"getUsersWithRolesCache");async function Ny(e,t,r=!0){Ci||await Gc();let n=Ci.get(e);if(!n){if(!r)return{username:e};throw new Ks(gy.GENERIC_AUTH_FAIL,mo.UNAUTHORIZED)}if(n&&!n.active)throw new Ks(gy.USER_INACTIVE,mo.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(tU.get(t)===n.password)return s;{let i=i_.validate(n.password,t,n.hash_function||i_.HASH_FUNCTION.MD5);if(i?.then&&(i=await i),i===!0)tU.set(t,n.password);else throw new Ks(gy.GENERIC_AUTH_FAIL,mo.UNAUTHORIZED)}}return s}a(Ny,"findAndValidateUser");async function qZ(){Ci||await Gc();for(let[,e]of Ci)if(e.role.role==="super_user")return e}a(qZ,"getSuperUser");async function $Z(){let e=await jp(),t=IZ.getConfigFromFile(Sy.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!(r==null||r?.role?.role!==Sy.ROLE_TYPES_ENUM.CLUSTER_USER))return r.decrypt_hash=by.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+eU.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+eU.SERVER_SUFFIX.ADMIN,r}a($Z,"getClusterUser");var dU=[];zp.invalidateUser=function(e){for(let t of dU)try{t(e)}catch(r){LZ.error("Error invalidating user",r)}};zp.onInvalidatedUser=function(e){dU.push(e)}});var c_=C((Abe,mU)=>{"use strict";var qc=ee(),Yn=(k(),P(q)),VZ=YM(),Sbe=ps(),Tbe=ho(),KZ=An(),{validateEvent:fU}=Ys(),a_=Kn(),YZ=require("process"),{resetDatabases:WZ}=(xe(),P(at)),zZ={[Yn.ITC_EVENT_TYPES.SCHEMA]:jZ,[Yn.ITC_EVENT_TYPES.USER]:hU};async function jZ(e){let t=fU(e);if(t){qc.error(t);return}qc.trace("ITC schemaHandler received schema event:",e),await VZ(e.message),await QZ(e.message)}a(jZ,"schemaHandler");async function QZ(e){try{a_.resetReadTxn(Yn.SYSTEM_SCHEMA_NAME,Yn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),a_.resetReadTxn(Yn.SYSTEM_SCHEMA_NAME,Yn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),a_.resetReadTxn(Yn.SYSTEM_SCHEMA_NAME,Yn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=WZ();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){qc.error(t)}}a(QZ,"syncSchemaMetadata");var _U=[];async function hU(e){try{try{a_.resetReadTxn(Yn.SYSTEM_SCHEMA_NAME,Yn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),a_.resetReadTxn(Yn.SYSTEM_SCHEMA_NAME,Yn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){qc.warn(r)}let t=fU(e);if(t){qc.error(t);return}qc.trace(`ITC userHandler ${Yn.HDB_ITC_CLIENT_PREFIX}${YZ.pid} received user event:`,e),await KZ.setUsersWithRolesCache();for(let r of _U)r()}catch(t){qc.error(t)}}a(hU,"userHandler");hU.addListener=function(e){_U.push(e)};mU.exports=zZ});var Ys=C((wbe,EU)=>{"use strict";var ybe=ee(),wy=oe(),JZ=(k(),P(q)),{ITC_ERRORS:l_}=xn(),{parentPort:bbe,threadId:XZ,isMainThread:ZZ,workerData:Obe}=require("worker_threads"),{onMessageFromWorkers:e8,broadcast:Nbe,broadcastWithAcknowledgement:t8}=it();EU.exports={sendItcEvent:r8,validateEvent:pU,SchemaEventMsg:n8,UserEventMsg:s8};var Qp;e8(async(e,t)=>{Qp=Qp||c_(),pU(e),Qp[e.type]&&await Qp[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function r8(e){return!ZZ&&e.message&&(e.message.originator=XZ),t8(e)}a(r8,"sendItcEvent");function pU(e){if(typeof e!="object")return l_.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||wy.isEmpty(e.type))return l_.MISSING_TYPE;if(!e.hasOwnProperty("message")||wy.isEmpty(e.message))return l_.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||wy.isEmpty(e.message.originator))return l_.MISSING_ORIGIN;if(JZ.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return l_.INVALID_EVENT(e.type)}a(pU,"validateEvent");function n8(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(n8,"SchemaEventMsg");function s8(e){this.originator=e}a(s8,"UserEventMsg")});var po=C((Pbe,AU)=>{"use strict";var gU=(k(),P(q)),Cbe=oe(),Jp=ee(),SU=$M(),mu,{sendItcEvent:TU}=Ys();function i8(e){try{Jp.info("signalSchemaChange called with message:",e),mu=mu||c_();let t=new SU(gU.ITC_EVENT_TYPES.SCHEMA,e);return mu.schema(t),TU(t)}catch(t){Jp.error(t)}}a(i8,"signalSchemaChange");function o8(e){try{Jp.trace("signalUserChange called with message:",e),mu=mu||c_();let t=new SU(gU.ITC_EVENT_TYPES.USER,e);return mu.user(t),TU(t)}catch(t){Jp.error(t)}}a(o8,"signalUserChange");AU.exports={signalSchemaChange:i8,signalUserChange:o8}});var Xp=C((Lbe,yU)=>{"use strict";var RU=oe(),a8=(k(),P(q)),c8=ee(),l8=Bp(),u8=xp(),d8=po(),{SchemaEventMsg:f8}=Ys(),_8="already exists in";yU.exports=h8;async function h8(e,t,r){if(RU.isEmptyOrZeroLength(r))return r;let n=[];RU.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 m8(e,t.schema,t.name,i)})),s}a(h8,"lmdbCheckForNewAttributes");async function m8(e,t,r,n){let s=new u8(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await p8(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(_8))c8.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(m8,"createNewAttribute");async function p8(e){let t;return t=await l8(e),d8.signalSchemaChange(new f8(process.pid,a8.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(p8,"createAttribute")});var pu=C((vbe,bU)=>{"use strict";var Iy=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}};bU.exports=Iy});var NU=C((xbe,OU)=>{"use strict";var E8=pu(),g8=(k(),P(q)).OPERATIONS_ENUM,Cy=class extends E8{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(g8.INSERT,r,n,s,i),this.records=t}};OU.exports=Cy});var IU=C((Hbe,wU)=>{"use strict";var S8=pu(),T8=(k(),P(q)).OPERATIONS_ENUM,Py=class extends S8{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(T8.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};wU.exports=Py});var PU=C((Fbe,CU)=>{"use strict";var A8=pu(),R8=(k(),P(q)).OPERATIONS_ENUM,Dy=class extends A8{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(R8.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};CU.exports=Dy});var LU=C((qbe,DU)=>{"use strict";var y8=pu(),b8=(k(),P(q)).OPERATIONS_ENUM,Ly=class extends y8{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(b8.DELETE,n,s,t,i),this.original_records=r}};DU.exports=Ly});var u_=C((Kbe,xU)=>{"use strict";var Vbe=require("path"),MU=_t(),O8=NU(),N8=IU(),w8=PU(),I8=LU(),Eu=kt(),vU=oe(),{CONFIG_PARAMS:C8}=(k(),P(q)),UU=ce();UU.initSync();var Zp=(k(),P(q)).OPERATIONS_ENUM,{getTransactionAuditStorePath:P8}=Et();xU.exports=D8;async function D8(e,t){if(UU.get(C8.LOGGING_AUDITLOG)===!1)return;let r=P8(e.schema,e.table),n=await MU.openEnvironment(r,e.table,!0),s=L8(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){MU.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),vU.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(D8,"writeTransaction");function L8(e,t){let r=vU.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===Zp.INSERT)return new O8(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Zp.UPDATE)return new N8(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Zp.UPSERT)return new w8(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Zp.DELETE)return new I8(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(L8,"createTransactionObject")});var My=C((zbe,BU)=>{"use strict";var M8=jf(),Wbe=Rf(),d_=(k(),P(q)),v8=yf(),U8=vc().insertRecords,x8=_t(),B8=ee(),H8=Xp(),{getSchemaPath:k8}=Et(),F8=u_();BU.exports=G8;async function G8(e){try{let{schema_table:t,attributes:r}=M8(e);v8(e,r,t.hash_attribute),e.schema!==d_.SYSTEM_SCHEMA_NAME&&(r.includes(d_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(d_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(d_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(d_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await H8(e.hdb_auth_header,t,r),s=k8(e.schema,e.table),i=await x8.openEnvironment(s,e.table),o=await U8(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await F8(e,o)}catch(c){B8.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(G8,"lmdbCreateRecords")});var FU=C((Qbe,kU)=>{"use strict";var HU=(k(),P(q)),q8=My(),$8=Rf(),V8=require("fs-extra"),{getSchemaPath:K8}=Et();kU.exports=Y8;async function Y8(e){let t=[{name:e.schema,createddate:Date.now()}],r=new $8(HU.SYSTEM_SCHEMA_NAME,HU.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await q8(r),await V8.mkdirp(K8(e.schema))}a(Y8,"lmdbCreateSchema")});var qU=C((Xbe,GU)=>{"use strict";var vy=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}};GU.exports=vy});var YU=C((nOe,KU)=>{"use strict";var $U=_t(),Uy=fn(),xy=xn().LMDB_ERRORS_ENUM,W8=kt(),VU=ee(),eOe=oe(),z8=require("lmdb"),j8=qU(),Q8=(k(),P(q)),{OVERFLOW_MARKER:tOe,MAX_SEARCH_KEY_LENGTH:rOe}=W8,J8=Q8.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function X8(e,t,r,n){if(Uy.validateEnv(e),t===void 0)throw new Error(xy.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(xy.IDS_REQUIRED):new Error(xy.IDS_MUST_BE_ITERABLE);try{let s=$U.listDBIs(e);$U.initializeDBIs(e,t,s);let i=new j8,o,c=[],l=[];for(let _=0,h=r.length;_<h;_++)try{o=r[_];let m=e.dbis[t].get(o);if(!m||n&&m[J8]>n){i.skipped.push(o);continue}let S=e.dbis[t].ifVersion(o,z8.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=Uy.getIndexedValues(T);if(N)for(let v=0,H=N.length;v<H;v++)E.remove(N[v],o)}catch{VU.warn(`cannot delete from attribute: ${R}, ${T}:${o}`)}}});c.push(S),l.push(o),i.original_records.push(m)}catch(m){VU.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=Uy.getNextMonotonicTime(),i}catch(s){throw s}}a(X8,"deleteRecords");KU.exports={deleteRecords:X8}});var f_=C((iOe,zU)=>{"use strict";var gu=oe(),Z8=YU(),e5=_t(),{getSchemaPath:t5}=Et(),r5=u_(),n5=ee();zU.exports=s5;async function s5(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 WU([],[]);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=t5(e.schema,e.table),i=await e5.openEnvironment(s,e.table),o=await Z8.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await r5(e,o)}catch(c){n5.error(`unable to write transaction due to ${c.message}`)}return WU(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(s5,"lmdbDeleteRecords");function WU(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(WU,"createDeleteResponse")});var Hy=C((cOe,jU)=>{"use strict";var i5=(k(),P(q)),aOe=fn();function By(e,t){let r=Object.create(null);if(t.length===1&&i5.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(By,"parseRow");function o5(e,t,r,n){let s=By(r,e);n.push(s)}a(o5,"searchAll");function a5(e,t,r,n){let s=By(r,e);n[t]=s}a(a5,"searchAllToMap");function c5(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(c5,"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 l5(e,t,r,n,s,i){t.toString().endsWith(e)&&$c(t,r,n,s,i)}a(l5,"endsWith");function u5(e,t,r,n,s,i){t.toString().includes(e)&&$c(t,r,n,s,i)}a(u5,"contains");function d5(e,t,r,n,s,i){t>e&&$c(t,r,n,s,i)}a(d5,"greaterThanCompare");function f5(e,t,r,n,s,i){t>=e&&$c(t,r,n,s,i)}a(f5,"greaterThanEqualCompare");function _5(e,t,r,n,s,i){t<e&&$c(t,r,n,s,i)}a(_5,"lessThanCompare");function h5(e,t,r,n,s,i){t<=e&&$c(t,r,n,s,i)}a(h5,"lessThanEqualCompare");jU.exports={parseRow:By,searchAll:o5,searchAllToMap:a5,iterateDBI:c5,endsWith:l5,contains:u5,greaterThanCompare:d5,greaterThanEqualCompare:f5,lessThanCompare:_5,lessThanEqualCompare:h5,pushResults:$c}});var Su=C((_Oe,r0)=>{"use strict";var ha=_t(),uOe=ee(),Wn=fn(),eE=kt(),zt=xn().LMDB_ERRORS_ENUM,dOe=oe(),m5=(k(),P(q)),tE=Hy(),{parseRow:p5}=tE,fOe=require("lmdb"),{OVERFLOW_MARKER:QU,MAX_SEARCH_KEY_LENGTH:E5}=eE;function JU(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(JU,"iterateFullIndex");function __(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(__,"iterateRangeBetween");function Vc(e,t,r,n){let s=e.database||e,i=ha.openDBI(s,r);i[eE.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&ha.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 XU(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(QU)){if(!s)if(r)s=ha.openDBI(e,r);else{let l=ha.listDBIs(e);for(let u=0,f=l.length;u<f&&(s=ha.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(XU,"getOverflowCheck");function g5(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=h_(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(u=>p5(u.value,r))))}a(g5,"searchAll");function S5(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=h_(e.database||e,r);let o=new Map;for(let{key:c,value:l}of JU(e,t,t,n,s,i))o.set(c,tE.parseRow(l,r));return o}a(S5,"searchAllToMap");function T5(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=JU(e,void 0,t,r,n,s),c=o.transaction,l=XU(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(T5,"iterateDBI");function A5(e,t){if(Wn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);return ha.statDBI(e,t).entryCount}a(A5,"countAll");function R5(e,t,r,n,s=!1,i=void 0,o=void 0){return ma(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(R5,"equals");function y5(e,t,r){return ma(e,t,r),ha.openDBI(e,t).getValuesCount(r)}a(y5,"count");function b5(e,t,r,n,s=!1,i=void 0,o=void 0){return ma(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(b5,"startsWith");function O5(e,t,r,n,s=!1,i=void 0,o=void 0){return ZU(e,t,r,n,s,i,o,!0)}a(O5,"endsWith");function ZU(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return ma(e,r,n),Vc(e,null,r,(l,u,f,d)=>{let _=XU(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(QU)?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(ZU,"contains");function N5(e,t,r,n,s=!1,i=void 0,o=void 0){ma(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),__(e,t,r,n,l,s,i,o,!0,!1)}a(N5,"greaterThan");function w5(e,t,r,n,s=!1,i=void 0,o=void 0){ma(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),__(e,t,r,n,l,s,i,o,!1,!1)}a(w5,"greaterThanEqual");function I5(e,t,r,n,s=!1,i=void 0,o=void 0){ma(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),__(e,t,r,l,n,s,i,o,!1,!0)}a(I5,"lessThan");function C5(e,t,r,n,s=!1,i=void 0,o=void 0){ma(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),__(e,t,r,l,n,s,i,o,!1,!1)}a(C5,"lessThanEqual");function P5(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 __(e,t,r,n,s,i,o,c)}a(P5,"between");function D5(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=h_(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(D5,"searchByHash");function L5(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(L5,"checkHashExists");function M5(e,t,r,n,s=[]){return t0(e,t,r,n,s),e0(e,t,r,n,s).map(i=>i[1])}a(M5,"batchSearchByHash");function v5(e,t,r,n,s=[]){t0(e,t,r,n,s);let i=new Map;for(let[o,c]of e0(e,t,r,n,s))i.set(o,c);return i}a(v5,"batchSearchByHashToMap");function e0(e,t,r,n,s=[]){return Vc(e,t,t,(i,o,c)=>{r=h_(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(e0,"batchHashSearch");function t0(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(t0,"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 ma(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>E5)throw new Error(zt.SEARCH_VALUE_TOO_LARGE)}a(ma,"validateComparisonFunctions");function h_(e,t){return t.length===1&&m5.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=ha.listDBIs(e)),t}a(h_,"setGetWholeRowAttributes");r0.exports={searchAll:g5,searchAllToMap:S5,count:y5,countAll:A5,equals:R5,startsWith:b5,endsWith:O5,contains:ZU,searchByHash:D5,setGetWholeRowAttributes:h_,batchSearchByHash:M5,batchSearchByHashToMap:v5,checkHashExists:L5,iterateDBI:T5,greaterThan:N5,greaterThanEqual:w5,lessThan:I5,lessThanEqual:C5,between:P5}});var Tu=C((mOe,a0)=>{var n0=require("lodash"),s0=st(),qe=require("joi"),U5=oe(),{hdb_schema_table:m_,checkValidTable:i0,hdb_table:o0,hdb_database:nE}=Oi(),{handleHDBError:x5,hdb_errors:B5}=me(),{getDatabases:H5}=(xe(),P(at)),{HTTP_STATUS_CODES:k5}=B5,F5=qe.object({database:nE,schema:nE,table:o0,search_attribute:m_,search_value:qe.any().required(),get_attributes:qe.array().min(1).items(qe.alternatives(m_,qe.object())).optional(),desc:qe.bool(),limit:qe.number().integer().min(1),offset:qe.number().integer().min(0)}),G5=qe.object({database:nE,schema:nE,table:o0,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(m_,qe.object())).optional(),sort:qe.object({attribute:qe.alternatives(m_,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(m_,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()});a0.exports=function(e,t){let r=null;switch(t){case"value":r=s0.validateBySchema(e,F5);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(i0("database",e.schema)),i(i0("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=s0.validateBySchema(e,G5);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=U5.checkGlobalSchemaTable(e.schema,e.table);if(s)return x5(new Error,s,k5.NOT_FOUND);let o=H5()[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=n0.filter(c,f=>f!=="*"&&!f.startsWith?.("$")&&f.attribute!=="*"&&!Array.isArray(f)&&!f.name&&!n0.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 ky=C((EOe,c0)=>{"use strict";var q5=_t(),$5=Tu(),{getSchemaPath:V5}=Et();c0.exports=K5;function K5(e){let t=$5(e,"hashes");if(t)throw t;let r=V5(e.schema,e.table);return q5.openEnvironment(r,e.table)}a(K5,"initialize")});var Fy=C((SOe,l0)=>{"use strict";var Y5=Su(),W5=ky();l0.exports=z5;async function z5(e){let t=await W5(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return Y5.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(z5,"lmdbGetDataByHash")});var Au=C((AOe,u0)=>{"use strict";var Gy=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};u0.exports=Gy});var f0=C((bOe,d0)=>{"use strict";var yOe=Au(),j5=Su(),Q5=ky();d0.exports=J5;async function J5(e){let t=await Q5(e),r=global.hdb_schema[e.schema][e.table];return j5.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(J5,"lmdbSearchByHash")});var Ws=C((NOe,_0)=>{"use strict";var qy=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}};_0.exports=qy});var sE=C((IOe,S0)=>{"use strict";var jr=Su(),X5=_t(),Z5=oe(),$e=kt(),Kc=(k(),P(q)),e9=lo(),h0=xn().LMDB_ERRORS_ENUM,{getSchemaPath:t9}=Et(),Eo=Kc.SEARCH_WILDCARDS;async function r9(e,t,r){let n;e.schema===Kc.SYSTEM_SCHEMA_NAME?n=e9[e.table]:n=global.hdb_schema[e.schema][e.table];let s=g0(e,n.hash_attribute,r,t);return p0(e,s,n.hash_attribute,r)}a(r9,"prepSearch");async function p0(e,t,r,n){let s=t9(e.schema,e.table),i=await X5.openEnvironment(s,e.table),o=E0(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(n9(e,r)===!1){let f=e.search_attribute;if(f===r)return n?m0(o,()=>!0):o.map(_=>({[r]:_.key}));let d=a(_=>({[r]:_.value,[f]:_.key}),"toObject");return n?m0(o,d):o.map(d)}let u=e.search_attribute===r?o.map(f=>f.key):o.map(f=>f.value);return n===!0?jr.batchSearchByHashToMap(c,r,e.get_attributes,u):jr.batchSearchByHash(c,r,e.get_attributes,u)}a(p0,"executeSearch");function E0(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=jr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.CONTAINS:s=jr.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=jr.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=jr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return jr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case $e.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return jr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case $e.SEARCH_TYPES.SEARCH_ALL:return jr.searchAll(e,n,t.get_attributes,o,c,l);case $e.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return jr.searchAllToMap(e,n,t.get_attributes,o,c,l);case $e.SEARCH_TYPES.BETWEEN:s=jr.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=jr.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=jr.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=jr.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=jr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;default:return Object.create(null)}return s}a(E0,"searchByType");function m0(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(m0,"createMapFromIterable");function n9(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(n9,"checkToFetchMore");function g0(e,t,r,n){if(Z5.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),Eo.indexOf(s)>-1)return r===!0?$e.SEARCH_TYPES.SEARCH_ALL_TO_MAP:$e.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(Eo[0])<0&&s.indexOf(Eo[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(Eo.indexOf(i)>=0&&Eo.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),$e.SEARCH_TYPES.CONTAINS;if(Eo.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),$e.SEARCH_TYPES.ENDS_WITH;if(Eo.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),$e.SEARCH_TYPES.STARTS_WITH;if(s.includes(Eo[0])||s.includes(Eo[1]))return $e.SEARCH_TYPES.EQUALS;throw new Error(h0.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(h0.UNKNOWN_SEARCH_TYPE)}}a(g0,"createSearchTypeFromSearchObject");S0.exports={executeSearch:p0,createSearchTypeFromSearchObject:g0,prepSearch:r9,searchByType:E0}});var A0=C((DOe,T0)=>{"use strict";var POe=Ws(),s9=Tu(),i9=oe(),o9=(k(),P(q)),a9=sE();T0.exports=c9;function c9(e,t){if(!i9.isEmpty(t)&&o9.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=s9(e,"value");if(n)throw n;return a9.prepSearch(e,t,!0)}a(c9,"lmdbGetDataByValue")});var p_=C((vOe,R0)=>{"use strict";var MOe=Ws(),l9=Tu(),u9=oe(),d9=(k(),P(q)),f9=sE();R0.exports=_9;async function _9(e,t){if(!u9.isEmpty(t)&&d9.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=l9(e,"value");if(n)throw n;return f9.prepSearch(e,t,!1)}a(_9,"lmdbSearchByValue")});var b0=C((BOe,y0)=>{"use strict";var xOe=kt(),$y=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}},Vy=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},Ky=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};y0.exports={SearchByConditionsObject:$y,SearchCondition:Vy,SortAttribute:Ky}});var C0=C((GOe,I0)=>{"use strict";var kOe=b0().SearchByConditionsObject,h9=Ws(),m9=Tu(),Yy=Su(),iE=kt(),{Resource:FOe}=(ia(),P(KA)),w0=sE(),p9=Hy(),E9=require("lodash"),{getSchemaPath:g9}=Et(),O0=_t(),{handleHDBError:S9,hdb_errors:T9}=me(),{HTTP_STATUS_CODES:A9}=T9,R9=1e8;I0.exports=y9;async function y9(e){let t=m9(e,"conditions");if(t)throw S9(t,t.message,A9.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=g9(e.schema,e.table),n=await O0.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let u of e.conditions)O0.openDBI(n,u.search_attribute);let i=E9.sortBy(e.conditions,u=>{if(u.estimated_count===void 0){let f=u.search_type;f===iE.SEARCH_TYPES.EQUALS?u.estimated_count=Yy.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=R9}return u.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await N0(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(w0.filterByType),d=f.length,_=Yy.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=>p9.parseRow(h,_))}else{for(let d=1;d<i.length;d++){let _=i[d],h=await N0(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=Yy.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(y9,"lmdbSearchByConditions");async function N0(e,t,r,n){let s=new h9(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,w0.searchByType(e,s,i,n).map(o=>o.value)}a(N0,"executeConditionSearch")});var E_=C(($Oe,P0)=>{"use strict";var b9=(k(),P(q)).OPERATIONS_ENUM,Wy=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=b9.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};P0.exports=Wy});var zy=C((KOe,H0)=>{"use strict";var v0=Ws(),U0=E_(),x0=p_(),B0=f_(),yn=(k(),P(q)),D0=oe(),L0=_t(),{getTransactionAuditStorePath:O9,getSchemaPath:N9}=Et(),M0=ee();H0.exports=w9;async function w9(e){try{if(D0.isEmpty(global.hdb_schema[e.schema])||D0.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await I9(e),await C9(e);let t=N9(e.schema,e.table);try{await L0.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")M0.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=O9(e.schema,e.table);await L0.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")M0.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(w9,"lmdbDropTable");async function I9(e){let t=new v0(yn.SYSTEM_SCHEMA_NAME,yn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,yn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[yn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await x0(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 U0(yn.SYSTEM_SCHEMA_NAME,yn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await B0(s)}a(I9,"deleteAttributesFromSystem");async function C9(e){let t=new v0(yn.SYSTEM_SCHEMA_NAME,yn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,yn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[yn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,yn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,yn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await x0(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 U0(yn.SYSTEM_SCHEMA_NAME,yn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await B0(s)}catch(i){throw i}}a(C9,"dropTableFromSystem")});var F0=C((WOe,k0)=>{"use strict";var P9=require("fs-extra"),D9=Ws(),L9=Au(),M9=E_(),v9=zy(),U9=f_(),x9=Fy(),B9=p_(),go=(k(),P(q)),{getSchemaPath:H9}=Et(),{handleHDBError:k9,hdb_errors:F9}=me(),{HDB_ERROR_MSGS:G9,HTTP_STATUS_CODES:q9}=F9;k0.exports=$9;async function $9(e){let t;try{t=await V9(e.schema);let r=new D9(go.SYSTEM_SCHEMA_NAME,go.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,go.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[go.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await B9(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await v9(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new M9(go.SYSTEM_SCHEMA_NAME,go.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await U9(s);let i=H9(t);await P9.remove(i)}catch(r){throw r}}a($9,"lmdbDropSchema");async function V9(e){let t=new L9(go.SYSTEM_SCHEMA_NAME,go.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[go.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await x9(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw k9(new Error,G9.SCHEMA_NOT_FOUND(e),q9.NOT_FOUND,void 0,void 0,!0);return n}a(V9,"validateDropSchema")});var g_=C((jOe,G0)=>{"use strict";var jy=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};G0.exports=jy});var Jy=C((XOe,q0)=>{"use strict";var K9=require("fs-extra"),oE=_t(),{getTransactionAuditStorePath:Y9}=Et(),Qy=kt(),JOe=g_();q0.exports=W9;async function W9(e){let t;try{let r=Y9(e.schema,e.table);await K9.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,Qy.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),oE.createDBI(t,Qy.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),oE.createDBI(t,Qy.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(W9,"createTransactionsAuditEnvironment")});var K0=C((tNe,V0)=>{"use strict";var Xy=(k(),P(q)),$0=_t(),z9=vc(),{getSystemSchemaPath:j9,getSchemaPath:Q9}=Et(),eNe=lo(),J9=Bp(),Zy=xp(),X9=ee(),Z9=Jy();V0.exports=e7;async function e7(e,t){let r=Q9(t.schema,t.table),n=new Zy(t.schema,t.table,Xy.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new Zy(t.schema,t.table,Xy.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new Zy(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await $0.createEnvironment(r,t.table),e!==void 0){let o=await $0.openEnvironment(j9(),Xy.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await z9.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 eb(n),await eb(s),await eb(i)}await Z9(t)}catch(o){throw o}}a(e7,"lmdbCreateTable");async function eb(e){try{await J9(e)}catch(t){X9.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(eb,"createAttribute")});var W0=C((nNe,Y0)=>{"use strict";var t7=jf(),r7=yf(),n7=Xp(),S_=(k(),P(q)),s7=vc().updateRecords,i7=_t(),{getSchemaPath:o7}=Et(),a7=u_(),c7=ee();Y0.exports=l7;async function l7(e){try{let{schema_table:t,attributes:r}=t7(e);r7(e,r,t.hash_attribute),e.schema!==S_.SYSTEM_SCHEMA_NAME&&(r.includes(S_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(S_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(S_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(S_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await n7(e.hdb_auth_header,t,r),s=o7(e.schema,e.table),i=await i7.openEnvironment(s,e.table),o=await s7(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await a7(e,o)}catch(c){c7.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(l7,"lmdbUpdateRecords")});var j0=C((iNe,z0)=>{"use strict";var u7=(k(),P(q)).OPERATIONS_ENUM,tb=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=u7.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};z0.exports=tb});var J0=C((cNe,Q0)=>{"use strict";var aNe=j0(),d7=jf(),f7=yf(),_7=Xp(),T_=(k(),P(q)),h7=vc().upsertRecords,m7=_t(),{getSchemaPath:p7}=Et(),E7=u_(),g7=ee(),{handleHDBError:S7,hdb_errors:T7}=me();Q0.exports=A7;async function A7(e){let t;try{t=d7(e)}catch(l){throw S7(l,l.message,T7.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;f7(e,n,r.hash_attribute),e.schema!==T_.SYSTEM_SCHEMA_NAME&&(n.includes(T_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(T_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(T_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(T_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await _7(e.hdb_auth_header,r,n),i=p7(e.schema,e.table),o=await m7.openEnvironment(i,e.table),c=await h7(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await E7(e,c)}catch(l){g7.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(A7,"lmdbUpsertRecords")});var Z0=C((uNe,X0)=>{"use strict";var rb=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};X0.exports=rb});var tx=C((fNe,ex)=>{"use strict";var nb=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}};ex.exports=nb});var sx=C((mNe,nx)=>{"use strict";var sb=_t(),{getTransactionAuditStorePath:R7}=Et(),hNe=Z0(),A_=kt(),y7=oe(),rx=tx(),b7=require("util").promisify,O7=b7(setTimeout),N7=1e4,w7=100;nx.exports=I7;async function I7(e){let t=R7(e.schema,e.table),r=await sb.openEnvironment(t,e.table,!0),n=sb.listDBIs(r);sb.initializeDBIs(r,A_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new rx;do s=await C7(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 O7(w7);while(s.transactions_deleted>0);return i}a(I7,"deleteAuditLogsBefore");async function C7(e,t){let r=new rx;try{let n=e.dbis[A_.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[A_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];y7.isEmpty(c)||(s=e.dbis[A_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[A_.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>N7)break}return await s,r}catch(n){throw n}}a(C7,"deleteTransactions")});var ox=C((ENe,ix)=>{"use strict";var ib=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};ix.exports=ib});var cx=C((TNe,ax)=>{"use strict";var P7=Ws(),D7=E_(),SNe=ox(),Pi=(k(),P(q)),L7=oe(),ob=_t(),M7=lo(),v7=p_(),U7=f_(),{getSchemaPath:x7}=Et();ax.exports=B7;async function B7(e,t=!0){let r;e.schema===Pi.SYSTEM_SCHEMA_NAME?r=M7[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await k7(e),s=x7(e.schema,e.table),i=await ob.openEnvironment(s,e.table);return t===!0&&await H7(e,i,r.hash_attribute),ob.dropDBI(i,e.attribute),n}a(B7,"lmdbDropAttribute");async function H7(e,t,r){let n=ob.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(H7,"removeAttributeFromAllObjects");async function k7(e){let t=new P7(Pi.SYSTEM_SCHEMA_NAME,Pi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Pi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Pi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,Pi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await v7(t)).filter(o=>o[Pi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(L7.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[Pi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new D7(Pi.SYSTEM_SCHEMA_NAME,Pi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return U7(i)}a(k7,"dropAttributeFromSystem")});var hx=C((yNe,_x)=>{"use strict";var ab=_t(),Ru=kt(),RNe=fn(),cb=(k(),P(q)),lx=oe(),{getTransactionAuditStorePath:F7}=Et(),G7=Su(),aE=pu(),q7=ee();_x.exports=$7;async function $7(e){let t=F7(e.schema,e.table),r=await ab.openEnvironment(t,e.table,!0),n=ab.listDBIs(r);ab.initializeDBIs(r,Ru.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case cb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return ux(r,e.search_values);case cb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,K7(r,e.search_values,s);case cb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return V7(r,e.search_values);default:return ux(r)}}a($7,"readAuditLog");function ux(e,t=[0,Date.now()]){lx.isEmpty(t[0])&&(t[0]=0),lx.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(ux,"searchTransactionsByTimestamp");function V7(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,fx(e,i))}return Object.fromEntries(r)}a(V7,"searchTransactionsByUsername");function K7(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let u=t[c],f=G7.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=fx(e,s),o=new Map;for(let c=0;c<i.length;c++){let l=i[c],u=l.timestamp,f=n.get(u);dx(l,"records",r,f,o),dx(l,"original_records",r,f,o)}return Object.fromEntries(o)}a(K7,"searchTransactionsByHashValues");function dx(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(dx,"loopRecords");function fx(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){q7.warn(i)}return r}catch(n){throw n}}a(fx,"batchSearchTransactions")});var px=C((wNe,mx)=>{"use strict";var{getSchemaPath:ONe}=Et(),NNe=_t(),{database:Y7}=(xe(),P(at));mx.exports={writeTransaction:W7};async function W7(e,t,r){return Y7({database:e,table:t}).transaction(r)}a(W7,"writeTransaction")});var Tx=C((CNe,Sx)=>{"use strict";var{getSchemaPath:Ex}=Et(),gx=_t();Sx.exports={flush:z7,resetReadTxn:j7};async function z7(e,t){return(await gx.openEnvironment(Ex(e,t),t.toString())).flushed}a(z7,"flush");async function j7(e,t){try{(await gx.openEnvironment(Ex(e,t),t.toString())).resetReadTxn()}catch{}}a(j7,"resetReadTxn")});var bx=C((DNe,yx)=>{"use strict";var{Readable:Q7}=require("stream"),{getDatabases:J7}=(xe(),P(at)),{readSync:X7,openSync:Z7,createReadStream:Ax}=require("fs"),{open:eee}=require("lmdb"),Rx=Vf(),tee=Kf(),{AUDIT_STORE_OPTIONS:ree}=(Ai(),P(Ox)),{INTERNAL_DBIS_NAME:nee,AUDIT_STORE_NAME:see}=kt();yx.exports=oee;var lb=32768,iee=100;async function oee(e){let t=e.database||e.schema||"data",r=J7()[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=eee({noSync:!0,maxDbs:tee.MAX_DBS}),_,h=d.openDB(nee,new Rx(!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++%iee===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 Rx(!v,v);await g(E,H)}e.include_audit&&await g(see,{...ree}),await _;let R=Ax(d.path);return R.headers=l(),R.on("close",()=>{m.done(),d.close()}),R}let o=r[Object.keys(r)[0]].primaryStore,c=Z7(o.path);return o.transaction(()=>{let u=Buffer.alloc(lb);X7(c,u,0,lb),o.resetReadTxn();let f=o.useReadTransaction();f.renew();let d=Ax(null,{fd:c,start:lb}),_=new Q7.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(oee,"getBackup")});var Ix=C((MNe,wx)=>{"use strict";var aee=ee(),{handleHDBError:cee}=me(),lee=nM(),uee=Bp(),dee=My(),fee=FU(),_ee=f_(),hee=Fy(),mee=f0(),pee=A0(),Eee=p_(),gee=C0(),See=F0(),Tee=K0(),Aee=W0(),Ree=J0(),yee=sx(),bee=zy(),Oee=cx(),Nee=hx(),wee=px(),Nx=Tx(),Iee=bx(),ub=class extends lee{static{a(this,"LMDBBridge")}async searchByConditions(t){return gee(t)}async getDataByHash(t){return await hee(t)}async searchByHash(t){return await mee(t)}async getDataByValue(t,r){return await pee(t,r)}async searchByValue(t){return await Eee(t)}async createSchema(t){return await fee(t)}async dropSchema(t){return await See(t)}async createTable(t,r){return await Tee(t,r)}async dropTable(t){return await bee(t)}async createAttribute(t){return await uee(t)}async createRecords(t){return await dee(t)}async updateRecords(t){return await Aee(t)}async upsertRecords(t){try{return await Ree(t)}catch(r){throw cee(r,null,null,aee.ERR,r)}}async deleteRecords(t){return await _ee(t)}async dropAttribute(t){return await Oee(t)}async deleteAuditLogsBefore(t){return await yee(t)}async readAuditLog(t){return await Nee(t)}writeTransaction(t,r,n){return wee.writeTransaction(t,r,n)}flush(t,r){return Nx.flush(t,r)}resetReadTxn(t,r){return Nx.resetReadTxn(t,r)}getBackup(t){return Iee(t)}};wx.exports=ub});var fb={};Ue(fb,{add:()=>cE,applyReverse:()=>Cx,getRecordAtTime:()=>db,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 Cx(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=Cee[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=Px}}function db(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":Cx(s,u.getValue(r));break;case"delete":s=null}i=u.previousLocalTime}let o={},c=0;for(let l in s)s[l]===Px&&(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 Cee,Px,uE=Re(()=>{Ai();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)};Cee={add:cE};a(lE,"rebuildUpdateBefore");a(Cx,"applyReverse");Px={};a(db,"getRecordAtTime")});function bn(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}`);bn(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}`);bn(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 ${_}`);bn(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}`);bn(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}`);bn(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}`);bn(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}`);bn(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}`);bn(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}`);bn(this)[l]=d},"set");break;case"Blob":u=a(function(d){if(!(d instanceof Ti||d==null&&c.nullable!==!1))throw new zn.ClientError(`${l} must be a Blob, attempt to assign ${d}`);bn(this)[l]=d},"set");break;case"Any":case void 0:u=a(function(d){bn(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}`);bn(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=_b(_,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");bn(this)[c]=l}),i("deleteProperty",function(c){bn(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,Lx);break}o=c}while(o&&o!==Lx)}function _b(e,t){let r;switch(e.constructor){case Object:return t?(r=t.TrackedObject,r||(t.TrackedObject=r=class extends R_{static{a(this,"TrackedObject")}},hE(r,t)),new r(e)):new R_(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=_b(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=fb[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)Pee.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,Dx,Lx,R_,Pee,Yc,fE,_E,hb=Re(()=>{zn=M(me());uE();gn();a(bn,"getChanges");a(hE,"assignTrackedAccessors");Dx=Object.prototype,Lx=new Proxy({},{get(e,t,r){if(typeof t=="string"){if(t==="then"||t==="getRecord"||t==="getChanges")return;if(Dx[t])return Dx[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=_b(s);if(i)return n||(n=Object.create(null),r._setChanges(n)),n[t]=i,i}return s}}});a(_b,"trackObject");R_=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(R_,{});a(mE,"collapseData");Pee=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 Fx={};Ue(Fx,{ResourceBridge:()=>Eb});function gb({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 vx(e,t){let r=Di(e),n=gb(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 Di(e){let t=e.database||e.schema||Lee,r=Xe()[t];if(!r)throw(0,zs.handleHDBError)(new Error,Dee.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function Ux(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*xx(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 Bx,pE,zs,Hx,mb,pb,kx,Dee,Lee,Mee,vee,Mx,Eb,Gx=Re(()=>{"use strict";Bx=M(Ix()),pE=M(Tu()),zs=M(me());xe();Hx=M(jf());k();mb=M(po()),pb=M(Ys()),kx=M(oe());gc();hb();({HDB_ERROR_MSGS:Dee}=zs.hdb_errors),Lee="data",Mee=1e4,vee=10,Eb=class extends Bx.default{static{a(this,"ResourceBridge")}constructor(t){super(t),Mx=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=Di(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:gb(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 Di(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=Di(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){Di(t).dropTable()}createSchema(t){return bu({database:t.schema,table:null}),mb.signalSchemaChange(new pb.SchemaEventMsg(process.pid,Yt.CREATE_SCHEMA,t.schema))}async dropSchema(t){await Sb(t.schema),mb.signalSchemaChange(new pb.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,Mx.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,Hx.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 Ux(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,kx.async_set_timeout)(vee),l=[],s=!0},"chunkDelete");for await(let f of n)l.push(f[r.primaryKey]),c++,c%Mee===0&&await u();return l.length>0&&await u(),s?Ux(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 vx(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of vx(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&pA[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=Di(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:gb(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async getDataByValue(t,r){let n=new Map,s=Di(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){Di({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return Di(t).deleteHistory(t.timestamp,t.cleanup_deleted_records)}async readAuditLog(t){let r=Di(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 xx(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return xx(r,t.search_values?.[0],t.search_values?.[1],t.limit)}}};a(gb,"getSelect");a(vx,"getRecords");a(Di,"getTable");a(Ux,"createDeleteResponse");a(xx,"groupRecordsInHistory")});var Kn=C((YNe,qx)=>{"use strict";var{ResourceBridge:Uee}=(Gx(),P(Fx)),xee=ce();xee.initSync();var EE;function Bee(){return EE||(EE=new Uee,EE)}a(Bee,"getBridge");qx.exports=Bee()});var Rn=C((zNe,Yx)=>{"use strict";var SE=hR(),xr=oe(),Hee=require("util"),TE=Kn(),kee=ps(),$x=ee(),{handleHDBError:Wc,hdb_errors:Fee}=me(),{HTTP_STATUS_CODES:zc}=Fee,Gee=Hee.promisify(kee.getTableSchema),qee="updated",Vx="inserted",Kx="upserted";Yx.exports={insert:Vee,update:Kee,upsert:Yee,validation:$ee,flush:Wee};async function $ee(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 Gee(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 $x.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 $x.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($ee,"validation");async function Vee(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(Vx,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(Vee,"insertData");async function Kee(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(qee,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(Kee,"updateData");async function Yee(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(Kx,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(Yee,"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===Vx?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===Kx?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(gE,"returnObject");function Wee(e){return xr.transformReq(e),TE.flush(e.schema,e.table)}a(Wee,"flush")});var Xx=C((QNe,Jx)=>{var Ou=require("validate.js"),zx=st(),Nu=(k(),P(q)),{handleHDBError:zee,hdb_errors:jee}=me(),{HDB_ERROR_MSGS:jt,HTTP_STATUS_CODES:Qee}=jee,Tb=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),Jee={STRUCTURE_USER:"structure_user"},Wx=Object.values(Nu.ROLE_TYPES_ENUM),Xee="attribute_permissions",Zee="attribute_name",{PERMS_CRUD_ENUM:wu}=Nu,ete=[Xee,...Object.values(wu)],jx=[wu.READ,wu.INSERT,wu.UPDATE],tte=[Zee,...jx];function rte(e){let t=Tb();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,Qx(e,t)}a(rte,"addRoleValidation");function nte(e){let t=Tb();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,Qx(e,t)}a(nte,"alterRoleValidation");function ste(e){let t=Tb();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,zx.validateObject(e,t)}a(ste,"dropRoleValidation");var ite=["operation","role","id","permission","hdb_user","access"];function Qx(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)ite.includes(n[o])||s.push(n[o]);s.length>0&&nr(jt.INVALID_ROLE_JSON_KEYS(s),r);let i=zx.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{nr(o,r)}),e.permission){let o=ote(e);o&&nr(o,r),Wx.forEach(c=>{e.permission[c]&&!Ou.isBoolean(e.permission[c])&&nr(jt.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(Wx.indexOf(o)<0){if(o===Jee.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(jt.SCHEMA_NOT_FOUND(d),r)}continue}nr(jt.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){nr(jt.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(jt.TABLE_NOT_FOUND(o,l),r);continue}if(Object.keys(u).forEach(f=>{ete.includes(f)||nr(jt.INVALID_PERM_KEY(f),r,o,l)}),Object.values(wu).forEach(f=>{Ou.isDefined(u[f])?Ou.isBoolean(u[f])||nr(jt.TABLE_PERM_NOT_BOOLEAN(f),r,o,l):nr(jt.TABLE_PERM_MISSING(f),r,o,l)}),u.attribute_permissions===void 0){nr(jt.ATTR_PERMS_ARRAY_MISSING,r,o,l);continue}else if(!(Array.isArray(u.attribute_permissions)||u.attribute_permissions===null)){nr(jt.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=>{!tte.includes(S)&&S!==wu.DELETE&&nr(jt.INVALID_ATTR_PERM_KEY(S),r,o,l)}),!Ou.isDefined(h.attribute_name)){nr(jt.ATTR_PERM_MISSING_NAME,r,o,l);continue}let m=h.attribute_name;if(!f.includes(m)){nr(jt.INVALID_ATTRIBUTE_IN_PERMS(m),r,o,l);continue}jx.forEach(S=>{Ou.isDefined(h[S])?Ou.isBoolean(h[S])||nr(jt.ATTR_PERM_NOT_BOOLEAN(S,m),r,o,l):nr(jt.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(jt.MISMATCHED_TABLE_ATTR_PERMS(_),r,o,l)}}}}return ate(r)}a(Qx,"customValidate");Jx.exports={addRoleValidation:rte,alterRoleValidation:nte,dropRoleValidation:ste};function ote(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 jt.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?Nu.ROLE_TYPES_ENUM.SUPER_USER:Nu.ROLE_TYPES_ENUM.CLUSTER_USER;return jt.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(ote,"validateNoSUPerms");function ate(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:jt.ROLE_PERMS_ERROR,...e};return zee(new Error,n,Qee.BAD_REQUEST)}else return null}a(ate,"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 b_=C((ZNe,rB)=>{"use strict";var Zx=Rn(),eB=Wr(),cte=Fc(),Rb=Xx(),yb=po(),XNe=require("uuid").v4,lte=require("util"),AE=(k(),P(q)),ute=oe(),bb=eB.searchByValue,dte=eB.searchByHash,fte=lte.promisify(cte.delete),_te=Ws(),hte=Au(),{hdb_errors:mte,handleHDBError:jc}=me(),{HDB_ERROR_MSGS:tB,HTTP_STATUS_CODES:y_}=mte,{UserEventMsg:Ob}=Ys();rB.exports={addRole:pte,alterRole:Ete,dropRole:gte,listRoles:Ste};function Ab(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(Ab,"scrubRoleDetails");async function pte(e){let t=Rb.addRoleValidation(e);if(t)throw t;e=Ab(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 bb(r)||[])}catch(i){throw jc(i)}if(n&&n.length>0)throw jc(new Error,tB.ROLE_ALREADY_EXISTS(e.role),y_.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 Zx.insert(s),yb.signalUserChange(new Ob(process.pid)),e=Ab(e),e}a(pte,"addRole");async function Ete(e){let t=Rb.alterRoleValidation(e);if(t)throw t;e=Ab(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await Zx.update(r)}catch(s){throw jc(s)}if(n&&n?.message==="updated 0 of 1 records")throw jc(new Error,"Invalid role id",y_.BAD_REQUEST,void 0,void 0,!0);return await yb.signalUserChange(new Ob(process.pid)),e}a(Ete,"alterRole");async function gte(e){let t=Rb.dropRoleValidation(e);if(t)throw jc(new Error,t,y_.BAD_REQUEST,void 0,void 0,!0);let r=new hte(AE.SYSTEM_SCHEMA_NAME,AE.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await dte(r));if(n.length===0)throw jc(new Error,tB.ROLE_NOT_FOUND,y_.NOT_FOUND,void 0,void 0,!0);let s=new _te(AE.SYSTEM_SCHEMA_NAME,AE.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await bb(s)),o=!1;if(ute.isEmptyOrZeroLength(i)===!1){for(let l=0;l<i.length;l++)if(i[l].active===!0){o=!0;break}}if(o===!0)throw jc(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,y_.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await fte(c),yb.signalUserChange(new Ob(process.pid)),`${n[0].role} successfully deleted`}a(gte,"dropRole");async function Ste(){return bb({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(Ste,"listRoles")});var Nb={};Ue(Nb,{start:()=>iB,startOnMainThread:()=>Rte});function iB({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r){let n=(0,nB.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(Tte.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 Ate(i)}}}async function Ate(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,sB.isEqual)(i,e)?void 0:(e.id=r.id,(0,RE.alterRole)(e))}return(0,RE.addRole)(e)}var RE,nB,sB,Tte,Rte,oB=Re(()=>{xe();RE=M(b_()),nB=require("yaml"),sB=require("lodash"),Tte=["super_user","cluster_user","structure_user"];a(iB,"start");a(Ate,"ensureRole");Rte=iB});async function yE(e){let t=(0,lB.pathToFileURL)(e).toString();if(yte)return O_||(O_=bte(Nte)),(await(await O_).import(t)).namespace;try{return await import(t)}catch(r){try{(await import("internal/util")).default.decorateErrorStack(r)}catch{}throw r}}async function bte(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),O_=new Compartment({console,Math,Date,fetch:Ote,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,cB.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:jn,databases:We})}};let n=await(0,aB.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)},"importHook")}),O_}function Ote(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 Nte(){return{Resource:Kr,tables:jn}}var aB,cB,lB,yte,O_,wb=Re(()=>{ia();xe();aB=require("fs/promises"),cB=require("path"),lB=require("url"),yte=!1;a(yE,"secureImport");a(bte,"getCompartment");a(Ote,"secureOnlyFetch");a(Nte,"getGlobalVars")});var Cb={};Ue(Cb,{handleFile:()=>wte});async function wte(e,t,r,n){let s=new Map,i=await yE(r);c(i.default)&&n.set((0,Ib.dirname)(t),i.default),o(i,(0,Ib.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 Ib,uB=Re(()=>{wb();Ib=require("path");a(wte,"handleFile")});var Db={};Ue(Db,{start:()=>Ite});function Ite({resources:e}){e.set("login",Pb),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var Pb,dB=Re(()=>{ia();a(Ite,"start");Pb=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 D_={};Ue(D_,{addAnalyticsListener:()=>P_,calculateCPUUtilization:()=>PB,diffResourceUsage:()=>DB,recordAction:()=>Dt,recordActionBinary:()=>Qn,setAnalyticsEnabled:()=>Cte});function Cte(e){OB=e}function Pte(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 Dte(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(!OB)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=OE.get(i);o?Pte(e,o):Dte(i,e,t,r,n,s),bE||Lte()}function Qn(e,t,r,n,s){Dt(!!e,t,r,n,s)}function P_(e){IB.push(e)}function Lte(){bE=performance.now(),setTimeout(async()=>{let e=performance.now()-bE;bE=0;let t=[],r={time:Date.now(),period:e,threadId:Qc.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 CB){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 LB()}let n=process.memoryUsage();t.push({metric:"memory",threadId:Qc.threadId,byThread:!0,...n});for(let s of IB)s(t);OE=new Map,Qc.parentPort?Qc.parentPort.postMessage({type:wB,report:r}):UB({report:r})},NB).unref()}function NE(e,t,r){let n={id:(0,I_.getNextMonotonicTime)(),metric:t,...r};e.primaryStore.put(n.id,n,{append:!0}).then(s=>{s||e.primaryStore.put(n.id,n)})}function PB(e,t){let r=e.userCPUTime+e.systemCPUTime;return Math.round(r/t*100)/100}function DB(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 Mte(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 fB(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s?.getAuditSize();if(!i)return;let o=bB.default.statSync(s.primaryStore.env.path).size,c=Mte(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 _B(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 vte(e,t=6e4){let r=Mb(),n=MB(),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 Mn=Ae[ut];typeof Mn=="number"&&(ye[ut]=(ye[ut]*xt+Mn*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 LB()}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,Mn)=>ut.value>Mn.value?1:-1);let v=N.count-1,H=[],X=0,W=0,$;for(let ut of CB){let Mn=v*ut;for(;X<Mn;)$=T[W++],X+=$.count,W===1&&X--;let an=T[W>1?W-2:0];$||($=T[0]),H.push($.value-($.value-an.value)*(X-Mn)/$.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,I_.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,I_.getNextMonotonicTime)(),T={id:E,metric:"main-thread-utilization",idle:h-hB,active:m-mB,taskQueueLatency:await s,time:_,...process.memoryUsage()};n.primaryStore.put(E,T,{append:!0}).then(N=>{N||n.primaryStore.put(E,T)})}hB=h,mB=m;let S=process.resourceUsage(),g=DB(N_,S);g.time=_,g.period=N_.time?_-N_.time:t,g.cpuUtilization=PB(N_,g.period),NE(n,"resource-usage",g),N_=g;let R=Xe();fB(n,R),fB(n,{system:R.system}),_B(n,R),_B(n,{system:R.system})}async function pB(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function Mb(){return EB||(EB=ft({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function MB(){return gB||(gB=ft({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function Bte(){vB=!0;let e=(0,C_.get)(B.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await vte(NB,e),await pB(Mb(),Ute),await pB(MB(),xte)},Math.min(e/2,2147483647)).unref()}function UB(e,t){let r=e.report;r.threadId=t?.threadId||Qc.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(SB+=n.mean*n.count);r.totalBytesProcessed=SB,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(TB.get(t))}),TB.set(t,t.performance.eventLoopUtilization())),r.id=(0,I_.getNextMonotonicTime)(),Mb().primaryStore.put(r.id,r),vB||Bte(),Hte&&(xB=Fte(r))}async function Fte(e){if(await xB,!pa){let r=(0,w_.dirname)((0,RB.getLogFilePath)());try{pa=await(0,Lb.open)((0,w_.join)(r,"analytics.log"),"r+")}catch{pa=await(0,Lb.open)((0,w_.join)(r,"analytics.log"),"w+")}}let t=(await pa.stat()).size;if(t>kte){let r=Buffer.alloc(t);await pa.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await pa.write(r,{position:0}),await pa.truncate(r.length),t=r.length}await pa.write(JSON.stringify(e)+`
|
|
20
20
|
`,t)}var Qc,AB,RB,yB,w_,Lb,I_,C_,bB,Jc,OE,OB,bE,NB,wB,IB,CB,hB,mB,N_,LB,Ute,xte,EB,gB,vB,SB,TB,Hte,xB,pa,kte,Li=Re(()=>{Qc=require("worker_threads"),AB=M(it());xe();RB=M(ee()),yB=M(Gs()),w_=require("path"),Lb=require("fs/promises"),I_=M(fn()),C_=M(ce());k();Mr();bB=M(require("node:fs")),Jc=(0,yB.loggerWithTag)("analytics");(0,C_.initSync)();OE=new Map,OB=(0,C_.get)(B.ANALYTICS_AGGREGATEPERIOD)>-1;a(Cte,"setAnalyticsEnabled");a(Pte,"recordExistingAction");a(Dte,"recordNewAction");a(Dt,"recordAction");Ye.recordAnalytics=Dt;a(Qn,"recordActionBinary");bE=0,NB=1e3,wB="analytics-report",IB=[];a(P_,"addAnalyticsListener");CB=[.01,.1,.25,.5,.75,.9,.95,.99,.999,1];a(Lte,"sendAnalytics");a(NE,"storeMetric");a(PB,"calculateCPUUtilization");a(DB,"diffResourceUsage");a(Mte,"storeTableSizeMetrics");a(fB,"storeDBSizeMetrics");a(_B,"storeVolumeMetrics");a(vte,"aggregation");hB=0,mB=0,N_={},LB=a(()=>new Promise(setImmediate),"rest");a(pB,"cleanup");Ute=36e5,xte=31536e6;a(Mb,"getRawAnalyticsTable");a(MB,"getAnalyticsTable");(0,AB.setChildListenerByType)(wB,UB);a(Bte,"startScheduledTasks");SB=0,TB=new Map,Hte=!1;a(UB,"recordAnalytics");kte=1e6;a(Fte,"logAnalytics")});var BB={};Ue(BB,{Headers:()=>So,appendHeader:()=>wE,mergeHeaders:()=>vb});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 vb(e,t){(typeof e.set!="function"||typeof e.has!="function")&&(e=new So(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 So,L_=Re(()=>{So=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(vb,"mergeHeaders")});function qB(e){let t={openapi:Gte,info:{title:"HarperDB HTTP REST interface",version:GB.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:Ea+v.type}}:u[N]={$ref:Ea+T};else{let W=X??v?.definition;if(W){if(!t.components.schemas[W.type]){let $={};W.properties.forEach(ie=>{$[ie.name]=new Hb(Ub[ie.type],ie.type)}),t.components.schemas[W.type]=new FB($)}T==="array"?u[N]={type:"array",items:{$ref:Ea+W.type}}:u[N]={$ref:Ea+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 Hb(Ub[v.type],v.type)}:T==="Any"||T=="ID"?u[N]={format:T}:u[N]=new Hb(Ub[T],T)}f.push(new kb(N,"query",u[N]))}let d=Object.keys(u),_=new kb(c,"path",{format:"ID"});_.required=!0,_.description="primary key of record";let h=new kb("property","path",{enum:d});h.required=!0,t.components.schemas[i]=new FB(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 qte(i,r,"create a new record auto-assigning a primary key")),g&&(t.paths[E]||(t.paths[E]={}),t.paths[E].get=new xb(f,r,{200:new Bb({$ref:Ea+i})},"search for records by the specified property name and value pairs")),R&&(t.paths[E]||(t.paths[E]={}),t.paths[E].delete=new kB(f,r,"delete all the records that match the provided query",{204:new HB})),E="/"+s+"/{"+c+"}",g&&(t.paths[E]={},t.paths[E].get=new xb([_],r,{200:new Bb({$ref:Ea+i})},"retrieve a record by its primary key")),S&&(t.paths[E]||(t.paths[E]={}),t.paths[E].put=new $te([_],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 kB([_],r,"delete a record with the given primary key",{204:new HB})),g&&h.schema.enum.length>0&&(E="/"+s+"/{"+c+"}.{property}",t.paths[E]={},t.paths[E].get=new xb([_,h],r,{200:new Bb({enum:d})},"used to retrieve the specified property of the specified record"))}return t}function qte(e,t,r){this.description=r,this.requestBody={content:{"application/json":{schema:{$ref:Ea+e}}}},this.security=t,this.responses={200:{description:Fb,headers:{Location:{description:"primary key of new record",schema:{type:"string",format:"ID"}}},content:{"application/json":{schema:{type:"string",format:"ID"}}}}}}function xb(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.responses=r}function Bb(e){this.description=Fb,this.content={"application/json":{schema:e}}}function HB(){this.description="successfully processed request, no content returned to client"}function $te(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.requestBody={content:{"application/json":{schema:{$ref:Ea+r}}}},this.responses={200:{description:Fb}}}function kB(e,t,r,n){this.description=r,this.parameters=e,this.security=t,this.responses=n}function FB(e){this.type="object",this.properties=e}function Hb(e,t){this.type=e,this.format=t}function kb(e,t,r){this.name=e,this.in=t,this.schema=r}var GB,Gte,Ub,Ea,Fb,$B=Re(()=>{GB=M(pt()),Gte="3.0.3",Ub={Int:"integer",Float:"number",Long:"integer",String:"string",Boolean:"boolean",Date:"string",Bytes:"string",BigInt:"integer",array:"array"},Ea="#/components/schemas/",Fb="successful operation";a(qB,"generateJsonApi");a(qte,"Post");a(xb,"Get");a(Bb,"Response200");a(HB,"Response204");a($te,"Put");a(kB,"Delete");a(FB,"ResourceSchema");a(Hb,"Type");a(kb,"Parameter")});var KB={};Ue(KB,{Request:()=>M_,createReuseportFd:()=>IE});var VB,M_,Gb,qb,IE,CE=Re(()=>{VB=require("os"),M_=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 qb(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 Gb(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)}},Gb=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)}},qb=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,VB.platform)()!="win32"&&(IE=require("node-unix-socket").createReuseportFd)});var DE={};Ue(DE,{parseHeaderValue:()=>Vb,start:()=>Yte});async function Kte(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 So;try{e.responseHeaders=i;let o=e.url.slice(1),c,l;if(o!==YB){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=Vb(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=Vb(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=ao(r["content-type"],!0)(e.body,e.headers)}catch(g){throw new Iu.ClientError(g,400)}if(e.authorize=!0,o===YB&&s==="GET"){if(e?.user?.role?.permission?.super_user)return qB(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,$b.lastModified&&e.lastModified&&i.setIfNone("Last-Modified",new Date(e.lastModified).toUTCString());else if(d.status>0&&d.headers){let g=vb(d.headers,i);return d.headers!==g&&(d.headers=g),d.data!==void 0&&(d.body=Bf(d.data,e,d)),d}else if(h=e.lastModified){Vte[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),$b.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=Bf(d,e,m),s==="HEAD"&&(m.body=void 0)),m}catch(o){o.statusCode?o.statusCode===500?Mi.warn(o):Mi.info(o):Mi.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=Bf(o.contentType?o:o.toString(),e,c),c}}function Yte(e){$b=e,e.includeExpensiveRecordCountEstimates&&(M_.prototype.includeExpensiveRecordCountEstimates=!0),!WB&&(WB=!0,PE=e.resources,e.server.http(async(t,r)=>{if(!t.isWebSocket)return Kte(t,r)},e),e.webSocket!==!1&&e.server.ws(async(t,r,n)=>{v_++;let s=new kn;zB||(zB=!0,P_(l=>{v_>0&&l.push({metric:"ws-connections",connections:v_,byThread:!0})}));let i;t.on("error",l=>{i=!0,Mi.warn(l)});let o;t.on("message",a(function(u){o||(o=ao(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",()=>{v_--,Qn(!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(Qn(!!u,"connection","ws","connect"),u){r.handlerPath=u.path,Dt(m=>({count:m.count,total:v_}),"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 la(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?Mi.warn(l):Mi.info(l):Mi.error(l),t.close(Wte[l.statusCode]||1011,l.toString())}t.close()},e))}function Vb(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 Mi,Iu,Br,Vte,$b,YB,WB,PE,zB,v_,Wte,jB=Re(()=>{so();Li();Mi=M(ee()),Iu=M(me());If();Ql();gc();L_();$B();If();CE();Br=new Uint8Array(8),Vte=new Float64Array(Br.buffer,0,1),$b={},YB="openapi";a(Kte,"http");v_=0;a(Yte,"start");Wte={401:3e3,403:3003};a(Vb,"parseHeaderValue")});var Kb=C((Pwe,JB)=>{var{recordAction:LE,recordActionBinary:QB}=(Li(),P(D_)),zte=require("fastify-plugin"),jte=200;JB.exports=zte(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),QB(s.raw.statusCode<400,"success",u,d,f),QB(1,"response_"+s.raw.statusCode,u,d,f);let _=jte;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 ZB=C((Dwe,XB)=>{var Qte=st(),Jte={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};XB.exports=function(e){return Qte.validateObject(e,Jte)}});var ME=C((Lwe,eH)=>{"use strict";var Xte=(k(),P(q)).OPERATIONS_ENUM,Yb=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=Xte.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};eH.exports=Yb});var B_={};Ue(B_,{createTokens:()=>ere,getJWTRSAKeys:()=>HE,refreshOperationToken:()=>tre,validateOperationToken:()=>jb,validateRefreshToken:()=>kE});async function HE(){if(vE)return vE;try{let e=U_.default.join(x_.default.getHdbBasePath(),_A),t=await UE.default.readFile(U_.default.join(e,cf.JWT_PASSPHRASE_NAME),"utf8"),r=await UE.default.readFile(U_.default.join(e,cf.JWT_PRIVATE_KEY_NAME),"utf8");return vE={publicKey:await UE.default.readFile(U_.default.join(e,cf.JWT_PUBLIC_KEY_NAME),"utf8"),privateKey:r,passphrase:t},vE}catch(e){throw BE.default.error(e),new js.ClientError(Pu.NO_ENCRYPTION_KEYS,Cu.INTERNAL_SERVER_ERROR)}}async function ere(e){let t=(0,Wb.validateBySchema)(e,vi.default.object({username:vi.default.string().optional(),password:vi.default.string().optional(),role:vi.default.string().optional(),expires_in:vi.default.alternatives(vi.default.string(),vi.default.number()).optional()}));if(t)throw new js.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,zb.findAndValidateUser)(e.username,e.password,d)}catch(d){throw BE.default.error(d),new js.ClientError(Pu.INVALID_CREDENTIALS,Cu.UNAUTHORIZED)}if(!r)throw new js.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??iH,algorithm:xE,subject:"operation"}),l=await Du.default.sign(i,{key:o.privateKey,passphrase:o.passphrase},{expiresIn:Zte,algorithm:xE,subject:"refresh"}),u=hy(l,"sha256");if((await(0,tH.update)(new rH.default(af,Kl.USER_TABLE_NAME,[{username:e.username,refresh_token:u}]))).skipped_hashes.length>0)throw new js.ClientError(Pu.REFRESH_TOKEN_SAVE_FAILED,Cu.INTERNAL_SERVER_ERROR);return nH.default.signalUserChange(new sH.UserEventMsg(process.pid)),{operation_token:c,refresh_token:l}}async function tre(e){let t=(0,Wb.validateBySchema)(e,vi.default.object({refresh_token:vi.default.string().required()}).required());if(t)throw new js.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:iH,algorithm:xE,subject:"operation"})}}async function jb(e){return oH(e,"operation")}async function kE(e){return oH(e,"refresh")}async function oH(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,zb.findAndValidateUser)(n.username,void 0,!1);if(t==="refresh"&&!my(s.refresh_token,e))throw new Error("Invalid token");return s}catch(r){throw BE.default.warn(r),r?.name==="TokenExpiredError"?new js.ClientError(Pu.TOKEN_EXPIRED,Cu.FORBIDDEN):new js.ClientError(Pu.INVALID_TOKEN,Cu.UNAUTHORIZED)}}var Du,UE,U_,vi,Wb,js,BE,zb,tH,rH,nH,sH,x_,Cu,Pu,iH,Zte,xE,vE,Lu=Re(()=>{Du=M(require("jsonwebtoken")),UE=M(require("fs-extra")),U_=M(require("node:path")),vi=M(require("joi")),Wb=M(st());k();js=M(me()),BE=M(ee());Wp();zb=M(An()),tH=M(Rn()),rH=M(ME()),nH=M(po()),sH=M(Ys()),x_=M(ce()),{HTTP_STATUS_CODES:Cu,AUTHENTICATION_ERROR_MSGS:Pu}=js.hdb_errors;x_.default.initSync();iH=x_.default.get(B.AUTHENTICATION_OPERATIONTOKENTIMEOUT)||"1d",Zte=x_.default.get(B.AUTHENTICATION_REFRESHTOKENTIMEOUT)||"30d",xE="RS256";a(HE,"getJWTRSAKeys");a(ere,"createTokens");a(tre,"refreshOperationToken");a(jb,"validateOperationToken");a(kE,"validateRefreshToken");a(oH,"validateToken")});var Qb=C((Bwe,lH)=>{"use strict";var rre=ZB(),Mu=require("passport"),nre=require("passport-local").Strategy,sre=require("passport-http").BasicStrategy,ire=require("util"),ore=An(),cH=ire.callbackify(ore.findAndValidateUser),xwe=xn(),are=(k(),P(q)),aH=(Lu(),P(B_));Mu.use(new nre(function(e,t,r){cH(e,t,r)}));Mu.use(new sre(function(e,t,r){cH(e,t,r)}));Mu.serializeUser(function(e,t){t(null,e)});Mu.deserializeUser(function(e,t){t(null,e)});function cre(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===are.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?aH.validateRefreshToken(s).then(o=>{e.body.refresh_token=s,r(null,o)}).catch(o=>{r(o)}):aH.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(cre,"authorize");function lre(e,t){let r=rre(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(lre,"checkPermissions");lH.exports={authorize:cre,checkPermissions:lre}});var FE=C((kwe,uH)=>{"use strict";var ure=Kn();uH.exports={writeTransaction:dre};function dre(e,t,r){return ure.writeTransaction(e,t,r)}a(dre,"writeTransaction")});var hH=C((qwe,_H)=>{"use strict";var fre=Wr(),_re=ps(),dH=ee(),hre=Rn(),Gwe=FE(),mre=require("clone"),Xb=require("alasql"),pre=kp(),fH=require("util"),Ere=fH.promisify(_re.getTableSchema),gre=fH.promisify(fre.search),Sre=(k(),P(q)),Jb=oe();pre(Xb);_H.exports={update:Are};var Tre="There was a problem performing this update. Please check the logs and try again.";async function Are({statement:e,hdb_user:t}){let r=await Ere(e.table.databaseid,e.table.tableid),n=Rre(e.columns);Jb.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=mre(s),c=Jb.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,u=Xb.parse(l).statements[0],f=await gre(u),d=yre(n,f);return bre(o,d,t)}a(Are,"update");function Rre(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=Xb.compile(`SELECT ${r.expression.toString()} AS [${Sre.FUNC_VAL}] FROM ?`)}),t}catch(t){throw dH.error(t),new Error(Tre)}}a(Rre,"createUpdateRecord");function yre(e,t){return Jb.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(yre,"buildUpdateRecords");async function bre(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await hre.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){dH.error(`Error delete new_attributes from update response: ${i}`)}return s}a(bre,"updateRecords")});var pH=C((Ywe,mH)=>{var Ore=require("alasql"),Nre=Wr(),wre=ee(),Ire=Kn(),eO=require("util"),Zb=oe(),Cre=(k(),P(q)),Pre=ps(),Vwe=FE(),Kwe=Rn(),Dre="record",Lre="successfully deleted",Mre=eO.callbackify(Bre),vre=eO.promisify(Nre.search),Ure=eO.promisify(Pre.getTableSchema);mH.exports={convertDelete:Mre};function xre(e){return`${e.deleted_hashes.length} ${Dre}${e.deleted_hashes.length===1?"":"s"} ${Lre}`}a(xre,"generateReturnMessage");async function Bre({statement:e,hdb_user:t}){let r=await Ure(e.table.databaseid,e.table.tableid);Zb.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=Zb.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=Ore.parse(o).statements[0],l={operation:Cre.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await vre(c);let u=await Ire.deleteRecords(l);return Zb.isEmptyOrZeroLength(u.message)&&(u.message=xre(u)),delete u.txn_time,u}catch(u){throw wre.error(u),u.hdb_code?u.message:u}}a(Bre,"convertDelete")});var AH=C((zwe,TH)=>{"use strict";var Hre=ho(),{hdb_errors:EH}=me(),{getDatabases:gH}=(xe(),P(at));TH.exports={checkSchemaExists:SH,checkSchemaTableExists:kre,schema_describe:Hre};async function SH(e){if(!gH()[e])return EH.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(SH,"checkSchemaExists");async function kre(e,t){let r=await SH(e);if(r)return r;if(!gH()[e][t])return EH.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(kre,"checkSchemaTableExists")});var iO=C((Zwe,MH)=>{"use strict";var{decode:Fre}=require("msgpackr"),{isMainThread:Qwe,parentPort:Jwe,threadId:Xwe}=require("worker_threads"),$E=sr(),vu=Pt(),nO=(k(),P(q)),Qr=ee(),rO=ce(),Gre=(k(),P(q)),{onMessageByType:qre}=it(),OH=_o(),{recordAction:RH,recordActionBinary:$re}=(Li(),P(D_)),{publishToStream:Vre}=$E,{ConsumerEvents:yH}=require("nats"),Kre=Wr(),{promisify:Yre}=require("util"),{decodeBlobsWithWrites:Wre}=(gn(),P(au)),NH=Yre(setTimeout),VE=1e4,KE,qE,zre,jre,wH,H_=new Map,Uu=new Map;MH.exports={initialize:IH,ingestConsumer:sO,setSubscription:Qre,setIgnoreOrigin:Zre,getDatabaseSubscriptions:Xre,updateConsumer:CH};async function IH(){qre(nO.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,async n=>{await CH(n)}),wH=!0,Qr.notify("Initializing clustering ingest service.");let{connection:e,jsm:t,js:r}=await $E.getNATSReferences();KE=e,qE=e.info.server_name,zre=t,jre=r}a(IH,"initialize");async function CH(e){if(e.status==="start"){let{js:t,jsm:r}=await PH(e.node_domain_name);sO(e.stream_name,t,r,e.node_domain_name)}else if(e.status==="stop"){let t=H_.get(e.stream_name+e.node_domain_name);t&&(Qr.notify("Closing ingest consumer for node:",e.node_domain_name,"stream:",e.stream_name),await t.close?.(),H_.set(e.stream_name+e.node_domain_name,"close")),Uu.get(e.node_domain_name)==="failed"&&Uu.set(e.node_domain_name,"close")}}a(CH,"updateConsumer");var YE=new Map;function Qre(e,t,r){let n=YE.get(e);n||YE.set(e,n=new Map),n.set(t,r),wH||IH().then(Jre)}a(Qre,"setSubscription");async function Jre(){let e=await Kre.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 PH(r),!n))break;let{schema:o,table:c}=i,l=OH.createNatsTableStreamName(o,c);sO(l,n,s,r)}}}a(Jre,"accessConsumers");async function PH(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&&Qr.warn("Nats ingest attempting to connect to:",e,"Nats error:",s.message);let i=n++*100<VE?n++*100:VE;await NH(i)}return{js:t,jsm:r}}a(PH,"connectToRemoteJS");function Xre(){return YE}a(Xre,"getDatabaseSubscriptions");var DH;function Zre(e){DH=e}a(Zre,"setIgnoreOrigin");var LH=100,bH=new Array(LH),GE=0;async function sO(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),Qr.notify("Initializing ingest consumer for node:",n,"stream:",e)}catch(u){if(Uu.get(n)==="close")break;o%10===1&&Qr.warn("Nats ingest error getting consumer:",n,"stream:",e,"Nats error:",u.message),u.code==="404"&&(Qr.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 NH(f)}let c=!1,l;for(;!c;){if(H_.get(e+n)==="close"||Uu.get(n)==="close"){H_.delete(e+n),c=!0;continue}l=await i.consume({max_messages:rO.get(nO.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS)??100,bind:!0}),H_.set(e+n,l);let u=!1;(async()=>{for await(let f of await l.status())if(f.type===yH.ConsumerDeleted&&(await l.close(),c=!0),f.type===yH.HeartbeatsMissed){let d=f.data;Qr.trace(`${d} clustering ingest consumer heartbeats missed, node: ${n} stream: ${l.consumer.stream}`),d===100&&(Qr.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 bH[GE],bH[GE]=ene(f).catch(d=>{Qr.error(d)}),++GE>=LH&&(GE=0)}catch(f){f.message==="consumer deleted"?(Qr.notify("Nats consumer deleted, closing messages for node:",n,"stream:",l.consumer.stream),await l.close(),c=!0):Qr.error("Error consuming clustering ingest, restarting consumer",f)}}}a(sO,"ingestConsumer");async function ene(e){let t;await Wre(()=>{t=Fre(e.data)}),RH(e.data.length,"bytes-received",e.subject,t.operation,"ingest"),Qr.trace("Nats message processor message size:",e?.msg?._msg?.size,"bytes");let r=e.headers,n=!1,s=rO.get(nO.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&&!DH),$re(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;Qr.trace("processing message:",o,c,u,(f?"records: "+f.map(v=>v?.id):"")+(d?"ids: "+d:""),"with sequence:",e.seq),Qr.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:tO(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:tO(o),value:H,expiresAt:h,id:d?.[X],table:u}));for(;l;)v.push({type:tO(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})}rO.get(Gre.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&Vre(e.subject.split(".").slice(0,-1).join("."),OH.createNatsTableStreamName(c,u),e.headers,e.data),await S;let N=Date.now()-g;g&&RH(N,"replication-latency",e.subject,o,"ingest")}catch(o){Qr.error(o)}e.ack()}a(ene,"messageProcessor");function tO(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}a(tO,"convertOperation")});var sr=C((oIe,QH)=>{"use strict";var wr=ce();wr.initSync();var tne=require("fs-extra"),rne=require("semver"),G_=require("path"),{monotonicFactory:nne}=require("ulidx"),UH=nne(),sne=require("util"),xH=require("child_process"),ine=sne.promisify(xH.exec),one=xH.spawn,Hr=Pt(),je=(k(),P(q)),{packageJson:ane,PACKAGE_ROOT:cne}=pt(),WE=oe(),Qs=ee(),zE=_o(),lne=FE(),k_=It(),{broadcast:une,onMessageByType:dne,getWorkerIndex:fne}=it(),{isMainThread:BH}=require("worker_threads"),{Encoder:_ne,decode:lO}=require("msgpackr"),HH=new _ne,{isEmpty:tl}=WE,kH=An(),tIe=48*36e11;BH&&dne(je.ITC_EVENT_TYPES.RESTART,()=>{Jr=void 0,el=void 0});var{connect:hne,StorageType:mne,RetentionPolicy:pne,AckPolicy:uO,DeliverPolicy:dO,DiscardPolicy:Ene,NatsConnection:rIe,JetStreamManager:nIe,JetStreamClient:sIe,StringCodec:iIe,JSONCodec:gne,createInbox:fO,headers:Sne,ErrorCode:vH}=require("nats"),{recordAction:Tne}=(Li(),P(D_)),{encodeBlobsAsBuffers:Ane}=(gn(),P(au)),FH=gne(),Rne="clustering",yne=ane.engines[Hr.NATS_SERVER_NAME],bne=G_.join(cne,"dependencies"),cO=G_.join(bne,`${process.platform}-${process.arch}`,Hr.NATS_BINARY_NAME),oO,aO,F_,Xc,Zc;QH.exports={runCommand:GH,checkNATSServerInstalled:One,createConnection:_O,getConnection:q_,getJetStreamManager:$_,getJetStream:$H,getNATSReferences:Ui,getServerList:wne,createLocalStream:hO,listStreams:VH,deleteLocalStream:Ine,getServerConfig:xu,listRemoteStreams:Cne,viewStream:Pne,viewStreamIterator:Dne,publishToStream:Lne,request:Une,reloadNATS:mO,reloadNATSHub:xne,reloadNATSLeaf:Bne,extractServerName:vne,requestErrorHandler:Hne,createLocalTableStream:zH,createTableStreams:Gne,purgeTableStream:jH,purgeSchemaTableStreams:qne,getStreamInfo:$ne,updateLocalStreams:Kne,closeConnection:Nne,getJsmServerName:jE,addNatsMsgHeader:KH,clearClientCache:qH,updateRemoteConsumer:kne,createConsumer:YH,updateConsumerIterator:Fne};async function GH(e,t=void 0){let{stdout:r,stderr:n}=await ine(e,{cwd:t});if(n)throw new Error(n.replace(`
|
|
21
21
|
`,""));return r.replace(`
|
|
22
22
|
`,"")}a(GH,"runCommand");async function One(){try{await tne.access(cO)}catch{return!1}let e=await GH(`${cO} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return rne.eq(t,yne)}a(One,"checkNATSServerInstalled");async function _O(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let o=await kH.getClusterUser();if(tl(o))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=o.username,r=o.decrypt_hash}Qs.trace("create nats connection called");let i=await hne({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:wr.get(je.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:wr.get(je.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:wr.get(je.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),Qs.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(o=>{o&&Qs.error("Error with Nats client connection, connection closed",o),i===Jr&&qH()}),i}a(_O,"createConnection");function qH(){Jr=void 0,Xc=void 0,Zc=void 0,el=void 0}a(qH,"clearClientCache");async function Nne(){Jr&&(await Jr.drain(),Jr=void 0,Xc=void 0,Zc=void 0,el=void 0)}a(Nne,"closeConnection");var Jr,el;async function q_(){return el||(el=_O(wr.get(je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),Jr=await el),Jr||el}a(q_,"getConnection");async function $_(){if(Xc)return Xc;tl(Jr)&&await q_();let{domain:e}=xu(je.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($_,"getJetStreamManager");async function $H(){if(Zc)return Zc;tl(Jr)&&await q_();let{domain:e}=xu(je.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($H,"getJetStream");async function Ui(){let e=Jr||await q_(),t=Xc||await $_(),r=Zc||await $H();return{connection:e,jsm:t,js:r}}a(Ui,"getNATSReferences");async function wne(e){let t=wr.get(je.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await kH.getClusterUser(),s=await _O(t,r,n),i=fO(),o=s.subscribe(i),c=[],l,u=(async()=>{for await(let f of o){let d=FH.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(wne,"getServerList");async function hO(e,t){let{jsm:r}=await Ui(),n=wr.get(je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=wr.get(je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=wr.get(je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:mne.File,retention:pne.Limits,subjects:t,discard:Ene.Old,max_msgs:s,max_bytes:i,max_age:n})}a(hO,"createLocalStream");async function VH(){let{jsm:e}=await Ui(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}a(VH,"listStreams");async function Ine(e){let{jsm:t}=await Ui();await t.streams.delete(e)}a(Ine,"deleteLocalStream");async function Cne(e){let{connection:t}=await Ui(),r=[],n=fO(),s=t.subscribe(n),i=(async()=>{for await(let o of s)r.push(FH.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(Cne,"listRemoteStreams");async function Pne(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Ui(),i=UH(),o={durable_name:i,ack_policy:uO.Explicit};t&&(o.deliver_policy=dO.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=lO(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(Pne,"viewStream");async function*Dne(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Ui(),i=UH(),o={durable_name:i,ack_policy:uO.Explicit};t&&(o.deliver_policy=dO.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=lO(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(Dne,"viewStreamIterator");async function Lne(e,t,r,n){Qs.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=KH(n,r);let{js:s}=await Ui(),i=await jE(),o=`${e}.${i}`,c=await Ane(()=>n instanceof Uint8Array?n:HH.encode(n));try{Qs.trace(`publishToStream publishing to subject: ${o}`),Tne(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 WH(async()=>{try{await s.publish(o,c,{headers:r})}catch{if(l.code&&l.code.toString()==="503"){Qs.trace(`publishToStream creating stream: ${t}`);let f=o.split(".");f[2]="*",await hO(t,[o]),await s.publish(o,c,{headers:r})}else throw l}});throw l}}a(Lne,"publishToStream");function KH(e,t){t===void 0&&(t=Sne());let r=wr.get(je.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(Hr.MSG_HEADERS.ORIGIN)&&r&&t.append(Hr.MSG_HEADERS.ORIGIN,r),t}a(KH,"addNatsMsgHeader");function xu(e){e=e.toLowerCase();let t=G_.join(wr.get(je.CONFIG_PARAMS.ROOTPATH),Rne);if(e===je.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return tl(aO)&&(aO={port:k_.getConfigFromFile(je.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:k_.getConfigFromFile(je.CONFIG_PARAMS.CLUSTERING_NODENAME)+Hr.SERVER_SUFFIX.HUB,config_file:Hr.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:G_.join(t,Hr.PID_FILES.HUB),hdb_nats_path:t}),aO;if(e===je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return tl(oO)&&(oO={port:k_.getConfigFromFile(je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:k_.getConfigFromFile(je.CONFIG_PARAMS.CLUSTERING_NODENAME)+Hr.SERVER_SUFFIX.LEAF,config_file:Hr.NATS_CONFIG_FILES.LEAF_SERVER,domain:k_.getConfigFromFile(je.CONFIG_PARAMS.CLUSTERING_NODENAME)+Hr.SERVER_SUFFIX.LEAF,pid_file_path:G_.join(t,Hr.PID_FILES.LEAF),hdb_nats_path:t}),oO;Qs.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(xu,"getServerConfig");async function YH(e,t,r,n){try{await e.consumers.add(t,{ack_policy:uO.Explicit,durable_name:r,deliver_policy:dO.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}a(YH,"createConsumer");async function Mne(e,t,r){await e.consumers.delete(t,r)}a(Mne,"removeConsumer");function vne(e){return e.split(".")[1]}a(vne,"extractServerName");async function Une(e,t,r=6e4,n=fO()){if(!WE.isObject(t))throw new Error("data param must be an object");let s=HH.encode(t),{connection:i}=await Ui(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return lO(c.data)}a(Une,"request");function mO(e){return new Promise(async(t,r)=>{let n=one(cO,["--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(mO,"reloadNATS");async function xne(){let{pid_file_path:e}=xu(je.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await mO(e)}a(xne,"reloadNATSHub");async function Bne(){let{pid_file_path:e}=xu(je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await mO(e)}a(Bne,"reloadNATSLeaf");function Hne(e,t,r){let n;switch(e.code){case vH.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case vH.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}a(Hne,"requestErrorHandler");async function kne(e,t){let r=t+Hr.SERVER_SUFFIX.LEAF,{connection:n}=await Ui(),{jsm:s}=await Wne(r),{schema:i,table:o}=e,c=zE.createNatsTableStreamName(i,o),l=e.start_time?e.start_time:new Date(Date.now()).toISOString();await WH(async()=>{if(e.subscribe===!0)await YH(s,c,n.info.server_name,l);else try{await Mne(s,c,n.info.server_name)}catch(u){Qs.trace(u)}})}a(kne,"updateRemoteConsumer");async function Fne(e,t,r,n){let s=zE.createNatsTableStreamName(e,t),i=r+Hr.SERVER_SUFFIX.LEAF,o={type:je.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!BH&&fne()<wr.get(je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=iO();await c(o)}await une(o),n==="stop"&&await WE.async_set_timeout(1e3)}a(Fne,"updateConsumerIterator");function WH(e){return lne.writeTransaction(je.SYSTEM_SCHEMA_NAME,je.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(WH,"exclusiveLock");async function zH(e,t){let r=zE.createNatsTableStreamName(e,t),n=await jE(),s=Vne(e,t,n);await hO(r,[s])}a(zH,"createLocalTableStream");async function Gne(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await zH(n,s)}}a(Gne,"createTableStreams");async function jH(e,t,r=void 0){if(wr.get(je.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=zE.createNatsTableStreamName(e,t),{domain:s}=xu(je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await q_()).jetstreamManager({domain:s,timeout:24e4})).streams.purge(n,r)}catch(n){if(n.message==="stream not found")Qs.warn(n);else throw n}}a(jH,"purgeTableStream");async function qne(e,t){if(wr.get(je.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await jH(e,t[r])}a(qne,"purgeSchemaTableStreams");async function $ne(e){return(await $_()).streams.info(e)}a($ne,"getStreamInfo");function Vne(e,t,r){return`${Hr.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}a(Vne,"createSubjectName");async function jE(){if(F_)return F_;if(F_=(await $_())?.nc?.info?.server_name,F_===void 0)throw new Error("Unable to get jetstream manager server name");return F_}a(jE,"getJsmServerName");async function Kne(){let e=await $_(),t=await jE(),r=await VH();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let o=Yne(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(".");Qs.trace(`Updating stream subject name from: ${i} to: ${f}`),s.subjects[0]=f,await e.streams.update(s.name,s)}}a(Kne,"updateLocalStreams");function Yne(e){let{config:t}=e,r=!1,n=wr.get(je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=wr.get(je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=wr.get(je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);return i=i===null?-1:i,n!==t.max_age&&(t.max_age=n,r=!0),s!==t.max_bytes&&(t.max_bytes=s,r=!0),i!==t.max_msgs&&(t.max_msgs=i,r=!0),r}a(Yne,"updateStreamLimits");async function Wne(e){let t,r;try{t=await Jr.jetstream({domain:e}),r=await Jr.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw Qs.error("Unable to connect to:",e),n}return{js:t,jsm:r}}a(Wne,"connectToRemoteJS")});function pO(e){let t=e.get(QE),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:K_(e)??1,nodes:[]})})}i[n]=0,e.putSync(QE,(0,Bu.pack)(r))}return r}function V_(e){return pO(e).remoteNameToId}function XH(e,t){let r=pO(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(QE,(0,Bu.pack)(r)),s}function JE(e,t){let r=pO(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(QE,(0,Bu.pack)(r))}return JH.trace?.("The remote node name map",e,n,s),s}var JH,Bu,QE,EO=Re(()=>{JH=M(Gs());Es();Bu=require("msgpackr"),QE=Symbol.for("remote-ids");a(pO,"getIdMappingRecord");a(V_,"exportIdMapping");a(XH,"remoteToLocalNodeId");a(JE,"getIdOfRemoteNode")});var gO={};Ue(gO,{commits_awaiting_replication:()=>ku,getHDBNodeTable:()=>ir,getReplicationSharedStatus:()=>XE,iterateRoutes:()=>W_,shouldReplicateToNode:()=>Y_,subscribeToNodeUpdates:()=>Fu});function ir(){return ZH||(ZH=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){ir().subscribe({}).then(async t=>{for await(let r of t){let n=r?.value?.name;nk.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 ir().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 Y_(e,t){return(e.replicates===!0||e.replicates?.sends)&&databases[t]&&ir().primaryStore.get(et())?.replicates||e.subscriptions?.some(r=>(r.database||r.schema)===t&&r.subscribe)}function zne(){Fu(e=>{ga({},(t,r)=>{let n=e.name,s=ek.get(n);if(s||ek.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*W_(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){tk.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 tk,rk,Hu,nk,ZH,ek,ku,rl=Re(()=>{xe();Es();rp();tk=require("worker_threads"),rk=M(me()),Hu=M(ce());k();nk=M(Gs());server.nodes=[];a(ir,"getHDBNodeTable");a(XE,"getReplicationSharedStatus");a(Fu,"subscribeToNodeUpdates");a(Y_,"shouldReplicateToNode");ek=new Map;eL((e,t,r)=>{if(r>server.nodes.length)throw new rk.ClientError(`Cannot confirm replication to more nodes (${r}) than are in the network (${server.nodes.length})`);ku||(ku=new Map,zne());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(zne,"startSubscriptionToReplications");a(W_,"iterateRoutes")});var ok={};Ue(ok,{connectedToNode:()=>nl,disconnectedFromNode:()=>qu,ensureNode:()=>To,requestClusterStatus:()=>ik,startOnMainThread:()=>AO});async function AO(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,K_(l.auditStore));break}}}Bi.whenThreadsStarted.then(async()=>{let i=[];for await(let o of r.system.hdb_nodes?.search([])||[])i.push(o);for(let o of W_(e))try{let c=!o.subscriptions;if(c){let u=et(),f=ir().primaryStore.get(u);if(f!==null){let d=e.url??Sa();(f===void 0||f.url!==d||f.shard!==e.shard)&&await To(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()||Sa()&&i?.url===Sa();if(c){let d=!!i?.replicates;if(n!==void 0&&n!==d)for(let _ of ir().search([]))_.replicates&&_.name!==o&&s(_,_.name);n=d}if(rt.trace("Setting up node replication for",i),!i){for(let[d,_]of xi){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){xi.get(d).iterator.remove(),xi.delete(d);return}}return}if(c)return;if(!i.url){rt.info(`Node ${i.name} is missing url`);return}let l=xi.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,xi.set(i.url,l)),l.iterator=ga(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=Y_(i,d),R=Bi.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):z_(E)},jne);else{rt.info("Node no longer should be used, unsubscribing from node",i.replicates,!!u[d],ir().primaryStore.get(et())?.replicates),ir().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=xi.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||!TO.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=xi.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}):z_({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=xi.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 xi.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,Bi.onMessageByType)("disconnected-from-node",qu),(0,Bi.onMessageByType)("connected-to-node",nl),(0,Bi.onMessageByType)("request-cluster-status",ik)}function ik(e,t){let r=[];for(let[n,s]of Gu)try{let i=xi.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,SO.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 To(e,t){let r=ir();e=e??Js(t.url),t.name=e;try{if(t.ca){let s=new sk.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&&!TO.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,SO.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 Bi,eg,rt,SO,TO,sk,jne,xi,qu,nl,Gu,ZE,j_=Re(()=>{xe();Bi=M(it());Es();eg=require("worker_threads");rl();rt=M(ee()),SO=require("lodash"),TO=M(ce());k();sk=require("crypto"),jne=200,xi=new Map,Gu=new Map,ZE=new Map;a(AO,"startOnMainThread");a(ik,"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,Bi.onMessageByType)("subscribe-to-node",e=>{z_(e)}),(0,Bi.onMessageByType)("unsubscribe-from-node",e=>{tg(e)}));a(To,"ensureNode")});var ei=C(Ck=>{"use strict";var or=require("path"),{watch:Qne}=require("chokidar"),On=require("fs-extra"),$u=require("node-forge"),fk=require("net"),{generateKeyPair:yO,X509Certificate:Ao,createPrivateKey:_k}=require("crypto"),Jne=require("util");yO=Jne.promisify(yO);var yt=$u.pki,Xs=require("joi"),{v4:hk}=require("uuid"),{validateBySchema:wO}=st(),St=ee(),Jn=ce(),gs=(k(),P(q)),{CONFIG_PARAMS:il}=gs,Zs=wA(),{ClientError:Aa}=me(),rg=require("node:tls"),{relative:mk,join:Xne}=require("node:path"),{CERT_PREFERENCE_APP:yIe,CERTIFICATE_VALUES:ak}=Zs,Zne=_c(),bO=It(),{table:ese,getDatabases:tse,databases:RO}=(xe(),P(at)),{getJWTRSAKeys:ck}=(Lu(),P(B_));Object.assign(Ck,{generateKeys:PO,updateConfigCert:yk,createCsr:cse,signCertificate:lse,setCertTable:Vu,loadCertificates:Tk,reviewSelfSignedCert:LO,createTLSSelector:Ok,listCertificates:wk,addCertificate:mse,removeCertificate:Ese,createNatsCerts:fse,generateCertsKeys:dse,getReplicationCert:J_,getReplicationCertAuth:ase,renewSelfSigned:_se,hostnamesFromCert:MO,getKey:gse});var{urlToNodeName:pk,getThisNodeUrl:rse,getThisNodeName:sg,clearThisNodeName:nse}=(Es(),P(ba)),{readFileSync:sse,statSync:Ek}=require("node:fs"),bIe=ce(),{getTicketKeys:ise,onMessageFromWorkers:ose}=it(),Ta=ee(),{isMainThread:gk}=require("worker_threads"),{TLSSocket:Sk,createSecureContext:OIe}=require("node:tls"),IO=3650,Q_=["127.0.0.1","localhost","::1"],CO=[{name:"countryName",value:"USA"},{name:"stateOrProvinceName",value:"Colorado"},{name:"localityName",value:"Denver"},{name:"organizationName",value:"HarperDB, Inc."}];ose(async e=>{e.type===gs.ITC_EVENT_TYPES.RESTART&&(Jn.initSync(!0),await LO())});var kr;function ya(){return kr||(kr=tse().system.hdb_certificate,kr||(kr=ese({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(ya,"getCertTable");async function J_(){let e=Ok("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 Ao(r.options.cert);return r.cert_parsed=n,r.issuer=n.issuer,r}a(J_,"getReplicationCert");async function ase(){ya();let e=(await J_()).options.cert,r=new Ao(e).issuer.match(/CN=(.*)/)?.[1];return kr.get(r)}a(ase,"getReplicationCertAuth");var lk,Ra=new Map;function Tk(){if(lk)return;lk=!0;let e=[{configKey:il.TLS},{configKey:il.OPERATIONSAPI_TLS}];ya();let t=or.dirname(bO.getConfigFilePath()),r;for(let{configKey:n}of e){let s=bO.getConfigFromFile(n);if(s){Array.isArray(s)||(s=[s]);for(let i of s){let o=i.privateKey,c=o&&mk(Xne(t,"keys"),o);c&&uk(o,l=>{Ra.set(c,l)},"private key");for(let l of[!1,!0]){let u=i[l?"certificateAuthority":"certificate"];if(u&&gk){let f;uk(u,d=>{if(ak.cert===d)return;let _=i.hostname??i.hostnames??i.host??i.hosts;_&&!Array.isArray(_)&&(_=[_]);let h=bk(u),m=new Ao(h),S;try{S=Ik(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 Ao(ak.cert)))return;let g=kr.primaryStore.get(S),R=Ek(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(Tk,"loadCertificates");function uk(e,t,r){let n,s=a((i,o)=>{try{let c=o.mtimeMs;c&&c!==n&&(n&&gk&&St.warn(`Reloading ${r}:`,i),n=c,t(bk(i)))}catch(c){St.error(`Error loading ${r}:`,i,c)}},"loadFile");On.existsSync(e)?s(e,Ek(e)):St.error(`${r} file not found:`,e),Qne(e,{persistent:!1}).on("change",s)}a(uk,"loadAndWatch");function OO(){let e=rse();if(e==null){let t=Q_[0];return St.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return pk(e)}a(OO,"getHost");function ng(){let e=sg();if(e==null){let t=Q_[0];return St.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return e}a(ng,"getCommonName");async function cse(){let e=await J_(),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()},...CO];St.info("Creating CSR with subject",s),n.setSubject(s);let i=[{name:"unstructuredName",value:"HarperDB, Inc."},{name:"extensionRequest",extensions:Ak()}];return St.info("Creating CSR with attributes",i),n.setAttributes(i),n.sign(r),$u.pki.certificationRequestToPem(n)}a(cse,"createCsr");function Ak(){let e=Q_.includes(ng())?Q_:[...Q_,ng()];return e.includes(OO())||e.push(OO()),[{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=>fk.isIP(t)?{type:7,ip:t}:{type:2,value:t})}]}a(Ak,"certExtensions");async function lse(e){let t={},r=or.join(Jn.getHdbBasePath(),gs.LICENSE_KEY_DIR_NAME);if(e.csr){let n,s;ya();for await(let f of kr.search([]))if(f.is_authority&&!f.details.issuer.includes("HarperDB-Certificate-Authority")){if(Ra.has(f.private_key_name)){n=Ra.get(f.private_key_name),s=f;break}else if(f.private_key_name&&await On.exists(or.join(r,f.private_key_name))){n=On.readFile(or.join(r,f.private_key_name)),s=f;break}}if(!n){let f=await NO();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()+IO),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(lse,"signCertificate");async function use(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(use,"createCertificateTable");async function Vu(e){let t=new Ao(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},ya(),await kr.patch(e)}a(Vu,"setCertTable");async function PO(){let e=await yO("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(PO,"generateKeys");async function DO(e,t,r){let n=yt.createCertificate();if(!t){let o=await J_();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()+IO);let i=[{name:"commonName",value:ng()},...CO];return n.setSubject(i),n.setIssuer(r.subject.attributes),n.setExtensions(Ak()),n.sign(e,$u.md.sha256.create()),yt.certificateToPem(n)}a(DO,"generateCertificates");async function NO(){let e=await wk(),t;for(let r of e){if(!r.is_authority)continue;let n=await Nk(r.private_key_name);if(r.private_key_name&&n&&new Ao(r.certificate).checkPrivateKey(_k(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(NO,"getCertAuthority");async function Rk(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()+IO);let i=[{name:"commonName",value:`HarperDB-Certificate-Authority-${Jn.get(il.REPLICATION_HOSTNAME)??pk(Jn.get(il.REPLICATION_URL))??hk().split("-")[0]}`},...CO];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=or.join(Jn.getHdbBasePath(),gs.LICENSE_KEY_DIR_NAME),c=or.join(o,Zs.PRIVATEKEY_PEM_NAME);return r&&await On.writeFile(c,yt.privateKeyToPem(e)),n}a(Rk,"generateCertAuthority");async function dse(){let{private_key:e,public_key:t}=await PO(),r=await Rk(e,t),n=await DO(e,t,r);await use(n,r),yk()}a(dse,"generateCertsKeys");async function fse(){let e=await DO(yt.privateKeyFromPem(Zs.CERTIFICATE_VALUES.key),void 0,yt.certificateFromPem(Zs.CERTIFICATE_VALUES.cert)),t=or.join(Jn.getHdbBasePath(),gs.LICENSE_KEY_DIR_NAME),r=or.join(t,Zs.NATS_CERTIFICATE_PEM_NAME);await On.exists(r)||await On.writeFile(r,e);let n=or.join(t,Zs.NATS_CA_PEM_NAME);await On.exists(n)||await On.writeFile(n,Zs.CERTIFICATE_VALUES.cert)}a(fse,"createNatsCerts");async function _se(){ya();for await(let e of kr.search([{attribute:"is_self_signed",value:!0}]))await kr.delete(e.name);await LO()}a(_se,"renewSelfSigned");async function LO(){nse(),await Tk(),ya();let e=await NO();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(On.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=or.join(Jn.getHdbBasePath(),gs.LICENSE_KEY_DIR_NAME),c=mk(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 PO(),On.existsSync(or.join(o,Zs.PRIVATEKEY_PEM_NAME))&&(c=`privateKey${hk().split("-")[0]}.pem`),await On.writeFile(or.join(o,c),yt.privateKeyToPem(s)));let l=await Rk(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 J_()){let r=sg();St.notify(`A suitable replication certificate was not found, creating new self singed cert named: ${r}`),e=e??await NO();let n=yt.certificateFromPem(e.ca.certificate),s=n.publicKey,i=await DO(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(LO,"reviewSelfSignedCert");function yk(){let e=Zne(Object.keys(gs.CONFIG_PARAM_MAP),!0),t=or.join(Jn.getHdbBasePath(),gs.LICENSE_KEY_DIR_NAME),r=or.join(t,Zs.PRIVATEKEY_PEM_NAME),n=or.join(t,Zs.NATS_CERTIFICATE_PEM_NAME),s=or.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),bO.updateConfigValue(void 0,void 0,o,!1,!0)}a(yk,"updateConfigCert");function bk(e){return e.startsWith("-----BEGIN")?e:sse(e,"utf8")}a(bk,"readPEM");var dk=rg.createSecureContext;rg.createSecureContext=function(e){if(!e.cert||!e.key)return dk(e);let t={...e};delete t.key,delete t.cert;let r=dk(t);return r.context.setCert(e.cert),r.context.setKey(e.key,void 0),r};var hse=Sk.prototype._init;Sk.prototype._init=function(e,t){hse.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 Ok(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 RO.system.hdb_certificate.search([])){let _=d.certificate,h=new Ao(_);d.is_authority&&(h.asString=_,sl.set(h.subject,_))}for await(let d of RO.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 Nk(d.private_key_name),S=d.certificate,g=new Ao(S);if(sl.has(g.issuer)&&(S+=`
|