harperdb 4.5.39 → 4.5.40
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/bin/harperdb.js +1 -1
- package/bin/lite.js +1 -1
- package/launchServiceScripts/launchNatsIngestService.js +1 -1
- package/launchServiceScripts/launchNatsReplyService.js +1 -1
- package/launchServiceScripts/launchUpdateNodes4-0-0.js +1 -1
- package/npm-shrinkwrap.json +284 -282
- package/package.json +2 -2
- package/server/jobs/jobProcess.js +1 -1
- package/server/threads/threadServer.js +1 -1
- package/studio/build-local/asset-manifest.json +2 -2
- package/studio/build-local/index.html +1 -1
- package/studio/build-local/static/js/{main.0a0bf640.js → main.e3c003ec.js} +2 -2
- package/utility/scripts/restartHdb.js +1 -1
- /package/studio/build-local/static/js/{main.0a0bf640.js.LICENSE.txt → main.e3c003ec.js.LICENSE.txt} +0 -0
|
@@ -16,7 +16,7 @@ Caused by:`));else if(typeof u=="object")try{n+=JSON.stringify(u)}catch{n+="Obje
|
|
|
16
16
|
|
|
17
17
|
`:`data: ${e}
|
|
18
18
|
|
|
19
|
-
`},"serialize"),compressible:!1,q:.8});Wr.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()}});$L={type:"application/json",serializeStream:Lf,serialize:Bf,deserialize:m3,q:.5};Wr.set("*/*",$L);Wr.set("",$L);a(m3,"tryJSONParse");a(kf,"registerContentHandlers");p3=require("fastify-plugin"),E3=p3(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:o,type:c}=yp(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(yp,"findBestSerializer");HL=_R.default.get(x.HTTP_COMPRESSIONTHRESHOLD);a(Ff,"serialize");a(ua,"serializeMessage");a(dR,"asyncSerialization");a(fR,"hasAsyncSerialization");a(g3,"streamToBuffer");S3=["ascii","utf8","utf-8","utf16le","utf-16le","ucs2","ucs-2","base64","base64url","latin1","binary","hex"];a(T3,"isBufferEncoding");a(A3,"parseContentType");a(lo,"getDeserializer");a(R3,"deserializerUnknownType");a(y3,"transformIterable");a(Rp,"toCsvStream")});var gR={};Ue(gR,{start:()=>L3});function b3(e){if(e.kind!==Me.Kind.OPERATION_DEFINITION&&e.kind!==Me.Kind.FRAGMENT_DEFINITION)throw new Or(`Unexpected non-executable definition type ${e.kind}.`)}function KL(e){if(typeof e!="object"||e===null)throw new bi("Request body must be an object.");if(!("query"in e))throw new bi("Request body must contain a `query` field.");if(typeof e.query!="string")throw new bi("Request body `query` field must be a string.");if("variables"in e&&(typeof e.variables!="object"||e.variables===null))throw new bi("Request body `variables` field must be an object.");if("operationName"in e&&typeof e.operationName!="string")throw new bi("Request body `operationName` field must be a string.")}function ER(e){return parseInt(e.value,10)}function WL(e){return parseFloat(e.value)}function zL(e,t,r){let n=r.get(e.name.value);return QL(n)?jL(n,t):{attribute:t,value:n}}function QL(e){return typeof e=="object"&&e!=null&&!Array.isArray(e)}function jL(e,t){return t=typeof t=="string"?[t]:t,Object.entries(e).flatMap(([r,n])=>(t=[...t,r],QL(n)?jL(n,t):{attribute:t,value:n}))}function O3(e,t,r){switch(t=[...t,e.name.value],e.value.kind){case Me.Kind.NULL:return{attribute:t,value:null};case Me.Kind.INT:return{attribute:t,value:ER(e.value)};case Me.Kind.FLOAT:return{attribute:t,value:WL(e.value)};case Me.Kind.BOOLEAN:case Me.Kind.STRING:return{attribute:t,value:e.value.value};case Me.Kind.VARIABLE:return zL(e.value,t,r);case Me.Kind.OBJECT:return JL(e.value,t,r);case Me.Kind.LIST:case Me.Kind.ENUM:default:throw new Or(`Value type, ${e.value.kind}, is not supported.`)}}function JL(e,t,r){return e.fields.flatMap(n=>O3(n,t,r))}function N3(e,t){switch(e.value.kind){case Me.Kind.NULL:return{attribute:e.name.value,value:null};case Me.Kind.INT:return{attribute:e.name.value,value:ER(e.value)};case Me.Kind.FLOAT:return{attribute:e.name.value,value:WL(e.value)};case Me.Kind.BOOLEAN:case Me.Kind.STRING:return{attribute:e.name.value,value:e.value.value};case Me.Kind.VARIABLE:return zL(e.value,e.name.value,t);case Me.Kind.OBJECT:return JL(e.value,[e.name.value],t);case Me.Kind.LIST:case Me.Kind.ENUM:default:throw new Or(`Argument type, ${e.value.kind}, is not supported.`)}}function w3(e,t){return e.flatMap(r=>N3(r,t))}function bp(e,t){return e.selections.flatMap(r=>{switch(r.kind){case Me.Kind.FIELD:return r;case Me.Kind.FRAGMENT_SPREAD:{let n=r.name.value,s=t.get(n);if(s==null)throw new Or(`Fragment \`${n}\` not found.`);return bp(s.selectionSet,t)}case Me.Kind.INLINE_FRAGMENT:return bp(r.selectionSet,t)}})}function XL(e,t){return bp(e,t).map(r=>r.selectionSet?.selections.length>0?{name:r.name.value,select:XL(r.selectionSet,t)}:r.name.value)}async function I3(e,t,r,n){let s=_s.getMatch(e.name.value,"graphql");if(s===void 0)throw new Or(`Resource \`${e.name.value}\` not found.`);let i=s.Resource,o={select:XL(e.selectionSet,r),conditions:w3(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 ZL(e){switch(e.kind){case Me.Kind.NULL:return null;case Me.Kind.INT:return ER(e);case Me.Kind.FLOAT:return parseFloat(e.value);case Me.Kind.STRING:case Me.Kind.BOOLEAN:return e.value;case Me.Kind.OBJECT:return e.fields.reduce((t,r)=>({[r.name.value]:ZL(r.value),...t}),{});case Me.Kind.LIST:case Me.Kind.ENUM:default:throw new Or(`Value type, ${e.kind}, is not supported.`)}}function C3(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=ZL(n.defaultValue)),n.type.kind===Me.Kind.NON_NULL_TYPE&&!(s in t)&&i===void 0)throw new Or(`Variable $${s} is required, but not provided.`);r.set(n.variable.name.value,i??null)}return r}async function P3(e,t,r,n){if(e.operation===Me.OperationTypeNode.SUBSCRIPTION)throw new Or("Subscriptions are not supported.");if(e.operation===Me.OperationTypeNode.MUTATION)throw new Or("Mutations are not supported yet.");let s=C3(e.variableDefinitions,t),i=await Promise.all(bp(e.selectionSet,r).map(c=>I3(c,s,r,n))),o={data:{}};for(let[c,l]of i)o.data[c]=l;return o}async function YL({query:e,variables:t={},operationName:r},n){let s=Me.parse(e),i=new Map,o=new Map;for(let u of s.definitions)if(b3(u),u.kind===Me.Kind.FRAGMENT_DEFINITION)o.set(u.name.value,u);else{if(u.name===void 0&&s.definitions.length>1)throw new Or("Unnamed operations are only allowed when there is a single operation in the document.");let f=u.name?.value??"Unnamed Query";if(i.has(f))throw new Or(`Duplicate operation definition: ${f}`);i.set(f,u)}let c;if(r==null)if(i.size===1)c=i.entries().next().value[1];else throw new Or("Operation name is required when there are multiple operations in the document.");else if(c=i.get(r),c==null)throw new Or(`Operation \`${r}\` not found.`);let l=await P3(c,t,o,n);return{status:200,headers:{"Content-Type":"application/graphql-response+json; charset=utf-8"},body:JSON.stringify(l)}}async function D3(e){switch(e.method){case"GET":{let t=new URLSearchParams(e.url.split("?")[1]),r={};for(let[n,s]of t)r[n]=n==="variables"||n==="extensions"?JSON.parse(s):s;return KL(r),YL(r,e)}case"POST":{let r=await lo(e.headers.get("content-type"),!0)(e._nodeRequest);return KL(r),YL(r,e)}default:throw new bi("Method Not Allowed",405,{Allow:"GET, POST"})}}function L3(e){e.server.http(async(t,r)=>{if(!t.url.startsWith("/graphql"))return r(t);try{return await D3(t)}catch(n){logger.error(n);let s=t.headers.get("accept")??"application/graphql-response+json";switch(s){case"application/json":{if(n instanceof bi)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json",...n.headers}};if(n instanceof Me.GraphQLError)return{status:200,body:JSON.stringify({errors:[n]}),headers:{"Content-Type":"application/json"}};if(n instanceof Or)return{status:200,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json"}};if(n instanceof Error)return{status:500,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json"}};break}default:logger.info(`Unsupported accept header, ${s}, defaulting to application/graphql-response+json`);case"application/graphql-response+json":{if(n instanceof bi)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json",...n.headers}};if(n instanceof Me.GraphQLError)return{status:400,body:JSON.stringify({errors:[n]}),headers:{"Content-Type":"application/graphql-response+json"}};if(n instanceof Or)return{status:400,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json"}};if(n instanceof Error)return{status:500,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json"}};break}}throw n}},{port:e.port,securePort:e.securePort})}var Me,Or,bi,eM=Re(()=>{Me=v(require("graphql"));oo();su();a(b3,"assertExecutableDefinitionNode");a(KL,"assertRequestParams");a(ER,"processIntValueNode");a(WL,"processFloatValueNode");a(zL,"processVariableNode");a(QL,"isObject");a(jL,"transformObjectIntoQueryCondition");a(O3,"processObjectFieldNode");a(JL,"processObjectValueNode");a(N3,"processArgumentNode");a(w3,"buildConditionsQuery");a(bp,"fillInFragments");a(XL,"buildSelectQuery");a(I3,"processFieldNode");a(ZL,"processConstValueNode");a(C3,"resolveVariables");a(P3,"executeOperation");a(YL,"resolver");Or=class extends Error{static{a(this,"GraphQLQueryingError")}},bi=class extends Error{static{a(this,"HTTPError")}statusCode;headers;constructor(t,r=400,n={}){super(t),this.statusCode=r,this.headers=n}};a(D3,"graphqlQueryingHandler");a(L3,"start")});var Ni=C((jRe,nM)=>{"use strict";var rM=ie(),tM=(k(),P(q)),du=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Oi=require("joi"),da={schema_format:{pattern:du,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},M3=Oi.alternatives(Oi.string().min(1).max(da.schema_length.maximum).pattern(du).messages({"string.pattern.base":"{:#label} "+da.schema_format.message}),Oi.number(),Oi.array()).required(),v3=Oi.alternatives(Oi.string().min(1).max(da.schema_length.maximum).pattern(du).messages({"string.pattern.base":"{:#label} "+da.schema_format.message}),Oi.number()),U3=Oi.alternatives(Oi.string().min(1).max(da.schema_length.maximum).pattern(du).messages({"string.pattern.base":"{:#label} "+da.schema_format.message}),Oi.number()).required();function x3(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>da.schema_length.maximum?`'${e}' maximum of 250 characters`:du.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(x3,"checkValidTable");function B3(e,t){return rM.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(B3,"validateSchemaExists");function H3(e,t){let r=t.state.ancestors[0].schema;return rM.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(H3,"validateTableExists");function k3(e,t){return e.toLowerCase()===tM.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${tM.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(k3,"validateSchemaName");nM.exports={common_validators:da,schema_regex:du,hdb_schema_table:M3,validateSchemaExists:B3,validateTableExists:H3,validateSchemaName:k3,checkValidTable:x3,hdb_database:v3,hdb_table:U3}});var TR=C((XRe,iM)=>{var{hdb_table:F3,hdb_database:sM}=Ni(),G3=it(),SR=require("joi"),q3={undefined:"undefined",null:"null"},$3=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||q3[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"),V3=SR.object({database:sM,schema:sM,table:F3,records:SR.array().items(SR.object().custom($3)).required()});iM.exports=function(e){return G3.validateBySchema(e,V3)}});var aM=C((eye,oM)=>{"use strict";var AR=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")}};oM.exports=AR});var lM=C((rye,cM)=>{"use strict";var RR=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};cM.exports=RR});var hM={};Ue(hM,{HAS_EXPIRATION:()=>Ip,HAS_RESIDENCY_ID:()=>IR,HAS_STRUCTURE_UPDATE:()=>Pp,LAST_TIMESTAMP_PLACEHOLDER:()=>Vf,LOCAL_TIMESTAMP:()=>K3,METADATA:()=>Pc,NEW_TIMESTAMP_PLACEHOLDER:()=>dM,NO_TIMESTAMP:()=>Np,PENDING_LOCAL_TIME:()=>CR,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>wR,RecordEncoder:()=>NR,TIMESTAMP_ASSIGN_LAST:()=>W3,TIMESTAMP_ASSIGN_NEW:()=>fM,TIMESTAMP_ASSIGN_PREVIOUS:()=>_M,TIMESTAMP_PLACEHOLDER:()=>Op,TIMESTAMP_RECORD_PREVIOUS:()=>yR,handleLocalTimeForGets:()=>Dp,recordUpdater:()=>PR,removeEntry:()=>Lc});function Q3(){return $f[0]=$f[0]^64,Y3.getFloat64(0)}function Dp(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?.[Pc];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?.[Pc]>=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[Pc];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,Cc.push(new WeakRef(this))),c.call(this)},o.prototype.done=function(){if(l.call(this),this.isDone)for(let u=0;u<Cc.length;u++){let f=Cc[u].deref();(!f||f.isDone||f.isCommitted)&&Cc.splice(u--,1)}},o.prototype.done.isTracked=!0}return e}function PR(e,t,r){return function(n,s,i,o,c=-1,l,u,f="put",d,_){l==null?Ic=Np:d?Ic=i?.localTime?yR|_M:Np:Ic=l?i?.localTime?yR|16384:fM|16384:Np;let h=u?.expiresAt;if(h>=0&&(c|=Ip),qf=c,bR=h,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let m={version:o,instructedWrite:Ic>0},S,g=0;try{let R=i?.residencyId,E=u?.residencyId;E&&(OR=E,qf|=IR,g|=Mc),R!==E&&(g|=vc,R||(R=0)),c&Ip&&(g|=Yf),u?.originatingOperation&&(g|=Kf),d&&(m.ifVersion=S=i?.version??null),i&&i.value&&f!=="message"&&i.metadataFlags&Ur&&(!i.localTime||!r.getBinaryFast(i.localTime))&&la(i.value);let T;if(s!==void 0&&(T=Tp(()=>e.put(n,s,m),n,e.rootStore),Oc&&(g|=Ur)),l){let N=u?.user?.username;if(_&&(Tp(()=>e.encoder.encode(_),n,e.rootStore),Oc&&(g|=Ur)),e.encoder.hasStructureUpdate&&(g|=Pp,e.encoder.hasStructureUpdate=!1),d&&i?.localTime){let M=i?.localTime,H=r.get(M);if(H){let X=St(H).previousLocalTime;return T=r.put(M,Dc(o,t,n,X,u?.nodeId??server.replication.getThisNodeId(r)??0,N,f,Gf,g,E,R,h),{ifVersion:S}),T}}T=r.put(s===void 0?dM:Vf,Dc(o,t,n,i?.localTime?1:0,u?.nodeId??server.replication?.getThisNodeId(r)??0,N,f,Gf,g,E,R,h,u?.originatingOperation),{instructedWrite:!0,ifVersion:S})}return T}catch(R){throw R.message+=" id: "+n+" options: "+m,R}}}function Lc(e,t,r){if(t)return t.value&&t.metadataFlags&Ur&&!e.auditStore?.getBinaryFast(t.localTime)&&la(t.value),e.remove(t.key,r)}var uM,wp,Op,Vf,wR,dM,K3,Pc,$f,Y3,Np,fM,W3,_M,yR,Ip,IR,CR,Pp,z3,Gf,Ic,qf,bR,OR,NR,Cc,fu=Re(()=>{uM=require("msgpackr");Ri();wp=v(ee());gn();gn();Op=new Uint8Array([1,1,1,1,4,64,0,0]),Vf=new Uint8Array([1,1,1,1,1,0,0,0]),wR=new Uint8Array([1,1,1,1,3,64,0,0]),dM=new Uint8Array([1,1,1,1,0,64,0,0]),K3=Symbol("local-timestamp"),Pc=Symbol("metadata"),$f=new Uint8Array(8),Y3=new DataView($f.buffer,0,8),Np=0,fM=0,W3=1,_M=3,yR=4,Ip=16,IR=32,CR=1,Pp=256,Ic=0,qf=-1,bR=-1,OR=0,NR=class extends uM.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(s,i){if(Ic||qf>=0){let o=0,c=Ic;c&&(o+=8,Ic=0);let l=qf,u=bR,f=OR;l>=0&&(o+=4,qf=-1,u>=0&&(o+=8,bR=-1),f&&(o+=4,OR=0));let d=z3=r.call(this,s,i|2048|o);Gf=d.subarray((d.start||0)+o,d.end);let _=d.start||0;return c&&(Op[4]=c,Op[5]=c>>8,d.set(Op,_),_+=8),Oc&&(l|=Ur),l>=0&&((d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setUint32(_,l|Cp<<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 Gf=r.call(this,s,i),Gf};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($f,0,c),c+=8;else for(let _=0;_<8;_++)$f[_]=t[c++];l=Q3(),i=t[c]}let u,f;i<32&&(i===Cp?(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&Ip&&(u=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8),o&IR&&(f=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4));let d=io(()=>r?.valueAsBuffer?t.subarray(c,s):super.decode(t.subarray(c,s),s-c),this.rootStore);return{localTime:l,value:d,[Pc]:o,expiresAt:u,residencyId:f}}return r?.valueAsBuffer?t:io(()=>super.decode(t,r),this.rootStore)}catch(c){return wp.error("Error decoding record",c,"data: "+t.slice(0,40).toString("hex")),null}}};a(Q3,"getTimestamp");a(Dp,"handleLocalTimeForGets");Cc=[];setInterval(()=>{for(let e=0;e<Cc.length;e++){let t=Cc[e].deref();!t||t.isDone||t.isCommitted?Cc.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(wp.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):wp.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(PR,"recordUpdater");a(Lc,"removeEntry")});var Wf=C((cye,pM)=>{"use strict";var mM=le(),j3=(k(),P(q)),{RecordEncoder:J3}=(fu(),P(hM));mM.initSync();var X3=mM.get(j3.CONFIG_PARAMS.STORAGE_CACHING)!==!1,DR=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=X3&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:J3})}};pM.exports=DR});var zf=C((uye,EM)=>{"use strict";var Gn=le(),hs=(k(),P(q));Gn.initSync();var Lp=class{static{a(this,"OpenEnvironmentObject")}constructor(t,r=!1){this.path=t,this.mapSize=1073741824,this.maxDbs=1e4,this.maxReaders=2048,this.sharedStructuresKey=Symbol.for("structures"),this.readOnly=r,this.trackMetrics=!0,this.eventTurnBatching=!1,this.noSync=Gn.get(hs.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Gn.get(hs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Gn.get(hs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Gn.get(hs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Gn.get(hs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Gn.get(hs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Gn.get(hs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Gn.get(hs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Gn.get(hs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Gn.get(hs.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Gn.get(hs.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Gn.get(hs.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};EM.exports=Lp;Lp.MAX_DBS=1e4});var ht=C((fye,wM)=>{"use strict";var MR=require("lmdb"),qs=require("fs-extra"),qn=require("path"),Mp=fn(),TM=ee(),Sn=Un().LMDB_ERRORS_ENUM,vp=lM(),vR=Wf(),AM=zf(),fa=Ft(),gM=(k(),P(q)),{table:Z3,resetDatabases:eX}=(xe(),P(ct)),SM=le(),$s=fa.INTERNAL_DBIS_NAME,RM=fa.DBI_DEFINITION_NAME,tX="data.mdb",rX="lock.mdb",Qf=".mdb",nX="-lock",LR=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=ms(t,r),this.key_type=this.dbi[fa.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[fa.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new MR.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function Up(e,t){if(e===void 0)throw new Error(Sn.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(Sn.ENV_NAME_REQUIRED)}a(Up,"pathEnvNameValidation");async function UR(e,t,r=!0){try{await qs.access(e)}catch(n){throw n.code==="ENOENT"?new Error(Sn.INVALID_BASE_PATH):n}try{let n=qn.join(e,t+Qf);return await qs.access(n,qs.constants.R_OK|qs.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await qs.access(qn.join(e,t,tX),qs.constants.R_OK|qs.constants.F_OK),qn.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(Sn.INVALID_ENVIRONMENT)}else throw new Error(Sn.INVALID_ENVIRONMENT);throw n}}a(UR,"validateEnvironmentPath");function xp(e,t){if(Mp.validateEnv(e),t===void 0)throw new Error(Sn.DBI_NAME_REQUIRED)}a(xp,"validateEnvDBIName");async function sX(e,t,r=!1,n=!1){Up(e,t);let s=qn.basename(e);t=t.toString();let i=SM.get(gM.CONFIG_PARAMS.DATABASES);i||SM.setProperty(gM.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await UR(e,t,n),yM(e,t,r)}catch(o){if(o.message===Sn.INVALID_ENVIRONMENT){let c=qn.join(e,t);await qs.mkdirp(n?c:e);let l=new AM(n?c:c+Qf,!1),u=MR.open(l);u.dbis=Object.create(null);let f=new vR(!1);u.openDB($s,f),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let d=xR(e,t,r);return u[fa.ENVIRONMENT_NAME_KEY]=d,global.lmdb_map[d]=u,u}throw o}}a(sX,"createEnvironment");async function iX(e,t,r,n=!0){Up(e,t),t=t.toString();let s=qn.join(e,t);return Z3({table:t,database:qn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(iX,"copyEnvironment");async function yM(e,t,r=!1){Up(e,t),t=t.toString();let n=xR(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 UR(e,t),i=qn.join(e,t+Qf),o=s!=i,c=new AM(s,o),l=MR.open(c);l.dbis=Object.create(null);let u=OM(l);for(let f=0;f<u.length;f++)ms(l,u[f]);return l[fa.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(yM,"openEnvironment");async function oX(e,t,r=!1){Up(e,t),t=t.toString();let n=qn.join(e,t+Qf),s=await UR(e,t);if(global.lmdb_map!==void 0){let i=xR(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await bM(o),delete global.lmdb_map[i]}}await qs.remove(s),await qs.remove(s===n?s+nX:qn.join(qn.dirname(s),rX))}a(oX,"deleteEnvironment");async function bM(e){Mp.validateEnv(e);let t=e[fa.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(bM,"closeEnvironment");function xR(e,t,r=!1){let s=`${qn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(xR,"getCachedEnvironmentName");function aX(e){Mp.validateEnv(e);let t=Object.create(null),r=ms(e,$s);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==$s)try{t[n]=Object.assign(new vp,s)}catch{TM.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(aX,"listDBIDefinitions");function OM(e){Mp.validateEnv(e);let t=[],r=ms(e,$s);for(let{key:n}of r.getRange({start:!1}))n!==$s&&t.push(n);return t}a(OM,"listDBIs");function cX(e,t){let n=ms(e,$s).getEntry(t),s=new vp;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{TM.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(cX,"getDBIDefinition");function NM(e,t,r,n=!r){if(xp(e,t),t=t.toString(),t===$s)throw new Error(Sn.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return ms(e,t)}catch(s){if(s.message===Sn.DBI_DOES_NOT_EXIST){let i=new vR(r,n===!0),o=e.openDB(t,i),c=new vp(r===!0,n);return o[RM]=c,ms(e,$s).putSync(t,c),e.dbis[t]=o,o}throw s}}a(NM,"createDBI");function ms(e,t){if(xp(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==$s?r=cX(e,t):r=new vp,r===void 0)throw new Error(Sn.DBI_DOES_NOT_EXIST);let n;try{let s=new vR(r.dup_sort,r.useVersions);if(n=e.openDB(t,s),n.db===void 0)throw new Error("MDB_NOTFOUND")}catch(s){throw s.message.includes("MDB_NOTFOUND")===!0?new Error(Sn.DBI_DOES_NOT_EXIST):s}return n[RM]=r,e.dbis[t]=n,n}a(ms,"openDBI");function lX(e,t){xp(e,t),t=t.toString();let r=ms(e,t),n=r.getStats();return r[fa.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(lX,"statDBI");async function uX(e,t){try{let r=qn.join(e,t+Qf);return(await qs.stat(r)).size}catch{throw new Error(Sn.INVALID_ENVIRONMENT)}}a(uX,"environmentDataSize");function dX(e,t){if(xp(e,t),t=t.toString(),t===$s)throw new Error(Sn.CANNOT_DROP_INTERNAL_DBIS_NAME);ms(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],ms(e,$s).removeSync(t)}a(dX,"dropDBI");function fX(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{ms(e,i)}catch(o){if(o.message===Sn.DBI_DOES_NOT_EXIST)NM(e,i,i!==t,i===t),n=!0;else throw o}}n&&eX()}a(fX,"initializeDBIs");wM.exports={openDBI:ms,openEnvironment:yM,createEnvironment:sX,listDBIs:OM,listDBIDefinitions:aX,createDBI:NM,dropDBI:dX,statDBI:lX,deleteEnvironment:oX,initializeDBIs:fX,TransactionCursor:LR,environmentDataSize:uX,copyEnvironment:iX,closeEnvironment:bM}});var CM=C((hye,IM)=>{"use strict";var BR=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};IM.exports=BR});var DM=C((pye,PM)=>{"use strict";var HR=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}};PM.exports=HR});var MM=C((gye,LM)=>{"use strict";var kR=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};LM.exports=kR});var xc=C((yye,xM)=>{"use strict";var _X=ht(),hX=CM(),mX=DM(),pX=MM(),wi=fn(),jf=Un().LMDB_ERRORS_ENUM,EX=Ft(),uo=(k(),P(q)),gX=ie(),SX=require("uuid"),Tye=require("lmdb"),{handleHDBError:TX,hdb_errors:AX}=he(),{OVERFLOW_MARKER:Aye,MAX_SEARCH_KEY_LENGTH:Rye}=EX,vM=le();vM.initSync();var Bp=vM.get(uo.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),FR=uo.TIME_STAMP_NAMES_ENUM.CREATED_TIME,Uc=uo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function RX(e,t,r,n,s=wi.getNextMonotonicTime()){VR(e,t,r,n),GR(e,t,r);let i=new hX,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l];UM(u,!0,s);let f=yX(e,t,r,u),d=u[t];o.push(f),c.push(d)}return qR(o,c,n,i,s)}a(RX,"insertRecords");function yX(e,t,r,n){let s=n[t];return e.dbis[t].ifNoExists(s,()=>{for(let i=0;i<r.length;i++){let o=r[i];if(o===t||n.hasOwnProperty(o)===!1)continue;let c=n[o];if(typeof c=="function"){let f=c([[{}]]);Array.isArray(f)&&(c=f[0][uo.FUNC_VAL],n[o]=c)}let l=wi.getIndexedValues(c),u=e.dbis[o];if(l){Bp&&u.prefetch(l.map(f=>({key:f,value:s})),Hp);for(let f=0,d=l.length;f<d;f++)u.put(l[f],s)}}Bp&&e.dbis[t].prefetch([s],Hp),e.dbis[t].put(s,n,n[Uc])})}a(yX,"insertRecord");function bX(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(bX,"removeSkippedRecords");function UM(e,t,r){let n=r>0;(n||!Number.isInteger(e[Uc]))&&(e[Uc]=r||(r=wi.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[FR]))&&(e[FR]=r||wi.getNextMonotonicTime()):delete e[FR]}a(UM,"setTimestamps");function GR(e,t,r){r.indexOf(uo.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(uo.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(uo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(uo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),_X.initializeDBIs(e,t,r)}a(GR,"initializeTransaction");async function OX(e,t,r,n,s=wi.getNextMonotonicTime()){VR(e,t,r,n),GR(e,t,r);let i=new mX,o=[],c=[],l=[];for(let u=0;u<n.length;u++){let f=n[u],d=f[t],_;try{_=$R(e,t,f,d,i,!0,s)}catch{i.skipped_hashes.push(d),o.push(u);continue}c.push(_),l.push(d)}return qR(c,l,n,i,s,o)}a(OX,"updateRecords");async function NX(e,t,r,n,s=wi.getNextMonotonicTime()){try{VR(e,t,r,n)}catch(l){throw TX(l,l.message,AX.HTTP_STATUS_CODES.BAD_REQUEST)}GR(e,t,r);let i=new pX,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l],f;gX.isEmpty(u[t])?(f=SX.v4(),u[t]=f):f=u[t];let d=$R(e,t,u,f,i,!1,s);o.push(d),c.push(f)}return qR(o,c,n,i,s)}a(NX,"upsertRecords");async function qR(e,t,r,n,s,i=[]){let o=await Promise.all(e);for(let c=0,l=o.length;c<l;c++)o[c]===!0?n.written_hashes.push(t[c]):(n.skipped_hashes.push(t[c]),i.push(c));return n.txn_time=s||wi.getNextMonotonicTime(),bX(r,i),n}a(qR,"finalizeWrite");function $R(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(UM(r,!f,o),Number.isInteger(r[Uc])&&u[Uc]>r[Uc])return!1;f&&s.original_records.push(u);let d,_=a(()=>{for(let m in r){if(!r.hasOwnProperty(m)||m===t)continue;let S=r[m],g=e.dbis[m];if(g===void 0)continue;let R=u[m];if(typeof S=="function"){let T=S([[u]]);Array.isArray(T)&&(S=T[0][uo.FUNC_VAL],r[m]=S)}if(S===R)continue;let E=wi.getIndexedValues(R);if(E){Bp&&g.prefetch(E.map(T=>({key:T,value:n})),Hp);for(let T=0,N=E.length;T<N;T++)g.remove(E[T],n)}if(E=wi.getIndexedValues(S),E){Bp&&g.prefetch(E.map(T=>({key:T,value:n})),Hp);for(let T=0,N=E.length;T<N;T++)g.put(E[T],n)}}let h={...u,...r};c.put(n,h,h[Uc])},"do_put");return l?d=c.ifVersion(n,l.version,_):d=c.ifNoExists(n,_),d.then(h=>h?!0:$R(e,t,r,n,s,i,o))}a($R,"updateUpsertRecord");function wX(e,t,r){if(wi.validateEnv(e),t===void 0)throw new Error(jf.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(jf.WRITE_ATTRIBUTES_REQUIRED):new Error(jf.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(wX,"validateBasic");function VR(e,t,r,n){if(wX(e,t,r),!Array.isArray(n))throw n===void 0?new Error(jf.RECORDS_REQUIRED):new Error(jf.RECORDS_MUST_BE_ARRAY)}a(VR,"validateWrite");function Hp(){}a(Hp,"noop");xM.exports={insertRecords:RX,updateRecords:OX,upsertRecords:NX}});var fo=C((Oye,IX)=>{IX.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 HM=C((Nye,BM)=>{"use strict";var CX=require("uuid"),KR=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||CX.v4(),this.schema_table=`${this.schema}.${this.table}`}};BM.exports=KR});var kp=C((Iye,kM)=>{"use strict";var PX=HM(),YR=class extends PX{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}};kM.exports=YR});var GM=C((Pye,FM)=>{"use strict";FM.exports=LX;var DX="inserted";function LX(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===DX?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(LX,"returnObject")});var Fp=C((Mye,$M)=>{"use strict";var MX=(k(),P(q)),WR=ht(),vX=xc(),{getSystemSchemaPath:UX,getSchemaPath:xX}=gt(),Lye=fo(),{validateBySchema:BX}=it(),Jf=require("joi"),HX=kp(),kX=GM(),{handleHDBError:FX,hdb_errors:GX,ClientError:qX}=he(),qM=ie(),{HTTP_STATUS_CODES:$X}=GX,VX="inserted";$M.exports=KX;async function KX(e){let t=BX(e,Jf.object({database:Jf.string(),schema:Jf.string(),table:Jf.string().required(),attribute:Jf.string().required()}));if(t)throw new qX(t.message);let r=!e.skip_table_check&&qM.checkGlobalSchemaTable(e.schema,e.table);if(r)throw FX(new Error,r,$X.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=qM.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 HX(e.schema,e.table,e.attribute,e.id);try{let i=await WR.openEnvironment(xX(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}`);WR.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await WR.openEnvironment(UX(),MX.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await vX.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_attribute_attributes,[s]);return kX(VX,c,{records:[s]},l)}catch(i){throw i}}a(KX,"lmdbCreateAttribute")});var Xf=C((xye,KM)=>{"use strict";var _o=ie(),VM=ee(),Uye=TR(),{getDatabases:YX}=(xe(),P(ct)),{ClientError:Bc}=he();KM.exports=WX;function WX(e){if(_o.isEmpty(e))throw new Bc("invalid update parameters defined.");if(_o.isEmptyOrZeroLength(e.schema))throw new Bc("invalid schema specified.");if(_o.isEmptyOrZeroLength(e.table))throw new Bc("invalid table specified.");if(!Array.isArray(e.records))throw new Bc("records must be an array");let t=YX()[e.schema]?.[e.table];if(_o.isEmpty(t))throw new Bc(`could not retrieve schema:${e.schema} and table ${e.table}`);let r=t.primaryKey,n=new Set,s={},i=!1;return e.operation==="update"&&(i=!0),e.records.forEach(o=>{if(i&&_o.isEmptyOrZeroLength(o[r]))throw VM.error("a valid hash attribute must be provided with update record:",o),new Bc("a valid hash attribute must be provided with update record, check log for more info");if(!_o.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw VM.error(`a valid hash value must be provided with ${e.operation} record:`,o),new Bc(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!_o.isEmpty(o[r])&&o[r]!==""&&n.has(_o.autoCast(o[r]))&&(o.skip=!0),n.add(_o.autoCast(o[r]));for(let c in o)s[c]=1}),s[r]=1,{schema_table:t,hashes:Array.from(n),attributes:Object.keys(s)}}a(WX,"insertUpdateValidate")});var WM=C((Hye,YM)=>{"use strict";var zR=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};YM.exports=zR});var jM=C((Fye,QM)=>{"use strict";var QR=ht(),zX=ee(),zM=Un().LMDB_ERRORS_ENUM;QM.exports=QX;async function QX(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 QR.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==zM.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await QR.closeEnvironment(global.lmdb_map[n]),await QR.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==zM.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){zX.error(t)}}a(QX,"cleanLMDBMap")});var lv=C(($ye,cv)=>{"use strict";var jR=require("recursive-iterator"),jX=require("alasql"),JR=require("clone"),JM=ie(),{handleHDBError:XM,hdb_errors:JX}=he(),{HDB_ERROR_MSGS:ZM,HTTP_STATUS_CODES:ev}=JX,{getDatabases:XX}=(xe(),P(ct)),ZX=["DISTINCT_ARRAY"],tv=Symbol("validateTables"),XR=Symbol("validateTable"),qye=Symbol("getAllColumns"),rv=Symbol("validateAllColumns"),Gp=Symbol("findColumn"),nv=Symbol("validateOrderBy"),Zf=Symbol("validateSegment"),ZR=Symbol("validateColumn"),sv=Symbol("setColumnsForTable"),iv=Symbol("checkColumnsForAsterisk"),ov=Symbol("validateGroupBy"),av=Symbol("hasColumns"),ey=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[tv](),this[iv](),this[rv]()}[tv](){if(this[av]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[XR](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[XR](t.table)})}}[av](){let t=!1,r=new jR(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[XR](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=XX();if(!r[t.databaseid])throw XM(new Error,ZM.SCHEMA_NOT_FOUND(t.databaseid),ev.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw XM(new Error,ZM.TABLE_NOT_FOUND(t.databaseid,t.tableid),ev.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=JR(s);i.table=JR(t),this.attributes.push(i)})}[Gp](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)}[iv](){let t=new jR(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[sv](r.tableid)}[sv](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new jX.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[rv](){this[Zf](this.statement.columns,!1),this[Zf](this.statement.joins,!1),this[Zf](this.statement.where,!1),this[ov](this.statement.group,!1),this[Zf](this.statement.order,!0)}[Zf](t,r){if(!t)return;let n=new jR(t),s=[];for(let{node:i,path:o}of n)!JM.isEmpty(i)&&!JM.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[nv](i):s.push(this[ZR](i)));return s}[ov](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&ZX.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=JR(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[Gp](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[Gp](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`}[nv](t){let r=this.statement.columns.filter(n=>n.as===t.columnid);if(r.length>1)throw`ambiguous column reference ${(t.tableid?t.tableid+".":"")+t.columnid} in order by`;r.length===0&&this[ZR](t)}[ZR](t){let r=this[Gp](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]}};cv.exports=ey});var _v=C((Kye,fv)=>{"use strict";var uv=require("lodash"),e_=require("mathjs"),e6=require("jsonata"),dv=ie();fv.exports={distinct_array:a(e=>Array.isArray(e)&&e.length>1?uv.uniqWith(e,uv.isEqual):e,"distinct_array"),searchJSON:t6,mad:t_.bind(null,e_.mad),mean:t_.bind(null,e_.mean),mode:t_.bind(null,e_.mode),prod:t_.bind(null,e_.prod),median:t_.bind(null,e_.median)};function t_(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(t_,"aggregateFunction");function t6(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(dv.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),dv.isEmpty(this.__ala__.res[r])){let n=e6(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(t6,"searchJSON")});var mv=C((Wye,hv)=>{"use strict";var rr=require("moment"),ty="YYYY-MM-DDTHH:mm:ss.SSSZZ";rr.suppressDeprecationWarnings=!0;hv.exports={current_date:a(()=>rr().utc().format("YYYY-MM-DD"),"current_date"),current_time:a(()=>rr().utc().format("HH:mm:ss.SSS"),"current_time"),extract:a((e,t)=>{switch(t.toLowerCase()){case"year":return rr(e).utc().format("YYYY");case"month":return rr(e).utc().format("MM");case"day":return rr(e).utc().format("DD");case"hour":return rr(e).utc().format("HH");case"minute":return rr(e).utc().format("mm");case"second":return rr(e).utc().format("ss");case"millisecond":return rr(e).utc().format("SSS");default:break}},"extract"),date:a(e=>rr(e).utc().format(ty),"date"),date_format:a((e,t)=>rr(e).utc().format(t),"date_format"),date_add:a((e,t,r)=>rr(e).utc().add(t,r).valueOf(),"date_add"),date_sub:a((e,t,r)=>rr(e).utc().subtract(t,r).valueOf(),"date_sub"),date_diff:a((e,t,r)=>{let n=rr(e).utc(),s=rr(t).utc();return r?n.diff(s,r,!0):n.diff(s)},"date_diff"),now:a(()=>rr().utc().valueOf(),"now"),get_server_time:a(()=>rr().format(ty),"get_server_time"),offset_utc:a((e,t)=>rr(e).utc().utcOffset(t).format(ty),"offset_utc")}});var Sv=C((Qye,gv)=>{"use strict";var r6=require("@turf/area"),n6=require("@turf/length"),s6=require("@turf/circle"),i6=require("@turf/difference"),o6=require("@turf/distance"),a6=require("@turf/boolean-contains"),c6=require("@turf/boolean-equal"),l6=require("@turf/boolean-disjoint"),u6=require("@turf/helpers"),pv=(k(),P(q)),Ke=ie(),ho=ee();gv.exports={geoArea:d6,geoLength:f6,geoCircle:_6,geoDifference:h6,geoDistance:Ev,geoNear:m6,geoContains:p6,geoEqual:E6,geoCrosses:g6,geoConvert:S6};function d6(e){if(Ke.isEmpty(e))return NaN;typeof e=="string"&&(e=Ke.autoCastJSON(e));try{return r6.default(e)}catch(t){return ho.trace(t,e),NaN}}a(d6,"geoArea");function f6(e,t){if(Ke.isEmpty(e))return NaN;typeof e=="string"&&(e=Ke.autoCastJSON(e));try{return n6.default(e,{units:t||"kilometers"})}catch(r){return ho.trace(r,e),NaN}}a(f6,"geoLength");function _6(e,t,r){if(Ke.isEmpty(e))return NaN;if(Ke.isEmpty(t))return NaN;typeof e=="string"&&(e=Ke.autoCastJSON(e));try{return s6.default(e,t,{units:r||"kilometers"})}catch(n){return ho.trace(n,e,t),NaN}}a(_6,"geoCircle");function h6(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 i6(e,t)}catch(r){return ho.trace(r,e,t),NaN}}a(h6,"geoDifference");function Ev(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 o6.default(e,t,{units:r||"kilometers"})}catch(n){return ho.trace(n,e,t),NaN}}a(Ev,"geoDistance");function m6(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 Ev(e,t,n)<=r}catch(s){return ho.trace(s,e,t),!1}}a(m6,"geoNear");function p6(e,t){if(Ke.isEmpty(e)||Ke.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Ke.autoCastJSON(e)),typeof t=="string"&&(t=Ke.autoCastJSON(t));try{return a6.default(e,t)}catch(r){return ho.trace(r,e,t),!1}}a(p6,"geoContains");function E6(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 c6.default(e,t)}catch(r){return ho.trace(r,e,t),!1}}a(E6,"geoEqual");function g6(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!l6.default(e,t)}catch(r){return ho.trace(r,e,t),!1}}a(g6,"geoCrosses");function S6(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(pv.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(pv.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Ke.autoCastJSON(e)),u6[t](e,r)}a(S6,"geoConvert")});var qp=C((Jye,Tv)=>{var Hc=_v(),$n=mv(),Ii=Sv();Tv.exports=e=>{e.aggr.mad=e.aggr.MAD=Hc.mad,e.aggr.mean=e.aggr.MEAN=Hc.mean,e.aggr.mode=e.aggr.MODE=Hc.mode,e.aggr.prod=e.aggr.PROD=Hc.prod,e.aggr.median=e.aggr.MEDIAN=Hc.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=Hc.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=Hc.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=$n.current_date,e.fn.current_time=e.fn.CURRENT_TIME=$n.current_time,e.fn.extract=e.fn.EXTRACT=$n.extract,e.fn.date=e.fn.DATE=$n.date,e.fn.date_format=e.fn.DATE_FORMAT=$n.date_format,e.fn.date_add=e.fn.DATE_ADD=$n.date_add,e.fn.date_sub=e.fn.DATE_SUB=$n.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=$n.date_diff,e.fn.now=e.fn.NOW=$n.now,e.fn.offset_utc=e.fn.OFFSET_UTC=$n.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=$n.get_server_time,e.fn.getdate=e.fn.GETDATE=$n.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=$n.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=Ii.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=Ii.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=Ii.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=Ii.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=Ii.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=Ii.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=Ii.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=Ii.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=Ii.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=Ii.geoNear}});var bv=C((Xye,yv)=>{"use strict";var r_=require("lodash"),Tn=require("alasql");Tn.options.cache=!1;var T6=qp(),Av=require("clone"),$p=require("recursive-iterator"),ke=ee(),Je=ie(),_u=Vn(),A6=(k(),P(q)),{hdb_errors:R6}=he(),{getDatabases:Rv}=(xe(),P(ct)),y6="IS NULL",Vs="There was a problem performing this search. Please check the logs and try again.";T6(Tn);var ry=class{static{a(this,"SQLSearch")}constructor(t,r){if(Je.isEmpty(t))throw ke.error("AST statement for SQL select process cannot be empty"),"statement cannot be null";this.statement=t,this.columns={},this.all_table_attributes=r,this.fetch_attributes=[],this.exact_search_values={},this.comparator_search_values={},this.tables=[],this.data={},this.has_aggregator=!1,this.has_ordinal=!1,this.has_outer_join=!1,this._getColumns(),this._getTables(),this._conditionsToFetchAttributeValues(),this._setAliasesForColumns(),Je.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!Je.isEmptyOrZeroLength(n))return ke.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw ke.error("Error thrown from checkEmptySQL in SQLSearch class method search."),ke.error(n),new Error(Vs)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw ke.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),ke.error(n),new Error(Vs)}if(Object.keys(this.data).length===0)return ke.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw ke.error("Error thrown from processJoins in SQLSearch class method search."),ke.error(n),new Error(Vs)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw ke.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),ke.error(n),new Error(Vs)}try{return t=await this._finalSQL(),t}catch(n){throw ke.error("Error thrown from finalSQL in SQLSearch class method search."),ke.error(n),new Error(Vs)}}_getColumns(){let t=new $p(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(Av(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=r_.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=Rv()[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 $p(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!Je.isEmpty(r)&&r.right)if(Je.isNotEmptyAndHasValue(r.right.value)){let n=Je.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new Tn.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=Je.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new Tn.yy.LogicValue({value:i}):n instanceof Tn.yy.StringValue&&Je.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new Tn.yy.NumValue({value:i}))});if(t){ke.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new $p(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(A6.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&&r_.pullAt(this.statement.columns,t)}_findColumn(t){let r=this.all_table_attributes.filter(n=>{if(t.columnid_orig&&t.tableid_orig)return(n.table.as===t.tableid_orig||n.table.tableid===t.tableid_orig)&&n.attribute===t.columnid_orig;if(t.tableid)return(n.table.as===t.tableid||n.table.tableid===t.tableid)&&n.attribute===t.columnid;let s=t.columnid_orig?t.columnid_orig:t.columnid;return n.attribute===s});if(Je.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);Je.isEmptyOrZeroLength(n)||(r=this.all_table_attributes.filter(s=>s.attribute===n[0].columnid&&n[0].tableid&&n[0].tableid===(s.table.as?s.table.as:s.table.tableid)))}return r[0]}async _checkEmptySQL(){let t=[];if(Je.isEmptyOrZeroLength(this.all_table_attributes)&&!Je.isEmptyOrZeroLength(this.columns.columns))return t;if(Je.isEmptyOrZeroLength(this.all_table_attributes)&&Je.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await Tn.promise(r)}catch(r){throw ke.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),ke.error(r),new Error("There was a problem with the SQL statement")}return t}_addFetchColumns(t){t&&t.length>0&&t.forEach(r=>{let n=this._findColumn(r);n&&this.fetch_attributes.push(Av(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(y6)>-1&&this.tables.forEach(s=>{let i={columnid:Rv()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=r_.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 _u.getDataByHash(c);for(let d of c.hash_values)f.get(d)&&!this.data[i].__merged_data[d]&&(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d))}catch(f){throw ke.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),ke.error(f),new Error(Vs)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[u].values).map(async f=>{let d={...c};d.search_value=f;let _=await _u.getDataByValue(d);for(let[h,m]of _)this.data[i].__merged_data[h]?this._updateMergedAttribute(i,h,s.attribute,m[s.attribute]):(this.data[i].__merged_data[h]=[...n[i]],this._updateMergedAttribute(i,h,s.attribute,m[s.attribute]),this._setMergedHashAttribute(i,h))}))}catch(f){throw ke.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),ke.error(f),new Error(Vs)}else if(!Je.isEmpty(this.comparator_search_values[u])&&!this.comparator_search_values[u].ignore&&!Je.isEmptyOrZeroLength(this.comparator_search_values[u].comparators))try{let f=this.comparator_search_values[u].comparators;for(let d=0,_=f.length;d<_;d++){let h=f[d];c.search_attribute=h.attribute,c.search_value=h.search_value;let m=await _u.getDataByValue(c,h.operation);if(l)for(let[S]of m)this.data[i].__merged_data[S]||(this.data[i].__merged_data[S]=[...n[i]],this._setMergedHashAttribute(i,S));else for(let[S,g]of m)this.data[i].__merged_data[S]?this._updateMergedAttribute(i,S,s.attribute,g[s.attribute]):(this.data[i].__merged_data[S]=[...n[i]],this._updateMergedAttribute(i,S,s.attribute,g[s.attribute]),this._setMergedHashAttribute(i,S))}}catch(f){throw ke.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),ke.error(f),new Error(Vs)}else try{c.search_attribute=s.attribute,c.search_value="*";let f=await _u.getDataByValue(c);if(l)for(let[d]of f)this.data[i].__merged_data[d]||(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d));else for(let[d,_]of f)this.data[i].__merged_data[d]?this._updateMergedAttribute(i,d,s.attribute,_[s.attribute]):(this.data[i].__merged_data[d]=[...n[i]],this._updateMergedAttribute(i,d,s.attribute,_[s.attribute]),this._setMergedHashAttribute(i,d))}catch(f){throw ke.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),ke.error(f),new Error(Vs)}}}_isSimpleSelect(){let t=!0;return Object.keys(this.statement).length!==2||!this.statement.columns||!this.statement.from||this.statement.from.length!==1?(t=!1,t):(this.statement.columns.forEach(r=>{r instanceof Tn.yy.Column||(t=!1)}),t)}_updateOrderByToAliases(){this.statement.order.forEach(t=>{if(t.expression.aggregatorid){t.is_aggregator=!0;return}if(t.expression.value){t.is_ordinal=!0,this.has_ordinal=!0;return}else t.is_ordinal=!1;let r=this.statement.columns.filter(s=>{let i=s.aggregatorid?s.expression:s,o=s.aggregatorid?s.as_orig:i.as_orig;return t.expression.tableid?i.columnid_orig===t.expression.columnid_orig&&i.tableid_orig===t.expression.tableid_orig:i.columnid_orig===t.expression.columnid_orig||t.expression.columnid_orig===o});r[0]||r.push(this._findColumn(t.expression));let n=r[0];if(t.is_func=!!n.funcid,t.is_aggregator=!!n.aggregatorid,n.as)if(n.as&&!t.expression.tableid)t.expression.columnid=n.as,t.expression.columnid_orig=n.as_orig;else{let s=new Tn.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new Tn.yy.Column,t.expression),t.initial_select_column.as=`[${t.expression.columnid_orig}]`,t.expression.columnid=t.initial_select_column.as;return}if(!t.is_aggregator){let s=t.is_func?new Tn.yy.FuncValue:new Tn.yy.Column;t.initial_select_column=Object.assign(s,n)}})}_addNonAggregatorsToFetchColumns(){let r=this.statement.order.filter(n=>!n.is_aggregator&&!n.is_ordinal).map(n=>n.is_func?{columnid:n.initial_select_column.args.filter(i=>!!i.columnid_orig)[0].columnid_orig}:{columnid:n.expression.columnid_orig});this._addFetchColumns(r)}async _processJoins(){let t=[],r=[],n=this.statement.from[0],s=[n],i=["? "+(n.as?" AS "+n.as:n.tableid)];t.push(Object.values(this.data[`${n.databaseid_orig}_${n.as?n.as_orig:n.tableid_orig}`].__merged_data)),this.statement.joins&&this.statement.joins.forEach(h=>{h.joinmode&&h.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(h.table);let m=h.joinmode+" JOIN ? AS "+(h.as?h.as:h.table.tableid);h.on&&(m+=" ON "+h.on.toString()),i.push(m),t.push(Object.values(this.data[`${h.table.databaseid_orig}_${h.table.as?h.table.as_orig:h.table.tableid_orig}`].__merged_data))});let o=[],c={};s.forEach(h=>{let m=this.data[`${h.databaseid_orig}_${h.as?h.as_orig:h.tableid_orig}`].__hash_name,S=h.as?h.as_orig:h.tableid_orig;o.push({key:`'${S}.${m}'`,schema:h.databaseid_orig,table:h.as?h.as_orig:h.tableid_orig,keys:new Set}),r.push(`${h.as?h.as:h.tableid}.\`${m}\` AS "${S}.${m}"`),c[h.as?h.as_orig:h.tableid_orig]=this.data[`${h.databaseid_orig}_${h.as?h.as_orig:h.tableid_orig}`].__merged_attributes});let l=this.statement.where?"WHERE "+this.statement.where:"";l=l.replace(/NOT\(NULL\)/g,"NOT NULL");let u="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(u="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(h=>{h.is_func?r.push(h.initial_select_column.toString()):h.initial_select_column.tableid?r.push(`${h.initial_select_column.tableid}.${h.initial_select_column.columnid} AS ${h.expression.columnid}`):r.push(`${h.initial_select_column.columnid} AS ${h.expression.columnid}`)}));let f="",d="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(f=this.statement.limit?"LIMIT "+this.statement.limit:"",d=this.statement.offset?"OFFSET "+this.statement.offset:"");let _=[];try{let h=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${l} ${u} ${f} ${d}`,m=this._convertColumnsToIndexes(h,s);_=await Tn.promise(m,t),t=null}catch(h){throw ke.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),ke.error(h),new Error("There was a problem processing the data.")}if(_&&_.length>0){for(let h=0,m=_.length;h<m;h++){let S=_[h];o.forEach(g=>{S[g.key]!==null&&S[g.key]!==void 0&&g.keys.add(S[g.key])})}o.forEach(h=>{let m=Object.keys(this.data[`${h.schema}_${h.table}`].__merged_data),S=r_.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 $p(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=r_.uniqBy(n,i=>[i.table.databaseid,i.table.as?i.table.as:i.table.tableid,i.attribute].join());try{await this._getData(n)}catch(i){throw ke.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),ke.error(i),new Error(Vs)}}async _getData(t){try{let r=t.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]?n[i].columns.push(s.attribute):n[i]={schema:s.table.databaseid,table:s.table.tableid,columns:[s.attribute]},n},{});for(let n in r){let s=r[n],i=this.data[n].__merged_data,o=[];for(let f in i)o.push(i[f][0]);this.data[n].__merged_attributes.push(...s.columns);let c={schema:s.schema,table:s.table,hash_values:o,get_attributes:s.columns},l=await _u.getDataByHash(c),u=s.columns.length;for(let f=0,d=o.length;f<d;f++){let _=o[f],h=l.get(_);for(let m=0;m<u;m++){let S=s.columns[m],g=h[S]===void 0?null:h[S];this.data[n].__merged_data[_].push(g)}}}}catch(r){throw ke.error("Error thrown from getDataByHash function in SQLSearch class method getData."),ke.error(r),r}}async _finalSQL(){let t=[],r=this.statement.from[0];t.push(Object.values(this.data[`${r.databaseid_orig}_${r.as?r.as_orig:r.tableid_orig}`].__merged_data)),r.as=r.as?r.as:r.tableid,r.databaseid="",r.tableid="?",this.statement.joins&&this.statement.joins.forEach(s=>{s.as=s.as?s.as:s.table.tableid,t.push(Object.values(this.data[`${s.table.databaseid_orig}_${s.table.as?s.table.as_orig:s.table.tableid_orig}`].__merged_data)),s.table.databaseid="",s.table.tableid="?"}),this.statement.order&&this.statement.order.forEach(s=>{if(s.is_ordinal)return;this.statement.columns.filter(o=>{let c=o.aggregatorid?o.expression:o,l=o.aggregatorid?o.as_orig:c.as_orig;return s.expression.tableid?c.columnid_orig===s.expression.columnid_orig&&c.tableid_orig===s.expression.tableid_orig:c.columnid_orig===s.expression.columnid_orig||s.expression.columnid_orig===l}).length===0&&(s.expression.columnid=s.initial_select_column.columnid)}),!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&this.statement.limit&&!this.statement.joins&&(delete this.statement.limit,delete this.statement.offset);let n;try{let s=this._buildSQL();ke.trace(`Final SQL: ${s}`),n=await Tn.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),ke.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw ke.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),ke.error(s),new Error("There was a problem running the generated sql.")}return n}_translateUndefinedValues(t){try{let r=[];for(let n of t){let s=Object.create(null);Object.keys(n).forEach(i=>{n[i]===void 0?s[i]=null:s[i]=n[i]}),r.push(s)}return r}catch(r){return ke.error(R6.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 _u.getDataByValue(i);for(let[c,l]of o)this.data[s].__merged_data[c]||(l[n.attribute]===void 0&&(l[n.attribute]=null),this.data[s].__merged_data[c]={...r[s]}),this.data[s].__merged_data[c][t[n.attribute]]=l[n.attribute]??null}catch(o){throw ke.error("There was an error when processing this SQL operation. Check your logs"),ke.error(o),new Error(Vs)}}return Object.values(Object.values(this.data)[0].__merged_data)}};yv.exports=ry});var zr=C((ebe,Ov)=>{"use strict";var b6=lv();Ov.exports={searchByConditions:N6,searchByHash:w6,searchByValue:I6,search:C6};var ny=Vn(),{transformReq:sy}=ie(),O6=bv();async function N6(e){return sy(e),ny.searchByConditions(e)}a(N6,"searchByConditions");async function w6(e){sy(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of ny.searchByHash(e))r&&t.push(r);return t}a(w6,"searchByHash");async function I6(e){sy(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of ny.searchByValue(e))t.push(r);return t}a(I6,"searchByValue");function C6(e,t){try{let r=new b6(e);r.validate(),new O6(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(C6,"search")});var mo=C((rbe,Cv)=>{"use strict";var n_=require("crypto"),P6=le(),{CONFIG_PARAMS:D6}=(k(),P(q)),wv="aes-256-cbc",L6=32,M6=16,iy=64,Iv=32,v6=iy+Iv,Nv=new Map;Cv.exports={encrypt:U6,decrypt:x6,createNatsTableStreamName:B6};function U6(e){let t=n_.randomBytes(L6),r=n_.randomBytes(M6),n=n_.createCipheriv(wv,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(U6,"encrypt");function x6(e){let t=e.substr(0,iy),r=e.substr(iy,Iv),n=e.substr(v6,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=n_.createDecipheriv(wv,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(x6,"decrypt");function B6(e,t){let r=P6.get(D6.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=Nv.get(r);return n||(n=n_.createHash("md5").update(r).digest("hex"),Nv.set(r,n)),n}a(B6,"createNatsTableStreamName")});var po=C((ibe,Mv)=>{"use strict";var sbe=zr(),s_=ee(),{validateBySchema:Pv}=it(),kc=require("joi"),H6=mo(),Vp=ie(),{handleHDBError:Kp,hdb_errors:k6,ClientError:Dv}=he(),{HDB_ERROR_MSGS:Yp,HTTP_STATUS_CODES:oy}=k6,Lv=le();Lv.initSync();var{getDatabases:ay}=(xe(),P(ct)),F6=require("fs-extra"),G6=(k(),P(q));Mv.exports={describeAll:q6,describeTable:Wp,describeSchema:$6};async function q6(e={}){try{let t=Vp.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=ay(),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 Wp({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 Wp({schema:d,table:h,exact_count:u},S)}m&&l.push(m)}catch(m){s_.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 s_.error("Got an error in describeAll"),s_.error(t),Kp(new Error,Yp.DESCRIBE_ALL_ERR)}}a(q6,"describeAll");async function Wp(e,t){Vp.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=Pv(e,kc.object({database:kc.string(),table:kc.string().required(),exact_count:kc.boolean().strict()}));if(i)throw new Dv(i.message);let c=ay()[r];if(!c)throw Kp(new Error,Yp.SCHEMA_NOT_FOUND(e.schema),oy.NOT_FOUND);let l=c[n];if(!l)throw Kp(new Error,Yp.TABLE_NOT_FOUND(e.schema,e.table),oy.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 F6.stat(l.primaryStore.env.path)).size}catch(h){s_.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")),Lv.get(G6.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(_.clustering_stream_name=H6.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){s_.warn(`unable to stat table dbi due to ${h}`)}return _}a(Wp,"descTable");async function $6(e){Vp.transformReq(e);let t=Pv(e,kc.object({database:kc.string(),exact_count:kc.boolean().strict()}));if(t)throw new Dv(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=ay()[n];if(!i)throw Kp(new Error,Yp.SCHEMA_NOT_FOUND(e.schema),oy.NOT_FOUND);let o={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),Vp.isEmpty(l)||l.describe){let u=await Wp({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);u&&(o[u.name]=u)}}return o}a($6,"describeSchema")});var ps=C((lbe,Hv)=>{var V6=fo(),{callbackify:Uv,promisify:K6}=require("util"),{getDatabases:xv}=(xe(),P(ct));Hv.exports={setSchemaDataToGlobal:vv,getTableSchema:Y6,getSystemSchema:W6,setSchemaDataToGlobalAsync:K6(vv)};var Bv=po(),abe=Uv(Bv.describeAll),cbe=Uv(Bv.describeTable);function vv(e){global.hdb_schema=xv(),e&&e()}a(vv,"setSchemaDataToGlobal");function Y6(e,t,r){let n=xv()[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(Y6,"getTableSchema");function W6(){return V6}a(W6,"getSystemSchema")});var ly=C((dbe,Gv)=>{var z6=it(),cy=require("joi"),{hdb_table:Q6,hdb_database:kv}=Ni(),Fv={schema:kv,database:kv,table:Q6},j6={date:cy.date().iso().required()},J6={timestamp:cy.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};Gv.exports=function(e,t){let r=t==="timestamp"?{...Fv,...J6}:{...Fv,...j6},n=cy.object(r);return z6.validateBySchema(e,n)}});var Vv=C((fbe,$v)=>{var X6=it(),uy=require("joi"),{hdb_table:Z6,hdb_database:qv}=Ni(),e8=uy.object({schema:qv,database:qv,table:Z6,hash_values:uy.array().required(),ids:uy.array()});$v.exports=function(e){return X6.validateBySchema(e,e8)}});var hy=C((_be,Kv)=>{"use strict";var dy=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}},fy=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}},_y=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};Kv.exports={InsertObject:dy,NoSQLSeachObject:fy,DeleteResponseObject:_y}});var qc=C((mbe,jv)=>{"use strict";var Wv=ly(),t8=Vv(),Fc=ie(),Yv=require("moment"),zv=ee(),{promisify:r8,callbackify:n8}=require("util"),Gc=(k(),P(q)),s8=ps(),my=r8(s8.getTableSchema),py=Vn(),{DeleteResponseObject:i8}=hy(),{handleHDBError:_a,hdb_errors:o8}=he(),{HDB_ERROR_MSGS:zp,HTTP_STATUS_CODES:ha}=o8,a8="records successfully deleted",c8=n8(Qv);jv.exports={delete:c8,deleteRecord:Qv,deleteFilesBefore:l8,deleteAuditLogsBefore:u8};async function l8(e){let t=Wv(e,"date");if(t)throw _a(t,t.message,ha.BAD_REQUEST,void 0,void 0,!0);if(Fc.transformReq(e),!Yv(e.date,Yv.ISO_8601).isValid())throw _a(new Error,zp.INVALID_DATE,ha.BAD_REQUEST,Gc.LOG_LEVELS.ERROR,zp.INVALID_DATE,!0);let n=Fc.checkSchemaTableExist(e.schema,e.table);if(n)throw _a(new Error,n,ha.NOT_FOUND,Gc.LOG_LEVELS.ERROR,n,!0);let s=await py.deleteRecordsBefore(e);if(await my(e.schema,e.table),zv.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(l8,"deleteFilesBefore");async function u8(e){let t=Wv(e,"timestamp");if(t)throw _a(t,t.message,ha.BAD_REQUEST,void 0,void 0,!0);if(Fc.transformReq(e),isNaN(e.timestamp))throw _a(new Error,zp.INVALID_VALUE("Timestamp"),ha.BAD_REQUEST,Gc.LOG_LEVELS.ERROR,zp.INVALID_VALUE("Timestamp"),!0);let r=Fc.checkSchemaTableExist(e.schema,e.table);if(r)throw _a(new Error,r,ha.NOT_FOUND,Gc.LOG_LEVELS.ERROR,r,!0);let n=await py.deleteAuditLogsBefore(e);return await my(e.schema,e.table),zv.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(u8,"deleteAuditLogsBefore");async function Qv(e){e.ids&&(e.hash_values=e.ids);let t=t8(e);if(t)throw _a(t,t.message,ha.BAD_REQUEST,void 0,void 0,!0);Fc.transformReq(e);let r=Fc.checkSchemaTableExist(e.schema,e.table);if(r)throw _a(new Error,r,ha.NOT_FOUND,Gc.LOG_LEVELS.ERROR,r,!0);try{await my(e.schema,e.table);let n=await py.deleteRecords(e);return Fc.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${a8}`),n}catch(n){if(n.message===Gc.SEARCH_NOT_FOUND_MESSAGE){let s=new i8;return s.message=Gc.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(Qv,"deleteRecord")});var Qp={};Ue(Qp,{HASH_FUNCTION:()=>a_,hash:()=>Sy,validate:()=>Ty});function Ey(e=o_){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ";return Array.from(i_.randomBytes(e)).map(r=>t[r%t.length]).join("")}function Sy(e,t=a_[Xv?.toUpperCase()]??"sha256"){return gy[t](e)}function Ty(e,t,r=a_[Xv?.toUpperCase()]??"sha256"){return e?d8[r](e,t):!1}var i_,hu,Jv,Xv,o_,Zv,a_,gy,d8,jp=Re(()=>{i_=v(require("node:crypto")),hu=v(require("argon2")),Jv=v(le());k();Xv=(0,Jv.get)(x.AUTHENTICATION_HASHFUNCTION)?.toLowerCase(),o_=16,Zv=9,a_=(n=>(n.MD5="md5",n.SHA256="sha256",n.ARGON2ID="argon2id",n))(a_||{});a(Ey,"generateSalt");gy={md5:a((e,t=void 0)=>{t=t??Ey(Zv);let r=i_.createHash("md5").update(e+t).digest("hex");return t+r},"md5"),sha256:a((e,t=void 0)=>{t=t??Ey(o_);let r=i_.createHash("sha256").update(e+t).digest("hex");return t+r},"sha256"),argon2id:a(async e=>{let t=Ey(o_),r=await hu.hash(e,{type:hu.argon2id,salt:Buffer.from(t)});return t+r},"argon2id")},d8={md5:a((e,t)=>{let r=e.slice(0,Zv);return e===gy.md5(t,r)},"md5"),sha256:a((e,t)=>{let r=e.slice(0,o_);return e===gy.sha256(t,r)},"sha256"),argon2id:a(async(e,t)=>await hu.verify(e.slice(o_),t),"argon2id")};a(Sy,"hash");a(Ty,"validate")});var tU=C((Sbe,eU)=>{var Ay=it(),Qr={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 f8(e){return Qr.password.presence=!0,Qr.username.presence=!0,Qr.role.presence=!0,Qr.active.presence=!0,Ay.validateObject(e,Qr)}a(f8,"addUserValidation");function _8(e){return Qr.password.presence=!1,Qr.username.presence=!0,Qr.role.presence=!1,Qr.active.presence=!1,Ay.validateObject(e,Qr)}a(_8,"alterUserValidation");function h8(e){return Qr.password.presence=!1,Qr.username.presence=!0,Qr.role.presence=!1,Qr.active.presence=!1,Ay.validateObject(e,Qr)}a(h8,"dropUserValidation");eU.exports={addUserValidation:f8,alterUserValidation:_8,dropUserValidation:h8}});var Lt=C((Rbe,nU)=>{"use strict";var{platform:Abe}=require("os"),m8="nats-server.zip",Ry="nats-server",p8=process.platform==="win32"?`${Ry}.exe`:Ry,E8=/^[^\s.,*>]+$/,rU="__request__",g8=a(e=>`${e}.${rU}`,"REQUEST_SUBJECT"),S8={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},T8={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},A8={HUB:"hub.pid",LEAF:"leaf.pid"},R8={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},y8={SUCCESS:"success",ERROR:"error"},b8={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},O8={TXN:"txn",MSGID:"msgid"},mu={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},N8={[mu.ERR]:1,[mu.WRN]:2,[mu.INF]:3,[mu.DBG]:4,[mu.TRC]:5},w8={debug:"-D",trace:"-DVV"};nU.exports={NATS_SERVER_ZIP:m8,NATS_SERVER_NAME:Ry,NATS_BINARY_NAME:p8,PID_FILES:A8,NATS_CONFIG_FILES:T8,SERVER_SUFFIX:R8,NATS_TERM_CONSTRAINTS_RX:E8,REQUEST_SUFFIX:rU,UPDATE_REMOTE_RESPONSE_STATUSES:y8,CLUSTER_STATUS_STATUSES:b8,REQUEST_SUBJECT:g8,SUBJECT_PREFIXES:O8,MSG_HEADERS:S8,LOG_LEVELS:mu,LOG_LEVEL_FLAGS:w8,LOG_LEVEL_HIERARCHY:N8}});var Kn=C((bbe,Nr)=>{"use strict";var oU="username is required",aU="nothing to update, must supply active, role or password to update",cU="password cannot be an empty string",lU="If role is specified, it cannot be empty.",uU="active must be true or false";Nr.exports.addUser=x8;Nr.exports.alterUser=B8;Nr.exports.dropUser=k8;Nr.exports.getSuperUser=V8;Nr.exports.userInfo=F8;Nr.exports.listUsers=Xp;Nr.exports.listUsersExternal=G8;Nr.exports.setUsersWithRolesCache=$c;Nr.exports.findAndValidateUser=Dy;Nr.exports.getClusterUser=K8;Nr.exports.getUsersWithRolesCache=$8;Nr.exports.USERNAME_REQUIRED=oU;Nr.exports.ALTERUSER_NOTHING_TO_UPDATE=aU;Nr.exports.EMPTY_PASSWORD=cU;Nr.exports.EMPTY_ROLE=lU;Nr.exports.ACTIVE_BOOLEAN=uU;var dU=An(),I8=qc(),c_=(jp(),P(Qp)),fU=tU(),l_=zr(),wy=go(),Ci=ie(),_U=require("validate.js"),Iy=ee(),{promisify:C8}=require("util"),Cy=mo(),by=(k(),P(q)),sU=Lt(),P8=Ct(),D8=le(),L8=fo(),{hdb_errors:M8,ClientError:Ks}=he(),{HTTP_STATUS_CODES:Eo,AUTHENTICATION_ERROR_MSGS:yy,HDB_ERROR_MSGS:pu}=M8,{UserEventMsg:Py}=Ys(),Oy=require("lodash"),{server:Jp}=(Mr(),P(Ql)),v8=ee();Jp.getUser=(e,t)=>Dy(e,t,t!=null);Jp.authenticateUser=(e,t)=>Dy(e,t);var hU={username:!0,active:!0,role:!0,password:!0},iU=new Map,U8=C8(I8.delete),Ny=D8.get(by.CONFIG_PARAMS.AUTHENTICATION_HASHFUNCTION)??c_.HASH_FUNCTION.SHA256,Pi;async function x8(e){let t=_U.cleanAttributes(e,hU),r=fU.addUserValidation(t);if(r)throw new Ks(r.message);let n=await l_.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(pu.ROLE_NAME_NOT_FOUND(t.role),Eo.NOT_FOUND);if(n.length>1)throw new Ks(pu.DUP_ROLES_FOUND(t.role),Eo.CONFLICT);n[0].permission.cluster_user===!0&&(t.hash=Cy.encrypt(t.password)),t.password=await c_.hash(t.password,Ny),t.hash_function=Ny,t.role=n[0].id;let s=await dU.insert({operation:"insert",schema:"system",table:"hdb_user",records:[t]});if(Iy.debug(s),await $c(),s.skipped_hashes.length===1)throw new Ks(pu.USER_ALREADY_EXISTS(t.username),Eo.CONFLICT);return wy.signalUserChange(new Py(process.pid)),`${t.username} successfully added`}a(x8,"addUser");async function B8(e){let t=_U.cleanAttributes(e,hU);if(Ci.isEmptyOrZeroLength(t.username))throw new Error(oU);if(Ci.isEmptyOrZeroLength(t.password)&&Ci.isEmptyOrZeroLength(t.role)&&Ci.isEmptyOrZeroLength(t.active))throw new Error(aU);if(!Ci.isEmpty(t.password)&&Ci.isEmptyOrZeroLength(t.password.trim()))throw new Error(cU);if(!Ci.isEmpty(t.active)&&!Ci.isBoolean(t.active))throw new Error(uU);if(!Ci.isEmpty(t.password)&&!Ci.isEmptyOrZeroLength(t.password.trim())&&(H8(t.username)&&(t.hash=Cy.encrypt(t.password)),t.password=await c_.hash(t.password,Ny)),t.role==="")throw new Error(lU);if(t.role){let n=await l_.searchByValue({schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]});if(!n||n.length===0)throw new Ks(pu.ALTER_USER_ROLE_NOT_FOUND(t.role),Eo.NOT_FOUND);if(n.length>1)throw new Ks(pu.DUP_ROLES_FOUND(t.role),Eo.CONFLICT);t.role=n[0].id}let r=await dU.update({operation:"update",schema:"system",table:"hdb_user",records:[t]});return await $c(),wy.signalUserChange(new Py(process.pid)),r}a(B8,"alterUser");function H8(e){let t=!1,r=Pi.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(H8,"isClusterUser");async function k8(e){let t=fU.dropUserValidation(e);if(t)throw new Ks(t.message);if(Pi.get(e.username)===void 0)throw new Ks(pu.USER_NOT_EXIST(e.username),Eo.NOT_FOUND);let r=await U8({table:"hdb_user",schema:"system",hash_values:[e.username]});return Iy.debug(r),await $c(),wy.signalUserChange(new Py(process.pid)),`${e.username} successfully deleted`}a(k8,"dropUser");async function F8(e){let t={};if(!e||!e.hdb_user)return"There was no user info in the body";t=Oy.cloneDeep(e.hdb_user);let r=await l_.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(F8,"userInfo");async function G8(){let e=await Xp();return e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token,delete t.hash_function}),[...e.values()]}a(G8,"listUsersExternal");async function Xp(){let e=await l_.searchByValue({schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]}),t={};for(let s of e)t[s.id]=Oy.cloneDeep(s);if(Object.keys(t).length===0)return null;let r=await l_.searchByValue({schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]}),n=new Map;for(let s of r)s=Oy.cloneDeep(s),s.role=t[s.role],q8(s.role),n.set(s.username,s);return n}a(Xp,"listUsers");function q8(e){if(!e){Iy.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(L8)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}a(q8,"appendSystemTablesToRole");async function $c(e=void 0){e?Pi=e:Pi=await Xp()}a($c,"setUsersWithRolesCache");async function $8(){return Pi||await $c(),Pi}a($8,"getUsersWithRolesCache");async function Dy(e,t,r=!0){Pi||await $c();let n=Pi.get(e);if(!n){if(!r)return{username:e};throw new Ks(yy.GENERIC_AUTH_FAIL,Eo.UNAUTHORIZED)}if(n&&!n.active)throw new Ks(yy.USER_INACTIVE,Eo.UNAUTHORIZED);let s={active:n.active,username:n.username};if(n.refresh_token&&(s.refresh_token=n.refresh_token),n.role&&(s.role=n.role),r===!0){if(iU.get(t)===n.password)return s;{let i=c_.validate(n.password,t,n.hash_function||c_.HASH_FUNCTION.MD5);if(i?.then&&(i=await i),i===!0)iU.set(t,n.password);else throw new Ks(yy.GENERIC_AUTH_FAIL,Eo.UNAUTHORIZED)}}return s}a(Dy,"findAndValidateUser");async function V8(){Pi||await $c();for(let[,e]of Pi)if(e.role.role==="super_user")return e}a(V8,"getSuperUser");async function K8(){let e=await Xp(),t=P8.getConfigFromFile(by.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!(r==null||r?.role?.role!==by.ROLE_TYPES_ENUM.CLUSTER_USER))return r.decrypt_hash=Cy.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+sU.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+sU.SERVER_SUFFIX.ADMIN,r}a(K8,"getClusterUser");var mU=[];Jp.invalidateUser=function(e){for(let t of mU)try{t(e)}catch(r){v8.error("Error invalidating user",r)}};Jp.onInvalidatedUser=function(e){mU.push(e)}});var d_=C((Ibe,SU)=>{"use strict";var Vc=ee(),Yn=(k(),P(q)),Y8=jM(),Nbe=ps(),wbe=po(),W8=Kn(),{validateEvent:pU}=Ys(),u_=Vn(),z8=require("process"),{resetDatabases:Q8}=(xe(),P(ct)),j8={[Yn.ITC_EVENT_TYPES.SCHEMA]:J8,[Yn.ITC_EVENT_TYPES.USER]:gU};async function J8(e){let t=pU(e);if(t){Vc.error(t);return}Vc.trace("ITC schemaHandler received schema event:",e),await Y8(e.message),await X8(e.message)}a(J8,"schemaHandler");async function X8(e){try{u_.resetReadTxn(Yn.SYSTEM_SCHEMA_NAME,Yn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),u_.resetReadTxn(Yn.SYSTEM_SCHEMA_NAME,Yn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),u_.resetReadTxn(Yn.SYSTEM_SCHEMA_NAME,Yn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=Q8();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){Vc.error(t)}}a(X8,"syncSchemaMetadata");var EU=[];async function gU(e){try{try{u_.resetReadTxn(Yn.SYSTEM_SCHEMA_NAME,Yn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),u_.resetReadTxn(Yn.SYSTEM_SCHEMA_NAME,Yn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){Vc.warn(r)}let t=pU(e);if(t){Vc.error(t);return}Vc.trace(`ITC userHandler ${Yn.HDB_ITC_CLIENT_PREFIX}${z8.pid} received user event:`,e),await W8.setUsersWithRolesCache();for(let r of EU)r()}catch(t){Vc.error(t)}}a(gU,"userHandler");gU.addListener=function(e){EU.push(e)};SU.exports=j8});var Ys=C((vbe,AU)=>{"use strict";var Pbe=ee(),Ly=ie(),Z8=(k(),P(q)),{ITC_ERRORS:f_}=Un(),{parentPort:Dbe,threadId:eZ,isMainThread:tZ,workerData:Lbe}=require("worker_threads"),{onMessageFromWorkers:rZ,broadcast:Mbe,broadcastWithAcknowledgement:nZ}=ot();AU.exports={sendItcEvent:sZ,validateEvent:TU,SchemaEventMsg:iZ,UserEventMsg:oZ};var Zp;rZ(async(e,t)=>{Zp=Zp||d_(),TU(e),Zp[e.type]&&await Zp[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function sZ(e){return!tZ&&e.message&&(e.message.originator=eZ),nZ(e)}a(sZ,"sendItcEvent");function TU(e){if(typeof e!="object")return f_.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||Ly.isEmpty(e.type))return f_.MISSING_TYPE;if(!e.hasOwnProperty("message")||Ly.isEmpty(e.message))return f_.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||Ly.isEmpty(e.message.originator))return f_.MISSING_ORIGIN;if(Z8.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return f_.INVALID_EVENT(e.type)}a(TU,"validateEvent");function iZ(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(iZ,"SchemaEventMsg");function oZ(e){this.originator=e}a(oZ,"UserEventMsg")});var go=C((Bbe,OU)=>{"use strict";var RU=(k(),P(q)),xbe=ie(),eE=ee(),yU=WM(),Eu,{sendItcEvent:bU}=Ys();function aZ(e){try{eE.info("signalSchemaChange called with message:",e),Eu=Eu||d_();let t=new yU(RU.ITC_EVENT_TYPES.SCHEMA,e);return Eu.schema(t),bU(t)}catch(t){eE.error(t)}}a(aZ,"signalSchemaChange");function cZ(e){try{eE.trace("signalUserChange called with message:",e),Eu=Eu||d_();let t=new yU(RU.ITC_EVENT_TYPES.USER,e);return Eu.user(t),bU(t)}catch(t){eE.error(t)}}a(cZ,"signalUserChange");OU.exports={signalSchemaChange:aZ,signalUserChange:cZ}});var tE=C((kbe,wU)=>{"use strict";var NU=ie(),lZ=(k(),P(q)),uZ=ee(),dZ=Fp(),fZ=kp(),_Z=go(),{SchemaEventMsg:hZ}=Ys(),mZ="already exists in";wU.exports=pZ;async function pZ(e,t,r){if(NU.isEmptyOrZeroLength(r))return r;let n=[];NU.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 EZ(e,t.schema,t.name,i)})),s}a(pZ,"lmdbCheckForNewAttributes");async function EZ(e,t,r,n){let s=new fZ(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await gZ(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(mZ))uZ.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(EZ,"createNewAttribute");async function gZ(e){let t;return t=await dZ(e),_Z.signalSchemaChange(new hZ(process.pid,lZ.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(gZ,"createAttribute")});var gu=C((Gbe,IU)=>{"use strict";var My=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}};IU.exports=My});var PU=C(($be,CU)=>{"use strict";var SZ=gu(),TZ=(k(),P(q)).OPERATIONS_ENUM,vy=class extends SZ{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(TZ.INSERT,r,n,s,i),this.records=t}};CU.exports=vy});var LU=C((Kbe,DU)=>{"use strict";var AZ=gu(),RZ=(k(),P(q)).OPERATIONS_ENUM,Uy=class extends AZ{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(RZ.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};DU.exports=Uy});var vU=C((Wbe,MU)=>{"use strict";var yZ=gu(),bZ=(k(),P(q)).OPERATIONS_ENUM,xy=class extends yZ{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(bZ.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};MU.exports=xy});var xU=C((Qbe,UU)=>{"use strict";var OZ=gu(),NZ=(k(),P(q)).OPERATIONS_ENUM,By=class extends OZ{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(NZ.DELETE,n,s,t,i),this.original_records=r}};UU.exports=By});var __=C((Xbe,FU)=>{"use strict";var Jbe=require("path"),BU=ht(),wZ=PU(),IZ=LU(),CZ=vU(),PZ=xU(),Su=Ft(),HU=ie(),{CONFIG_PARAMS:DZ}=(k(),P(q)),kU=le();kU.initSync();var rE=(k(),P(q)).OPERATIONS_ENUM,{getTransactionAuditStorePath:LZ}=gt();FU.exports=MZ;async function MZ(e,t){if(kU.get(DZ.LOGGING_AUDITLOG)===!1)return;let r=LZ(e.schema,e.table),n=await BU.openEnvironment(r,e.table,!0),s=vZ(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){BU.initializeDBIs(n,Su.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Su.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[Su.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[Su.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),HU.isEmpty(s.user_name)||n.dbis[Su.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[Su.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(MZ,"writeTransaction");function vZ(e,t){let r=HU.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===rE.INSERT)return new wZ(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===rE.UPDATE)return new IZ(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===rE.UPSERT)return new CZ(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===rE.DELETE)return new PZ(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(vZ,"createTransactionObject")});var Hy=C((tOe,GU)=>{"use strict";var UZ=Xf(),eOe=bf(),h_=(k(),P(q)),xZ=Of(),BZ=xc().insertRecords,HZ=ht(),kZ=ee(),FZ=tE(),{getSchemaPath:GZ}=gt(),qZ=__();GU.exports=$Z;async function $Z(e){try{let{schema_table:t,attributes:r}=UZ(e);xZ(e,r,t.hash_attribute),e.schema!==h_.SYSTEM_SCHEMA_NAME&&(r.includes(h_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(h_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(h_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(h_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await FZ(e.hdb_auth_header,t,r),s=GZ(e.schema,e.table),i=await HZ.openEnvironment(s,e.table),o=await BZ(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await qZ(e,o)}catch(c){kZ.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($Z,"lmdbCreateRecords")});var VU=C((nOe,$U)=>{"use strict";var qU=(k(),P(q)),VZ=Hy(),KZ=bf(),YZ=require("fs-extra"),{getSchemaPath:WZ}=gt();$U.exports=zZ;async function zZ(e){let t=[{name:e.schema,createddate:Date.now()}],r=new KZ(qU.SYSTEM_SCHEMA_NAME,qU.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await VZ(r),await YZ.mkdirp(WZ(e.schema))}a(zZ,"lmdbCreateSchema")});var YU=C((iOe,KU)=>{"use strict";var ky=class{static{a(this,"DeleteRecordsResponseObject")}constructor(t=[],r=[],n=void 0,s=[]){this.deleted=t,this.skipped=r,this.txn_time=n,this.original_records=s}};KU.exports=ky});var jU=C((uOe,QU)=>{"use strict";var WU=ht(),Fy=fn(),Gy=Un().LMDB_ERRORS_ENUM,QZ=Ft(),zU=ee(),aOe=ie(),jZ=require("lmdb"),JZ=YU(),XZ=(k(),P(q)),{OVERFLOW_MARKER:cOe,MAX_SEARCH_KEY_LENGTH:lOe}=QZ,ZZ=XZ.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function e5(e,t,r,n){if(Fy.validateEnv(e),t===void 0)throw new Error(Gy.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(Gy.IDS_REQUIRED):new Error(Gy.IDS_MUST_BE_ITERABLE);try{let s=WU.listDBIs(e);WU.initializeDBIs(e,t,s);let i=new JZ,o,c=[],l=[];for(let _=0,h=r.length;_<h;_++)try{o=r[_];let m=e.dbis[t].get(o);if(!m||n&&m[ZZ]>n){i.skipped.push(o);continue}let S=e.dbis[t].ifVersion(o,jZ.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=Fy.getIndexedValues(T);if(N)for(let M=0,H=N.length;M<H;M++)E.remove(N[M],o)}catch{zU.warn(`cannot delete from attribute: ${R}, ${T}:${o}`)}}});c.push(S),l.push(o),i.original_records.push(m)}catch(m){zU.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=Fy.getNextMonotonicTime(),i}catch(s){throw s}}a(e5,"deleteRecords");QU.exports={deleteRecords:e5}});var m_=C((fOe,XU)=>{"use strict";var Tu=ie(),t5=jU(),r5=ht(),{getSchemaPath:n5}=gt(),s5=__(),i5=ee();XU.exports=o5;async function o5(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(Tu.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(Tu.isEmptyOrZeroLength(e.hash_values)&&!Tu.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];Tu.isEmpty(l)||e.hash_values.push(l)}}if(Tu.isEmptyOrZeroLength(e.hash_values))return JU([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(Tu.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=n5(e.schema,e.table),i=await r5.openEnvironment(s,e.table),o=await t5.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await s5(e,o)}catch(c){i5.error(`unable to write transaction due to ${c.message}`)}return JU(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(o5,"lmdbDeleteRecords");function JU(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(JU,"createDeleteResponse")});var $y=C((mOe,ZU)=>{"use strict";var a5=(k(),P(q)),hOe=fn();function qy(e,t){let r=Object.create(null);if(t.length===1&&a5.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(qy,"parseRow");function c5(e,t,r,n){let s=qy(r,e);n.push(s)}a(c5,"searchAll");function l5(e,t,r,n){let s=qy(r,e);n[t]=s}a(l5,"searchAllToMap");function u5(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(u5,"iterateDBI");function Kc(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(Kc,"pushResults");function d5(e,t,r,n,s,i){t.toString().endsWith(e)&&Kc(t,r,n,s,i)}a(d5,"endsWith");function f5(e,t,r,n,s,i){t.toString().includes(e)&&Kc(t,r,n,s,i)}a(f5,"contains");function _5(e,t,r,n,s,i){t>e&&Kc(t,r,n,s,i)}a(_5,"greaterThanCompare");function h5(e,t,r,n,s,i){t>=e&&Kc(t,r,n,s,i)}a(h5,"greaterThanEqualCompare");function m5(e,t,r,n,s,i){t<e&&Kc(t,r,n,s,i)}a(m5,"lessThanCompare");function p5(e,t,r,n,s,i){t<=e&&Kc(t,r,n,s,i)}a(p5,"lessThanEqualCompare");ZU.exports={parseRow:qy,searchAll:c5,searchAllToMap:l5,iterateDBI:u5,endsWith:d5,contains:f5,greaterThanCompare:_5,greaterThanEqualCompare:h5,lessThanCompare:m5,lessThanEqualCompare:p5,pushResults:Kc}});var Au=C((TOe,o0)=>{"use strict";var ma=ht(),EOe=ee(),Wn=fn(),nE=Ft(),zt=Un().LMDB_ERRORS_ENUM,gOe=ie(),E5=(k(),P(q)),sE=$y(),{parseRow:g5}=sE,SOe=require("lmdb"),{OVERFLOW_MARKER:e0,MAX_SEARCH_KEY_LENGTH:S5}=nE;function t0(e,t,r,n=!1,s=void 0,i=void 0){return Yc(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(t0,"iterateFullIndex");function p_(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,u=!1){return Yc(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(p_,"iterateRangeBetween");function Yc(e,t,r,n){let s=e.database||e,i=ma.openDBI(s,r);i[nE.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&ma.openDBI(s,t);let o;e.database?o=e:(o=e.useReadTransaction(),o.database=e);let c=n(o,i,s,t);return c.transaction=o,e.database||(c.onDone=()=>{o.done()}),c}a(Yc,"setupTransaction");function r0(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(e0)){if(!s)if(r)s=ma.openDBI(e,r);else{let l=ma.listDBIs(e);for(let u=0,f=l.length;u<f&&(s=ma.openDBI(e,l[u]),!s[nE.DBI_DEFINITION_NAME].is_hash_attribute);u++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(r0,"getOverflowCheck");function T5(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 Yc(e,t,t,(o,c,l)=>(iE(r),r=E_(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(u=>g5(u.value,r))))}a(T5,"searchAll");function A5(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);iE(r),r=E_(e.database||e,r);let o=new Map;for(let{key:c,value:l}of t0(e,t,t,n,s,i))o.set(c,sE.parseRow(l,r));return o}a(A5,"searchAllToMap");function R5(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=t0(e,void 0,t,r,n,s),c=o.transaction,l=r0(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(R5,"iterateDBI");function y5(e,t){if(Wn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);return ma.statDBI(e,t).entryCount}a(y5,"countAll");function b5(e,t,r,n,s=!1,i=void 0,o=void 0){return pa(e,r,n),Yc(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(b5,"equals");function O5(e,t,r){return pa(e,t,r),ma.openDBI(e,t).getValuesCount(r)}a(O5,"count");function N5(e,t,r,n,s=!1,i=void 0,o=void 0){return pa(e,r,n),Yc(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(N5,"startsWith");function w5(e,t,r,n,s=!1,i=void 0,o=void 0){return n0(e,t,r,n,s,i,o,!0)}a(w5,"endsWith");function n0(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return pa(e,r,n),Yc(e,null,r,(l,u,f,d)=>{let _=r0(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(e0)?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[nE.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(n0,"contains");function I5(e,t,r,n,s=!1,i=void 0,o=void 0){pa(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),p_(e,t,r,n,l,s,i,o,!0,!1)}a(I5,"greaterThan");function C5(e,t,r,n,s=!1,i=void 0,o=void 0){pa(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),p_(e,t,r,n,l,s,i,o,!1,!1)}a(C5,"greaterThanEqual");function P5(e,t,r,n,s=!1,i=void 0,o=void 0){pa(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),p_(e,t,r,l,n,s,i,o,!1,!0)}a(P5,"lessThan");function D5(e,t,r,n,s=!1,i=void 0,o=void 0){pa(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),p_(e,t,r,l,n,s,i,o,!1,!1)}a(D5,"lessThanEqual");function L5(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 p_(e,t,r,n,s,i,o,c)}a(L5,"between");function M5(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(iE(r),r=E_(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=sE.parseRow(c,r)),o}a(M5,"searchByHash");function v5(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(v5,"checkHashExists");function U5(e,t,r,n,s=[]){return i0(e,t,r,n,s),s0(e,t,r,n,s).map(i=>i[1])}a(U5,"batchSearchByHash");function x5(e,t,r,n,s=[]){i0(e,t,r,n,s);let i=new Map;for(let[o,c]of s0(e,t,r,n,s))i.set(o,c);return i}a(x5,"batchSearchByHashToMap");function s0(e,t,r,n,s=[]){return Yc(e,t,t,(i,o,c)=>{r=E_(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,sE.parseRow(f,r)];s.push(u)}).filter(u=>u)})}a(s0,"batchHashSearch");function i0(e,t,r,n,s){if(Wn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);if(iE(r),n==null)throw new Error(zt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(zt.IDS_MUST_BE_ITERABLE)}a(i0,"initializeBatchSearchByHash");function iE(e){if(!Array.isArray(e))throw e===void 0?new Error(zt.FETCH_ATTRIBUTES_REQUIRED):new Error(zt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(iE,"validateFetchAttributes");function pa(e,t,r){if(Wn.validateEnv(e),t===void 0)throw new Error(zt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(zt.SEARCH_VALUE_REQUIRED);if(r?.length>S5)throw new Error(zt.SEARCH_VALUE_TOO_LARGE)}a(pa,"validateComparisonFunctions");function E_(e,t){return t.length===1&&E5.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=ma.listDBIs(e)),t}a(E_,"setGetWholeRowAttributes");o0.exports={searchAll:T5,searchAllToMap:A5,count:O5,countAll:y5,equals:b5,startsWith:N5,endsWith:w5,contains:n0,searchByHash:M5,setGetWholeRowAttributes:E_,batchSearchByHash:U5,batchSearchByHashToMap:x5,checkHashExists:v5,iterateDBI:R5,greaterThan:I5,greaterThanEqual:C5,lessThan:P5,lessThanEqual:D5,between:L5}});var Ru=C((ROe,d0)=>{var a0=require("lodash"),c0=it(),qe=require("joi"),B5=ie(),{hdb_schema_table:g_,checkValidTable:l0,hdb_table:u0,hdb_database:oE}=Ni(),{handleHDBError:H5,hdb_errors:k5}=he(),{getDatabases:F5}=(xe(),P(ct)),{HTTP_STATUS_CODES:G5}=k5,q5=qe.object({database:oE,schema:oE,table:u0,search_attribute:g_,search_value:qe.any().required(),get_attributes:qe.array().min(1).items(qe.alternatives(g_,qe.object())).optional(),desc:qe.bool(),limit:qe.number().integer().min(1),offset:qe.number().integer().min(0)}),$5=qe.object({database:oE,schema:oE,table:u0,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(g_,qe.object())).optional(),sort:qe.object({attribute:qe.alternatives(g_,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(g_,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()});d0.exports=function(e,t){let r=null;switch(t){case"value":r=c0.validateBySchema(e,q5);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(l0("database",e.schema)),i(l0("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=c0.validateBySchema(e,$5);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=B5.checkGlobalSchemaTable(e.schema,e.table);if(s)return H5(new Error,s,G5.NOT_FOUND);let o=F5()[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=a0.filter(c,f=>f!=="*"&&!f.startsWith?.("$")&&f.attribute!=="*"&&!Array.isArray(f)&&!f.name&&!a0.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((bOe,f0)=>{"use strict";var V5=ht(),K5=Ru(),{getSchemaPath:Y5}=gt();f0.exports=W5;function W5(e){let t=K5(e,"hashes");if(t)throw t;let r=Y5(e.schema,e.table);return V5.openEnvironment(r,e.table)}a(W5,"initialize")});var Ky=C((NOe,_0)=>{"use strict";var z5=Au(),Q5=Vy();_0.exports=j5;async function j5(e){let t=await Q5(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return z5.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(j5,"lmdbGetDataByHash")});var yu=C((IOe,h0)=>{"use strict";var Yy=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};h0.exports=Yy});var p0=C((DOe,m0)=>{"use strict";var POe=yu(),J5=Au(),X5=Vy();m0.exports=Z5;async function Z5(e){let t=await X5(e),r=global.hdb_schema[e.schema][e.table];return J5.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(Z5,"lmdbSearchByHash")});var Ws=C((MOe,E0)=>{"use strict";var Wy=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}};E0.exports=Wy});var aE=C((UOe,y0)=>{"use strict";var jr=Au(),e9=ht(),t9=ie(),$e=Ft(),Wc=(k(),P(q)),r9=fo(),g0=Un().LMDB_ERRORS_ENUM,{getSchemaPath:n9}=gt(),So=Wc.SEARCH_WILDCARDS;async function s9(e,t,r){let n;e.schema===Wc.SYSTEM_SCHEMA_NAME?n=r9[e.table]:n=global.hdb_schema[e.schema][e.table];let s=R0(e,n.hash_attribute,r,t);return T0(e,s,n.hash_attribute,r)}a(s9,"prepSearch");async function T0(e,t,r,n){let s=n9(e.schema,e.table),i=await e9.openEnvironment(s,e.table),o=A0(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(i9(e,r)===!1){let f=e.search_attribute;if(f===r)return n?S0(o,()=>!0):o.map(_=>({[r]:_.key}));let d=a(_=>({[r]:_.value,[f]:_.key}),"toObject");return n?S0(o,d):o.map(d)}let u=e.search_attribute===r?o.map(f=>f.key):o.map(f=>f.value);return n===!0?jr.batchSearchByHashToMap(c,r,e.get_attributes,u):jr.batchSearchByHash(c,r,e.get_attributes,u)}a(T0,"executeSearch");function A0(e,t,r,n){let s,i=n;t.get_attributes.indexOf(n)<0&&(i=void 0);let{reverse:o,limit:c,offset:l}=t;switch(o=typeof o=="boolean"?o:!1,c=Number.isInteger(c)?c:void 0,l=Number.isInteger(l)?l:void 0,r){case $e.SEARCH_TYPES.EQUALS:s=jr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.CONTAINS:s=jr.contains(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.ENDS_WITH:case $e.SEARCH_TYPES._ENDS_WITH:s=jr.endsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.STARTS_WITH:case $e.SEARCH_TYPES._STARTS_WITH:s=jr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return jr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case $e.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return jr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case $e.SEARCH_TYPES.SEARCH_ALL:return jr.searchAll(e,n,t.get_attributes,o,c,l);case $e.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return jr.searchAllToMap(e,n,t.get_attributes,o,c,l);case $e.SEARCH_TYPES.BETWEEN:s=jr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,l);break;case $e.SEARCH_TYPES.GREATER_THAN:case $e.SEARCH_TYPES._GREATER_THAN:s=jr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.GREATER_THAN_EQUAL:case $e.SEARCH_TYPES._GREATER_THAN_EQUAL:s=jr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.LESS_THAN:case $e.SEARCH_TYPES._LESS_THAN:s=jr.lessThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.LESS_THAN_EQUAL:case $e.SEARCH_TYPES._LESS_THAN_EQUAL:s=jr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;default:return Object.create(null)}return s}a(A0,"searchByType");function S0(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(S0,"createMapFromIterable");function i9(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(i9,"checkToFetchMore");function R0(e,t,r,n){if(t9.isEmpty(n)){let s=e.search_value;typeof s=="object"?s=JSON.stringify(s):s=s.toString();let i=s.charAt(0),o=s.charAt(s.length-1),c=!1;if(e.search_attribute===t&&(c=!0),So.indexOf(s)>-1)return r===!0?$e.SEARCH_TYPES.SEARCH_ALL_TO_MAP:$e.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(So[0])<0&&s.indexOf(So[1])<0)return c===!0?r===!0?$e.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:$e.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:$e.SEARCH_TYPES.EQUALS;if(So.indexOf(i)>=0&&So.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),$e.SEARCH_TYPES.CONTAINS;if(So.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),$e.SEARCH_TYPES.ENDS_WITH;if(So.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),$e.SEARCH_TYPES.STARTS_WITH;if(s.includes(So[0])||s.includes(So[1]))return $e.SEARCH_TYPES.EQUALS;throw new Error(g0.UNKNOWN_SEARCH_TYPE)}else switch(n){case Wc.VALUE_SEARCH_COMPARATORS.BETWEEN:return $e.SEARCH_TYPES.BETWEEN;case Wc.VALUE_SEARCH_COMPARATORS.GREATER:return $e.SEARCH_TYPES.GREATER_THAN;case Wc.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return $e.SEARCH_TYPES.GREATER_THAN_EQUAL;case Wc.VALUE_SEARCH_COMPARATORS.LESS:return $e.SEARCH_TYPES.LESS_THAN;case Wc.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return $e.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(g0.UNKNOWN_SEARCH_TYPE)}}a(R0,"createSearchTypeFromSearchObject");y0.exports={executeSearch:T0,createSearchTypeFromSearchObject:R0,prepSearch:s9,searchByType:A0}});var O0=C((HOe,b0)=>{"use strict";var BOe=Ws(),o9=Ru(),a9=ie(),c9=(k(),P(q)),l9=aE();b0.exports=u9;function u9(e,t){if(!a9.isEmpty(t)&&c9.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=o9(e,"value");if(n)throw n;return l9.prepSearch(e,t,!0)}a(u9,"lmdbGetDataByValue")});var S_=C((GOe,N0)=>{"use strict";var FOe=Ws(),d9=Ru(),f9=ie(),_9=(k(),P(q)),h9=aE();N0.exports=m9;async function m9(e,t){if(!f9.isEmpty(t)&&_9.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=d9(e,"value");if(n)throw n;return h9.prepSearch(e,t,!1)}a(m9,"lmdbSearchByValue")});var I0=C((VOe,w0)=>{"use strict";var $Oe=Ft(),zy=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}},Qy=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},jy=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};w0.exports={SearchByConditionsObject:zy,SearchCondition:Qy,SortAttribute:jy}});var M0=C((zOe,L0)=>{"use strict";var YOe=I0().SearchByConditionsObject,p9=Ws(),E9=Ru(),Jy=Au(),cE=Ft(),{Resource:WOe}=(oa(),P(jA)),D0=aE(),g9=$y(),S9=require("lodash"),{getSchemaPath:T9}=gt(),C0=ht(),{handleHDBError:A9,hdb_errors:R9}=he(),{HTTP_STATUS_CODES:y9}=R9,b9=1e8;L0.exports=O9;async function O9(e){let t=E9(e,"conditions");if(t)throw A9(t,t.message,y9.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=T9(e.schema,e.table),n=await C0.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let u of e.conditions)C0.openDBI(n,u.search_attribute);let i=S9.sortBy(e.conditions,u=>{if(u.estimated_count===void 0){let f=u.search_type;f===cE.SEARCH_TYPES.EQUALS?u.estimated_count=Jy.count(n,u.search_attribute,u.search_value):f===cE.SEARCH_TYPES.CONTAINS||f===cE.SEARCH_TYPES.ENDS_WITH?u.estimated_count=1/0:u.estimated_count=b9}return u.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await P0(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(D0.filterByType),d=f.length,_=Jy.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=>g9.parseRow(h,_))}else{for(let d=1;d<i.length;d++){let _=i[d],h=await P0(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=Jy.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(O9,"lmdbSearchByConditions");async function P0(e,t,r,n){let s=new p9(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===cE.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,D0.searchByType(e,s,i,n).map(o=>o.value)}a(P0,"executeConditionSearch")});var T_=C((jOe,v0)=>{"use strict";var N9=(k(),P(q)).OPERATIONS_ENUM,Xy=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=N9.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};v0.exports=Xy});var Zy=C((XOe,q0)=>{"use strict";var H0=Ws(),k0=T_(),F0=S_(),G0=m_(),Rn=(k(),P(q)),U0=ie(),x0=ht(),{getTransactionAuditStorePath:w9,getSchemaPath:I9}=gt(),B0=ee();q0.exports=C9;async function C9(e){try{if(U0.isEmpty(global.hdb_schema[e.schema])||U0.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await P9(e),await D9(e);let t=I9(e.schema,e.table);try{await x0.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=w9(e.schema,e.table);await x0.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(C9,"lmdbDropTable");async function P9(e){let t=new H0(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 F0(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 k0(Rn.SYSTEM_SCHEMA_NAME,Rn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await G0(s)}a(P9,"deleteAttributesFromSystem");async function D9(e){let t=new H0(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 F0(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 k0(Rn.SYSTEM_SCHEMA_NAME,Rn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await G0(s)}catch(i){throw i}}a(D9,"dropTableFromSystem")});var V0=C((eNe,$0)=>{"use strict";var L9=require("fs-extra"),M9=Ws(),v9=yu(),U9=T_(),x9=Zy(),B9=m_(),H9=Ky(),k9=S_(),To=(k(),P(q)),{getSchemaPath:F9}=gt(),{handleHDBError:G9,hdb_errors:q9}=he(),{HDB_ERROR_MSGS:$9,HTTP_STATUS_CODES:V9}=q9;$0.exports=K9;async function K9(e){let t;try{t=await Y9(e.schema);let r=new M9(To.SYSTEM_SCHEMA_NAME,To.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,To.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[To.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await k9(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await x9(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new U9(To.SYSTEM_SCHEMA_NAME,To.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await B9(s);let i=F9(t);await L9.remove(i)}catch(r){throw r}}a(K9,"lmdbDropSchema");async function Y9(e){let t=new v9(To.SYSTEM_SCHEMA_NAME,To.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[To.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await H9(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw G9(new Error,$9.SCHEMA_NOT_FOUND(e),V9.NOT_FOUND,void 0,void 0,!0);return n}a(Y9,"validateDropSchema")});var A_=C((rNe,K0)=>{"use strict";var eb=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};K0.exports=eb});var rb=C((iNe,Y0)=>{"use strict";var W9=require("fs-extra"),lE=ht(),{getTransactionAuditStorePath:z9}=gt(),tb=Ft(),sNe=A_();Y0.exports=Q9;async function Q9(e){let t;try{let r=z9(e.schema,e.table);await W9.mkdirp(r),t=await lE.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{lE.createDBI(t,tb.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),lE.createDBI(t,tb.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),lE.createDBI(t,tb.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(Q9,"createTransactionsAuditEnvironment")});var Q0=C((cNe,z0)=>{"use strict";var nb=(k(),P(q)),W0=ht(),j9=xc(),{getSystemSchemaPath:J9,getSchemaPath:X9}=gt(),aNe=fo(),Z9=Fp(),sb=kp(),e7=ee(),t7=rb();z0.exports=r7;async function r7(e,t){let r=X9(t.schema,t.table),n=new sb(t.schema,t.table,nb.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new sb(t.schema,t.table,nb.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new sb(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await W0.createEnvironment(r,t.table),e!==void 0){let o=await W0.openEnvironment(J9(),nb.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await j9.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 ib(n),await ib(s),await ib(i)}await t7(t)}catch(o){throw o}}a(r7,"lmdbCreateTable");async function ib(e){try{await Z9(e)}catch(t){e7.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(ib,"createAttribute")});var J0=C((uNe,j0)=>{"use strict";var n7=Xf(),s7=Of(),i7=tE(),R_=(k(),P(q)),o7=xc().updateRecords,a7=ht(),{getSchemaPath:c7}=gt(),l7=__(),u7=ee();j0.exports=d7;async function d7(e){try{let{schema_table:t,attributes:r}=n7(e);s7(e,r,t.hash_attribute),e.schema!==R_.SYSTEM_SCHEMA_NAME&&(r.includes(R_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(R_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(R_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(R_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await i7(e.hdb_auth_header,t,r),s=c7(e.schema,e.table),i=await a7.openEnvironment(s,e.table),o=await o7(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await l7(e,o)}catch(c){u7.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(d7,"lmdbUpdateRecords")});var Z0=C((fNe,X0)=>{"use strict";var f7=(k(),P(q)).OPERATIONS_ENUM,ob=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=f7.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};X0.exports=ob});var tx=C((mNe,ex)=>{"use strict";var hNe=Z0(),_7=Xf(),h7=Of(),m7=tE(),y_=(k(),P(q)),p7=xc().upsertRecords,E7=ht(),{getSchemaPath:g7}=gt(),S7=__(),T7=ee(),{handleHDBError:A7,hdb_errors:R7}=he();ex.exports=y7;async function y7(e){let t;try{t=_7(e)}catch(l){throw A7(l,l.message,R7.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;h7(e,n,r.hash_attribute),e.schema!==y_.SYSTEM_SCHEMA_NAME&&(n.includes(y_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(y_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(y_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(y_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await m7(e.hdb_auth_header,r,n),i=g7(e.schema,e.table),o=await E7.openEnvironment(i,e.table),c=await p7(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await S7(e,c)}catch(l){T7.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(y7,"lmdbUpsertRecords")});var nx=C((ENe,rx)=>{"use strict";var ab=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};rx.exports=ab});var ix=C((SNe,sx)=>{"use strict";var cb=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}};sx.exports=cb});var cx=C((RNe,ax)=>{"use strict";var lb=ht(),{getTransactionAuditStorePath:b7}=gt(),ANe=nx(),b_=Ft(),O7=ie(),ox=ix(),N7=require("util").promisify,w7=N7(setTimeout),I7=1e4,C7=100;ax.exports=P7;async function P7(e){let t=b7(e.schema,e.table),r=await lb.openEnvironment(t,e.table,!0),n=lb.listDBIs(r);lb.initializeDBIs(r,b_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new ox;do s=await D7(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 w7(C7);while(s.transactions_deleted>0);return i}a(P7,"deleteAuditLogsBefore");async function D7(e,t){let r=new ox;try{let n=e.dbis[b_.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[b_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];O7.isEmpty(c)||(s=e.dbis[b_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[b_.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>I7)break}return await s,r}catch(n){throw n}}a(D7,"deleteTransactions")});var ux=C((bNe,lx)=>{"use strict";var ub=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};lx.exports=ub});var fx=C((wNe,dx)=>{"use strict";var L7=Ws(),M7=T_(),NNe=ux(),Di=(k(),P(q)),v7=ie(),db=ht(),U7=fo(),x7=S_(),B7=m_(),{getSchemaPath:H7}=gt();dx.exports=k7;async function k7(e,t=!0){let r;e.schema===Di.SYSTEM_SCHEMA_NAME?r=U7[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await G7(e),s=H7(e.schema,e.table),i=await db.openEnvironment(s,e.table);return t===!0&&await F7(e,i,r.hash_attribute),db.dropDBI(i,e.attribute),n}a(k7,"lmdbDropAttribute");async function F7(e,t,r){let n=db.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(F7,"removeAttributeFromAllObjects");async function G7(e){let t=new L7(Di.SYSTEM_SCHEMA_NAME,Di.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Di.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Di.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,Di.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await x7(t)).filter(o=>o[Di.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(v7.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[Di.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new M7(Di.SYSTEM_SCHEMA_NAME,Di.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return B7(i)}a(G7,"dropAttributeFromSystem")});var gx=C((PNe,Ex)=>{"use strict";var fb=ht(),bu=Ft(),CNe=fn(),_b=(k(),P(q)),_x=ie(),{getTransactionAuditStorePath:q7}=gt(),$7=Au(),uE=gu(),V7=ee();Ex.exports=K7;async function K7(e){let t=q7(e.schema,e.table),r=await fb.openEnvironment(t,e.table,!0),n=fb.listDBIs(r);fb.initializeDBIs(r,bu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case _b.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return hx(r,e.search_values);case _b.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,W7(r,e.search_values,s);case _b.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return Y7(r,e.search_values);default:return hx(r)}}a(K7,"readAuditLog");function hx(e,t=[0,Date.now()]){_x.isEmpty(t[0])&&(t[0]=0),_x.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[bu.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 uE,s))}a(hx,"searchTransactionsByTimestamp");function Y7(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[bu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,px(e,i))}return Object.fromEntries(r)}a(Y7,"searchTransactionsByUsername");function W7(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let u=t[c],f=$7.equals(e,bu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,bu.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=px(e,s),o=new Map;for(let c=0;c<i.length;c++){let l=i[c],u=l.timestamp,f=n.get(u);mx(l,"records",r,f,o),mx(l,"original_records",r,f,o)}return Object.fromEntries(o)}a(W7,"searchTransactionsByHashValues");function mx(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 uE(e.operation,e.user_name,i,void 0);d[t]=[c],u.push(d)}}else{let u=new uE(e.operation,e.user_name,i,void 0);u[t]=[c],s.set(l,[u])}}}a(mx,"loopRecords");function px(e,t){let r=[];try{let n=e.dbis[bu.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 uE,i);r.push(o)}}catch(i){V7.warn(i)}return r}catch(n){throw n}}a(px,"batchSearchTransactions")});var Tx=C((vNe,Sx)=>{"use strict";var{getSchemaPath:LNe}=gt(),MNe=ht(),{database:z7}=(xe(),P(ct));Sx.exports={writeTransaction:Q7};async function Q7(e,t,r){return z7({database:e,table:t}).transaction(r)}a(Q7,"writeTransaction")});var bx=C((xNe,yx)=>{"use strict";var{getSchemaPath:Ax}=gt(),Rx=ht();yx.exports={flush:j7,resetReadTxn:J7};async function j7(e,t){return(await Rx.openEnvironment(Ax(e,t),t.toString())).flushed}a(j7,"flush");async function J7(e,t){try{(await Rx.openEnvironment(Ax(e,t),t.toString())).resetReadTxn()}catch{}}a(J7,"resetReadTxn")});var Ix=C((HNe,wx)=>{"use strict";var{Readable:X7}=require("stream"),{getDatabases:Z7}=(xe(),P(ct)),{readSync:eee,openSync:tee,createReadStream:Ox}=require("fs"),{open:ree}=require("lmdb"),Nx=Wf(),nee=zf(),{AUDIT_STORE_OPTIONS:see}=(Ri(),P(Cx)),{INTERNAL_DBIS_NAME:iee,AUDIT_STORE_NAME:oee}=Ft();wx.exports=cee;var hb=32768,aee=100;async function cee(e){let t=e.database||e.schema||"data",r=Z7()[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=ree({noSync:!0,maxDbs:nee.MAX_DBS}),_,h=d.openDB(iee,new Nx(!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),M=f.openDB(E,T);for(let{key:H,version:X,value:W}of M.getRange({start:null,transaction:m,versions:M.useVersions}))_=N.put(H,W,X),S++%aee===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("/"),M=!N,H=new Nx(!M,M);await g(E,H)}e.include_audit&&await g(oee,{...see}),await _;let R=Ox(d.path);return R.headers=l(),R.on("close",()=>{m.done(),d.close()}),R}let o=r[Object.keys(r)[0]].primaryStore,c=tee(o.path);return o.transaction(()=>{let u=Buffer.alloc(hb);eee(c,u,0,hb),o.resetReadTxn();let f=o.useReadTransaction();f.renew();let d=Ox(null,{fd:c,start:hb}),_=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(cee,"getBackup")});var Lx=C((FNe,Dx)=>{"use strict";var lee=ee(),{handleHDBError:uee}=he(),dee=aM(),fee=Fp(),_ee=Hy(),hee=VU(),mee=m_(),pee=Ky(),Eee=p0(),gee=O0(),See=S_(),Tee=M0(),Aee=V0(),Ree=Q0(),yee=J0(),bee=tx(),Oee=cx(),Nee=Zy(),wee=fx(),Iee=gx(),Cee=Tx(),Px=bx(),Pee=Ix(),mb=class extends dee{static{a(this,"LMDBBridge")}async searchByConditions(t){return Tee(t)}async getDataByHash(t){return await pee(t)}async searchByHash(t){return await Eee(t)}async getDataByValue(t,r){return await gee(t,r)}async searchByValue(t){return await See(t)}async createSchema(t){return await hee(t)}async dropSchema(t){return await Aee(t)}async createTable(t,r){return await Ree(t,r)}async dropTable(t){return await Nee(t)}async createAttribute(t){return await fee(t)}async createRecords(t){return await _ee(t)}async updateRecords(t){return await yee(t)}async upsertRecords(t){try{return await bee(t)}catch(r){throw uee(r,null,null,lee.ERR,r)}}async deleteRecords(t){return await mee(t)}async dropAttribute(t){return await wee(t)}async deleteAuditLogsBefore(t){return await Oee(t)}async readAuditLog(t){return await Iee(t)}writeTransaction(t,r,n){return Cee.writeTransaction(t,r,n)}flush(t,r){return Px.flush(t,r)}resetReadTxn(t,r){return Px.resetReadTxn(t,r)}getBackup(t){return Pee(t)}};Dx.exports=mb});var Eb={};Ue(Eb,{add:()=>dE,applyReverse:()=>Mx,getRecordAtTime:()=>pb,rebuildUpdateBefore:()=>fE});function dE(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 fE(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,dE(n,s,i)}else r&&(n||(n={}),n[s]=i)}else n||(n={}),n[s]=e[s];return n}function Mx(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=Dee[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=vx}}function pb(e,t,r){let n=r.rootStore.auditStore,s={...e.value},i=e.localTime;for(;i>t;){let l=n.get(i),u=St(l);switch(u.type){case"put":s=u.getValue(r);break;case"patch":Mx(s,u.getValue(r));break;case"delete":s=null}i=u.previousLocalTime}let o={},c=0;for(let l in s)s[l]===vx&&(o[l]=!0,c++);for(;c>0&&i>0;){let l=n.get(i),u=St(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 Dee,vx,_E=Re(()=>{Ri();a(dE,"add");dE.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)};Dee={add:dE};a(fE,"rebuildUpdateBefore");a(Mx,"applyReverse");vx={};a(pb,"getRecordAtTime")});function yn(e){let t=e.getChanges();return t||(t=Object.create(null),e._setChanges(t)),t}function EE(e,t){let r=e.prototype,n={},s=t.attributes||t.properties||[];for(let c of s){let l=c.name,u,f;if(c.resolve)f={get(){return c.resolve(this,this.getContext?.())},set(d){return c.set(this,d)},configurable:!0};else{switch(c.type){case"String":u=a(function(d){if(!(typeof d=="string"||d==null&&c.nullable!==!1))throw new zn.ClientError(`${l} must be a string, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"ID":u=a(function(d){if(!(typeof d=="string"||d?.length>0&&d.every?.(_=>typeof _=="string")||d==null&&c.nullable!==!1))throw new zn.ClientError(`${l} must be a string, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"Float":case"Number":u=a(function(d){let _=d?.__op__?d.value:d;if(!(typeof _=="number"||d==null&&c.nullable!==!1))throw new zn.ClientError(`${l} must be a number, attempt to assign ${_}`);yn(this)[l]=d},"set");break;case"Int":u=a(function(d){let _=d?.__op__?d.value:d;if(!(_>>0===_||d==null&&c.nullable!==!1))if(typeof _=="number"&&Math.abs((_>>0)-_)<=1)_=Math.round(_),d?.__op__?d.value=_:d=_;else throw new zn.ClientError(`${l} must be an integer between -2147483648 and 2147483647, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"Long":u=a(function(d){let _=d?.__op__?d.value:d;if(!(Math.round(_)===d&&Math.abs(_)<=9007199254740992||d==null&&c.nullable!==!1))if(typeof _=="number"&&Math.abs(_)<=9007199254740992)_=Math.round(_),d?.__op__?d.value=_:d=_;else throw new zn.ClientError(`${l} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"BigInt":u=a(function(d){let _=d?.__op__?d.value:d;if(!(typeof _=="bigint"||d==null&&c.nullable!==!1))if(typeof _=="string"||typeof _=="number")_=BigInt(_),d?.__op__?d.value=_:d=_;else throw new zn.ClientError(`${l} must be a number, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"Boolean":u=a(function(d){if(!(typeof d=="boolean"||d==null&&c.nullable!==!1))throw new zn.ClientError(`${l} must be a boolean, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"Date":u=a(function(d){if(!(d instanceof Date||d==null&&c.nullable!==!1))if(typeof d=="string"||typeof d=="number")d=new Date(d);else throw new zn.ClientError(`${l} must be a Date, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"Bytes":u=a(function(d){if(!(d instanceof Uint8Array||d==null&&c.nullable!==!1))throw new zn.ClientError(`${l} must be a Buffer or Uint8Array, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"Blob":u=a(function(d){if(!(d instanceof Ai||d==null&&c.nullable!==!1))throw new zn.ClientError(`${l} must be a Blob, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"Any":case void 0:u=a(function(d){yn(this)[l]=d},"set");break;default:u=a(function(d){if(!(typeof d=="object"||d==null&&c.nullable!==!1))throw new zn.ClientError(`${l} must be an object, attempt to assign ${d}`);yn(this)[l]=d},"set")}f={get(){let d=this.getChanges?.();if(d&&l in d){let h=d[l];if(h?.__op__){let m=this.getRecord()?.[l];return h.update(m)}return h}let _=this.getRecord()?.[l];if(_&&typeof _=="object"){let h=gb(_,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,xx);break}o=c}while(o&&o!==xx)}function gb(e,t){let r;switch(e.constructor){case Object:return t?(r=t.TrackedObject,r||(t.TrackedObject=r=class extends O_{static{a(this,"TrackedObject")}},EE(r,t)),new r(e)):new O_(e);case Array:let n=new mE(e.length,e);for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=gb(o,t?.elements)),n[s]=o}return n;default:return e}}function gE(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=gE(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 Ou(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=Ou(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=Eb[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=Ou(s);r[n]=s}if(!Array.isArray(e))for(let n in e)Lee.call(e,n)&&(r||(r={...e.getRecord?.()}),r[n]=e[n]);return r?Object.freeze(r):e.getRecord?.()??e}function hE(e){let t=e.getRecord?.();if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[zc]||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(hE(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(hE(s))return!0}else return!0}else return!0}}return!1}var zn,Ux,xx,O_,Lee,zc,mE,pE,Sb=Re(()=>{zn=v(he());_E();gn();a(yn,"getChanges");a(EE,"assignTrackedAccessors");Ux=Object.prototype,xx=new Proxy({},{get(e,t,r){if(typeof t=="string"){if(t==="then"||t==="getRecord"||t==="getChanges")return;if(Ux[t])return Ux[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=gb(s);if(i)return n||(n=Object.create(null),r._setChanges(n)),n[t]=i,i}return s}}});a(gb,"trackObject");O_=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}};EE(O_,{});a(gE,"collapseData");Lee=Object.prototype.hasOwnProperty;a(Ou,"updateAndFreeze");a(hE,"hasChanges");zc=Symbol.for("has-array-changes"),mE=class extends Array{static{a(this,"TrackedArray")}#e;[zc];constructor(t,r){super(t),this.#e=r}getRecord(){return this.#e}splice(...t){return this[zc]=!0,super.splice(...t)}push(...t){return this[zc]=!0,super.push(...t)}pop(){return this[zc]=!0,super.pop()}unshift(...t){return this[zc]=!0,super.unshift(...t)}shift(){return this[zc]=!0,super.shift()}};mE.prototype.constructor=Array;pE=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var Vx={};Ue(Vx,{ResourceBridge:()=>Rb});function yb({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 Hx(e,t){let r=Li(e),n=yb(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;Pt(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&&gE(f)}catch(d){f={message:d.toString()}}return t?{value:{key:u,value:f}}:{value:f}}else return o(),{done:!0}},return(u){return o(),{value:u,done:!0}},throw(u){return o(),{done:!0}}}}}}function Li(e){let t=e.database||e.schema||vee,r=Xe()[t];if(!r)throw(0,zs.handleHDBError)(new Error,Mee.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function kx(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*Fx(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 Gx,SE,zs,qx,Tb,Ab,$x,Mee,vee,Uee,xee,Bx,Rb,Kx=Re(()=>{"use strict";Gx=v(Lx()),SE=v(Ru()),zs=v(he());xe();qx=v(Xf());k();Tb=v(go()),Ab=v(Ys()),$x=v(ie());Sc();Sb();({HDB_ERROR_MSGS:Mee}=zs.hdb_errors),vee="data",Uee=1e4,xee=10,Rb=class extends Gx.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,SE.default)(t,"conditions");if(r)throw(0,zs.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=Li(t);if(!n)throw new zs.ClientError(`Table ${t.table} not found`);let s=t.conditions.map(i);function i(o){return o.conditions?(o.conditions=o.conditions.map(i),o):{attribute:o.search_attribute??o.attribute,comparator:o.search_type??o.comparator,value:o.search_value!==void 0?o.search_value:o.value}}return a(i,"mapCondition"),n.search({conditions:s,operator:t.operator?t.operator.toLowerCase():void 0,limit:t.limit,offset:t.offset,reverse:t.reverse,select:yb(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}]}_t({database:r.database??r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration,audit:r.audit})}async createAttribute(t){return await Li(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=Li(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=a((o,c,l)=>(c={...c},delete c[n],r.primaryStore.ifVersion(o,l,()=>r.primaryStore.put(o,c,l)).then(u=>{if(!u){let{value:f,version:d}=r.primaryStore.getEntry(o);return i(o,f,d)}})),"deleteRecord");for(let{key:o,value:c,version:l}of r.primaryStore.getRange({start:!0,versions:!0}))s=i(o,c,l),await new Promise(u=>setImmediate(u));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){Li(t).dropTable()}createSchema(t){return Nu({database:t.schema,table:null}),Tb.signalSchemaChange(new Ab.SchemaEventMsg(process.pid,Yt.CREATE_SCHEMA,t.schema))}async dropSchema(t){await bb(t.schema),Tb.signalSchemaChange(new Ab.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,qx.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),Pt(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}_&&(_=gE(_));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),Pt(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 kx(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:Hm.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,$x.async_set_timeout)(xee),l=[],s=!0},"chunkDelete");for await(let f of n)l.push(f[r.primaryKey]),c++,c%Uee===0&&await u();return l.length>0&&await u(),s?kx(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,SE.default)(t,"hashes");if(r)throw r;return Hx(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of Hx(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&AA[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,SE.default)(t,"value");if(n)throw n;let s=Li(t);if(!s)throw new zs.ClientError(`Table ${t.table} not found`);let i=t.search_value;i.includes?.("*")&&(i.startsWith("*")?i.endsWith("*")?i!=="*"&&(r="contains",i=i.slice(1,-1)):(r="ends_with",i=i.slice(1)):i.endsWith("*")&&(r="starts_with",i=i.slice(0,-1))),r===Hm.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:yb(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async getDataByValue(t,r){let n=new Map,s=Li(t);t.get_attributes&&!t.get_attributes.includes(s.primaryKey)&&t.get_attributes[0]!=="*"&&t.get_attributes.push(s.primaryKey);for await(let i of this.searchByValue(t,r))n.set(i[s.primaryKey],i);return n}resetReadTxn(t,r){Li({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return Li(t).deleteHistory(t.timestamp,t.cleanup_deleted_records)}async readAuditLog(t){let r=Li(t),n={};switch(t.search_type){case km.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 km.USERNAME:let s=t.search_values;for await(let i of Fx(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return Fx(r,t.search_values?.[0],t.search_values?.[1],t.limit)}}};a(yb,"getSelect");a(Hx,"getRecords");a(Li,"getTable");a(kx,"createDeleteResponse");a(Fx,"groupRecordsInHistory")});var Vn=C((ZNe,Yx)=>{"use strict";var{ResourceBridge:Bee}=(Kx(),P(Vx)),Hee=le();Hee.initSync();var TE;function kee(){return TE||(TE=new Bee,TE)}a(kee,"getBridge");Yx.exports=kee()});var An=C((twe,jx)=>{"use strict";var RE=TR(),xr=ie(),Fee=require("util"),yE=Vn(),Gee=ps(),Wx=ee(),{handleHDBError:Qc,hdb_errors:qee}=he(),{HTTP_STATUS_CODES:jc}=qee,$ee=Fee.promisify(Gee.getTableSchema),Vee="updated",zx="inserted",Qx="upserted";jx.exports={insert:Yee,update:Wee,upsert:zee,validation:Kee,flush:Qee};async function Kee(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 $ee(e.schema,e.table),r=RE(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 Wx.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 Wx.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(Kee,"validation");async function Yee(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=RE(e);if(t)throw Qc(new Error,t.message,jc.BAD_REQUEST);xr.transformReq(e);let r=xr.checkSchemaTableExist(e.schema,e.table);if(r)throw Qc(new Error,r,jc.BAD_REQUEST);let n=await yE.createRecords(e);return AE(zx,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(Yee,"insertData");async function Wee(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=RE(e);if(t)throw Qc(new Error,t.message,jc.BAD_REQUEST);xr.transformReq(e);let r=xr.checkSchemaTableExist(e.schema,e.table);if(r)throw Qc(new Error,r,jc.BAD_REQUEST);let n=await yE.updateRecords(e);return xr.isEmpty(n.existing_rows)?AE(Vee,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):AE(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(Wee,"updateData");async function zee(e){if(e.operation!=="upsert")throw Qc(new Error,"invalid operation, must be upsert",jc.INTERNAL_SERVER_ERROR);let t=RE(e);if(t)throw Qc(new Error,t.message,jc.BAD_REQUEST);xr.transformReq(e);let r=xr.checkSchemaTableExist(e.schema,e.table);if(r)throw Qc(new Error,r,jc.BAD_REQUEST);let n=await yE.upsertRecords(e);return AE(Qx,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(zee,"upsertData");function AE(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===zx?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===Qx?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(AE,"returnObject");function Qee(e){return xr.transformReq(e),yE.flush(e.schema,e.table)}a(Qee,"flush")});var rB=C((nwe,tB)=>{var wu=require("validate.js"),Xx=it(),Iu=(k(),P(q)),{handleHDBError:jee,hdb_errors:Jee}=he(),{HDB_ERROR_MSGS:Qt,HTTP_STATUS_CODES:Xee}=Jee,Ob=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),Zee={STRUCTURE_USER:"structure_user"},Jx=Object.values(Iu.ROLE_TYPES_ENUM),ete="attribute_permissions",tte="attribute_name",{PERMS_CRUD_ENUM:Cu}=Iu,rte=[ete,...Object.values(Cu)],Zx=[Cu.READ,Cu.INSERT,Cu.UPDATE],nte=[tte,...Zx];function ste(e){let t=Ob();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,eB(e,t)}a(ste,"addRoleValidation");function ite(e){let t=Ob();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,eB(e,t)}a(ite,"alterRoleValidation");function ote(e){let t=Ob();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,Xx.validateObject(e,t)}a(ote,"dropRoleValidation");var ate=["operation","role","id","permission","hdb_user","access"];function eB(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)ate.includes(n[o])||s.push(n[o]);s.length>0&&nr(Qt.INVALID_ROLE_JSON_KEYS(s),r);let i=Xx.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{nr(o,r)}),e.permission){let o=cte(e);o&&nr(o,r),Jx.forEach(c=>{e.permission[c]&&!wu.isBoolean(e.permission[c])&&nr(Qt.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(Jx.indexOf(o)<0){if(o===Zee.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=>{rte.includes(f)||nr(Qt.INVALID_PERM_KEY(f),r,o,l)}),Object.values(Cu).forEach(f=>{wu.isDefined(u[f])?wu.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=>{!nte.includes(S)&&S!==Cu.DELETE&&nr(Qt.INVALID_ATTR_PERM_KEY(S),r,o,l)}),!wu.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}Zx.forEach(S=>{wu.isDefined(h[S])?wu.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 lte(r)}a(eB,"customValidate");tB.exports={addRoleValidation:ste,alterRoleValidation:ite,dropRoleValidation:ote};function cte(e){let{operation:t,permission:r}=e;if(t===Iu.OPERATIONS_ENUM.ADD_ROLE||t===Iu.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?Iu.ROLE_TYPES_ENUM.SUPER_USER:Iu.ROLE_TYPES_ENUM.CLUSTER_USER;return Qt.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(cte,"validateNoSUPerms");function lte(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 jee(new Error,n,Xee.BAD_REQUEST)}else return null}a(lte,"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 w_=C((owe,oB)=>{"use strict";var nB=An(),sB=zr(),ute=qc(),wb=rB(),Ib=go(),iwe=require("uuid").v4,dte=require("util"),bE=(k(),P(q)),fte=ie(),Cb=sB.searchByValue,_te=sB.searchByHash,hte=dte.promisify(ute.delete),mte=Ws(),pte=yu(),{hdb_errors:Ete,handleHDBError:Jc}=he(),{HDB_ERROR_MSGS:iB,HTTP_STATUS_CODES:N_}=Ete,{UserEventMsg:Pb}=Ys();oB.exports={addRole:gte,alterRole:Ste,dropRole:Tte,listRoles:Ate};function Nb(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(Nb,"scrubRoleDetails");async function gte(e){let t=wb.addRoleValidation(e);if(t)throw t;e=Nb(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 Cb(r)||[])}catch(i){throw Jc(i)}if(n&&n.length>0)throw Jc(new Error,iB.ROLE_ALREADY_EXISTS(e.role),N_.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 nB.insert(s),Ib.signalUserChange(new Pb(process.pid)),e=Nb(e),e}a(gte,"addRole");async function Ste(e){let t=wb.alterRoleValidation(e);if(t)throw t;e=Nb(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await nB.update(r)}catch(s){throw Jc(s)}if(n&&n?.message==="updated 0 of 1 records")throw Jc(new Error,"Invalid role id",N_.BAD_REQUEST,void 0,void 0,!0);return await Ib.signalUserChange(new Pb(process.pid)),e}a(Ste,"alterRole");async function Tte(e){let t=wb.dropRoleValidation(e);if(t)throw Jc(new Error,t,N_.BAD_REQUEST,void 0,void 0,!0);let r=new pte(bE.SYSTEM_SCHEMA_NAME,bE.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await _te(r));if(n.length===0)throw Jc(new Error,iB.ROLE_NOT_FOUND,N_.NOT_FOUND,void 0,void 0,!0);let s=new mte(bE.SYSTEM_SCHEMA_NAME,bE.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await Cb(s)),o=!1;if(fte.isEmptyOrZeroLength(i)===!1){for(let l=0;l<i.length;l++)if(i[l].active===!0){o=!0;break}}if(o===!0)throw Jc(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,N_.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await hte(c),Ib.signalUserChange(new Pb(process.pid)),`${n[0].role} successfully deleted`}a(Tte,"dropRole");async function Ate(){return Cb({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(Ate,"listRoles")});var Db={};Ue(Db,{start:()=>lB,startOnMainThread:()=>bte});function lB({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r){let n=(0,aB.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(Rte.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 yte(i)}}}async function yte(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,cB.isEqual)(i,e)?void 0:(e.id=r.id,(0,OE.alterRole)(e))}return(0,OE.addRole)(e)}var OE,aB,cB,Rte,bte,uB=Re(()=>{xe();OE=v(w_()),aB=require("yaml"),cB=require("lodash"),Rte=["super_user","cluster_user","structure_user"];a(lB,"start");a(yte,"ensureRole");bte=lB});async function NE(e){let t=(0,_B.pathToFileURL)(e).toString();if(Ote)return I_||(I_=Nte(Ite)),(await(await I_).import(t)).namespace;try{return await import(t)}catch(r){try{(await import("internal/util")).default.decorateErrorStack(r)}catch{}throw r}}async function Nte(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),I_=new Compartment({console,Math,Date,fetch:wte,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,fB.extname)(r)||(r+=".js"),r)},importHook:a(async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){Object.assign(s,{Resource:Yr,tables:Qn,databases:We})}};let n=await(0,dB.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)},"importHook")}),I_}function wte(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 Ite(){return{Resource:Yr,tables:Qn}}var dB,fB,_B,Ote,I_,Lb=Re(()=>{oa();xe();dB=require("fs/promises"),fB=require("path"),_B=require("url"),Ote=!1;a(NE,"secureImport");a(Nte,"getCompartment");a(wte,"secureOnlyFetch");a(Ite,"getGlobalVars")});var vb={};Ue(vb,{handleFile:()=>Cte});async function Cte(e,t,r,n){let s=new Map,i=await NE(r);c(i.default)&&n.set((0,Mb.dirname)(t),i.default),o(i,(0,Mb.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 Mb,hB=Re(()=>{Lb();Mb=require("path");a(Cte,"handleFile")});var xb={};Ue(xb,{start:()=>Pte});function Pte({resources:e}){e.set("login",Ub),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var Ub,mB=Re(()=>{oa();a(Pte,"start");Ub=class extends Yr{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 v_={};Ue(v_,{addAnalyticsListener:()=>M_,calculateCPUUtilization:()=>vB,diffResourceUsage:()=>UB,recordAction:()=>Mt,recordActionBinary:()=>jn,setAnalyticsEnabled:()=>Dte});function Dte(e){CB=e}function Lte(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 Mte(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},IE.set(e,o)}function Mt(e,t,r,n,s){if(!CB)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=IE.get(i);o?Lte(e,o):Mte(i,e,t,r,n,s),wE||vte()}function jn(e,t,r,n,s){Mt(!!e,t,r,n,s)}function M_(e){LB.push(e)}function vte(){wE=performance.now(),setTimeout(async()=>{let e=performance.now()-wE;wE=0;let t=[],r={time:Date.now(),period:e,threadId:Xc.threadId,metrics:t};for(let[s,i]of IE){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 MB){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 xB()}let n=process.memoryUsage();t.push({metric:"memory",threadId:Xc.threadId,byThread:!0,...n});for(let s of LB)s(t);IE=new Map,Xc.parentPort?Xc.parentPort.postMessage({type:DB,report:r}):kB({report:r})},PB).unref()}function CE(e,t,r){let n={id:(0,D_.getNextMonotonicTime)(),metric:t,...r};e.primaryStore.put(n.id,n,{append:!0}).then(s=>{s||e.primaryStore.put(n.id,n)})}function vB(e,t){let r=e.userCPUTime+e.systemCPUTime;return Math.round(r/t*100)/100}function UB(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 Ute(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};CE(e,"table-size",l),Zc.trace?.(`table ${o} size metric: ${JSON.stringify(l)}`),n+=c}return n}function pB(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s?.getAuditSize();if(!i)return;let o=IB.default.statSync(s.primaryStore.env.path).size,c=Ute(e,r,n),l=o-c,u={database:r,size:o,used:c,free:l,audit:i};CE(e,"database-size",u),Zc.trace?.(`database ${r} size metric: ${JSON.stringify(u)}`)}catch(s){Zc.warn?.("Error getting DB size metrics",s)}}function EB(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};CE(e,"storage-volume",o),Zc.trace?.(`db ${r} storage volume metrics: ${JSON.stringify(o)}`)}catch(s){Zc.warn?.("Error getting DB volume metrics",s)}}async function xte(e,t=6e4){let r=Hb(),n=BB(),s=new Promise(E=>{let T=performance.now();setImmediate(()=>{let N=performance.now();N-T>5e3&&Zc.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&&Zc.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:M}=T;for(let H of N||[]){let{path:X,method:W,type:$,metric:se,count:z,total:fe,distribution:ue,threads:Z,...Ae}=H;z||(z=1);let me=se+(X?"-"+X:"");W!==void 0&&(me+="-"+W),$!==void 0&&(me+="-"+$);let ye=c.get(me);if(ye){if(ye.threads){let dt=ye.threads[M];if(dt)ye=dt;else{ye.threads[M]={...Ae};continue}}ye.count||(ye.count=1);let Ht=ye.count;for(let dt in Ae){let Ln=Ae[dt];typeof Ln=="number"&&(ye[dt]=(ye[dt]*Ht+Ln*z)/(Ht+z))}ye.count+=z,fe>=0&&(ye.total+=fe,ye.ratio=ye.total/ye.count)}else ye={period:t,...H},delete ye.distribution,c.set(me,ye),ye.byThread&&(ye.threads=[],ye.threads[M]={...Ae},u.push(ye));if(ue){ue=ue.map(dt=>typeof dt=="number"?{value:dt,count:1}:dt);let Ht=l.get(me);Ht?Ht.push(...ue):l.set(me,ue)}}await xB()}for(let E of u){let{path:T,method:N,type:M,metric:H,count:X,total:W,distribution:$,threads:se,...z}=E;se=se.filter(fe=>fe);for(let fe in z){if(typeof E[fe]!="number")continue;let ue=0;for(let Z of se){let Ae=Z[fe];typeof Ae=="number"&&(ue+=Ae)}E[fe]=ue}E.count=se.length,delete E.threads,delete E.byThread}for(let[E,T]of l){let N=c.get(E);T.sort((dt,Ln)=>dt.value>Ln.value?1:-1);let M=N.count-1,H=[],X=0,W=0,$;for(let dt of MB){let Ln=M*dt;for(;X<Ln;)$=T[W++],X+=$.count,W===1&&X--;let Vr=T[W>1?W-2:0];$||($=T[0]),H.push($.value-($.value-Vr.value)*(X-Ln)/$.count)}let[se,z,fe,ue,Z,Ae,me,ye,Ht]=H;Object.assign(N,{p1:se,p10:z,p25:fe,median:ue,p75:Z,p90:Ae,p95:me,p99:ye,p999:Ht})}let d;for(let[E,T]of c)T.id=(0,D_.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,D_.getNextMonotonicTime)(),T={id:E,metric:"main-thread-utilization",idle:h-gB,active:m-SB,taskQueueLatency:await s,time:_,...process.memoryUsage()};n.primaryStore.put(E,T,{append:!0}).then(N=>{N||n.primaryStore.put(E,T)})}gB=h,SB=m;let S=process.resourceUsage(),g=UB(C_,S);g.time=_,g.period=C_.time?_-C_.time:t,g.cpuUtilization=vB(C_,g.period),CE(n,"resource-usage",g),C_=g;let R=Xe();pB(n,R),pB(n,{system:R.system}),EB(n,R),EB(n,{system:R.system})}async function TB(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function Hb(){return AB||(AB=_t({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function BB(){return RB||(RB=_t({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function kte(){HB=!0;let e=(0,L_.get)(x.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await xte(PB,e),await TB(Hb(),Bte),await TB(BB(),Hte)},Math.min(e/2,2147483647)).unref()}function kB(e,t){let r=e.report;r.threadId=t?.threadId||Xc.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(yB+=n.mean*n.count);r.totalBytesProcessed=yB,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(bB.get(t))}),bB.set(t,t.performance.eventLoopUtilization())),r.id=(0,D_.getNextMonotonicTime)(),Hb().primaryStore.put(r.id,r),HB||kte(),Fte&&(FB=qte(r))}async function qte(e){if(await FB,!Ea){let r=(0,P_.dirname)((0,NB.getLogFilePath)());try{Ea=await(0,Bb.open)((0,P_.join)(r,"analytics.log"),"r+")}catch{Ea=await(0,Bb.open)((0,P_.join)(r,"analytics.log"),"w+")}}let t=(await Ea.stat()).size;if(t>Gte){let r=Buffer.alloc(t);await Ea.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await Ea.write(r,{position:0}),await Ea.truncate(r.length),t=r.length}await Ea.write(JSON.stringify(e)+`
|
|
19
|
+
`},"serialize"),compressible:!1,q:.8});Wr.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()}});$L={type:"application/json",serializeStream:Lf,serialize:Bf,deserialize:m3,q:.5};Wr.set("*/*",$L);Wr.set("",$L);a(m3,"tryJSONParse");a(kf,"registerContentHandlers");p3=require("fastify-plugin"),E3=p3(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:o,type:c}=yp(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(yp,"findBestSerializer");HL=_R.default.get(x.HTTP_COMPRESSIONTHRESHOLD);a(Ff,"serialize");a(ua,"serializeMessage");a(dR,"asyncSerialization");a(fR,"hasAsyncSerialization");a(g3,"streamToBuffer");S3=["ascii","utf8","utf-8","utf16le","utf-16le","ucs2","ucs-2","base64","base64url","latin1","binary","hex"];a(T3,"isBufferEncoding");a(A3,"parseContentType");a(lo,"getDeserializer");a(R3,"deserializerUnknownType");a(y3,"transformIterable");a(Rp,"toCsvStream")});var gR={};Ue(gR,{start:()=>L3});function b3(e){if(e.kind!==Me.Kind.OPERATION_DEFINITION&&e.kind!==Me.Kind.FRAGMENT_DEFINITION)throw new Or(`Unexpected non-executable definition type ${e.kind}.`)}function KL(e){if(typeof e!="object"||e===null)throw new bi("Request body must be an object.");if(!("query"in e))throw new bi("Request body must contain a `query` field.");if(typeof e.query!="string")throw new bi("Request body `query` field must be a string.");if("variables"in e&&(typeof e.variables!="object"||e.variables===null))throw new bi("Request body `variables` field must be an object.");if("operationName"in e&&typeof e.operationName!="string")throw new bi("Request body `operationName` field must be a string.")}function ER(e){return parseInt(e.value,10)}function WL(e){return parseFloat(e.value)}function zL(e,t,r){let n=r.get(e.name.value);return QL(n)?jL(n,t):{attribute:t,value:n}}function QL(e){return typeof e=="object"&&e!=null&&!Array.isArray(e)}function jL(e,t){return t=typeof t=="string"?[t]:t,Object.entries(e).flatMap(([r,n])=>(t=[...t,r],QL(n)?jL(n,t):{attribute:t,value:n}))}function O3(e,t,r){switch(t=[...t,e.name.value],e.value.kind){case Me.Kind.NULL:return{attribute:t,value:null};case Me.Kind.INT:return{attribute:t,value:ER(e.value)};case Me.Kind.FLOAT:return{attribute:t,value:WL(e.value)};case Me.Kind.BOOLEAN:case Me.Kind.STRING:return{attribute:t,value:e.value.value};case Me.Kind.VARIABLE:return zL(e.value,t,r);case Me.Kind.OBJECT:return JL(e.value,t,r);case Me.Kind.LIST:case Me.Kind.ENUM:default:throw new Or(`Value type, ${e.value.kind}, is not supported.`)}}function JL(e,t,r){return e.fields.flatMap(n=>O3(n,t,r))}function N3(e,t){switch(e.value.kind){case Me.Kind.NULL:return{attribute:e.name.value,value:null};case Me.Kind.INT:return{attribute:e.name.value,value:ER(e.value)};case Me.Kind.FLOAT:return{attribute:e.name.value,value:WL(e.value)};case Me.Kind.BOOLEAN:case Me.Kind.STRING:return{attribute:e.name.value,value:e.value.value};case Me.Kind.VARIABLE:return zL(e.value,e.name.value,t);case Me.Kind.OBJECT:return JL(e.value,[e.name.value],t);case Me.Kind.LIST:case Me.Kind.ENUM:default:throw new Or(`Argument type, ${e.value.kind}, is not supported.`)}}function w3(e,t){return e.flatMap(r=>N3(r,t))}function bp(e,t){return e.selections.flatMap(r=>{switch(r.kind){case Me.Kind.FIELD:return r;case Me.Kind.FRAGMENT_SPREAD:{let n=r.name.value,s=t.get(n);if(s==null)throw new Or(`Fragment \`${n}\` not found.`);return bp(s.selectionSet,t)}case Me.Kind.INLINE_FRAGMENT:return bp(r.selectionSet,t)}})}function XL(e,t){return bp(e,t).map(r=>r.selectionSet?.selections.length>0?{name:r.name.value,select:XL(r.selectionSet,t)}:r.name.value)}async function I3(e,t,r,n){let s=_s.getMatch(e.name.value,"graphql");if(s===void 0)throw new Or(`Resource \`${e.name.value}\` not found.`);let i=s.Resource,o={select:XL(e.selectionSet,r),conditions:w3(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 ZL(e){switch(e.kind){case Me.Kind.NULL:return null;case Me.Kind.INT:return ER(e);case Me.Kind.FLOAT:return parseFloat(e.value);case Me.Kind.STRING:case Me.Kind.BOOLEAN:return e.value;case Me.Kind.OBJECT:return e.fields.reduce((t,r)=>({[r.name.value]:ZL(r.value),...t}),{});case Me.Kind.LIST:case Me.Kind.ENUM:default:throw new Or(`Value type, ${e.kind}, is not supported.`)}}function C3(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=ZL(n.defaultValue)),n.type.kind===Me.Kind.NON_NULL_TYPE&&!(s in t)&&i===void 0)throw new Or(`Variable $${s} is required, but not provided.`);r.set(n.variable.name.value,i??null)}return r}async function P3(e,t,r,n){if(e.operation===Me.OperationTypeNode.SUBSCRIPTION)throw new Or("Subscriptions are not supported.");if(e.operation===Me.OperationTypeNode.MUTATION)throw new Or("Mutations are not supported yet.");let s=C3(e.variableDefinitions,t),i=await Promise.all(bp(e.selectionSet,r).map(c=>I3(c,s,r,n))),o={data:{}};for(let[c,l]of i)o.data[c]=l;return o}async function YL({query:e,variables:t={},operationName:r},n){let s=Me.parse(e),i=new Map,o=new Map;for(let u of s.definitions)if(b3(u),u.kind===Me.Kind.FRAGMENT_DEFINITION)o.set(u.name.value,u);else{if(u.name===void 0&&s.definitions.length>1)throw new Or("Unnamed operations are only allowed when there is a single operation in the document.");let f=u.name?.value??"Unnamed Query";if(i.has(f))throw new Or(`Duplicate operation definition: ${f}`);i.set(f,u)}let c;if(r==null)if(i.size===1)c=i.entries().next().value[1];else throw new Or("Operation name is required when there are multiple operations in the document.");else if(c=i.get(r),c==null)throw new Or(`Operation \`${r}\` not found.`);let l=await P3(c,t,o,n);return{status:200,headers:{"Content-Type":"application/graphql-response+json; charset=utf-8"},body:JSON.stringify(l)}}async function D3(e){switch(e.method){case"GET":{let t=new URLSearchParams(e.url.split("?")[1]),r={};for(let[n,s]of t)r[n]=n==="variables"||n==="extensions"?JSON.parse(s):s;return KL(r),YL(r,e)}case"POST":{let r=await lo(e.headers.get("content-type"),!0)(e._nodeRequest);return KL(r),YL(r,e)}default:throw new bi("Method Not Allowed",405,{Allow:"GET, POST"})}}function L3(e){e.server.http(async(t,r)=>{if(!t.url.startsWith("/graphql"))return r(t);try{return await D3(t)}catch(n){logger.error(n);let s=t.headers.get("accept")??"application/graphql-response+json";switch(s){case"application/json":{if(n instanceof bi)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json",...n.headers}};if(n instanceof Me.GraphQLError)return{status:200,body:JSON.stringify({errors:[n]}),headers:{"Content-Type":"application/json"}};if(n instanceof Or)return{status:200,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json"}};if(n instanceof Error)return{status:500,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json"}};break}default:logger.info(`Unsupported accept header, ${s}, defaulting to application/graphql-response+json`);case"application/graphql-response+json":{if(n instanceof bi)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json",...n.headers}};if(n instanceof Me.GraphQLError)return{status:400,body:JSON.stringify({errors:[n]}),headers:{"Content-Type":"application/graphql-response+json"}};if(n instanceof Or)return{status:400,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json"}};if(n instanceof Error)return{status:500,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json"}};break}}throw n}},{port:e.port,securePort:e.securePort})}var Me,Or,bi,eM=Re(()=>{Me=v(require("graphql"));oo();su();a(b3,"assertExecutableDefinitionNode");a(KL,"assertRequestParams");a(ER,"processIntValueNode");a(WL,"processFloatValueNode");a(zL,"processVariableNode");a(QL,"isObject");a(jL,"transformObjectIntoQueryCondition");a(O3,"processObjectFieldNode");a(JL,"processObjectValueNode");a(N3,"processArgumentNode");a(w3,"buildConditionsQuery");a(bp,"fillInFragments");a(XL,"buildSelectQuery");a(I3,"processFieldNode");a(ZL,"processConstValueNode");a(C3,"resolveVariables");a(P3,"executeOperation");a(YL,"resolver");Or=class extends Error{static{a(this,"GraphQLQueryingError")}},bi=class extends Error{static{a(this,"HTTPError")}statusCode;headers;constructor(t,r=400,n={}){super(t),this.statusCode=r,this.headers=n}};a(D3,"graphqlQueryingHandler");a(L3,"start")});var Ni=C((jRe,nM)=>{"use strict";var rM=ie(),tM=(k(),P(q)),du=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Oi=require("joi"),da={schema_format:{pattern:du,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},M3=Oi.alternatives(Oi.string().min(1).max(da.schema_length.maximum).pattern(du).messages({"string.pattern.base":"{:#label} "+da.schema_format.message}),Oi.number(),Oi.array()).required(),v3=Oi.alternatives(Oi.string().min(1).max(da.schema_length.maximum).pattern(du).messages({"string.pattern.base":"{:#label} "+da.schema_format.message}),Oi.number()),U3=Oi.alternatives(Oi.string().min(1).max(da.schema_length.maximum).pattern(du).messages({"string.pattern.base":"{:#label} "+da.schema_format.message}),Oi.number()).required();function x3(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>da.schema_length.maximum?`'${e}' maximum of 250 characters`:du.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(x3,"checkValidTable");function B3(e,t){return rM.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(B3,"validateSchemaExists");function H3(e,t){let r=t.state.ancestors[0].schema;return rM.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(H3,"validateTableExists");function k3(e,t){return e.toLowerCase()===tM.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${tM.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(k3,"validateSchemaName");nM.exports={common_validators:da,schema_regex:du,hdb_schema_table:M3,validateSchemaExists:B3,validateTableExists:H3,validateSchemaName:k3,checkValidTable:x3,hdb_database:v3,hdb_table:U3}});var TR=C((XRe,iM)=>{var{hdb_table:F3,hdb_database:sM}=Ni(),G3=it(),SR=require("joi"),q3={undefined:"undefined",null:"null"},$3=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||q3[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"),V3=SR.object({database:sM,schema:sM,table:F3,records:SR.array().items(SR.object().custom($3)).required()});iM.exports=function(e){return G3.validateBySchema(e,V3)}});var aM=C((eye,oM)=>{"use strict";var AR=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")}};oM.exports=AR});var lM=C((rye,cM)=>{"use strict";var RR=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};cM.exports=RR});var hM={};Ue(hM,{HAS_EXPIRATION:()=>Ip,HAS_RESIDENCY_ID:()=>IR,HAS_STRUCTURE_UPDATE:()=>Pp,LAST_TIMESTAMP_PLACEHOLDER:()=>Vf,LOCAL_TIMESTAMP:()=>K3,METADATA:()=>Pc,NEW_TIMESTAMP_PLACEHOLDER:()=>dM,NO_TIMESTAMP:()=>Np,PENDING_LOCAL_TIME:()=>CR,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>wR,RecordEncoder:()=>NR,TIMESTAMP_ASSIGN_LAST:()=>W3,TIMESTAMP_ASSIGN_NEW:()=>fM,TIMESTAMP_ASSIGN_PREVIOUS:()=>_M,TIMESTAMP_PLACEHOLDER:()=>Op,TIMESTAMP_RECORD_PREVIOUS:()=>yR,handleLocalTimeForGets:()=>Dp,recordUpdater:()=>PR,removeEntry:()=>Lc});function Q3(){return $f[0]=$f[0]^64,Y3.getFloat64(0)}function Dp(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?.[Pc];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?.[Pc]>=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?.[Pc];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,Cc.push(new WeakRef(this))),c.call(this)},o.prototype.done=function(){if(l.call(this),this.isDone)for(let u=0;u<Cc.length;u++){let f=Cc[u].deref();(!f||f.isDone||f.isCommitted)&&Cc.splice(u--,1)}},o.prototype.done.isTracked=!0}return e}function PR(e,t,r){return function(n,s,i,o,c=-1,l,u,f="put",d,_){l==null?Ic=Np:d?Ic=i?.localTime?yR|_M:Np:Ic=l?i?.localTime?yR|16384:fM|16384:Np;let h=u?.expiresAt;if(h>=0&&(c|=Ip),qf=c,bR=h,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let m={version:o,instructedWrite:Ic>0},S,g=0;try{let R=i?.residencyId,E=u?.residencyId;E&&(OR=E,qf|=IR,g|=Mc),R!==E&&(g|=vc,R||(R=0)),c&Ip&&(g|=Yf),u?.originatingOperation&&(g|=Kf),d&&(m.ifVersion=S=i?.version??null),i&&i.value&&f!=="message"&&i.metadataFlags&Ur&&(!i.localTime||!r.getBinaryFast(i.localTime))&&la(i.value);let T;if(s!==void 0&&(T=Tp(()=>e.put(n,s,m),n,e.rootStore),Oc&&(g|=Ur)),l){let N=u?.user?.username;if(_&&(Tp(()=>e.encoder.encode(_),n,e.rootStore),Oc&&(g|=Ur)),e.encoder.hasStructureUpdate&&(g|=Pp,e.encoder.hasStructureUpdate=!1),d&&i?.localTime){let M=i?.localTime,H=r.get(M);if(H){let X=St(H).previousLocalTime;return T=r.put(M,Dc(o,t,n,X,u?.nodeId??server.replication.getThisNodeId(r)??0,N,f,Gf,g,E,R,h),{ifVersion:S}),T}}T=r.put(s===void 0?dM:Vf,Dc(o,t,n,i?.localTime?1:0,u?.nodeId??server.replication?.getThisNodeId(r)??0,N,f,Gf,g,E,R,h,u?.originatingOperation),{instructedWrite:!0,ifVersion:S})}return T}catch(R){throw R.message+=" id: "+n+" options: "+m,R}}}function Lc(e,t,r){if(t)return t.value&&t.metadataFlags&Ur&&!e.auditStore?.getBinaryFast(t.localTime)&&la(t.value),e.remove(t.key,r)}var uM,wp,Op,Vf,wR,dM,K3,Pc,$f,Y3,Np,fM,W3,_M,yR,Ip,IR,CR,Pp,z3,Gf,Ic,qf,bR,OR,NR,Cc,fu=Re(()=>{uM=require("msgpackr");Ri();wp=v(ee());gn();gn();Op=new Uint8Array([1,1,1,1,4,64,0,0]),Vf=new Uint8Array([1,1,1,1,1,0,0,0]),wR=new Uint8Array([1,1,1,1,3,64,0,0]),dM=new Uint8Array([1,1,1,1,0,64,0,0]),K3=Symbol("local-timestamp"),Pc=Symbol("metadata"),$f=new Uint8Array(8),Y3=new DataView($f.buffer,0,8),Np=0,fM=0,W3=1,_M=3,yR=4,Ip=16,IR=32,CR=1,Pp=256,Ic=0,qf=-1,bR=-1,OR=0,NR=class extends uM.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(s,i){if(Ic||qf>=0){let o=0,c=Ic;c&&(o+=8,Ic=0);let l=qf,u=bR,f=OR;l>=0&&(o+=4,qf=-1,u>=0&&(o+=8,bR=-1),f&&(o+=4,OR=0));let d=z3=r.call(this,s,i|2048|o);Gf=d.subarray((d.start||0)+o,d.end);let _=d.start||0;return c&&(Op[4]=c,Op[5]=c>>8,d.set(Op,_),_+=8),Oc&&(l|=Ur),l>=0&&((d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setUint32(_,l|Cp<<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 Gf=r.call(this,s,i),Gf};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($f,0,c),c+=8;else for(let _=0;_<8;_++)$f[_]=t[c++];l=Q3(),i=t[c]}let u,f;i<32&&(i===Cp?(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&Ip&&(u=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8),o&IR&&(f=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4));let d=io(()=>r?.valueAsBuffer?t.subarray(c,s):super.decode(t.subarray(c,s),s-c),this.rootStore);return{localTime:l,value:d,[Pc]:o,expiresAt:u,residencyId:f}}return r?.valueAsBuffer?t:io(()=>super.decode(t,r),this.rootStore)}catch(c){return wp.error("Error decoding record",c,"data: "+t.slice(0,40).toString("hex")),null}}};a(Q3,"getTimestamp");a(Dp,"handleLocalTimeForGets");Cc=[];setInterval(()=>{for(let e=0;e<Cc.length;e++){let t=Cc[e].deref();!t||t.isDone||t.isCommitted?Cc.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(wp.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):wp.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(PR,"recordUpdater");a(Lc,"removeEntry")});var Wf=C((cye,pM)=>{"use strict";var mM=le(),j3=(k(),P(q)),{RecordEncoder:J3}=(fu(),P(hM));mM.initSync();var X3=mM.get(j3.CONFIG_PARAMS.STORAGE_CACHING)!==!1,DR=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=X3&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:J3})}};pM.exports=DR});var zf=C((uye,EM)=>{"use strict";var Gn=le(),hs=(k(),P(q));Gn.initSync();var Lp=class{static{a(this,"OpenEnvironmentObject")}constructor(t,r=!1){this.path=t,this.mapSize=1073741824,this.maxDbs=1e4,this.maxReaders=2048,this.sharedStructuresKey=Symbol.for("structures"),this.readOnly=r,this.trackMetrics=!0,this.eventTurnBatching=!1,this.noSync=Gn.get(hs.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Gn.get(hs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Gn.get(hs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Gn.get(hs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Gn.get(hs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Gn.get(hs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Gn.get(hs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Gn.get(hs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Gn.get(hs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Gn.get(hs.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Gn.get(hs.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Gn.get(hs.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};EM.exports=Lp;Lp.MAX_DBS=1e4});var ht=C((fye,wM)=>{"use strict";var MR=require("lmdb"),qs=require("fs-extra"),qn=require("path"),Mp=fn(),TM=ee(),Sn=Un().LMDB_ERRORS_ENUM,vp=lM(),vR=Wf(),AM=zf(),fa=Ft(),gM=(k(),P(q)),{table:Z3,resetDatabases:eX}=(xe(),P(ct)),SM=le(),$s=fa.INTERNAL_DBIS_NAME,RM=fa.DBI_DEFINITION_NAME,tX="data.mdb",rX="lock.mdb",Qf=".mdb",nX="-lock",LR=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=ms(t,r),this.key_type=this.dbi[fa.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[fa.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new MR.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function Up(e,t){if(e===void 0)throw new Error(Sn.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(Sn.ENV_NAME_REQUIRED)}a(Up,"pathEnvNameValidation");async function UR(e,t,r=!0){try{await qs.access(e)}catch(n){throw n.code==="ENOENT"?new Error(Sn.INVALID_BASE_PATH):n}try{let n=qn.join(e,t+Qf);return await qs.access(n,qs.constants.R_OK|qs.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await qs.access(qn.join(e,t,tX),qs.constants.R_OK|qs.constants.F_OK),qn.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(Sn.INVALID_ENVIRONMENT)}else throw new Error(Sn.INVALID_ENVIRONMENT);throw n}}a(UR,"validateEnvironmentPath");function xp(e,t){if(Mp.validateEnv(e),t===void 0)throw new Error(Sn.DBI_NAME_REQUIRED)}a(xp,"validateEnvDBIName");async function sX(e,t,r=!1,n=!1){Up(e,t);let s=qn.basename(e);t=t.toString();let i=SM.get(gM.CONFIG_PARAMS.DATABASES);i||SM.setProperty(gM.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await UR(e,t,n),yM(e,t,r)}catch(o){if(o.message===Sn.INVALID_ENVIRONMENT){let c=qn.join(e,t);await qs.mkdirp(n?c:e);let l=new AM(n?c:c+Qf,!1),u=MR.open(l);u.dbis=Object.create(null);let f=new vR(!1);u.openDB($s,f),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let d=xR(e,t,r);return u[fa.ENVIRONMENT_NAME_KEY]=d,global.lmdb_map[d]=u,u}throw o}}a(sX,"createEnvironment");async function iX(e,t,r,n=!0){Up(e,t),t=t.toString();let s=qn.join(e,t);return Z3({table:t,database:qn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(iX,"copyEnvironment");async function yM(e,t,r=!1){Up(e,t),t=t.toString();let n=xR(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 UR(e,t),i=qn.join(e,t+Qf),o=s!=i,c=new AM(s,o),l=MR.open(c);l.dbis=Object.create(null);let u=OM(l);for(let f=0;f<u.length;f++)ms(l,u[f]);return l[fa.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(yM,"openEnvironment");async function oX(e,t,r=!1){Up(e,t),t=t.toString();let n=qn.join(e,t+Qf),s=await UR(e,t);if(global.lmdb_map!==void 0){let i=xR(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await bM(o),delete global.lmdb_map[i]}}await qs.remove(s),await qs.remove(s===n?s+nX:qn.join(qn.dirname(s),rX))}a(oX,"deleteEnvironment");async function bM(e){Mp.validateEnv(e);let t=e[fa.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(bM,"closeEnvironment");function xR(e,t,r=!1){let s=`${qn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(xR,"getCachedEnvironmentName");function aX(e){Mp.validateEnv(e);let t=Object.create(null),r=ms(e,$s);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==$s)try{t[n]=Object.assign(new vp,s)}catch{TM.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(aX,"listDBIDefinitions");function OM(e){Mp.validateEnv(e);let t=[],r=ms(e,$s);for(let{key:n}of r.getRange({start:!1}))n!==$s&&t.push(n);return t}a(OM,"listDBIs");function cX(e,t){let n=ms(e,$s).getEntry(t),s=new vp;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{TM.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(cX,"getDBIDefinition");function NM(e,t,r,n=!r){if(xp(e,t),t=t.toString(),t===$s)throw new Error(Sn.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return ms(e,t)}catch(s){if(s.message===Sn.DBI_DOES_NOT_EXIST){let i=new vR(r,n===!0),o=e.openDB(t,i),c=new vp(r===!0,n);return o[RM]=c,ms(e,$s).putSync(t,c),e.dbis[t]=o,o}throw s}}a(NM,"createDBI");function ms(e,t){if(xp(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==$s?r=cX(e,t):r=new vp,r===void 0)throw new Error(Sn.DBI_DOES_NOT_EXIST);let n;try{let s=new vR(r.dup_sort,r.useVersions);if(n=e.openDB(t,s),n.db===void 0)throw new Error("MDB_NOTFOUND")}catch(s){throw s.message.includes("MDB_NOTFOUND")===!0?new Error(Sn.DBI_DOES_NOT_EXIST):s}return n[RM]=r,e.dbis[t]=n,n}a(ms,"openDBI");function lX(e,t){xp(e,t),t=t.toString();let r=ms(e,t),n=r.getStats();return r[fa.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(lX,"statDBI");async function uX(e,t){try{let r=qn.join(e,t+Qf);return(await qs.stat(r)).size}catch{throw new Error(Sn.INVALID_ENVIRONMENT)}}a(uX,"environmentDataSize");function dX(e,t){if(xp(e,t),t=t.toString(),t===$s)throw new Error(Sn.CANNOT_DROP_INTERNAL_DBIS_NAME);ms(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],ms(e,$s).removeSync(t)}a(dX,"dropDBI");function fX(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{ms(e,i)}catch(o){if(o.message===Sn.DBI_DOES_NOT_EXIST)NM(e,i,i!==t,i===t),n=!0;else throw o}}n&&eX()}a(fX,"initializeDBIs");wM.exports={openDBI:ms,openEnvironment:yM,createEnvironment:sX,listDBIs:OM,listDBIDefinitions:aX,createDBI:NM,dropDBI:dX,statDBI:lX,deleteEnvironment:oX,initializeDBIs:fX,TransactionCursor:LR,environmentDataSize:uX,copyEnvironment:iX,closeEnvironment:bM}});var CM=C((hye,IM)=>{"use strict";var BR=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};IM.exports=BR});var DM=C((pye,PM)=>{"use strict";var HR=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}};PM.exports=HR});var MM=C((gye,LM)=>{"use strict";var kR=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};LM.exports=kR});var xc=C((yye,xM)=>{"use strict";var _X=ht(),hX=CM(),mX=DM(),pX=MM(),wi=fn(),jf=Un().LMDB_ERRORS_ENUM,EX=Ft(),uo=(k(),P(q)),gX=ie(),SX=require("uuid"),Tye=require("lmdb"),{handleHDBError:TX,hdb_errors:AX}=he(),{OVERFLOW_MARKER:Aye,MAX_SEARCH_KEY_LENGTH:Rye}=EX,vM=le();vM.initSync();var Bp=vM.get(uo.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),FR=uo.TIME_STAMP_NAMES_ENUM.CREATED_TIME,Uc=uo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function RX(e,t,r,n,s=wi.getNextMonotonicTime()){VR(e,t,r,n),GR(e,t,r);let i=new hX,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l];UM(u,!0,s);let f=yX(e,t,r,u),d=u[t];o.push(f),c.push(d)}return qR(o,c,n,i,s)}a(RX,"insertRecords");function yX(e,t,r,n){let s=n[t];return e.dbis[t].ifNoExists(s,()=>{for(let i=0;i<r.length;i++){let o=r[i];if(o===t||n.hasOwnProperty(o)===!1)continue;let c=n[o];if(typeof c=="function"){let f=c([[{}]]);Array.isArray(f)&&(c=f[0][uo.FUNC_VAL],n[o]=c)}let l=wi.getIndexedValues(c),u=e.dbis[o];if(l){Bp&&u.prefetch(l.map(f=>({key:f,value:s})),Hp);for(let f=0,d=l.length;f<d;f++)u.put(l[f],s)}}Bp&&e.dbis[t].prefetch([s],Hp),e.dbis[t].put(s,n,n[Uc])})}a(yX,"insertRecord");function bX(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(bX,"removeSkippedRecords");function UM(e,t,r){let n=r>0;(n||!Number.isInteger(e[Uc]))&&(e[Uc]=r||(r=wi.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[FR]))&&(e[FR]=r||wi.getNextMonotonicTime()):delete e[FR]}a(UM,"setTimestamps");function GR(e,t,r){r.indexOf(uo.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(uo.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(uo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(uo.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),_X.initializeDBIs(e,t,r)}a(GR,"initializeTransaction");async function OX(e,t,r,n,s=wi.getNextMonotonicTime()){VR(e,t,r,n),GR(e,t,r);let i=new mX,o=[],c=[],l=[];for(let u=0;u<n.length;u++){let f=n[u],d=f[t],_;try{_=$R(e,t,f,d,i,!0,s)}catch{i.skipped_hashes.push(d),o.push(u);continue}c.push(_),l.push(d)}return qR(c,l,n,i,s,o)}a(OX,"updateRecords");async function NX(e,t,r,n,s=wi.getNextMonotonicTime()){try{VR(e,t,r,n)}catch(l){throw TX(l,l.message,AX.HTTP_STATUS_CODES.BAD_REQUEST)}GR(e,t,r);let i=new pX,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l],f;gX.isEmpty(u[t])?(f=SX.v4(),u[t]=f):f=u[t];let d=$R(e,t,u,f,i,!1,s);o.push(d),c.push(f)}return qR(o,c,n,i,s)}a(NX,"upsertRecords");async function qR(e,t,r,n,s,i=[]){let o=await Promise.all(e);for(let c=0,l=o.length;c<l;c++)o[c]===!0?n.written_hashes.push(t[c]):(n.skipped_hashes.push(t[c]),i.push(c));return n.txn_time=s||wi.getNextMonotonicTime(),bX(r,i),n}a(qR,"finalizeWrite");function $R(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(UM(r,!f,o),Number.isInteger(r[Uc])&&u[Uc]>r[Uc])return!1;f&&s.original_records.push(u);let d,_=a(()=>{for(let m in r){if(!r.hasOwnProperty(m)||m===t)continue;let S=r[m],g=e.dbis[m];if(g===void 0)continue;let R=u[m];if(typeof S=="function"){let T=S([[u]]);Array.isArray(T)&&(S=T[0][uo.FUNC_VAL],r[m]=S)}if(S===R)continue;let E=wi.getIndexedValues(R);if(E){Bp&&g.prefetch(E.map(T=>({key:T,value:n})),Hp);for(let T=0,N=E.length;T<N;T++)g.remove(E[T],n)}if(E=wi.getIndexedValues(S),E){Bp&&g.prefetch(E.map(T=>({key:T,value:n})),Hp);for(let T=0,N=E.length;T<N;T++)g.put(E[T],n)}}let h={...u,...r};c.put(n,h,h[Uc])},"do_put");return l?d=c.ifVersion(n,l.version,_):d=c.ifNoExists(n,_),d.then(h=>h?!0:$R(e,t,r,n,s,i,o))}a($R,"updateUpsertRecord");function wX(e,t,r){if(wi.validateEnv(e),t===void 0)throw new Error(jf.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(jf.WRITE_ATTRIBUTES_REQUIRED):new Error(jf.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(wX,"validateBasic");function VR(e,t,r,n){if(wX(e,t,r),!Array.isArray(n))throw n===void 0?new Error(jf.RECORDS_REQUIRED):new Error(jf.RECORDS_MUST_BE_ARRAY)}a(VR,"validateWrite");function Hp(){}a(Hp,"noop");xM.exports={insertRecords:RX,updateRecords:OX,upsertRecords:NX}});var fo=C((Oye,IX)=>{IX.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 HM=C((Nye,BM)=>{"use strict";var CX=require("uuid"),KR=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||CX.v4(),this.schema_table=`${this.schema}.${this.table}`}};BM.exports=KR});var kp=C((Iye,kM)=>{"use strict";var PX=HM(),YR=class extends PX{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}};kM.exports=YR});var GM=C((Pye,FM)=>{"use strict";FM.exports=LX;var DX="inserted";function LX(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===DX?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(LX,"returnObject")});var Fp=C((Mye,$M)=>{"use strict";var MX=(k(),P(q)),WR=ht(),vX=xc(),{getSystemSchemaPath:UX,getSchemaPath:xX}=gt(),Lye=fo(),{validateBySchema:BX}=it(),Jf=require("joi"),HX=kp(),kX=GM(),{handleHDBError:FX,hdb_errors:GX,ClientError:qX}=he(),qM=ie(),{HTTP_STATUS_CODES:$X}=GX,VX="inserted";$M.exports=KX;async function KX(e){let t=BX(e,Jf.object({database:Jf.string(),schema:Jf.string(),table:Jf.string().required(),attribute:Jf.string().required()}));if(t)throw new qX(t.message);let r=!e.skip_table_check&&qM.checkGlobalSchemaTable(e.schema,e.table);if(r)throw FX(new Error,r,$X.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=qM.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 HX(e.schema,e.table,e.attribute,e.id);try{let i=await WR.openEnvironment(xX(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}`);WR.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await WR.openEnvironment(UX(),MX.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await vX.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_attribute_attributes,[s]);return kX(VX,c,{records:[s]},l)}catch(i){throw i}}a(KX,"lmdbCreateAttribute")});var Xf=C((xye,KM)=>{"use strict";var _o=ie(),VM=ee(),Uye=TR(),{getDatabases:YX}=(xe(),P(ct)),{ClientError:Bc}=he();KM.exports=WX;function WX(e){if(_o.isEmpty(e))throw new Bc("invalid update parameters defined.");if(_o.isEmptyOrZeroLength(e.schema))throw new Bc("invalid schema specified.");if(_o.isEmptyOrZeroLength(e.table))throw new Bc("invalid table specified.");if(!Array.isArray(e.records))throw new Bc("records must be an array");let t=YX()[e.schema]?.[e.table];if(_o.isEmpty(t))throw new Bc(`could not retrieve schema:${e.schema} and table ${e.table}`);let r=t.primaryKey,n=new Set,s={},i=!1;return e.operation==="update"&&(i=!0),e.records.forEach(o=>{if(i&&_o.isEmptyOrZeroLength(o[r]))throw VM.error("a valid hash attribute must be provided with update record:",o),new Bc("a valid hash attribute must be provided with update record, check log for more info");if(!_o.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw VM.error(`a valid hash value must be provided with ${e.operation} record:`,o),new Bc(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!_o.isEmpty(o[r])&&o[r]!==""&&n.has(_o.autoCast(o[r]))&&(o.skip=!0),n.add(_o.autoCast(o[r]));for(let c in o)s[c]=1}),s[r]=1,{schema_table:t,hashes:Array.from(n),attributes:Object.keys(s)}}a(WX,"insertUpdateValidate")});var WM=C((Hye,YM)=>{"use strict";var zR=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};YM.exports=zR});var jM=C((Fye,QM)=>{"use strict";var QR=ht(),zX=ee(),zM=Un().LMDB_ERRORS_ENUM;QM.exports=QX;async function QX(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 QR.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==zM.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await QR.closeEnvironment(global.lmdb_map[n]),await QR.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==zM.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){zX.error(t)}}a(QX,"cleanLMDBMap")});var lv=C(($ye,cv)=>{"use strict";var jR=require("recursive-iterator"),jX=require("alasql"),JR=require("clone"),JM=ie(),{handleHDBError:XM,hdb_errors:JX}=he(),{HDB_ERROR_MSGS:ZM,HTTP_STATUS_CODES:ev}=JX,{getDatabases:XX}=(xe(),P(ct)),ZX=["DISTINCT_ARRAY"],tv=Symbol("validateTables"),XR=Symbol("validateTable"),qye=Symbol("getAllColumns"),rv=Symbol("validateAllColumns"),Gp=Symbol("findColumn"),nv=Symbol("validateOrderBy"),Zf=Symbol("validateSegment"),ZR=Symbol("validateColumn"),sv=Symbol("setColumnsForTable"),iv=Symbol("checkColumnsForAsterisk"),ov=Symbol("validateGroupBy"),av=Symbol("hasColumns"),ey=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[tv](),this[iv](),this[rv]()}[tv](){if(this[av]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[XR](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[XR](t.table)})}}[av](){let t=!1,r=new jR(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[XR](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=XX();if(!r[t.databaseid])throw XM(new Error,ZM.SCHEMA_NOT_FOUND(t.databaseid),ev.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw XM(new Error,ZM.TABLE_NOT_FOUND(t.databaseid,t.tableid),ev.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=JR(s);i.table=JR(t),this.attributes.push(i)})}[Gp](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)}[iv](){let t=new jR(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[sv](r.tableid)}[sv](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new jX.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[rv](){this[Zf](this.statement.columns,!1),this[Zf](this.statement.joins,!1),this[Zf](this.statement.where,!1),this[ov](this.statement.group,!1),this[Zf](this.statement.order,!0)}[Zf](t,r){if(!t)return;let n=new jR(t),s=[];for(let{node:i,path:o}of n)!JM.isEmpty(i)&&!JM.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[nv](i):s.push(this[ZR](i)));return s}[ov](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&ZX.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=JR(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[Gp](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[Gp](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`}[nv](t){let r=this.statement.columns.filter(n=>n.as===t.columnid);if(r.length>1)throw`ambiguous column reference ${(t.tableid?t.tableid+".":"")+t.columnid} in order by`;r.length===0&&this[ZR](t)}[ZR](t){let r=this[Gp](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]}};cv.exports=ey});var _v=C((Kye,fv)=>{"use strict";var uv=require("lodash"),e_=require("mathjs"),e6=require("jsonata"),dv=ie();fv.exports={distinct_array:a(e=>Array.isArray(e)&&e.length>1?uv.uniqWith(e,uv.isEqual):e,"distinct_array"),searchJSON:t6,mad:t_.bind(null,e_.mad),mean:t_.bind(null,e_.mean),mode:t_.bind(null,e_.mode),prod:t_.bind(null,e_.prod),median:t_.bind(null,e_.median)};function t_(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(t_,"aggregateFunction");function t6(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(dv.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),dv.isEmpty(this.__ala__.res[r])){let n=e6(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(t6,"searchJSON")});var mv=C((Wye,hv)=>{"use strict";var rr=require("moment"),ty="YYYY-MM-DDTHH:mm:ss.SSSZZ";rr.suppressDeprecationWarnings=!0;hv.exports={current_date:a(()=>rr().utc().format("YYYY-MM-DD"),"current_date"),current_time:a(()=>rr().utc().format("HH:mm:ss.SSS"),"current_time"),extract:a((e,t)=>{switch(t.toLowerCase()){case"year":return rr(e).utc().format("YYYY");case"month":return rr(e).utc().format("MM");case"day":return rr(e).utc().format("DD");case"hour":return rr(e).utc().format("HH");case"minute":return rr(e).utc().format("mm");case"second":return rr(e).utc().format("ss");case"millisecond":return rr(e).utc().format("SSS");default:break}},"extract"),date:a(e=>rr(e).utc().format(ty),"date"),date_format:a((e,t)=>rr(e).utc().format(t),"date_format"),date_add:a((e,t,r)=>rr(e).utc().add(t,r).valueOf(),"date_add"),date_sub:a((e,t,r)=>rr(e).utc().subtract(t,r).valueOf(),"date_sub"),date_diff:a((e,t,r)=>{let n=rr(e).utc(),s=rr(t).utc();return r?n.diff(s,r,!0):n.diff(s)},"date_diff"),now:a(()=>rr().utc().valueOf(),"now"),get_server_time:a(()=>rr().format(ty),"get_server_time"),offset_utc:a((e,t)=>rr(e).utc().utcOffset(t).format(ty),"offset_utc")}});var Sv=C((Qye,gv)=>{"use strict";var r6=require("@turf/area"),n6=require("@turf/length"),s6=require("@turf/circle"),i6=require("@turf/difference"),o6=require("@turf/distance"),a6=require("@turf/boolean-contains"),c6=require("@turf/boolean-equal"),l6=require("@turf/boolean-disjoint"),u6=require("@turf/helpers"),pv=(k(),P(q)),Ke=ie(),ho=ee();gv.exports={geoArea:d6,geoLength:f6,geoCircle:_6,geoDifference:h6,geoDistance:Ev,geoNear:m6,geoContains:p6,geoEqual:E6,geoCrosses:g6,geoConvert:S6};function d6(e){if(Ke.isEmpty(e))return NaN;typeof e=="string"&&(e=Ke.autoCastJSON(e));try{return r6.default(e)}catch(t){return ho.trace(t,e),NaN}}a(d6,"geoArea");function f6(e,t){if(Ke.isEmpty(e))return NaN;typeof e=="string"&&(e=Ke.autoCastJSON(e));try{return n6.default(e,{units:t||"kilometers"})}catch(r){return ho.trace(r,e),NaN}}a(f6,"geoLength");function _6(e,t,r){if(Ke.isEmpty(e))return NaN;if(Ke.isEmpty(t))return NaN;typeof e=="string"&&(e=Ke.autoCastJSON(e));try{return s6.default(e,t,{units:r||"kilometers"})}catch(n){return ho.trace(n,e,t),NaN}}a(_6,"geoCircle");function h6(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 i6(e,t)}catch(r){return ho.trace(r,e,t),NaN}}a(h6,"geoDifference");function Ev(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 o6.default(e,t,{units:r||"kilometers"})}catch(n){return ho.trace(n,e,t),NaN}}a(Ev,"geoDistance");function m6(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 Ev(e,t,n)<=r}catch(s){return ho.trace(s,e,t),!1}}a(m6,"geoNear");function p6(e,t){if(Ke.isEmpty(e)||Ke.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Ke.autoCastJSON(e)),typeof t=="string"&&(t=Ke.autoCastJSON(t));try{return a6.default(e,t)}catch(r){return ho.trace(r,e,t),!1}}a(p6,"geoContains");function E6(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 c6.default(e,t)}catch(r){return ho.trace(r,e,t),!1}}a(E6,"geoEqual");function g6(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!l6.default(e,t)}catch(r){return ho.trace(r,e,t),!1}}a(g6,"geoCrosses");function S6(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(pv.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(pv.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Ke.autoCastJSON(e)),u6[t](e,r)}a(S6,"geoConvert")});var qp=C((Jye,Tv)=>{var Hc=_v(),$n=mv(),Ii=Sv();Tv.exports=e=>{e.aggr.mad=e.aggr.MAD=Hc.mad,e.aggr.mean=e.aggr.MEAN=Hc.mean,e.aggr.mode=e.aggr.MODE=Hc.mode,e.aggr.prod=e.aggr.PROD=Hc.prod,e.aggr.median=e.aggr.MEDIAN=Hc.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=Hc.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=Hc.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=$n.current_date,e.fn.current_time=e.fn.CURRENT_TIME=$n.current_time,e.fn.extract=e.fn.EXTRACT=$n.extract,e.fn.date=e.fn.DATE=$n.date,e.fn.date_format=e.fn.DATE_FORMAT=$n.date_format,e.fn.date_add=e.fn.DATE_ADD=$n.date_add,e.fn.date_sub=e.fn.DATE_SUB=$n.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=$n.date_diff,e.fn.now=e.fn.NOW=$n.now,e.fn.offset_utc=e.fn.OFFSET_UTC=$n.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=$n.get_server_time,e.fn.getdate=e.fn.GETDATE=$n.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=$n.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=Ii.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=Ii.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=Ii.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=Ii.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=Ii.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=Ii.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=Ii.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=Ii.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=Ii.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=Ii.geoNear}});var bv=C((Xye,yv)=>{"use strict";var r_=require("lodash"),Tn=require("alasql");Tn.options.cache=!1;var T6=qp(),Av=require("clone"),$p=require("recursive-iterator"),ke=ee(),Je=ie(),_u=Vn(),A6=(k(),P(q)),{hdb_errors:R6}=he(),{getDatabases:Rv}=(xe(),P(ct)),y6="IS NULL",Vs="There was a problem performing this search. Please check the logs and try again.";T6(Tn);var ry=class{static{a(this,"SQLSearch")}constructor(t,r){if(Je.isEmpty(t))throw ke.error("AST statement for SQL select process cannot be empty"),"statement cannot be null";this.statement=t,this.columns={},this.all_table_attributes=r,this.fetch_attributes=[],this.exact_search_values={},this.comparator_search_values={},this.tables=[],this.data={},this.has_aggregator=!1,this.has_ordinal=!1,this.has_outer_join=!1,this._getColumns(),this._getTables(),this._conditionsToFetchAttributeValues(),this._setAliasesForColumns(),Je.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!Je.isEmptyOrZeroLength(n))return ke.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw ke.error("Error thrown from checkEmptySQL in SQLSearch class method search."),ke.error(n),new Error(Vs)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw ke.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),ke.error(n),new Error(Vs)}if(Object.keys(this.data).length===0)return ke.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw ke.error("Error thrown from processJoins in SQLSearch class method search."),ke.error(n),new Error(Vs)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw ke.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),ke.error(n),new Error(Vs)}try{return t=await this._finalSQL(),t}catch(n){throw ke.error("Error thrown from finalSQL in SQLSearch class method search."),ke.error(n),new Error(Vs)}}_getColumns(){let t=new $p(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(Av(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=r_.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=Rv()[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 $p(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!Je.isEmpty(r)&&r.right)if(Je.isNotEmptyAndHasValue(r.right.value)){let n=Je.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new Tn.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=Je.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new Tn.yy.LogicValue({value:i}):n instanceof Tn.yy.StringValue&&Je.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new Tn.yy.NumValue({value:i}))});if(t){ke.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new $p(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(A6.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&&r_.pullAt(this.statement.columns,t)}_findColumn(t){let r=this.all_table_attributes.filter(n=>{if(t.columnid_orig&&t.tableid_orig)return(n.table.as===t.tableid_orig||n.table.tableid===t.tableid_orig)&&n.attribute===t.columnid_orig;if(t.tableid)return(n.table.as===t.tableid||n.table.tableid===t.tableid)&&n.attribute===t.columnid;let s=t.columnid_orig?t.columnid_orig:t.columnid;return n.attribute===s});if(Je.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);Je.isEmptyOrZeroLength(n)||(r=this.all_table_attributes.filter(s=>s.attribute===n[0].columnid&&n[0].tableid&&n[0].tableid===(s.table.as?s.table.as:s.table.tableid)))}return r[0]}async _checkEmptySQL(){let t=[];if(Je.isEmptyOrZeroLength(this.all_table_attributes)&&!Je.isEmptyOrZeroLength(this.columns.columns))return t;if(Je.isEmptyOrZeroLength(this.all_table_attributes)&&Je.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await Tn.promise(r)}catch(r){throw ke.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),ke.error(r),new Error("There was a problem with the SQL statement")}return t}_addFetchColumns(t){t&&t.length>0&&t.forEach(r=>{let n=this._findColumn(r);n&&this.fetch_attributes.push(Av(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(y6)>-1&&this.tables.forEach(s=>{let i={columnid:Rv()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=r_.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 _u.getDataByHash(c);for(let d of c.hash_values)f.get(d)&&!this.data[i].__merged_data[d]&&(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d))}catch(f){throw ke.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),ke.error(f),new Error(Vs)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[u].values).map(async f=>{let d={...c};d.search_value=f;let _=await _u.getDataByValue(d);for(let[h,m]of _)this.data[i].__merged_data[h]?this._updateMergedAttribute(i,h,s.attribute,m[s.attribute]):(this.data[i].__merged_data[h]=[...n[i]],this._updateMergedAttribute(i,h,s.attribute,m[s.attribute]),this._setMergedHashAttribute(i,h))}))}catch(f){throw ke.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),ke.error(f),new Error(Vs)}else if(!Je.isEmpty(this.comparator_search_values[u])&&!this.comparator_search_values[u].ignore&&!Je.isEmptyOrZeroLength(this.comparator_search_values[u].comparators))try{let f=this.comparator_search_values[u].comparators;for(let d=0,_=f.length;d<_;d++){let h=f[d];c.search_attribute=h.attribute,c.search_value=h.search_value;let m=await _u.getDataByValue(c,h.operation);if(l)for(let[S]of m)this.data[i].__merged_data[S]||(this.data[i].__merged_data[S]=[...n[i]],this._setMergedHashAttribute(i,S));else for(let[S,g]of m)this.data[i].__merged_data[S]?this._updateMergedAttribute(i,S,s.attribute,g[s.attribute]):(this.data[i].__merged_data[S]=[...n[i]],this._updateMergedAttribute(i,S,s.attribute,g[s.attribute]),this._setMergedHashAttribute(i,S))}}catch(f){throw ke.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),ke.error(f),new Error(Vs)}else try{c.search_attribute=s.attribute,c.search_value="*";let f=await _u.getDataByValue(c);if(l)for(let[d]of f)this.data[i].__merged_data[d]||(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d));else for(let[d,_]of f)this.data[i].__merged_data[d]?this._updateMergedAttribute(i,d,s.attribute,_[s.attribute]):(this.data[i].__merged_data[d]=[...n[i]],this._updateMergedAttribute(i,d,s.attribute,_[s.attribute]),this._setMergedHashAttribute(i,d))}catch(f){throw ke.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),ke.error(f),new Error(Vs)}}}_isSimpleSelect(){let t=!0;return Object.keys(this.statement).length!==2||!this.statement.columns||!this.statement.from||this.statement.from.length!==1?(t=!1,t):(this.statement.columns.forEach(r=>{r instanceof Tn.yy.Column||(t=!1)}),t)}_updateOrderByToAliases(){this.statement.order.forEach(t=>{if(t.expression.aggregatorid){t.is_aggregator=!0;return}if(t.expression.value){t.is_ordinal=!0,this.has_ordinal=!0;return}else t.is_ordinal=!1;let r=this.statement.columns.filter(s=>{let i=s.aggregatorid?s.expression:s,o=s.aggregatorid?s.as_orig:i.as_orig;return t.expression.tableid?i.columnid_orig===t.expression.columnid_orig&&i.tableid_orig===t.expression.tableid_orig:i.columnid_orig===t.expression.columnid_orig||t.expression.columnid_orig===o});r[0]||r.push(this._findColumn(t.expression));let n=r[0];if(t.is_func=!!n.funcid,t.is_aggregator=!!n.aggregatorid,n.as)if(n.as&&!t.expression.tableid)t.expression.columnid=n.as,t.expression.columnid_orig=n.as_orig;else{let s=new Tn.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new Tn.yy.Column,t.expression),t.initial_select_column.as=`[${t.expression.columnid_orig}]`,t.expression.columnid=t.initial_select_column.as;return}if(!t.is_aggregator){let s=t.is_func?new Tn.yy.FuncValue:new Tn.yy.Column;t.initial_select_column=Object.assign(s,n)}})}_addNonAggregatorsToFetchColumns(){let r=this.statement.order.filter(n=>!n.is_aggregator&&!n.is_ordinal).map(n=>n.is_func?{columnid:n.initial_select_column.args.filter(i=>!!i.columnid_orig)[0].columnid_orig}:{columnid:n.expression.columnid_orig});this._addFetchColumns(r)}async _processJoins(){let t=[],r=[],n=this.statement.from[0],s=[n],i=["? "+(n.as?" AS "+n.as:n.tableid)];t.push(Object.values(this.data[`${n.databaseid_orig}_${n.as?n.as_orig:n.tableid_orig}`].__merged_data)),this.statement.joins&&this.statement.joins.forEach(h=>{h.joinmode&&h.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(h.table);let m=h.joinmode+" JOIN ? AS "+(h.as?h.as:h.table.tableid);h.on&&(m+=" ON "+h.on.toString()),i.push(m),t.push(Object.values(this.data[`${h.table.databaseid_orig}_${h.table.as?h.table.as_orig:h.table.tableid_orig}`].__merged_data))});let o=[],c={};s.forEach(h=>{let m=this.data[`${h.databaseid_orig}_${h.as?h.as_orig:h.tableid_orig}`].__hash_name,S=h.as?h.as_orig:h.tableid_orig;o.push({key:`'${S}.${m}'`,schema:h.databaseid_orig,table:h.as?h.as_orig:h.tableid_orig,keys:new Set}),r.push(`${h.as?h.as:h.tableid}.\`${m}\` AS "${S}.${m}"`),c[h.as?h.as_orig:h.tableid_orig]=this.data[`${h.databaseid_orig}_${h.as?h.as_orig:h.tableid_orig}`].__merged_attributes});let l=this.statement.where?"WHERE "+this.statement.where:"";l=l.replace(/NOT\(NULL\)/g,"NOT NULL");let u="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(u="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(h=>{h.is_func?r.push(h.initial_select_column.toString()):h.initial_select_column.tableid?r.push(`${h.initial_select_column.tableid}.${h.initial_select_column.columnid} AS ${h.expression.columnid}`):r.push(`${h.initial_select_column.columnid} AS ${h.expression.columnid}`)}));let f="",d="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(f=this.statement.limit?"LIMIT "+this.statement.limit:"",d=this.statement.offset?"OFFSET "+this.statement.offset:"");let _=[];try{let h=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${l} ${u} ${f} ${d}`,m=this._convertColumnsToIndexes(h,s);_=await Tn.promise(m,t),t=null}catch(h){throw ke.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),ke.error(h),new Error("There was a problem processing the data.")}if(_&&_.length>0){for(let h=0,m=_.length;h<m;h++){let S=_[h];o.forEach(g=>{S[g.key]!==null&&S[g.key]!==void 0&&g.keys.add(S[g.key])})}o.forEach(h=>{let m=Object.keys(this.data[`${h.schema}_${h.table}`].__merged_data),S=r_.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 $p(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=r_.uniqBy(n,i=>[i.table.databaseid,i.table.as?i.table.as:i.table.tableid,i.attribute].join());try{await this._getData(n)}catch(i){throw ke.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),ke.error(i),new Error(Vs)}}async _getData(t){try{let r=t.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]?n[i].columns.push(s.attribute):n[i]={schema:s.table.databaseid,table:s.table.tableid,columns:[s.attribute]},n},{});for(let n in r){let s=r[n],i=this.data[n].__merged_data,o=[];for(let f in i)o.push(i[f][0]);this.data[n].__merged_attributes.push(...s.columns);let c={schema:s.schema,table:s.table,hash_values:o,get_attributes:s.columns},l=await _u.getDataByHash(c),u=s.columns.length;for(let f=0,d=o.length;f<d;f++){let _=o[f],h=l.get(_);for(let m=0;m<u;m++){let S=s.columns[m],g=h[S]===void 0?null:h[S];this.data[n].__merged_data[_].push(g)}}}}catch(r){throw ke.error("Error thrown from getDataByHash function in SQLSearch class method getData."),ke.error(r),r}}async _finalSQL(){let t=[],r=this.statement.from[0];t.push(Object.values(this.data[`${r.databaseid_orig}_${r.as?r.as_orig:r.tableid_orig}`].__merged_data)),r.as=r.as?r.as:r.tableid,r.databaseid="",r.tableid="?",this.statement.joins&&this.statement.joins.forEach(s=>{s.as=s.as?s.as:s.table.tableid,t.push(Object.values(this.data[`${s.table.databaseid_orig}_${s.table.as?s.table.as_orig:s.table.tableid_orig}`].__merged_data)),s.table.databaseid="",s.table.tableid="?"}),this.statement.order&&this.statement.order.forEach(s=>{if(s.is_ordinal)return;this.statement.columns.filter(o=>{let c=o.aggregatorid?o.expression:o,l=o.aggregatorid?o.as_orig:c.as_orig;return s.expression.tableid?c.columnid_orig===s.expression.columnid_orig&&c.tableid_orig===s.expression.tableid_orig:c.columnid_orig===s.expression.columnid_orig||s.expression.columnid_orig===l}).length===0&&(s.expression.columnid=s.initial_select_column.columnid)}),!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&this.statement.limit&&!this.statement.joins&&(delete this.statement.limit,delete this.statement.offset);let n;try{let s=this._buildSQL();ke.trace(`Final SQL: ${s}`),n=await Tn.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),ke.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw ke.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),ke.error(s),new Error("There was a problem running the generated sql.")}return n}_translateUndefinedValues(t){try{let r=[];for(let n of t){let s=Object.create(null);Object.keys(n).forEach(i=>{n[i]===void 0?s[i]=null:s[i]=n[i]}),r.push(s)}return r}catch(r){return ke.error(R6.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 _u.getDataByValue(i);for(let[c,l]of o)this.data[s].__merged_data[c]||(l[n.attribute]===void 0&&(l[n.attribute]=null),this.data[s].__merged_data[c]={...r[s]}),this.data[s].__merged_data[c][t[n.attribute]]=l[n.attribute]??null}catch(o){throw ke.error("There was an error when processing this SQL operation. Check your logs"),ke.error(o),new Error(Vs)}}return Object.values(Object.values(this.data)[0].__merged_data)}};yv.exports=ry});var zr=C((ebe,Ov)=>{"use strict";var b6=lv();Ov.exports={searchByConditions:N6,searchByHash:w6,searchByValue:I6,search:C6};var ny=Vn(),{transformReq:sy}=ie(),O6=bv();async function N6(e){return sy(e),ny.searchByConditions(e)}a(N6,"searchByConditions");async function w6(e){sy(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of ny.searchByHash(e))r&&t.push(r);return t}a(w6,"searchByHash");async function I6(e){sy(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of ny.searchByValue(e))t.push(r);return t}a(I6,"searchByValue");function C6(e,t){try{let r=new b6(e);r.validate(),new O6(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(C6,"search")});var mo=C((rbe,Cv)=>{"use strict";var n_=require("crypto"),P6=le(),{CONFIG_PARAMS:D6}=(k(),P(q)),wv="aes-256-cbc",L6=32,M6=16,iy=64,Iv=32,v6=iy+Iv,Nv=new Map;Cv.exports={encrypt:U6,decrypt:x6,createNatsTableStreamName:B6};function U6(e){let t=n_.randomBytes(L6),r=n_.randomBytes(M6),n=n_.createCipheriv(wv,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(U6,"encrypt");function x6(e){let t=e.substr(0,iy),r=e.substr(iy,Iv),n=e.substr(v6,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=n_.createDecipheriv(wv,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(x6,"decrypt");function B6(e,t){let r=P6.get(D6.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=Nv.get(r);return n||(n=n_.createHash("md5").update(r).digest("hex"),Nv.set(r,n)),n}a(B6,"createNatsTableStreamName")});var po=C((ibe,Mv)=>{"use strict";var sbe=zr(),s_=ee(),{validateBySchema:Pv}=it(),kc=require("joi"),H6=mo(),Vp=ie(),{handleHDBError:Kp,hdb_errors:k6,ClientError:Dv}=he(),{HDB_ERROR_MSGS:Yp,HTTP_STATUS_CODES:oy}=k6,Lv=le();Lv.initSync();var{getDatabases:ay}=(xe(),P(ct)),F6=require("fs-extra"),G6=(k(),P(q));Mv.exports={describeAll:q6,describeTable:Wp,describeSchema:$6};async function q6(e={}){try{let t=Vp.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=ay(),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 Wp({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 Wp({schema:d,table:h,exact_count:u},S)}m&&l.push(m)}catch(m){s_.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 s_.error("Got an error in describeAll"),s_.error(t),Kp(new Error,Yp.DESCRIBE_ALL_ERR)}}a(q6,"describeAll");async function Wp(e,t){Vp.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=Pv(e,kc.object({database:kc.string(),table:kc.string().required(),exact_count:kc.boolean().strict()}));if(i)throw new Dv(i.message);let c=ay()[r];if(!c)throw Kp(new Error,Yp.SCHEMA_NOT_FOUND(e.schema),oy.NOT_FOUND);let l=c[n];if(!l)throw Kp(new Error,Yp.TABLE_NOT_FOUND(e.schema,e.table),oy.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 F6.stat(l.primaryStore.env.path)).size}catch(h){s_.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")),Lv.get(G6.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(_.clustering_stream_name=H6.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){s_.warn(`unable to stat table dbi due to ${h}`)}return _}a(Wp,"descTable");async function $6(e){Vp.transformReq(e);let t=Pv(e,kc.object({database:kc.string(),exact_count:kc.boolean().strict()}));if(t)throw new Dv(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=ay()[n];if(!i)throw Kp(new Error,Yp.SCHEMA_NOT_FOUND(e.schema),oy.NOT_FOUND);let o={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),Vp.isEmpty(l)||l.describe){let u=await Wp({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);u&&(o[u.name]=u)}}return o}a($6,"describeSchema")});var ps=C((lbe,Hv)=>{var V6=fo(),{callbackify:Uv,promisify:K6}=require("util"),{getDatabases:xv}=(xe(),P(ct));Hv.exports={setSchemaDataToGlobal:vv,getTableSchema:Y6,getSystemSchema:W6,setSchemaDataToGlobalAsync:K6(vv)};var Bv=po(),abe=Uv(Bv.describeAll),cbe=Uv(Bv.describeTable);function vv(e){global.hdb_schema=xv(),e&&e()}a(vv,"setSchemaDataToGlobal");function Y6(e,t,r){let n=xv()[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(Y6,"getTableSchema");function W6(){return V6}a(W6,"getSystemSchema")});var ly=C((dbe,Gv)=>{var z6=it(),cy=require("joi"),{hdb_table:Q6,hdb_database:kv}=Ni(),Fv={schema:kv,database:kv,table:Q6},j6={date:cy.date().iso().required()},J6={timestamp:cy.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};Gv.exports=function(e,t){let r=t==="timestamp"?{...Fv,...J6}:{...Fv,...j6},n=cy.object(r);return z6.validateBySchema(e,n)}});var Vv=C((fbe,$v)=>{var X6=it(),uy=require("joi"),{hdb_table:Z6,hdb_database:qv}=Ni(),e8=uy.object({schema:qv,database:qv,table:Z6,hash_values:uy.array().required(),ids:uy.array()});$v.exports=function(e){return X6.validateBySchema(e,e8)}});var hy=C((_be,Kv)=>{"use strict";var dy=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}},fy=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}},_y=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};Kv.exports={InsertObject:dy,NoSQLSeachObject:fy,DeleteResponseObject:_y}});var qc=C((mbe,jv)=>{"use strict";var Wv=ly(),t8=Vv(),Fc=ie(),Yv=require("moment"),zv=ee(),{promisify:r8,callbackify:n8}=require("util"),Gc=(k(),P(q)),s8=ps(),my=r8(s8.getTableSchema),py=Vn(),{DeleteResponseObject:i8}=hy(),{handleHDBError:_a,hdb_errors:o8}=he(),{HDB_ERROR_MSGS:zp,HTTP_STATUS_CODES:ha}=o8,a8="records successfully deleted",c8=n8(Qv);jv.exports={delete:c8,deleteRecord:Qv,deleteFilesBefore:l8,deleteAuditLogsBefore:u8};async function l8(e){let t=Wv(e,"date");if(t)throw _a(t,t.message,ha.BAD_REQUEST,void 0,void 0,!0);if(Fc.transformReq(e),!Yv(e.date,Yv.ISO_8601).isValid())throw _a(new Error,zp.INVALID_DATE,ha.BAD_REQUEST,Gc.LOG_LEVELS.ERROR,zp.INVALID_DATE,!0);let n=Fc.checkSchemaTableExist(e.schema,e.table);if(n)throw _a(new Error,n,ha.NOT_FOUND,Gc.LOG_LEVELS.ERROR,n,!0);let s=await py.deleteRecordsBefore(e);if(await my(e.schema,e.table),zv.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(l8,"deleteFilesBefore");async function u8(e){let t=Wv(e,"timestamp");if(t)throw _a(t,t.message,ha.BAD_REQUEST,void 0,void 0,!0);if(Fc.transformReq(e),isNaN(e.timestamp))throw _a(new Error,zp.INVALID_VALUE("Timestamp"),ha.BAD_REQUEST,Gc.LOG_LEVELS.ERROR,zp.INVALID_VALUE("Timestamp"),!0);let r=Fc.checkSchemaTableExist(e.schema,e.table);if(r)throw _a(new Error,r,ha.NOT_FOUND,Gc.LOG_LEVELS.ERROR,r,!0);let n=await py.deleteAuditLogsBefore(e);return await my(e.schema,e.table),zv.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(u8,"deleteAuditLogsBefore");async function Qv(e){e.ids&&(e.hash_values=e.ids);let t=t8(e);if(t)throw _a(t,t.message,ha.BAD_REQUEST,void 0,void 0,!0);Fc.transformReq(e);let r=Fc.checkSchemaTableExist(e.schema,e.table);if(r)throw _a(new Error,r,ha.NOT_FOUND,Gc.LOG_LEVELS.ERROR,r,!0);try{await my(e.schema,e.table);let n=await py.deleteRecords(e);return Fc.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${a8}`),n}catch(n){if(n.message===Gc.SEARCH_NOT_FOUND_MESSAGE){let s=new i8;return s.message=Gc.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(Qv,"deleteRecord")});var Qp={};Ue(Qp,{HASH_FUNCTION:()=>a_,hash:()=>Sy,validate:()=>Ty});function Ey(e=o_){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ";return Array.from(i_.randomBytes(e)).map(r=>t[r%t.length]).join("")}function Sy(e,t=a_[Xv?.toUpperCase()]??"sha256"){return gy[t](e)}function Ty(e,t,r=a_[Xv?.toUpperCase()]??"sha256"){return e?d8[r](e,t):!1}var i_,hu,Jv,Xv,o_,Zv,a_,gy,d8,jp=Re(()=>{i_=v(require("node:crypto")),hu=v(require("argon2")),Jv=v(le());k();Xv=(0,Jv.get)(x.AUTHENTICATION_HASHFUNCTION)?.toLowerCase(),o_=16,Zv=9,a_=(n=>(n.MD5="md5",n.SHA256="sha256",n.ARGON2ID="argon2id",n))(a_||{});a(Ey,"generateSalt");gy={md5:a((e,t=void 0)=>{t=t??Ey(Zv);let r=i_.createHash("md5").update(e+t).digest("hex");return t+r},"md5"),sha256:a((e,t=void 0)=>{t=t??Ey(o_);let r=i_.createHash("sha256").update(e+t).digest("hex");return t+r},"sha256"),argon2id:a(async e=>{let t=Ey(o_),r=await hu.hash(e,{type:hu.argon2id,salt:Buffer.from(t)});return t+r},"argon2id")},d8={md5:a((e,t)=>{let r=e.slice(0,Zv);return e===gy.md5(t,r)},"md5"),sha256:a((e,t)=>{let r=e.slice(0,o_);return e===gy.sha256(t,r)},"sha256"),argon2id:a(async(e,t)=>await hu.verify(e.slice(o_),t),"argon2id")};a(Sy,"hash");a(Ty,"validate")});var tU=C((Sbe,eU)=>{var Ay=it(),Qr={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 f8(e){return Qr.password.presence=!0,Qr.username.presence=!0,Qr.role.presence=!0,Qr.active.presence=!0,Ay.validateObject(e,Qr)}a(f8,"addUserValidation");function _8(e){return Qr.password.presence=!1,Qr.username.presence=!0,Qr.role.presence=!1,Qr.active.presence=!1,Ay.validateObject(e,Qr)}a(_8,"alterUserValidation");function h8(e){return Qr.password.presence=!1,Qr.username.presence=!0,Qr.role.presence=!1,Qr.active.presence=!1,Ay.validateObject(e,Qr)}a(h8,"dropUserValidation");eU.exports={addUserValidation:f8,alterUserValidation:_8,dropUserValidation:h8}});var Lt=C((Rbe,nU)=>{"use strict";var{platform:Abe}=require("os"),m8="nats-server.zip",Ry="nats-server",p8=process.platform==="win32"?`${Ry}.exe`:Ry,E8=/^[^\s.,*>]+$/,rU="__request__",g8=a(e=>`${e}.${rU}`,"REQUEST_SUBJECT"),S8={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},T8={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},A8={HUB:"hub.pid",LEAF:"leaf.pid"},R8={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},y8={SUCCESS:"success",ERROR:"error"},b8={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},O8={TXN:"txn",MSGID:"msgid"},mu={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},N8={[mu.ERR]:1,[mu.WRN]:2,[mu.INF]:3,[mu.DBG]:4,[mu.TRC]:5},w8={debug:"-D",trace:"-DVV"};nU.exports={NATS_SERVER_ZIP:m8,NATS_SERVER_NAME:Ry,NATS_BINARY_NAME:p8,PID_FILES:A8,NATS_CONFIG_FILES:T8,SERVER_SUFFIX:R8,NATS_TERM_CONSTRAINTS_RX:E8,REQUEST_SUFFIX:rU,UPDATE_REMOTE_RESPONSE_STATUSES:y8,CLUSTER_STATUS_STATUSES:b8,REQUEST_SUBJECT:g8,SUBJECT_PREFIXES:O8,MSG_HEADERS:S8,LOG_LEVELS:mu,LOG_LEVEL_FLAGS:w8,LOG_LEVEL_HIERARCHY:N8}});var Kn=C((bbe,Nr)=>{"use strict";var oU="username is required",aU="nothing to update, must supply active, role or password to update",cU="password cannot be an empty string",lU="If role is specified, it cannot be empty.",uU="active must be true or false";Nr.exports.addUser=x8;Nr.exports.alterUser=B8;Nr.exports.dropUser=k8;Nr.exports.getSuperUser=V8;Nr.exports.userInfo=F8;Nr.exports.listUsers=Xp;Nr.exports.listUsersExternal=G8;Nr.exports.setUsersWithRolesCache=$c;Nr.exports.findAndValidateUser=Dy;Nr.exports.getClusterUser=K8;Nr.exports.getUsersWithRolesCache=$8;Nr.exports.USERNAME_REQUIRED=oU;Nr.exports.ALTERUSER_NOTHING_TO_UPDATE=aU;Nr.exports.EMPTY_PASSWORD=cU;Nr.exports.EMPTY_ROLE=lU;Nr.exports.ACTIVE_BOOLEAN=uU;var dU=An(),I8=qc(),c_=(jp(),P(Qp)),fU=tU(),l_=zr(),wy=go(),Ci=ie(),_U=require("validate.js"),Iy=ee(),{promisify:C8}=require("util"),Cy=mo(),by=(k(),P(q)),sU=Lt(),P8=Ct(),D8=le(),L8=fo(),{hdb_errors:M8,ClientError:Ks}=he(),{HTTP_STATUS_CODES:Eo,AUTHENTICATION_ERROR_MSGS:yy,HDB_ERROR_MSGS:pu}=M8,{UserEventMsg:Py}=Ys(),Oy=require("lodash"),{server:Jp}=(Mr(),P(Ql)),v8=ee();Jp.getUser=(e,t)=>Dy(e,t,t!=null);Jp.authenticateUser=(e,t)=>Dy(e,t);var hU={username:!0,active:!0,role:!0,password:!0},iU=new Map,U8=C8(I8.delete),Ny=D8.get(by.CONFIG_PARAMS.AUTHENTICATION_HASHFUNCTION)??c_.HASH_FUNCTION.SHA256,Pi;async function x8(e){let t=_U.cleanAttributes(e,hU),r=fU.addUserValidation(t);if(r)throw new Ks(r.message);let n=await l_.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(pu.ROLE_NAME_NOT_FOUND(t.role),Eo.NOT_FOUND);if(n.length>1)throw new Ks(pu.DUP_ROLES_FOUND(t.role),Eo.CONFLICT);n[0].permission.cluster_user===!0&&(t.hash=Cy.encrypt(t.password)),t.password=await c_.hash(t.password,Ny),t.hash_function=Ny,t.role=n[0].id;let s=await dU.insert({operation:"insert",schema:"system",table:"hdb_user",records:[t]});if(Iy.debug(s),await $c(),s.skipped_hashes.length===1)throw new Ks(pu.USER_ALREADY_EXISTS(t.username),Eo.CONFLICT);return wy.signalUserChange(new Py(process.pid)),`${t.username} successfully added`}a(x8,"addUser");async function B8(e){let t=_U.cleanAttributes(e,hU);if(Ci.isEmptyOrZeroLength(t.username))throw new Error(oU);if(Ci.isEmptyOrZeroLength(t.password)&&Ci.isEmptyOrZeroLength(t.role)&&Ci.isEmptyOrZeroLength(t.active))throw new Error(aU);if(!Ci.isEmpty(t.password)&&Ci.isEmptyOrZeroLength(t.password.trim()))throw new Error(cU);if(!Ci.isEmpty(t.active)&&!Ci.isBoolean(t.active))throw new Error(uU);if(!Ci.isEmpty(t.password)&&!Ci.isEmptyOrZeroLength(t.password.trim())&&(H8(t.username)&&(t.hash=Cy.encrypt(t.password)),t.password=await c_.hash(t.password,Ny)),t.role==="")throw new Error(lU);if(t.role){let n=await l_.searchByValue({schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]});if(!n||n.length===0)throw new Ks(pu.ALTER_USER_ROLE_NOT_FOUND(t.role),Eo.NOT_FOUND);if(n.length>1)throw new Ks(pu.DUP_ROLES_FOUND(t.role),Eo.CONFLICT);t.role=n[0].id}let r=await dU.update({operation:"update",schema:"system",table:"hdb_user",records:[t]});return await $c(),wy.signalUserChange(new Py(process.pid)),r}a(B8,"alterUser");function H8(e){let t=!1,r=Pi.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(H8,"isClusterUser");async function k8(e){let t=fU.dropUserValidation(e);if(t)throw new Ks(t.message);if(Pi.get(e.username)===void 0)throw new Ks(pu.USER_NOT_EXIST(e.username),Eo.NOT_FOUND);let r=await U8({table:"hdb_user",schema:"system",hash_values:[e.username]});return Iy.debug(r),await $c(),wy.signalUserChange(new Py(process.pid)),`${e.username} successfully deleted`}a(k8,"dropUser");async function F8(e){let t={};if(!e||!e.hdb_user)return"There was no user info in the body";t=Oy.cloneDeep(e.hdb_user);let r=await l_.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(F8,"userInfo");async function G8(){let e=await Xp();return e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token,delete t.hash_function}),[...e.values()]}a(G8,"listUsersExternal");async function Xp(){let e=await l_.searchByValue({schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]}),t={};for(let s of e)t[s.id]=Oy.cloneDeep(s);if(Object.keys(t).length===0)return null;let r=await l_.searchByValue({schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]}),n=new Map;for(let s of r)s=Oy.cloneDeep(s),s.role=t[s.role],q8(s.role),n.set(s.username,s);return n}a(Xp,"listUsers");function q8(e){if(!e){Iy.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(L8)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}a(q8,"appendSystemTablesToRole");async function $c(e=void 0){e?Pi=e:Pi=await Xp()}a($c,"setUsersWithRolesCache");async function $8(){return Pi||await $c(),Pi}a($8,"getUsersWithRolesCache");async function Dy(e,t,r=!0){Pi||await $c();let n=Pi.get(e);if(!n){if(!r)return{username:e};throw new Ks(yy.GENERIC_AUTH_FAIL,Eo.UNAUTHORIZED)}if(n&&!n.active)throw new Ks(yy.USER_INACTIVE,Eo.UNAUTHORIZED);let s={active:n.active,username:n.username};if(n.refresh_token&&(s.refresh_token=n.refresh_token),n.role&&(s.role=n.role),r===!0){if(iU.get(t)===n.password)return s;{let i=c_.validate(n.password,t,n.hash_function||c_.HASH_FUNCTION.MD5);if(i?.then&&(i=await i),i===!0)iU.set(t,n.password);else throw new Ks(yy.GENERIC_AUTH_FAIL,Eo.UNAUTHORIZED)}}return s}a(Dy,"findAndValidateUser");async function V8(){Pi||await $c();for(let[,e]of Pi)if(e.role.role==="super_user")return e}a(V8,"getSuperUser");async function K8(){let e=await Xp(),t=P8.getConfigFromFile(by.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!(r==null||r?.role?.role!==by.ROLE_TYPES_ENUM.CLUSTER_USER))return r.decrypt_hash=Cy.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+sU.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+sU.SERVER_SUFFIX.ADMIN,r}a(K8,"getClusterUser");var mU=[];Jp.invalidateUser=function(e){for(let t of mU)try{t(e)}catch(r){v8.error("Error invalidating user",r)}};Jp.onInvalidatedUser=function(e){mU.push(e)}});var d_=C((Ibe,SU)=>{"use strict";var Vc=ee(),Yn=(k(),P(q)),Y8=jM(),Nbe=ps(),wbe=po(),W8=Kn(),{validateEvent:pU}=Ys(),u_=Vn(),z8=require("process"),{resetDatabases:Q8}=(xe(),P(ct)),j8={[Yn.ITC_EVENT_TYPES.SCHEMA]:J8,[Yn.ITC_EVENT_TYPES.USER]:gU};async function J8(e){let t=pU(e);if(t){Vc.error(t);return}Vc.trace("ITC schemaHandler received schema event:",e),await Y8(e.message),await X8(e.message)}a(J8,"schemaHandler");async function X8(e){try{u_.resetReadTxn(Yn.SYSTEM_SCHEMA_NAME,Yn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),u_.resetReadTxn(Yn.SYSTEM_SCHEMA_NAME,Yn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),u_.resetReadTxn(Yn.SYSTEM_SCHEMA_NAME,Yn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=Q8();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){Vc.error(t)}}a(X8,"syncSchemaMetadata");var EU=[];async function gU(e){try{try{u_.resetReadTxn(Yn.SYSTEM_SCHEMA_NAME,Yn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),u_.resetReadTxn(Yn.SYSTEM_SCHEMA_NAME,Yn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){Vc.warn(r)}let t=pU(e);if(t){Vc.error(t);return}Vc.trace(`ITC userHandler ${Yn.HDB_ITC_CLIENT_PREFIX}${z8.pid} received user event:`,e),await W8.setUsersWithRolesCache();for(let r of EU)r()}catch(t){Vc.error(t)}}a(gU,"userHandler");gU.addListener=function(e){EU.push(e)};SU.exports=j8});var Ys=C((vbe,AU)=>{"use strict";var Pbe=ee(),Ly=ie(),Z8=(k(),P(q)),{ITC_ERRORS:f_}=Un(),{parentPort:Dbe,threadId:eZ,isMainThread:tZ,workerData:Lbe}=require("worker_threads"),{onMessageFromWorkers:rZ,broadcast:Mbe,broadcastWithAcknowledgement:nZ}=ot();AU.exports={sendItcEvent:sZ,validateEvent:TU,SchemaEventMsg:iZ,UserEventMsg:oZ};var Zp;rZ(async(e,t)=>{Zp=Zp||d_(),TU(e),Zp[e.type]&&await Zp[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function sZ(e){return!tZ&&e.message&&(e.message.originator=eZ),nZ(e)}a(sZ,"sendItcEvent");function TU(e){if(typeof e!="object")return f_.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||Ly.isEmpty(e.type))return f_.MISSING_TYPE;if(!e.hasOwnProperty("message")||Ly.isEmpty(e.message))return f_.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||Ly.isEmpty(e.message.originator))return f_.MISSING_ORIGIN;if(Z8.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return f_.INVALID_EVENT(e.type)}a(TU,"validateEvent");function iZ(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(iZ,"SchemaEventMsg");function oZ(e){this.originator=e}a(oZ,"UserEventMsg")});var go=C((Bbe,OU)=>{"use strict";var RU=(k(),P(q)),xbe=ie(),eE=ee(),yU=WM(),Eu,{sendItcEvent:bU}=Ys();function aZ(e){try{eE.info("signalSchemaChange called with message:",e),Eu=Eu||d_();let t=new yU(RU.ITC_EVENT_TYPES.SCHEMA,e);return Eu.schema(t),bU(t)}catch(t){eE.error(t)}}a(aZ,"signalSchemaChange");function cZ(e){try{eE.trace("signalUserChange called with message:",e),Eu=Eu||d_();let t=new yU(RU.ITC_EVENT_TYPES.USER,e);return Eu.user(t),bU(t)}catch(t){eE.error(t)}}a(cZ,"signalUserChange");OU.exports={signalSchemaChange:aZ,signalUserChange:cZ}});var tE=C((kbe,wU)=>{"use strict";var NU=ie(),lZ=(k(),P(q)),uZ=ee(),dZ=Fp(),fZ=kp(),_Z=go(),{SchemaEventMsg:hZ}=Ys(),mZ="already exists in";wU.exports=pZ;async function pZ(e,t,r){if(NU.isEmptyOrZeroLength(r))return r;let n=[];NU.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 EZ(e,t.schema,t.name,i)})),s}a(pZ,"lmdbCheckForNewAttributes");async function EZ(e,t,r,n){let s=new fZ(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await gZ(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(mZ))uZ.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(EZ,"createNewAttribute");async function gZ(e){let t;return t=await dZ(e),_Z.signalSchemaChange(new hZ(process.pid,lZ.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(gZ,"createAttribute")});var gu=C((Gbe,IU)=>{"use strict";var My=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}};IU.exports=My});var PU=C(($be,CU)=>{"use strict";var SZ=gu(),TZ=(k(),P(q)).OPERATIONS_ENUM,vy=class extends SZ{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(TZ.INSERT,r,n,s,i),this.records=t}};CU.exports=vy});var LU=C((Kbe,DU)=>{"use strict";var AZ=gu(),RZ=(k(),P(q)).OPERATIONS_ENUM,Uy=class extends AZ{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(RZ.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};DU.exports=Uy});var vU=C((Wbe,MU)=>{"use strict";var yZ=gu(),bZ=(k(),P(q)).OPERATIONS_ENUM,xy=class extends yZ{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(bZ.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};MU.exports=xy});var xU=C((Qbe,UU)=>{"use strict";var OZ=gu(),NZ=(k(),P(q)).OPERATIONS_ENUM,By=class extends OZ{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(NZ.DELETE,n,s,t,i),this.original_records=r}};UU.exports=By});var __=C((Xbe,FU)=>{"use strict";var Jbe=require("path"),BU=ht(),wZ=PU(),IZ=LU(),CZ=vU(),PZ=xU(),Su=Ft(),HU=ie(),{CONFIG_PARAMS:DZ}=(k(),P(q)),kU=le();kU.initSync();var rE=(k(),P(q)).OPERATIONS_ENUM,{getTransactionAuditStorePath:LZ}=gt();FU.exports=MZ;async function MZ(e,t){if(kU.get(DZ.LOGGING_AUDITLOG)===!1)return;let r=LZ(e.schema,e.table),n=await BU.openEnvironment(r,e.table,!0),s=vZ(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){BU.initializeDBIs(n,Su.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Su.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[Su.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[Su.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),HU.isEmpty(s.user_name)||n.dbis[Su.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[Su.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(MZ,"writeTransaction");function vZ(e,t){let r=HU.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===rE.INSERT)return new wZ(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===rE.UPDATE)return new IZ(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===rE.UPSERT)return new CZ(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===rE.DELETE)return new PZ(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(vZ,"createTransactionObject")});var Hy=C((tOe,GU)=>{"use strict";var UZ=Xf(),eOe=bf(),h_=(k(),P(q)),xZ=Of(),BZ=xc().insertRecords,HZ=ht(),kZ=ee(),FZ=tE(),{getSchemaPath:GZ}=gt(),qZ=__();GU.exports=$Z;async function $Z(e){try{let{schema_table:t,attributes:r}=UZ(e);xZ(e,r,t.hash_attribute),e.schema!==h_.SYSTEM_SCHEMA_NAME&&(r.includes(h_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(h_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(h_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(h_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await FZ(e.hdb_auth_header,t,r),s=GZ(e.schema,e.table),i=await HZ.openEnvironment(s,e.table),o=await BZ(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await qZ(e,o)}catch(c){kZ.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($Z,"lmdbCreateRecords")});var VU=C((nOe,$U)=>{"use strict";var qU=(k(),P(q)),VZ=Hy(),KZ=bf(),YZ=require("fs-extra"),{getSchemaPath:WZ}=gt();$U.exports=zZ;async function zZ(e){let t=[{name:e.schema,createddate:Date.now()}],r=new KZ(qU.SYSTEM_SCHEMA_NAME,qU.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await VZ(r),await YZ.mkdirp(WZ(e.schema))}a(zZ,"lmdbCreateSchema")});var YU=C((iOe,KU)=>{"use strict";var ky=class{static{a(this,"DeleteRecordsResponseObject")}constructor(t=[],r=[],n=void 0,s=[]){this.deleted=t,this.skipped=r,this.txn_time=n,this.original_records=s}};KU.exports=ky});var jU=C((uOe,QU)=>{"use strict";var WU=ht(),Fy=fn(),Gy=Un().LMDB_ERRORS_ENUM,QZ=Ft(),zU=ee(),aOe=ie(),jZ=require("lmdb"),JZ=YU(),XZ=(k(),P(q)),{OVERFLOW_MARKER:cOe,MAX_SEARCH_KEY_LENGTH:lOe}=QZ,ZZ=XZ.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function e5(e,t,r,n){if(Fy.validateEnv(e),t===void 0)throw new Error(Gy.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(Gy.IDS_REQUIRED):new Error(Gy.IDS_MUST_BE_ITERABLE);try{let s=WU.listDBIs(e);WU.initializeDBIs(e,t,s);let i=new JZ,o,c=[],l=[];for(let _=0,h=r.length;_<h;_++)try{o=r[_];let m=e.dbis[t].get(o);if(!m||n&&m[ZZ]>n){i.skipped.push(o);continue}let S=e.dbis[t].ifVersion(o,jZ.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=Fy.getIndexedValues(T);if(N)for(let M=0,H=N.length;M<H;M++)E.remove(N[M],o)}catch{zU.warn(`cannot delete from attribute: ${R}, ${T}:${o}`)}}});c.push(S),l.push(o),i.original_records.push(m)}catch(m){zU.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=Fy.getNextMonotonicTime(),i}catch(s){throw s}}a(e5,"deleteRecords");QU.exports={deleteRecords:e5}});var m_=C((fOe,XU)=>{"use strict";var Tu=ie(),t5=jU(),r5=ht(),{getSchemaPath:n5}=gt(),s5=__(),i5=ee();XU.exports=o5;async function o5(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(Tu.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(Tu.isEmptyOrZeroLength(e.hash_values)&&!Tu.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];Tu.isEmpty(l)||e.hash_values.push(l)}}if(Tu.isEmptyOrZeroLength(e.hash_values))return JU([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(Tu.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=n5(e.schema,e.table),i=await r5.openEnvironment(s,e.table),o=await t5.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await s5(e,o)}catch(c){i5.error(`unable to write transaction due to ${c.message}`)}return JU(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(o5,"lmdbDeleteRecords");function JU(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(JU,"createDeleteResponse")});var $y=C((mOe,ZU)=>{"use strict";var a5=(k(),P(q)),hOe=fn();function qy(e,t){let r=Object.create(null);if(t.length===1&&a5.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(qy,"parseRow");function c5(e,t,r,n){let s=qy(r,e);n.push(s)}a(c5,"searchAll");function l5(e,t,r,n){let s=qy(r,e);n[t]=s}a(l5,"searchAllToMap");function u5(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(u5,"iterateDBI");function Kc(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(Kc,"pushResults");function d5(e,t,r,n,s,i){t.toString().endsWith(e)&&Kc(t,r,n,s,i)}a(d5,"endsWith");function f5(e,t,r,n,s,i){t.toString().includes(e)&&Kc(t,r,n,s,i)}a(f5,"contains");function _5(e,t,r,n,s,i){t>e&&Kc(t,r,n,s,i)}a(_5,"greaterThanCompare");function h5(e,t,r,n,s,i){t>=e&&Kc(t,r,n,s,i)}a(h5,"greaterThanEqualCompare");function m5(e,t,r,n,s,i){t<e&&Kc(t,r,n,s,i)}a(m5,"lessThanCompare");function p5(e,t,r,n,s,i){t<=e&&Kc(t,r,n,s,i)}a(p5,"lessThanEqualCompare");ZU.exports={parseRow:qy,searchAll:c5,searchAllToMap:l5,iterateDBI:u5,endsWith:d5,contains:f5,greaterThanCompare:_5,greaterThanEqualCompare:h5,lessThanCompare:m5,lessThanEqualCompare:p5,pushResults:Kc}});var Au=C((TOe,o0)=>{"use strict";var ma=ht(),EOe=ee(),Wn=fn(),nE=Ft(),zt=Un().LMDB_ERRORS_ENUM,gOe=ie(),E5=(k(),P(q)),sE=$y(),{parseRow:g5}=sE,SOe=require("lmdb"),{OVERFLOW_MARKER:e0,MAX_SEARCH_KEY_LENGTH:S5}=nE;function t0(e,t,r,n=!1,s=void 0,i=void 0){return Yc(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(t0,"iterateFullIndex");function p_(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,u=!1){return Yc(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(p_,"iterateRangeBetween");function Yc(e,t,r,n){let s=e.database||e,i=ma.openDBI(s,r);i[nE.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&ma.openDBI(s,t);let o;e.database?o=e:(o=e.useReadTransaction(),o.database=e);let c=n(o,i,s,t);return c.transaction=o,e.database||(c.onDone=()=>{o.done()}),c}a(Yc,"setupTransaction");function r0(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(e0)){if(!s)if(r)s=ma.openDBI(e,r);else{let l=ma.listDBIs(e);for(let u=0,f=l.length;u<f&&(s=ma.openDBI(e,l[u]),!s[nE.DBI_DEFINITION_NAME].is_hash_attribute);u++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(r0,"getOverflowCheck");function T5(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 Yc(e,t,t,(o,c,l)=>(iE(r),r=E_(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(u=>g5(u.value,r))))}a(T5,"searchAll");function A5(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);iE(r),r=E_(e.database||e,r);let o=new Map;for(let{key:c,value:l}of t0(e,t,t,n,s,i))o.set(c,sE.parseRow(l,r));return o}a(A5,"searchAllToMap");function R5(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=t0(e,void 0,t,r,n,s),c=o.transaction,l=r0(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(R5,"iterateDBI");function y5(e,t){if(Wn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);return ma.statDBI(e,t).entryCount}a(y5,"countAll");function b5(e,t,r,n,s=!1,i=void 0,o=void 0){return pa(e,r,n),Yc(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(b5,"equals");function O5(e,t,r){return pa(e,t,r),ma.openDBI(e,t).getValuesCount(r)}a(O5,"count");function N5(e,t,r,n,s=!1,i=void 0,o=void 0){return pa(e,r,n),Yc(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(N5,"startsWith");function w5(e,t,r,n,s=!1,i=void 0,o=void 0){return n0(e,t,r,n,s,i,o,!0)}a(w5,"endsWith");function n0(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return pa(e,r,n),Yc(e,null,r,(l,u,f,d)=>{let _=r0(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(e0)?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[nE.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(n0,"contains");function I5(e,t,r,n,s=!1,i=void 0,o=void 0){pa(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),p_(e,t,r,n,l,s,i,o,!0,!1)}a(I5,"greaterThan");function C5(e,t,r,n,s=!1,i=void 0,o=void 0){pa(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),p_(e,t,r,n,l,s,i,o,!1,!1)}a(C5,"greaterThanEqual");function P5(e,t,r,n,s=!1,i=void 0,o=void 0){pa(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),p_(e,t,r,l,n,s,i,o,!1,!0)}a(P5,"lessThan");function D5(e,t,r,n,s=!1,i=void 0,o=void 0){pa(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),p_(e,t,r,l,n,s,i,o,!1,!1)}a(D5,"lessThanEqual");function L5(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 p_(e,t,r,n,s,i,o,c)}a(L5,"between");function M5(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(iE(r),r=E_(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=sE.parseRow(c,r)),o}a(M5,"searchByHash");function v5(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(v5,"checkHashExists");function U5(e,t,r,n,s=[]){return i0(e,t,r,n,s),s0(e,t,r,n,s).map(i=>i[1])}a(U5,"batchSearchByHash");function x5(e,t,r,n,s=[]){i0(e,t,r,n,s);let i=new Map;for(let[o,c]of s0(e,t,r,n,s))i.set(o,c);return i}a(x5,"batchSearchByHashToMap");function s0(e,t,r,n,s=[]){return Yc(e,t,t,(i,o,c)=>{r=E_(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,sE.parseRow(f,r)];s.push(u)}).filter(u=>u)})}a(s0,"batchHashSearch");function i0(e,t,r,n,s){if(Wn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);if(iE(r),n==null)throw new Error(zt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(zt.IDS_MUST_BE_ITERABLE)}a(i0,"initializeBatchSearchByHash");function iE(e){if(!Array.isArray(e))throw e===void 0?new Error(zt.FETCH_ATTRIBUTES_REQUIRED):new Error(zt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(iE,"validateFetchAttributes");function pa(e,t,r){if(Wn.validateEnv(e),t===void 0)throw new Error(zt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(zt.SEARCH_VALUE_REQUIRED);if(r?.length>S5)throw new Error(zt.SEARCH_VALUE_TOO_LARGE)}a(pa,"validateComparisonFunctions");function E_(e,t){return t.length===1&&E5.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=ma.listDBIs(e)),t}a(E_,"setGetWholeRowAttributes");o0.exports={searchAll:T5,searchAllToMap:A5,count:O5,countAll:y5,equals:b5,startsWith:N5,endsWith:w5,contains:n0,searchByHash:M5,setGetWholeRowAttributes:E_,batchSearchByHash:U5,batchSearchByHashToMap:x5,checkHashExists:v5,iterateDBI:R5,greaterThan:I5,greaterThanEqual:C5,lessThan:P5,lessThanEqual:D5,between:L5}});var Ru=C((ROe,d0)=>{var a0=require("lodash"),c0=it(),qe=require("joi"),B5=ie(),{hdb_schema_table:g_,checkValidTable:l0,hdb_table:u0,hdb_database:oE}=Ni(),{handleHDBError:H5,hdb_errors:k5}=he(),{getDatabases:F5}=(xe(),P(ct)),{HTTP_STATUS_CODES:G5}=k5,q5=qe.object({database:oE,schema:oE,table:u0,search_attribute:g_,search_value:qe.any().required(),get_attributes:qe.array().min(1).items(qe.alternatives(g_,qe.object())).optional(),desc:qe.bool(),limit:qe.number().integer().min(1),offset:qe.number().integer().min(0)}),$5=qe.object({database:oE,schema:oE,table:u0,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(g_,qe.object())).optional(),sort:qe.object({attribute:qe.alternatives(g_,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(g_,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()});d0.exports=function(e,t){let r=null;switch(t){case"value":r=c0.validateBySchema(e,q5);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(l0("database",e.schema)),i(l0("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=c0.validateBySchema(e,$5);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=B5.checkGlobalSchemaTable(e.schema,e.table);if(s)return H5(new Error,s,G5.NOT_FOUND);let o=F5()[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=a0.filter(c,f=>f!=="*"&&!f.startsWith?.("$")&&f.attribute!=="*"&&!Array.isArray(f)&&!f.name&&!a0.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((bOe,f0)=>{"use strict";var V5=ht(),K5=Ru(),{getSchemaPath:Y5}=gt();f0.exports=W5;function W5(e){let t=K5(e,"hashes");if(t)throw t;let r=Y5(e.schema,e.table);return V5.openEnvironment(r,e.table)}a(W5,"initialize")});var Ky=C((NOe,_0)=>{"use strict";var z5=Au(),Q5=Vy();_0.exports=j5;async function j5(e){let t=await Q5(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return z5.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(j5,"lmdbGetDataByHash")});var yu=C((IOe,h0)=>{"use strict";var Yy=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};h0.exports=Yy});var p0=C((DOe,m0)=>{"use strict";var POe=yu(),J5=Au(),X5=Vy();m0.exports=Z5;async function Z5(e){let t=await X5(e),r=global.hdb_schema[e.schema][e.table];return J5.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(Z5,"lmdbSearchByHash")});var Ws=C((MOe,E0)=>{"use strict";var Wy=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}};E0.exports=Wy});var aE=C((UOe,y0)=>{"use strict";var jr=Au(),e9=ht(),t9=ie(),$e=Ft(),Wc=(k(),P(q)),r9=fo(),g0=Un().LMDB_ERRORS_ENUM,{getSchemaPath:n9}=gt(),So=Wc.SEARCH_WILDCARDS;async function s9(e,t,r){let n;e.schema===Wc.SYSTEM_SCHEMA_NAME?n=r9[e.table]:n=global.hdb_schema[e.schema][e.table];let s=R0(e,n.hash_attribute,r,t);return T0(e,s,n.hash_attribute,r)}a(s9,"prepSearch");async function T0(e,t,r,n){let s=n9(e.schema,e.table),i=await e9.openEnvironment(s,e.table),o=A0(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(i9(e,r)===!1){let f=e.search_attribute;if(f===r)return n?S0(o,()=>!0):o.map(_=>({[r]:_.key}));let d=a(_=>({[r]:_.value,[f]:_.key}),"toObject");return n?S0(o,d):o.map(d)}let u=e.search_attribute===r?o.map(f=>f.key):o.map(f=>f.value);return n===!0?jr.batchSearchByHashToMap(c,r,e.get_attributes,u):jr.batchSearchByHash(c,r,e.get_attributes,u)}a(T0,"executeSearch");function A0(e,t,r,n){let s,i=n;t.get_attributes.indexOf(n)<0&&(i=void 0);let{reverse:o,limit:c,offset:l}=t;switch(o=typeof o=="boolean"?o:!1,c=Number.isInteger(c)?c:void 0,l=Number.isInteger(l)?l:void 0,r){case $e.SEARCH_TYPES.EQUALS:s=jr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.CONTAINS:s=jr.contains(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.ENDS_WITH:case $e.SEARCH_TYPES._ENDS_WITH:s=jr.endsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.STARTS_WITH:case $e.SEARCH_TYPES._STARTS_WITH:s=jr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return jr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case $e.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return jr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case $e.SEARCH_TYPES.SEARCH_ALL:return jr.searchAll(e,n,t.get_attributes,o,c,l);case $e.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return jr.searchAllToMap(e,n,t.get_attributes,o,c,l);case $e.SEARCH_TYPES.BETWEEN:s=jr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,l);break;case $e.SEARCH_TYPES.GREATER_THAN:case $e.SEARCH_TYPES._GREATER_THAN:s=jr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.GREATER_THAN_EQUAL:case $e.SEARCH_TYPES._GREATER_THAN_EQUAL:s=jr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.LESS_THAN:case $e.SEARCH_TYPES._LESS_THAN:s=jr.lessThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case $e.SEARCH_TYPES.LESS_THAN_EQUAL:case $e.SEARCH_TYPES._LESS_THAN_EQUAL:s=jr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;default:return Object.create(null)}return s}a(A0,"searchByType");function S0(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(S0,"createMapFromIterable");function i9(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(i9,"checkToFetchMore");function R0(e,t,r,n){if(t9.isEmpty(n)){let s=e.search_value;typeof s=="object"?s=JSON.stringify(s):s=s.toString();let i=s.charAt(0),o=s.charAt(s.length-1),c=!1;if(e.search_attribute===t&&(c=!0),So.indexOf(s)>-1)return r===!0?$e.SEARCH_TYPES.SEARCH_ALL_TO_MAP:$e.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(So[0])<0&&s.indexOf(So[1])<0)return c===!0?r===!0?$e.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:$e.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:$e.SEARCH_TYPES.EQUALS;if(So.indexOf(i)>=0&&So.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),$e.SEARCH_TYPES.CONTAINS;if(So.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),$e.SEARCH_TYPES.ENDS_WITH;if(So.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),$e.SEARCH_TYPES.STARTS_WITH;if(s.includes(So[0])||s.includes(So[1]))return $e.SEARCH_TYPES.EQUALS;throw new Error(g0.UNKNOWN_SEARCH_TYPE)}else switch(n){case Wc.VALUE_SEARCH_COMPARATORS.BETWEEN:return $e.SEARCH_TYPES.BETWEEN;case Wc.VALUE_SEARCH_COMPARATORS.GREATER:return $e.SEARCH_TYPES.GREATER_THAN;case Wc.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return $e.SEARCH_TYPES.GREATER_THAN_EQUAL;case Wc.VALUE_SEARCH_COMPARATORS.LESS:return $e.SEARCH_TYPES.LESS_THAN;case Wc.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return $e.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(g0.UNKNOWN_SEARCH_TYPE)}}a(R0,"createSearchTypeFromSearchObject");y0.exports={executeSearch:T0,createSearchTypeFromSearchObject:R0,prepSearch:s9,searchByType:A0}});var O0=C((HOe,b0)=>{"use strict";var BOe=Ws(),o9=Ru(),a9=ie(),c9=(k(),P(q)),l9=aE();b0.exports=u9;function u9(e,t){if(!a9.isEmpty(t)&&c9.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=o9(e,"value");if(n)throw n;return l9.prepSearch(e,t,!0)}a(u9,"lmdbGetDataByValue")});var S_=C((GOe,N0)=>{"use strict";var FOe=Ws(),d9=Ru(),f9=ie(),_9=(k(),P(q)),h9=aE();N0.exports=m9;async function m9(e,t){if(!f9.isEmpty(t)&&_9.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=d9(e,"value");if(n)throw n;return h9.prepSearch(e,t,!1)}a(m9,"lmdbSearchByValue")});var I0=C((VOe,w0)=>{"use strict";var $Oe=Ft(),zy=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}},Qy=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},jy=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};w0.exports={SearchByConditionsObject:zy,SearchCondition:Qy,SortAttribute:jy}});var M0=C((zOe,L0)=>{"use strict";var YOe=I0().SearchByConditionsObject,p9=Ws(),E9=Ru(),Jy=Au(),cE=Ft(),{Resource:WOe}=(oa(),P(jA)),D0=aE(),g9=$y(),S9=require("lodash"),{getSchemaPath:T9}=gt(),C0=ht(),{handleHDBError:A9,hdb_errors:R9}=he(),{HTTP_STATUS_CODES:y9}=R9,b9=1e8;L0.exports=O9;async function O9(e){let t=E9(e,"conditions");if(t)throw A9(t,t.message,y9.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=T9(e.schema,e.table),n=await C0.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let u of e.conditions)C0.openDBI(n,u.search_attribute);let i=S9.sortBy(e.conditions,u=>{if(u.estimated_count===void 0){let f=u.search_type;f===cE.SEARCH_TYPES.EQUALS?u.estimated_count=Jy.count(n,u.search_attribute,u.search_value):f===cE.SEARCH_TYPES.CONTAINS||f===cE.SEARCH_TYPES.ENDS_WITH?u.estimated_count=1/0:u.estimated_count=b9}return u.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await P0(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(D0.filterByType),d=f.length,_=Jy.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=>g9.parseRow(h,_))}else{for(let d=1;d<i.length;d++){let _=i[d],h=await P0(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=Jy.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(O9,"lmdbSearchByConditions");async function P0(e,t,r,n){let s=new p9(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===cE.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,D0.searchByType(e,s,i,n).map(o=>o.value)}a(P0,"executeConditionSearch")});var T_=C((jOe,v0)=>{"use strict";var N9=(k(),P(q)).OPERATIONS_ENUM,Xy=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=N9.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};v0.exports=Xy});var Zy=C((XOe,q0)=>{"use strict";var H0=Ws(),k0=T_(),F0=S_(),G0=m_(),Rn=(k(),P(q)),U0=ie(),x0=ht(),{getTransactionAuditStorePath:w9,getSchemaPath:I9}=gt(),B0=ee();q0.exports=C9;async function C9(e){try{if(U0.isEmpty(global.hdb_schema[e.schema])||U0.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await P9(e),await D9(e);let t=I9(e.schema,e.table);try{await x0.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=w9(e.schema,e.table);await x0.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(C9,"lmdbDropTable");async function P9(e){let t=new H0(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 F0(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 k0(Rn.SYSTEM_SCHEMA_NAME,Rn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await G0(s)}a(P9,"deleteAttributesFromSystem");async function D9(e){let t=new H0(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 F0(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 k0(Rn.SYSTEM_SCHEMA_NAME,Rn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await G0(s)}catch(i){throw i}}a(D9,"dropTableFromSystem")});var V0=C((eNe,$0)=>{"use strict";var L9=require("fs-extra"),M9=Ws(),v9=yu(),U9=T_(),x9=Zy(),B9=m_(),H9=Ky(),k9=S_(),To=(k(),P(q)),{getSchemaPath:F9}=gt(),{handleHDBError:G9,hdb_errors:q9}=he(),{HDB_ERROR_MSGS:$9,HTTP_STATUS_CODES:V9}=q9;$0.exports=K9;async function K9(e){let t;try{t=await Y9(e.schema);let r=new M9(To.SYSTEM_SCHEMA_NAME,To.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,To.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[To.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await k9(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await x9(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new U9(To.SYSTEM_SCHEMA_NAME,To.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await B9(s);let i=F9(t);await L9.remove(i)}catch(r){throw r}}a(K9,"lmdbDropSchema");async function Y9(e){let t=new v9(To.SYSTEM_SCHEMA_NAME,To.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[To.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await H9(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw G9(new Error,$9.SCHEMA_NOT_FOUND(e),V9.NOT_FOUND,void 0,void 0,!0);return n}a(Y9,"validateDropSchema")});var A_=C((rNe,K0)=>{"use strict";var eb=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};K0.exports=eb});var rb=C((iNe,Y0)=>{"use strict";var W9=require("fs-extra"),lE=ht(),{getTransactionAuditStorePath:z9}=gt(),tb=Ft(),sNe=A_();Y0.exports=Q9;async function Q9(e){let t;try{let r=z9(e.schema,e.table);await W9.mkdirp(r),t=await lE.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{lE.createDBI(t,tb.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),lE.createDBI(t,tb.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),lE.createDBI(t,tb.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(Q9,"createTransactionsAuditEnvironment")});var Q0=C((cNe,z0)=>{"use strict";var nb=(k(),P(q)),W0=ht(),j9=xc(),{getSystemSchemaPath:J9,getSchemaPath:X9}=gt(),aNe=fo(),Z9=Fp(),sb=kp(),e7=ee(),t7=rb();z0.exports=r7;async function r7(e,t){let r=X9(t.schema,t.table),n=new sb(t.schema,t.table,nb.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new sb(t.schema,t.table,nb.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new sb(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await W0.createEnvironment(r,t.table),e!==void 0){let o=await W0.openEnvironment(J9(),nb.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await j9.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 ib(n),await ib(s),await ib(i)}await t7(t)}catch(o){throw o}}a(r7,"lmdbCreateTable");async function ib(e){try{await Z9(e)}catch(t){e7.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(ib,"createAttribute")});var J0=C((uNe,j0)=>{"use strict";var n7=Xf(),s7=Of(),i7=tE(),R_=(k(),P(q)),o7=xc().updateRecords,a7=ht(),{getSchemaPath:c7}=gt(),l7=__(),u7=ee();j0.exports=d7;async function d7(e){try{let{schema_table:t,attributes:r}=n7(e);s7(e,r,t.hash_attribute),e.schema!==R_.SYSTEM_SCHEMA_NAME&&(r.includes(R_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(R_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(R_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(R_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await i7(e.hdb_auth_header,t,r),s=c7(e.schema,e.table),i=await a7.openEnvironment(s,e.table),o=await o7(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await l7(e,o)}catch(c){u7.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(d7,"lmdbUpdateRecords")});var Z0=C((fNe,X0)=>{"use strict";var f7=(k(),P(q)).OPERATIONS_ENUM,ob=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=f7.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};X0.exports=ob});var tx=C((mNe,ex)=>{"use strict";var hNe=Z0(),_7=Xf(),h7=Of(),m7=tE(),y_=(k(),P(q)),p7=xc().upsertRecords,E7=ht(),{getSchemaPath:g7}=gt(),S7=__(),T7=ee(),{handleHDBError:A7,hdb_errors:R7}=he();ex.exports=y7;async function y7(e){let t;try{t=_7(e)}catch(l){throw A7(l,l.message,R7.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;h7(e,n,r.hash_attribute),e.schema!==y_.SYSTEM_SCHEMA_NAME&&(n.includes(y_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(y_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(y_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(y_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await m7(e.hdb_auth_header,r,n),i=g7(e.schema,e.table),o=await E7.openEnvironment(i,e.table),c=await p7(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await S7(e,c)}catch(l){T7.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(y7,"lmdbUpsertRecords")});var nx=C((ENe,rx)=>{"use strict";var ab=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};rx.exports=ab});var ix=C((SNe,sx)=>{"use strict";var cb=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}};sx.exports=cb});var cx=C((RNe,ax)=>{"use strict";var lb=ht(),{getTransactionAuditStorePath:b7}=gt(),ANe=nx(),b_=Ft(),O7=ie(),ox=ix(),N7=require("util").promisify,w7=N7(setTimeout),I7=1e4,C7=100;ax.exports=P7;async function P7(e){let t=b7(e.schema,e.table),r=await lb.openEnvironment(t,e.table,!0),n=lb.listDBIs(r);lb.initializeDBIs(r,b_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new ox;do s=await D7(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 w7(C7);while(s.transactions_deleted>0);return i}a(P7,"deleteAuditLogsBefore");async function D7(e,t){let r=new ox;try{let n=e.dbis[b_.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[b_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];O7.isEmpty(c)||(s=e.dbis[b_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[b_.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>I7)break}return await s,r}catch(n){throw n}}a(D7,"deleteTransactions")});var ux=C((bNe,lx)=>{"use strict";var ub=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};lx.exports=ub});var fx=C((wNe,dx)=>{"use strict";var L7=Ws(),M7=T_(),NNe=ux(),Di=(k(),P(q)),v7=ie(),db=ht(),U7=fo(),x7=S_(),B7=m_(),{getSchemaPath:H7}=gt();dx.exports=k7;async function k7(e,t=!0){let r;e.schema===Di.SYSTEM_SCHEMA_NAME?r=U7[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await G7(e),s=H7(e.schema,e.table),i=await db.openEnvironment(s,e.table);return t===!0&&await F7(e,i,r.hash_attribute),db.dropDBI(i,e.attribute),n}a(k7,"lmdbDropAttribute");async function F7(e,t,r){let n=db.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(F7,"removeAttributeFromAllObjects");async function G7(e){let t=new L7(Di.SYSTEM_SCHEMA_NAME,Di.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Di.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Di.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,Di.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await x7(t)).filter(o=>o[Di.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(v7.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[Di.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new M7(Di.SYSTEM_SCHEMA_NAME,Di.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return B7(i)}a(G7,"dropAttributeFromSystem")});var gx=C((PNe,Ex)=>{"use strict";var fb=ht(),bu=Ft(),CNe=fn(),_b=(k(),P(q)),_x=ie(),{getTransactionAuditStorePath:q7}=gt(),$7=Au(),uE=gu(),V7=ee();Ex.exports=K7;async function K7(e){let t=q7(e.schema,e.table),r=await fb.openEnvironment(t,e.table,!0),n=fb.listDBIs(r);fb.initializeDBIs(r,bu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case _b.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return hx(r,e.search_values);case _b.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,W7(r,e.search_values,s);case _b.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return Y7(r,e.search_values);default:return hx(r)}}a(K7,"readAuditLog");function hx(e,t=[0,Date.now()]){_x.isEmpty(t[0])&&(t[0]=0),_x.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[bu.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 uE,s))}a(hx,"searchTransactionsByTimestamp");function Y7(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[bu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,px(e,i))}return Object.fromEntries(r)}a(Y7,"searchTransactionsByUsername");function W7(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let u=t[c],f=$7.equals(e,bu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,bu.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=px(e,s),o=new Map;for(let c=0;c<i.length;c++){let l=i[c],u=l.timestamp,f=n.get(u);mx(l,"records",r,f,o),mx(l,"original_records",r,f,o)}return Object.fromEntries(o)}a(W7,"searchTransactionsByHashValues");function mx(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 uE(e.operation,e.user_name,i,void 0);d[t]=[c],u.push(d)}}else{let u=new uE(e.operation,e.user_name,i,void 0);u[t]=[c],s.set(l,[u])}}}a(mx,"loopRecords");function px(e,t){let r=[];try{let n=e.dbis[bu.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 uE,i);r.push(o)}}catch(i){V7.warn(i)}return r}catch(n){throw n}}a(px,"batchSearchTransactions")});var Tx=C((vNe,Sx)=>{"use strict";var{getSchemaPath:LNe}=gt(),MNe=ht(),{database:z7}=(xe(),P(ct));Sx.exports={writeTransaction:Q7};async function Q7(e,t,r){return z7({database:e,table:t}).transaction(r)}a(Q7,"writeTransaction")});var bx=C((xNe,yx)=>{"use strict";var{getSchemaPath:Ax}=gt(),Rx=ht();yx.exports={flush:j7,resetReadTxn:J7};async function j7(e,t){return(await Rx.openEnvironment(Ax(e,t),t.toString())).flushed}a(j7,"flush");async function J7(e,t){try{(await Rx.openEnvironment(Ax(e,t),t.toString())).resetReadTxn()}catch{}}a(J7,"resetReadTxn")});var Ix=C((HNe,wx)=>{"use strict";var{Readable:X7}=require("stream"),{getDatabases:Z7}=(xe(),P(ct)),{readSync:eee,openSync:tee,createReadStream:Ox}=require("fs"),{open:ree}=require("lmdb"),Nx=Wf(),nee=zf(),{AUDIT_STORE_OPTIONS:see}=(Ri(),P(Cx)),{INTERNAL_DBIS_NAME:iee,AUDIT_STORE_NAME:oee}=Ft();wx.exports=cee;var hb=32768,aee=100;async function cee(e){let t=e.database||e.schema||"data",r=Z7()[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=ree({noSync:!0,maxDbs:nee.MAX_DBS}),_,h=d.openDB(iee,new Nx(!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),M=f.openDB(E,T);for(let{key:H,version:X,value:W}of M.getRange({start:null,transaction:m,versions:M.useVersions}))_=N.put(H,W,X),S++%aee===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("/"),M=!N,H=new Nx(!M,M);await g(E,H)}e.include_audit&&await g(oee,{...see}),await _;let R=Ox(d.path);return R.headers=l(),R.on("close",()=>{m.done(),d.close()}),R}let o=r[Object.keys(r)[0]].primaryStore,c=tee(o.path);return o.transaction(()=>{let u=Buffer.alloc(hb);eee(c,u,0,hb),o.resetReadTxn();let f=o.useReadTransaction();f.renew();let d=Ox(null,{fd:c,start:hb}),_=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(cee,"getBackup")});var Lx=C((FNe,Dx)=>{"use strict";var lee=ee(),{handleHDBError:uee}=he(),dee=aM(),fee=Fp(),_ee=Hy(),hee=VU(),mee=m_(),pee=Ky(),Eee=p0(),gee=O0(),See=S_(),Tee=M0(),Aee=V0(),Ree=Q0(),yee=J0(),bee=tx(),Oee=cx(),Nee=Zy(),wee=fx(),Iee=gx(),Cee=Tx(),Px=bx(),Pee=Ix(),mb=class extends dee{static{a(this,"LMDBBridge")}async searchByConditions(t){return Tee(t)}async getDataByHash(t){return await pee(t)}async searchByHash(t){return await Eee(t)}async getDataByValue(t,r){return await gee(t,r)}async searchByValue(t){return await See(t)}async createSchema(t){return await hee(t)}async dropSchema(t){return await Aee(t)}async createTable(t,r){return await Ree(t,r)}async dropTable(t){return await Nee(t)}async createAttribute(t){return await fee(t)}async createRecords(t){return await _ee(t)}async updateRecords(t){return await yee(t)}async upsertRecords(t){try{return await bee(t)}catch(r){throw uee(r,null,null,lee.ERR,r)}}async deleteRecords(t){return await mee(t)}async dropAttribute(t){return await wee(t)}async deleteAuditLogsBefore(t){return await Oee(t)}async readAuditLog(t){return await Iee(t)}writeTransaction(t,r,n){return Cee.writeTransaction(t,r,n)}flush(t,r){return Px.flush(t,r)}resetReadTxn(t,r){return Px.resetReadTxn(t,r)}getBackup(t){return Pee(t)}};Dx.exports=mb});var Eb={};Ue(Eb,{add:()=>dE,applyReverse:()=>Mx,getRecordAtTime:()=>pb,rebuildUpdateBefore:()=>fE});function dE(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 fE(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,dE(n,s,i)}else r&&(n||(n={}),n[s]=i)}else n||(n={}),n[s]=e[s];return n}function Mx(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=Dee[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=vx}}function pb(e,t,r){let n=r.rootStore.auditStore,s={...e.value},i=e.localTime;for(;i>t;){let l=n.get(i),u=St(l);switch(u.type){case"put":s=u.getValue(r);break;case"patch":Mx(s,u.getValue(r));break;case"delete":s=null}i=u.previousLocalTime}let o={},c=0;for(let l in s)s[l]===vx&&(o[l]=!0,c++);for(;c>0&&i>0;){let l=n.get(i),u=St(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 Dee,vx,_E=Re(()=>{Ri();a(dE,"add");dE.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)};Dee={add:dE};a(fE,"rebuildUpdateBefore");a(Mx,"applyReverse");vx={};a(pb,"getRecordAtTime")});function yn(e){let t=e.getChanges();return t||(t=Object.create(null),e._setChanges(t)),t}function EE(e,t){let r=e.prototype,n={},s=t.attributes||t.properties||[];for(let c of s){let l=c.name,u,f;if(c.resolve)f={get(){return c.resolve(this,this.getContext?.())},set(d){return c.set(this,d)},configurable:!0};else{switch(c.type){case"String":u=a(function(d){if(!(typeof d=="string"||d==null&&c.nullable!==!1))throw new zn.ClientError(`${l} must be a string, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"ID":u=a(function(d){if(!(typeof d=="string"||d?.length>0&&d.every?.(_=>typeof _=="string")||d==null&&c.nullable!==!1))throw new zn.ClientError(`${l} must be a string, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"Float":case"Number":u=a(function(d){let _=d?.__op__?d.value:d;if(!(typeof _=="number"||d==null&&c.nullable!==!1))throw new zn.ClientError(`${l} must be a number, attempt to assign ${_}`);yn(this)[l]=d},"set");break;case"Int":u=a(function(d){let _=d?.__op__?d.value:d;if(!(_>>0===_||d==null&&c.nullable!==!1))if(typeof _=="number"&&Math.abs((_>>0)-_)<=1)_=Math.round(_),d?.__op__?d.value=_:d=_;else throw new zn.ClientError(`${l} must be an integer between -2147483648 and 2147483647, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"Long":u=a(function(d){let _=d?.__op__?d.value:d;if(!(Math.round(_)===d&&Math.abs(_)<=9007199254740992||d==null&&c.nullable!==!1))if(typeof _=="number"&&Math.abs(_)<=9007199254740992)_=Math.round(_),d?.__op__?d.value=_:d=_;else throw new zn.ClientError(`${l} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"BigInt":u=a(function(d){let _=d?.__op__?d.value:d;if(!(typeof _=="bigint"||d==null&&c.nullable!==!1))if(typeof _=="string"||typeof _=="number")_=BigInt(_),d?.__op__?d.value=_:d=_;else throw new zn.ClientError(`${l} must be a number, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"Boolean":u=a(function(d){if(!(typeof d=="boolean"||d==null&&c.nullable!==!1))throw new zn.ClientError(`${l} must be a boolean, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"Date":u=a(function(d){if(!(d instanceof Date||d==null&&c.nullable!==!1))if(typeof d=="string"||typeof d=="number")d=new Date(d);else throw new zn.ClientError(`${l} must be a Date, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"Bytes":u=a(function(d){if(!(d instanceof Uint8Array||d==null&&c.nullable!==!1))throw new zn.ClientError(`${l} must be a Buffer or Uint8Array, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"Blob":u=a(function(d){if(!(d instanceof Ai||d==null&&c.nullable!==!1))throw new zn.ClientError(`${l} must be a Blob, attempt to assign ${d}`);yn(this)[l]=d},"set");break;case"Any":case void 0:u=a(function(d){yn(this)[l]=d},"set");break;default:u=a(function(d){if(!(typeof d=="object"||d==null&&c.nullable!==!1))throw new zn.ClientError(`${l} must be an object, attempt to assign ${d}`);yn(this)[l]=d},"set")}f={get(){let d=this.getChanges?.();if(d&&l in d){let h=d[l];if(h?.__op__){let m=this.getRecord()?.[l];return h.update(m)}return h}let _=this.getRecord()?.[l];if(_&&typeof _=="object"){let h=gb(_,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,xx);break}o=c}while(o&&o!==xx)}function gb(e,t){let r;switch(e.constructor){case Object:return t?(r=t.TrackedObject,r||(t.TrackedObject=r=class extends O_{static{a(this,"TrackedObject")}},EE(r,t)),new r(e)):new O_(e);case Array:let n=new mE(e.length,e);for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=gb(o,t?.elements)),n[s]=o}return n;default:return e}}function gE(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=gE(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 Ou(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=Ou(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=Eb[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=Ou(s);r[n]=s}if(!Array.isArray(e))for(let n in e)Lee.call(e,n)&&(r||(r={...e.getRecord?.()}),r[n]=e[n]);return r?Object.freeze(r):e.getRecord?.()??e}function hE(e){let t=e.getRecord?.();if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[zc]||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(hE(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(hE(s))return!0}else return!0}else return!0}}return!1}var zn,Ux,xx,O_,Lee,zc,mE,pE,Sb=Re(()=>{zn=v(he());_E();gn();a(yn,"getChanges");a(EE,"assignTrackedAccessors");Ux=Object.prototype,xx=new Proxy({},{get(e,t,r){if(typeof t=="string"){if(t==="then"||t==="getRecord"||t==="getChanges")return;if(Ux[t])return Ux[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=gb(s);if(i)return n||(n=Object.create(null),r._setChanges(n)),n[t]=i,i}return s}}});a(gb,"trackObject");O_=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}};EE(O_,{});a(gE,"collapseData");Lee=Object.prototype.hasOwnProperty;a(Ou,"updateAndFreeze");a(hE,"hasChanges");zc=Symbol.for("has-array-changes"),mE=class extends Array{static{a(this,"TrackedArray")}#e;[zc];constructor(t,r){super(t),this.#e=r}getRecord(){return this.#e}splice(...t){return this[zc]=!0,super.splice(...t)}push(...t){return this[zc]=!0,super.push(...t)}pop(){return this[zc]=!0,super.pop()}unshift(...t){return this[zc]=!0,super.unshift(...t)}shift(){return this[zc]=!0,super.shift()}};mE.prototype.constructor=Array;pE=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var Vx={};Ue(Vx,{ResourceBridge:()=>Rb});function yb({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 Hx(e,t){let r=Li(e),n=yb(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;Pt(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&&gE(f)}catch(d){f={message:d.toString()}}return t?{value:{key:u,value:f}}:{value:f}}else return o(),{done:!0}},return(u){return o(),{value:u,done:!0}},throw(u){return o(),{done:!0}}}}}}function Li(e){let t=e.database||e.schema||vee,r=Xe()[t];if(!r)throw(0,zs.handleHDBError)(new Error,Mee.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function kx(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*Fx(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 Gx,SE,zs,qx,Tb,Ab,$x,Mee,vee,Uee,xee,Bx,Rb,Kx=Re(()=>{"use strict";Gx=v(Lx()),SE=v(Ru()),zs=v(he());xe();qx=v(Xf());k();Tb=v(go()),Ab=v(Ys()),$x=v(ie());Sc();Sb();({HDB_ERROR_MSGS:Mee}=zs.hdb_errors),vee="data",Uee=1e4,xee=10,Rb=class extends Gx.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,SE.default)(t,"conditions");if(r)throw(0,zs.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=Li(t);if(!n)throw new zs.ClientError(`Table ${t.table} not found`);let s=t.conditions.map(i);function i(o){return o.conditions?(o.conditions=o.conditions.map(i),o):{attribute:o.search_attribute??o.attribute,comparator:o.search_type??o.comparator,value:o.search_value!==void 0?o.search_value:o.value}}return a(i,"mapCondition"),n.search({conditions:s,operator:t.operator?t.operator.toLowerCase():void 0,limit:t.limit,offset:t.offset,reverse:t.reverse,select:yb(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}]}_t({database:r.database??r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration,audit:r.audit})}async createAttribute(t){return await Li(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=Li(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=a((o,c,l)=>(c={...c},delete c[n],r.primaryStore.ifVersion(o,l,()=>r.primaryStore.put(o,c,l)).then(u=>{if(!u){let{value:f,version:d}=r.primaryStore.getEntry(o);return i(o,f,d)}})),"deleteRecord");for(let{key:o,value:c,version:l}of r.primaryStore.getRange({start:!0,versions:!0}))s=i(o,c,l),await new Promise(u=>setImmediate(u));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){Li(t).dropTable()}createSchema(t){return Nu({database:t.schema,table:null}),Tb.signalSchemaChange(new Ab.SchemaEventMsg(process.pid,Yt.CREATE_SCHEMA,t.schema))}async dropSchema(t){await bb(t.schema),Tb.signalSchemaChange(new Ab.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,qx.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),Pt(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}_&&(_=gE(_));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),Pt(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 kx(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:Hm.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,$x.async_set_timeout)(xee),l=[],s=!0},"chunkDelete");for await(let f of n)l.push(f[r.primaryKey]),c++,c%Uee===0&&await u();return l.length>0&&await u(),s?kx(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,SE.default)(t,"hashes");if(r)throw r;return Hx(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of Hx(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&AA[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,SE.default)(t,"value");if(n)throw n;let s=Li(t);if(!s)throw new zs.ClientError(`Table ${t.table} not found`);let i=t.search_value;i.includes?.("*")&&(i.startsWith("*")?i.endsWith("*")?i!=="*"&&(r="contains",i=i.slice(1,-1)):(r="ends_with",i=i.slice(1)):i.endsWith("*")&&(r="starts_with",i=i.slice(0,-1))),r===Hm.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:yb(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async getDataByValue(t,r){let n=new Map,s=Li(t);t.get_attributes&&!t.get_attributes.includes(s.primaryKey)&&t.get_attributes[0]!=="*"&&t.get_attributes.push(s.primaryKey);for await(let i of this.searchByValue(t,r))n.set(i[s.primaryKey],i);return n}resetReadTxn(t,r){Li({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return Li(t).deleteHistory(t.timestamp,t.cleanup_deleted_records)}async readAuditLog(t){let r=Li(t),n={};switch(t.search_type){case km.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 km.USERNAME:let s=t.search_values;for await(let i of Fx(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return Fx(r,t.search_values?.[0],t.search_values?.[1],t.limit)}}};a(yb,"getSelect");a(Hx,"getRecords");a(Li,"getTable");a(kx,"createDeleteResponse");a(Fx,"groupRecordsInHistory")});var Vn=C((ZNe,Yx)=>{"use strict";var{ResourceBridge:Bee}=(Kx(),P(Vx)),Hee=le();Hee.initSync();var TE;function kee(){return TE||(TE=new Bee,TE)}a(kee,"getBridge");Yx.exports=kee()});var An=C((twe,jx)=>{"use strict";var RE=TR(),xr=ie(),Fee=require("util"),yE=Vn(),Gee=ps(),Wx=ee(),{handleHDBError:Qc,hdb_errors:qee}=he(),{HTTP_STATUS_CODES:jc}=qee,$ee=Fee.promisify(Gee.getTableSchema),Vee="updated",zx="inserted",Qx="upserted";jx.exports={insert:Yee,update:Wee,upsert:zee,validation:Kee,flush:Qee};async function Kee(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 $ee(e.schema,e.table),r=RE(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 Wx.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 Wx.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(Kee,"validation");async function Yee(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=RE(e);if(t)throw Qc(new Error,t.message,jc.BAD_REQUEST);xr.transformReq(e);let r=xr.checkSchemaTableExist(e.schema,e.table);if(r)throw Qc(new Error,r,jc.BAD_REQUEST);let n=await yE.createRecords(e);return AE(zx,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(Yee,"insertData");async function Wee(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=RE(e);if(t)throw Qc(new Error,t.message,jc.BAD_REQUEST);xr.transformReq(e);let r=xr.checkSchemaTableExist(e.schema,e.table);if(r)throw Qc(new Error,r,jc.BAD_REQUEST);let n=await yE.updateRecords(e);return xr.isEmpty(n.existing_rows)?AE(Vee,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):AE(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(Wee,"updateData");async function zee(e){if(e.operation!=="upsert")throw Qc(new Error,"invalid operation, must be upsert",jc.INTERNAL_SERVER_ERROR);let t=RE(e);if(t)throw Qc(new Error,t.message,jc.BAD_REQUEST);xr.transformReq(e);let r=xr.checkSchemaTableExist(e.schema,e.table);if(r)throw Qc(new Error,r,jc.BAD_REQUEST);let n=await yE.upsertRecords(e);return AE(Qx,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(zee,"upsertData");function AE(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===zx?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===Qx?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(AE,"returnObject");function Qee(e){return xr.transformReq(e),yE.flush(e.schema,e.table)}a(Qee,"flush")});var rB=C((nwe,tB)=>{var wu=require("validate.js"),Xx=it(),Iu=(k(),P(q)),{handleHDBError:jee,hdb_errors:Jee}=he(),{HDB_ERROR_MSGS:Qt,HTTP_STATUS_CODES:Xee}=Jee,Ob=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),Zee={STRUCTURE_USER:"structure_user"},Jx=Object.values(Iu.ROLE_TYPES_ENUM),ete="attribute_permissions",tte="attribute_name",{PERMS_CRUD_ENUM:Cu}=Iu,rte=[ete,...Object.values(Cu)],Zx=[Cu.READ,Cu.INSERT,Cu.UPDATE],nte=[tte,...Zx];function ste(e){let t=Ob();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,eB(e,t)}a(ste,"addRoleValidation");function ite(e){let t=Ob();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,eB(e,t)}a(ite,"alterRoleValidation");function ote(e){let t=Ob();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,Xx.validateObject(e,t)}a(ote,"dropRoleValidation");var ate=["operation","role","id","permission","hdb_user","access"];function eB(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)ate.includes(n[o])||s.push(n[o]);s.length>0&&nr(Qt.INVALID_ROLE_JSON_KEYS(s),r);let i=Xx.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{nr(o,r)}),e.permission){let o=cte(e);o&&nr(o,r),Jx.forEach(c=>{e.permission[c]&&!wu.isBoolean(e.permission[c])&&nr(Qt.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(Jx.indexOf(o)<0){if(o===Zee.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=>{rte.includes(f)||nr(Qt.INVALID_PERM_KEY(f),r,o,l)}),Object.values(Cu).forEach(f=>{wu.isDefined(u[f])?wu.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=>{!nte.includes(S)&&S!==Cu.DELETE&&nr(Qt.INVALID_ATTR_PERM_KEY(S),r,o,l)}),!wu.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}Zx.forEach(S=>{wu.isDefined(h[S])?wu.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 lte(r)}a(eB,"customValidate");tB.exports={addRoleValidation:ste,alterRoleValidation:ite,dropRoleValidation:ote};function cte(e){let{operation:t,permission:r}=e;if(t===Iu.OPERATIONS_ENUM.ADD_ROLE||t===Iu.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?Iu.ROLE_TYPES_ENUM.SUPER_USER:Iu.ROLE_TYPES_ENUM.CLUSTER_USER;return Qt.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(cte,"validateNoSUPerms");function lte(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 jee(new Error,n,Xee.BAD_REQUEST)}else return null}a(lte,"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 w_=C((owe,oB)=>{"use strict";var nB=An(),sB=zr(),ute=qc(),wb=rB(),Ib=go(),iwe=require("uuid").v4,dte=require("util"),bE=(k(),P(q)),fte=ie(),Cb=sB.searchByValue,_te=sB.searchByHash,hte=dte.promisify(ute.delete),mte=Ws(),pte=yu(),{hdb_errors:Ete,handleHDBError:Jc}=he(),{HDB_ERROR_MSGS:iB,HTTP_STATUS_CODES:N_}=Ete,{UserEventMsg:Pb}=Ys();oB.exports={addRole:gte,alterRole:Ste,dropRole:Tte,listRoles:Ate};function Nb(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(Nb,"scrubRoleDetails");async function gte(e){let t=wb.addRoleValidation(e);if(t)throw t;e=Nb(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 Cb(r)||[])}catch(i){throw Jc(i)}if(n&&n.length>0)throw Jc(new Error,iB.ROLE_ALREADY_EXISTS(e.role),N_.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 nB.insert(s),Ib.signalUserChange(new Pb(process.pid)),e=Nb(e),e}a(gte,"addRole");async function Ste(e){let t=wb.alterRoleValidation(e);if(t)throw t;e=Nb(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await nB.update(r)}catch(s){throw Jc(s)}if(n&&n?.message==="updated 0 of 1 records")throw Jc(new Error,"Invalid role id",N_.BAD_REQUEST,void 0,void 0,!0);return await Ib.signalUserChange(new Pb(process.pid)),e}a(Ste,"alterRole");async function Tte(e){let t=wb.dropRoleValidation(e);if(t)throw Jc(new Error,t,N_.BAD_REQUEST,void 0,void 0,!0);let r=new pte(bE.SYSTEM_SCHEMA_NAME,bE.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await _te(r));if(n.length===0)throw Jc(new Error,iB.ROLE_NOT_FOUND,N_.NOT_FOUND,void 0,void 0,!0);let s=new mte(bE.SYSTEM_SCHEMA_NAME,bE.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await Cb(s)),o=!1;if(fte.isEmptyOrZeroLength(i)===!1){for(let l=0;l<i.length;l++)if(i[l].active===!0){o=!0;break}}if(o===!0)throw Jc(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,N_.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await hte(c),Ib.signalUserChange(new Pb(process.pid)),`${n[0].role} successfully deleted`}a(Tte,"dropRole");async function Ate(){return Cb({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(Ate,"listRoles")});var Db={};Ue(Db,{start:()=>lB,startOnMainThread:()=>bte});function lB({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r){let n=(0,aB.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(Rte.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 yte(i)}}}async function yte(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,cB.isEqual)(i,e)?void 0:(e.id=r.id,(0,OE.alterRole)(e))}return(0,OE.addRole)(e)}var OE,aB,cB,Rte,bte,uB=Re(()=>{xe();OE=v(w_()),aB=require("yaml"),cB=require("lodash"),Rte=["super_user","cluster_user","structure_user"];a(lB,"start");a(yte,"ensureRole");bte=lB});async function NE(e){let t=(0,_B.pathToFileURL)(e).toString();if(Ote)return I_||(I_=Nte(Ite)),(await(await I_).import(t)).namespace;try{return await import(t)}catch(r){try{(await import("internal/util")).default.decorateErrorStack(r)}catch{}throw r}}async function Nte(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),I_=new Compartment({console,Math,Date,fetch:wte,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,fB.extname)(r)||(r+=".js"),r)},importHook:a(async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){Object.assign(s,{Resource:Yr,tables:Qn,databases:We})}};let n=await(0,dB.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)},"importHook")}),I_}function wte(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 Ite(){return{Resource:Yr,tables:Qn}}var dB,fB,_B,Ote,I_,Lb=Re(()=>{oa();xe();dB=require("fs/promises"),fB=require("path"),_B=require("url"),Ote=!1;a(NE,"secureImport");a(Nte,"getCompartment");a(wte,"secureOnlyFetch");a(Ite,"getGlobalVars")});var vb={};Ue(vb,{handleFile:()=>Cte});async function Cte(e,t,r,n){let s=new Map,i=await NE(r);c(i.default)&&n.set((0,Mb.dirname)(t),i.default),o(i,(0,Mb.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 Mb,hB=Re(()=>{Lb();Mb=require("path");a(Cte,"handleFile")});var xb={};Ue(xb,{start:()=>Pte});function Pte({resources:e}){e.set("login",Ub),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var Ub,mB=Re(()=>{oa();a(Pte,"start");Ub=class extends Yr{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 v_={};Ue(v_,{addAnalyticsListener:()=>M_,calculateCPUUtilization:()=>vB,diffResourceUsage:()=>UB,recordAction:()=>Mt,recordActionBinary:()=>jn,setAnalyticsEnabled:()=>Dte});function Dte(e){CB=e}function Lte(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 Mte(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},IE.set(e,o)}function Mt(e,t,r,n,s){if(!CB)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=IE.get(i);o?Lte(e,o):Mte(i,e,t,r,n,s),wE||vte()}function jn(e,t,r,n,s){Mt(!!e,t,r,n,s)}function M_(e){LB.push(e)}function vte(){wE=performance.now(),setTimeout(async()=>{let e=performance.now()-wE;wE=0;let t=[],r={time:Date.now(),period:e,threadId:Xc.threadId,metrics:t};for(let[s,i]of IE){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 MB){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 xB()}let n=process.memoryUsage();t.push({metric:"memory",threadId:Xc.threadId,byThread:!0,...n});for(let s of LB)s(t);IE=new Map,Xc.parentPort?Xc.parentPort.postMessage({type:DB,report:r}):kB({report:r})},PB).unref()}function CE(e,t,r){let n={id:(0,D_.getNextMonotonicTime)(),metric:t,...r};e.primaryStore.put(n.id,n,{append:!0}).then(s=>{s||e.primaryStore.put(n.id,n)})}function vB(e,t){let r=e.userCPUTime+e.systemCPUTime;return Math.round(r/t*100)/100}function UB(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 Ute(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};CE(e,"table-size",l),Zc.trace?.(`table ${o} size metric: ${JSON.stringify(l)}`),n+=c}return n}function pB(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s?.getAuditSize();if(!i)return;let o=IB.default.statSync(s.primaryStore.env.path).size,c=Ute(e,r,n),l=o-c,u={database:r,size:o,used:c,free:l,audit:i};CE(e,"database-size",u),Zc.trace?.(`database ${r} size metric: ${JSON.stringify(u)}`)}catch(s){Zc.warn?.("Error getting DB size metrics",s)}}function EB(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};CE(e,"storage-volume",o),Zc.trace?.(`db ${r} storage volume metrics: ${JSON.stringify(o)}`)}catch(s){Zc.warn?.("Error getting DB volume metrics",s)}}async function xte(e,t=6e4){let r=Hb(),n=BB(),s=new Promise(E=>{let T=performance.now();setImmediate(()=>{let N=performance.now();N-T>5e3&&Zc.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&&Zc.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:M}=T;for(let H of N||[]){let{path:X,method:W,type:$,metric:se,count:z,total:fe,distribution:ue,threads:Z,...Ae}=H;z||(z=1);let me=se+(X?"-"+X:"");W!==void 0&&(me+="-"+W),$!==void 0&&(me+="-"+$);let ye=c.get(me);if(ye){if(ye.threads){let dt=ye.threads[M];if(dt)ye=dt;else{ye.threads[M]={...Ae};continue}}ye.count||(ye.count=1);let Ht=ye.count;for(let dt in Ae){let Ln=Ae[dt];typeof Ln=="number"&&(ye[dt]=(ye[dt]*Ht+Ln*z)/(Ht+z))}ye.count+=z,fe>=0&&(ye.total+=fe,ye.ratio=ye.total/ye.count)}else ye={period:t,...H},delete ye.distribution,c.set(me,ye),ye.byThread&&(ye.threads=[],ye.threads[M]={...Ae},u.push(ye));if(ue){ue=ue.map(dt=>typeof dt=="number"?{value:dt,count:1}:dt);let Ht=l.get(me);Ht?Ht.push(...ue):l.set(me,ue)}}await xB()}for(let E of u){let{path:T,method:N,type:M,metric:H,count:X,total:W,distribution:$,threads:se,...z}=E;se=se.filter(fe=>fe);for(let fe in z){if(typeof E[fe]!="number")continue;let ue=0;for(let Z of se){let Ae=Z[fe];typeof Ae=="number"&&(ue+=Ae)}E[fe]=ue}E.count=se.length,delete E.threads,delete E.byThread}for(let[E,T]of l){let N=c.get(E);T.sort((dt,Ln)=>dt.value>Ln.value?1:-1);let M=N.count-1,H=[],X=0,W=0,$;for(let dt of MB){let Ln=M*dt;for(;X<Ln;)$=T[W++],X+=$.count,W===1&&X--;let Vr=T[W>1?W-2:0];$||($=T[0]),H.push($.value-($.value-Vr.value)*(X-Ln)/$.count)}let[se,z,fe,ue,Z,Ae,me,ye,Ht]=H;Object.assign(N,{p1:se,p10:z,p25:fe,median:ue,p75:Z,p90:Ae,p95:me,p99:ye,p999:Ht})}let d;for(let[E,T]of c)T.id=(0,D_.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,D_.getNextMonotonicTime)(),T={id:E,metric:"main-thread-utilization",idle:h-gB,active:m-SB,taskQueueLatency:await s,time:_,...process.memoryUsage()};n.primaryStore.put(E,T,{append:!0}).then(N=>{N||n.primaryStore.put(E,T)})}gB=h,SB=m;let S=process.resourceUsage(),g=UB(C_,S);g.time=_,g.period=C_.time?_-C_.time:t,g.cpuUtilization=vB(C_,g.period),CE(n,"resource-usage",g),C_=g;let R=Xe();pB(n,R),pB(n,{system:R.system}),EB(n,R),EB(n,{system:R.system})}async function TB(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function Hb(){return AB||(AB=_t({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function BB(){return RB||(RB=_t({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function kte(){HB=!0;let e=(0,L_.get)(x.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await xte(PB,e),await TB(Hb(),Bte),await TB(BB(),Hte)},Math.min(e/2,2147483647)).unref()}function kB(e,t){let r=e.report;r.threadId=t?.threadId||Xc.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(yB+=n.mean*n.count);r.totalBytesProcessed=yB,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(bB.get(t))}),bB.set(t,t.performance.eventLoopUtilization())),r.id=(0,D_.getNextMonotonicTime)(),Hb().primaryStore.put(r.id,r),HB||kte(),Fte&&(FB=qte(r))}async function qte(e){if(await FB,!Ea){let r=(0,P_.dirname)((0,NB.getLogFilePath)());try{Ea=await(0,Bb.open)((0,P_.join)(r,"analytics.log"),"r+")}catch{Ea=await(0,Bb.open)((0,P_.join)(r,"analytics.log"),"w+")}}let t=(await Ea.stat()).size;if(t>Gte){let r=Buffer.alloc(t);await Ea.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await Ea.write(r,{position:0}),await Ea.truncate(r.length),t=r.length}await Ea.write(JSON.stringify(e)+`
|
|
20
20
|
`,t)}var Xc,OB,NB,wB,P_,Bb,D_,L_,IB,Zc,IE,CB,wE,PB,DB,LB,MB,gB,SB,C_,xB,Bte,Hte,AB,RB,HB,yB,bB,Fte,FB,Ea,Gte,Mi=Re(()=>{Xc=require("worker_threads"),OB=v(ot());xe();NB=v(ee()),wB=v(Gs()),P_=require("path"),Bb=require("fs/promises"),D_=v(fn()),L_=v(le());k();Mr();IB=v(require("node:fs")),Zc=(0,wB.loggerWithTag)("analytics");(0,L_.initSync)();IE=new Map,CB=(0,L_.get)(x.ANALYTICS_AGGREGATEPERIOD)>-1;a(Dte,"setAnalyticsEnabled");a(Lte,"recordExistingAction");a(Mte,"recordNewAction");a(Mt,"recordAction");Ye.recordAnalytics=Mt;a(jn,"recordActionBinary");wE=0,PB=1e3,DB="analytics-report",LB=[];a(M_,"addAnalyticsListener");MB=[.01,.1,.25,.5,.75,.9,.95,.99,.999,1];a(vte,"sendAnalytics");a(CE,"storeMetric");a(vB,"calculateCPUUtilization");a(UB,"diffResourceUsage");a(Ute,"storeTableSizeMetrics");a(pB,"storeDBSizeMetrics");a(EB,"storeVolumeMetrics");a(xte,"aggregation");gB=0,SB=0,C_={},xB=a(()=>new Promise(setImmediate),"rest");a(TB,"cleanup");Bte=36e5,Hte=31536e6;a(Hb,"getRawAnalyticsTable");a(BB,"getAnalyticsTable");(0,OB.setChildListenerByType)(DB,kB);a(kte,"startScheduledTasks");yB=0,bB=new Map,Fte=!1;a(kB,"recordAnalytics");Gte=1e6;a(qte,"logAnalytics")});var GB={};Ue(GB,{Headers:()=>Ao,appendHeader:()=>PE,mergeHeaders:()=>kb});function PE(e,t,r,n){if(e.append)e.append(t,r,n);else if(e.set){let s=e.get(t);if(s)if(n)r=(typeof s=="string"?s:s.join(", "))+", "+r;else if(typeof s=="string")r=[s,r];else{s.push(r);return}return e.set(t,r)}else e[t]=(e[t]?e[t]+", ":"")+r}function kb(e,t){(typeof e.set!="function"||typeof e.has!="function")&&(e=new Ao(e));for(let[r,n]of t)e.has(r)?r.toLowerCase()==="set-cookie"&&e.append?.(r,n,!0):e.set(r,n);return e}var Ao,U_=Re(()=>{Ao=class extends Map{static{a(this,"Headers")}constructor(t){if(t)if(t[Symbol.iterator])super(t);else{super();for(let r in t)this.set(r,t[r])}else super()}set(t,r){return typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r),super.set(t.toLowerCase(),[t,r])}get(t){return typeof t!="string"&&(t=""+t),super.get(t.toLowerCase())?.[1]}has(t){return typeof t!="string"&&(t=""+t),super.has(t.toLowerCase())}setIfNone(t,r){typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r);let n=t.toLowerCase();if(!super.has(n))return super.set(n,[t,r])}append(t,r,n){typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r);let s=t.toLowerCase(),i=super.get(s);if(i){let o=i[1];if(n)r=(typeof o=="string"?o:o.join(", "))+", "+r;else if(typeof o=="string")r=[o,r];else{o.push(r);return}}return super.set(s,[t,r])}[Symbol.iterator](){return super.values()[Symbol.iterator]()}};a(PE,"appendHeader");a(kb,"mergeHeaders")});function YB(e){let t={openapi:$te,info:{title:"HarperDB HTTP REST interface",version:KB.packageJson.version},paths:{},components:{schemas:{},securitySchemes:{basicAuth:{type:"http",scheme:"basic"},bearerAuth:{type:"http",scheme:"bearer",bearerFormat:"JWT"}}}},r=[{basicAuth:[],bearerAuth:[]}];for(let[,n]of e){if(!n.path||n.Resource.isError)continue;let{path:s}=n,i=s.split("/").slice(-1),{attributes:o,primaryKey:c,prototype:l}=n.Resource;if(c=c??"id",!c)continue;let u={},f=[];if(o)for(let{type:T,name:N,elements:M,relationship:H,definition:X}of o){if(H)T==="array"?u[N]={type:"array",items:{$ref:ga+M.type}}:u[N]={$ref:ga+T};else{let W=X??M?.definition;if(W){if(!t.components.schemas[W.type]){let $={};W.properties.forEach(se=>{$[se.name]=new $b(Fb[se.type],se.type)}),t.components.schemas[W.type]=new VB($)}T==="array"?u[N]={type:"array",items:{$ref:ga+W.type}}:u[N]={$ref:ga+W.type}}else T==="array"?M.type==="Any"||M.type=="ID"?u[N]={type:"array",items:{format:M.type}}:u[N]={type:"array",items:new $b(Fb[M.type],M.type)}:T==="Any"||T=="ID"?u[N]={format:T}:u[N]=new $b(Fb[T],T)}f.push(new Vb(N,"query",u[N]))}let d=Object.keys(u),_=new Vb(c,"path",{format:"ID"});_.required=!0,_.description="primary key of record";let h=new Vb("property","path",{enum:d});h.required=!0,t.components.schemas[i]=new VB(u);let m=l.post!==Resource.prototype.post||l.update,S=typeof l.put=="function",g=typeof l.get=="function",R=typeof l.delete=="function",E="/"+s+"/";m&&(t.paths[E]={},t.paths[E].post=new Vte(i,r,"create a new record auto-assigning a primary key")),g&&(t.paths[E]||(t.paths[E]={}),t.paths[E].get=new Gb(f,r,{200:new qb({$ref:ga+i})},"search for records by the specified property name and value pairs")),R&&(t.paths[E]||(t.paths[E]={}),t.paths[E].delete=new $B(f,r,"delete all the records that match the provided query",{204:new qB})),E="/"+s+"/{"+c+"}",g&&(t.paths[E]={},t.paths[E].get=new Gb([_],r,{200:new qb({$ref:ga+i})},"retrieve a record by its primary key")),S&&(t.paths[E]||(t.paths[E]={}),t.paths[E].put=new Kte([_],r,i,"create or update the record with the URL path that maps to the record's primary key")),R&&(t.paths[E]||(t.paths[E]={}),t.paths[E].delete=new $B([_],r,"delete a record with the given primary key",{204:new qB})),g&&h.schema.enum.length>0&&(E="/"+s+"/{"+c+"}.{property}",t.paths[E]={},t.paths[E].get=new Gb([_,h],r,{200:new qb({enum:d})},"used to retrieve the specified property of the specified record"))}return t}function Vte(e,t,r){this.description=r,this.requestBody={content:{"application/json":{schema:{$ref:ga+e}}}},this.security=t,this.responses={200:{description:Kb,headers:{Location:{description:"primary key of new record",schema:{type:"string",format:"ID"}}},content:{"application/json":{schema:{type:"string",format:"ID"}}}}}}function Gb(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.responses=r}function qb(e){this.description=Kb,this.content={"application/json":{schema:e}}}function qB(){this.description="successfully processed request, no content returned to client"}function Kte(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.requestBody={content:{"application/json":{schema:{$ref:ga+r}}}},this.responses={200:{description:Kb}}}function $B(e,t,r,n){this.description=r,this.parameters=e,this.security=t,this.responses=n}function VB(e){this.type="object",this.properties=e}function $b(e,t){this.type=e,this.format=t}function Vb(e,t,r){this.name=e,this.in=t,this.schema=r}var KB,$te,Fb,ga,Kb,WB=Re(()=>{KB=v(Et()),$te="3.0.3",Fb={Int:"integer",Float:"number",Long:"integer",String:"string",Boolean:"boolean",Date:"string",Bytes:"string",BigInt:"integer",array:"array"},ga="#/components/schemas/",Kb="successful operation";a(YB,"generateJsonApi");a(Vte,"Post");a(Gb,"Get");a(qb,"Response200");a(qB,"Response204");a(Kte,"Put");a($B,"Delete");a(VB,"ResourceSchema");a($b,"Type");a(Vb,"Parameter")});var QB={};Ue(QB,{Request:()=>x_,createReuseportFd:()=>DE});var zB,x_,Yb,Wb,DE,LE=Re(()=>{zB=require("os"),x_=class{static{a(this,"Request")}#e;constructor(t,r){this.method=t.method;let n=t.url;this._nodeRequest=t,this._nodeResponse=r,this.url=n,this.headers=new Wb(t.headers)}get absoluteURL(){return this.protocol+"://"+this.host+this.url}get pathname(){let t=this.url.indexOf("?");return t>-1?this.url.slice(0,t):this.url}set pathname(t){let r=this.url.indexOf("?");r>-1?this.url=t+this.url.slice(r):this.url=t}get protocol(){return this._nodeRequest.socket.encrypted?"https":"http"}get ip(){return this._nodeRequest.socket.remoteAddress}get authorized(){return this._nodeRequest.socket.authorized}get peerCertificate(){return this._nodeRequest.socket.getPeerCertificate()}get mtlsConfig(){return this._nodeRequest.socket.server.mtlsConfig}get body(){return this.#e||(this.#e=new Yb(this._nodeRequest))}get host(){return this._nodeRequest.authority||this._nodeRequest.headers.host}get isAborted(){return!1}sendEarlyHints(t,r={}){r.link=t,this._nodeResponse.writeEarlyHints(r)}},Yb=class{static{a(this,"RequestBody")}#e;constructor(t){this.#e=t}on(t,r){return this.#e.on(t,r),this}pipe(t,r){return this.#e.pipe(t,r)}},Wb=class{constructor(t){this.asObject=t}static{a(this,"Headers")}set(t,r){this.asObject[t.toLowerCase()]=r}get(t){return this.asObject[t.toLowerCase()]}has(t){return this.asObject.hasOwnProperty(t.toLowerCase())}[Symbol.iterator](){return Object.entries(this.asObject)[Symbol.iterator]()}keys(){return Object.keys(this.asObject)}values(){return Object.values(this.asObject)}delete(t){delete this.asObject[t.toLowerCase()]}forEach(t){for(let[r,n]of this)t(n,r,this)}};(0,zB.platform)()!="win32"&&(DE=require("node-unix-socket").createReuseportFd)});var vE={};Ue(vE,{parseHeaderValue:()=>Qb,start:()=>zte});async function Wte(e,t){let r=e.headers.asObject,n=r.accept==="text/event-stream",s=n?"CONNECT":e.method;e.search&&cp(e);let i=new Ao;try{e.responseHeaders=i;let o=e.url.slice(1),c,l;if(o!==jB){let g=ME.getMatch(o,n?"sse":"rest");if(!g)return t(e);e.handlerPath=g.path,c=new Tc(g.relativeURL),c.async=!0,l=g.Resource}if(l?.isCaching){let g=r["cache-control"];if(g){let R=Qb(g);for(let E of R)switch(E.name){case"max-age":e.expiresAt=E.value*1e3+Date.now();break;case"only-if-cached":e.onlyIfCached=!0;break;case"no-cache":e.noCache=!0;break;case"no-store":e.noCacheStore=!0;break;case"stale-if-error":e.staleIfError=!0;break;case"must-revalidate":e.mustRevalidate=!0;break}}}let u=r["x-replicate-to"];if(u){let g=Qb(u).map(R=>(R.next?.name==="confirm"&&R.next.value>=0&&(e.replicatedConfirmation=+R.next.value),R.name));e.replicateTo=g.length===1&&+g[0]>=0?+g[0]:g[0]==="*"?void 0:g}r["x-replicate-from"]==="none"&&(e.replicateFrom=!1);let d=await Pt(e,()=>{if(r["content-length"]||r["transfer-encoding"])try{e.data=lo(r["content-type"],!0)(e.body,e.headers)}catch(g){throw new Pu.ClientError(g,400)}if(e.authorize=!0,o===jB&&s==="GET"){if(e?.user?.role?.permission?.super_user)return YB(ME);throw new Pu.ServerError("Forbidden",403)}switch(s){case"GET":case"HEAD":return l.get(c,e);case"POST":return l.post(c,e.data,e);case"PUT":return l.put(c,e.data,e);case"DELETE":return l.delete(c,e);case"PATCH":return l.patch(c,e.data,e);case"OPTIONS":i.setIfNone("Allow","GET, HEAD, POST, PUT, DELETE, PATCH, OPTIONS, TRACE, QUERY, COPY, MOVE");return;case"CONNECT":return l.connect(c,null,e);case"TRACE":return"HarperDB is the terminating server";case"QUERY":return l.query(c,e.data,e);case"COPY":return l.copy(c,r.destination,e);case"MOVE":return l.move(c,r.destination,e);case"BREW":throw new Pu.ClientError("HarperDB is short and stout and can't brew coffee",418);default:throw new Pu.ServerError(`Method ${s} is not recognized`,501)}}),_=200,h;if(d==null)_=s==="GET"||s==="HEAD"?404:204,zb.lastModified&&e.lastModified&&i.setIfNone("Last-Modified",new Date(e.lastModified).toUTCString());else if(d.status>0&&d.headers){let g=kb(d.headers,i);return d.headers!==g&&(d.headers=g),d.data!==void 0&&(d.body=Ff(d.data,e,d)),d}else if(h=e.lastModified){Yte[0]=h;let g=String.fromCharCode(34,(Br[0]&63)+62,(Br[0]>>6)+(Br[1]<<2&63)+62,(Br[1]>>4)+(Br[2]<<4&63)+62,(Br[2]>>2)+62,(Br[3]&63)+62,(Br[3]>>6)+(Br[4]<<2&63)+62,(Br[4]>>4)+(Br[5]<<4&63)+62,(Br[5]>>2)+62,(Br[6]&63)+62,(Br[6]>>6)+(Br[7]<<2&63)+62,34),R=r["if-none-match"];R&&g==R?(d?.onDone&&d.onDone(),_=304,d=void 0):i.setIfNone("ETag",g),zb.lastModified&&i.setIfNone("Last-Modified",new Date(h).toUTCString())}e.createdResource&&(_=201),e.newLocation&&i.setIfNone("Location",e.newLocation);let m={status:_,headers:i,body:void 0},S=d?.wasLoadedFromSource?.();return S!==void 0&&(m.wasCacheMiss=S,!S&&h&&i.setIfNone("Age",Math.round((Date.now()-(e.lastRefreshed||h))/1e3))),d!==void 0&&(m.body=Ff(d,e,m),s==="HEAD"&&(m.body=void 0)),m}catch(o){o.statusCode?o.statusCode===500?vi.warn(o):vi.info(o):vi.error(o),o.statusCode===405&&(o.method&&(o.message+=` to handle HTTP method ${o.method.toUpperCase()||""}`),o.allow&&(o.allow.push("trace","head","options"),i.setIfNone("Allow",o.allow.map(l=>l.toUpperCase()).join(", "))));let c={status:o.statusCode||500,headers:i,body:void 0};return c.body=Ff(o.contentType?o:o.toString(),e,c),c}}function zte(e){zb=e,e.includeExpensiveRecordCountEstimates&&(x_.prototype.includeExpensiveRecordCountEstimates=!0),!JB&&(JB=!0,ME=e.resources,e.server.http(async(t,r)=>{if(!t.isWebSocket)return Wte(t,r)},e),e.webSocket!==!1&&e.server.ws(async(t,r,n)=>{B_++;let s=new Hn;XB||(XB=!0,M_(l=>{B_>0&&l.push({metric:"ws-connections",connections:B_,byThread:!0})}));let i;t.on("error",l=>{i=!0,vi.warn(l)});let o;t.on("message",a(function(u){o||(o=lo(r.requestedContentType??r.headers.asObject["content-type"],!1));let f=o(u);Mt(u.length,"bytes-received",r.handlerPath,"message","ws"),s.push(f)},"message"));let c;t.on("close",()=>{B_--,jn(!i,"connection","ws","disconnect"),s.emit("close"),c&&c.return()});try{await n;let l=r.url.slice(1),u=ME.getMatch(l,"ws");if(jn(!!u,"connection","ws","connect"),u){r.handlerPath=u.path,Mt(m=>({count:m.count,total:B_}),"connections",r.handlerPath,"connect","ws"),r.authorize=!0;let f=new Tc(u.relativeURL),d=u.Resource;c=(await Pt(r,()=>d.connect(f,s,r)))[Symbol.asyncIterator]();let h;for(;!(h=await c.next()).done;){let m=await ua(h.value,r);t.send(m),Mt(m.length,"bytes-sent",r.handlerPath,"message","ws"),t._socket.writableNeedDrain&&await new Promise(S=>t._socket.once("drain",S))}}else return t.close(1011,`No resource was found to handle ${r.pathname}`)}catch(l){l.statusCode?l.statusCode===500?vi.warn(l):vi.info(l):vi.error(l),t.close(Qte[l.statusCode]||1011,l.toString())}t.close()},e))}function Qb(e){return e.trim().split(",").map(t=>{let r,n=t.trim().split(";"),s;for(;s=n.pop();)if(s.includes("=")){let[i,o]=s.trim().split("=");i=i.trim(),o&&(o=o.trim()),r={name:i.toLowerCase(),value:o,next:r}}else r={name:s.toLowerCase(),next:r};return r})}var vi,Pu,Br,Yte,zb,jB,JB,ME,XB,B_,Qte,ZB=Re(()=>{oo();Mi();vi=v(ee()),Pu=v(he());Pf();Xl();Sc();U_();WB();Pf();LE();Br=new Uint8Array(8),Yte=new Float64Array(Br.buffer,0,1),zb={},jB="openapi";a(Wte,"http");B_=0;a(zte,"start");Qte={401:3e3,403:3003};a(Qb,"parseHeaderValue")});var jb=C((Bwe,tH)=>{var{recordAction:UE,recordActionBinary:eH}=(Mi(),P(v_)),jte=require("fastify-plugin"),Jte=200;tH.exports=jte(function(e,t,r){e.addHook("onResponse",async(n,s)=>{let i=s.elapsedTime}),e.addHook("onSend",async(n,s,i)=>{let o=s.elapsedTime,c=performance.now(),l=s.request.routeOptions,u,f,d;l.config?.isOperation?(u=n.body?.operation,f="operation"):(u=l.url,f="fastify-route",d=l.method),UE(o,"duration",u,d,f),eH(s.raw.statusCode<400,"success",u,d,f),eH(1,"response_"+s.raw.statusCode,u,d,f);let _=Jte;i?.pipe?(i.on("data",g=>{_+=g.length}),i.on("end",()=>{UE(performance.now()-c,"transfer",u,d,f),UE(_,"bytes-sent",u,d,f)})):(_+=i?.length||0,UE(_,"bytes-sent",u,d,f));let h=o.toFixed(3),m=s.getHeader("Server-Timing"),S=`db;dur=${h}`;s.header("Server-Timing",m?`${m}, ${S}`:S)}),r()},{name:"hdb-request-time"})});var nH=C((Hwe,rH)=>{var Xte=it(),Zte={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};rH.exports=function(e){return Xte.validateObject(e,Zte)}});var xE=C((kwe,sH)=>{"use strict";var ere=(k(),P(q)).OPERATIONS_ENUM,Jb=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=ere.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};sH.exports=Jb});var F_={};Ue(F_,{createTokens:()=>rre,getJWTRSAKeys:()=>GE,refreshOperationToken:()=>nre,validateOperationToken:()=>eO,validateRefreshToken:()=>qE});async function GE(){if(BE)return BE;try{let e=H_.default.join(k_.default.getHdbBasePath(),gA),t=await HE.default.readFile(H_.default.join(e,uf.JWT_PASSPHRASE_NAME),"utf8"),r=await HE.default.readFile(H_.default.join(e,uf.JWT_PRIVATE_KEY_NAME),"utf8");return BE={publicKey:await HE.default.readFile(H_.default.join(e,uf.JWT_PUBLIC_KEY_NAME),"utf8"),privateKey:r,passphrase:t},BE}catch(e){throw FE.default.error(e),new Qs.ClientError(Lu.NO_ENCRYPTION_KEYS,Du.INTERNAL_SERVER_ERROR)}}async function rre(e){let t=(0,Xb.validateBySchema)(e,Ui.default.object({username:Ui.default.string().optional(),password:Ui.default.string().optional(),role:Ui.default.string().optional(),expires_in:Ui.default.alternatives(Ui.default.string(),Ui.default.number()).optional()}));if(t)throw new Qs.ClientError(t.message);let r;try{let d=e.bypass_auth!==!0;!e.username&&!e.password&&(e.username=e.hdb_user?.username,d=!1),r=await(0,Zb.findAndValidateUser)(e.username,e.password,d)}catch(d){throw FE.default.error(d),new Qs.ClientError(Lu.INVALID_CREDENTIALS,Du.UNAUTHORIZED)}if(!r)throw new Qs.ClientError(Lu.INVALID_CREDENTIALS,Du.UNAUTHORIZED);let n=!1,s=!1;r.role?.permission&&(n=r.role.permission.super_user===!0,s=r.role.permission.cluster_user===!0);let i={username:e.username,super_user:n,cluster_user:s};e.role&&(i.role=e.role);let o=await GE(),c=await Mu.default.sign(i,{key:o.privateKey,passphrase:o.passphrase},{expiresIn:e.expires_in??lH,algorithm:kE,subject:"operation"}),l=await Mu.default.sign(i,{key:o.privateKey,passphrase:o.passphrase},{expiresIn:tre,algorithm:kE,subject:"refresh"}),u=Sy(l,"sha256");if((await(0,iH.update)(new oH.default(lf,Wl.USER_TABLE_NAME,[{username:e.username,refresh_token:u}]))).skipped_hashes.length>0)throw new Qs.ClientError(Lu.REFRESH_TOKEN_SAVE_FAILED,Du.INTERNAL_SERVER_ERROR);return aH.default.signalUserChange(new cH.UserEventMsg(process.pid)),{operation_token:c,refresh_token:l}}async function nre(e){let t=(0,Xb.validateBySchema)(e,Ui.default.object({refresh_token:Ui.default.string().required()}).required());if(t)throw new Qs.ClientError(t.message);let{refresh_token:r}=e;await qE(r);let n=await GE(),s=await Mu.default.decode(r);return{operation_token:await Mu.default.sign({username:s.username,super_user:s.super_user,cluster_user:s.cluster_user},{key:n.privateKey,passphrase:n.passphrase},{expiresIn:lH,algorithm:kE,subject:"operation"})}}async function eO(e){return uH(e,"operation")}async function qE(e){return uH(e,"refresh")}async function uH(e,t){try{let r=await GE(),n=await Mu.default.verify(e,r.publicKey,{algorithms:kE,subject:t});if(n.role)throw new Error("Invalid token");let s=await(0,Zb.findAndValidateUser)(n.username,void 0,!1);if(t==="refresh"&&!Ty(s.refresh_token,e))throw new Error("Invalid token");return s}catch(r){throw FE.default.warn(r),r?.name==="TokenExpiredError"?new Qs.ClientError(Lu.TOKEN_EXPIRED,Du.FORBIDDEN):new Qs.ClientError(Lu.INVALID_TOKEN,Du.UNAUTHORIZED)}}var Mu,HE,H_,Ui,Xb,Qs,FE,Zb,iH,oH,aH,cH,k_,Du,Lu,lH,tre,kE,BE,vu=Re(()=>{Mu=v(require("jsonwebtoken")),HE=v(require("fs-extra")),H_=v(require("node:path")),Ui=v(require("joi")),Xb=v(it());k();Qs=v(he()),FE=v(ee());jp();Zb=v(Kn()),iH=v(An()),oH=v(xE()),aH=v(go()),cH=v(Ys()),k_=v(le()),{HTTP_STATUS_CODES:Du,AUTHENTICATION_ERROR_MSGS:Lu}=Qs.hdb_errors;k_.default.initSync();lH=k_.default.get(x.AUTHENTICATION_OPERATIONTOKENTIMEOUT)||"1d",tre=k_.default.get(x.AUTHENTICATION_REFRESHTOKENTIMEOUT)||"30d",kE="RS256";a(GE,"getJWTRSAKeys");a(rre,"createTokens");a(nre,"refreshOperationToken");a(eO,"validateOperationToken");a(qE,"validateRefreshToken");a(uH,"validateToken")});var tO=C((Vwe,_H)=>{"use strict";var sre=nH(),Uu=require("passport"),ire=require("passport-local").Strategy,ore=require("passport-http").BasicStrategy,are=require("util"),cre=Kn(),fH=are.callbackify(cre.findAndValidateUser),$we=Un(),lre=(k(),P(q)),dH=(vu(),P(F_));Uu.use(new ire(function(e,t,r){fH(e,t,r)}));Uu.use(new ore(function(e,t,r){fH(e,t,r)}));Uu.serializeUser(function(e,t){t(null,e)});Uu.deserializeUser(function(e,t){t(null,e)});function ure(e,t,r){if(e.raw?.user!==void 0)return r(null,e.raw.user);let n,s;if(e.headers?.authorization){let o=e.headers.authorization.split(" ");n=o[0],s=o[1]}function i(o,c){return o?r(o):c?r(null,c):r("Must login")}switch(a(i,"handleResponse"),n){case"Basic":Uu.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===lre.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?dH.validateRefreshToken(s).then(o=>{e.body.refresh_token=s,r(null,o)}).catch(o=>{r(o)}):dH.validateOperationToken(s).then(o=>{r(null,o)}).catch(o=>{r(o)});break;default:Uu.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(ure,"authorize");function dre(e,t){let r=sre(e);if(r){t(r);return}let n={authorized:!0,messages:[]},s=e.user.role;if(!s?.permission)return t("Invalid role");let i=JSON.parse(s.permission);if(i.super_user)return t(null,n);if(!i[e.schema])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.schema} schema`),t(null,n);if(!i[e.schema].tables[e.table])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.table} table`),t(null,n);if(!i[e.schema].tables[e.table][e.operation])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.operation} on ${e.table} table`),t(null,n);if(i[e.schema].tables[e.table].attribute_permissions&&!e.attributes)return n.authorized=!1,n.messages.push(`${e.schema}.${e.table} has attribute permissions. Missing attributes to validate`),t(null,n);if(i[e.schema].tables[e.table].attribute_permissions&&e.attributes){let o=i[e.schema].tables[e.table].attribute_permissions;for(let c in o)e.attributes.indexOf(o[c].attribute_name)>-1&&!o[c][e.operation]&&(n.authorized=!1,n.messages.push(`Not authorized to ${e.operation} ${o[c].attribute_name} `))}return t(null,n)}a(dre,"checkPermissions");_H.exports={authorize:ure,checkPermissions:dre}});var $E=C((Ywe,hH)=>{"use strict";var fre=Vn();hH.exports={writeTransaction:_re};function _re(e,t,r){return fre.writeTransaction(e,t,r)}a(_re,"writeTransaction")});var gH=C((Qwe,EH)=>{"use strict";var hre=zr(),mre=ps(),mH=ee(),pre=An(),zwe=$E(),Ere=require("clone"),nO=require("alasql"),gre=qp(),pH=require("util"),Sre=pH.promisify(mre.getTableSchema),Tre=pH.promisify(hre.search),Are=(k(),P(q)),rO=ie();gre(nO);EH.exports={update:yre};var Rre="There was a problem performing this update. Please check the logs and try again.";async function yre({statement:e,hdb_user:t}){let r=await Sre(e.table.databaseid,e.table.tableid),n=bre(e.columns);rO.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=Ere(s),c=rO.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,u=nO.parse(l).statements[0],f=await Tre(u),d=Ore(n,f);return Nre(o,d,t)}a(yre,"update");function bre(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=nO.compile(`SELECT ${r.expression.toString()} AS [${Are.FUNC_VAL}] FROM ?`)}),t}catch(t){throw mH.error(t),new Error(Rre)}}a(bre,"createUpdateRecord");function Ore(e,t){return rO.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(Ore,"buildUpdateRecords");async function Nre(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await pre.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){mH.error(`Error delete new_attributes from update response: ${i}`)}return s}a(Nre,"updateRecords")});var TH=C((Zwe,SH)=>{var wre=require("alasql"),Ire=zr(),Cre=ee(),Pre=Vn(),iO=require("util"),sO=ie(),Dre=(k(),P(q)),Lre=ps(),Jwe=$E(),Xwe=An(),Mre="record",vre="successfully deleted",Ure=iO.callbackify(kre),xre=iO.promisify(Ire.search),Bre=iO.promisify(Lre.getTableSchema);SH.exports={convertDelete:Ure};function Hre(e){return`${e.deleted_hashes.length} ${Mre}${e.deleted_hashes.length===1?"":"s"} ${vre}`}a(Hre,"generateReturnMessage");async function kre({statement:e,hdb_user:t}){let r=await Bre(e.table.databaseid,e.table.tableid);sO.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=sO.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=wre.parse(o).statements[0],l={operation:Dre.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await xre(c);let u=await Pre.deleteRecords(l);return sO.isEmptyOrZeroLength(u.message)&&(u.message=Hre(u)),delete u.txn_time,u}catch(u){throw Cre.error(u),u.hdb_code?u.message:u}}a(kre,"convertDelete")});var OH=C((tIe,bH)=>{"use strict";var Fre=po(),{hdb_errors:AH}=he(),{getDatabases:RH}=(xe(),P(ct));bH.exports={checkSchemaExists:yH,checkSchemaTableExists:Gre,schema_describe:Fre};async function yH(e){if(!RH()[e])return AH.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(yH,"checkSchemaExists");async function Gre(e,t){let r=await yH(e);if(r)return r;if(!RH()[e][t])return AH.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(Gre,"checkSchemaTableExists")});var uO=C((oIe,BH)=>{"use strict";var{decode:qre}=require("msgpackr"),{isMainThread:nIe,parentPort:sIe,threadId:iIe}=require("worker_threads"),YE=Er(),xu=Lt(),cO=(k(),P(q)),Jr=ee(),aO=le(),$re=(k(),P(q)),{onMessageByType:Vre}=ot(),CH=mo(),{recordAction:NH,recordActionBinary:Kre}=(Mi(),P(v_)),{publishToStream:Yre}=YE,{ConsumerEvents:wH}=require("nats"),Wre=zr(),{promisify:zre}=require("util"),{decodeBlobsWithWrites:Qre}=(gn(),P(uu)),PH=zre(setTimeout),WE=1e4,zE,KE,jre,Jre,DH,G_=new Map,Bu=new Map;BH.exports={initialize:LH,ingestConsumer:lO,setSubscription:Xre,setIgnoreOrigin:tne,getDatabaseSubscriptions:ene,updateConsumer:MH};async function LH(){Vre(cO.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,async n=>{await MH(n)}),DH=!0,Jr.notify("Initializing clustering ingest service.");let{connection:e,jsm:t,js:r}=await YE.getNATSReferences();zE=e,KE=e.info.server_name,jre=t,Jre=r}a(LH,"initialize");async function MH(e){if(e.status==="start"){let{js:t,jsm:r}=await vH(e.node_domain_name);lO(e.stream_name,t,r,e.node_domain_name)}else if(e.status==="stop"){let t=G_.get(e.stream_name+e.node_domain_name);t&&(Jr.notify("Closing ingest consumer for node:",e.node_domain_name,"stream:",e.stream_name),await t.close?.(),G_.set(e.stream_name+e.node_domain_name,"close")),Bu.get(e.node_domain_name)==="failed"&&Bu.set(e.node_domain_name,"close")}}a(MH,"updateConsumer");var QE=new Map;function Xre(e,t,r){let n=QE.get(e);n||QE.set(e,n=new Map),n.set(t,r),DH||LH().then(Zre)}a(Xre,"setSubscription");async function Zre(){let e=await Wre.searchByValue({database:"system",table:"hdb_nodes",search_attribute:"name",search_value:"*"});for await(let t of e){let r=t.name+xu.SERVER_SUFFIX.LEAF,n,s;for(let i of t.subscriptions||[])if(i.subscribe===!0){if(!n&&({js:n,jsm:s}=await vH(r),!n))break;let{schema:o,table:c}=i,l=CH.createNatsTableStreamName(o,c);lO(l,n,s,r)}}}a(Zre,"accessConsumers");async function vH(e){let t,r,n=1;for(;!r;)try{t=await zE.jetstream({domain:e}),r=await zE.jetstreamManager({domain:e,checkAPI:!1})}catch(s){if(Bu.get(e)==="close")break;Bu.set(e,"failed"),n%10===1&&Jr.warn("Nats ingest attempting to connect to:",e,"Nats error:",s.message);let i=n++*100<WE?n++*100:WE;await PH(i)}return{js:t,jsm:r}}a(vH,"connectToRemoteJS");function ene(){return QE}a(ene,"getDatabaseSubscriptions");var UH;function tne(e){UH=e}a(tne,"setIgnoreOrigin");var xH=100,IH=new Array(xH),VE=0;async function lO(e,t,r,n){let{connection:s}=await YE.getNATSReferences();zE=s,KE=s.info.server_name;let i,o=1;for(;!i;)try{i=await t.consumers.get(e,KE),Jr.notify("Initializing ingest consumer for node:",n,"stream:",e)}catch(u){if(Bu.get(n)==="close")break;o%10===1&&Jr.warn("Nats ingest error getting consumer:",n,"stream:",e,"Nats error:",u.message),u.code==="404"&&(Jr.notify("Nats ingest creating consumer for node:",n,"stream:",e),i=await YE.createConsumer(r,e,KE,new Date(Date.now()).toISOString()));let f=o++*100<WE?o++*100:WE;await PH(f)}let c=!1,l;for(;!c;){if(G_.get(e+n)==="close"||Bu.get(n)==="close"){G_.delete(e+n),c=!0;continue}l=await i.consume({max_messages:aO.get(cO.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS)??100,bind:!0}),G_.set(e+n,l);let u=!1;(async()=>{for await(let f of await l.status())if(f.type===wH.ConsumerDeleted&&(await l.close(),c=!0),f.type===wH.HeartbeatsMissed){let d=f.data;Jr.trace(`${d} clustering ingest consumer heartbeats missed, node: ${n} stream: ${l.consumer.stream}`),d===100&&(Jr.warn(`Restarting clustering ingest consumer due to missed heartbeat threshold being met, node: ${n} stream: ${l.consumer.stream}`),l.stop(),u=!0)}})();try{for await(let f of l)await IH[VE],IH[VE]=rne(f).catch(d=>{Jr.error(d)}),++VE>=xH&&(VE=0)}catch(f){f.message==="consumer deleted"?(Jr.notify("Nats consumer deleted, closing messages for node:",n,"stream:",l.consumer.stream),await l.close(),c=!0):Jr.error("Error consuming clustering ingest, restarting consumer",f)}}}a(lO,"ingestConsumer");async function rne(e){let t;await Qre(()=>{t=qre(e.data)}),NH(e.data.length,"bytes-received",e.subject,t.operation,"ingest"),Jr.trace("Nats message processor message size:",e?.msg?._msg?.size,"bytes");let r=e.headers,n=!1,s=aO.get(cO.CONFIG_PARAMS.CLUSTERING_NODENAME);r.has(xu.MSG_HEADERS.TRANSACTED_NODES)&&r.values(xu.MSG_HEADERS.TRANSACTED_NODES).indexOf(s)>-1&&(n=!0);let i=r.get(xu.MSG_HEADERS.ORIGIN);if(n||(n=i===s&&!UH),Kre(n,"echo",e.subject,t.operation,"ingest"),n){e.ack();return}r.append(xu.MSG_HEADERS.TRANSACTED_NODES,s);try{let{operation:o,schema:c,next:l,table:u,records:f,hash_values:d,__origin:_,expiresAt:h}=t;Jr.trace("processing message:",o,c,u,(f?"records: "+f.map(M=>M?.id):"")+(d?"ids: "+d:""),"with sequence:",e.seq),Jr.trace(`messageProcessor nats msg id: ${e.headers.get(xu.MSG_HEADERS.NATS_MSG_ID)}`);let m;f||(f=d);let S=new Promise(M=>m=M),{timestamp:g,user:R,node_name:E}=_||{},T=QE.get(c)?.get(u);if(!T)throw new Error(`Missing table for replication message: ${u}`);if(o==="define_schema")t.type=o,t.onCommit=m,T.send(t);else if(f.length===1&&!l)T.send({type:oO(o),value:f[0],id:d?.[0],expiresAt:h,timestamp:g,table:u,onCommit:m,user:R,nodeName:E});else{let M=f.map((H,X)=>({type:oO(o),value:H,expiresAt:h,id:d?.[X],table:u}));for(;l;)M.push({type:oO(l.operation),value:l.record,expiresAt:l.expiresAt,id:l.id,table:l.table}),l=l.next;T.send({type:"transaction",writes:M,table:u,timestamp:g,onCommit:m,user:R,nodeName:E})}aO.get($re.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&Yre(e.subject.split(".").slice(0,-1).join("."),CH.createNatsTableStreamName(c,u),e.headers,e.data),await S;let N=Date.now()-g;g&&NH(N,"replication-latency",e.subject,o,"ingest")}catch(o){Jr.error(o)}e.ack()}a(rne,"messageProcessor");function oO(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}a(oO,"convertOperation")});var Er=C((_Ie,ek)=>{"use strict";var wr=le();wr.initSync();var nne=require("fs-extra"),sne=require("semver"),V_=require("path"),{monotonicFactory:ine}=require("ulidx"),kH=ine(),one=require("util"),FH=require("child_process"),ane=one.promisify(FH.exec),cne=FH.spawn,Hr=Lt(),Qe=(k(),P(q)),{packageJson:lne,PACKAGE_ROOT:une}=Et(),jE=ie(),js=ee(),JE=mo(),dne=$E(),q_=Ct(),{broadcast:fne,onMessageByType:_ne,getWorkerIndex:hne}=ot(),{isMainThread:GH}=require("worker_threads"),{Encoder:mne,decode:hO}=require("msgpackr"),qH=new mne,{isEmpty:nl}=jE,$H=Kn(),cIe=48*36e11;GH&&_ne(Qe.ITC_EVENT_TYPES.RESTART,()=>{Xr=void 0,rl=void 0});var{connect:pne,StorageType:Ene,RetentionPolicy:gne,AckPolicy:mO,DeliverPolicy:pO,DiscardPolicy:Sne,NatsConnection:lIe,JetStreamManager:uIe,JetStreamClient:dIe,StringCodec:fIe,JSONCodec:Tne,createInbox:EO,headers:Ane,ErrorCode:HH}=require("nats"),{recordAction:Rne}=(Mi(),P(v_)),{encodeBlobsAsBuffers:yne}=(gn(),P(uu)),VH=Tne(),bne="clustering",One=lne.engines[Hr.NATS_SERVER_NAME],Nne=V_.join(une,"dependencies"),_O=V_.join(Nne,`${process.platform}-${process.arch}`,Hr.NATS_BINARY_NAME),dO,fO,$_,el,tl;ek.exports={runCommand:KH,checkNATSServerInstalled:wne,createConnection:gO,getConnection:K_,getJetStreamManager:Y_,getJetStream:WH,getNATSReferences:xi,getServerList:Cne,createLocalStream:SO,listStreams:zH,deleteLocalStream:Pne,getServerConfig:Hu,listRemoteStreams:Dne,viewStream:Lne,viewStreamIterator:Mne,publishToStream:vne,request:Bne,reloadNATS:TO,reloadNATSHub:Hne,reloadNATSLeaf:kne,extractServerName:xne,requestErrorHandler:Fne,createLocalTableStream:XH,createTableStreams:$ne,purgeTableStream:ZH,purgeSchemaTableStreams:Vne,getStreamInfo:Kne,updateLocalStreams:Wne,closeConnection:Ine,getJsmServerName:XE,addNatsMsgHeader:QH,clearClientCache:YH,updateRemoteConsumer:Gne,createConsumer:jH,updateConsumerIterator:qne};async function KH(e,t=void 0){let{stdout:r,stderr:n}=await ane(e,{cwd:t});if(n)throw new Error(n.replace(`
|
|
21
21
|
`,""));return r.replace(`
|
|
22
22
|
`,"")}a(KH,"runCommand");async function wne(){try{await nne.access(_O)}catch{return!1}let e=await KH(`${_O} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return sne.eq(t,One)}a(wne,"checkNATSServerInstalled");async function gO(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let o=await $H.getClusterUser();if(nl(o))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=o.username,r=o.decrypt_hash}js.trace("create nats connection called");let i=await pne({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:wr.get(Qe.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:wr.get(Qe.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:wr.get(Qe.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),js.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(o=>{o&&js.error("Error with Nats client connection, connection closed",o),i===Xr&&YH()}),i}a(gO,"createConnection");function YH(){Xr=void 0,el=void 0,tl=void 0,rl=void 0}a(YH,"clearClientCache");async function Ine(){Xr&&(await Xr.drain(),Xr=void 0,el=void 0,tl=void 0,rl=void 0)}a(Ine,"closeConnection");var Xr,rl;async function K_(){return rl||(rl=gO(wr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),Xr=await rl),Xr||rl}a(K_,"getConnection");async function Y_(){if(el)return el;nl(Xr)&&await K_();let{domain:e}=Hu(Qe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(nl(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return el=await Xr.jetstreamManager({domain:e,timeout:6e4}),el}a(Y_,"getJetStreamManager");async function WH(){if(tl)return tl;nl(Xr)&&await K_();let{domain:e}=Hu(Qe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(nl(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return tl=Xr.jetstream({domain:e,timeout:6e4}),tl}a(WH,"getJetStream");async function xi(){let e=Xr||await K_(),t=el||await Y_(),r=tl||await WH();return{connection:e,jsm:t,js:r}}a(xi,"getNATSReferences");async function Cne(e){let t=wr.get(Qe.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await $H.getClusterUser(),s=await gO(t,r,n),i=EO(),o=s.subscribe(i),c=[],l,u=(async()=>{for await(let f of o){let d=VH.decode(f.data);d.response_time=Date.now()-l,c.push(d)}})();return l=Date.now(),await s.publish("$SYS.REQ.SERVER.PING.VARZ",void 0,{reply:i}),await s.publish("$SYS.REQ.SERVER.PING",void 0,{reply:i}),await s.flush(),await jE.async_set_timeout(e),await o.drain(),await s.close(),await u,c}a(Cne,"getServerList");async function SO(e,t){let{jsm:r}=await xi(),n=wr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=wr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=wr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:Ene.File,retention:gne.Limits,subjects:t,discard:Sne.Old,max_msgs:s,max_bytes:i,max_age:n})}a(SO,"createLocalStream");async function zH(){let{jsm:e}=await xi(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}a(zH,"listStreams");async function Pne(e){let{jsm:t}=await xi();await t.streams.delete(e)}a(Pne,"deleteLocalStream");async function Dne(e){let{connection:t}=await xi(),r=[],n=EO(),s=t.subscribe(n),i=(async()=>{for await(let o of s)r.push(VH.decode(o.data))})();return await t.publish(`$JS.${e}.API.STREAM.LIST`,void 0,{reply:n}),await t.flush(),await s.drain(),await i,r}a(Dne,"listRemoteStreams");async function Lne(e,t=void 0,r=void 0){let{jsm:n,js:s}=await xi(),i=kH(),o={durable_name:i,ack_policy:mO.Explicit};t&&(o.deliver_policy=pO.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];let u=[];for await(let f of l){let d=hO(f.data),_={nats_timestamp:f.info.timestampNanos,nats_sequence:f.info.streamSequence,entry:d};if(f.headers&&(_.origin=f.headers.get(Hr.MSG_HEADERS.ORIGIN)),u.push(_),f.ack(),f.info.pending===0)break}return await c.delete(),u}a(Lne,"viewStream");async function*Mne(e,t=void 0,r=void 0){let{jsm:n,js:s}=await xi(),i=kH(),o={durable_name:i,ack_policy:mO.Explicit};t&&(o.deliver_policy=pO.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];for await(let u of l){let f=hO(u.data);f[0]||(f=[f]);for(let d of f){let _={nats_timestamp:u.info.timestampNanos,nats_sequence:u.info.streamSequence,entry:d};u.headers&&(_.origin=u.headers.get(Hr.MSG_HEADERS.ORIGIN)),yield _}if(u.ack(),u.info.pending===0)break}await c.delete()}a(Mne,"viewStreamIterator");async function vne(e,t,r,n){js.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=QH(n,r);let{js:s}=await xi(),i=await XE(),o=`${e}.${i}`,c=await yne(()=>n instanceof Uint8Array?n:qH.encode(n));try{js.trace(`publishToStream publishing to subject: ${o}`),Rne(c.length,"bytes-sent",e,n.operation,"replication"),await s.publish(o,c,{headers:r})}catch(l){if(l.code&&l.code.toString()==="503")return JH(async()=>{try{await s.publish(o,c,{headers:r})}catch{if(l.code&&l.code.toString()==="503"){js.trace(`publishToStream creating stream: ${t}`);let f=o.split(".");f[2]="*",await SO(t,[o]),await s.publish(o,c,{headers:r})}else throw l}});throw l}}a(vne,"publishToStream");function QH(e,t){t===void 0&&(t=Ane());let r=wr.get(Qe.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(Hr.MSG_HEADERS.ORIGIN)&&r&&t.append(Hr.MSG_HEADERS.ORIGIN,r),t}a(QH,"addNatsMsgHeader");function Hu(e){e=e.toLowerCase();let t=V_.join(wr.get(Qe.CONFIG_PARAMS.ROOTPATH),bne);if(e===Qe.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return nl(fO)&&(fO={port:q_.getConfigFromFile(Qe.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:q_.getConfigFromFile(Qe.CONFIG_PARAMS.CLUSTERING_NODENAME)+Hr.SERVER_SUFFIX.HUB,config_file:Hr.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:V_.join(t,Hr.PID_FILES.HUB),hdb_nats_path:t}),fO;if(e===Qe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return nl(dO)&&(dO={port:q_.getConfigFromFile(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:q_.getConfigFromFile(Qe.CONFIG_PARAMS.CLUSTERING_NODENAME)+Hr.SERVER_SUFFIX.LEAF,config_file:Hr.NATS_CONFIG_FILES.LEAF_SERVER,domain:q_.getConfigFromFile(Qe.CONFIG_PARAMS.CLUSTERING_NODENAME)+Hr.SERVER_SUFFIX.LEAF,pid_file_path:V_.join(t,Hr.PID_FILES.LEAF),hdb_nats_path:t}),dO;js.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(Hu,"getServerConfig");async function jH(e,t,r,n){try{await e.consumers.add(t,{ack_policy:mO.Explicit,durable_name:r,deliver_policy:pO.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}a(jH,"createConsumer");async function Une(e,t,r){await e.consumers.delete(t,r)}a(Une,"removeConsumer");function xne(e){return e.split(".")[1]}a(xne,"extractServerName");async function Bne(e,t,r=6e4,n=EO()){if(!jE.isObject(t))throw new Error("data param must be an object");let s=qH.encode(t),{connection:i}=await xi(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return hO(c.data)}a(Bne,"request");function TO(e){return new Promise(async(t,r)=>{let n=cne(_O,["--signal",`reload=${e}`],{cwd:__dirname}),s,i;n.on("error",o=>{r(o)}),n.stdout.on("data",o=>{i+=o.toString()}),n.stderr.on("data",o=>{s+=o.toString()}),n.stderr.on("close",o=>{s&&r(s),t(i)})})}a(TO,"reloadNATS");async function Hne(){let{pid_file_path:e}=Hu(Qe.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await TO(e)}a(Hne,"reloadNATSHub");async function kne(){let{pid_file_path:e}=Hu(Qe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await TO(e)}a(kne,"reloadNATSLeaf");function Fne(e,t,r){let n;switch(e.code){case HH.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case HH.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}a(Fne,"requestErrorHandler");async function Gne(e,t){let r=t+Hr.SERVER_SUFFIX.LEAF,{connection:n}=await xi(),{jsm:s}=await Qne(r),{schema:i,table:o}=e,c=JE.createNatsTableStreamName(i,o),l=e.start_time?e.start_time:new Date(Date.now()).toISOString();await JH(async()=>{if(e.subscribe===!0)await jH(s,c,n.info.server_name,l);else try{await Une(s,c,n.info.server_name)}catch(u){js.trace(u)}})}a(Gne,"updateRemoteConsumer");async function qne(e,t,r,n){let s=JE.createNatsTableStreamName(e,t),i=r+Hr.SERVER_SUFFIX.LEAF,o={type:Qe.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!GH&&hne()<wr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=uO();await c(o)}await fne(o),n==="stop"&&await jE.async_set_timeout(1e3)}a(qne,"updateConsumerIterator");function JH(e){return dne.writeTransaction(Qe.SYSTEM_SCHEMA_NAME,Qe.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(JH,"exclusiveLock");async function XH(e,t){let r=JE.createNatsTableStreamName(e,t),n=await XE(),s=Yne(e,t,n);await SO(r,[s])}a(XH,"createLocalTableStream");async function $ne(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await XH(n,s)}}a($ne,"createTableStreams");async function ZH(e,t,r=void 0){if(wr.get(Qe.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=JE.createNatsTableStreamName(e,t),{domain:s}=Hu(Qe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await K_()).jetstreamManager({domain:s,timeout:24e4})).streams.purge(n,r)}catch(n){if(n.message==="stream not found")js.warn(n);else throw n}}a(ZH,"purgeTableStream");async function Vne(e,t){if(wr.get(Qe.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await ZH(e,t[r])}a(Vne,"purgeSchemaTableStreams");async function Kne(e){return(await Y_()).streams.info(e)}a(Kne,"getStreamInfo");function Yne(e,t,r){return`${Hr.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}a(Yne,"createSubjectName");async function XE(){if($_)return $_;if($_=(await Y_())?.nc?.info?.server_name,$_===void 0)throw new Error("Unable to get jetstream manager server name");return $_}a(XE,"getJsmServerName");async function Wne(){let e=await Y_(),t=await XE(),r=await zH();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let o=zne(n),c=i.split(".");if(c[c.length-1]===t&&!o||s.name==="__HARPERDB_WORK_QUEUE__")continue;let u=i.split(".");u[u.length-1]=t;let f=u.join(".");js.trace(`Updating stream subject name from: ${i} to: ${f}`),s.subjects[0]=f,await e.streams.update(s.name,s)}}a(Wne,"updateLocalStreams");function zne(e){let{config:t}=e,r=!1,n=wr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=wr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=wr.get(Qe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);return i=i===null?-1:i,n!==t.max_age&&(t.max_age=n,r=!0),s!==t.max_bytes&&(t.max_bytes=s,r=!0),i!==t.max_msgs&&(t.max_msgs=i,r=!0),r}a(zne,"updateStreamLimits");async function Qne(e){let t,r;try{t=await Xr.jetstream({domain:e}),r=await Xr.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw js.error("Unable to connect to:",e),n}return{js:t,jsm:r}}a(Qne,"connectToRemoteJS")});function AO(e){let t=e.get(ZE),r=t?(0,ku.unpack)(t):null;r||(r={remoteNameToId:{}});let n=et(),s=!1;r.nodeName=et();let i=r.remoteNameToId;if(i[n]!==0){let o=0,c;for(let l in i){let u=i[l];u===0?c=l:u>o&&(o=u)}if(c){o++,i[c]=o;let l=[Symbol.for("seq"),o];e.rootStore.dbisDb.transactionSync(()=>{e.rootStore.dbisDb.get(l)||e.rootStore.dbisDb.putSync(l,{seqId:z_(e)??1,nodes:[]})})}i[n]=0,e.putSync(ZE,(0,ku.pack)(r))}return r}function W_(e){return AO(e).remoteNameToId}function rk(e,t){let r=AO(t),n=r.remoteNameToId,s=new Map,i=!1;for(let o in e){let c=e[o],l=n[o];if(l==null){let u=0;for(let f in n){let d=n[f];d>u&&(u=d)}l=u+1,n[o]=l,i=!0}s.set(c,l)}return i&&t.putSync(ZE,(0,ku.pack)(r)),s}function eg(e,t){let r=AO(t),n=r.remoteNameToId,s=n[e];if(s==null){let i=0;for(let o in n){let c=n[o];c>i&&(i=c)}s=i+1,n[e]=s,t.putSync(ZE,(0,ku.pack)(r))}return tk.trace?.("The remote node name map",e,n,s),s}var tk,ku,ZE,RO=Re(()=>{tk=v(Gs());Es();ku=require("msgpackr"),ZE=Symbol.for("remote-ids");a(AO,"getIdMappingRecord");a(W_,"exportIdMapping");a(rk,"remoteToLocalNodeId");a(eg,"getIdOfRemoteNode")});var yO={};Ue(yO,{commits_awaiting_replication:()=>Fu,getHDBNodeTable:()=>sr,getReplicationSharedStatus:()=>tg,iterateRoutes:()=>j_,shouldReplicateToNode:()=>Q_,subscribeToNodeUpdates:()=>Gu});function sr(){return nk||(nk=_t({table:"hdb_nodes",database:"system",attributes:[{name:"name",isPrimaryKey:!0},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"},{attribute:"ca"},{attribute:"ca_info"},{attribute:"replicates"},{attribute:"revoked_certificates"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]}))}function tg(e,t,r,n){return new Float64Array(e.getUserSharedBuffer(["replicated",t,r],new ArrayBuffer(48),n&&{callback:n}))}function Gu(e){sr().subscribe({}).then(async t=>{for await(let r of t){let n=r?.value?.name;ak.debug?.("adding node",n,"on node",et()," on process",process.pid),server.nodes=server.nodes.filter(i=>i.name!==n),r.type==="put"&&n!==et()&&(r.value?server.nodes.push(r.value):console.error("Invalid node update event",r));let s=new Map;for await(let i of sr().search({}))if(i.shard!=null){let o=s.get(i.shard);o||s.set(i.shard,o=[]),o.push(i)}server.shards=s,(r.type==="put"||r.type==="delete")&&e(r.value,r.id)}})}function Q_(e,t){let r=Sa.default.get(x.REPLICATION_DATABASES);return(e.replicates===!0||e.replicates?.sends)&&databases[t]&&(r==="*"||r?.find?.(n=>(typeof n=="string"?n:n.name)===t&&(!n.sharded||e.shard===Sa.default.get(x.REPLICATION_SHARD))))&&sr().primaryStore.get(et())?.replicates||e.subscriptions?.some(n=>(n.database||n.schema)===t&&n.subscribe)}function jne(){Gu(e=>{Ta({},(t,r)=>{let n=e.name,s=sk.get(n);if(s||sk.set(n,s=new Map),s.has(r))return;let i;for(let o in t)if(i=t[o].auditStore,i)break;if(i){let o=tg(i,r,n,()=>{let c=o[0],l=o.lastTime;for(let{txnTime:u,onConfirm:f}of Fu.get(r)||[])u>l&&u<=c&&f();o.lastTime=c});o.lastTime=0,s.set(r,o)}})})}function*j_(e){for(let t of e.routes||[]){let r=t.url,n;if(typeof t=="string"?t.includes("://")?r=t:n=t:n=t.hostname??t.host,n&&!r){let s=Sa.default.get(x.REPLICATION_SECUREPORT)??(!Sa.default.get(x.REPLICATION_PORT)&&Sa.default.get(x.OPERATIONSAPI_NETWORK_SECUREPORT)),i;(i=n.match(/:(\d+)$/)?.[1])?n=n.slice(0,-i[0].length-1):t.port?i=t.port:i=s||Sa.default.get(x.REPLICATION_PORT)||Sa.default.get(x.OPERATIONSAPI_NETWORK_PORT);let o=i?.lastIndexOf?.(":");o>0&&(i=+i.slice(o+1).replace(/[\[\]]/g,"")),r=(s?"wss://":"ws://")+n+":"+i}if(!r){ik.isMainThread&&console.error("Invalid route, must specify a url or host (with port)");continue}yield{replicates:!t.subscriptions,url:r,subscription:t.subscriptions,routes:t.routes,start_time:t.startTime,revoked_certificates:t.revokedCertificates}}}var ik,ok,Sa,ak,nk,sk,Fu,sl=Re(()=>{xe();Es();ip();ik=require("worker_threads"),ok=v(he()),Sa=v(le());k();ak=v(Gs());server.nodes=[];a(sr,"getHDBNodeTable");a(tg,"getReplicationSharedStatus");a(Gu,"subscribeToNodeUpdates");a(Q_,"shouldReplicateToNode");sk=new Map;nL((e,t,r)=>{if(r>server.nodes.length)throw new ok.ClientError(`Cannot confirm replication to more nodes (${r}) than are in the network (${server.nodes.length})`);Fu||(Fu=new Map,jne());let n=Fu.get(e);return n||(n=[],Fu.set(e,n)),new Promise(s=>{let i=0;n.push({txnTime:t,onConfirm:a(()=>{++i===r&&s()},"onConfirm")})})});a(jne,"startSubscriptionToReplications");a(j_,"iterateRoutes")});var uk={};Ue(uk,{connectedToNode:()=>il,disconnectedFromNode:()=>$u,ensureNode:()=>Ro,requestClusterStatus:()=>lk,startOnMainThread:()=>OO});async function OO(e){let t=0,r=Xe();for(let i of Object.getOwnPropertyNames(r)){let o=r[i];for(let c in o){let l=o[c];if(l.auditStore){rg.set(i,z_(l.auditStore));break}}}Hi.whenThreadsStarted.then(async()=>{let i=[];for await(let o of r.system.hdb_nodes?.search([])||[])i.push(o);for(let o of j_(e))try{let c=!o.subscriptions;if(c){let u=et(),f=sr().primaryStore.get(u);if(f!==null){let d=e.url??Aa();(f===void 0||f.url!==d||f.shard!==e.shard)&&await Ro(u,{name:u,url:d,shard:e.shard,replicates:!0})}}let l=o.trusted!==!1;if(c&&o.replicates==null&&(o.replicates=!0),i.find(u=>u.url===o.url))continue;s(o)}catch(c){console.error(c)}Gu(s)});let n;function s(i,o=i?.name){let c=et()&&o===et()||Aa()&&i?.url===Aa();if(c){let d=!!i?.replicates;if(n!==void 0&&n!==d)for(let _ of sr().search([]))_.replicates&&_.name!==o&&s(_,_.name);n=d}if(nt.trace("Setting up node replication for",i),!i){for(let[d,_]of Bi){let h;for(let[m,{worker:S,nodes:g}]of _){let R=g[0];if(R&&R.name==o){h=!0;for(let[E,{worker:T}]of _)_.delete(E),nt.warn("Node was deleted, unsubscribing from node",o,E,d),T?.postMessage({type:"unsubscribe-from-node",node:o,database:E,url:d});break}}if(h){Bi.get(d).iterator.remove(),Bi.delete(d);return}}return}if(c)return;if(!i.url){nt.info(`Node ${i.name} is missing url`);return}let l=Bi.get(i.url);if(l&&l.iterator.remove(),!(i.replicates===!0||i.replicates?.sends)&&!i.subscriptions?.length&&!l)return;if(nt.info(`Added node ${i.name} at ${i.url} for process ${et()}`),i.replicates&&i.subscriptions&&(i={...i,subscriptions:null}),i.name){for(let[d,_]of qu)if(i.url===_.url){qu.delete(d);break}qu.set(i.name,i)}let u=Xe();if(l||(l=new Map,Bi.set(i.url,l)),l.iterator=Ta(e,(d,_,h)=>{h?f(_,!0):f(_,!1)}),i.subscriptions)for(let d of i.subscriptions){let _=d.database||d.schema;u[_]||(nt.warn(`Database ${_} not found for node ${i.name}, making a subscription anyway`),f(_,!1))}function f(d,_){nt.trace("Setting up replication for database",d,"on node",i.name);let h=l.get(d),m,S=[{replicateByDefault:_,...i}];rg.has(d)&&J_.default.get(x.REPLICATION_FAILOVER)&&(S.push({replicateByDefault:_,name:et(),start_time:rg.get(d),end_time:Date.now(),replicates:!0}),rg.delete(d));let g=Q_(i,d),R=Hi.workers.filter(E=>E.name==="http");if(h?(m=h.worker,h.nodes=S):g&&(t=t%R.length,m=R[t++],l.set(d,{worker:m,nodes:S,url:i.url}),m?.on("exit",()=>{l.get(d)?.worker===m&&(l.delete(d),f(d,_))})),g)setTimeout(()=>{let E={type:"subscribe-to-node",database:d,nodes:S};m?m.postMessage(E):X_(E)},Jne);else{nt.info("Node no longer should be used, unsubscribing from node",i.replicates,!!u[d],sr().primaryStore.get(et())?.replicates),sr().primaryStore.get(et())?.replicates||(n=!1);let E={type:"unsubscribe-from-node",database:d,url:i.url,name:i.name};m?m.postMessage(E):sg(E)}}a(f,"onDatabase")}a(s,"onNodeUpdate"),$u=a(function(i){try{nt.info("Disconnected from node",i.name,i.url,"finished",!!i.finished);let o=Array.from(qu.keys()),c=o.sort(),l=c.indexOf(i.name||Js(i.url));if(l===-1){nt.warn("Disconnected node not found in node map",i.name,o);return}let u=Bi.get(i.url),f=u?.get(i.database);if(!f){nt.warn("Disconnected node not found in replication map",i.database,u);return}if(f.connected=!1,i.finished||!J_.default.get(x.REPLICATION_FAILOVER))return;let d=f.nodes[0];if(!(d.replicates===!0||d.replicates?.sends||d.subscriptions?.length))return;let _=d.shard,h=(l+1)%c.length;for(;l!==h;){let m=c[h],S=qu.get(m);u=Bi.get(S.url);let g=u?.get(i.database);if(!g||g.connected===!1||g.nodes[0].shard!==_){h=(h+1)%c.length;continue}let{worker:R,nodes:E}=g,T=!1;for(let N of f.nodes){if(E.some(M=>M.name===N.name)){nt.info(`Disconnected node is already failing over to ${m} for ${i.database}`);continue}N.end_time<Date.now()||(E.push(N),T=!0)}if(f.nodes=[f.nodes[0]],!T){nt.info(`Disconnected node ${i.name} has no nodes to fail over to ${m}`);return}nt.info(`Failing over ${i.database} from ${i.name} to ${m}`),R?R.postMessage({type:"subscribe-to-node",database:i.database,nodes:E}):X_({database:i.database,nodes:E});return}nt.warn("Unable to find any other node to fail over to",i.name,i.url)}catch(o){nt.error("Error failing over node",o)}},"disconnectedFromNode"),il=a(function(i){let o=Bi.get(i.url),c=o?.get(i.database);if(!c){nt.warn("Connected node not found in replication map, this may be because the node is being removed",i.database,o);return}c.connected=!0,c.latency=i.latency;let l=c.nodes[0];if(!l){nt.info("Connected node has no nodes",i.database,c);return}if(!l.name){nt.debug("Connected node is not named yet",i.database,c);return}if(!J_.default.get(x.REPLICATION_FAILOVER))return;c.nodes=[l];let u=!1;for(let f of Bi.values()){let d=f.get(i.database);if(!d||d==c)continue;let{worker:_,nodes:h,connected:m}=d;if(h)if(m===!1&&h[0].shard===l.shard)u=!0,c.nodes.push(h[0]);else{let S=h.filter(g=>g.name!==l.name);S.length<h.length&&(d.nodes=S,_.postMessage({type:"subscribe-to-node",database:i.database,nodes:h}))}}u&&c.worker&&c.worker.postMessage({type:"subscribe-to-node",database:i.database,nodes:c.nodes})},"connectedToNode"),(0,Hi.onMessageByType)("disconnected-from-node",$u),(0,Hi.onMessageByType)("connected-to-node",il),(0,Hi.onMessageByType)("request-cluster-status",lk)}function lk(e,t){let r=[];for(let[n,s]of qu)try{let i=Bi.get(s.url);nt.info("Getting cluster status for",n,s.url,"has dbs",i?.size);let o=[];if(i){for(let[l,{worker:u,connected:f,nodes:d,latency:_}]of i)o.push({database:l,connected:f,latency:_,thread_id:u?.threadId,nodes:d.filter(h=>!(h.end_time<Date.now())).map(h=>h.name)});let c=(0,bO.cloneDeep)(s);c.database_sockets=o,delete c.ca,delete c.node_name,delete c.__updatedtime__,delete c.__createdtime__,r.push(c)}}catch(i){nt.warn("Error getting cluster status for",s?.url,i)}return t?.postMessage({type:"cluster-status",connections:r}),{connections:r}}async function Ro(e,t){let r=sr();e=e??Js(t.url),t.name=e;try{if(t.ca){let s=new ck.X509Certificate(t.ca);t.ca_info={issuer:s.issuer.replace(/\n/g," "),subject:s.subject.replace(/\n/g," "),subject_alt_name:s.subjectAltName,serial_number:s.serialNumber,valid_from:s.validFrom,valid_to:s.validTo}}}catch(s){nt.error("Error parsing replication CA info for hdb_nodes table",s.message)}let n=r.primaryStore.get(e);if(nt.debug(`Ensuring node ${e} at ${t.url}, existing record:`,n,"new record:",t),!n)await r.patch(t);else{t.replicates&&!J_.default.get(x.CLUSTERING_ENABLED)&&(t.subscriptions=null);for(let s in t)if(n[s]!==t[s]&&s==="subscriptions"&&t[s]&&n[s]){let i=[],o=(0,bO.cloneDeep)(n[s]);for(let c of t[s]){let l=!1;for(let u of o)if((c.database??c.schema)===(u.database??u.schema)&&c.table===u.table){u.publish=c.publish,u.subscribe=c.subscribe,l=!0;break}l||i.push(c)}t.subscriptions=[...o,...i];break}if(Array.isArray(t.revoked_certificates)){let s=n.revoked_certificates||[];t.revoked_certificates=[...new Set([...s,...t.revoked_certificates])]}nt.info(`Updating node ${e} at ${t.url}`),await r.patch(t)}}var Hi,ng,nt,bO,J_,ck,Jne,Bi,$u,il,qu,rg,Z_=Re(()=>{xe();Hi=v(ot());Es();ng=require("worker_threads");sl();nt=v(ee()),bO=require("lodash"),J_=v(le());k();ck=require("crypto"),Jne=200,Bi=new Map,qu=new Map,rg=new Map;a(OO,"startOnMainThread");a(lk,"requestClusterStatus");ng.parentPort&&($u=a(e=>{ng.parentPort.postMessage({type:"disconnected-from-node",...e})},"disconnectedFromNode"),il=a(e=>{ng.parentPort.postMessage({type:"connected-to-node",...e})},"connectedToNode"),(0,Hi.onMessageByType)("subscribe-to-node",e=>{X_(e)}),(0,Hi.onMessageByType)("unsubscribe-from-node",e=>{sg(e)}));a(Ro,"ensureNode")});var ei=C(Lk=>{"use strict";var ir=require("path"),{watch:pk}=require("chokidar"),bn=require("fs-extra"),Vu=require("node-forge"),Ek=require("net"),{generateKeyPair:wO,X509Certificate:yo,createPrivateKey:gk}=require("crypto"),Xne=require("util");wO=Xne.promisify(wO);var bt=Vu.pki,Xs=require("joi"),{v4:Sk}=require("uuid"),{validateBySchema:DO}=it(),yt=ee(),Jn=le(),gs=(k(),P(q)),{CONFIG_PARAMS:al}=gs,Zs=LA(),{ClientError:ya}=he(),og=require("node:tls"),{relative:Tk,join:Zne}=require("node:path"),{CERT_PREFERENCE_APP:PIe,CERTIFICATE_VALUES:dk}=Zs,ese=hc(),ig=Ct(),{table:tse,getDatabases:rse,databases:NO}=(xe(),P(ct)),{getJWTRSAKeys:fk}=(vu(),P(F_));Object.assign(Lk,{generateKeys:UO,updateConfigCert:Nk,createCsr:use,signCertificate:dse,setCertTable:Ku,loadCertificates:vO,reviewSelfSignedCert:BO,createTLSSelector:Ik,listCertificates:Pk,addCertificate:Ese,removeCertificate:Sse,createNatsCerts:hse,generateCertsKeys:_se,getReplicationCert:th,getReplicationCertAuth:cse,renewSelfSigned:mse,hostnamesFromCert:HO,getKey:Tse});var{urlToNodeName:Ak,getThisNodeUrl:nse,getThisNodeName:ug,clearThisNodeName:sse}=(Es(),P(Na)),{readFileSync:ise,statSync:Rk}=require("node:fs"),DIe=le(),{getTicketKeys:ose,onMessageFromWorkers:ase}=ot(),Ra=ee(),{isMainThread:IO}=require("worker_threads"),{TLSSocket:yk,createSecureContext:LIe}=require("node:tls"),LO=3650,eh=["127.0.0.1","localhost","::1"],MO=[{name:"countryName",value:"USA"},{name:"stateOrProvinceName",value:"Colorado"},{name:"localityName",value:"Denver"},{name:"organizationName",value:"HarperDB, Inc."}];ase(async e=>{e.type===gs.ITC_EVENT_TYPES.RESTART&&(Jn.initSync(!0),await BO())});var kr;function Oa(){return kr||(kr=rse().system.hdb_certificate,kr||(kr=tse({table:"hdb_certificate",database:"system",attributes:[{name:"name",isPrimaryKey:!0},{attribute:"uses"},{attribute:"certificate"},{attribute:"is_authority"},{attribute:"private_key_name"},{attribute:"details"},{attribute:"is_self_signed"},{attribute:"__updatedtime__"}]}))),kr}a(Oa,"getCertTable");async function th(){let e=Ik("replication"),t={secureContexts:null,setSecureContext:a(s=>{},"setSecureContext")};await e.initialize(t);let r=t.secureContexts.get(ug());if(!r)return;let n=new yo(r.options.cert);return r.cert_parsed=n,r.issuer=n.issuer,r}a(th,"getReplicationCert");async function cse(){Oa();let e=(await th()).options.cert,r=new yo(e).issuer.match(/CN=(.*)/)?.[1];return kr.get(r)}a(cse,"getReplicationCertAuth");var CO,ba=new Map,ag=[],_k;function vO(){if(CO)return;if(CO=!0,!_k&&IO){let n=ig.getConfigFilePath();_k=pk(n,{persistent:!1}).on("change",()=>{logger.warn?.("Config file changed, reloading certificates"),lse()})}let e=[{configKey:al.TLS},{configKey:al.OPERATIONSAPI_TLS}];Oa();let t=ir.dirname(ig.getConfigFilePath()),r;for(let{configKey:n}of e){let s=ig.getConfigFromFile(n);if(s){Array.isArray(s)||(s=[s]);for(let i of s){let o=i.privateKey,c=o&&Tk(Zne(t,"keys"),o);if(c){let l=hk(o,u=>{ba.set(c,u)},"private key");l&&ag.push(l)}for(let l of[!1,!0]){let u=i[l?"certificateAuthority":"certificate"];if(u&&IO){let f=hk(u,d=>{if(dk.cert===d)return;let _=i.hostname??i.hostnames??i.host??i.hosts;_&&!Array.isArray(_)&&(_=[_]);let h=wk(u),m=new yo(h),S;try{S=!l&&i.name||Dk(x509Cert)}catch(M){logger.error("error extracting host name from certificate",M);return}if(S==null){logger.error("No host name found on certificate");return}if(m.checkIssued(new yo(dk.cert)))return;let g=kr.primaryStore.get(S),R=Rk(u).mtimeMs,E=!g||g.is_self_signed?1:g.fileTimestamp??g.__updatedtime__,T=i.uses??["https",...n.includes("operations")?["operations"]:[]],N=g&&R===E&&(JSON.stringify(g.uses)!==JSON.stringify(T)||g.ciphers!==i.ciphers||JSON.stringify(g.hostnames)!==JSON.stringify(_));if(E&&R<=E&&!N){R<E&&logger.info?.(`Certificate ${S} at ${u} is older (${new Date(R)}) than the certificate in the database (${E>1?new Date(E):"only self signed certificate available"})`);return}N&&logger.info?.(`Config values changed for certificate ${S}, updating record`),r=kr.put({name:S,uses:i.uses??["https",...n.includes("operations")?["operations"]:[]],ciphers:i.ciphers,certificate:h,private_key_name:c,is_authority:l,hostnames:_,file_timestamp:R,details:{issuer:m.issuer.replace(/\n/g," "),subject:m.subject?.replace(/\n/g," "),subject_alt_name:m.subjectAltName,serial_number:m.serialNumber,valid_from:m.validFrom,valid_to:m.validTo}})},l?"certificate authority":"certificate");f&&ag.push(f)}}}}}return r}a(vO,"loadCertificates");function lse(){for(let e of ag)e.close();ag.length=0,CO=!1,vO()}a(lse,"reloadCertificates");function hk(e,t,r){let n,s=a((i,o)=>{try{let c=o.mtimeMs;c&&c!==n&&(n&&IO&&yt.warn(`Reloading ${r}:`,i),n=c,t(wk(i)))}catch(c){yt.error(`Error loading ${r}:`,i,c)}},"loadFile");return bn.existsSync(e)?s(e,Rk(e)):yt.error?.(`${r} file not found:`,e),pk(e,{persistent:!1}).on("change",s)}a(hk,"loadAndWatch");function cg(){let e=nse();if(e==null){let t=eh[0];return yt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return Ak(e)}a(cg,"getHost");function lg(){let e=ug();if(e==null){let t=eh[0];return yt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return e}a(lg,"getCommonName");async function use(){let e=await th(),t=bt.certificateFromPem(e.options.cert),r=bt.privateKeyFromPem(e.options.key);yt.info("Creating CSR with cert named:",e.name);let n=bt.createCertificationRequest();n.publicKey=t.publicKey;let s=[{name:"commonName",value:lg()},...MO];yt.info("Creating CSR with subject",s),n.setSubject(s);let i=[{name:"unstructuredName",value:"HarperDB, Inc."},{name:"extensionRequest",extensions:bk()}];return yt.info("Creating CSR with attributes",i),n.setAttributes(i),n.sign(r),Vu.pki.certificationRequestToPem(n)}a(use,"createCsr");function bk(){let e=eh.includes(lg())?eh:[...eh,lg()];return e.includes(cg())||e.push(cg()),[{name:"basicConstraints",cA:!1,critical:!0},{name:"keyUsage",digitalSignature:!0,keyEncipherment:!0,critical:!0},{name:"extKeyUsage",serverAuth:!0,clientAuth:!0},{name:"nsCertType",client:!0,server:!0},{name:"subjectAltName",altNames:e.map(t=>Ek.isIP(t)?{type:7,ip:t}:{type:2,value:t})}]}a(bk,"certExtensions");async function dse(e){let t={},r=ir.join(Jn.getHdbBasePath(),gs.LICENSE_KEY_DIR_NAME);if(e.csr){let n,s;Oa();for await(let f of kr.search([]))if(f.is_authority&&!f.details.issuer.includes("HarperDB-Certificate-Authority")){if(ba.has(f.private_key_name)){n=ba.get(f.private_key_name),s=f;break}else if(f.private_key_name&&await bn.exists(ir.join(r,f.private_key_name))){n=bn.readFile(ir.join(r,f.private_key_name)),s=f;break}}if(!n){let f=await PO();s=f.ca,n=f.private_key}n=bt.privateKeyFromPem(n),t.signingCA=s.certificate;let i=bt.certificateFromPem(s.certificate);yt.info("Signing CSR with cert named",s.name);let o=bt.certificationRequestFromPem(e.csr);try{o.verify()}catch(f){return yt.error(f),new Error("Error verifying CSR: "+f.message)}let c=Vu.pki.createCertificate();c.serialNumber=Math.random().toString().slice(2,10),c.validity.notBefore=new Date;let l=new Date;c.validity.notAfter=l,c.validity.notAfter.setDate(l.getDate()+LO),yt.info("sign cert setting validity:",c.validity),yt.info("sign cert setting subject from CSR:",o.subject.attributes),c.setSubject(o.subject.attributes),yt.info("sign cert setting issuer:",i.subject.attributes),c.setIssuer(i.subject.attributes);let u=o.getAttribute({name:"extensionRequest"}).extensions;yt.info("sign cert adding extensions from CSR:",u),c.setExtensions(u),c.publicKey=o.publicKey,c.sign(n,Vu.md.sha256.create()),t.certificate=bt.certificateToPem(c)}else yt.info("Sign cert did not receive a CSR from:",e.url,"only the CA will be returned");return t}a(dse,"signCertificate");async function fse(e,t){await Ku({name:ug(),uses:["https","wss"],certificate:e,private_key_name:"privateKey.pem",is_authority:!1,is_self_signed:!0}),await Ku({name:t.subject.getField("CN").value,uses:["https","wss"],certificate:bt.certificateToPem(t),private_key_name:"privateKey.pem",is_authority:!0,is_self_signed:!0})}a(fse,"createCertificateTable");async function Ku(e){let t=new yo(e.certificate);e.details={issuer:t.issuer.replace(/\n/g," "),subject:t.subject?.replace(/\n/g," "),subject_alt_name:t.subjectAltName,serial_number:t.serialNumber,valid_from:t.validFrom,valid_to:t.validTo},Oa(),await kr.patch(e)}a(Ku,"setCertTable");async function UO(){let e=await wO("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}});return{public_key:bt.publicKeyFromPem(e.publicKey),private_key:bt.privateKeyFromPem(e.privateKey)}}a(UO,"generateKeys");async function xO(e,t,r){let n=bt.createCertificate();if(!t){let o=await th();t=bt.certificateFromPem(o.options.cert).publicKey}n.publicKey=t,n.serialNumber=Math.random().toString().slice(2,10),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+LO);let i=[{name:"commonName",value:lg()},...MO];return n.setSubject(i),n.setIssuer(r.subject.attributes),n.setExtensions(bk()),n.sign(e,Vu.md.sha256.create()),bt.certificateToPem(n)}a(xO,"generateCertificates");async function PO(){let e=await Pk(),t;for(let r of e){if(!r.is_authority)continue;let n=await Ck(r.private_key_name);if(r.private_key_name&&n&&new yo(r.certificate).checkPrivateKey(gk(n))){yt.trace(`CA named: ${r.name} found with matching private key`),t={ca:r,private_key:n};break}}if(t)return t;yt.trace("No CA found with matching private key")}a(PO,"getCertAuthority");async function Ok(e,t,r=!0){let n=bt.createCertificate();n.publicKey=t,n.serialNumber=Math.random().toString().slice(2,10),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+LO);let i=[{name:"commonName",value:`HarperDB-Certificate-Authority-${Jn.get(al.REPLICATION_HOSTNAME)??Ak(Jn.get(al.REPLICATION_URL))??Sk().split("-")[0]}`},...MO];n.setSubject(i),n.setIssuer(i),n.setExtensions([{name:"basicConstraints",cA:!0,critical:!0},{name:"keyUsage",keyCertSign:!0,critical:!0}]),n.sign(e,Vu.md.sha256.create());let o=ir.join(Jn.getHdbBasePath(),gs.LICENSE_KEY_DIR_NAME),c=ir.join(o,Zs.PRIVATEKEY_PEM_NAME);return r&&await bn.writeFile(c,bt.privateKeyToPem(e)),n}a(Ok,"generateCertAuthority");async function _se(){let{private_key:e,public_key:t}=await UO(),r=await Ok(e,t),n=await xO(e,t,r);await fse(n,r),Nk()}a(_se,"generateCertsKeys");async function hse(){let e=await xO(bt.privateKeyFromPem(Zs.CERTIFICATE_VALUES.key),void 0,bt.certificateFromPem(Zs.CERTIFICATE_VALUES.cert)),t=ir.join(Jn.getHdbBasePath(),gs.LICENSE_KEY_DIR_NAME),r=ir.join(t,Zs.NATS_CERTIFICATE_PEM_NAME);await bn.exists(r)||await bn.writeFile(r,e);let n=ir.join(t,Zs.NATS_CA_PEM_NAME);await bn.exists(n)||await bn.writeFile(n,Zs.CERTIFICATE_VALUES.cert)}a(hse,"createNatsCerts");async function mse(){Oa();for await(let e of kr.search([{attribute:"is_self_signed",value:!0}]))await kr.delete(e.name);await BO()}a(mse,"renewSelfSigned");async function BO(){sse(),await vO(),Oa();let e=await PO();if(!e){yt.notify("A matching Certificate Authority and key was not found. A new CA will be created in advance, so it's available if needed.");let r=a(u=>{try{return{key:bt.privateKeyFromPem(bn.readFileSync(u)),keyPath:u}}catch(f){return yt.warn(`Failed to parse private key from ${u}:`,f.message),{key:null,keyPath:u}}},"tryToParseKey"),n=Jn.get(al.TLS),s,i;if(Array.isArray(n)){for(let u of n)if(u.privateKey){let f=r(u.privateKey);if(s=f.key,i=f.keyPath,f.key)break}}else{let u=Jn.get(al.TLS_PRIVATEKEY),f=r(u);s=f.key,i=f.keyPath}let o=ir.join(Jn.getHdbBasePath(),gs.LICENSE_KEY_DIR_NAME),c=Tk(o,i);s||(yt.warn("Unable to parse the TLS key",i,"A new key will be generated and used to create Certificate Authority"),{private_key:s}=await UO(),bn.existsSync(ir.join(o,Zs.PRIVATEKEY_PEM_NAME))&&(c=`privateKey${Sk().split("-")[0]}.pem`),await bn.writeFile(ir.join(o,c),bt.privateKeyToPem(s)));let l=await Ok(s,bt.setRsaPublicKey(s.n,s.e),!1);await Ku({name:l.subject.getField("CN").value,uses:["https"],certificate:bt.certificateToPem(l),private_key_name:c,is_authority:!0,is_self_signed:!0})}if(!await th()){let r=ug();yt.notify(`A suitable replication certificate was not found, creating new self singed cert named: ${r}`),e=e??await PO();let n=bt.certificateFromPem(e.ca.certificate),s=n.publicKey,i=await xO(bt.privateKeyFromPem(e.private_key),s,n);await Ku({name:r,uses:["https","operations","wss"],certificate:i,is_authority:!1,private_key_name:e.ca.private_key_name,is_self_signed:!0})}}a(BO,"reviewSelfSignedCert");function Nk(){let e=ese(Object.keys(gs.CONFIG_PARAM_MAP),!0),t=ir.join(Jn.getHdbBasePath(),gs.LICENSE_KEY_DIR_NAME),r=ir.join(t,Zs.PRIVATEKEY_PEM_NAME),n=ir.join(t,Zs.NATS_CERTIFICATE_PEM_NAME),s=ir.join(t,Zs.NATS_CA_PEM_NAME),i=gs.CONFIG_PARAMS,o={[i.TLS_PRIVATEKEY]:e[i.TLS_PRIVATEKEY.toLowerCase()]?e[i.TLS_PRIVATEKEY.toLowerCase()]:r};e[i.TLS_CERTIFICATE.toLowerCase()]&&(o[i.TLS_CERTIFICATE]=e[i.TLS_CERTIFICATE.toLowerCase()]),e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(o[i.TLS_CERTIFICATEAUTHORITY]=e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_CERTIFICATE]=e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]),e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_PRIVATEKEY]=e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY]=e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]),(e[i.CLUSTERING_ENABLED.toLowerCase()]||e.clustering)&&(o[i.CLUSTERING_TLS_CERTIFICATE]=e[i.CLUSTERING_TLS_CERTIFICATE.toLowerCase()]??n,o[i.CLUSTERING_TLS_CERT_AUTH]=e[i.CLUSTERING_TLS_CERT_AUTH.toLowerCase()]??s,o[i.CLUSTERING_TLS_PRIVATEKEY]=e[i.CLUSTERING_TLS_PRIVATEKEY.toLowerCase()]??r),ig.updateConfigValue(void 0,void 0,o,!1,!0)}a(Nk,"updateConfigCert");function wk(e){return e.startsWith("-----BEGIN")?e:ise(e,"utf8")}a(wk,"readPEM");var mk=og.createSecureContext;og.createSecureContext=function(e){if(!e.cert||!e.key)return mk(e);let t={...e};delete t.key,delete t.cert;let r=mk(t);return r.context.setCert(e.cert),r.context.setKey(e.key,void 0),r};var pse=yk.prototype._init;yk.prototype._init=function(e,t){pse.call(this,e,t);let r=this;this._handle.oncertcb=function(n){let s=n.servername;r._SNICallback(s,(i,o)=>{this.sni_context=o?.context||o,this.certCbDone()})}};var ol=new Map;function Ik(e,t){let r=new Map,n,s=!1;return i.initialize=o=>i.ready?i.ready:(o&&(o.secureContexts=r,o.secureContextsListeners=[]),i.ready=new Promise((c,l)=>{async function u(){try{r.clear(),ol.clear();let f=0;for await(let d of NO.system.hdb_certificate.search([])){let _=d.certificate,h=new yo(_);d.is_authority&&(h.asString=_,ol.set(h.subject,_))}for await(let d of NO.system.hdb_certificate.search([]))try{if(d.is_authority)continue;let _=e==="operations-api",h=d.is_self_signed?1:2;d.uses?.includes(e)&&(h+=1);let m=await Ck(d.private_key_name),S=d.certificate,g=new yo(S);if(ol.has(g.issuer)&&(S+=`
|