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.
@@ -13,7 +13,7 @@ Caused by:`));else if(typeof u=="object")try{n+=JSON.stringify(u)}catch{n+="Obje
13
13
 
14
14
  `:`data: ${e}
15
15
 
16
- `},"serialize"),compressible:!1,q:.8});Kr.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()}});dL={type:"application/json",serializeStream:Of,serialize:Cf,deserialize:QJ,q:.5};Kr.set("*/*",dL);Kr.set("",dL);a(QJ,"tryJSONParse");a(Df,"registerContentHandlers");jJ=require("fastify-plugin"),JJ=jJ(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:o,type:c}=fp(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(fp,"findBestSerializer");oL=QA.default.get(B.HTTP_COMPRESSIONTHRESHOLD);a(Lf,"serialize");a(aa,"serializeMessage");a(WA,"asyncSerialization");a(zA,"hasAsyncSerialization");a(XJ,"streamToBuffer");ZJ=["ascii","utf8","utf-8","utf16le","utf-16le","ucs2","ucs-2","base64","base64url","latin1","binary","hex"];a(e4,"isBufferEncoding");a(t4,"parseContentType");a(oo,"getDeserializer");a(r4,"deserializerUnknownType");a(n4,"transformIterable");a(dp,"toCsvStream")});var eR={};Ue(eR,{start:()=>f4});function s4(e){if(e.kind!==Le.Kind.OPERATION_DEFINITION&&e.kind!==Le.Kind.FRAGMENT_DEFINITION)throw new Or(`Unexpected non-executable definition type ${e.kind}.`)}function _L(e){if(typeof e!="object"||e===null)throw new Ri("Request body must be an object.");if(!("query"in e))throw new Ri("Request body must contain a `query` field.");if(typeof e.query!="string")throw new Ri("Request body `query` field must be a string.");if("variables"in e&&(typeof e.variables!="object"||e.variables===null))throw new Ri("Request body `variables` field must be an object.");if("operationName"in e&&typeof e.operationName!="string")throw new Ri("Request body `operationName` field must be a string.")}function ZA(e){return parseInt(e.value,10)}function mL(e){return parseFloat(e.value)}function pL(e,t,r){let n=r.get(e.name.value);return EL(n)?gL(n,t):{attribute:t,value:n}}function EL(e){return typeof e=="object"&&e!=null&&!Array.isArray(e)}function gL(e,t){return t=typeof t=="string"?[t]:t,Object.entries(e).flatMap(([r,n])=>(t=[...t,r],EL(n)?gL(n,t):{attribute:t,value:n}))}function i4(e,t,r){switch(t=[...t,e.name.value],e.value.kind){case Le.Kind.NULL:return{attribute:t,value:null};case Le.Kind.INT:return{attribute:t,value:ZA(e.value)};case Le.Kind.FLOAT:return{attribute:t,value:mL(e.value)};case Le.Kind.BOOLEAN:case Le.Kind.STRING:return{attribute:t,value:e.value.value};case Le.Kind.VARIABLE:return pL(e.value,t,r);case Le.Kind.OBJECT:return SL(e.value,t,r);case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new Or(`Value type, ${e.value.kind}, is not supported.`)}}function SL(e,t,r){return e.fields.flatMap(n=>i4(n,t,r))}function o4(e,t){switch(e.value.kind){case Le.Kind.NULL:return{attribute:e.name.value,value:null};case Le.Kind.INT:return{attribute:e.name.value,value:ZA(e.value)};case Le.Kind.FLOAT:return{attribute:e.name.value,value:mL(e.value)};case Le.Kind.BOOLEAN:case Le.Kind.STRING:return{attribute:e.name.value,value:e.value.value};case Le.Kind.VARIABLE:return pL(e.value,e.name.value,t);case Le.Kind.OBJECT:return SL(e.value,[e.name.value],t);case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new Or(`Argument type, ${e.value.kind}, is not supported.`)}}function a4(e,t){return e.flatMap(r=>o4(r,t))}function _p(e,t){return e.selections.flatMap(r=>{switch(r.kind){case Le.Kind.FIELD:return r;case Le.Kind.FRAGMENT_SPREAD:{let n=r.name.value,s=t.get(n);if(s==null)throw new Or(`Fragment \`${n}\` not found.`);return _p(s.selectionSet,t)}case Le.Kind.INLINE_FRAGMENT:return _p(r.selectionSet,t)}})}function TL(e,t){return _p(e,t).map(r=>r.selectionSet?.selections.length>0?{name:r.name.value,select:TL(r.selectionSet,t)}:r.name.value)}async function c4(e,t,r,n){let s=fs.getMatch(e.name.value,"graphql");if(s===void 0)throw new Or(`Resource \`${e.name.value}\` not found.`);let i=s.Resource,o={select:TL(e.selectionSet,r),conditions:a4(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 AL(e){switch(e.kind){case Le.Kind.NULL:return null;case Le.Kind.INT:return ZA(e);case Le.Kind.FLOAT:return parseFloat(e.value);case Le.Kind.STRING:case Le.Kind.BOOLEAN:return e.value;case Le.Kind.OBJECT:return e.fields.reduce((t,r)=>({[r.name.value]:AL(r.value),...t}),{});case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new Or(`Value type, ${e.kind}, is not supported.`)}}function l4(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=AL(n.defaultValue)),n.type.kind===Le.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 u4(e,t,r,n){if(e.operation===Le.OperationTypeNode.SUBSCRIPTION)throw new Or("Subscriptions are not supported.");if(e.operation===Le.OperationTypeNode.MUTATION)throw new Or("Mutations are not supported yet.");let s=l4(e.variableDefinitions,t),i=await Promise.all(_p(e.selectionSet,r).map(c=>c4(c,s,r,n))),o={data:{}};for(let[c,l]of i)o.data[c]=l;return o}async function hL({query:e,variables:t={},operationName:r},n){let s=Le.parse(e),i=new Map,o=new Map;for(let u of s.definitions)if(s4(u),u.kind===Le.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 u4(c,t,o,n);return{status:200,headers:{"Content-Type":"application/graphql-response+json; charset=utf-8"},body:JSON.stringify(l)}}async function d4(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 _L(r),hL(r,e)}case"POST":{let r=await oo(e.headers.get("content-type"),!0)(e._nodeRequest);return _L(r),hL(r,e)}default:throw new Ri("Method Not Allowed",405,{Allow:"GET, POST"})}}function f4(e){e.server.http(async(t,r)=>{if(!t.url.startsWith("/graphql"))return r(t);try{return await d4(t)}catch(n){logger.error(n);let s=t.headers.get("accept")??"application/graphql-response+json";switch(s){case"application/json":{if(n instanceof Ri)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json",...n.headers}};if(n instanceof Le.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 Ri)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json",...n.headers}};if(n instanceof Le.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 Le,Or,Ri,RL=Re(()=>{Le=M(require("graphql"));no();Zl();a(s4,"assertExecutableDefinitionNode");a(_L,"assertRequestParams");a(ZA,"processIntValueNode");a(mL,"processFloatValueNode");a(pL,"processVariableNode");a(EL,"isObject");a(gL,"transformObjectIntoQueryCondition");a(i4,"processObjectFieldNode");a(SL,"processObjectValueNode");a(o4,"processArgumentNode");a(a4,"buildConditionsQuery");a(_p,"fillInFragments");a(TL,"buildSelectQuery");a(c4,"processFieldNode");a(AL,"processConstValueNode");a(l4,"resolveVariables");a(u4,"executeOperation");a(hL,"resolver");Or=class extends Error{static{a(this,"GraphQLQueryingError")}},Ri=class extends Error{static{a(this,"HTTPError")}statusCode;headers;constructor(t,r=400,n={}){super(t),this.statusCode=r,this.headers=n}};a(d4,"graphqlQueryingHandler");a(f4,"start")});var bi=C((RRe,OL)=>{"use strict";var bL=oe(),yL=(k(),P(q)),iu=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,yi=require("joi"),ca={schema_format:{pattern:iu,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},_4=yi.alternatives(yi.string().min(1).max(ca.schema_length.maximum).pattern(iu).messages({"string.pattern.base":"{:#label} "+ca.schema_format.message}),yi.number(),yi.array()).required(),h4=yi.alternatives(yi.string().min(1).max(ca.schema_length.maximum).pattern(iu).messages({"string.pattern.base":"{:#label} "+ca.schema_format.message}),yi.number()),m4=yi.alternatives(yi.string().min(1).max(ca.schema_length.maximum).pattern(iu).messages({"string.pattern.base":"{:#label} "+ca.schema_format.message}),yi.number()).required();function p4(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>ca.schema_length.maximum?`'${e}' maximum of 250 characters`:iu.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(p4,"checkValidTable");function E4(e,t){return bL.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(E4,"validateSchemaExists");function g4(e,t){let r=t.state.ancestors[0].schema;return bL.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(g4,"validateTableExists");function S4(e,t){return e.toLowerCase()===yL.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${yL.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(S4,"validateSchemaName");OL.exports={common_validators:ca,schema_regex:iu,hdb_schema_table:_4,validateSchemaExists:E4,validateTableExists:g4,validateSchemaName:S4,checkValidTable:p4,hdb_database:h4,hdb_table:m4}});var it=C((bRe,NL)=>{"use strict";var En=require("validate.js");En.validators.type=function(e,t,r,n){return e===null||typeof e>"u"||En.validators.type.checks[t](e)?null:` must be a '${t}' value`};En.validators.type.checks={Object:a(function(e){return En.isObject(e)&&!En.isArray(e)},"Object"),Array:En.isArray,Integer:En.isInteger,Number:En.isNumber,String:En.isString,Date:En.isDate,Boolean:a(function(e){return typeof e=="boolean"},"Boolean")};En.validators.hasValidFileExt=function(e,t){return En.isString(e)?e===""?"can't be blank":t.filter(r=>e.endsWith(r)).length>0?null:`must include one of the following valid file extensions - '${t.join("', '")}'`:null};NL.exports={validateObject:T4,validateObjectAsync:A4,validateBySchema:R4};function T4(e,t){if(!e||!t)return new Error("validateObject parameters were null");let r=En(e,t,{format:"flat"});return r?new Error(r):null}a(T4,"validateObject");async function A4(e,t){if(!e||!t)return new Error("validateObject parameters were null");try{await En.async(e,t,{format:"flat"})}catch(r){let n=r.join(",");return new Error(n)}return null}a(A4,"validateObjectAsync");function R4(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(R4,"validateBySchema")});var rR=C((NRe,IL)=>{var{hdb_table:y4,hdb_database:wL}=bi(),b4=it(),tR=require("joi"),O4={undefined:"undefined",null:"null"},N4=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||O4[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"),w4=tR.object({database:wL,schema:wL,table:y4,records:tR.array().items(tR.object().custom(N4)).required()});IL.exports=function(e){return b4.validateBySchema(e,w4)}});var PL=C((IRe,CL)=>{"use strict";var nR=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")}};CL.exports=nR});var LL=C((PRe,DL)=>{"use strict";var sR=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};DL.exports=sR});var BL={};Ue(BL,{HAS_EXPIRATION:()=>pp,HAS_RESIDENCY_ID:()=>dR,HAS_STRUCTURE_UPDATE:()=>gp,LAST_TIMESTAMP_PLACEHOLDER:()=>xf,LOCAL_TIMESTAMP:()=>I4,METADATA:()=>bc,NEW_TIMESTAMP_PLACEHOLDER:()=>vL,NO_TIMESTAMP:()=>iR,PENDING_LOCAL_TIME:()=>fR,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>uR,RecordEncoder:()=>lR,TIMESTAMP_ASSIGN_LAST:()=>P4,TIMESTAMP_ASSIGN_NEW:()=>UL,TIMESTAMP_ASSIGN_PREVIOUS:()=>xL,TIMESTAMP_PLACEHOLDER:()=>hp,TIMESTAMP_RECORD_PREVIOUS:()=>oR,handleLocalTimeForGets:()=>Sp,recordUpdater:()=>_R,removeEntry:()=>Nc});function L4(){return Uf[0]=Uf[0]^64,C4.getFloat64(0)}function Sp(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?.[bc];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?.[bc]>=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[bc];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,yc.push(new WeakRef(this))),c.call(this)},o.prototype.done=function(){if(l.call(this),this.isDone)for(let u=0;u<yc.length;u++){let f=yc[u].deref();(!f||f.isDone||f.isCommitted)&&yc.splice(u--,1)}},o.prototype.done.isTracked=!0}return e}function _R(e,t,r){return function(n,s,i,o,c=-1,l,u,f="put",d,_){d||l==null?ou=i?.localTime?oR|xL:iR:ou=l?i?.localTime?oR|16384:UL|16384:iR;let h=u?.expiresAt;if(h>=0&&(c|=pp),vf=c,aR=h,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let m={version:o,instructedWrite:ou>0},S,g=0;try{let R=i?.residencyId,E=u?.residencyId;E&&(cR=E,vf|=dR,g|=wc),R!==E&&(g|=Ic,R||(R=0)),c&pp&&(g|=Hf),u?.originatingOperation&&(g|=Bf),d&&(m.ifVersion=S=i?.version??null),i&&i.value&&f!=="message"&&i.metadataFlags&Ur&&(r.getBinaryFast(i.localTime)||oa(i.value));let T;if(s!==void 0&&(T=lp(()=>e.put(n,s,m),n,e.rootStore),Tc&&(g|=Ur)),l){let N=u?.user?.username;if(_&&(lp(()=>e.encoder.encode(_),n,e.rootStore),Tc&&(g|=Ur)),e.encoder.hasStructureUpdate&&(g|=gp,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,Oc(o,t,n,X,u?.nodeId??server.replication.getThisNodeId(r)??0,N,f,Mf,g,E,R,h),{ifVersion:S}),T}}T=r.put(s===void 0?vL:xf,Oc(o,t,n,i?.localTime?1:0,u?.nodeId??server.replication?.getThisNodeId(r)??0,N,f,Mf,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 Nc(e,t,r){if(t)return t.value&&t.metadataFlags&Ur&&!e.auditStore?.getBinaryFast(t.localTime)&&oa(t.value),e.remove(t.key,r)}var ML,mp,hp,xf,uR,vL,I4,bc,Uf,C4,iR,UL,P4,xL,oR,pp,dR,fR,gp,D4,Mf,ou,vf,aR,cR,lR,yc,au=Re(()=>{ML=require("msgpackr");Ti();mp=M(ee());pn();pn();hp=new Uint8Array([1,1,1,1,4,64,0,0]),xf=new Uint8Array([1,1,1,1,1,0,0,0]),uR=new Uint8Array([1,1,1,1,3,64,0,0]),vL=new Uint8Array([1,1,1,1,0,64,0,0]),I4=Symbol("local-timestamp"),bc=Symbol("metadata"),Uf=new Uint8Array(8),C4=new DataView(Uf.buffer,0,8),iR=0,UL=0,P4=1,xL=3,oR=4,pp=16,dR=32,fR=1,gp=256,ou=0,vf=-1,aR=-1,cR=0,lR=class extends ML.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(s,i){if(ou||vf>=0){let o=0,c=ou;c&&(o+=8,ou=0);let l=vf,u=aR,f=cR;l>=0&&(o+=4,vf=-1,u>=0&&(o+=8,aR=-1),f&&(o+=4,cR=0));let d=D4=r.call(this,s,i|2048|o);Mf=d.subarray((d.start||0)+o,d.end);let _=d.start||0;return c&&(hp[4]=c,hp[5]=c>>8,d.set(hp,_),_+=8),Tc&&(l|=Ur),l>=0&&((d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setUint32(_,l|Ep<<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 Mf=r.call(this,s,i),Mf};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(Uf,0,c),c+=8;else for(let _=0;_<8;_++)Uf[_]=t[c++];l=L4(),i=t[c]}let u,f;i<32&&(i===Ep?(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&pp&&(u=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8),o&dR&&(f=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4));let d=ro(()=>r?.valueAsBuffer?t.subarray(c,s):super.decode(t.subarray(c,s),s-c),this.rootStore);return{localTime:l,value:d,[bc]:o,expiresAt:u,residencyId:f}}return r?.valueAsBuffer?t:ro(()=>super.decode(t,r),this.rootStore)}catch(c){return mp.error("Error decoding record",c,"data: "+t.slice(0,40).toString("hex")),null}}};a(L4,"getTimestamp");a(Sp,"handleLocalTimeForGets");yc=[];setInterval(()=>{for(let e=0;e<yc.length;e++){let t=yc[e].deref();!t||t.isDone||t.isCommitted?yc.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(mp.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):mp.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(_R,"recordUpdater");a(Nc,"removeEntry")});var kf=C((xRe,kL)=>{"use strict";var HL=ce(),M4=(k(),P(q)),{RecordEncoder:v4}=(au(),P(BL));HL.initSync();var U4=HL.get(M4.CONFIG_PARAMS.STORAGE_CACHING)!==!1,hR=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=U4&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:v4})}};kL.exports=hR});var Ff=C((HRe,FL)=>{"use strict";var kn=ce(),_s=(k(),P(q));kn.initSync();var Tp=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=kn.get(_s.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||kn.get(_s.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||kn.get(_s.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",kn.get(_s.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=kn.get(_s.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),kn.get(_s.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=kn.get(_s.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),kn.get(_s.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=kn.get(_s.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),kn.get(_s.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=kn.get(_s.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=kn.get(_s.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};FL.exports=Tp;Tp.MAX_DBS=1e4});var ft=C((FRe,jL)=>{"use strict";var pR=require("lmdb"),Fs=require("fs-extra"),Fn=require("path"),Ap=un(),$L=ee(),gn=Un().LMDB_ERRORS_ENUM,Rp=LL(),ER=kf(),VL=Ff(),la=kt(),GL=(k(),P(q)),{table:x4,resetDatabases:B4}=(xe(),P(at)),qL=ce(),Gs=la.INTERNAL_DBIS_NAME,KL=la.DBI_DEFINITION_NAME,H4="data.mdb",k4="lock.mdb",Gf=".mdb",F4="-lock",mR=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=hs(t,r),this.key_type=this.dbi[la.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[la.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new pR.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function yp(e,t){if(e===void 0)throw new Error(gn.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(gn.ENV_NAME_REQUIRED)}a(yp,"pathEnvNameValidation");async function gR(e,t,r=!0){try{await Fs.access(e)}catch(n){throw n.code==="ENOENT"?new Error(gn.INVALID_BASE_PATH):n}try{let n=Fn.join(e,t+Gf);return await Fs.access(n,Fs.constants.R_OK|Fs.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await Fs.access(Fn.join(e,t,H4),Fs.constants.R_OK|Fs.constants.F_OK),Fn.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(gn.INVALID_ENVIRONMENT)}else throw new Error(gn.INVALID_ENVIRONMENT);throw n}}a(gR,"validateEnvironmentPath");function bp(e,t){if(Ap.validateEnv(e),t===void 0)throw new Error(gn.DBI_NAME_REQUIRED)}a(bp,"validateEnvDBIName");async function G4(e,t,r=!1,n=!1){yp(e,t);let s=Fn.basename(e);t=t.toString();let i=qL.get(GL.CONFIG_PARAMS.DATABASES);i||qL.setProperty(GL.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await gR(e,t,n),YL(e,t,r)}catch(o){if(o.message===gn.INVALID_ENVIRONMENT){let c=Fn.join(e,t);await Fs.mkdirp(n?c:e);let l=new VL(n?c:c+Gf,!1),u=pR.open(l);u.dbis=Object.create(null);let f=new ER(!1);u.openDB(Gs,f),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let d=SR(e,t,r);return u[la.ENVIRONMENT_NAME_KEY]=d,global.lmdb_map[d]=u,u}throw o}}a(G4,"createEnvironment");async function q4(e,t,r,n=!0){yp(e,t),t=t.toString();let s=Fn.join(e,t);return x4({table:t,database:Fn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(q4,"copyEnvironment");async function YL(e,t,r=!1){yp(e,t),t=t.toString();let n=SR(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 gR(e,t),i=Fn.join(e,t+Gf),o=s!=i,c=new VL(s,o),l=pR.open(c);l.dbis=Object.create(null);let u=zL(l);for(let f=0;f<u.length;f++)hs(l,u[f]);return l[la.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(YL,"openEnvironment");async function $4(e,t,r=!1){yp(e,t),t=t.toString();let n=Fn.join(e,t+Gf),s=await gR(e,t);if(global.lmdb_map!==void 0){let i=SR(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await WL(o),delete global.lmdb_map[i]}}await Fs.remove(s),await Fs.remove(s===n?s+F4:Fn.join(Fn.dirname(s),k4))}a($4,"deleteEnvironment");async function WL(e){Ap.validateEnv(e);let t=e[la.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(WL,"closeEnvironment");function SR(e,t,r=!1){let s=`${Fn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(SR,"getCachedEnvironmentName");function V4(e){Ap.validateEnv(e);let t=Object.create(null),r=hs(e,Gs);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==Gs)try{t[n]=Object.assign(new Rp,s)}catch{$L.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(V4,"listDBIDefinitions");function zL(e){Ap.validateEnv(e);let t=[],r=hs(e,Gs);for(let{key:n}of r.getRange({start:!1}))n!==Gs&&t.push(n);return t}a(zL,"listDBIs");function K4(e,t){let n=hs(e,Gs).getEntry(t),s=new Rp;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{$L.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(K4,"getDBIDefinition");function QL(e,t,r,n=!r){if(bp(e,t),t=t.toString(),t===Gs)throw new Error(gn.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return hs(e,t)}catch(s){if(s.message===gn.DBI_DOES_NOT_EXIST){let i=new ER(r,n===!0),o=e.openDB(t,i),c=new Rp(r===!0,n);return o[KL]=c,hs(e,Gs).putSync(t,c),e.dbis[t]=o,o}throw s}}a(QL,"createDBI");function hs(e,t){if(bp(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==Gs?r=K4(e,t):r=new Rp,r===void 0)throw new Error(gn.DBI_DOES_NOT_EXIST);let n;try{let s=new ER(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(gn.DBI_DOES_NOT_EXIST):s}return n[KL]=r,e.dbis[t]=n,n}a(hs,"openDBI");function Y4(e,t){bp(e,t),t=t.toString();let r=hs(e,t),n=r.getStats();return r[la.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(Y4,"statDBI");async function W4(e,t){try{let r=Fn.join(e,t+Gf);return(await Fs.stat(r)).size}catch{throw new Error(gn.INVALID_ENVIRONMENT)}}a(W4,"environmentDataSize");function z4(e,t){if(bp(e,t),t=t.toString(),t===Gs)throw new Error(gn.CANNOT_DROP_INTERNAL_DBIS_NAME);hs(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],hs(e,Gs).removeSync(t)}a(z4,"dropDBI");function Q4(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{hs(e,i)}catch(o){if(o.message===gn.DBI_DOES_NOT_EXIST)QL(e,i,i!==t,i===t),n=!0;else throw o}}n&&B4()}a(Q4,"initializeDBIs");jL.exports={openDBI:hs,openEnvironment:YL,createEnvironment:G4,listDBIs:zL,listDBIDefinitions:V4,createDBI:QL,dropDBI:z4,statDBI:Y4,deleteEnvironment:$4,initializeDBIs:Q4,TransactionCursor:mR,environmentDataSize:W4,copyEnvironment:q4,closeEnvironment:WL}});var XL=C((qRe,JL)=>{"use strict";var TR=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};JL.exports=TR});var eM=C((VRe,ZL)=>{"use strict";var AR=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}};ZL.exports=AR});var rM=C((YRe,tM)=>{"use strict";var RR=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};tM.exports=RR});var Pc=C((JRe,iM)=>{"use strict";var j4=ft(),J4=XL(),X4=eM(),Z4=rM(),Oi=un(),qf=Un().LMDB_ERRORS_ENUM,e3=kt(),ao=(k(),P(q)),t3=oe(),r3=require("uuid"),zRe=require("lmdb"),{handleHDBError:n3,hdb_errors:s3}=me(),{OVERFLOW_MARKER:QRe,MAX_SEARCH_KEY_LENGTH:jRe}=e3,nM=ce();nM.initSync();var Op=nM.get(ao.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),yR=ao.TIME_STAMP_NAMES_ENUM.CREATED_TIME,Cc=ao.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function i3(e,t,r,n,s=Oi.getNextMonotonicTime()){wR(e,t,r,n),bR(e,t,r);let i=new J4,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l];sM(u,!0,s);let f=o3(e,t,r,u),d=u[t];o.push(f),c.push(d)}return OR(o,c,n,i,s)}a(i3,"insertRecords");function o3(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][ao.FUNC_VAL],n[o]=c)}let l=Oi.getIndexedValues(c),u=e.dbis[o];if(l){Op&&u.prefetch(l.map(f=>({key:f,value:s})),Np);for(let f=0,d=l.length;f<d;f++)u.put(l[f],s)}}Op&&e.dbis[t].prefetch([s],Np),e.dbis[t].put(s,n,n[Cc])})}a(o3,"insertRecord");function a3(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(a3,"removeSkippedRecords");function sM(e,t,r){let n=r>0;(n||!Number.isInteger(e[Cc]))&&(e[Cc]=r||(r=Oi.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[yR]))&&(e[yR]=r||Oi.getNextMonotonicTime()):delete e[yR]}a(sM,"setTimestamps");function bR(e,t,r){r.indexOf(ao.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(ao.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(ao.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(ao.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),j4.initializeDBIs(e,t,r)}a(bR,"initializeTransaction");async function c3(e,t,r,n,s=Oi.getNextMonotonicTime()){wR(e,t,r,n),bR(e,t,r);let i=new X4,o=[],c=[],l=[];for(let u=0;u<n.length;u++){let f=n[u],d=f[t],_;try{_=NR(e,t,f,d,i,!0,s)}catch{i.skipped_hashes.push(d),o.push(u);continue}c.push(_),l.push(d)}return OR(c,l,n,i,s,o)}a(c3,"updateRecords");async function l3(e,t,r,n,s=Oi.getNextMonotonicTime()){try{wR(e,t,r,n)}catch(l){throw n3(l,l.message,s3.HTTP_STATUS_CODES.BAD_REQUEST)}bR(e,t,r);let i=new Z4,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l],f;t3.isEmpty(u[t])?(f=r3.v4(),u[t]=f):f=u[t];let d=NR(e,t,u,f,i,!1,s);o.push(d),c.push(f)}return OR(o,c,n,i,s)}a(l3,"upsertRecords");async function OR(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||Oi.getNextMonotonicTime(),a3(r,i),n}a(OR,"finalizeWrite");function NR(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(sM(r,!f,o),Number.isInteger(r[Cc])&&u[Cc]>r[Cc])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][ao.FUNC_VAL],r[m]=S)}if(S===R)continue;let E=Oi.getIndexedValues(R);if(E){Op&&g.prefetch(E.map(T=>({key:T,value:n})),Np);for(let T=0,N=E.length;T<N;T++)g.remove(E[T],n)}if(E=Oi.getIndexedValues(S),E){Op&&g.prefetch(E.map(T=>({key:T,value:n})),Np);for(let T=0,N=E.length;T<N;T++)g.put(E[T],n)}}let h={...u,...r};c.put(n,h,h[Cc])},"do_put");return l?d=c.ifVersion(n,l.version,_):d=c.ifNoExists(n,_),d.then(h=>h?!0:NR(e,t,r,n,s,i,o))}a(NR,"updateUpsertRecord");function u3(e,t,r){if(Oi.validateEnv(e),t===void 0)throw new Error(qf.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(qf.WRITE_ATTRIBUTES_REQUIRED):new Error(qf.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(u3,"validateBasic");function wR(e,t,r,n){if(u3(e,t,r),!Array.isArray(n))throw n===void 0?new Error(qf.RECORDS_REQUIRED):new Error(qf.RECORDS_MUST_BE_ARRAY)}a(wR,"validateWrite");function Np(){}a(Np,"noop");iM.exports={insertRecords:i3,updateRecords:c3,upsertRecords:l3}});var co=C((ZRe,d3)=>{d3.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 aM=C((eye,oM)=>{"use strict";var f3=require("uuid"),IR=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||f3.v4(),this.schema_table=`${this.schema}.${this.table}`}};oM.exports=IR});var wp=C((rye,cM)=>{"use strict";var _3=aM(),CR=class extends _3{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}};cM.exports=CR});var uM=C((sye,lM)=>{"use strict";lM.exports=m3;var h3="inserted";function m3(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===h3?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(m3,"returnObject")});var Ip=C((aye,fM)=>{"use strict";var p3=(k(),P(q)),PR=ft(),E3=Pc(),{getSystemSchemaPath:g3,getSchemaPath:S3}=Et(),oye=co(),{validateBySchema:T3}=it(),$f=require("joi"),A3=wp(),R3=uM(),{handleHDBError:y3,hdb_errors:b3,ClientError:O3}=me(),dM=oe(),{HTTP_STATUS_CODES:N3}=b3,w3="inserted";fM.exports=I3;async function I3(e){let t=T3(e,$f.object({database:$f.string(),schema:$f.string(),table:$f.string().required(),attribute:$f.string().required()}));if(t)throw new O3(t.message);let r=!e.skip_table_check&&dM.checkGlobalSchemaTable(e.schema,e.table);if(r)throw y3(new Error,r,N3.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=dM.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 A3(e.schema,e.table,e.attribute,e.id);try{let i=await PR.openEnvironment(S3(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}`);PR.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await PR.openEnvironment(g3(),p3.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await E3.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_attribute_attributes,[s]);return R3(w3,c,{records:[s]},l)}catch(i){throw i}}a(I3,"lmdbCreateAttribute")});var Vf=C((uye,hM)=>{"use strict";var lo=oe(),_M=ee(),lye=rR(),{getDatabases:C3}=(xe(),P(at)),{ClientError:Dc}=me();hM.exports=P3;function P3(e){if(lo.isEmpty(e))throw new Dc("invalid update parameters defined.");if(lo.isEmptyOrZeroLength(e.schema))throw new Dc("invalid schema specified.");if(lo.isEmptyOrZeroLength(e.table))throw new Dc("invalid table specified.");if(!Array.isArray(e.records))throw new Dc("records must be an array");let t=C3()[e.schema]?.[e.table];if(lo.isEmpty(t))throw new Dc(`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&&lo.isEmptyOrZeroLength(o[r]))throw _M.error("a valid hash attribute must be provided with update record:",o),new Dc("a valid hash attribute must be provided with update record, check log for more info");if(!lo.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw _M.error(`a valid hash value must be provided with ${e.operation} record:`,o),new Dc(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!lo.isEmpty(o[r])&&o[r]!==""&&n.has(lo.autoCast(o[r]))&&(o.skip=!0),n.add(lo.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(P3,"insertUpdateValidate")});var pM=C((fye,mM)=>{"use strict";var DR=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};mM.exports=DR});var SM=C((hye,gM)=>{"use strict";var LR=ft(),D3=ee(),EM=Un().LMDB_ERRORS_ENUM;gM.exports=L3;async function L3(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 LR.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==EM.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await LR.closeEnvironment(global.lmdb_map[n]),await LR.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==EM.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){D3.error(t)}}a(L3,"cleanLMDBMap")});var LM=C((Eye,DM)=>{"use strict";var MR=require("recursive-iterator"),M3=require("alasql"),vR=require("clone"),TM=oe(),{handleHDBError:AM,hdb_errors:v3}=me(),{HDB_ERROR_MSGS:RM,HTTP_STATUS_CODES:yM}=v3,{getDatabases:U3}=(xe(),P(at)),x3=["DISTINCT_ARRAY"],bM=Symbol("validateTables"),UR=Symbol("validateTable"),pye=Symbol("getAllColumns"),OM=Symbol("validateAllColumns"),Cp=Symbol("findColumn"),NM=Symbol("validateOrderBy"),Kf=Symbol("validateSegment"),xR=Symbol("validateColumn"),wM=Symbol("setColumnsForTable"),IM=Symbol("checkColumnsForAsterisk"),CM=Symbol("validateGroupBy"),PM=Symbol("hasColumns"),BR=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[bM](),this[IM](),this[OM]()}[bM](){if(this[PM]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[UR](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[UR](t.table)})}}[PM](){let t=!1,r=new MR(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[UR](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=U3();if(!r[t.databaseid])throw AM(new Error,RM.SCHEMA_NOT_FOUND(t.databaseid),yM.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw AM(new Error,RM.TABLE_NOT_FOUND(t.databaseid,t.tableid),yM.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=vR(s);i.table=vR(t),this.attributes.push(i)})}[Cp](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)}[IM](){let t=new MR(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[wM](r.tableid)}[wM](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new M3.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[OM](){this[Kf](this.statement.columns,!1),this[Kf](this.statement.joins,!1),this[Kf](this.statement.where,!1),this[CM](this.statement.group,!1),this[Kf](this.statement.order,!0)}[Kf](t,r){if(!t)return;let n=new MR(t),s=[];for(let{node:i,path:o}of n)!TM.isEmpty(i)&&!TM.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[NM](i):s.push(this[xR](i)));return s}[CM](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&x3.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=vR(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[Cp](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[Cp](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`}[NM](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[xR](t)}[xR](t){let r=this[Cp](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]}};DM.exports=BR});var xM=C((Sye,UM)=>{"use strict";var MM=require("lodash"),Yf=require("mathjs"),B3=require("jsonata"),vM=oe();UM.exports={distinct_array:a(e=>Array.isArray(e)&&e.length>1?MM.uniqWith(e,MM.isEqual):e,"distinct_array"),searchJSON:H3,mad:Wf.bind(null,Yf.mad),mean:Wf.bind(null,Yf.mean),mode:Wf.bind(null,Yf.mode),prod:Wf.bind(null,Yf.prod),median:Wf.bind(null,Yf.median)};function Wf(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(Wf,"aggregateFunction");function H3(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(vM.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),vM.isEmpty(this.__ala__.res[r])){let n=B3(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(H3,"searchJSON")});var HM=C((Aye,BM)=>{"use strict";var er=require("moment"),HR="YYYY-MM-DDTHH:mm:ss.SSSZZ";er.suppressDeprecationWarnings=!0;BM.exports={current_date:a(()=>er().utc().format("YYYY-MM-DD"),"current_date"),current_time:a(()=>er().utc().format("HH:mm:ss.SSS"),"current_time"),extract:a((e,t)=>{switch(t.toLowerCase()){case"year":return er(e).utc().format("YYYY");case"month":return er(e).utc().format("MM");case"day":return er(e).utc().format("DD");case"hour":return er(e).utc().format("HH");case"minute":return er(e).utc().format("mm");case"second":return er(e).utc().format("ss");case"millisecond":return er(e).utc().format("SSS");default:break}},"extract"),date:a(e=>er(e).utc().format(HR),"date"),date_format:a((e,t)=>er(e).utc().format(t),"date_format"),date_add:a((e,t,r)=>er(e).utc().add(t,r).valueOf(),"date_add"),date_sub:a((e,t,r)=>er(e).utc().subtract(t,r).valueOf(),"date_sub"),date_diff:a((e,t,r)=>{let n=er(e).utc(),s=er(t).utc();return r?n.diff(s,r,!0):n.diff(s)},"date_diff"),now:a(()=>er().utc().valueOf(),"now"),get_server_time:a(()=>er().format(HR),"get_server_time"),offset_utc:a((e,t)=>er(e).utc().utcOffset(t).format(HR),"offset_utc")}});var qM=C((yye,GM)=>{"use strict";var k3=require("@turf/area"),F3=require("@turf/length"),G3=require("@turf/circle"),q3=require("@turf/difference"),$3=require("@turf/distance"),V3=require("@turf/boolean-contains"),K3=require("@turf/boolean-equal"),Y3=require("@turf/boolean-disjoint"),W3=require("@turf/helpers"),kM=(k(),P(q)),Ke=oe(),uo=ee();GM.exports={geoArea:z3,geoLength:Q3,geoCircle:j3,geoDifference:J3,geoDistance:FM,geoNear:X3,geoContains:Z3,geoEqual:eX,geoCrosses:tX,geoConvert:rX};function z3(e){if(Ke.isEmpty(e))return NaN;typeof e=="string"&&(e=Ke.autoCastJSON(e));try{return k3.default(e)}catch(t){return uo.trace(t,e),NaN}}a(z3,"geoArea");function Q3(e,t){if(Ke.isEmpty(e))return NaN;typeof e=="string"&&(e=Ke.autoCastJSON(e));try{return F3.default(e,{units:t||"kilometers"})}catch(r){return uo.trace(r,e),NaN}}a(Q3,"geoLength");function j3(e,t,r){if(Ke.isEmpty(e))return NaN;if(Ke.isEmpty(t))return NaN;typeof e=="string"&&(e=Ke.autoCastJSON(e));try{return G3.default(e,t,{units:r||"kilometers"})}catch(n){return uo.trace(n,e,t),NaN}}a(j3,"geoCircle");function J3(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 q3(e,t)}catch(r){return uo.trace(r,e,t),NaN}}a(J3,"geoDifference");function FM(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 $3.default(e,t,{units:r||"kilometers"})}catch(n){return uo.trace(n,e,t),NaN}}a(FM,"geoDistance");function X3(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 FM(e,t,n)<=r}catch(s){return uo.trace(s,e,t),!1}}a(X3,"geoNear");function Z3(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 V3.default(e,t)}catch(r){return uo.trace(r,e,t),!1}}a(Z3,"geoContains");function eX(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 K3.default(e,t)}catch(r){return uo.trace(r,e,t),!1}}a(eX,"geoEqual");function tX(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!Y3.default(e,t)}catch(r){return uo.trace(r,e,t),!1}}a(tX,"geoCrosses");function rX(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(kM.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(kM.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Ke.autoCastJSON(e)),W3[t](e,r)}a(rX,"geoConvert")});var Pp=C((Oye,$M)=>{var Lc=xM(),Gn=HM(),Ni=qM();$M.exports=e=>{e.aggr.mad=e.aggr.MAD=Lc.mad,e.aggr.mean=e.aggr.MEAN=Lc.mean,e.aggr.mode=e.aggr.MODE=Lc.mode,e.aggr.prod=e.aggr.PROD=Lc.prod,e.aggr.median=e.aggr.MEDIAN=Lc.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=Lc.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=Lc.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=Gn.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Gn.current_time,e.fn.extract=e.fn.EXTRACT=Gn.extract,e.fn.date=e.fn.DATE=Gn.date,e.fn.date_format=e.fn.DATE_FORMAT=Gn.date_format,e.fn.date_add=e.fn.DATE_ADD=Gn.date_add,e.fn.date_sub=e.fn.DATE_SUB=Gn.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Gn.date_diff,e.fn.now=e.fn.NOW=Gn.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Gn.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Gn.get_server_time,e.fn.getdate=e.fn.GETDATE=Gn.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Gn.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=Ni.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=Ni.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=Ni.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=Ni.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=Ni.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=Ni.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=Ni.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=Ni.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=Ni.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=Ni.geoNear}});var WM=C((Nye,YM)=>{"use strict";var zf=require("lodash"),Sn=require("alasql");Sn.options.cache=!1;var nX=Pp(),VM=require("clone"),Dp=require("recursive-iterator"),ke=ee(),Je=oe(),cu=qn(),sX=(k(),P(q)),{hdb_errors:iX}=me(),{getDatabases:KM}=(xe(),P(at)),oX="IS NULL",qs="There was a problem performing this search. Please check the logs and try again.";nX(Sn);var kR=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(qs)}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(qs)}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(qs)}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(qs)}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(qs)}}_getColumns(){let t=new Dp(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(VM(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=KM()[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 Dp(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 Sn.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 Sn.yy.LogicValue({value:i}):n instanceof Sn.yy.StringValue&&Je.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new Sn.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 Dp(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(sX.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 Sn.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(VM(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(oX)>-1&&this.tables.forEach(s=>{let i={columnid:KM()[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 cu.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(qs)}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 cu.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(qs)}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 cu.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(qs)}else try{c.search_attribute=s.attribute,c.search_value="*";let f=await cu.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(qs)}}}_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 Sn.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 Sn.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new Sn.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 Sn.yy.FuncValue:new Sn.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 Sn.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 Dp(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(qs)}}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 cu.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 Sn.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(iX.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 cu.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(qs)}}return Object.values(Object.values(this.data)[0].__merged_data)}};YM.exports=kR});var Yr=C((Iye,zM)=>{"use strict";var aX=LM();zM.exports={searchByConditions:lX,searchByHash:uX,searchByValue:dX,search:fX};var FR=qn(),{transformReq:GR}=oe(),cX=WM();async function lX(e){return GR(e),FR.searchByConditions(e)}a(lX,"searchByConditions");async function uX(e){GR(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of FR.searchByHash(e))r&&t.push(r);return t}a(uX,"searchByHash");async function dX(e){GR(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of FR.searchByValue(e))t.push(r);return t}a(dX,"searchByValue");function fX(e,t){try{let r=new aX(e);r.validate(),new cX(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(fX,"search")});var fo=C((Pye,XM)=>{"use strict";var Qf=require("crypto"),_X=ce(),{CONFIG_PARAMS:hX}=(k(),P(q)),jM="aes-256-cbc",mX=32,pX=16,qR=64,JM=32,EX=qR+JM,QM=new Map;XM.exports={encrypt:gX,decrypt:SX,createNatsTableStreamName:TX};function gX(e){let t=Qf.randomBytes(mX),r=Qf.randomBytes(pX),n=Qf.createCipheriv(jM,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(gX,"encrypt");function SX(e){let t=e.substr(0,qR),r=e.substr(qR,JM),n=e.substr(EX,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=Qf.createDecipheriv(jM,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(SX,"decrypt");function TX(e,t){let r=_X.get(hX.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=QM.get(r);return n||(n=Qf.createHash("md5").update(r).digest("hex"),QM.set(r,n)),n}a(TX,"createNatsTableStreamName")});var _o=C((Mye,rv)=>{"use strict";var Lye=Yr(),jf=ee(),{validateBySchema:ZM}=it(),Mc=require("joi"),AX=fo(),Lp=oe(),{handleHDBError:Mp,hdb_errors:RX,ClientError:ev}=me(),{HDB_ERROR_MSGS:vp,HTTP_STATUS_CODES:$R}=RX,tv=ce();tv.initSync();var{getDatabases:VR}=(xe(),P(at)),yX=require("fs-extra"),bX=(k(),P(q));rv.exports={describeAll:OX,describeTable:Up,describeSchema:NX};async function OX(e={}){try{let t=Lp.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=VR(),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 Up({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 Up({schema:d,table:h,exact_count:u},S)}m&&l.push(m)}catch(m){jf.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 jf.error("Got an error in describeAll"),jf.error(t),Mp(new Error,vp.DESCRIBE_ALL_ERR)}}a(OX,"describeAll");async function Up(e,t){Lp.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=ZM(e,Mc.object({database:Mc.string(),table:Mc.string().required(),exact_count:Mc.boolean().strict()}));if(i)throw new ev(i.message);let c=VR()[r];if(!c)throw Mp(new Error,vp.SCHEMA_NOT_FOUND(e.schema),$R.NOT_FOUND);let l=c[n];if(!l)throw Mp(new Error,vp.TABLE_NOT_FOUND(e.schema,e.table),$R.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 yX.stat(l.primaryStore.env.path)).size}catch(h){jf.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")),tv.get(bX.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(_.clustering_stream_name=AX.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){jf.warn(`unable to stat table dbi due to ${h}`)}return _}a(Up,"descTable");async function NX(e){Lp.transformReq(e);let t=ZM(e,Mc.object({database:Mc.string(),exact_count:Mc.boolean().strict()}));if(t)throw new ev(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=VR()[n];if(!i)throw Mp(new Error,vp.SCHEMA_NOT_FOUND(e.schema),$R.NOT_FOUND);let o={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),Lp.isEmpty(l)||l.describe){let u=await Up({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);u&&(o[u.name]=u)}}return o}a(NX,"describeSchema")});var $s=C((Bye,av)=>{var wX=co(),{callbackify:sv,promisify:IX}=require("util"),{getDatabases:iv}=(xe(),P(at));av.exports={setSchemaDataToGlobal:nv,getTableSchema:CX,getSystemSchema:PX,setSchemaDataToGlobalAsync:IX(nv)};var ov=_o(),Uye=sv(ov.describeAll),xye=sv(ov.describeTable);function nv(e){global.hdb_schema=iv(),e&&e()}a(nv,"setSchemaDataToGlobal");function CX(e,t,r){let n=iv()[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(CX,"getTableSchema");function PX(){return wX}a(PX,"getSystemSchema")});var YR=C((kye,uv)=>{var DX=it(),KR=require("joi"),{hdb_table:LX,hdb_database:cv}=bi(),lv={schema:cv,database:cv,table:LX},MX={date:KR.date().iso().required()},vX={timestamp:KR.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};uv.exports=function(e,t){let r=t==="timestamp"?{...lv,...vX}:{...lv,...MX},n=KR.object(r);return DX.validateBySchema(e,n)}});var _v=C((Fye,fv)=>{var UX=it(),WR=require("joi"),{hdb_table:xX,hdb_database:dv}=bi(),BX=WR.object({schema:dv,database:dv,table:xX,hash_values:WR.array().required(),ids:WR.array()});fv.exports=function(e){return UX.validateBySchema(e,BX)}});var JR=C((Gye,hv)=>{"use strict";var zR=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}},QR=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}},jR=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};hv.exports={InsertObject:zR,NoSQLSeachObject:QR,DeleteResponseObject:jR}});var xc=C(($ye,Sv)=>{"use strict";var pv=YR(),HX=_v(),vc=oe(),mv=require("moment"),Ev=ee(),{promisify:kX,callbackify:FX}=require("util"),Uc=(k(),P(q)),GX=$s(),XR=kX(GX.getTableSchema),ZR=qn(),{DeleteResponseObject:qX}=JR(),{handleHDBError:ua,hdb_errors:$X}=me(),{HDB_ERROR_MSGS:xp,HTTP_STATUS_CODES:da}=$X,VX="records successfully deleted",KX=FX(gv);Sv.exports={delete:KX,deleteRecord:gv,deleteFilesBefore:YX,deleteAuditLogsBefore:WX};async function YX(e){let t=pv(e,"date");if(t)throw ua(t,t.message,da.BAD_REQUEST,void 0,void 0,!0);if(vc.transformReq(e),!mv(e.date,mv.ISO_8601).isValid())throw ua(new Error,xp.INVALID_DATE,da.BAD_REQUEST,Uc.LOG_LEVELS.ERROR,xp.INVALID_DATE,!0);let n=vc.checkSchemaTableExist(e.schema,e.table);if(n)throw ua(new Error,n,da.NOT_FOUND,Uc.LOG_LEVELS.ERROR,n,!0);let s=await ZR.deleteRecordsBefore(e);if(await XR(e.schema,e.table),Ev.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(YX,"deleteFilesBefore");async function WX(e){let t=pv(e,"timestamp");if(t)throw ua(t,t.message,da.BAD_REQUEST,void 0,void 0,!0);if(vc.transformReq(e),isNaN(e.timestamp))throw ua(new Error,xp.INVALID_VALUE("Timestamp"),da.BAD_REQUEST,Uc.LOG_LEVELS.ERROR,xp.INVALID_VALUE("Timestamp"),!0);let r=vc.checkSchemaTableExist(e.schema,e.table);if(r)throw ua(new Error,r,da.NOT_FOUND,Uc.LOG_LEVELS.ERROR,r,!0);let n=await ZR.deleteAuditLogsBefore(e);return await XR(e.schema,e.table),Ev.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(WX,"deleteAuditLogsBefore");async function gv(e){e.ids&&(e.hash_values=e.ids);let t=HX(e);if(t)throw ua(t,t.message,da.BAD_REQUEST,void 0,void 0,!0);vc.transformReq(e);let r=vc.checkSchemaTableExist(e.schema,e.table);if(r)throw ua(new Error,r,da.NOT_FOUND,Uc.LOG_LEVELS.ERROR,r,!0);try{await XR(e.schema,e.table);let n=await ZR.deleteRecords(e);return vc.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${VX}`),n}catch(n){if(n.message===Uc.SEARCH_NOT_FOUND_MESSAGE){let s=new qX;return s.message=Uc.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(gv,"deleteRecord")});var Bp={};Ue(Bp,{HASH_FUNCTION:()=>Zf,hash:()=>ry,validate:()=>ny});function ey(e=Xf){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ";return Array.from(Jf.randomBytes(e)).map(r=>t[r%t.length]).join("")}function ry(e,t=Zf[Av?.toUpperCase()]??"sha256"){return ty[t](e)}function ny(e,t,r=Zf[Av?.toUpperCase()]??"sha256"){return e?zX[r](e,t):!1}var Jf,lu,Tv,Av,Xf,Rv,Zf,ty,zX,Hp=Re(()=>{Jf=M(require("node:crypto")),lu=M(require("argon2")),Tv=M(ce());k();Av=(0,Tv.get)(B.AUTHENTICATION_HASHFUNCTION)?.toLowerCase(),Xf=16,Rv=9,Zf=(n=>(n.MD5="md5",n.SHA256="sha256",n.ARGON2ID="argon2id",n))(Zf||{});a(ey,"generateSalt");ty={md5:a((e,t=void 0)=>{t=t??ey(Rv);let r=Jf.createHash("md5").update(e+t).digest("hex");return t+r},"md5"),sha256:a((e,t=void 0)=>{t=t??ey(Xf);let r=Jf.createHash("sha256").update(e+t).digest("hex");return t+r},"sha256"),argon2id:a(async e=>{let t=ey(Xf),r=await lu.hash(e,{type:lu.argon2id,salt:Buffer.from(t)});return t+r},"argon2id")},zX={md5:a((e,t)=>{let r=e.slice(0,Rv);return e===ty.md5(t,r)},"md5"),sha256:a((e,t)=>{let r=e.slice(0,Xf);return e===ty.sha256(t,r)},"sha256"),argon2id:a(async(e,t)=>await lu.verify(e.slice(Xf),t),"argon2id")};a(ry,"hash");a(ny,"validate")});var bv=C((Wye,yv)=>{var sy=it(),Wr={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 QX(e){return Wr.password.presence=!0,Wr.username.presence=!0,Wr.role.presence=!0,Wr.active.presence=!0,sy.validateObject(e,Wr)}a(QX,"addUserValidation");function jX(e){return Wr.password.presence=!1,Wr.username.presence=!0,Wr.role.presence=!1,Wr.active.presence=!1,sy.validateObject(e,Wr)}a(jX,"alterUserValidation");function JX(e){return Wr.password.presence=!1,Wr.username.presence=!0,Wr.role.presence=!1,Wr.active.presence=!1,sy.validateObject(e,Wr)}a(JX,"dropUserValidation");yv.exports={addUserValidation:QX,alterUserValidation:jX,dropUserValidation:JX}});var It=C((jye,Nv)=>{"use strict";var{platform:Qye}=require("os"),XX="nats-server.zip",iy="nats-server",ZX=process.platform==="win32"?`${iy}.exe`:iy,e6=/^[^\s.,*>]+$/,Ov="__request__",t6=a(e=>`${e}.${Ov}`,"REQUEST_SUBJECT"),r6={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},n6={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},s6={HUB:"hub.pid",LEAF:"leaf.pid"},i6={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},o6={SUCCESS:"success",ERROR:"error"},a6={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},c6={TXN:"txn",MSGID:"msgid"},uu={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},l6={[uu.ERR]:1,[uu.WRN]:2,[uu.INF]:3,[uu.DBG]:4,[uu.TRC]:5},u6={debug:"-D",trace:"-DVV"};Nv.exports={NATS_SERVER_ZIP:XX,NATS_SERVER_NAME:iy,NATS_BINARY_NAME:ZX,PID_FILES:s6,NATS_CONFIG_FILES:n6,SERVER_SUFFIX:i6,NATS_TERM_CONSTRAINTS_RX:e6,REQUEST_SUFFIX:Ov,UPDATE_REMOTE_RESPONSE_STATUSES:o6,CLUSTER_STATUS_STATUSES:a6,REQUEST_SUBJECT:t6,SUBJECT_PREFIXES:c6,MSG_HEADERS:r6,LOG_LEVELS:uu,LOG_LEVEL_FLAGS:u6,LOG_LEVEL_HIERARCHY:l6}});var oy=C(wv=>{"use strict";var d6={cert:"-----BEGIN CERTIFICATE-----\rMIIDXDCCAkSgAwIBAgIFNTE4MzQwDQYJKoZIhvcNAQELBQAwXTEXMBUGA1UEAxMO\rSGFycGVyREIsIEluYy4xCzAJBgNVBAYTAlVTMQswCQYDVQQIEwJDTzEPMA0GA1UE\rBxMGRGVudmVyMRcwFQYDVQQKEw5IYXJwZXJEQiwgSW5jLjAeFw0yMjAzMTEyMzAz\rNDlaFw0yNzAzMTAyMzAzNDlaMF0xFzAVBgNVBAMTDkhhcnBlckRCLCBJbmMuMQsw\rCQYDVQQGEwJVUzELMAkGA1UECBMCQ08xDzANBgNVBAcTBkRlbnZlcjEXMBUGA1UE\rChMOSGFycGVyREIsIEluYy4wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIB\rAQCsEUlBF8WImS78rCFXVKyntxfrW++4qZ3hGnoD2MHZAuDHyeP/5eGnaE9GQhKc\r4DwG4DGvh0wP2zIYnBfiQ3L2ZtnlDR9ZkKIQYGlVxTUn6T43krhK5nZKqDF43Yg3\rZEvO3cbJBjiKZx0eA2/toehdSsTAHHQx5gTDcggNe2tgoJHYPwi9YF/AxSBZrbgb\ryWlYgtYDmF32ytHP03GUCIdKOFuBPsHTGu4SkdEIdLIqO9oglW1YFH5qZ6NiwApW\rsP+GCuqOwDXXbdjr75iq9Tq/CDrjGFLaTPmvd2Q0qG/BtaCll0ghpG+yIHvt/iQs\rajS+LxEWAnVlGMaDdFErbDUtAgMBAAGjIzAhMA8GA1UdEwEB/wQFMAMBAf8wDgYD\rVR0PAQH/BAQDAgIEMA0GCSqGSIb3DQEBCwUAA4IBAQASR4YW/rPK7PNArHVe9zzM\rb0rKNX/2T9/0nybRhmE/+hdlSgliTAeebmwkUS2APckmekYt/q2ZY2NS65Fo/jjp\rG8TJrtcF4h+ylVqUp0ZXQLFtIsr7r2JZA7hJ6njW6G4DHSZ0gxtECLi4CBlTjzm5\rNmnmIDObvGRTuqmcdAZmXeObbta/He2XIzietukPAYX062pNM+G5XT5UM1eG/Vlp\rN86vjhpyI+ffKy+C60SJqxmKM3ydgN7oLscE7+2wLPN25XqN4W99OwGsp5dTdu/f\r5lPtFayXdJ55e/sNQKmGN+UGLrL05c2MWgjb8U/LFilnupUianceoeSERZmVjzKX\r-----END CERTIFICATE-----\r".replace(/\r/g,`\r
16
+ `},"serialize"),compressible:!1,q:.8});Kr.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()}});dL={type:"application/json",serializeStream:Of,serialize:Cf,deserialize:QJ,q:.5};Kr.set("*/*",dL);Kr.set("",dL);a(QJ,"tryJSONParse");a(Df,"registerContentHandlers");jJ=require("fastify-plugin"),JJ=jJ(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:o,type:c}=fp(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(fp,"findBestSerializer");oL=QA.default.get(B.HTTP_COMPRESSIONTHRESHOLD);a(Lf,"serialize");a(aa,"serializeMessage");a(WA,"asyncSerialization");a(zA,"hasAsyncSerialization");a(XJ,"streamToBuffer");ZJ=["ascii","utf8","utf-8","utf16le","utf-16le","ucs2","ucs-2","base64","base64url","latin1","binary","hex"];a(e4,"isBufferEncoding");a(t4,"parseContentType");a(oo,"getDeserializer");a(r4,"deserializerUnknownType");a(n4,"transformIterable");a(dp,"toCsvStream")});var eR={};Ue(eR,{start:()=>f4});function s4(e){if(e.kind!==Le.Kind.OPERATION_DEFINITION&&e.kind!==Le.Kind.FRAGMENT_DEFINITION)throw new Or(`Unexpected non-executable definition type ${e.kind}.`)}function _L(e){if(typeof e!="object"||e===null)throw new Ri("Request body must be an object.");if(!("query"in e))throw new Ri("Request body must contain a `query` field.");if(typeof e.query!="string")throw new Ri("Request body `query` field must be a string.");if("variables"in e&&(typeof e.variables!="object"||e.variables===null))throw new Ri("Request body `variables` field must be an object.");if("operationName"in e&&typeof e.operationName!="string")throw new Ri("Request body `operationName` field must be a string.")}function ZA(e){return parseInt(e.value,10)}function mL(e){return parseFloat(e.value)}function pL(e,t,r){let n=r.get(e.name.value);return EL(n)?gL(n,t):{attribute:t,value:n}}function EL(e){return typeof e=="object"&&e!=null&&!Array.isArray(e)}function gL(e,t){return t=typeof t=="string"?[t]:t,Object.entries(e).flatMap(([r,n])=>(t=[...t,r],EL(n)?gL(n,t):{attribute:t,value:n}))}function i4(e,t,r){switch(t=[...t,e.name.value],e.value.kind){case Le.Kind.NULL:return{attribute:t,value:null};case Le.Kind.INT:return{attribute:t,value:ZA(e.value)};case Le.Kind.FLOAT:return{attribute:t,value:mL(e.value)};case Le.Kind.BOOLEAN:case Le.Kind.STRING:return{attribute:t,value:e.value.value};case Le.Kind.VARIABLE:return pL(e.value,t,r);case Le.Kind.OBJECT:return SL(e.value,t,r);case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new Or(`Value type, ${e.value.kind}, is not supported.`)}}function SL(e,t,r){return e.fields.flatMap(n=>i4(n,t,r))}function o4(e,t){switch(e.value.kind){case Le.Kind.NULL:return{attribute:e.name.value,value:null};case Le.Kind.INT:return{attribute:e.name.value,value:ZA(e.value)};case Le.Kind.FLOAT:return{attribute:e.name.value,value:mL(e.value)};case Le.Kind.BOOLEAN:case Le.Kind.STRING:return{attribute:e.name.value,value:e.value.value};case Le.Kind.VARIABLE:return pL(e.value,e.name.value,t);case Le.Kind.OBJECT:return SL(e.value,[e.name.value],t);case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new Or(`Argument type, ${e.value.kind}, is not supported.`)}}function a4(e,t){return e.flatMap(r=>o4(r,t))}function _p(e,t){return e.selections.flatMap(r=>{switch(r.kind){case Le.Kind.FIELD:return r;case Le.Kind.FRAGMENT_SPREAD:{let n=r.name.value,s=t.get(n);if(s==null)throw new Or(`Fragment \`${n}\` not found.`);return _p(s.selectionSet,t)}case Le.Kind.INLINE_FRAGMENT:return _p(r.selectionSet,t)}})}function TL(e,t){return _p(e,t).map(r=>r.selectionSet?.selections.length>0?{name:r.name.value,select:TL(r.selectionSet,t)}:r.name.value)}async function c4(e,t,r,n){let s=fs.getMatch(e.name.value,"graphql");if(s===void 0)throw new Or(`Resource \`${e.name.value}\` not found.`);let i=s.Resource,o={select:TL(e.selectionSet,r),conditions:a4(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 AL(e){switch(e.kind){case Le.Kind.NULL:return null;case Le.Kind.INT:return ZA(e);case Le.Kind.FLOAT:return parseFloat(e.value);case Le.Kind.STRING:case Le.Kind.BOOLEAN:return e.value;case Le.Kind.OBJECT:return e.fields.reduce((t,r)=>({[r.name.value]:AL(r.value),...t}),{});case Le.Kind.LIST:case Le.Kind.ENUM:default:throw new Or(`Value type, ${e.kind}, is not supported.`)}}function l4(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=AL(n.defaultValue)),n.type.kind===Le.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 u4(e,t,r,n){if(e.operation===Le.OperationTypeNode.SUBSCRIPTION)throw new Or("Subscriptions are not supported.");if(e.operation===Le.OperationTypeNode.MUTATION)throw new Or("Mutations are not supported yet.");let s=l4(e.variableDefinitions,t),i=await Promise.all(_p(e.selectionSet,r).map(c=>c4(c,s,r,n))),o={data:{}};for(let[c,l]of i)o.data[c]=l;return o}async function hL({query:e,variables:t={},operationName:r},n){let s=Le.parse(e),i=new Map,o=new Map;for(let u of s.definitions)if(s4(u),u.kind===Le.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 u4(c,t,o,n);return{status:200,headers:{"Content-Type":"application/graphql-response+json; charset=utf-8"},body:JSON.stringify(l)}}async function d4(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 _L(r),hL(r,e)}case"POST":{let r=await oo(e.headers.get("content-type"),!0)(e._nodeRequest);return _L(r),hL(r,e)}default:throw new Ri("Method Not Allowed",405,{Allow:"GET, POST"})}}function f4(e){e.server.http(async(t,r)=>{if(!t.url.startsWith("/graphql"))return r(t);try{return await d4(t)}catch(n){logger.error(n);let s=t.headers.get("accept")??"application/graphql-response+json";switch(s){case"application/json":{if(n instanceof Ri)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json",...n.headers}};if(n instanceof Le.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 Ri)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json",...n.headers}};if(n instanceof Le.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 Le,Or,Ri,RL=Re(()=>{Le=M(require("graphql"));no();Zl();a(s4,"assertExecutableDefinitionNode");a(_L,"assertRequestParams");a(ZA,"processIntValueNode");a(mL,"processFloatValueNode");a(pL,"processVariableNode");a(EL,"isObject");a(gL,"transformObjectIntoQueryCondition");a(i4,"processObjectFieldNode");a(SL,"processObjectValueNode");a(o4,"processArgumentNode");a(a4,"buildConditionsQuery");a(_p,"fillInFragments");a(TL,"buildSelectQuery");a(c4,"processFieldNode");a(AL,"processConstValueNode");a(l4,"resolveVariables");a(u4,"executeOperation");a(hL,"resolver");Or=class extends Error{static{a(this,"GraphQLQueryingError")}},Ri=class extends Error{static{a(this,"HTTPError")}statusCode;headers;constructor(t,r=400,n={}){super(t),this.statusCode=r,this.headers=n}};a(d4,"graphqlQueryingHandler");a(f4,"start")});var bi=C((RRe,OL)=>{"use strict";var bL=oe(),yL=(k(),P(q)),iu=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,yi=require("joi"),ca={schema_format:{pattern:iu,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},_4=yi.alternatives(yi.string().min(1).max(ca.schema_length.maximum).pattern(iu).messages({"string.pattern.base":"{:#label} "+ca.schema_format.message}),yi.number(),yi.array()).required(),h4=yi.alternatives(yi.string().min(1).max(ca.schema_length.maximum).pattern(iu).messages({"string.pattern.base":"{:#label} "+ca.schema_format.message}),yi.number()),m4=yi.alternatives(yi.string().min(1).max(ca.schema_length.maximum).pattern(iu).messages({"string.pattern.base":"{:#label} "+ca.schema_format.message}),yi.number()).required();function p4(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>ca.schema_length.maximum?`'${e}' maximum of 250 characters`:iu.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(p4,"checkValidTable");function E4(e,t){return bL.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(E4,"validateSchemaExists");function g4(e,t){let r=t.state.ancestors[0].schema;return bL.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(g4,"validateTableExists");function S4(e,t){return e.toLowerCase()===yL.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${yL.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(S4,"validateSchemaName");OL.exports={common_validators:ca,schema_regex:iu,hdb_schema_table:_4,validateSchemaExists:E4,validateTableExists:g4,validateSchemaName:S4,checkValidTable:p4,hdb_database:h4,hdb_table:m4}});var it=C((bRe,NL)=>{"use strict";var En=require("validate.js");En.validators.type=function(e,t,r,n){return e===null||typeof e>"u"||En.validators.type.checks[t](e)?null:` must be a '${t}' value`};En.validators.type.checks={Object:a(function(e){return En.isObject(e)&&!En.isArray(e)},"Object"),Array:En.isArray,Integer:En.isInteger,Number:En.isNumber,String:En.isString,Date:En.isDate,Boolean:a(function(e){return typeof e=="boolean"},"Boolean")};En.validators.hasValidFileExt=function(e,t){return En.isString(e)?e===""?"can't be blank":t.filter(r=>e.endsWith(r)).length>0?null:`must include one of the following valid file extensions - '${t.join("', '")}'`:null};NL.exports={validateObject:T4,validateObjectAsync:A4,validateBySchema:R4};function T4(e,t){if(!e||!t)return new Error("validateObject parameters were null");let r=En(e,t,{format:"flat"});return r?new Error(r):null}a(T4,"validateObject");async function A4(e,t){if(!e||!t)return new Error("validateObject parameters were null");try{await En.async(e,t,{format:"flat"})}catch(r){let n=r.join(",");return new Error(n)}return null}a(A4,"validateObjectAsync");function R4(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(R4,"validateBySchema")});var rR=C((NRe,IL)=>{var{hdb_table:y4,hdb_database:wL}=bi(),b4=it(),tR=require("joi"),O4={undefined:"undefined",null:"null"},N4=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||O4[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"),w4=tR.object({database:wL,schema:wL,table:y4,records:tR.array().items(tR.object().custom(N4)).required()});IL.exports=function(e){return b4.validateBySchema(e,w4)}});var PL=C((IRe,CL)=>{"use strict";var nR=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")}};CL.exports=nR});var LL=C((PRe,DL)=>{"use strict";var sR=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};DL.exports=sR});var BL={};Ue(BL,{HAS_EXPIRATION:()=>pp,HAS_RESIDENCY_ID:()=>dR,HAS_STRUCTURE_UPDATE:()=>gp,LAST_TIMESTAMP_PLACEHOLDER:()=>xf,LOCAL_TIMESTAMP:()=>I4,METADATA:()=>bc,NEW_TIMESTAMP_PLACEHOLDER:()=>vL,NO_TIMESTAMP:()=>iR,PENDING_LOCAL_TIME:()=>fR,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>uR,RecordEncoder:()=>lR,TIMESTAMP_ASSIGN_LAST:()=>P4,TIMESTAMP_ASSIGN_NEW:()=>UL,TIMESTAMP_ASSIGN_PREVIOUS:()=>xL,TIMESTAMP_PLACEHOLDER:()=>hp,TIMESTAMP_RECORD_PREVIOUS:()=>oR,handleLocalTimeForGets:()=>Sp,recordUpdater:()=>_R,removeEntry:()=>Nc});function L4(){return Uf[0]=Uf[0]^64,C4.getFloat64(0)}function Sp(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?.[bc];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?.[bc]>=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[bc];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,yc.push(new WeakRef(this))),c.call(this)},o.prototype.done=function(){if(l.call(this),this.isDone)for(let u=0;u<yc.length;u++){let f=yc[u].deref();(!f||f.isDone||f.isCommitted)&&yc.splice(u--,1)}},o.prototype.done.isTracked=!0}return e}function _R(e,t,r){return function(n,s,i,o,c=-1,l,u,f="put",d,_){d||l==null?ou=i?.localTime?oR|xL:iR:ou=l?i?.localTime?oR|16384:UL|16384:iR;let h=u?.expiresAt;if(h>=0&&(c|=pp),vf=c,aR=h,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let m={version:o,instructedWrite:ou>0},S,g=0;try{let R=i?.residencyId,E=u?.residencyId;E&&(cR=E,vf|=dR,g|=wc),R!==E&&(g|=Ic,R||(R=0)),c&pp&&(g|=Hf),u?.originatingOperation&&(g|=Bf),d&&(m.ifVersion=S=i?.version??null),i&&i.value&&f!=="message"&&i.metadataFlags&Ur&&(r.getBinaryFast(i.localTime)||oa(i.value));let T;if(s!==void 0&&(T=lp(()=>e.put(n,s,m),n,e.rootStore),Tc&&(g|=Ur)),l){let N=u?.user?.username;if(_&&(lp(()=>e.encoder.encode(_),n,e.rootStore),Tc&&(g|=Ur)),e.encoder.hasStructureUpdate&&(g|=gp,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,Oc(o,t,n,X,u?.nodeId??server.replication.getThisNodeId(r)??0,N,f,Mf,g,E,R,h),{ifVersion:S}),T}}T=r.put(s===void 0?vL:xf,Oc(o,t,n,i?.localTime?1:0,u?.nodeId??server.replication?.getThisNodeId(r)??0,N,f,Mf,g,E,R,h,u?.originatingOperation),{instructedWrite:!0,ifVersion:S})}return T}catch(R){throw R.message+=" id: "+n+" options: "+m,R}}}function Nc(e,t,r){if(t)return t.value&&t.metadataFlags&Ur&&!e.auditStore?.getBinaryFast(t.localTime)&&oa(t.value),e.remove(t.key,r)}var ML,mp,hp,xf,uR,vL,I4,bc,Uf,C4,iR,UL,P4,xL,oR,pp,dR,fR,gp,D4,Mf,ou,vf,aR,cR,lR,yc,au=Re(()=>{ML=require("msgpackr");Ti();mp=M(ee());pn();pn();hp=new Uint8Array([1,1,1,1,4,64,0,0]),xf=new Uint8Array([1,1,1,1,1,0,0,0]),uR=new Uint8Array([1,1,1,1,3,64,0,0]),vL=new Uint8Array([1,1,1,1,0,64,0,0]),I4=Symbol("local-timestamp"),bc=Symbol("metadata"),Uf=new Uint8Array(8),C4=new DataView(Uf.buffer,0,8),iR=0,UL=0,P4=1,xL=3,oR=4,pp=16,dR=32,fR=1,gp=256,ou=0,vf=-1,aR=-1,cR=0,lR=class extends ML.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(s,i){if(ou||vf>=0){let o=0,c=ou;c&&(o+=8,ou=0);let l=vf,u=aR,f=cR;l>=0&&(o+=4,vf=-1,u>=0&&(o+=8,aR=-1),f&&(o+=4,cR=0));let d=D4=r.call(this,s,i|2048|o);Mf=d.subarray((d.start||0)+o,d.end);let _=d.start||0;return c&&(hp[4]=c,hp[5]=c>>8,d.set(hp,_),_+=8),Tc&&(l|=Ur),l>=0&&((d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setUint32(_,l|Ep<<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 Mf=r.call(this,s,i),Mf};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(Uf,0,c),c+=8;else for(let _=0;_<8;_++)Uf[_]=t[c++];l=L4(),i=t[c]}let u,f;i<32&&(i===Ep?(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&pp&&(u=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8),o&dR&&(f=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4));let d=ro(()=>r?.valueAsBuffer?t.subarray(c,s):super.decode(t.subarray(c,s),s-c),this.rootStore);return{localTime:l,value:d,[bc]:o,expiresAt:u,residencyId:f}}return r?.valueAsBuffer?t:ro(()=>super.decode(t,r),this.rootStore)}catch(c){return mp.error("Error decoding record",c,"data: "+t.slice(0,40).toString("hex")),null}}};a(L4,"getTimestamp");a(Sp,"handleLocalTimeForGets");yc=[];setInterval(()=>{for(let e=0;e<yc.length;e++){let t=yc[e].deref();!t||t.isDone||t.isCommitted?yc.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(mp.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):mp.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(_R,"recordUpdater");a(Nc,"removeEntry")});var kf=C((xRe,kL)=>{"use strict";var HL=ce(),M4=(k(),P(q)),{RecordEncoder:v4}=(au(),P(BL));HL.initSync();var U4=HL.get(M4.CONFIG_PARAMS.STORAGE_CACHING)!==!1,hR=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=U4&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:v4})}};kL.exports=hR});var Ff=C((HRe,FL)=>{"use strict";var kn=ce(),_s=(k(),P(q));kn.initSync();var Tp=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=kn.get(_s.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||kn.get(_s.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||kn.get(_s.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",kn.get(_s.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=kn.get(_s.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),kn.get(_s.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=kn.get(_s.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),kn.get(_s.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=kn.get(_s.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),kn.get(_s.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=kn.get(_s.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=kn.get(_s.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};FL.exports=Tp;Tp.MAX_DBS=1e4});var ft=C((FRe,jL)=>{"use strict";var pR=require("lmdb"),Fs=require("fs-extra"),Fn=require("path"),Ap=un(),$L=ee(),gn=Un().LMDB_ERRORS_ENUM,Rp=LL(),ER=kf(),VL=Ff(),la=kt(),GL=(k(),P(q)),{table:x4,resetDatabases:B4}=(xe(),P(at)),qL=ce(),Gs=la.INTERNAL_DBIS_NAME,KL=la.DBI_DEFINITION_NAME,H4="data.mdb",k4="lock.mdb",Gf=".mdb",F4="-lock",mR=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=hs(t,r),this.key_type=this.dbi[la.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[la.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new pR.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function yp(e,t){if(e===void 0)throw new Error(gn.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(gn.ENV_NAME_REQUIRED)}a(yp,"pathEnvNameValidation");async function gR(e,t,r=!0){try{await Fs.access(e)}catch(n){throw n.code==="ENOENT"?new Error(gn.INVALID_BASE_PATH):n}try{let n=Fn.join(e,t+Gf);return await Fs.access(n,Fs.constants.R_OK|Fs.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await Fs.access(Fn.join(e,t,H4),Fs.constants.R_OK|Fs.constants.F_OK),Fn.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(gn.INVALID_ENVIRONMENT)}else throw new Error(gn.INVALID_ENVIRONMENT);throw n}}a(gR,"validateEnvironmentPath");function bp(e,t){if(Ap.validateEnv(e),t===void 0)throw new Error(gn.DBI_NAME_REQUIRED)}a(bp,"validateEnvDBIName");async function G4(e,t,r=!1,n=!1){yp(e,t);let s=Fn.basename(e);t=t.toString();let i=qL.get(GL.CONFIG_PARAMS.DATABASES);i||qL.setProperty(GL.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await gR(e,t,n),YL(e,t,r)}catch(o){if(o.message===gn.INVALID_ENVIRONMENT){let c=Fn.join(e,t);await Fs.mkdirp(n?c:e);let l=new VL(n?c:c+Gf,!1),u=pR.open(l);u.dbis=Object.create(null);let f=new ER(!1);u.openDB(Gs,f),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let d=SR(e,t,r);return u[la.ENVIRONMENT_NAME_KEY]=d,global.lmdb_map[d]=u,u}throw o}}a(G4,"createEnvironment");async function q4(e,t,r,n=!0){yp(e,t),t=t.toString();let s=Fn.join(e,t);return x4({table:t,database:Fn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(q4,"copyEnvironment");async function YL(e,t,r=!1){yp(e,t),t=t.toString();let n=SR(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 gR(e,t),i=Fn.join(e,t+Gf),o=s!=i,c=new VL(s,o),l=pR.open(c);l.dbis=Object.create(null);let u=zL(l);for(let f=0;f<u.length;f++)hs(l,u[f]);return l[la.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(YL,"openEnvironment");async function $4(e,t,r=!1){yp(e,t),t=t.toString();let n=Fn.join(e,t+Gf),s=await gR(e,t);if(global.lmdb_map!==void 0){let i=SR(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await WL(o),delete global.lmdb_map[i]}}await Fs.remove(s),await Fs.remove(s===n?s+F4:Fn.join(Fn.dirname(s),k4))}a($4,"deleteEnvironment");async function WL(e){Ap.validateEnv(e);let t=e[la.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(WL,"closeEnvironment");function SR(e,t,r=!1){let s=`${Fn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(SR,"getCachedEnvironmentName");function V4(e){Ap.validateEnv(e);let t=Object.create(null),r=hs(e,Gs);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==Gs)try{t[n]=Object.assign(new Rp,s)}catch{$L.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(V4,"listDBIDefinitions");function zL(e){Ap.validateEnv(e);let t=[],r=hs(e,Gs);for(let{key:n}of r.getRange({start:!1}))n!==Gs&&t.push(n);return t}a(zL,"listDBIs");function K4(e,t){let n=hs(e,Gs).getEntry(t),s=new Rp;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{$L.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(K4,"getDBIDefinition");function QL(e,t,r,n=!r){if(bp(e,t),t=t.toString(),t===Gs)throw new Error(gn.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return hs(e,t)}catch(s){if(s.message===gn.DBI_DOES_NOT_EXIST){let i=new ER(r,n===!0),o=e.openDB(t,i),c=new Rp(r===!0,n);return o[KL]=c,hs(e,Gs).putSync(t,c),e.dbis[t]=o,o}throw s}}a(QL,"createDBI");function hs(e,t){if(bp(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==Gs?r=K4(e,t):r=new Rp,r===void 0)throw new Error(gn.DBI_DOES_NOT_EXIST);let n;try{let s=new ER(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(gn.DBI_DOES_NOT_EXIST):s}return n[KL]=r,e.dbis[t]=n,n}a(hs,"openDBI");function Y4(e,t){bp(e,t),t=t.toString();let r=hs(e,t),n=r.getStats();return r[la.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(Y4,"statDBI");async function W4(e,t){try{let r=Fn.join(e,t+Gf);return(await Fs.stat(r)).size}catch{throw new Error(gn.INVALID_ENVIRONMENT)}}a(W4,"environmentDataSize");function z4(e,t){if(bp(e,t),t=t.toString(),t===Gs)throw new Error(gn.CANNOT_DROP_INTERNAL_DBIS_NAME);hs(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],hs(e,Gs).removeSync(t)}a(z4,"dropDBI");function Q4(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{hs(e,i)}catch(o){if(o.message===gn.DBI_DOES_NOT_EXIST)QL(e,i,i!==t,i===t),n=!0;else throw o}}n&&B4()}a(Q4,"initializeDBIs");jL.exports={openDBI:hs,openEnvironment:YL,createEnvironment:G4,listDBIs:zL,listDBIDefinitions:V4,createDBI:QL,dropDBI:z4,statDBI:Y4,deleteEnvironment:$4,initializeDBIs:Q4,TransactionCursor:mR,environmentDataSize:W4,copyEnvironment:q4,closeEnvironment:WL}});var XL=C((qRe,JL)=>{"use strict";var TR=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};JL.exports=TR});var eM=C((VRe,ZL)=>{"use strict";var AR=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}};ZL.exports=AR});var rM=C((YRe,tM)=>{"use strict";var RR=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};tM.exports=RR});var Pc=C((JRe,iM)=>{"use strict";var j4=ft(),J4=XL(),X4=eM(),Z4=rM(),Oi=un(),qf=Un().LMDB_ERRORS_ENUM,e3=kt(),ao=(k(),P(q)),t3=oe(),r3=require("uuid"),zRe=require("lmdb"),{handleHDBError:n3,hdb_errors:s3}=me(),{OVERFLOW_MARKER:QRe,MAX_SEARCH_KEY_LENGTH:jRe}=e3,nM=ce();nM.initSync();var Op=nM.get(ao.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),yR=ao.TIME_STAMP_NAMES_ENUM.CREATED_TIME,Cc=ao.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function i3(e,t,r,n,s=Oi.getNextMonotonicTime()){wR(e,t,r,n),bR(e,t,r);let i=new J4,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l];sM(u,!0,s);let f=o3(e,t,r,u),d=u[t];o.push(f),c.push(d)}return OR(o,c,n,i,s)}a(i3,"insertRecords");function o3(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][ao.FUNC_VAL],n[o]=c)}let l=Oi.getIndexedValues(c),u=e.dbis[o];if(l){Op&&u.prefetch(l.map(f=>({key:f,value:s})),Np);for(let f=0,d=l.length;f<d;f++)u.put(l[f],s)}}Op&&e.dbis[t].prefetch([s],Np),e.dbis[t].put(s,n,n[Cc])})}a(o3,"insertRecord");function a3(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(a3,"removeSkippedRecords");function sM(e,t,r){let n=r>0;(n||!Number.isInteger(e[Cc]))&&(e[Cc]=r||(r=Oi.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[yR]))&&(e[yR]=r||Oi.getNextMonotonicTime()):delete e[yR]}a(sM,"setTimestamps");function bR(e,t,r){r.indexOf(ao.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(ao.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(ao.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(ao.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),j4.initializeDBIs(e,t,r)}a(bR,"initializeTransaction");async function c3(e,t,r,n,s=Oi.getNextMonotonicTime()){wR(e,t,r,n),bR(e,t,r);let i=new X4,o=[],c=[],l=[];for(let u=0;u<n.length;u++){let f=n[u],d=f[t],_;try{_=NR(e,t,f,d,i,!0,s)}catch{i.skipped_hashes.push(d),o.push(u);continue}c.push(_),l.push(d)}return OR(c,l,n,i,s,o)}a(c3,"updateRecords");async function l3(e,t,r,n,s=Oi.getNextMonotonicTime()){try{wR(e,t,r,n)}catch(l){throw n3(l,l.message,s3.HTTP_STATUS_CODES.BAD_REQUEST)}bR(e,t,r);let i=new Z4,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l],f;t3.isEmpty(u[t])?(f=r3.v4(),u[t]=f):f=u[t];let d=NR(e,t,u,f,i,!1,s);o.push(d),c.push(f)}return OR(o,c,n,i,s)}a(l3,"upsertRecords");async function OR(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||Oi.getNextMonotonicTime(),a3(r,i),n}a(OR,"finalizeWrite");function NR(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(sM(r,!f,o),Number.isInteger(r[Cc])&&u[Cc]>r[Cc])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][ao.FUNC_VAL],r[m]=S)}if(S===R)continue;let E=Oi.getIndexedValues(R);if(E){Op&&g.prefetch(E.map(T=>({key:T,value:n})),Np);for(let T=0,N=E.length;T<N;T++)g.remove(E[T],n)}if(E=Oi.getIndexedValues(S),E){Op&&g.prefetch(E.map(T=>({key:T,value:n})),Np);for(let T=0,N=E.length;T<N;T++)g.put(E[T],n)}}let h={...u,...r};c.put(n,h,h[Cc])},"do_put");return l?d=c.ifVersion(n,l.version,_):d=c.ifNoExists(n,_),d.then(h=>h?!0:NR(e,t,r,n,s,i,o))}a(NR,"updateUpsertRecord");function u3(e,t,r){if(Oi.validateEnv(e),t===void 0)throw new Error(qf.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(qf.WRITE_ATTRIBUTES_REQUIRED):new Error(qf.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(u3,"validateBasic");function wR(e,t,r,n){if(u3(e,t,r),!Array.isArray(n))throw n===void 0?new Error(qf.RECORDS_REQUIRED):new Error(qf.RECORDS_MUST_BE_ARRAY)}a(wR,"validateWrite");function Np(){}a(Np,"noop");iM.exports={insertRecords:i3,updateRecords:c3,upsertRecords:l3}});var co=C((ZRe,d3)=>{d3.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 aM=C((eye,oM)=>{"use strict";var f3=require("uuid"),IR=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||f3.v4(),this.schema_table=`${this.schema}.${this.table}`}};oM.exports=IR});var wp=C((rye,cM)=>{"use strict";var _3=aM(),CR=class extends _3{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}};cM.exports=CR});var uM=C((sye,lM)=>{"use strict";lM.exports=m3;var h3="inserted";function m3(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===h3?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(m3,"returnObject")});var Ip=C((aye,fM)=>{"use strict";var p3=(k(),P(q)),PR=ft(),E3=Pc(),{getSystemSchemaPath:g3,getSchemaPath:S3}=Et(),oye=co(),{validateBySchema:T3}=it(),$f=require("joi"),A3=wp(),R3=uM(),{handleHDBError:y3,hdb_errors:b3,ClientError:O3}=me(),dM=oe(),{HTTP_STATUS_CODES:N3}=b3,w3="inserted";fM.exports=I3;async function I3(e){let t=T3(e,$f.object({database:$f.string(),schema:$f.string(),table:$f.string().required(),attribute:$f.string().required()}));if(t)throw new O3(t.message);let r=!e.skip_table_check&&dM.checkGlobalSchemaTable(e.schema,e.table);if(r)throw y3(new Error,r,N3.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=dM.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 A3(e.schema,e.table,e.attribute,e.id);try{let i=await PR.openEnvironment(S3(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}`);PR.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await PR.openEnvironment(g3(),p3.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await E3.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_attribute_attributes,[s]);return R3(w3,c,{records:[s]},l)}catch(i){throw i}}a(I3,"lmdbCreateAttribute")});var Vf=C((uye,hM)=>{"use strict";var lo=oe(),_M=ee(),lye=rR(),{getDatabases:C3}=(xe(),P(at)),{ClientError:Dc}=me();hM.exports=P3;function P3(e){if(lo.isEmpty(e))throw new Dc("invalid update parameters defined.");if(lo.isEmptyOrZeroLength(e.schema))throw new Dc("invalid schema specified.");if(lo.isEmptyOrZeroLength(e.table))throw new Dc("invalid table specified.");if(!Array.isArray(e.records))throw new Dc("records must be an array");let t=C3()[e.schema]?.[e.table];if(lo.isEmpty(t))throw new Dc(`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&&lo.isEmptyOrZeroLength(o[r]))throw _M.error("a valid hash attribute must be provided with update record:",o),new Dc("a valid hash attribute must be provided with update record, check log for more info");if(!lo.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw _M.error(`a valid hash value must be provided with ${e.operation} record:`,o),new Dc(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!lo.isEmpty(o[r])&&o[r]!==""&&n.has(lo.autoCast(o[r]))&&(o.skip=!0),n.add(lo.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(P3,"insertUpdateValidate")});var pM=C((fye,mM)=>{"use strict";var DR=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};mM.exports=DR});var SM=C((hye,gM)=>{"use strict";var LR=ft(),D3=ee(),EM=Un().LMDB_ERRORS_ENUM;gM.exports=L3;async function L3(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 LR.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==EM.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await LR.closeEnvironment(global.lmdb_map[n]),await LR.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==EM.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){D3.error(t)}}a(L3,"cleanLMDBMap")});var LM=C((Eye,DM)=>{"use strict";var MR=require("recursive-iterator"),M3=require("alasql"),vR=require("clone"),TM=oe(),{handleHDBError:AM,hdb_errors:v3}=me(),{HDB_ERROR_MSGS:RM,HTTP_STATUS_CODES:yM}=v3,{getDatabases:U3}=(xe(),P(at)),x3=["DISTINCT_ARRAY"],bM=Symbol("validateTables"),UR=Symbol("validateTable"),pye=Symbol("getAllColumns"),OM=Symbol("validateAllColumns"),Cp=Symbol("findColumn"),NM=Symbol("validateOrderBy"),Kf=Symbol("validateSegment"),xR=Symbol("validateColumn"),wM=Symbol("setColumnsForTable"),IM=Symbol("checkColumnsForAsterisk"),CM=Symbol("validateGroupBy"),PM=Symbol("hasColumns"),BR=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[bM](),this[IM](),this[OM]()}[bM](){if(this[PM]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[UR](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[UR](t.table)})}}[PM](){let t=!1,r=new MR(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[UR](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=U3();if(!r[t.databaseid])throw AM(new Error,RM.SCHEMA_NOT_FOUND(t.databaseid),yM.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw AM(new Error,RM.TABLE_NOT_FOUND(t.databaseid,t.tableid),yM.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=vR(s);i.table=vR(t),this.attributes.push(i)})}[Cp](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)}[IM](){let t=new MR(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[wM](r.tableid)}[wM](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new M3.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[OM](){this[Kf](this.statement.columns,!1),this[Kf](this.statement.joins,!1),this[Kf](this.statement.where,!1),this[CM](this.statement.group,!1),this[Kf](this.statement.order,!0)}[Kf](t,r){if(!t)return;let n=new MR(t),s=[];for(let{node:i,path:o}of n)!TM.isEmpty(i)&&!TM.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[NM](i):s.push(this[xR](i)));return s}[CM](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&x3.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=vR(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[Cp](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[Cp](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`}[NM](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[xR](t)}[xR](t){let r=this[Cp](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]}};DM.exports=BR});var xM=C((Sye,UM)=>{"use strict";var MM=require("lodash"),Yf=require("mathjs"),B3=require("jsonata"),vM=oe();UM.exports={distinct_array:a(e=>Array.isArray(e)&&e.length>1?MM.uniqWith(e,MM.isEqual):e,"distinct_array"),searchJSON:H3,mad:Wf.bind(null,Yf.mad),mean:Wf.bind(null,Yf.mean),mode:Wf.bind(null,Yf.mode),prod:Wf.bind(null,Yf.prod),median:Wf.bind(null,Yf.median)};function Wf(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(Wf,"aggregateFunction");function H3(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(vM.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),vM.isEmpty(this.__ala__.res[r])){let n=B3(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(H3,"searchJSON")});var HM=C((Aye,BM)=>{"use strict";var er=require("moment"),HR="YYYY-MM-DDTHH:mm:ss.SSSZZ";er.suppressDeprecationWarnings=!0;BM.exports={current_date:a(()=>er().utc().format("YYYY-MM-DD"),"current_date"),current_time:a(()=>er().utc().format("HH:mm:ss.SSS"),"current_time"),extract:a((e,t)=>{switch(t.toLowerCase()){case"year":return er(e).utc().format("YYYY");case"month":return er(e).utc().format("MM");case"day":return er(e).utc().format("DD");case"hour":return er(e).utc().format("HH");case"minute":return er(e).utc().format("mm");case"second":return er(e).utc().format("ss");case"millisecond":return er(e).utc().format("SSS");default:break}},"extract"),date:a(e=>er(e).utc().format(HR),"date"),date_format:a((e,t)=>er(e).utc().format(t),"date_format"),date_add:a((e,t,r)=>er(e).utc().add(t,r).valueOf(),"date_add"),date_sub:a((e,t,r)=>er(e).utc().subtract(t,r).valueOf(),"date_sub"),date_diff:a((e,t,r)=>{let n=er(e).utc(),s=er(t).utc();return r?n.diff(s,r,!0):n.diff(s)},"date_diff"),now:a(()=>er().utc().valueOf(),"now"),get_server_time:a(()=>er().format(HR),"get_server_time"),offset_utc:a((e,t)=>er(e).utc().utcOffset(t).format(HR),"offset_utc")}});var qM=C((yye,GM)=>{"use strict";var k3=require("@turf/area"),F3=require("@turf/length"),G3=require("@turf/circle"),q3=require("@turf/difference"),$3=require("@turf/distance"),V3=require("@turf/boolean-contains"),K3=require("@turf/boolean-equal"),Y3=require("@turf/boolean-disjoint"),W3=require("@turf/helpers"),kM=(k(),P(q)),Ke=oe(),uo=ee();GM.exports={geoArea:z3,geoLength:Q3,geoCircle:j3,geoDifference:J3,geoDistance:FM,geoNear:X3,geoContains:Z3,geoEqual:eX,geoCrosses:tX,geoConvert:rX};function z3(e){if(Ke.isEmpty(e))return NaN;typeof e=="string"&&(e=Ke.autoCastJSON(e));try{return k3.default(e)}catch(t){return uo.trace(t,e),NaN}}a(z3,"geoArea");function Q3(e,t){if(Ke.isEmpty(e))return NaN;typeof e=="string"&&(e=Ke.autoCastJSON(e));try{return F3.default(e,{units:t||"kilometers"})}catch(r){return uo.trace(r,e),NaN}}a(Q3,"geoLength");function j3(e,t,r){if(Ke.isEmpty(e))return NaN;if(Ke.isEmpty(t))return NaN;typeof e=="string"&&(e=Ke.autoCastJSON(e));try{return G3.default(e,t,{units:r||"kilometers"})}catch(n){return uo.trace(n,e,t),NaN}}a(j3,"geoCircle");function J3(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 q3(e,t)}catch(r){return uo.trace(r,e,t),NaN}}a(J3,"geoDifference");function FM(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 $3.default(e,t,{units:r||"kilometers"})}catch(n){return uo.trace(n,e,t),NaN}}a(FM,"geoDistance");function X3(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 FM(e,t,n)<=r}catch(s){return uo.trace(s,e,t),!1}}a(X3,"geoNear");function Z3(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 V3.default(e,t)}catch(r){return uo.trace(r,e,t),!1}}a(Z3,"geoContains");function eX(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 K3.default(e,t)}catch(r){return uo.trace(r,e,t),!1}}a(eX,"geoEqual");function tX(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!Y3.default(e,t)}catch(r){return uo.trace(r,e,t),!1}}a(tX,"geoCrosses");function rX(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(kM.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(kM.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Ke.autoCastJSON(e)),W3[t](e,r)}a(rX,"geoConvert")});var Pp=C((Oye,$M)=>{var Lc=xM(),Gn=HM(),Ni=qM();$M.exports=e=>{e.aggr.mad=e.aggr.MAD=Lc.mad,e.aggr.mean=e.aggr.MEAN=Lc.mean,e.aggr.mode=e.aggr.MODE=Lc.mode,e.aggr.prod=e.aggr.PROD=Lc.prod,e.aggr.median=e.aggr.MEDIAN=Lc.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=Lc.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=Lc.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=Gn.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Gn.current_time,e.fn.extract=e.fn.EXTRACT=Gn.extract,e.fn.date=e.fn.DATE=Gn.date,e.fn.date_format=e.fn.DATE_FORMAT=Gn.date_format,e.fn.date_add=e.fn.DATE_ADD=Gn.date_add,e.fn.date_sub=e.fn.DATE_SUB=Gn.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Gn.date_diff,e.fn.now=e.fn.NOW=Gn.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Gn.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Gn.get_server_time,e.fn.getdate=e.fn.GETDATE=Gn.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Gn.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=Ni.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=Ni.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=Ni.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=Ni.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=Ni.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=Ni.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=Ni.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=Ni.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=Ni.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=Ni.geoNear}});var WM=C((Nye,YM)=>{"use strict";var zf=require("lodash"),Sn=require("alasql");Sn.options.cache=!1;var nX=Pp(),VM=require("clone"),Dp=require("recursive-iterator"),ke=ee(),Je=oe(),cu=qn(),sX=(k(),P(q)),{hdb_errors:iX}=me(),{getDatabases:KM}=(xe(),P(at)),oX="IS NULL",qs="There was a problem performing this search. Please check the logs and try again.";nX(Sn);var kR=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(qs)}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(qs)}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(qs)}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(qs)}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(qs)}}_getColumns(){let t=new Dp(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(VM(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=KM()[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 Dp(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 Sn.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 Sn.yy.LogicValue({value:i}):n instanceof Sn.yy.StringValue&&Je.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new Sn.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 Dp(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(sX.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 Sn.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(VM(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(oX)>-1&&this.tables.forEach(s=>{let i={columnid:KM()[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 cu.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(qs)}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 cu.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(qs)}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 cu.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(qs)}else try{c.search_attribute=s.attribute,c.search_value="*";let f=await cu.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(qs)}}}_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 Sn.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 Sn.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new Sn.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 Sn.yy.FuncValue:new Sn.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 Sn.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 Dp(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(qs)}}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 cu.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 Sn.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(iX.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 cu.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(qs)}}return Object.values(Object.values(this.data)[0].__merged_data)}};YM.exports=kR});var Yr=C((Iye,zM)=>{"use strict";var aX=LM();zM.exports={searchByConditions:lX,searchByHash:uX,searchByValue:dX,search:fX};var FR=qn(),{transformReq:GR}=oe(),cX=WM();async function lX(e){return GR(e),FR.searchByConditions(e)}a(lX,"searchByConditions");async function uX(e){GR(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of FR.searchByHash(e))r&&t.push(r);return t}a(uX,"searchByHash");async function dX(e){GR(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of FR.searchByValue(e))t.push(r);return t}a(dX,"searchByValue");function fX(e,t){try{let r=new aX(e);r.validate(),new cX(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(fX,"search")});var fo=C((Pye,XM)=>{"use strict";var Qf=require("crypto"),_X=ce(),{CONFIG_PARAMS:hX}=(k(),P(q)),jM="aes-256-cbc",mX=32,pX=16,qR=64,JM=32,EX=qR+JM,QM=new Map;XM.exports={encrypt:gX,decrypt:SX,createNatsTableStreamName:TX};function gX(e){let t=Qf.randomBytes(mX),r=Qf.randomBytes(pX),n=Qf.createCipheriv(jM,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(gX,"encrypt");function SX(e){let t=e.substr(0,qR),r=e.substr(qR,JM),n=e.substr(EX,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=Qf.createDecipheriv(jM,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(SX,"decrypt");function TX(e,t){let r=_X.get(hX.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=QM.get(r);return n||(n=Qf.createHash("md5").update(r).digest("hex"),QM.set(r,n)),n}a(TX,"createNatsTableStreamName")});var _o=C((Mye,rv)=>{"use strict";var Lye=Yr(),jf=ee(),{validateBySchema:ZM}=it(),Mc=require("joi"),AX=fo(),Lp=oe(),{handleHDBError:Mp,hdb_errors:RX,ClientError:ev}=me(),{HDB_ERROR_MSGS:vp,HTTP_STATUS_CODES:$R}=RX,tv=ce();tv.initSync();var{getDatabases:VR}=(xe(),P(at)),yX=require("fs-extra"),bX=(k(),P(q));rv.exports={describeAll:OX,describeTable:Up,describeSchema:NX};async function OX(e={}){try{let t=Lp.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=VR(),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 Up({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 Up({schema:d,table:h,exact_count:u},S)}m&&l.push(m)}catch(m){jf.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 jf.error("Got an error in describeAll"),jf.error(t),Mp(new Error,vp.DESCRIBE_ALL_ERR)}}a(OX,"describeAll");async function Up(e,t){Lp.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=ZM(e,Mc.object({database:Mc.string(),table:Mc.string().required(),exact_count:Mc.boolean().strict()}));if(i)throw new ev(i.message);let c=VR()[r];if(!c)throw Mp(new Error,vp.SCHEMA_NOT_FOUND(e.schema),$R.NOT_FOUND);let l=c[n];if(!l)throw Mp(new Error,vp.TABLE_NOT_FOUND(e.schema,e.table),$R.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 yX.stat(l.primaryStore.env.path)).size}catch(h){jf.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")),tv.get(bX.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(_.clustering_stream_name=AX.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){jf.warn(`unable to stat table dbi due to ${h}`)}return _}a(Up,"descTable");async function NX(e){Lp.transformReq(e);let t=ZM(e,Mc.object({database:Mc.string(),exact_count:Mc.boolean().strict()}));if(t)throw new ev(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=VR()[n];if(!i)throw Mp(new Error,vp.SCHEMA_NOT_FOUND(e.schema),$R.NOT_FOUND);let o={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),Lp.isEmpty(l)||l.describe){let u=await Up({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);u&&(o[u.name]=u)}}return o}a(NX,"describeSchema")});var $s=C((Bye,av)=>{var wX=co(),{callbackify:sv,promisify:IX}=require("util"),{getDatabases:iv}=(xe(),P(at));av.exports={setSchemaDataToGlobal:nv,getTableSchema:CX,getSystemSchema:PX,setSchemaDataToGlobalAsync:IX(nv)};var ov=_o(),Uye=sv(ov.describeAll),xye=sv(ov.describeTable);function nv(e){global.hdb_schema=iv(),e&&e()}a(nv,"setSchemaDataToGlobal");function CX(e,t,r){let n=iv()[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(CX,"getTableSchema");function PX(){return wX}a(PX,"getSystemSchema")});var YR=C((kye,uv)=>{var DX=it(),KR=require("joi"),{hdb_table:LX,hdb_database:cv}=bi(),lv={schema:cv,database:cv,table:LX},MX={date:KR.date().iso().required()},vX={timestamp:KR.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};uv.exports=function(e,t){let r=t==="timestamp"?{...lv,...vX}:{...lv,...MX},n=KR.object(r);return DX.validateBySchema(e,n)}});var _v=C((Fye,fv)=>{var UX=it(),WR=require("joi"),{hdb_table:xX,hdb_database:dv}=bi(),BX=WR.object({schema:dv,database:dv,table:xX,hash_values:WR.array().required(),ids:WR.array()});fv.exports=function(e){return UX.validateBySchema(e,BX)}});var JR=C((Gye,hv)=>{"use strict";var zR=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}},QR=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}},jR=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};hv.exports={InsertObject:zR,NoSQLSeachObject:QR,DeleteResponseObject:jR}});var xc=C(($ye,Sv)=>{"use strict";var pv=YR(),HX=_v(),vc=oe(),mv=require("moment"),Ev=ee(),{promisify:kX,callbackify:FX}=require("util"),Uc=(k(),P(q)),GX=$s(),XR=kX(GX.getTableSchema),ZR=qn(),{DeleteResponseObject:qX}=JR(),{handleHDBError:ua,hdb_errors:$X}=me(),{HDB_ERROR_MSGS:xp,HTTP_STATUS_CODES:da}=$X,VX="records successfully deleted",KX=FX(gv);Sv.exports={delete:KX,deleteRecord:gv,deleteFilesBefore:YX,deleteAuditLogsBefore:WX};async function YX(e){let t=pv(e,"date");if(t)throw ua(t,t.message,da.BAD_REQUEST,void 0,void 0,!0);if(vc.transformReq(e),!mv(e.date,mv.ISO_8601).isValid())throw ua(new Error,xp.INVALID_DATE,da.BAD_REQUEST,Uc.LOG_LEVELS.ERROR,xp.INVALID_DATE,!0);let n=vc.checkSchemaTableExist(e.schema,e.table);if(n)throw ua(new Error,n,da.NOT_FOUND,Uc.LOG_LEVELS.ERROR,n,!0);let s=await ZR.deleteRecordsBefore(e);if(await XR(e.schema,e.table),Ev.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(YX,"deleteFilesBefore");async function WX(e){let t=pv(e,"timestamp");if(t)throw ua(t,t.message,da.BAD_REQUEST,void 0,void 0,!0);if(vc.transformReq(e),isNaN(e.timestamp))throw ua(new Error,xp.INVALID_VALUE("Timestamp"),da.BAD_REQUEST,Uc.LOG_LEVELS.ERROR,xp.INVALID_VALUE("Timestamp"),!0);let r=vc.checkSchemaTableExist(e.schema,e.table);if(r)throw ua(new Error,r,da.NOT_FOUND,Uc.LOG_LEVELS.ERROR,r,!0);let n=await ZR.deleteAuditLogsBefore(e);return await XR(e.schema,e.table),Ev.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(WX,"deleteAuditLogsBefore");async function gv(e){e.ids&&(e.hash_values=e.ids);let t=HX(e);if(t)throw ua(t,t.message,da.BAD_REQUEST,void 0,void 0,!0);vc.transformReq(e);let r=vc.checkSchemaTableExist(e.schema,e.table);if(r)throw ua(new Error,r,da.NOT_FOUND,Uc.LOG_LEVELS.ERROR,r,!0);try{await XR(e.schema,e.table);let n=await ZR.deleteRecords(e);return vc.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${VX}`),n}catch(n){if(n.message===Uc.SEARCH_NOT_FOUND_MESSAGE){let s=new qX;return s.message=Uc.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(gv,"deleteRecord")});var Bp={};Ue(Bp,{HASH_FUNCTION:()=>Zf,hash:()=>ry,validate:()=>ny});function ey(e=Xf){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ";return Array.from(Jf.randomBytes(e)).map(r=>t[r%t.length]).join("")}function ry(e,t=Zf[Av?.toUpperCase()]??"sha256"){return ty[t](e)}function ny(e,t,r=Zf[Av?.toUpperCase()]??"sha256"){return e?zX[r](e,t):!1}var Jf,lu,Tv,Av,Xf,Rv,Zf,ty,zX,Hp=Re(()=>{Jf=M(require("node:crypto")),lu=M(require("argon2")),Tv=M(ce());k();Av=(0,Tv.get)(B.AUTHENTICATION_HASHFUNCTION)?.toLowerCase(),Xf=16,Rv=9,Zf=(n=>(n.MD5="md5",n.SHA256="sha256",n.ARGON2ID="argon2id",n))(Zf||{});a(ey,"generateSalt");ty={md5:a((e,t=void 0)=>{t=t??ey(Rv);let r=Jf.createHash("md5").update(e+t).digest("hex");return t+r},"md5"),sha256:a((e,t=void 0)=>{t=t??ey(Xf);let r=Jf.createHash("sha256").update(e+t).digest("hex");return t+r},"sha256"),argon2id:a(async e=>{let t=ey(Xf),r=await lu.hash(e,{type:lu.argon2id,salt:Buffer.from(t)});return t+r},"argon2id")},zX={md5:a((e,t)=>{let r=e.slice(0,Rv);return e===ty.md5(t,r)},"md5"),sha256:a((e,t)=>{let r=e.slice(0,Xf);return e===ty.sha256(t,r)},"sha256"),argon2id:a(async(e,t)=>await lu.verify(e.slice(Xf),t),"argon2id")};a(ry,"hash");a(ny,"validate")});var bv=C((Wye,yv)=>{var sy=it(),Wr={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 QX(e){return Wr.password.presence=!0,Wr.username.presence=!0,Wr.role.presence=!0,Wr.active.presence=!0,sy.validateObject(e,Wr)}a(QX,"addUserValidation");function jX(e){return Wr.password.presence=!1,Wr.username.presence=!0,Wr.role.presence=!1,Wr.active.presence=!1,sy.validateObject(e,Wr)}a(jX,"alterUserValidation");function JX(e){return Wr.password.presence=!1,Wr.username.presence=!0,Wr.role.presence=!1,Wr.active.presence=!1,sy.validateObject(e,Wr)}a(JX,"dropUserValidation");yv.exports={addUserValidation:QX,alterUserValidation:jX,dropUserValidation:JX}});var It=C((jye,Nv)=>{"use strict";var{platform:Qye}=require("os"),XX="nats-server.zip",iy="nats-server",ZX=process.platform==="win32"?`${iy}.exe`:iy,e6=/^[^\s.,*>]+$/,Ov="__request__",t6=a(e=>`${e}.${Ov}`,"REQUEST_SUBJECT"),r6={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},n6={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},s6={HUB:"hub.pid",LEAF:"leaf.pid"},i6={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},o6={SUCCESS:"success",ERROR:"error"},a6={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},c6={TXN:"txn",MSGID:"msgid"},uu={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},l6={[uu.ERR]:1,[uu.WRN]:2,[uu.INF]:3,[uu.DBG]:4,[uu.TRC]:5},u6={debug:"-D",trace:"-DVV"};Nv.exports={NATS_SERVER_ZIP:XX,NATS_SERVER_NAME:iy,NATS_BINARY_NAME:ZX,PID_FILES:s6,NATS_CONFIG_FILES:n6,SERVER_SUFFIX:i6,NATS_TERM_CONSTRAINTS_RX:e6,REQUEST_SUFFIX:Ov,UPDATE_REMOTE_RESPONSE_STATUSES:o6,CLUSTER_STATUS_STATUSES:a6,REQUEST_SUBJECT:t6,SUBJECT_PREFIXES:c6,MSG_HEADERS:r6,LOG_LEVELS:uu,LOG_LEVEL_FLAGS:u6,LOG_LEVEL_HIERARCHY:l6}});var oy=C(wv=>{"use strict";var d6={cert:"-----BEGIN CERTIFICATE-----\rMIIDXDCCAkSgAwIBAgIFNTE4MzQwDQYJKoZIhvcNAQELBQAwXTEXMBUGA1UEAxMO\rSGFycGVyREIsIEluYy4xCzAJBgNVBAYTAlVTMQswCQYDVQQIEwJDTzEPMA0GA1UE\rBxMGRGVudmVyMRcwFQYDVQQKEw5IYXJwZXJEQiwgSW5jLjAeFw0yMjAzMTEyMzAz\rNDlaFw0yNzAzMTAyMzAzNDlaMF0xFzAVBgNVBAMTDkhhcnBlckRCLCBJbmMuMQsw\rCQYDVQQGEwJVUzELMAkGA1UECBMCQ08xDzANBgNVBAcTBkRlbnZlcjEXMBUGA1UE\rChMOSGFycGVyREIsIEluYy4wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIB\rAQCsEUlBF8WImS78rCFXVKyntxfrW++4qZ3hGnoD2MHZAuDHyeP/5eGnaE9GQhKc\r4DwG4DGvh0wP2zIYnBfiQ3L2ZtnlDR9ZkKIQYGlVxTUn6T43krhK5nZKqDF43Yg3\rZEvO3cbJBjiKZx0eA2/toehdSsTAHHQx5gTDcggNe2tgoJHYPwi9YF/AxSBZrbgb\ryWlYgtYDmF32ytHP03GUCIdKOFuBPsHTGu4SkdEIdLIqO9oglW1YFH5qZ6NiwApW\rsP+GCuqOwDXXbdjr75iq9Tq/CDrjGFLaTPmvd2Q0qG/BtaCll0ghpG+yIHvt/iQs\rajS+LxEWAnVlGMaDdFErbDUtAgMBAAGjIzAhMA8GA1UdEwEB/wQFMAMBAf8wDgYD\rVR0PAQH/BAQDAgIEMA0GCSqGSIb3DQEBCwUAA4IBAQASR4YW/rPK7PNArHVe9zzM\rb0rKNX/2T9/0nybRhmE/+hdlSgliTAeebmwkUS2APckmekYt/q2ZY2NS65Fo/jjp\rG8TJrtcF4h+ylVqUp0ZXQLFtIsr7r2JZA7hJ6njW6G4DHSZ0gxtECLi4CBlTjzm5\rNmnmIDObvGRTuqmcdAZmXeObbta/He2XIzietukPAYX062pNM+G5XT5UM1eG/Vlp\rN86vjhpyI+ffKy+C60SJqxmKM3ydgN7oLscE7+2wLPN25XqN4W99OwGsp5dTdu/f\r5lPtFayXdJ55e/sNQKmGN+UGLrL05c2MWgjb8U/LFilnupUianceoeSERZmVjzKX\r-----END CERTIFICATE-----\r".replace(/\r/g,`\r
17
17
  `),key:"-----BEGIN RSA PRIVATE KEY-----\rMIIEowIBAAKCAQEArBFJQRfFiJku/KwhV1Ssp7cX61vvuKmd4Rp6A9jB2QLgx8nj\r/+Xhp2hPRkISnOA8BuAxr4dMD9syGJwX4kNy9mbZ5Q0fWZCiEGBpVcU1J+k+N5K4\rSuZ2SqgxeN2IN2RLzt3GyQY4imcdHgNv7aHoXUrEwBx0MeYEw3IIDXtrYKCR2D8I\rvWBfwMUgWa24G8lpWILWA5hd9srRz9NxlAiHSjhbgT7B0xruEpHRCHSyKjvaIJVt\rWBR+amejYsAKVrD/hgrqjsA1123Y6++YqvU6vwg64xhS2kz5r3dkNKhvwbWgpZdI\rIaRvsiB77f4kLGo0vi8RFgJ1ZRjGg3RRK2w1LQIDAQABAoIBAQCEOmh78EOpnGZC\rYBjjHrvrysVD5gvLcfVUtl8Ls7gMB60re1eOIF+PoZZCHKZnDd6zPfiQtj1adg0C\rYnnsM/8VoaZS4gm0b3RLd3ubIQifWhuo40RissY2yxfxlPSH9LhZCY8ojnJG0cTL\resK579E8WCfopjUY33XLqEbN7Ylv39J+DSqInjqV3efJZUa+HqUJ98VxxzodcKMD\rP3bwUU4gHoSSp4pAsOFH5sQhaIWH1IcNjrAwpee2cJQuh4G157RRIuuUpagtaEG/\rXJIiAyBguJyu3JQFnIBQF01N5+omJgXYJ1L0m54543/iIRThmF3zDCDgCyUzmOk+\rH6As9fv1AoGBANOpOtOZLSAScjGsgJamT3ceJ2wCa86g2j8Oxu8lJUmUp5s3tA0v\rBFW5O3S4KR1EXwkLMBUMrfFM8YvzHWxsXBI6XV8azGLvyqPHxr65OhmpGYkGZMXu\rn9okgjkqlewnY2I073gvyK7ppX51UL5y9fF1vlsk+UlW+Rgx/vMHbdcjAoGBANAc\rxRUsxs4QJpbS4zD3JOkHjr24a97TrS3kCybAHUMpR2NrEHPZw9zex0/aphOJUHfL\rIMkOZdpfDqMfxWy4FAEmqBEMkO2SB+h0Wp4P+qp81ax4vGFiB0cD3wtixr11U1tt\rlZ/ZTdv4VDpDFNK1KaplhTDeyuCjeYfS3/GJia9vAoGAcOsAgjBevZR5rXx84WH6\rVO8WUu37u7FenXNxt9VWTinrPMh72uixZFY8nOk+rely1e1NCn3IMko9Ns9NbDFm\r8SaH95vhXArXTYbfxZIlp9jp0YtCqcHDL+p4Oq04bFMbFyJseu7rHj1x18QYfnHw\rOY/6LL/N6k1m+Hx7qgXVmIcCgYB/w0nTCBw84XlvWqSTqQaF8VfWbWP79mP5KmkW\rLxdH5g2noVEGbohqDnK6OXd/wusdwByukiJBf94Skyy25AOT+VFwthA7aU1ljhkb\rtJ+lDuJ28eBkwLPLCzthWBC+u0qjdJFJAzVjd/7tjcU43nNn4s90AzL12iaAFhvZ\rwyA+DQKBgGc/4cdyGJ3YkcA8150gQBawgJZ7q8V1JND87ggWA8wnK3cHn7rMZQl2\r3emDp9HEFXFex5dbGDDqZFAoesZCDxjknIn9oNfW4PvaWS8q7b6ZKLZG1p03Pu7/\rtYaD0kPbo0kysfFT/co+NgHbdykvIyboomfGdNLTUjYuy6lpwpvs\r-----END RSA PRIVATE KEY-----\r".replace(/\r/g,`\r
18
18
  `)},f6="certificate.pem",_6="privateKey.pem",h6="caCertificate.pem",m6="natsCertificate.pem",p6="natsCaCertificate.pem",Rt={DEFAULT:"default","DEFAULT-CA":"default-ca",SERVER:"server",CA:"ca","OPERATIONS-API":"operations-api","OPERATIONS-CA":"operations-ca"},E6={tls_certificate:Rt.SERVER,tls_certificateAuthority:Rt.CA,customFunctions_tls_certificate:Rt.SERVER,customFunctions_tls_certificateAuthority:Rt.CA,operationsApi_tls_certificate:Rt["OPERATIONS-API"],operationsApi_tls_certificateAuthority:Rt["OPERATIONS-CA"]},g6={[Rt.SERVER]:2,[Rt.DEFAULT]:1},S6={[Rt["OPERATIONS-API"]]:3,[Rt.SERVER]:2,[Rt.DEFAULT]:1},T6={[Rt["OPERATIONS-API"]]:3,[Rt.SERVER]:2,[Rt.DEFAULT]:1},A6={[Rt["OPERATIONS-CA"]]:3,[Rt.CA]:2,[Rt["DEFAULT-CA"]]:1},R6={[Rt["OPERATIONS-CA"]]:3,[Rt.CA]:2,[Rt["DEFAULT-CA"]]:1},y6={[Rt.CA]:2,[Rt["DEFAULT-CA"]]:1};Object.assign(wv,{CERTIFICATE_PEM_NAME:f6,PRIVATEKEY_PEM_NAME:_6,CA_PEM_NAME:h6,CERT_NAME:Rt,CERT_CONFIG_NAME_MAP:E6,CERT_PREFERENCE_APP:g6,CERT_PREFERENCE_OPS:S6,CERT_PREFERENCE_REP:T6,CA_CERT_PREFERENCE_REP:A6,CA_CERT_PREFERENCE_OPS:R6,CA_CERT_PREFERENCE_APP:y6,CERTIFICATE_VALUES:d6,NATS_CERTIFICATE_PEM_NAME:m6,NATS_CA_PEM_NAME:p6})});var cy=C((ebe,Mv)=>{"use strict";var Dv=require("fs-extra"),Ee=require("joi"),b6=require("os"),{boolean:Ge,string:_t,number:tr,array:fa}=Ee.types(),{totalmem:Iv}=require("os"),Bc=require("path"),O6=ee(),ay=oe(),Zye=oy(),Cv=(k(),P(q)),N6=it(),Pv="log",w6="components",I6="Invalid logging.rotation.maxSize unit. Available units are G, M or K",C6="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",P6="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",D6="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",L6="rootPath config parameter is undefined",Tn=Ee.alternatives([tr.min(0),_t]).optional().empty(null),kp=Ee.alternatives([fa.items(_t,{host:_t.required(),port:Tn},{hostname:_t.required(),port:Tn}).empty(null),fa.items(_t)]),wi,Lv=!1;Mv.exports={configValidator:M6,routesValidator:k6,route_constraints:kp};function M6(e,t=!1){if(Lv=t,wi=e.rootPath,ay.isEmpty(wi))throw L6;let r=Ge.optional(),n=tr.min(0).max(1e3).empty(null).default(H6),s=_t.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(e_),i=_t.optional().empty(null),o=_t.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null).required(),c=Ee.string().empty(null).default(e_),l=Ee.custom(U6).empty(null).default(e_),u=e.clustering?.enabled,f=Ee.object({certificate:i,certificateAuthority:i,privateKey:i}),d;return u===!0?d=Ee.object({enabled:r,hubServer:Ee.object({cluster:Ee.object({name:Ee.required().empty(null),network:Ee.object({port:Tn,routes:kp}).required()}).required(),leafNodes:Ee.object({network:Ee.object({port:Tn}).required()}).required(),network:Ee.object({port:Tn}).required()}).required(),leafServer:Ee.object({network:Ee.object({port:Tn,routes:kp}).required(),streams:Ee.object({maxAge:tr.min(120).allow(null).optional(),maxBytes:tr.min(1).allow(null).optional(),maxMsgs:tr.min(1).allow(null).optional(),path:c}).required()}).required(),logLevel:Ee.valid("error","warn","info","debug","trace"),nodeName:o,republishMessages:Ge.optional(),databaseLevel:Ge.optional(),tls:Ee.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:Ge.required(),verify:Ge.optional()}),user:_t.optional().empty(null)}).optional():d=Ee.object({enabled:r,tls:Ee.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:Ge.optional()})}).optional(),Ee.object({authentication:Ee.alternatives(Ee.object({authorizeLocal:Ge,cacheTTL:tr.required(),cookie:Ee.object({domains:fa.items(_t).optional(),expires:_t.optional()}),enableSessions:Ge,hashFunction:_t.valid("md5","sha256","argon2id").optional().empty(null)}),Ge).optional(),analytics:Ee.object({aggregatePeriod:tr}),replication:Ee.object({hostname:Ee.alternatives(_t,tr).optional().empty(null),url:_t.optional().empty(null),port:Tn,securePort:Tn,routes:fa.optional().empty(null),databases:Ee.alternatives(_t,fa),enableRootCAs:Ge.optional(),copyTablesToCatchUp:Ge.optional()}).optional(),componentsRoot:s.optional(),clustering:d,localStudio:Ee.object({enabled:r}).required(),logging:Ee.object({auditAuthEvents:Ee.object({logFailed:Ge,logSuccessful:Ge}),file:Ge.required(),level:Ee.valid("notify","fatal","error","warn","info","debug","trace"),rotation:Ee.object({enabled:Ge.optional(),compress:Ge.optional(),interval:_t.custom(B6).optional().empty(null),maxSize:_t.custom(x6).optional().empty(null),path:_t.optional().empty(null).default(e_)}).required(),root:s,stdStreams:Ge.required(),auditLog:Ge.required()}).required(),operationsApi:Ee.object({network:Ee.object({cors:Ge.optional(),corsAccessList:fa.optional(),headersTimeout:tr.min(1).optional(),keepAliveTimeout:tr.min(1).optional(),port:Tn,domainSocket:Ee.optional().empty("hdb/operations-server").default(e_),securePort:Tn,timeout:tr.min(1).optional()}).optional(),tls:Ee.alternatives([Ee.array().items(f),f])}).required(),rootPath:_t.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").required(),mqtt:Ee.object({network:Ee.object({port:Tn,securePort:Tn,mtls:Ee.alternatives([Ge.optional(),Ee.object({user:_t.optional(),certificateAuthority:i,required:Ge.optional()})])}).required(),webSocket:Ge.optional(),requireAuthentication:Ge.optional()}),http:Ee.object({compressionThreshold:tr.optional(),cors:Ge.optional(),corsAccessList:fa.optional(),headersTimeout:tr.min(1).optional(),port:Tn,securePort:Tn,maxHeaderSize:tr.optional(),mtls:Ee.alternatives([Ge.optional(),Ee.object({user:_t.optional(),certificateAuthority:i,required:Ge.optional()})]),threadRange:Ee.alternatives([fa.optional(),_t.optional()])}).required(),threads:Ee.alternatives(n.optional(),Ee.object({count:n.optional(),debug:Ee.alternatives(Ge.optional(),Ee.object({startingPort:tr.min(1).optional(),host:_t.optional(),waitForDebugger:Ge.optional()})),maxHeapMemory:tr.min(0).optional()})),storage:Ee.object({writeAsync:Ge.required(),overlappingSync:Ge.optional(),caching:Ge.optional(),compression:Ee.alternatives([Ge.optional(),Ee.object({dictionary:_t.optional(),threshold:tr.optional()})]),compactOnStart:Ge.optional(),compactOnStartKeepBackup:Ge.optional(),noReadAhead:Ge.optional(),path:l,prefetchWrites:Ge.optional(),maxFreeSpaceToLoad:tr.optional(),maxFreeSpaceToRetain:tr.optional()}).required(),ignoreScripts:Ge.optional(),tls:Ee.alternatives([Ee.array().items(f),f])}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(M6,"configValidator");function v6(e){return Lv||Dv.existsSync(e)?null:`Specified path ${e} does not exist.`}a(v6,"doesPathExist");function U6(e,t){Ee.assert(e,_t.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=v6(e);if(r)return t.message(r)}a(U6,"validatePath");function x6(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(I6);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(P6):e}a(x6,"validateRotationMaxSize");function B6(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message(C6);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(D6):e}a(B6,"validateRotationInterval");function H6(e,t){let r=t.state.path.join("."),n=b6.cpus().length,s=n-1;s<=2&&(s=2);let i=process.constrainedMemory?.()||Iv();return i=Math.round(Math.min(i,Iv())/1e6),s=Math.max(Math.min(s,Math.round((i-750)/300)),1),O6.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}a(H6,"setDefaultThreads");function e_(e,t){let r=t.state.path.join(".");if(!ay.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if(ay.isEmpty(wi))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return Bc.join(wi,w6);case"logging.root":return Bc.join(wi,Pv);case"clustering.leafServer.streams.path":return Bc.join(wi,"clustering","leaf");case"storage.path":let n=Bc.join(wi,Cv.LEGACY_DATABASES_DIR_NAME);return Dv.existsSync(n)?n:Bc.join(wi,Cv.DATABASES_DIR_NAME);case"logging.rotation.path":return Bc.join(wi,Pv);case"operationsApi.network.domainSocket":return r==null?null:Bc.join(wi,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(e_,"setDefaultRoot");function k6(e){let t=Ee.object({routes:kp});return N6.validateBySchema({routes:e},t)}a(k6,"routesValidator")});var Pt=C(Vv=>{"use strict";var ms=(k(),P(q)),pr=oe(),rr=ee(),{configValidator:F6,routesValidator:vv}=cy(),zr=require("fs-extra"),xv=require("yaml"),Vn=require("path"),G6=require("is-number"),Bv=require("properties-reader"),q6=require("lodash"),{handleHDBError:$6}=me(),{HTTP_STATUS_CODES:V6,HDB_ERROR_MSGS:du}=Un(),{server:K6}=(Mr(),P(Jl)),{PACKAGE_ROOT:Hv}=pt(),{DATABASES_PARAM_CONFIG:t_,CONFIG_PARAMS:$n,CONFIG_PARAM_MAP:Vs}=ms,Y6="Unable to get config value because config is uninitialized",W6="Config successfully initialized",z6="Error backing up config file",Q6="Empty parameter sent to getConfigValue",kv=Vn.join(Hv,"config","yaml",ms.HDB_DEFAULT_CONFIG_FILE),j6=Vn.join(Hv,"config","yaml","defaultNatsConfig.yaml"),J6="Configuration successfully set. You must restart HarperDB for new config settings to take effect.",Uv={logging_rotation_retain:"logging.rotation.retain",logging_rotation_rotate:"logging.rotation.rotate",logging_rotation_rotateinterval:"logging.rotation.rotateInterval",logging_rotation_rotatemodule:"logging.rotation.rotateModule",logging_rotation_timezone:"logging.rotation.timezone",logging_rotation_workerinterval:"logging.rotation.workerInterval"},Fp,Ct,Gp;Object.assign(Vv,{createConfigFile:X6,getDefaultConfig:Z6,getConfigValue:Gv,initConfig:qp,flattenConfig:fu,updateConfigValue:qv,updateConfigObject:tZ,getConfiguration:sZ,setConfiguration:iZ,readConfigFile:fy,getClusteringRoutes:oZ,initOldConfig:$v,getConfigFromFile:aZ,getConfigFilePath:Hc,addConfig:cZ,deleteConfigFromFile:lZ,getConfigObj:uZ,resolvePath:ly,getFlatConfigObj:dZ});function ly(e){if(e?.startsWith("~/"))return Vn.join(pr.getHomeDir(),e.slice(1));let t=ce();try{return Vn.resolve(t.getHdbBasePath(),e)}catch(r){return console.error("Unable to resolve path",e,r),e}}a(ly,"resolvePath");function X6(e,t=!1){let r=_a(kv);if(e.clustering_enabled||e.CLUSTERING_ENABLED||e.clustering){let c=xv.parseDocument(zr.readFileSync(j6,"utf8"),{simpleKeys:!0});r.addIn(["clustering"],c.toJSON().clustering)}Fp=fu(r.toJSON());let n;for(let c in e){let l=Vs[c.toLowerCase()];if(l===$n.DATABASES){Array.isArray(e[c])?n=e[c]:n=Object.keys(e[c]).map(u=>({[u]:e[c][u]}));continue}if(!l&&(c.endsWith("_package")||c.endsWith("_port"))&&(l=c),l!==void 0){let u=l.split("_"),f=uy(l,e[c]);l==="rootPath"&&f?.endsWith("/")&&(f=f.slice(0,-1));try{r.setIn([...u],f)}catch(d){rr.error(d)}}}n&&Fv(r,n),dy(r,t);let s=r.toJSON();Ct=fu(s);let i=r.getIn(["rootPath"]),o=Vn.join(i,ms.HDB_CONFIG_FILE);if(zr.createFileSync(o),r.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${r.errors}`);zr.writeFileSync(o,String(r)),rr.trace(`Config file written to ${o}`)}a(X6,"createConfigFile");function Fv(e,t){let r;try{try{r=JSON.parse(t)}catch(n){if(!pr.isObject(t))throw n;r=t}for(let n of r){let s=Object.keys(n)[0];if(n[s].hasOwnProperty(t_.TABLES))for(let i in n[s][t_.TABLES])for(let o in n[s][t_.TABLES][i]){let c=n[s][t_.TABLES][i][o],l=[$n.DATABASES,s,t_.TABLES,i,o];e.hasIn(l)?e.setIn(l,c):e.addIn(l,c)}else for(let i in n[s]){let o=n[s][i],c=[$n.DATABASES,s,i];e.hasIn(c)?e.setIn(c,o):e.addIn(c,o)}}}catch(n){rr.error("Error parsing schemas CLI/env config arguments",n)}}a(Fv,"setSchemasConfig");function Z6(e){if(Fp===void 0){let r=_a(kv);Fp=fu(r.toJSON())}let t=Vs[e.toLowerCase()];if(t!==void 0)return Fp[t.toLowerCase()]}a(Z6,"getDefaultConfig");function Gv(e){if(e==null){rr.info(Q6);return}if(Ct===void 0){rr.trace(Y6);return}let t=Vs[e.toLowerCase()];if(t!==void 0)return Ct[t.toLowerCase()]}a(Gv,"getConfigValue");function Hc(e=pr.getPropsFilePath()){let t=pr.getEnvCliRootPath();if(t)return ly(Vn.join(t,ms.HDB_CONFIG_FILE));let r=Bv(e);return ly(r.get(ms.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}a(Hc,"getConfigFilePath");function qp(e=!1){if(Ct===void 0||e){let t;if(!pr.noBootFile()){t=pr.getPropsFilePath();try{zr.accessSync(t,zr.constants.F_OK|zr.constants.R_OK)}catch(i){throw rr.error(i),new Error(`HarperDB properties file at path ${t} does not exist`)}}let r=Hc(t),n;if(r.includes("config/settings.js"))try{$v(r);return}catch(i){if(i.code!==ms.NODE_ERROR_CODES.ENOENT)throw i}try{n=_a(r)}catch(i){if(i.code===ms.NODE_ERROR_CODES.ENOENT){rr.trace(`HarperDB config file not found at ${r}.
19
19
  This can occur during early stages of install where the config file has not yet been created`);return}else throw rr.error(i),new Error(`Error reading HarperDB config file at ${r}`)}eZ(n,r),dy(n);let s=n.toJSON();if(K6.config=s,Ct=fu(s),Ct.logging_rotation_rotate)for(let i in Uv)Ct[i]&&rr.error(`Config ${Uv[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);rr.trace(W6)}}a(qp,"initConfig");function eZ(e,t){let r=e.getIn(["rootPath"]),n=!1;if(e.hasIn(["storage","path"])||(e.setIn(["storage","path"],Vn.join(r,"database")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],Vn.join(r,"log")),n=!0),e.hasIn(["authentication"])||(e.addIn(["authentication"],{cacheTTL:3e4,enableSessions:!0,operationTokenTimeout:e.getIn(["operationsApi","authentication","operationTokenTimeout"])??"1d",refreshTokenTimeout:e.getIn(["operationsApi","authentication","refreshTokenTimeout"])??"30d"}),n=!0),e.hasIn(["analytics"])||(e.addIn(["analytics"],{aggregatePeriod:60}),n=!0),n){if(rr.trace("Updating config file with missing config params"),e.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${e.errors}`);zr.writeFileSync(t,String(e))}}a(eZ,"checkForUpdatedConfig");function dy(e,t=!1){let r=e.toJSON();if(r.componentsRoot=r.componentsRoot??r?.customFunctions?.root,r?.http?.threads&&(r.threads=r?.http?.threads),r.http?.port&&r.http?.port===r.http?.securePort)throw du.CONFIG_VALIDATION("http.port and http.securePort cannot be the same value");if(r.operationsApi?.network?.port&&r.operationsApi?.network?.port===r.operationsApi?.network?.securePort)throw du.CONFIG_VALIDATION("operationsApi.network.port and operationsApi.network.securePort cannot be the same value");let n=F6(r,t);if(n.error)throw du.CONFIG_VALIDATION(n.error.message);typeof n.value.threads=="object"?e.setIn(["threads","count"],n.value.threads.count):e.setIn(["threads"],n.value.threads),e.setIn(["componentsRoot"],n.value.componentsRoot),e.setIn(["logging","root"],n.value.logging.root),e.setIn(["storage","path"],n.value.storage.path),e.setIn(["logging","rotation","path"],n.value.logging.rotation.path),e.setIn(["operationsApi","network","domainSocket"],n.value?.operationsApi?.network?.domainSocket),r?.clustering?.enabled&&e.setIn(["clustering","leafServer","streams","path"],n.value.clustering.leafServer.streams?.path)}a(dy,"validateConfig");function tZ(e,t){Ct===void 0&&(Ct={});let r=Vs[e.toLowerCase()];if(r===void 0){rr.trace(`Unable to update config object because config param '${e}' does not exist`);return}Ct[r.toLowerCase()]=t}a(tZ,"updateConfigObject");function qv(e,t,r=void 0,n=!1,s=!1,i=!1){Ct===void 0&&qp();let o=Gv(Vs.hdb_root),c=Vn.join(o,ms.HDB_CONFIG_FILE),l=_a(c),u;if(r&&Ct){let _=!1;for(let h in r)if(r[h]!=Ct[h.toLowerCase()]){_=!0;break}if(!_){rr.trace("No changes detected in config parameters, skipping update");return}}if(r===void 0&&e.toLowerCase()===$n.DATABASES)u=t;else if(r===void 0){let _;if(i)_=e;else if(_=Vs[e.toLowerCase()],_===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let h=_.split("_"),m=uy(_,t);l.setIn([...h],m)}else for(let _ in r){let h=Vs[_.toLowerCase()];if(h===$n.HTTP_SECUREPORT&&r[_]===Ct[$n.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),h===$n.OPERATIONSAPI_NETWORK_SECUREPORT&&r[_]===Ct[$n.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&l.setIn(["operationsApi","network","port"],null),h===$n.DATABASES){u=r[_];continue}if(h?.startsWith("threads_")){let m=l.getIn(["threads"]);m>=0&&(l.deleteIn(["threads"]),l.setIn(["threads","count"],m))}if(!h&&(_.endsWith("_package")||_.endsWith("_port"))&&(h=_),h!==void 0){let m=h.split("_"),S=ms.LEGACY_CONFIG_PARAMS[_.toUpperCase()];S&&S.startsWith("customFunctions")&&l.hasIn(S.split("_"))&&(h=S,m=S.split("_"));let g=uy(h,r[_]);h==="rootPath"&&g?.endsWith("/")&&(g=g.slice(0,-1));try{m.length>1&&typeof l.getIn(m.slice(0,-1))=="boolean"&&l.deleteIn(m.slice(0,-1)),l.setIn([...m],g)}catch(R){rr.error(R)}}}u&&Fv(l,u),dy(l);let f=l.getIn(["rootPath"]),d=Vn.join(f,ms.HDB_CONFIG_FILE);if(n===!0&&rZ(c,f),l.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${l.errors}`);zr.writeFileSync(d,String(l)),s&&(Ct=fu(l.toJSON())),rr.trace(`Config parameter: ${e} updated with value: ${t}`)}a(qv,"updateConfigValue");function rZ(e,t){try{let r=Vn.join(t,"backup",`${new Date(Date.now()).toISOString().replaceAll(":","-")}-${ms.HDB_CONFIG_FILE}.bak`);zr.copySync(e,r),rr.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){rr.error(z6),rr.error(r)}}a(rZ,"backupConfigFile");var nZ=["databases"];function fu(e){return e.http&&Object.assign(e.http,e?.customFunctions?.network),e?.operationsApi?.network&&(e.operationsApi.network={...e.http,...e.operationsApi.network}),e?.operationsApi&&(e.operationsApi.tls={...e.tls,...e.operationsApi.tls}),Gp=e,r(e);function r(n){let s={};for(let i in n)if(n.hasOwnProperty(i)){if(typeof n[i]=="object"&&n[i]!==null&&!Array.isArray(n[i])&&!nZ.includes(i)){let o=r(n[i]);for(let c in o){if(!o.hasOwnProperty(c))continue;c!=="package"&&(i=i.toLowerCase());let l=i+"_"+c;!$n[l.toUpperCase()]&&Vs[l]&&(s[Vs[l].toLowerCase()]=o[c]),s[l]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(fu,"flattenConfig");function uy(e,t){if(e===$n.CLUSTERING_NODENAME||e===$n.CLUSTERING_USER){if(t==null)return t;if(!isNaN(t))return t.toString();if(typeof t=="string"&&t.toLowerCase()==="true"||typeof t=="string"&&t.toLowerCase()==="false")return t}else{if(G6(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||pr.isObject(t)||t===null)return t;if(typeof t=="string"&&t.toLowerCase()==="true")return!0;if(typeof t=="string"&&t.toLowerCase()==="false")return!1}if(t===void 0||t.toLowerCase()==="undefined")return null;if(typeof t=="string"&&(t.startsWith("{")&&t.endsWith("}")||t.startsWith("[")&&t.endsWith("]")))try{return JSON.parse(t)}catch{}return pr.autoCast(t)}a(uy,"castConfigValue");function sZ(){let e=pr.getPropsFilePath(),t=Hc(e);return _a(t).toJSON()}a(sZ,"getConfiguration");async function iZ(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return qv(void 0,void 0,s,!0),J6}catch(i){throw typeof i=="string"||i instanceof String?$6(i,i,V6.BAD_REQUEST,void 0,void 0,!0):i}}a(iZ,"setConfiguration");function fy(){let e=pr.getPropsFilePath();try{zr.accessSync(e,zr.constants.F_OK|zr.constants.R_OK)}catch(n){if(!pr.noBootFile())throw rr.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=Hc(e);return _a(t).toJSON()}a(fy,"readConfigFile");function _a(e){return xv.parseDocument(zr.readFileSync(e,"utf8"),{simpleKeys:!0})}a(_a,"parseYamlDoc");function oZ(){let e=fy(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=pr.isEmptyOrZeroLength(t)?[]:t;let r=vv(t);if(r)throw du.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=pr.isEmptyOrZeroLength(n)?[]:n;let s=vv(n);if(s)throw du.CONFIG_VALIDATION(s.message);if(!pr.isEmptyOrZeroLength(n)&&!pr.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!pr.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw du.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(oZ,"getClusteringRoutes");function $v(e){let t=Bv(e);Ct={};for(let r in Vs){let n=t.get(r.toUpperCase());if(pr.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=Vs[r].toLowerCase();s===$n.LOGGING_ROOT?Ct[s]=Vn.dirname(n):Ct[s]=n}return Ct}a($v,"initOldConfig");function aZ(e){let t=fy();return q6.get(t,e.replaceAll("_","."))}a(aZ,"getConfigFromFile");async function cZ(e,t){let r=_a(Hc());if(r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),r.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${r.errors}`);await zr.writeFile(Hc(),String(r))}a(cZ,"addConfig");function lZ(e){let t=Hc(pr.getPropsFilePath()),r=_a(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=Vn.join(n,ms.HDB_CONFIG_FILE);zr.writeFileSync(s,String(r))}a(lZ,"deleteConfigFromFile");function uZ(){return Gp||(qp(),Gp)}a(uZ,"getConfigObj");function dZ(){return Ct||qp(),Ct}a(dZ,"getFlatConfigObj")});var Kn=C((sbe,Nr)=>{"use strict";var Wv="username is required",zv="nothing to update, must supply active, role or password to update",Qv="password cannot be an empty string",jv="If role is specified, it cannot be empty.",Jv="active must be true or false";Nr.exports.addUser=TZ;Nr.exports.alterUser=AZ;Nr.exports.dropUser=yZ;Nr.exports.getSuperUser=IZ;Nr.exports.userInfo=bZ;Nr.exports.listUsers=Vp;Nr.exports.listUsersExternal=OZ;Nr.exports.setUsersWithRolesCache=kc;Nr.exports.findAndValidateUser=Ay;Nr.exports.getClusterUser=CZ;Nr.exports.getUsersWithRolesCache=wZ;Nr.exports.USERNAME_REQUIRED=Wv;Nr.exports.ALTERUSER_NOTHING_TO_UPDATE=zv;Nr.exports.EMPTY_PASSWORD=Qv;Nr.exports.EMPTY_ROLE=jv;Nr.exports.ACTIVE_BOOLEAN=Jv;var Xv=An(),fZ=xc(),r_=(Hp(),P(Bp)),Zv=bv(),n_=Yr(),Ey=mo(),Ii=oe(),eU=require("validate.js"),gy=ee(),{promisify:_Z}=require("util"),Sy=fo(),hy=(k(),P(q)),Kv=It(),hZ=Pt(),mZ=ce(),pZ=co(),{hdb_errors:EZ,ClientError:Ks}=me(),{HTTP_STATUS_CODES:ho,AUTHENTICATION_ERROR_MSGS:_y,HDB_ERROR_MSGS:_u}=EZ,{UserEventMsg:Ty}=Ys(),my=require("lodash"),{server:$p}=(Mr(),P(Jl)),gZ=ee();$p.getUser=(e,t)=>Ay(e,t,t!=null);$p.authenticateUser=(e,t)=>Ay(e,t);var tU={username:!0,active:!0,role:!0,password:!0},Yv=new Map,SZ=_Z(fZ.delete),py=mZ.get(hy.CONFIG_PARAMS.AUTHENTICATION_HASHFUNCTION)??r_.HASH_FUNCTION.SHA256,Ci;async function TZ(e){let t=eU.cleanAttributes(e,tU),r=Zv.addUserValidation(t);if(r)throw new Ks(r.message);let n=await n_.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(_u.ROLE_NAME_NOT_FOUND(t.role),ho.NOT_FOUND);if(n.length>1)throw new Ks(_u.DUP_ROLES_FOUND(t.role),ho.CONFLICT);n[0].permission.cluster_user===!0&&(t.hash=Sy.encrypt(t.password)),t.password=await r_.hash(t.password,py),t.hash_function=py,t.role=n[0].id;let s=await Xv.insert({operation:"insert",schema:"system",table:"hdb_user",records:[t]});if(gy.debug(s),await kc(),s.skipped_hashes.length===1)throw new Ks(_u.USER_ALREADY_EXISTS(t.username),ho.CONFLICT);return Ey.signalUserChange(new Ty(process.pid)),`${t.username} successfully added`}a(TZ,"addUser");async function AZ(e){let t=eU.cleanAttributes(e,tU);if(Ii.isEmptyOrZeroLength(t.username))throw new Error(Wv);if(Ii.isEmptyOrZeroLength(t.password)&&Ii.isEmptyOrZeroLength(t.role)&&Ii.isEmptyOrZeroLength(t.active))throw new Error(zv);if(!Ii.isEmpty(t.password)&&Ii.isEmptyOrZeroLength(t.password.trim()))throw new Error(Qv);if(!Ii.isEmpty(t.active)&&!Ii.isBoolean(t.active))throw new Error(Jv);if(!Ii.isEmpty(t.password)&&!Ii.isEmptyOrZeroLength(t.password.trim())&&(RZ(t.username)&&(t.hash=Sy.encrypt(t.password)),t.password=await r_.hash(t.password,py)),t.role==="")throw new Error(jv);if(t.role){let n=await n_.searchByValue({schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]});if(!n||n.length===0)throw new Ks(_u.ALTER_USER_ROLE_NOT_FOUND(t.role),ho.NOT_FOUND);if(n.length>1)throw new Ks(_u.DUP_ROLES_FOUND(t.role),ho.CONFLICT);t.role=n[0].id}let r=await Xv.update({operation:"update",schema:"system",table:"hdb_user",records:[t]});return await kc(),Ey.signalUserChange(new Ty(process.pid)),r}a(AZ,"alterUser");function RZ(e){let t=!1,r=Ci.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(RZ,"isClusterUser");async function yZ(e){let t=Zv.dropUserValidation(e);if(t)throw new Ks(t.message);if(Ci.get(e.username)===void 0)throw new Ks(_u.USER_NOT_EXIST(e.username),ho.NOT_FOUND);let r=await SZ({table:"hdb_user",schema:"system",hash_values:[e.username]});return gy.debug(r),await kc(),Ey.signalUserChange(new Ty(process.pid)),`${e.username} successfully deleted`}a(yZ,"dropUser");async function bZ(e){let t={};if(!e||!e.hdb_user)return"There was no user info in the body";t=my.cloneDeep(e.hdb_user);let r=await n_.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(bZ,"userInfo");async function OZ(){let e=await Vp();return e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token,delete t.hash_function}),[...e.values()]}a(OZ,"listUsersExternal");async function Vp(){let e=await n_.searchByValue({schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]}),t={};for(let s of e)t[s.id]=my.cloneDeep(s);if(Object.keys(t).length===0)return null;let r=await n_.searchByValue({schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]}),n=new Map;for(let s of r)s=my.cloneDeep(s),s.role=t[s.role],NZ(s.role),n.set(s.username,s);return n}a(Vp,"listUsers");function NZ(e){if(!e){gy.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(NZ,"appendSystemTablesToRole");async function kc(e=void 0){e?Ci=e:Ci=await Vp()}a(kc,"setUsersWithRolesCache");async function wZ(){return Ci||await kc(),Ci}a(wZ,"getUsersWithRolesCache");async function Ay(e,t,r=!0){Ci||await kc();let n=Ci.get(e);if(!n){if(!r)return{username:e};throw new Ks(_y.GENERIC_AUTH_FAIL,ho.UNAUTHORIZED)}if(n&&!n.active)throw new Ks(_y.USER_INACTIVE,ho.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(Yv.get(t)===n.password)return s;{let i=r_.validate(n.password,t,n.hash_function||r_.HASH_FUNCTION.MD5);if(i?.then&&(i=await i),i===!0)Yv.set(t,n.password);else throw new Ks(_y.GENERIC_AUTH_FAIL,ho.UNAUTHORIZED)}}return s}a(Ay,"findAndValidateUser");async function IZ(){Ci||await kc();for(let[,e]of Ci)if(e.role.role==="super_user")return e}a(IZ,"getSuperUser");async function CZ(){let e=await Vp(),t=hZ.getConfigFromFile(hy.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!(r==null||r?.role?.role!==hy.ROLE_TYPES_ENUM.CLUSTER_USER))return r.decrypt_hash=Sy.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+Kv.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+Kv.SERVER_SUFFIX.ADMIN,r}a(CZ,"getClusterUser");var rU=[];$p.invalidateUser=function(e){for(let t of rU)try{t(e)}catch(r){gZ.error("Error invalidating user",r)}};$p.onInvalidatedUser=function(e){rU.push(e)}});var i_=C((cbe,oU)=>{"use strict";var Fc=ee(),Yn=(k(),P(q)),PZ=SM(),obe=$s(),abe=_o(),DZ=Kn(),{validateEvent:nU}=Ys(),s_=qn(),LZ=require("process"),{resetDatabases:MZ}=(xe(),P(at)),vZ={[Yn.ITC_EVENT_TYPES.SCHEMA]:UZ,[Yn.ITC_EVENT_TYPES.USER]:iU};async function UZ(e){let t=nU(e);if(t){Fc.error(t);return}Fc.trace("ITC schemaHandler received schema event:",e),await PZ(e.message),await xZ(e.message)}a(UZ,"schemaHandler");async function xZ(e){try{s_.resetReadTxn(Yn.SYSTEM_SCHEMA_NAME,Yn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),s_.resetReadTxn(Yn.SYSTEM_SCHEMA_NAME,Yn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),s_.resetReadTxn(Yn.SYSTEM_SCHEMA_NAME,Yn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=MZ();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){Fc.error(t)}}a(xZ,"syncSchemaMetadata");var sU=[];async function iU(e){try{try{s_.resetReadTxn(Yn.SYSTEM_SCHEMA_NAME,Yn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),s_.resetReadTxn(Yn.SYSTEM_SCHEMA_NAME,Yn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){Fc.warn(r)}let t=nU(e);if(t){Fc.error(t);return}Fc.trace(`ITC userHandler ${Yn.HDB_ITC_CLIENT_PREFIX}${LZ.pid} received user event:`,e),await DZ.setUsersWithRolesCache();for(let r of sU)r()}catch(t){Fc.error(t)}}a(iU,"userHandler");iU.addListener=function(e){sU.push(e)};oU.exports=vZ});var Ys=C((hbe,cU)=>{"use strict";var ube=ee(),Ry=oe(),BZ=(k(),P(q)),{ITC_ERRORS:o_}=Un(),{parentPort:dbe,threadId:HZ,isMainThread:kZ,workerData:fbe}=require("worker_threads"),{onMessageFromWorkers:FZ,broadcast:_be,broadcastWithAcknowledgement:GZ}=st();cU.exports={sendItcEvent:qZ,validateEvent:aU,SchemaEventMsg:$Z,UserEventMsg:VZ};var Kp;FZ(async(e,t)=>{Kp=Kp||i_(),aU(e),Kp[e.type]&&await Kp[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function qZ(e){return!kZ&&e.message&&(e.message.originator=HZ),GZ(e)}a(qZ,"sendItcEvent");function aU(e){if(typeof e!="object")return o_.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||Ry.isEmpty(e.type))return o_.MISSING_TYPE;if(!e.hasOwnProperty("message")||Ry.isEmpty(e.message))return o_.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||Ry.isEmpty(e.message.originator))return o_.MISSING_ORIGIN;if(BZ.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return o_.INVALID_EVENT(e.type)}a(aU,"validateEvent");function $Z(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($Z,"SchemaEventMsg");function VZ(e){this.originator=e}a(VZ,"UserEventMsg")});var mo=C((Ebe,fU)=>{"use strict";var lU=(k(),P(q)),pbe=oe(),Yp=ee(),uU=pM(),hu,{sendItcEvent:dU}=Ys();function KZ(e){try{Yp.info("signalSchemaChange called with message:",e),hu=hu||i_();let t=new uU(lU.ITC_EVENT_TYPES.SCHEMA,e);return hu.schema(t),dU(t)}catch(t){Yp.error(t)}}a(KZ,"signalSchemaChange");function YZ(e){try{Yp.trace("signalUserChange called with message:",e),hu=hu||i_();let t=new uU(lU.ITC_EVENT_TYPES.USER,e);return hu.user(t),dU(t)}catch(t){Yp.error(t)}}a(YZ,"signalUserChange");fU.exports={signalSchemaChange:KZ,signalUserChange:YZ}});var Wp=C((Sbe,hU)=>{"use strict";var _U=oe(),WZ=(k(),P(q)),zZ=ee(),QZ=Ip(),jZ=wp(),JZ=mo(),{SchemaEventMsg:XZ}=Ys(),ZZ="already exists in";hU.exports=e8;async function e8(e,t,r){if(_U.isEmptyOrZeroLength(r))return r;let n=[];_U.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 t8(e,t.schema,t.name,i)})),s}a(e8,"lmdbCheckForNewAttributes");async function t8(e,t,r,n){let s=new jZ(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await r8(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(ZZ))zZ.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(t8,"createNewAttribute");async function r8(e){let t;return t=await QZ(e),JZ.signalSchemaChange(new XZ(process.pid,WZ.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(r8,"createAttribute")});var mu=C((Abe,mU)=>{"use strict";var yy=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}};mU.exports=yy});var EU=C((ybe,pU)=>{"use strict";var n8=mu(),s8=(k(),P(q)).OPERATIONS_ENUM,by=class extends n8{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(s8.INSERT,r,n,s,i),this.records=t}};pU.exports=by});var SU=C((Obe,gU)=>{"use strict";var i8=mu(),o8=(k(),P(q)).OPERATIONS_ENUM,Oy=class extends i8{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(o8.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};gU.exports=Oy});var AU=C((wbe,TU)=>{"use strict";var a8=mu(),c8=(k(),P(q)).OPERATIONS_ENUM,Ny=class extends a8{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(c8.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};TU.exports=Ny});var yU=C((Cbe,RU)=>{"use strict";var l8=mu(),u8=(k(),P(q)).OPERATIONS_ENUM,wy=class extends l8{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(u8.DELETE,n,s,t,i),this.original_records=r}};RU.exports=wy});var a_=C((Lbe,wU)=>{"use strict";var Dbe=require("path"),bU=ft(),d8=EU(),f8=SU(),_8=AU(),h8=yU(),pu=kt(),OU=oe(),{CONFIG_PARAMS:m8}=(k(),P(q)),NU=ce();NU.initSync();var zp=(k(),P(q)).OPERATIONS_ENUM,{getTransactionAuditStorePath:p8}=Et();wU.exports=E8;async function E8(e,t){if(NU.get(m8.LOGGING_AUDITLOG)===!1)return;let r=p8(e.schema,e.table),n=await bU.openEnvironment(r,e.table,!0),s=g8(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){bU.initializeDBIs(n,pu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,pu.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[pu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[pu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),OU.isEmpty(s.user_name)||n.dbis[pu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[pu.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(E8,"writeTransaction");function g8(e,t){let r=OU.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===zp.INSERT)return new d8(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===zp.UPDATE)return new f8(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===zp.UPSERT)return new _8(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===zp.DELETE)return new h8(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(g8,"createTransactionObject")});var Iy=C((Ube,IU)=>{"use strict";var S8=Vf(),vbe=Ef(),c_=(k(),P(q)),T8=gf(),A8=Pc().insertRecords,R8=ft(),y8=ee(),b8=Wp(),{getSchemaPath:O8}=Et(),N8=a_();IU.exports=w8;async function w8(e){try{let{schema_table:t,attributes:r}=S8(e);T8(e,r,t.hash_attribute),e.schema!==c_.SYSTEM_SCHEMA_NAME&&(r.includes(c_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(c_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(c_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(c_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await b8(e.hdb_auth_header,t,r),s=O8(e.schema,e.table),i=await R8.openEnvironment(s,e.table),o=await A8(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await N8(e,o)}catch(c){y8.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(w8,"lmdbCreateRecords")});var DU=C((Bbe,PU)=>{"use strict";var CU=(k(),P(q)),I8=Iy(),C8=Ef(),P8=require("fs-extra"),{getSchemaPath:D8}=Et();PU.exports=L8;async function L8(e){let t=[{name:e.schema,createddate:Date.now()}],r=new C8(CU.SYSTEM_SCHEMA_NAME,CU.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await I8(r),await P8.mkdirp(D8(e.schema))}a(L8,"lmdbCreateSchema")});var MU=C((kbe,LU)=>{"use strict";var Cy=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}};LU.exports=Cy});var BU=C((Vbe,xU)=>{"use strict";var vU=ft(),Py=un(),Dy=Un().LMDB_ERRORS_ENUM,M8=kt(),UU=ee(),Gbe=oe(),v8=require("lmdb"),U8=MU(),x8=(k(),P(q)),{OVERFLOW_MARKER:qbe,MAX_SEARCH_KEY_LENGTH:$be}=M8,B8=x8.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function H8(e,t,r,n){if(Py.validateEnv(e),t===void 0)throw new Error(Dy.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(Dy.IDS_REQUIRED):new Error(Dy.IDS_MUST_BE_ITERABLE);try{let s=vU.listDBIs(e);vU.initializeDBIs(e,t,s);let i=new U8,o,c=[],l=[];for(let _=0,h=r.length;_<h;_++)try{o=r[_];let m=e.dbis[t].get(o);if(!m||n&&m[B8]>n){i.skipped.push(o);continue}let S=e.dbis[t].ifVersion(o,v8.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=Py.getIndexedValues(T);if(N)for(let v=0,H=N.length;v<H;v++)E.remove(N[v],o)}catch{UU.warn(`cannot delete from attribute: ${R}, ${T}:${o}`)}}});c.push(S),l.push(o),i.original_records.push(m)}catch(m){UU.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=Py.getNextMonotonicTime(),i}catch(s){throw s}}a(H8,"deleteRecords");xU.exports={deleteRecords:H8}});var l_=C((Ybe,kU)=>{"use strict";var Eu=oe(),k8=BU(),F8=ft(),{getSchemaPath:G8}=Et(),q8=a_(),$8=ee();kU.exports=V8;async function V8(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(Eu.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(Eu.isEmptyOrZeroLength(e.hash_values)&&!Eu.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];Eu.isEmpty(l)||e.hash_values.push(l)}}if(Eu.isEmptyOrZeroLength(e.hash_values))return HU([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(Eu.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=G8(e.schema,e.table),i=await F8.openEnvironment(s,e.table),o=await k8.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await q8(e,o)}catch(c){$8.error(`unable to write transaction due to ${c.message}`)}return HU(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(V8,"lmdbDeleteRecords");function HU(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(HU,"createDeleteResponse")});var My=C((Qbe,FU)=>{"use strict";var K8=(k(),P(q)),zbe=un();function Ly(e,t){let r=Object.create(null);if(t.length===1&&K8.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(Ly,"parseRow");function Y8(e,t,r,n){let s=Ly(r,e);n.push(s)}a(Y8,"searchAll");function W8(e,t,r,n){let s=Ly(r,e);n[t]=s}a(W8,"searchAllToMap");function z8(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(z8,"iterateDBI");function Gc(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(Gc,"pushResults");function Q8(e,t,r,n,s,i){t.toString().endsWith(e)&&Gc(t,r,n,s,i)}a(Q8,"endsWith");function j8(e,t,r,n,s,i){t.toString().includes(e)&&Gc(t,r,n,s,i)}a(j8,"contains");function J8(e,t,r,n,s,i){t>e&&Gc(t,r,n,s,i)}a(J8,"greaterThanCompare");function X8(e,t,r,n,s,i){t>=e&&Gc(t,r,n,s,i)}a(X8,"greaterThanEqualCompare");function Z8(e,t,r,n,s,i){t<e&&Gc(t,r,n,s,i)}a(Z8,"lessThanCompare");function e5(e,t,r,n,s,i){t<=e&&Gc(t,r,n,s,i)}a(e5,"lessThanEqualCompare");FU.exports={parseRow:Ly,searchAll:Y8,searchAllToMap:W8,iterateDBI:z8,endsWith:Q8,contains:j8,greaterThanCompare:J8,greaterThanEqualCompare:X8,lessThanCompare:Z8,lessThanEqualCompare:e5,pushResults:Gc}});var gu=C((eOe,WU)=>{"use strict";var ha=ft(),Jbe=ee(),Wn=un(),Qp=kt(),zt=Un().LMDB_ERRORS_ENUM,Xbe=oe(),t5=(k(),P(q)),jp=My(),{parseRow:r5}=jp,Zbe=require("lmdb"),{OVERFLOW_MARKER:GU,MAX_SEARCH_KEY_LENGTH:n5}=Qp;function qU(e,t,r,n=!1,s=void 0,i=void 0){return qc(e,t,r,(o,c)=>c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}))}a(qU,"iterateFullIndex");function u_(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,u=!1){return qc(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(u_,"iterateRangeBetween");function qc(e,t,r,n){let s=e.database||e,i=ha.openDBI(s,r);i[Qp.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(qc,"setupTransaction");function $U(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(GU)){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[Qp.DBI_DEFINITION_NAME].is_hash_attribute);u++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a($U,"getOverflowCheck");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);return qc(e,t,t,(o,c,l)=>(Jp(r),r=d_(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(u=>r5(u.value,r))))}a(s5,"searchAll");function i5(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);Jp(r),r=d_(e.database||e,r);let o=new Map;for(let{key:c,value:l}of qU(e,t,t,n,s,i))o.set(c,jp.parseRow(l,r));return o}a(i5,"searchAllToMap");function o5(e,t,r=!1,n=void 0,s=void 0){if(Wn.validateEnv(e),t===void 0)throw new Error(zt.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=qU(e,void 0,t,r,n,s),c=o.transaction,l=$U(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(o5,"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 c5(e,t,r,n,s=!1,i=void 0,o=void 0){return ma(e,r,n),qc(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(c5,"equals");function l5(e,t,r){return ma(e,t,r),ha.openDBI(e,t).getValuesCount(r)}a(l5,"count");function u5(e,t,r,n,s=!1,i=void 0,o=void 0){return ma(e,r,n),qc(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(u5,"startsWith");function d5(e,t,r,n,s=!1,i=void 0,o=void 0){return VU(e,t,r,n,s,i,o,!0)}a(d5,"endsWith");function VU(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return ma(e,r,n),qc(e,null,r,(l,u,f,d)=>{let _=$U(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(GU)?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[Qp.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(VU,"contains");function f5(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),u_(e,t,r,n,l,s,i,o,!0,!1)}a(f5,"greaterThan");function _5(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),u_(e,t,r,n,l,s,i,o,!1,!1)}a(_5,"greaterThanEqual");function h5(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),u_(e,t,r,l,n,s,i,o,!1,!0)}a(h5,"lessThan");function m5(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),u_(e,t,r,l,n,s,i,o,!1,!1)}a(m5,"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 u_(e,t,r,n,s,i,o,c)}a(p5,"between");function E5(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(Jp(r),r=d_(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=jp.parseRow(c,r)),o}a(E5,"searchByHash");function g5(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(g5,"checkHashExists");function S5(e,t,r,n,s=[]){return YU(e,t,r,n,s),KU(e,t,r,n,s).map(i=>i[1])}a(S5,"batchSearchByHash");function T5(e,t,r,n,s=[]){YU(e,t,r,n,s);let i=new Map;for(let[o,c]of KU(e,t,r,n,s))i.set(o,c);return i}a(T5,"batchSearchByHashToMap");function KU(e,t,r,n,s=[]){return qc(e,t,t,(i,o,c)=>{r=d_(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,jp.parseRow(f,r)];s.push(u)}).filter(u=>u)})}a(KU,"batchHashSearch");function YU(e,t,r,n,s){if(Wn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);if(Jp(r),n==null)throw new Error(zt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(zt.IDS_MUST_BE_ITERABLE)}a(YU,"initializeBatchSearchByHash");function Jp(e){if(!Array.isArray(e))throw e===void 0?new Error(zt.FETCH_ATTRIBUTES_REQUIRED):new Error(zt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(Jp,"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>n5)throw new Error(zt.SEARCH_VALUE_TOO_LARGE)}a(ma,"validateComparisonFunctions");function d_(e,t){return t.length===1&&t5.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=ha.listDBIs(e)),t}a(d_,"setGetWholeRowAttributes");WU.exports={searchAll:s5,searchAllToMap:i5,count:l5,countAll:a5,equals:c5,startsWith:u5,endsWith:d5,contains:VU,searchByHash:E5,setGetWholeRowAttributes:d_,batchSearchByHash:S5,batchSearchByHashToMap:T5,checkHashExists:g5,iterateDBI:o5,greaterThan:f5,greaterThanEqual:_5,lessThan:h5,lessThanEqual:m5,between:p5}});var Su=C((rOe,XU)=>{var zU=require("lodash"),QU=it(),qe=require("joi"),A5=oe(),{hdb_schema_table:f_,checkValidTable:jU,hdb_table:JU,hdb_database:Xp}=bi(),{handleHDBError:R5,hdb_errors:y5}=me(),{getDatabases:b5}=(xe(),P(at)),{HTTP_STATUS_CODES:O5}=y5,N5=qe.object({database:Xp,schema:Xp,table:JU,search_attribute:f_,search_value:qe.any().required(),get_attributes:qe.array().min(1).items(qe.alternatives(f_,qe.object())).optional(),desc:qe.bool(),limit:qe.number().integer().min(1),offset:qe.number().integer().min(0)}),w5=qe.object({database:Xp,schema:Xp,table:JU,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(f_,qe.object())).optional(),sort:qe.object({attribute:qe.alternatives(f_,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(f_,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()});XU.exports=function(e,t){let r=null;switch(t){case"value":r=QU.validateBySchema(e,N5);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(jU("database",e.schema)),i(jU("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=QU.validateBySchema(e,w5);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=A5.checkGlobalSchemaTable(e.schema,e.table);if(s)return R5(new Error,s,O5.NOT_FOUND);let o=b5()[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=zU.filter(c,f=>f!=="*"&&!f.startsWith?.("$")&&f.attribute!=="*"&&!Array.isArray(f)&&!f.name&&!zU.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 vy=C((sOe,ZU)=>{"use strict";var I5=ft(),C5=Su(),{getSchemaPath:P5}=Et();ZU.exports=D5;function D5(e){let t=C5(e,"hashes");if(t)throw t;let r=P5(e.schema,e.table);return I5.openEnvironment(r,e.table)}a(D5,"initialize")});var Uy=C((oOe,e0)=>{"use strict";var L5=gu(),M5=vy();e0.exports=v5;async function v5(e){let t=await M5(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return L5.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(v5,"lmdbGetDataByHash")});var Tu=C((cOe,t0)=>{"use strict";var xy=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};t0.exports=xy});var n0=C((dOe,r0)=>{"use strict";var uOe=Tu(),U5=gu(),x5=vy();r0.exports=B5;async function B5(e){let t=await x5(e),r=global.hdb_schema[e.schema][e.table];return U5.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(B5,"lmdbSearchByHash")});var Ws=C((_Oe,s0)=>{"use strict";var By=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}};s0.exports=By});var Zp=C((mOe,u0)=>{"use strict";var Qr=gu(),H5=ft(),k5=oe(),$e=kt(),$c=(k(),P(q)),F5=co(),i0=Un().LMDB_ERRORS_ENUM,{getSchemaPath:G5}=Et(),po=$c.SEARCH_WILDCARDS;async function q5(e,t,r){let n;e.schema===$c.SYSTEM_SCHEMA_NAME?n=F5[e.table]:n=global.hdb_schema[e.schema][e.table];let s=l0(e,n.hash_attribute,r,t);return a0(e,s,n.hash_attribute,r)}a(q5,"prepSearch");async function a0(e,t,r,n){let s=G5(e.schema,e.table),i=await H5.openEnvironment(s,e.table),o=c0(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($5(e,r)===!1){let f=e.search_attribute;if(f===r)return n?o0(o,()=>!0):o.map(_=>({[r]:_.key}));let d=a(_=>({[r]:_.value,[f]:_.key}),"toObject");return n?o0(o,d):o.map(d)}let u=e.search_attribute===r?o.map(f=>f.key):o.map(f=>f.value);return n===!0?Qr.batchSearchByHashToMap(c,r,e.get_attributes,u):Qr.batchSearchByHash(c,r,e.get_attributes,u)}a(a0,"executeSearch");function c0(e,t,r,n){let s,i=n;t.get_attributes.indexOf(n)<0&&(i=void 0);let{reverse:o,limit:c,offset:l}=t;switch(o=typeof o=="boolean"?o:!1,c=Number.isInteger(c)?c:void 0,l=Number.isInteger(l)?l:void 0,r){case $e.SEARCH_TYPES.EQUALS:s=Qr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.CONTAINS:s=Qr.contains(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.ENDS_WITH:case $e.SEARCH_TYPES._ENDS_WITH:s=Qr.endsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.STARTS_WITH:case $e.SEARCH_TYPES._STARTS_WITH:s=Qr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return Qr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case $e.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return Qr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case $e.SEARCH_TYPES.SEARCH_ALL:return Qr.searchAll(e,n,t.get_attributes,o,c,l);case $e.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return Qr.searchAllToMap(e,n,t.get_attributes,o,c,l);case $e.SEARCH_TYPES.BETWEEN:s=Qr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,l);break;case $e.SEARCH_TYPES.GREATER_THAN:case $e.SEARCH_TYPES._GREATER_THAN:s=Qr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.GREATER_THAN_EQUAL:case $e.SEARCH_TYPES._GREATER_THAN_EQUAL:s=Qr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.LESS_THAN:case $e.SEARCH_TYPES._LESS_THAN:s=Qr.lessThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.LESS_THAN_EQUAL:case $e.SEARCH_TYPES._LESS_THAN_EQUAL:s=Qr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;default:return Object.create(null)}return s}a(c0,"searchByType");function o0(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(o0,"createMapFromIterable");function $5(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($5,"checkToFetchMore");function l0(e,t,r,n){if(k5.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),po.indexOf(s)>-1)return r===!0?$e.SEARCH_TYPES.SEARCH_ALL_TO_MAP:$e.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(po[0])<0&&s.indexOf(po[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(po.indexOf(i)>=0&&po.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),$e.SEARCH_TYPES.CONTAINS;if(po.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),$e.SEARCH_TYPES.ENDS_WITH;if(po.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),$e.SEARCH_TYPES.STARTS_WITH;if(s.includes(po[0])||s.includes(po[1]))return $e.SEARCH_TYPES.EQUALS;throw new Error(i0.UNKNOWN_SEARCH_TYPE)}else switch(n){case $c.VALUE_SEARCH_COMPARATORS.BETWEEN:return $e.SEARCH_TYPES.BETWEEN;case $c.VALUE_SEARCH_COMPARATORS.GREATER:return $e.SEARCH_TYPES.GREATER_THAN;case $c.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return $e.SEARCH_TYPES.GREATER_THAN_EQUAL;case $c.VALUE_SEARCH_COMPARATORS.LESS:return $e.SEARCH_TYPES.LESS_THAN;case $c.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return $e.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(i0.UNKNOWN_SEARCH_TYPE)}}a(l0,"createSearchTypeFromSearchObject");u0.exports={executeSearch:a0,createSearchTypeFromSearchObject:l0,prepSearch:q5,searchByType:c0}});var f0=C((gOe,d0)=>{"use strict";var EOe=Ws(),V5=Su(),K5=oe(),Y5=(k(),P(q)),W5=Zp();d0.exports=z5;function z5(e,t){if(!K5.isEmpty(t)&&Y5.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=V5(e,"value");if(n)throw n;return W5.prepSearch(e,t,!0)}a(z5,"lmdbGetDataByValue")});var __=C((AOe,_0)=>{"use strict";var TOe=Ws(),Q5=Su(),j5=oe(),J5=(k(),P(q)),X5=Zp();_0.exports=Z5;async function Z5(e,t){if(!j5.isEmpty(t)&&J5.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=Q5(e,"value");if(n)throw n;return X5.prepSearch(e,t,!1)}a(Z5,"lmdbSearchByValue")});var m0=C((bOe,h0)=>{"use strict";var yOe=kt(),Hy=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}},ky=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},Fy=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};h0.exports={SearchByConditionsObject:Hy,SearchCondition:ky,SortAttribute:Fy}});var T0=C((IOe,S0)=>{"use strict";var NOe=m0().SearchByConditionsObject,e9=Ws(),t9=Su(),Gy=gu(),eE=kt(),{Resource:wOe}=(na(),P(LA)),g0=Zp(),r9=My(),n9=require("lodash"),{getSchemaPath:s9}=Et(),p0=ft(),{handleHDBError:i9,hdb_errors:o9}=me(),{HTTP_STATUS_CODES:a9}=o9,c9=1e8;S0.exports=l9;async function l9(e){let t=t9(e,"conditions");if(t)throw i9(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=s9(e.schema,e.table),n=await p0.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let u of e.conditions)p0.openDBI(n,u.search_attribute);let i=n9.sortBy(e.conditions,u=>{if(u.estimated_count===void 0){let f=u.search_type;f===eE.SEARCH_TYPES.EQUALS?u.estimated_count=Gy.count(n,u.search_attribute,u.search_value):f===eE.SEARCH_TYPES.CONTAINS||f===eE.SEARCH_TYPES.ENDS_WITH?u.estimated_count=1/0:u.estimated_count=c9}return u.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await E0(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(g0.filterByType),d=f.length,_=Gy.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=>r9.parseRow(h,_))}else{for(let d=1;d<i.length;d++){let _=i[d],h=await E0(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=Gy.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(l9,"lmdbSearchByConditions");async function E0(e,t,r,n){let s=new e9(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===eE.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,g0.searchByType(e,s,i,n).map(o=>o.value)}a(E0,"executeConditionSearch")});var h_=C((POe,A0)=>{"use strict";var u9=(k(),P(q)).OPERATIONS_ENUM,qy=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=u9.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};A0.exports=qy});var $y=C((LOe,C0)=>{"use strict";var O0=Ws(),N0=h_(),w0=__(),I0=l_(),Rn=(k(),P(q)),R0=oe(),y0=ft(),{getTransactionAuditStorePath:d9,getSchemaPath:f9}=Et(),b0=ee();C0.exports=_9;async function _9(e){try{if(R0.isEmpty(global.hdb_schema[e.schema])||R0.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await h9(e),await m9(e);let t=f9(e.schema,e.table);try{await y0.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")b0.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=d9(e.schema,e.table);await y0.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")b0.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(_9,"lmdbDropTable");async function h9(e){let t=new O0(Rn.SYSTEM_SCHEMA_NAME,Rn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Rn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Rn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await w0(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 N0(Rn.SYSTEM_SCHEMA_NAME,Rn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await I0(s)}a(h9,"deleteAttributesFromSystem");async function m9(e){let t=new O0(Rn.SYSTEM_SCHEMA_NAME,Rn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Rn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[Rn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,Rn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,Rn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await w0(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 N0(Rn.SYSTEM_SCHEMA_NAME,Rn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await I0(s)}catch(i){throw i}}a(m9,"dropTableFromSystem")});var D0=C((vOe,P0)=>{"use strict";var p9=require("fs-extra"),E9=Ws(),g9=Tu(),S9=h_(),T9=$y(),A9=l_(),R9=Uy(),y9=__(),Eo=(k(),P(q)),{getSchemaPath:b9}=Et(),{handleHDBError:O9,hdb_errors:N9}=me(),{HDB_ERROR_MSGS:w9,HTTP_STATUS_CODES:I9}=N9;P0.exports=C9;async function C9(e){let t;try{t=await P9(e.schema);let r=new E9(Eo.SYSTEM_SCHEMA_NAME,Eo.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Eo.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[Eo.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await y9(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await T9(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new S9(Eo.SYSTEM_SCHEMA_NAME,Eo.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await A9(s);let i=b9(t);await p9.remove(i)}catch(r){throw r}}a(C9,"lmdbDropSchema");async function P9(e){let t=new g9(Eo.SYSTEM_SCHEMA_NAME,Eo.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[Eo.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await R9(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw O9(new Error,w9.SCHEMA_NOT_FOUND(e),I9.NOT_FOUND,void 0,void 0,!0);return n}a(P9,"validateDropSchema")});var m_=C((xOe,L0)=>{"use strict";var Vy=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};L0.exports=Vy});var Yy=C((kOe,M0)=>{"use strict";var D9=require("fs-extra"),tE=ft(),{getTransactionAuditStorePath:L9}=Et(),Ky=kt(),HOe=m_();M0.exports=M9;async function M9(e){let t;try{let r=L9(e.schema,e.table);await D9.mkdirp(r),t=await tE.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{tE.createDBI(t,Ky.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),tE.createDBI(t,Ky.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),tE.createDBI(t,Ky.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(M9,"createTransactionsAuditEnvironment")});var x0=C((qOe,U0)=>{"use strict";var Wy=(k(),P(q)),v0=ft(),v9=Pc(),{getSystemSchemaPath:U9,getSchemaPath:x9}=Et(),GOe=co(),B9=Ip(),zy=wp(),H9=ee(),k9=Yy();U0.exports=F9;async function F9(e,t){let r=x9(t.schema,t.table),n=new zy(t.schema,t.table,Wy.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new zy(t.schema,t.table,Wy.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 v0.createEnvironment(r,t.table),e!==void 0){let o=await v0.openEnvironment(U9(),Wy.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await v9.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 Qy(n),await Qy(s),await Qy(i)}await k9(t)}catch(o){throw o}}a(F9,"lmdbCreateTable");async function Qy(e){try{await B9(e)}catch(t){H9.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(Qy,"createAttribute")});var H0=C((VOe,B0)=>{"use strict";var G9=Vf(),q9=gf(),$9=Wp(),p_=(k(),P(q)),V9=Pc().updateRecords,K9=ft(),{getSchemaPath:Y9}=Et(),W9=a_(),z9=ee();B0.exports=Q9;async function Q9(e){try{let{schema_table:t,attributes:r}=G9(e);q9(e,r,t.hash_attribute),e.schema!==p_.SYSTEM_SCHEMA_NAME&&(r.includes(p_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(p_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(p_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(p_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await $9(e.hdb_auth_header,t,r),s=Y9(e.schema,e.table),i=await K9.openEnvironment(s,e.table),o=await V9(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await W9(e,o)}catch(c){z9.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(Q9,"lmdbUpdateRecords")});var F0=C((YOe,k0)=>{"use strict";var j9=(k(),P(q)).OPERATIONS_ENUM,jy=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=j9.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};k0.exports=jy});var q0=C((QOe,G0)=>{"use strict";var zOe=F0(),J9=Vf(),X9=gf(),Z9=Wp(),E_=(k(),P(q)),e7=Pc().upsertRecords,t7=ft(),{getSchemaPath:r7}=Et(),n7=a_(),s7=ee(),{handleHDBError:i7,hdb_errors:o7}=me();G0.exports=a7;async function a7(e){let t;try{t=J9(e)}catch(l){throw i7(l,l.message,o7.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;X9(e,n,r.hash_attribute),e.schema!==E_.SYSTEM_SCHEMA_NAME&&(n.includes(E_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(E_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(E_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(E_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await Z9(e.hdb_auth_header,r,n),i=r7(e.schema,e.table),o=await t7.openEnvironment(i,e.table),c=await e7(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await n7(e,c)}catch(l){s7.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 V0=C((JOe,$0)=>{"use strict";var Jy=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};$0.exports=Jy});var Y0=C((ZOe,K0)=>{"use strict";var Xy=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}};K0.exports=Xy});var Q0=C((rNe,z0)=>{"use strict";var Zy=ft(),{getTransactionAuditStorePath:c7}=Et(),tNe=V0(),g_=kt(),l7=oe(),W0=Y0(),u7=require("util").promisify,d7=u7(setTimeout),f7=1e4,_7=100;z0.exports=h7;async function h7(e){let t=c7(e.schema,e.table),r=await Zy.openEnvironment(t,e.table,!0),n=Zy.listDBIs(r);Zy.initializeDBIs(r,g_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new W0;do s=await m7(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 d7(_7);while(s.transactions_deleted>0);return i}a(h7,"deleteAuditLogsBefore");async function m7(e,t){let r=new W0;try{let n=e.dbis[g_.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[g_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];l7.isEmpty(c)||(s=e.dbis[g_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[g_.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>f7)break}return await s,r}catch(n){throw n}}a(m7,"deleteTransactions")});var J0=C((sNe,j0)=>{"use strict";var eb=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};j0.exports=eb});var Z0=C((aNe,X0)=>{"use strict";var p7=Ws(),E7=h_(),oNe=J0(),Pi=(k(),P(q)),g7=oe(),tb=ft(),S7=co(),T7=__(),A7=l_(),{getSchemaPath:R7}=Et();X0.exports=y7;async function y7(e,t=!0){let r;e.schema===Pi.SYSTEM_SCHEMA_NAME?r=S7[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await O7(e),s=R7(e.schema,e.table),i=await tb.openEnvironment(s,e.table);return t===!0&&await b7(e,i,r.hash_attribute),tb.dropDBI(i,e.attribute),n}a(y7,"lmdbDropAttribute");async function b7(e,t,r){let n=tb.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(b7,"removeAttributeFromAllObjects");async function O7(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 T7(t)).filter(o=>o[Pi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(g7.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 E7(Pi.SYSTEM_SCHEMA_NAME,Pi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return A7(i)}a(O7,"dropAttributeFromSystem")});var ix=C((uNe,sx)=>{"use strict";var rb=ft(),Au=kt(),lNe=un(),nb=(k(),P(q)),ex=oe(),{getTransactionAuditStorePath:N7}=Et(),w7=gu(),rE=mu(),I7=ee();sx.exports=C7;async function C7(e){let t=N7(e.schema,e.table),r=await rb.openEnvironment(t,e.table,!0),n=rb.listDBIs(r);rb.initializeDBIs(r,Au.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case nb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return tx(r,e.search_values);case nb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,D7(r,e.search_values,s);case nb.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return P7(r,e.search_values);default:return tx(r)}}a(C7,"readAuditLog");function tx(e,t=[0,Date.now()]){ex.isEmpty(t[0])&&(t[0]=0),ex.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[Au.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 rE,s))}a(tx,"searchTransactionsByTimestamp");function P7(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[Au.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,nx(e,i))}return Object.fromEntries(r)}a(P7,"searchTransactionsByUsername");function D7(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let u=t[c],f=w7.equals(e,Au.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Au.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=nx(e,s),o=new Map;for(let c=0;c<i.length;c++){let l=i[c],u=l.timestamp,f=n.get(u);rx(l,"records",r,f,o),rx(l,"original_records",r,f,o)}return Object.fromEntries(o)}a(D7,"searchTransactionsByHashValues");function rx(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 rE(e.operation,e.user_name,i,void 0);d[t]=[c],u.push(d)}}else{let u=new rE(e.operation,e.user_name,i,void 0);u[t]=[c],s.set(l,[u])}}}a(rx,"loopRecords");function nx(e,t){let r=[];try{let n=e.dbis[Au.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 rE,i);r.push(o)}}catch(i){I7.warn(i)}return r}catch(n){throw n}}a(nx,"batchSearchTransactions")});var ax=C((hNe,ox)=>{"use strict";var{getSchemaPath:fNe}=Et(),_Ne=ft(),{database:L7}=(xe(),P(at));ox.exports={writeTransaction:M7};async function M7(e,t,r){return L7({database:e,table:t}).transaction(r)}a(M7,"writeTransaction")});var dx=C((pNe,ux)=>{"use strict";var{getSchemaPath:cx}=Et(),lx=ft();ux.exports={flush:v7,resetReadTxn:U7};async function v7(e,t){return(await lx.openEnvironment(cx(e,t),t.toString())).flushed}a(v7,"flush");async function U7(e,t){try{(await lx.openEnvironment(cx(e,t),t.toString())).resetReadTxn()}catch{}}a(U7,"resetReadTxn")});var mx=C((gNe,hx)=>{"use strict";var{Readable:x7}=require("stream"),{getDatabases:B7}=(xe(),P(at)),{readSync:H7,openSync:k7,createReadStream:fx}=require("fs"),{open:F7}=require("lmdb"),_x=kf(),G7=Ff(),{AUDIT_STORE_OPTIONS:q7}=(Ti(),P(px)),{INTERNAL_DBIS_NAME:$7,AUDIT_STORE_NAME:V7}=kt();hx.exports=Y7;var sb=32768,K7=100;async function Y7(e){let t=e.database||e.schema||"data",r=B7()[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=F7({noSync:!0,maxDbs:G7.MAX_DBS}),_,h=d.openDB($7,new _x(!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++%K7===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 _x(!v,v);await g(E,H)}e.include_audit&&await g(V7,{...q7}),await _;let R=fx(d.path);return R.headers=l(),R.on("close",()=>{m.done(),d.close()}),R}let o=r[Object.keys(r)[0]].primaryStore,c=k7(o.path);return o.transaction(()=>{let u=Buffer.alloc(sb);H7(c,u,0,sb),o.resetReadTxn();let f=o.useReadTransaction();f.renew();let d=fx(null,{fd:c,start:sb}),_=new x7.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(Y7,"getBackup")});var Sx=C((TNe,gx)=>{"use strict";var W7=ee(),{handleHDBError:z7}=me(),Q7=PL(),j7=Ip(),J7=Iy(),X7=DU(),Z7=l_(),eee=Uy(),tee=n0(),ree=f0(),nee=__(),see=T0(),iee=D0(),oee=x0(),aee=H0(),cee=q0(),lee=Q0(),uee=$y(),dee=Z0(),fee=ix(),_ee=ax(),Ex=dx(),hee=mx(),ib=class extends Q7{static{a(this,"LMDBBridge")}async searchByConditions(t){return see(t)}async getDataByHash(t){return await eee(t)}async searchByHash(t){return await tee(t)}async getDataByValue(t,r){return await ree(t,r)}async searchByValue(t){return await nee(t)}async createSchema(t){return await X7(t)}async dropSchema(t){return await iee(t)}async createTable(t,r){return await oee(t,r)}async dropTable(t){return await uee(t)}async createAttribute(t){return await j7(t)}async createRecords(t){return await J7(t)}async updateRecords(t){return await aee(t)}async upsertRecords(t){try{return await cee(t)}catch(r){throw z7(r,null,null,W7.ERR,r)}}async deleteRecords(t){return await Z7(t)}async dropAttribute(t){return await dee(t)}async deleteAuditLogsBefore(t){return await lee(t)}async readAuditLog(t){return await fee(t)}writeTransaction(t,r,n){return _ee.writeTransaction(t,r,n)}flush(t,r){return Ex.flush(t,r)}resetReadTxn(t,r){return Ex.resetReadTxn(t,r)}getBackup(t){return hee(t)}};gx.exports=ib});var ab={};Ue(ab,{add:()=>nE,applyReverse:()=>Tx,getRecordAtTime:()=>ob,rebuildUpdateBefore:()=>sE});function nE(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 sE(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,nE(n,s,i)}else r&&(n||(n={}),n[s]=i)}else n||(n={}),n[s]=e[s];return n}function Tx(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=mee[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=Ax}}function ob(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":Tx(s,u.getValue(r));break;case"delete":s=null}i=u.previousLocalTime}let o={},c=0;for(let l in s)s[l]===Ax&&(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 mee,Ax,iE=Re(()=>{Ti();a(nE,"add");nE.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)};mee={add:nE};a(sE,"rebuildUpdateBefore");a(Tx,"applyReverse");Ax={};a(ob,"getRecordAtTime")});function yn(e){let t=e.getChanges();return t||(t=Object.create(null),e._setChanges(t)),t}function lE(e,t){let r=e.prototype,n={},s=t.attributes||t.properties||[];for(let c of s){let l=c.name,u,f;if(c.resolve)f={get(){return c.resolve(this,this.getContext?.())},set(d){return c.set(this,d)},configurable:!0};else{switch(c.type){case"String":u=a(function(d){if(!(typeof d=="string"||d==null&&c.nullable!==!1))throw new zn.ClientError(`${l} must be a string, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"ID":u=a(function(d){if(!(typeof d=="string"||d?.length>0&&d.every?.(_=>typeof _=="string")||d==null&&c.nullable!==!1))throw new zn.ClientError(`${l} must be a string, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"Float":case"Number":u=a(function(d){let _=d?.__op__?d.value:d;if(!(typeof _=="number"||d==null&&c.nullable!==!1))throw new zn.ClientError(`${l} must be a number, attempt to assign ${_}`);yn(this)[l]=d},"set");break;case"Int":u=a(function(d){let _=d?.__op__?d.value:d;if(!(_>>0===_||d==null&&c.nullable!==!1))if(typeof _=="number"&&Math.abs((_>>0)-_)<=1)_=Math.round(_),d?.__op__?d.value=_:d=_;else throw new zn.ClientError(`${l} must be an integer between -2147483648 and 2147483647, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"Long":u=a(function(d){let _=d?.__op__?d.value:d;if(!(Math.round(_)===d&&Math.abs(_)<=9007199254740992||d==null&&c.nullable!==!1))if(typeof _=="number"&&Math.abs(_)<=9007199254740992)_=Math.round(_),d?.__op__?d.value=_:d=_;else throw new zn.ClientError(`${l} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"BigInt":u=a(function(d){let _=d?.__op__?d.value:d;if(!(typeof _=="bigint"||d==null&&c.nullable!==!1))if(typeof _=="string"||typeof _=="number")_=BigInt(_),d?.__op__?d.value=_:d=_;else throw new zn.ClientError(`${l} must be a number, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"Boolean":u=a(function(d){if(!(typeof d=="boolean"||d==null&&c.nullable!==!1))throw new zn.ClientError(`${l} must be a boolean, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"Date":u=a(function(d){if(!(d instanceof Date||d==null&&c.nullable!==!1))if(typeof d=="string"||typeof d=="number")d=new Date(d);else throw new zn.ClientError(`${l} must be a Date, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"Bytes":u=a(function(d){if(!(d instanceof Uint8Array||d==null&&c.nullable!==!1))throw new zn.ClientError(`${l} must be a Buffer or Uint8Array, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"Blob":u=a(function(d){if(!(d instanceof Si||d==null&&c.nullable!==!1))throw new zn.ClientError(`${l} must be a Blob, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"Any":case void 0:u=a(function(d){yn(this)[l]=d},"set");break;default:u=a(function(d){if(!(typeof d=="object"||d==null&&c.nullable!==!1))throw new zn.ClientError(`${l} must be an object, attempt to assign ${d}`);yn(this)[l]=d},"set")}f={get(){let d=this.getChanges?.();if(d&&l in d){let h=d[l];if(h?.__op__){let m=this.getRecord()?.[l];return h.update(m)}return h}let _=this.getRecord()?.[l];if(_&&typeof _=="object"){let h=cb(_,c);if(h)return d||this._setChanges(d=Object.create(null)),d[l]=h}return _},set:u,enumerable:!0,configurable:!0}}f.get.isAttribute=!0,n[l]=f,(!(l in r)||Object.getOwnPropertyDescriptor(r,l)?.get?.isAttribute)&&Object.defineProperty(r,l,f)}i("getProperty",function(c){let l=n[c];if(l)return l.get.call(this);let u=this.getChanges();return u?.[c]!==void 0?u[c]:this.getRecord()?.[c]}),i("set",function(c,l){let u=n[c];if(u)return u.set.call(this,l);if(t.sealed)throw new zn.ClientError("Can not add a property to a sealed table schema");yn(this)[c]=l}),i("deleteProperty",function(c){yn(this)[c]=void 0}),i("toJSON",function(){let c=this.getChanges?.(),l;for(let f in c){l||(l={...this.getRecord()});let d=c[f];if(d?.__op__){let _=l[f];d=d.update(_)}l[f]=d}return Object.keys(this).length>0&&(l||(l={...this.getRecord()}),Object.assign(l,this)),l||this.getRecord()}),r.get||i("get",r.getProperty),r.delete||i("delete",r.deleteProperty),r.then||i("then",null);function i(c,l){Object.defineProperty(r,c,{value:l,configurable:!0})}a(i,"setMethod");let o=r;do{let c=Object.getPrototypeOf(o);if(c===Object.prototype){Object.setPrototypeOf(o,yx);break}o=c}while(o&&o!==yx)}function cb(e,t){let r;switch(e.constructor){case Object:return t?(r=t.TrackedObject,r||(t.TrackedObject=r=class extends S_{static{a(this,"TrackedObject")}},lE(r,t)),new r(e)):new S_(e);case Array:let n=new aE(e.length,e);for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=cb(o,t?.elements)),n[s]=o}return n;default:return e}}function uE(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=uE(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 Ru(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=Ru(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=ab[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=Ru(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 oE(e){let t=e.getRecord?.();if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[Vc]||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(oE(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(oE(s))return!0}else return!0}else return!0}}return!1}var zn,Rx,yx,S_,pee,Vc,aE,cE,lb=Re(()=>{zn=M(me());iE();pn();a(yn,"getChanges");a(lE,"assignTrackedAccessors");Rx=Object.prototype,yx=new Proxy({},{get(e,t,r){if(typeof t=="string"){if(t==="then"||t==="getRecord"||t==="getChanges")return;if(Rx[t])return Rx[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=cb(s);if(i)return n||(n=Object.create(null),r._setChanges(n)),n[t]=i,i}return s}}});a(cb,"trackObject");S_=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}};lE(S_,{});a(uE,"collapseData");pee=Object.prototype.hasOwnProperty;a(Ru,"updateAndFreeze");a(oE,"hasChanges");Vc=Symbol.for("has-array-changes"),aE=class extends Array{static{a(this,"TrackedArray")}#e;[Vc];constructor(t,r){super(t),this.#e=r}getRecord(){return this.#e}splice(...t){return this[Vc]=!0,super.splice(...t)}push(...t){return this[Vc]=!0,super.push(...t)}pop(){return this[Vc]=!0,super.pop()}unshift(...t){return this[Vc]=!0,super.unshift(...t)}shift(){return this[Vc]=!0,super.shift()}};aE.prototype.constructor=Array;cE=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var Dx={};Ue(Dx,{ResourceBridge:()=>fb});function _b({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 Ox(e,t){let r=Di(e),n=_b(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;wt(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&&uE(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||gee,r=Xe()[t];if(!r)throw(0,zs.handleHDBError)(new Error,Eee.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function Nx(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*wx(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 Ix,dE,zs,Cx,ub,db,Px,Eee,gee,See,Tee,bx,fb,Lx=Re(()=>{"use strict";Ix=M(Sx()),dE=M(Su()),zs=M(me());xe();Cx=M(Vf());k();ub=M(mo()),db=M(Ys()),Px=M(oe());hc();lb();({HDB_ERROR_MSGS:Eee}=zs.hdb_errors),gee="data",See=1e4,Tee=10,fb=class extends Ix.default{static{a(this,"ResourceBridge")}constructor(t){super(t),bx=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,dE.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:_b(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}]}dt({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 yu({database:t.schema,table:null}),ub.signalSchemaChange(new db.SchemaEventMsg(process.pid,Yt.CREATE_SCHEMA,t.schema))}async dropSchema(t){await hb(t.schema),ub.signalSchemaChange(new db.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,bx.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,Cx.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),wt(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}_&&(_=uE(_));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),wt(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 Nx(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:Lm.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,Px.async_set_timeout)(Tee),l=[],s=!0},"chunkDelete");for await(let f of n)l.push(f[r.primaryKey]),c++,c%See===0&&await u();return l.length>0&&await u(),s?Nx(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,dE.default)(t,"hashes");if(r)throw r;return Ox(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of Ox(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&dA[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,dE.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===Lm.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:_b(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 Mm.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 Mm.USERNAME:let s=t.search_values;for await(let i of wx(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return wx(r,t.search_values?.[0],t.search_values?.[1],t.limit)}}};a(_b,"getSelect");a(Ox,"getRecords");a(Di,"getTable");a(Nx,"createDeleteResponse");a(wx,"groupRecordsInHistory")});var qn=C((MNe,Mx)=>{"use strict";var{ResourceBridge:Aee}=(Lx(),P(Dx)),Ree=ce();Ree.initSync();var fE;function yee(){return fE||(fE=new Aee,fE)}a(yee,"getBridge");Mx.exports=yee()});var An=C((UNe,Bx)=>{"use strict";var hE=rR(),xr=oe(),bee=require("util"),mE=qn(),Oee=$s(),vx=ee(),{handleHDBError:Kc,hdb_errors:Nee}=me(),{HTTP_STATUS_CODES:Yc}=Nee,wee=bee.promisify(Oee.getTableSchema),Iee="updated",Ux="inserted",xx="upserted";Bx.exports={insert:Pee,update:Dee,upsert:Lee,validation:Cee,flush:Mee};async function Cee(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 wee(e.schema,e.table),r=hE(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 vx.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 vx.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(Cee,"validation");async function Pee(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=hE(e);if(t)throw Kc(new Error,t.message,Yc.BAD_REQUEST);xr.transformReq(e);let r=xr.checkSchemaTableExist(e.schema,e.table);if(r)throw Kc(new Error,r,Yc.BAD_REQUEST);let n=await mE.createRecords(e);return _E(Ux,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(Pee,"insertData");async function Dee(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=hE(e);if(t)throw Kc(new Error,t.message,Yc.BAD_REQUEST);xr.transformReq(e);let r=xr.checkSchemaTableExist(e.schema,e.table);if(r)throw Kc(new Error,r,Yc.BAD_REQUEST);let n=await mE.updateRecords(e);return xr.isEmpty(n.existing_rows)?_E(Iee,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):_E(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(Dee,"updateData");async function Lee(e){if(e.operation!=="upsert")throw Kc(new Error,"invalid operation, must be upsert",Yc.INTERNAL_SERVER_ERROR);let t=hE(e);if(t)throw Kc(new Error,t.message,Yc.BAD_REQUEST);xr.transformReq(e);let r=xr.checkSchemaTableExist(e.schema,e.table);if(r)throw Kc(new Error,r,Yc.BAD_REQUEST);let n=await mE.upsertRecords(e);return _E(xx,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(Lee,"upsertData");function _E(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===Ux?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===xx?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(_E,"returnObject");function Mee(e){return xr.transformReq(e),mE.flush(e.schema,e.table)}a(Mee,"flush")});var $x=C((BNe,qx)=>{var bu=require("validate.js"),kx=it(),Ou=(k(),P(q)),{handleHDBError:vee,hdb_errors:Uee}=me(),{HDB_ERROR_MSGS:Qt,HTTP_STATUS_CODES:xee}=Uee,mb=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),Bee={STRUCTURE_USER:"structure_user"},Hx=Object.values(Ou.ROLE_TYPES_ENUM),Hee="attribute_permissions",kee="attribute_name",{PERMS_CRUD_ENUM:Nu}=Ou,Fee=[Hee,...Object.values(Nu)],Fx=[Nu.READ,Nu.INSERT,Nu.UPDATE],Gee=[kee,...Fx];function qee(e){let t=mb();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,Gx(e,t)}a(qee,"addRoleValidation");function $ee(e){let t=mb();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,Gx(e,t)}a($ee,"alterRoleValidation");function Vee(e){let t=mb();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,kx.validateObject(e,t)}a(Vee,"dropRoleValidation");var Kee=["operation","role","id","permission","hdb_user","access"];function Gx(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)Kee.includes(n[o])||s.push(n[o]);s.length>0&&nr(Qt.INVALID_ROLE_JSON_KEYS(s),r);let i=kx.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{nr(o,r)}),e.permission){let o=Yee(e);o&&nr(o,r),Hx.forEach(c=>{e.permission[c]&&!bu.isBoolean(e.permission[c])&&nr(Qt.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(Hx.indexOf(o)<0){if(o===Bee.STRUCTURE_USER){let l=e.permission[o];if(typeof l=="boolean")continue;if(Array.isArray(l)){for(let u=0,f=l.length;u<f;u++){let d=l[u];global.hdb_schema[d]||nr(Qt.SCHEMA_NOT_FOUND(d),r)}continue}nr(Qt.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){nr(Qt.SCHEMA_NOT_FOUND(o),r);continue}if(c.tables)for(let l in c.tables){let u=c.tables[l];if(!l||!global.hdb_schema[o][l]){nr(Qt.TABLE_NOT_FOUND(o,l),r);continue}if(Object.keys(u).forEach(f=>{Fee.includes(f)||nr(Qt.INVALID_PERM_KEY(f),r,o,l)}),Object.values(Nu).forEach(f=>{bu.isDefined(u[f])?bu.isBoolean(u[f])||nr(Qt.TABLE_PERM_NOT_BOOLEAN(f),r,o,l):nr(Qt.TABLE_PERM_MISSING(f),r,o,l)}),u.attribute_permissions===void 0){nr(Qt.ATTR_PERMS_ARRAY_MISSING,r,o,l);continue}else if(!(Array.isArray(u.attribute_permissions)||u.attribute_permissions===null)){nr(Qt.ATTR_PERMS_NOT_ARRAY,r,o,l);continue}if(u.attribute_permissions){let f=global.hdb_schema[o][l].attributes.map(({attribute:_})=>_),d={read:!1,insert:!1,update:!1};for(let _ in u.attribute_permissions){let h=u.attribute_permissions[_];if(Object.keys(h).forEach(S=>{!Gee.includes(S)&&S!==Nu.DELETE&&nr(Qt.INVALID_ATTR_PERM_KEY(S),r,o,l)}),!bu.isDefined(h.attribute_name)){nr(Qt.ATTR_PERM_MISSING_NAME,r,o,l);continue}let m=h.attribute_name;if(!f.includes(m)){nr(Qt.INVALID_ATTRIBUTE_IN_PERMS(m),r,o,l);continue}Fx.forEach(S=>{bu.isDefined(h[S])?bu.isBoolean(h[S])||nr(Qt.ATTR_PERM_NOT_BOOLEAN(S,m),r,o,l):nr(Qt.ATTR_PERM_MISSING(S,m),r,o,l)}),!d.read&&h.read===!0&&(d.read=!0),!d.insert&&h.insert===!0&&(d.insert=!0),!d.update&&h.update===!0&&(d.update=!0)}if(u.read===!1&&d.read===!0||u.insert===!1&&d.insert===!0||u.update===!1&&d.update===!0){let _=`${o}.${l}`;nr(Qt.MISMATCHED_TABLE_ATTR_PERMS(_),r,o,l)}}}}return Wee(r)}a(Gx,"customValidate");qx.exports={addRoleValidation:qee,alterRoleValidation:$ee,dropRoleValidation:Vee};function Yee(e){let{operation:t,permission:r}=e;if(t===Ou.OPERATIONS_ENUM.ADD_ROLE||t===Ou.OPERATIONS_ENUM.ALTER_ROLE){let n=r.super_user===!0,s=r.cluster_user===!0;if(Object.keys(r).length>1&&(n||s)){if(s&&n)return Qt.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?Ou.ROLE_TYPES_ENUM.SUPER_USER:Ou.ROLE_TYPES_ENUM.CLUSTER_USER;return Qt.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(Yee,"validateNoSUPerms");function Wee(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:Qt.ROLE_PERMS_ERROR,...e};return vee(new Error,n,xee.BAD_REQUEST)}else return null}a(Wee,"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 A_=C((FNe,Wx)=>{"use strict";var Vx=An(),Kx=Yr(),zee=xc(),Eb=$x(),gb=mo(),kNe=require("uuid").v4,Qee=require("util"),pE=(k(),P(q)),jee=oe(),Sb=Kx.searchByValue,Jee=Kx.searchByHash,Xee=Qee.promisify(zee.delete),Zee=Ws(),ete=Tu(),{hdb_errors:tte,handleHDBError:Wc}=me(),{HDB_ERROR_MSGS:Yx,HTTP_STATUS_CODES:T_}=tte,{UserEventMsg:Tb}=Ys();Wx.exports={addRole:rte,alterRole:nte,dropRole:ste,listRoles:ite};function pb(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(pb,"scrubRoleDetails");async function rte(e){let t=Eb.addRoleValidation(e);if(t)throw t;e=pb(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 Sb(r)||[])}catch(i){throw Wc(i)}if(n&&n.length>0)throw Wc(new Error,Yx.ROLE_ALREADY_EXISTS(e.role),T_.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 Vx.insert(s),gb.signalUserChange(new Tb(process.pid)),e=pb(e),e}a(rte,"addRole");async function nte(e){let t=Eb.alterRoleValidation(e);if(t)throw t;e=pb(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await Vx.update(r)}catch(s){throw Wc(s)}if(n&&n?.message==="updated 0 of 1 records")throw Wc(new Error,"Invalid role id",T_.BAD_REQUEST,void 0,void 0,!0);return await gb.signalUserChange(new Tb(process.pid)),e}a(nte,"alterRole");async function ste(e){let t=Eb.dropRoleValidation(e);if(t)throw Wc(new Error,t,T_.BAD_REQUEST,void 0,void 0,!0);let r=new ete(pE.SYSTEM_SCHEMA_NAME,pE.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await Jee(r));if(n.length===0)throw Wc(new Error,Yx.ROLE_NOT_FOUND,T_.NOT_FOUND,void 0,void 0,!0);let s=new Zee(pE.SYSTEM_SCHEMA_NAME,pE.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await Sb(s)),o=!1;if(jee.isEmptyOrZeroLength(i)===!1){for(let l=0;l<i.length;l++)if(i[l].active===!0){o=!0;break}}if(o===!0)throw Wc(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,T_.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await Xee(c),gb.signalUserChange(new Tb(process.pid)),`${n[0].role} successfully deleted`}a(ste,"dropRole");async function ite(){return Sb({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(ite,"listRoles")});var Ab={};Ue(Ab,{start:()=>jx,startOnMainThread:()=>cte});function jx({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r){let n=(0,zx.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(ote.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,Qx.isEqual)(i,e)?void 0:(e.id=r.id,(0,EE.alterRole)(e))}return(0,EE.addRole)(e)}var EE,zx,Qx,ote,cte,Jx=Re(()=>{xe();EE=M(A_()),zx=require("yaml"),Qx=require("lodash"),ote=["super_user","cluster_user","structure_user"];a(jx,"start");a(ate,"ensureRole");cte=jx});async function gE(e){let t=(0,eB.pathToFileURL)(e).toString();if(lte)return R_||(R_=ute(fte)),(await(await R_).import(t)).namespace;try{return await import(t)}catch(r){try{(await import("internal/util")).default.decorateErrorStack(r)}catch{}throw r}}async function ute(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),R_=new Compartment({console,Math,Date,fetch:dte,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,Zx.extname)(r)||(r+=".js"),r)},importHook:a(async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){Object.assign(s,{Resource:Vr,tables:Qn,databases:We})}};let n=await(0,Xx.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)},"importHook")}),R_}function dte(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 fte(){return{Resource:Vr,tables:Qn}}var Xx,Zx,eB,lte,R_,Rb=Re(()=>{na();xe();Xx=require("fs/promises"),Zx=require("path"),eB=require("url"),lte=!1;a(gE,"secureImport");a(ute,"getCompartment");a(dte,"secureOnlyFetch");a(fte,"getGlobalVars")});var bb={};Ue(bb,{handleFile:()=>_te});async function _te(e,t,r,n){let s=new Map,i=await gE(r);c(i.default)&&n.set((0,yb.dirname)(t),i.default),o(i,(0,yb.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 yb,tB=Re(()=>{Rb();yb=require("path");a(_te,"handleFile")});var Nb={};Ue(Nb,{start:()=>hte});function hte({resources:e}){e.set("login",Ob),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var Ob,rB=Re(()=>{na();a(hte,"start");Ob=class extends Vr{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 I_={};Ue(I_,{addAnalyticsListener:()=>w_,calculateCPUUtilization:()=>AB,diffResourceUsage:()=>RB,recordAction:()=>Dt,recordActionBinary:()=>jn,setAnalyticsEnabled:()=>mte});function mte(e){pB=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 Ete(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},TE.set(e,o)}function Dt(e,t,r,n,s){if(!pB)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=TE.get(i);o?pte(e,o):Ete(i,e,t,r,n,s),SE||gte()}function jn(e,t,r,n,s){Dt(!!e,t,r,n,s)}function w_(e){SB.push(e)}function gte(){SE=performance.now(),setTimeout(async()=>{let e=performance.now()-SE;SE=0;let t=[],r={time:Date.now(),period:e,threadId:zc.threadId,metrics:t};for(let[s,i]of TE){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 TB){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 yB()}let n=process.memoryUsage();t.push({metric:"memory",threadId:zc.threadId,byThread:!0,...n});for(let s of SB)s(t);TE=new Map,zc.parentPort?zc.parentPort.postMessage({type:gB,report:r}):NB({report:r})},EB).unref()}function AE(e,t,r){let n={id:(0,O_.getNextMonotonicTime)(),metric:t,...r};e.primaryStore.put(n.id,n,{append:!0}).then(s=>{s||e.primaryStore.put(n.id,n)})}function AB(e,t){let r=e.userCPUTime+e.systemCPUTime;return Math.round(r/t*100)/100}function RB(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 Ste(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};AE(e,"table-size",l),Qc.trace?.(`table ${o} size metric: ${JSON.stringify(l)}`),n+=c}return n}function nB(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s?.getAuditSize();if(!i)return;let o=mB.default.statSync(s.primaryStore.env.path).size,c=Ste(e,r,n),l=o-c,u={database:r,size:o,used:c,free:l,audit:i};AE(e,"database-size",u),Qc.trace?.(`database ${r} size metric: ${JSON.stringify(u)}`)}catch(s){Qc.warn?.("Error getting DB size metrics",s)}}function sB(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};AE(e,"storage-volume",o),Qc.trace?.(`db ${r} storage volume metrics: ${JSON.stringify(o)}`)}catch(s){Qc.warn?.("Error getting DB volume metrics",s)}}async function Tte(e,t=6e4){let r=Ib(),n=bB(),s=new Promise(E=>{let T=performance.now();setImmediate(()=>{let N=performance.now();N-T>5e3&&Qc.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&&Qc.warn?.("Unusually high task queue latency on the main thread of "+Math.round(N-T)+"ms"),E(N-T)})}),i;for(let E of n.primaryStore.getRange({start:1/0,end:!1,reverse:!0}))if(E.value?.time){i=E.value.time;break}if(Date.now()-t<i)return;let o,c=new Map,l=new Map,u=[],f;for(let{key:E,value:T}of r.primaryStore.getRange({start:i||!1,exclusiveStart:!0,end:1/0})){if(!T)continue;if(o){if(E>o+t)break}else o=E;f=E;let{metrics:N,threadId:v}=T;for(let H of N||[]){let{path:X,method:W,type:$,metric:ie,count:z,total:de,distribution:le,threads:Z,...Ae}=H;z||(z=1);let pe=ie+(X?"-"+X:"");W!==void 0&&(pe+="-"+W),$!==void 0&&(pe+="-"+$);let ye=c.get(pe);if(ye){if(ye.threads){let ut=ye.threads[v];if(ut)ye=ut;else{ye.threads[v]={...Ae};continue}}ye.count||(ye.count=1);let xt=ye.count;for(let ut in Ae){let Ln=Ae[ut];typeof Ln=="number"&&(ye[ut]=(ye[ut]*xt+Ln*z)/(xt+z))}ye.count+=z,de>=0&&(ye.total+=de,ye.ratio=ye.total/ye.count)}else ye={period:t,...H},delete ye.distribution,c.set(pe,ye),ye.byThread&&(ye.threads=[],ye.threads[v]={...Ae},u.push(ye));if(le){le=le.map(ut=>typeof ut=="number"?{value:ut,count:1}:ut);let xt=l.get(pe);xt?xt.push(...le):l.set(pe,le)}}await yB()}for(let E of u){let{path:T,method:N,type:v,metric:H,count:X,total:W,distribution:$,threads:ie,...z}=E;ie=ie.filter(de=>de);for(let de in z){if(typeof E[de]!="number")continue;let le=0;for(let Z of ie){let Ae=Z[de];typeof Ae=="number"&&(le+=Ae)}E[de]=le}E.count=ie.length,delete E.threads,delete E.byThread}for(let[E,T]of l){let N=c.get(E);T.sort((ut,Ln)=>ut.value>Ln.value?1:-1);let v=N.count-1,H=[],X=0,W=0,$;for(let ut of TB){let Ln=v*ut;for(;X<Ln;)$=T[W++],X+=$.count,W===1&&X--;let an=T[W>1?W-2:0];$||($=T[0]),H.push($.value-($.value-an.value)*(X-Ln)/$.count)}let[ie,z,de,le,Z,Ae,pe,ye,xt]=H;Object.assign(N,{p1:ie,p10:z,p25:de,median:le,p75:Z,p90:Ae,p95:pe,p99:ye,p999:xt})}let d;for(let[E,T]of c)T.id=(0,O_.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,O_.getNextMonotonicTime)(),T={id:E,metric:"main-thread-utilization",idle:h-iB,active:m-oB,taskQueueLatency:await s,time:_,...process.memoryUsage()};n.primaryStore.put(E,T,{append:!0}).then(N=>{N||n.primaryStore.put(E,T)})}iB=h,oB=m;let S=process.resourceUsage(),g=RB(y_,S);g.time=_,g.period=y_.time?_-y_.time:t,g.cpuUtilization=AB(y_,g.period),AE(n,"resource-usage",g),y_=g;let R=Xe();nB(n,R),nB(n,{system:R.system}),sB(n,R),sB(n,{system:R.system})}async function aB(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function Ib(){return cB||(cB=dt({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function bB(){return lB||(lB=dt({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function yte(){OB=!0;let e=(0,N_.get)(B.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await Tte(EB,e),await aB(Ib(),Ate),await aB(bB(),Rte)},Math.min(e/2,2147483647)).unref()}function NB(e,t){let r=e.report;r.threadId=t?.threadId||zc.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(uB+=n.mean*n.count);r.totalBytesProcessed=uB,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(dB.get(t))}),dB.set(t,t.performance.eventLoopUtilization())),r.id=(0,O_.getNextMonotonicTime)(),Ib().primaryStore.put(r.id,r),OB||yte(),bte&&(wB=Nte(r))}async function Nte(e){if(await wB,!pa){let r=(0,b_.dirname)((0,_B.getLogFilePath)());try{pa=await(0,wb.open)((0,b_.join)(r,"analytics.log"),"r+")}catch{pa=await(0,wb.open)((0,b_.join)(r,"analytics.log"),"w+")}}let t=(await pa.stat()).size;if(t>Ote){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)+`