harperdb 4.5.2 → 4.5.3
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 +2 -2
- package/bin/lite.js +2 -2
- package/launchServiceScripts/launchNatsIngestService.js +2 -2
- package/launchServiceScripts/launchNatsReplyService.js +2 -2
- package/launchServiceScripts/launchUpdateNodes4-0-0.js +2 -2
- package/npm-shrinkwrap.json +75 -66
- package/package.json +2 -1
- package/server/jobs/jobProcess.js +2 -2
- package/server/threads/threadServer.js +2 -2
- package/studio/build-local/asset-manifest.json +34 -34
- package/studio/build-local/index.html +1 -1
- package/studio/build-local/static/js/{164.f552d832.chunk.js → 164.13a1ca36.chunk.js} +1 -1
- package/studio/build-local/static/js/{833.5847bc85.chunk.js → 833.0adf7923.chunk.js} +1 -1
- package/studio/build-local/static/js/86.5d79defb.chunk.js +2 -0
- package/studio/build-local/static/js/{browse-csvupload.97e20c4a.chunk.js → browse-csvupload.aceb2454.chunk.js} +1 -1
- package/studio/build-local/static/js/{browse-datatable.339fb83c.chunk.js → browse-datatable.170a2dc3.chunk.js} +1 -1
- package/studio/build-local/static/js/{browse-entitymanager.fd37a083.chunk.js → browse-entitymanager.bab20377.chunk.js} +1 -1
- package/studio/build-local/static/js/{browse-jsonviewer.f57cc39c.chunk.js → browse-jsonviewer.62991eaa.chunk.js} +1 -1
- package/studio/build-local/static/js/{custom-functions.f682aa33.chunk.js → custom-functions.fc08c212.chunk.js} +1 -1
- package/studio/build-local/static/js/{instance-cluster.e2dba73f.chunk.js → instance-cluster.b1cecd22.chunk.js} +1 -1
- package/studio/build-local/static/js/{instance-config.4e2c4644.chunk.js → instance-config.3b4c8bb2.chunk.js} +1 -1
- package/studio/build-local/static/js/{instance-logs.bcec2256.chunk.js → instance-logs.7ffbdb78.chunk.js} +1 -1
- package/studio/build-local/static/js/{instance-roles.1ad69c74.chunk.js → instance-roles.0496670c.chunk.js} +1 -1
- package/studio/build-local/static/js/{instance-status.4e190908.chunk.js → instance-status.e1d264ed.chunk.js} +1 -1
- package/studio/build-local/static/js/{instance-users-datatable.4a2c57e4.chunk.js → instance-users-datatable.74be158e.chunk.js} +1 -1
- package/studio/build-local/static/js/{instance-users-edit.ecf717d1.chunk.js → instance-users-edit.f6546639.chunk.js} +1 -1
- package/studio/build-local/static/js/{instance-users.967796d9.chunk.js → instance-users.9f8c9ce8.chunk.js} +1 -1
- package/studio/build-local/static/js/{instance.809ece1e.chunk.js → instance.7f8bc10e.chunk.js} +1 -1
- package/studio/build-local/static/js/{instances.2eb16b86.chunk.js → instances.b9528378.chunk.js} +1 -1
- package/studio/build-local/static/js/{main.2384076c.js → main.055e9e0e.js} +2 -2
- package/studio/build-local/static/js/{offline-app.86377447.chunk.js → offline-app.2b3d559a.chunk.js} +1 -1
- package/studio/build-local/static/js/{online-app.e65f9ef3.chunk.js → online-app.75d38a43.chunk.js} +1 -1
- package/studio/build-local/static/js/{organization-billing.1c318ac1.chunk.js → organization-billing.eb5f253c.chunk.js} +1 -1
- package/studio/build-local/static/js/{organization-users.36a2ed5a.chunk.js → organization-users.6e22a1a5.chunk.js} +1 -1
- package/studio/build-local/static/js/{organization.9a81d022.chunk.js → organization.42c0f784.chunk.js} +1 -1
- package/studio/build-local/static/js/{organizations.af48c8e8.chunk.js → organizations.44dd3bd2.chunk.js} +1 -1
- package/studio/build-local/static/js/{profile.190afea3.chunk.js → profile.97200a91.chunk.js} +1 -1
- package/studio/build-local/static/js/{resetPassword.50fa5b91.chunk.js → resetPassword.a3406893.chunk.js} +1 -1
- package/studio/build-local/static/js/{roles-jsonviewer.b5d5a908.chunk.js → roles-jsonviewer.b6e22a22.chunk.js} +1 -1
- package/studio/build-local/static/js/{signIn.8fbf4021.chunk.js → signIn.6aa68409.chunk.js} +1 -1
- package/studio/build-local/static/js/{signUp.459d42df.chunk.js → signUp.1df9eab1.chunk.js} +1 -1
- package/studio/build-local/static/js/{structure-reloader.ceaf6675.chunk.js → structure-reloader.b808fbf1.chunk.js} +1 -1
- package/studio/build-local/static/js/{topnav.79dbd3ab.chunk.js → topnav.64ebd91d.chunk.js} +1 -1
- package/studio/build-local/static/js/{updatePassword.b05821cb.chunk.js → updatePassword.a3c0ffcf.chunk.js} +1 -1
- package/utility/scripts/restartHdb.js +2 -2
- package/studio/build-local/static/js/708.1805e937.chunk.js +0 -2
- /package/studio/build-local/static/js/{708.1805e937.chunk.js.LICENSE.txt → 86.5d79defb.chunk.js.LICENSE.txt} +0 -0
- /package/studio/build-local/static/js/{main.2384076c.js.LICENSE.txt → main.055e9e0e.js.LICENSE.txt} +0 -0
|
@@ -16,10 +16,10 @@ Caused by:`));else if(typeof u=="object")try{n+=JSON.stringify(u)}catch{n+="Obje
|
|
|
16
16
|
`},"serialize"),compressible:!1,q:.8});$r.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()}});qD={type:"application/json",serializeStream:_f,serialize:hf,deserialize:RJ,q:.5};$r.set("*/*",qD);$r.set("",qD);a(RJ,"tryJSONParse");a(pf,"registerContentHandlers");yJ=require("fastify-plugin"),bJ=yJ(function(e,t,r){e.addHook("preSerialization",async(n,s)=>{if(s.raw.getHeader("content-type"))return;let{serializer:o,type:c}=jm(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(jm,"findBestSerializer");BD=PA.default.get(x.HTTP_COMPRESSIONTHRESHOLD);a(Ef,"serialize");a(Zo,"serializeMessage");a(vA,"asyncSerialization");a(UA,"hasAsyncSerialization");a(OJ,"streamToBuffer");NJ=["ascii","utf8","utf-8","utf16le","utf-16le","ucs2","ucs-2","base64","base64url","latin1","binary","hex"];a(wJ,"isBufferEncoding");a(IJ,"parseContentType");a(Wi,"getDeserializer");a(CJ,"deserializerUnknownType");a(PJ,"transformIterable");a(Qm,"toCsvStream")});var BA={};Ue(BA,{start:()=>kJ});function DJ(e){if(e.kind!==De.Kind.OPERATION_DEFINITION&&e.kind!==De.Kind.FRAGMENT_DEFINITION)throw new yr(`Unexpected non-executable definition type ${e.kind}.`)}function VD(e){if(typeof e!="object"||e===null)throw new pi("Request body must be an object.");if(!("query"in e))throw new pi("Request body must contain a `query` field.");if(typeof e.query!="string")throw new pi("Request body `query` field must be a string.");if("variables"in e&&(typeof e.variables!="object"||e.variables===null))throw new pi("Request body `variables` field must be an object.");if("operationName"in e&&typeof e.operationName!="string")throw new pi("Request body `operationName` field must be a string.")}function xA(e){return parseInt(e.value,10)}function YD(e){return parseFloat(e.value)}function WD(e,t,r){let n=r.get(e.name.value);return zD(n)?QD(n,t):{attribute:t,value:n}}function zD(e){return typeof e=="object"&&e!=null&&!Array.isArray(e)}function QD(e,t){return t=typeof t=="string"?[t]:t,Object.entries(e).flatMap(([r,n])=>(t=[...t,r],zD(n)?QD(n,t):{attribute:t,value:n}))}function LJ(e,t,r){switch(t=[...t,e.name.value],e.value.kind){case De.Kind.NULL:return{attribute:t,value:null};case De.Kind.INT:return{attribute:t,value:xA(e.value)};case De.Kind.FLOAT:return{attribute:t,value:YD(e.value)};case De.Kind.BOOLEAN:case De.Kind.STRING:return{attribute:t,value:e.value.value};case De.Kind.VARIABLE:return WD(e.value,t,r);case De.Kind.OBJECT:return jD(e.value,t,r);case De.Kind.LIST:case De.Kind.ENUM:default:throw new yr(`Value type, ${e.value.kind}, is not supported.`)}}function jD(e,t,r){return e.fields.flatMap(n=>LJ(n,t,r))}function MJ(e,t){switch(e.value.kind){case De.Kind.NULL:return{attribute:e.name.value,value:null};case De.Kind.INT:return{attribute:e.name.value,value:xA(e.value)};case De.Kind.FLOAT:return{attribute:e.name.value,value:YD(e.value)};case De.Kind.BOOLEAN:case De.Kind.STRING:return{attribute:e.name.value,value:e.value.value};case De.Kind.VARIABLE:return WD(e.value,e.name.value,t);case De.Kind.OBJECT:return jD(e.value,[e.name.value],t);case De.Kind.LIST:case De.Kind.ENUM:default:throw new yr(`Argument type, ${e.value.kind}, is not supported.`)}}function vJ(e,t){return e.flatMap(r=>MJ(r,t))}function Jm(e,t){return e.selections.flatMap(r=>{switch(r.kind){case De.Kind.FIELD:return r;case De.Kind.FRAGMENT_SPREAD:{let n=r.name.value,s=t.get(n);if(s==null)throw new yr(`Fragment \`${n}\` not found.`);return Jm(s.selectionSet,t)}case De.Kind.INLINE_FRAGMENT:return Jm(r.selectionSet,t)}})}function JD(e,t){return Jm(e,t).map(r=>r.selectionSet?.selections.length>0?{name:r.name.value,select:JD(r.selectionSet,t)}:r.name.value)}async function UJ(e,t,r,n){let s=fi.getMatch(e.name.value,"graphql");if(s===void 0)throw new yr(`Resource \`${e.name.value}\` not found.`);let i=s.Resource,o={select:JD(e.selectionSet,r),conditions:vJ(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 XD(e){switch(e.kind){case De.Kind.NULL:return null;case De.Kind.INT:return xA(e);case De.Kind.FLOAT:return parseFloat(e.value);case De.Kind.STRING:case De.Kind.BOOLEAN:return e.value;case De.Kind.OBJECT:return e.fields.reduce((t,r)=>({[r.name.value]:XD(r.value),...t}),{});case De.Kind.LIST:case De.Kind.ENUM:default:throw new yr(`Value type, ${e.kind}, is not supported.`)}}function xJ(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=XD(n.defaultValue)),n.type.kind===De.Kind.NON_NULL_TYPE&&!(s in t)&&i===void 0)throw new yr(`Variable $${s} is required, but not provided.`);r.set(n.variable.name.value,i??null)}return r}async function BJ(e,t,r,n){if(e.operation===De.OperationTypeNode.SUBSCRIPTION)throw new yr("Subscriptions are not supported.");if(e.operation===De.OperationTypeNode.MUTATION)throw new yr("Mutations are not supported yet.");let s=xJ(e.variableDefinitions,t),i=await Promise.all(Jm(e.selectionSet,r).map(c=>UJ(c,s,r,n))),o={data:{}};for(let[c,l]of i)o.data[c]=l;return o}async function KD({query:e,variables:t={},operationName:r},n){let s=De.parse(e),i=new Map,o=new Map;for(let u of s.definitions)if(DJ(u),u.kind===De.Kind.FRAGMENT_DEFINITION)o.set(u.name.value,u);else{if(u.name===void 0&&s.definitions.length>1)throw new yr("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 yr(`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 yr("Operation name is required when there are multiple operations in the document.");else if(c=i.get(r),c==null)throw new yr(`Operation \`${r}\` not found.`);let l=await BJ(c,t,o,n);return{status:200,headers:{"Content-Type":"application/graphql-response+json; charset=utf-8"},body:JSON.stringify(l)}}async function HJ(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 VD(r),KD(r,e)}case"POST":{let r=await Wi(e.headers.get("content-type"),!0)(e._nodeRequest);return VD(r),KD(r,e)}default:throw new pi("Method Not Allowed",405,{Allow:"GET, POST"})}}function kJ(e){e.server.http(async(t,r)=>{if(!t.url.startsWith("/graphql"))return r(t);try{return await HJ(t)}catch(n){logger.error(n);let s=t.headers.get("accept")??"application/graphql-response+json";switch(s){case"application/json":{if(n instanceof pi)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/json",...n.headers}};if(n instanceof De.GraphQLError)return{status:200,body:JSON.stringify({errors:[n]}),headers:{"Content-Type":"application/json"}};if(n instanceof yr)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 pi)return{status:n.statusCode,body:JSON.stringify({errors:[{message:n.message}]}),headers:{"Content-Type":"application/graphql-response+json",...n.headers}};if(n instanceof De.GraphQLError)return{status:400,body:JSON.stringify({errors:[n]}),headers:{"Content-Type":"application/graphql-response+json"}};if(n instanceof yr)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 De,yr,pi,ZD=be(()=>{De=M(require("graphql"));zi();zl();a(DJ,"assertExecutableDefinitionNode");a(VD,"assertRequestParams");a(xA,"processIntValueNode");a(YD,"processFloatValueNode");a(WD,"processVariableNode");a(zD,"isObject");a(QD,"transformObjectIntoQueryCondition");a(LJ,"processObjectFieldNode");a(jD,"processObjectValueNode");a(MJ,"processArgumentNode");a(vJ,"buildConditionsQuery");a(Jm,"fillInFragments");a(JD,"buildSelectQuery");a(UJ,"processFieldNode");a(XD,"processConstValueNode");a(xJ,"resolveVariables");a(BJ,"executeOperation");a(KD,"resolver");yr=class extends Error{static{a(this,"GraphQLQueryingError")}},pi=class extends Error{static{a(this,"HTTPError")}statusCode;headers;constructor(t,r=400,n={}){super(t),this.statusCode=r,this.headers=n}};a(HJ,"graphqlQueryingHandler");a(kJ,"start")});var gi=C((FAe,rL)=>{"use strict";var tL=ae(),eL=(H(),P($)),jl=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Ei=require("joi"),ea={schema_format:{pattern:jl,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},FJ=Ei.alternatives(Ei.string().min(1).max(ea.schema_length.maximum).pattern(jl).messages({"string.pattern.base":"{:#label} "+ea.schema_format.message}),Ei.number(),Ei.array()).required(),GJ=Ei.alternatives(Ei.string().min(1).max(ea.schema_length.maximum).pattern(jl).messages({"string.pattern.base":"{:#label} "+ea.schema_format.message}),Ei.number()),qJ=Ei.alternatives(Ei.string().min(1).max(ea.schema_length.maximum).pattern(jl).messages({"string.pattern.base":"{:#label} "+ea.schema_format.message}),Ei.number()).required();function $J(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>ea.schema_length.maximum?`'${e}' maximum of 250 characters`:jl.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a($J,"checkValidTable");function VJ(e,t){return tL.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(VJ,"validateSchemaExists");function KJ(e,t){let r=t.state.ancestors[0].schema;return tL.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(KJ,"validateTableExists");function YJ(e,t){return e.toLowerCase()===eL.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${eL.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(YJ,"validateSchemaName");rL.exports={common_validators:ea,schema_regex:jl,hdb_schema_table:FJ,validateSchemaExists:VJ,validateTableExists:KJ,validateSchemaName:YJ,checkValidTable:$J,hdb_database:GJ,hdb_table:qJ}});var nt=C((qAe,nL)=>{"use strict";var fn=require("validate.js");fn.validators.type=function(e,t,r,n){return e===null||typeof e>"u"||fn.validators.type.checks[t](e)?null:` must be a '${t}' value`};fn.validators.type.checks={Object:a(function(e){return fn.isObject(e)&&!fn.isArray(e)},"Object"),Array:fn.isArray,Integer:fn.isInteger,Number:fn.isNumber,String:fn.isString,Date:fn.isDate,Boolean:a(function(e){return typeof e=="boolean"},"Boolean")};fn.validators.hasValidFileExt=function(e,t){return fn.isString(e)?e===""?"can't be blank":t.filter(r=>e.endsWith(r)).length>0?null:`must include one of the following valid file extensions - '${t.join("', '")}'`:null};nL.exports={validateObject:WJ,validateObjectAsync:zJ,validateBySchema:QJ};function WJ(e,t){if(!e||!t)return new Error("validateObject parameters were null");let r=fn(e,t,{format:"flat"});return r?new Error(r):null}a(WJ,"validateObject");async function zJ(e,t){if(!e||!t)return new Error("validateObject parameters were null");try{await fn.async(e,t,{format:"flat"})}catch(r){let n=r.join(",");return new Error(n)}return null}a(zJ,"validateObjectAsync");function QJ(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(QJ,"validateBySchema")});var kA=C((VAe,iL)=>{var{hdb_table:jJ,hdb_database:sL}=gi(),JJ=nt(),HA=require("joi"),XJ={undefined:"undefined",null:"null"},ZJ=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||XJ[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"),e4=HA.object({database:sL,schema:sL,table:jJ,records:HA.array().items(HA.object().custom(ZJ)).required()});iL.exports=function(e){return JJ.validateBySchema(e,e4)}});var aL=C((YAe,oL)=>{"use strict";var FA=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")}};oL.exports=FA});var lL=C((zAe,cL)=>{"use strict";var GA=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};cL.exports=GA});var hL={};Ue(hL,{HAS_EXPIRATION:()=>ep,HAS_RESIDENCY_ID:()=>zA,HAS_STRUCTURE_UPDATE:()=>np,LAST_TIMESTAMP_PLACEHOLDER:()=>Rf,LOCAL_TIMESTAMP:()=>t4,METADATA:()=>gf,NEW_TIMESTAMP_PLACEHOLDER:()=>dL,NO_TIMESTAMP:()=>qA,PENDING_LOCAL_TIME:()=>QA,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>WA,RecordEncoder:()=>YA,TIMESTAMP_ASSIGN_LAST:()=>n4,TIMESTAMP_ASSIGN_NEW:()=>fL,TIMESTAMP_ASSIGN_PREVIOUS:()=>_L,TIMESTAMP_PLACEHOLDER:()=>Xm,TIMESTAMP_RECORD_PREVIOUS:()=>$A,handleLocalTimeForGets:()=>sp,recordUpdater:()=>jA,removeEntry:()=>mc});function i4(){return Af[0]=Af[0]^64,r4.getFloat64(0)}function sp(e,t){let r=e.getEntry;e.readCount=0,e.cachePuts=!1,e.rootStore=t,e.encoder.rootStore=t,e.getEntry=function(o,c){e.readCount++;let l=r.call(this,o,c),u=l?.value,f=u?.[gf];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?.[gf]>=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[gf];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,fc.push(new WeakRef(this))),c.call(this)},o.prototype.done=function(){if(l.call(this),this.isDone)for(let u=0;u<fc.length;u++){let f=fc[u].deref();(!f||f.isDone||f.isCommitted)&&fc.splice(u--,1)}},o.prototype.done.isTracked=!0}return e}function jA(e,t,r){return function(n,s,i,o,c=-1,l,u,f="put",d,h){d||l==null?Jl=i?.localTime?$A|_L:qA:Jl=l?i?.localTime?$A|16384:fL|16384:qA;let _=u?.expiresAt;if(_>=0&&(c|=ep),Tf=c,VA=_,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let m={version:o,instructedWrite:Jl>0},S,g=0;try{let R=i?.residencyId,E=u?.residencyId;E&&(KA=E,Tf|=zA,g|=pc),R!==E&&(g|=Ec,R||(R=0)),c&ep&&(g|=bf),u?.originatingOperation&&(g|=yf),d&&(m.ifVersion=S=i?.version??null),i&&i.value&&i.metadataFlags&Mn&&(r.getBinaryFast(i.localTime)||ta(i.value));let A;if(s!==void 0&&(A=rp(()=>e.put(n,s,m),n,e.rootStore),_c&&(g|=Mn)),l){let N=u?.user?.username;if(h&&(rp(()=>e.encoder.encode(h),n,e.rootStore),_c&&(g|=Mn)),e.encoder.hasStructureUpdate&&(g|=np,e.encoder.hasStructureUpdate=!1),d&&i?.localTime){let v=i?.localTime,F=r.get(v);if(F){let q=Ot(F).previousLocalTime;return A=r.put(v,Xl(o,t,n,q,u?.nodeId??server.replication.getThisNodeId(r)??0,N,f,Sf,g,E,R,_),{ifVersion:S}),A}}A=r.put(s===void 0?dL:Rf,Xl(o,t,n,i?.localTime?1:0,u?.nodeId??server.replication?.getThisNodeId(r)??0,N,f,Sf,g,E,R,_,u?.originatingOperation),{append:f!=="invalidate",instructedWrite:!0,ifVersion:S})}return A}catch(R){throw R.message+=" id: "+n+" options: "+m,R}}}function mc(e,t,r){if(t)return t.value&&t.metadataFlags&Mn&&!e.auditStore.getBinaryFast(t.localTime)&&ta(t.value),e.remove(t.key,r)}var uL,Zm,Xm,Rf,WA,dL,t4,gf,Af,r4,qA,fL,n4,_L,$A,ep,zA,QA,np,s4,Sf,Jl,Tf,VA,KA,YA,fc,Zl=be(()=>{uL=require("msgpackr");Qi();Zm=M(J());as();as();Xm=new Uint8Array([1,1,1,1,4,64,0,0]),Rf=new Uint8Array([1,1,1,1,1,0,0,0]),WA=new Uint8Array([1,1,1,1,3,64,0,0]),dL=new Uint8Array([1,1,1,1,0,64,0,0]),t4=Symbol("local-timestamp"),gf=Symbol("metadata"),Af=new Uint8Array(8),r4=new DataView(Af.buffer,0,8),qA=0,fL=0,n4=1,_L=3,$A=4,ep=16,zA=32,QA=1,np=256,Jl=0,Tf=-1,VA=-1,KA=0,YA=class extends uL.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(s,i){if(Jl||Tf>=0){let o=0,c=Jl;c&&(o+=8,Jl=0);let l=Tf,u=VA,f=KA;l>=0&&(o+=4,Tf=-1,u>=0&&(o+=8,VA=-1),f&&(o+=4,KA=0));let d=s4=r.call(this,s,i|2048|o);Sf=d.subarray((d.start||0)+o,d.end);let h=d.start||0;return c&&(Xm[4]=c,Xm[5]=c>>8,d.set(Xm,h),h+=8),_c&&(l|=Mn),l>=0&&((d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setUint32(h,l|tp<<24),h+=4,u>=0&&((d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setFloat64(h,u),h+=8),f&&(d.dataView||(d.dataView=new DataView(d.buffer,d.byteOffset,d.byteLength))).setUint32(h,f)),d}else return Sf=r.call(this,s,i),Sf};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(Af,0,c),c+=8;else for(let h=0;h<8;h++)Af[h]=t[c++];l=i4(),i=t[c]}let u,f;i<32&&(i===tp?(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&ep&&(u=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8),o&zA&&(f=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4));let d=hc(()=>r?.valueAsBuffer?t.subarray(c,s):super.decode(t.subarray(c,s),s-c),this.rootStore);return{localTime:l,value:d,[gf]:o,expiresAt:u,residencyId:f}}return r?.valueAsBuffer?t:hc(()=>super.decode(t,r),this.rootStore)}catch(c){return Zm.error("Error decoding record",c,"data: "+t.slice(0,40).toString("hex")),null}}};a(i4,"getTimestamp");a(sp,"handleLocalTimeForGets");fc=[];setInterval(()=>{for(let e=0;e<fc.length;e++){let t=fc[e].deref();!t||t.isDone||t.isCommitted?fc.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(Zm.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):Zm.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(jA,"recordUpdater");a(mc,"removeEntry")});var Of=C((eRe,pL)=>{"use strict";var mL=ce(),o4=(H(),P($)),{RecordEncoder:a4}=(Zl(),P(hL));mL.initSync();var c4=mL.get(o4.CONFIG_PARAMS.STORAGE_CACHING)!==!1,JA=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=c4&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:a4})}};pL.exports=JA});var Nf=C((rRe,EL)=>{"use strict";var vn=ce(),cs=(H(),P($));vn.initSync();var ip=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=vn.get(cs.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||vn.get(cs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||vn.get(cs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",vn.get(cs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=vn.get(cs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),vn.get(cs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=vn.get(cs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),vn.get(cs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=vn.get(cs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),vn.get(cs.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=vn.get(cs.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=vn.get(cs.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};EL.exports=ip;ip.MAX_DBS=1e4});var dt=C((sRe,wL)=>{"use strict";var ZA=require("lmdb"),vs=require("fs-extra"),Un=require("path"),op=cn(),TL=J(),_n=Cn().LMDB_ERRORS_ENUM,ap=lL(),eR=Of(),AL=Nf(),ra=Ut(),gL=(H(),P($)),{table:l4,resetDatabases:u4}=(ve(),P(it)),SL=ce(),Us=ra.INTERNAL_DBIS_NAME,RL=ra.DBI_DEFINITION_NAME,d4="data.mdb",f4="lock.mdb",wf=".mdb",_4="-lock",XA=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=ls(t,r),this.key_type=this.dbi[ra.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[ra.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new ZA.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function cp(e,t){if(e===void 0)throw new Error(_n.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(_n.ENV_NAME_REQUIRED)}a(cp,"pathEnvNameValidation");async function tR(e,t,r=!0){try{await vs.access(e)}catch(n){throw n.code==="ENOENT"?new Error(_n.INVALID_BASE_PATH):n}try{let n=Un.join(e,t+wf);return await vs.access(n,vs.constants.R_OK|vs.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await vs.access(Un.join(e,t,d4),vs.constants.R_OK|vs.constants.F_OK),Un.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(_n.INVALID_ENVIRONMENT)}else throw new Error(_n.INVALID_ENVIRONMENT);throw n}}a(tR,"validateEnvironmentPath");function lp(e,t){if(op.validateEnv(e),t===void 0)throw new Error(_n.DBI_NAME_REQUIRED)}a(lp,"validateEnvDBIName");async function h4(e,t,r=!1,n=!1){cp(e,t);let s=Un.basename(e);t=t.toString();let i=SL.get(gL.CONFIG_PARAMS.DATABASES);i||SL.setProperty(gL.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await tR(e,t,n),yL(e,t,r)}catch(o){if(o.message===_n.INVALID_ENVIRONMENT){let c=Un.join(e,t);await vs.mkdirp(n?c:e);let l=new AL(n?c:c+wf,!1),u=ZA.open(l);u.dbis=Object.create(null);let f=new eR(!1);u.openDB(Us,f),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let d=rR(e,t,r);return u[ra.ENVIRONMENT_NAME_KEY]=d,global.lmdb_map[d]=u,u}throw o}}a(h4,"createEnvironment");async function m4(e,t,r,n=!0){cp(e,t),t=t.toString();let s=Un.join(e,t);return l4({table:t,database:Un.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(m4,"copyEnvironment");async function yL(e,t,r=!1){cp(e,t),t=t.toString();let n=rR(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 tR(e,t),i=Un.join(e,t+wf),o=s!=i,c=new AL(s,o),l=ZA.open(c);l.dbis=Object.create(null);let u=OL(l);for(let f=0;f<u.length;f++)ls(l,u[f]);return l[ra.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(yL,"openEnvironment");async function p4(e,t,r=!1){cp(e,t),t=t.toString();let n=Un.join(e,t+wf),s=await tR(e,t);if(global.lmdb_map!==void 0){let i=rR(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await bL(o),delete global.lmdb_map[i]}}await vs.remove(s),await vs.remove(s===n?s+_4:Un.join(Un.dirname(s),f4))}a(p4,"deleteEnvironment");async function bL(e){op.validateEnv(e);let t=e[ra.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(bL,"closeEnvironment");function rR(e,t,r=!1){let s=`${Un.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(rR,"getCachedEnvironmentName");function E4(e){op.validateEnv(e);let t=Object.create(null),r=ls(e,Us);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==Us)try{t[n]=Object.assign(new ap,s)}catch{TL.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(E4,"listDBIDefinitions");function OL(e){op.validateEnv(e);let t=[],r=ls(e,Us);for(let{key:n}of r.getRange({start:!1}))n!==Us&&t.push(n);return t}a(OL,"listDBIs");function g4(e,t){let n=ls(e,Us).getEntry(t),s=new ap;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{TL.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(g4,"getDBIDefinition");function NL(e,t,r,n=!r){if(lp(e,t),t=t.toString(),t===Us)throw new Error(_n.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return ls(e,t)}catch(s){if(s.message===_n.DBI_DOES_NOT_EXIST){let i=new eR(r,n===!0),o=e.openDB(t,i),c=new ap(r===!0,n);return o[RL]=c,ls(e,Us).putSync(t,c),e.dbis[t]=o,o}throw s}}a(NL,"createDBI");function ls(e,t){if(lp(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==Us?r=g4(e,t):r=new ap,r===void 0)throw new Error(_n.DBI_DOES_NOT_EXIST);let n;try{let s=new eR(r.dup_sort,r.useVersions);if(n=e.openDB(t,s),n.db===void 0)throw new Error("MDB_NOTFOUND")}catch(s){throw s.message.includes("MDB_NOTFOUND")===!0?new Error(_n.DBI_DOES_NOT_EXIST):s}return n[RL]=r,e.dbis[t]=n,n}a(ls,"openDBI");function S4(e,t){lp(e,t),t=t.toString();let r=ls(e,t),n=r.getStats();return r[ra.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(S4,"statDBI");async function T4(e,t){try{let r=Un.join(e,t+wf);return(await vs.stat(r)).size}catch{throw new Error(_n.INVALID_ENVIRONMENT)}}a(T4,"environmentDataSize");function A4(e,t){if(lp(e,t),t=t.toString(),t===Us)throw new Error(_n.CANNOT_DROP_INTERNAL_DBIS_NAME);ls(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],ls(e,Us).removeSync(t)}a(A4,"dropDBI");function R4(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{ls(e,i)}catch(o){if(o.message===_n.DBI_DOES_NOT_EXIST)NL(e,i,i!==t,i===t),n=!0;else throw o}}n&&u4()}a(R4,"initializeDBIs");wL.exports={openDBI:ls,openEnvironment:yL,createEnvironment:h4,listDBIs:OL,listDBIDefinitions:E4,createDBI:NL,dropDBI:A4,statDBI:S4,deleteEnvironment:p4,initializeDBIs:R4,TransactionCursor:XA,environmentDataSize:T4,copyEnvironment:m4,closeEnvironment:bL}});var CL=C((oRe,IL)=>{"use strict";var nR=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};IL.exports=nR});var DL=C((cRe,PL)=>{"use strict";var sR=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}};PL.exports=sR});var ML=C((uRe,LL)=>{"use strict";var iR=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};LL.exports=iR});var Sc=C((mRe,xL)=>{"use strict";var y4=dt(),b4=CL(),O4=DL(),N4=ML(),Si=cn(),If=Cn().LMDB_ERRORS_ENUM,w4=Ut(),ji=(H(),P($)),I4=ae(),C4=require("uuid"),fRe=require("lmdb"),{handleHDBError:P4,hdb_errors:D4}=he(),{OVERFLOW_MARKER:_Re,MAX_SEARCH_KEY_LENGTH:hRe}=w4,vL=ce();vL.initSync();var up=vL.get(ji.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),oR=ji.TIME_STAMP_NAMES_ENUM.CREATED_TIME,gc=ji.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function L4(e,t,r,n,s=Si.getNextMonotonicTime()){uR(e,t,r,n),aR(e,t,r);let i=new b4,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l];UL(u,!0,s);let f=M4(e,t,r,u),d=u[t];o.push(f),c.push(d)}return cR(o,c,n,i,s)}a(L4,"insertRecords");function M4(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][ji.FUNC_VAL],n[o]=c)}let l=Si.getIndexedValues(c),u=e.dbis[o];if(l){up&&u.prefetch(l.map(f=>({key:f,value:s})),dp);for(let f=0,d=l.length;f<d;f++)u.put(l[f],s)}}up&&e.dbis[t].prefetch([s],dp),e.dbis[t].put(s,n,n[gc])})}a(M4,"insertRecord");function v4(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(v4,"removeSkippedRecords");function UL(e,t,r){let n=r>0;(n||!Number.isInteger(e[gc]))&&(e[gc]=r||(r=Si.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[oR]))&&(e[oR]=r||Si.getNextMonotonicTime()):delete e[oR]}a(UL,"setTimestamps");function aR(e,t,r){r.indexOf(ji.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(ji.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(ji.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(ji.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),y4.initializeDBIs(e,t,r)}a(aR,"initializeTransaction");async function U4(e,t,r,n,s=Si.getNextMonotonicTime()){uR(e,t,r,n),aR(e,t,r);let i=new O4,o=[],c=[],l=[];for(let u=0;u<n.length;u++){let f=n[u],d=f[t],h;try{h=lR(e,t,f,d,i,!0,s)}catch{i.skipped_hashes.push(d),o.push(u);continue}c.push(h),l.push(d)}return cR(c,l,n,i,s,o)}a(U4,"updateRecords");async function x4(e,t,r,n,s=Si.getNextMonotonicTime()){try{uR(e,t,r,n)}catch(l){throw P4(l,l.message,D4.HTTP_STATUS_CODES.BAD_REQUEST)}aR(e,t,r);let i=new N4,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l],f;I4.isEmpty(u[t])?(f=C4.v4(),u[t]=f):f=u[t];let d=lR(e,t,u,f,i,!1,s);o.push(d),c.push(f)}return cR(o,c,n,i,s)}a(x4,"upsertRecords");async function cR(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||Si.getNextMonotonicTime(),v4(r,i),n}a(cR,"finalizeWrite");function lR(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(UL(r,!f,o),Number.isInteger(r[gc])&&u[gc]>r[gc])return!1;f&&s.original_records.push(u);let d,h=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 A=S([[u]]);Array.isArray(A)&&(S=A[0][ji.FUNC_VAL],r[m]=S)}if(S===R)continue;let E=Si.getIndexedValues(R);if(E){up&&g.prefetch(E.map(A=>({key:A,value:n})),dp);for(let A=0,N=E.length;A<N;A++)g.remove(E[A],n)}if(E=Si.getIndexedValues(S),E){up&&g.prefetch(E.map(A=>({key:A,value:n})),dp);for(let A=0,N=E.length;A<N;A++)g.put(E[A],n)}}let _={...u,...r};c.put(n,_,_[gc])},"do_put");return l?d=c.ifVersion(n,l.version,h):d=c.ifNoExists(n,h),d.then(_=>_?!0:lR(e,t,r,n,s,i,o))}a(lR,"updateUpsertRecord");function B4(e,t,r){if(Si.validateEnv(e),t===void 0)throw new Error(If.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(If.WRITE_ATTRIBUTES_REQUIRED):new Error(If.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(B4,"validateBasic");function uR(e,t,r,n){if(B4(e,t,r),!Array.isArray(n))throw n===void 0?new Error(If.RECORDS_REQUIRED):new Error(If.RECORDS_MUST_BE_ARRAY)}a(uR,"validateWrite");function dp(){}a(dp,"noop");xL.exports={insertRecords:L4,updateRecords:U4,upsertRecords:x4}});var Ji=C((ERe,H4)=>{H4.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 HL=C((gRe,BL)=>{"use strict";var k4=require("uuid"),dR=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||k4.v4(),this.schema_table=`${this.schema}.${this.table}`}};BL.exports=dR});var fp=C((TRe,kL)=>{"use strict";var F4=HL(),fR=class extends F4{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}};kL.exports=fR});var GL=C((RRe,FL)=>{"use strict";FL.exports=q4;var G4="inserted";function q4(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===G4?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(q4,"returnObject")});var _p=C((ORe,$L)=>{"use strict";var $4=(H(),P($)),_R=dt(),V4=Sc(),{getSystemSchemaPath:K4,getSchemaPath:Y4}=Et(),bRe=Ji(),{validateBySchema:W4}=nt(),Cf=require("joi"),z4=fp(),Q4=GL(),{handleHDBError:j4,hdb_errors:J4,ClientError:X4}=he(),qL=ae(),{HTTP_STATUS_CODES:Z4}=J4,e3="inserted";$L.exports=t3;async function t3(e){let t=W4(e,Cf.object({database:Cf.string(),schema:Cf.string(),table:Cf.string().required(),attribute:Cf.string().required()}));if(t)throw new X4(t.message);let r=!e.skip_table_check&&qL.checkGlobalSchemaTable(e.schema,e.table);if(r)throw j4(new Error,r,Z4.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=qL.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 z4(e.schema,e.table,e.attribute,e.id);try{let i=await _R.openEnvironment(Y4(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}`);_R.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await _R.openEnvironment(K4(),$4.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await V4.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_attribute_attributes,[s]);return Q4(e3,c,{records:[s]},l)}catch(i){throw i}}a(t3,"lmdbCreateAttribute")});var Pf=C((IRe,KL)=>{"use strict";var Xi=ae(),VL=J(),wRe=kA(),{getDatabases:r3}=(ve(),P(it)),{ClientError:Tc}=he();KL.exports=n3;function n3(e){if(Xi.isEmpty(e))throw new Tc("invalid update parameters defined.");if(Xi.isEmptyOrZeroLength(e.schema))throw new Tc("invalid schema specified.");if(Xi.isEmptyOrZeroLength(e.table))throw new Tc("invalid table specified.");if(!Array.isArray(e.records))throw new Tc("records must be an array");let t=r3()[e.schema]?.[e.table];if(Xi.isEmpty(t))throw new Tc(`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&&Xi.isEmptyOrZeroLength(o[r]))throw VL.error("a valid hash attribute must be provided with update record:",o),new Tc("a valid hash attribute must be provided with update record, check log for more info");if(!Xi.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw VL.error(`a valid hash value must be provided with ${e.operation} record:`,o),new Tc(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!Xi.isEmpty(o[r])&&o[r]!==""&&n.has(Xi.autoCast(o[r]))&&(o.skip=!0),n.add(Xi.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(n3,"insertUpdateValidate")});var WL=C((PRe,YL)=>{"use strict";var hR=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};YL.exports=hR});var jL=C((LRe,QL)=>{"use strict";var mR=dt(),s3=J(),zL=Cn().LMDB_ERRORS_ENUM;QL.exports=i3;async function i3(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 mR.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==zL.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await mR.closeEnvironment(global.lmdb_map[n]),await mR.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==zL.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){s3.error(t)}}a(i3,"cleanLMDBMap")});var lM=C((URe,cM)=>{"use strict";var pR=require("recursive-iterator"),o3=require("alasql"),ER=require("clone"),JL=ae(),{handleHDBError:XL,hdb_errors:a3}=he(),{HDB_ERROR_MSGS:ZL,HTTP_STATUS_CODES:eM}=a3,{getDatabases:c3}=(ve(),P(it)),l3=["DISTINCT_ARRAY"],tM=Symbol("validateTables"),gR=Symbol("validateTable"),vRe=Symbol("getAllColumns"),rM=Symbol("validateAllColumns"),hp=Symbol("findColumn"),nM=Symbol("validateOrderBy"),Df=Symbol("validateSegment"),SR=Symbol("validateColumn"),sM=Symbol("setColumnsForTable"),iM=Symbol("checkColumnsForAsterisk"),oM=Symbol("validateGroupBy"),aM=Symbol("hasColumns"),TR=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[tM](),this[iM](),this[rM]()}[tM](){if(this[aM]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[gR](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[gR](t.table)})}}[aM](){let t=!1,r=new pR(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[gR](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=c3();if(!r[t.databaseid])throw XL(new Error,ZL.SCHEMA_NOT_FOUND(t.databaseid),eM.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw XL(new Error,ZL.TABLE_NOT_FOUND(t.databaseid,t.tableid),eM.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=ER(s);i.table=ER(t),this.attributes.push(i)})}[hp](t){return this.attributes.filter(r=>t.tableid?(r.table.as===t.tableid||r.table.tableid===t.tableid)&&r.attribute===t.columnid:r.attribute===t.columnid)}[iM](){let t=new pR(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[sM](r.tableid)}[sM](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new o3.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[rM](){this[Df](this.statement.columns,!1),this[Df](this.statement.joins,!1),this[Df](this.statement.where,!1),this[oM](this.statement.group,!1),this[Df](this.statement.order,!0)}[Df](t,r){if(!t)return;let n=new pR(t),s=[];for(let{node:i,path:o}of n)!JL.isEmpty(i)&&!JL.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[nM](i):s.push(this[SR](i)));return s}[oM](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&l3.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=ER(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[hp](n)[0];s&&r.push(s)}}}),this.statement.group.forEach(n=>{let s=null;if(!n.columnid)r.forEach((i,o)=>{if(i.toString()===n.toString()){s=i,r.splice(o,1);return}});else{let i=this[hp](n);if(!i||i.length===0)throw`unknown column '${n.toString()}' in group by`;if(i.length>1)throw`ambiguously defined column '${n.toString()}' in group by`;r.forEach((o,c)=>{if(o.attribute===i[0].attribute&&o.table.tableid===i[0].table.tableid){s=o,r.splice(c,1);return}})}if(!s)throw`group by column '${n.toString()}' must be in select`}),r.length>0)throw`select column '${r[0].attribute?r[0].attribute:r[0].toString()}' must be in group by`}[nM](t){let r=this.statement.columns.filter(n=>n.as===t.columnid);if(r.length>1)throw`ambiguous column reference ${(t.tableid?t.tableid+".":"")+t.columnid} in order by`;r.length===0&&this[SR](t)}[SR](t){let r=this[hp](t),n=(t.tableid?t.tableid+".":"")+t.columnid;if(r.length===0)throw`unknown column ${n}`;if(r.length>1)throw`ambiguous column reference ${n}`;return r[0]}};cM.exports=TR});var _M=C((BRe,fM)=>{"use strict";var uM=require("lodash"),Lf=require("mathjs"),u3=require("jsonata"),dM=ae();fM.exports={distinct_array:a(e=>Array.isArray(e)&&e.length>1?uM.uniqWith(e,uM.isEqual):e,"distinct_array"),searchJSON:d3,mad:Mf.bind(null,Lf.mad),mean:Mf.bind(null,Lf.mean),mode:Mf.bind(null,Lf.mode),prod:Mf.bind(null,Lf.prod),median:Mf.bind(null,Lf.median)};function Mf(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(Mf,"aggregateFunction");function d3(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(dM.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),dM.isEmpty(this.__ala__.res[r])){let n=u3(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(d3,"searchJSON")});var mM=C((kRe,hM)=>{"use strict";var Xt=require("moment"),AR="YYYY-MM-DDTHH:mm:ss.SSSZZ";Xt.suppressDeprecationWarnings=!0;hM.exports={current_date:a(()=>Xt().utc().format("YYYY-MM-DD"),"current_date"),current_time:a(()=>Xt().utc().format("HH:mm:ss.SSS"),"current_time"),extract:a((e,t)=>{switch(t.toLowerCase()){case"year":return Xt(e).utc().format("YYYY");case"month":return Xt(e).utc().format("MM");case"day":return Xt(e).utc().format("DD");case"hour":return Xt(e).utc().format("HH");case"minute":return Xt(e).utc().format("mm");case"second":return Xt(e).utc().format("ss");case"millisecond":return Xt(e).utc().format("SSS");default:break}},"extract"),date:a(e=>Xt(e).utc().format(AR),"date"),date_format:a((e,t)=>Xt(e).utc().format(t),"date_format"),date_add:a((e,t,r)=>Xt(e).utc().add(t,r).valueOf(),"date_add"),date_sub:a((e,t,r)=>Xt(e).utc().subtract(t,r).valueOf(),"date_sub"),date_diff:a((e,t,r)=>{let n=Xt(e).utc(),s=Xt(t).utc();return r?n.diff(s,r,!0):n.diff(s)},"date_diff"),now:a(()=>Xt().utc().valueOf(),"now"),get_server_time:a(()=>Xt().format(AR),"get_server_time"),offset_utc:a((e,t)=>Xt(e).utc().utcOffset(t).format(AR),"offset_utc")}});var SM=C((GRe,gM)=>{"use strict";var f3=require("@turf/area"),_3=require("@turf/length"),h3=require("@turf/circle"),m3=require("@turf/difference"),p3=require("@turf/distance"),E3=require("@turf/boolean-contains"),g3=require("@turf/boolean-equal"),S3=require("@turf/boolean-disjoint"),T3=require("@turf/helpers"),pM=(H(),P($)),qe=ae(),Zi=J();gM.exports={geoArea:A3,geoLength:R3,geoCircle:y3,geoDifference:b3,geoDistance:EM,geoNear:O3,geoContains:N3,geoEqual:w3,geoCrosses:I3,geoConvert:C3};function A3(e){if(qe.isEmpty(e))return NaN;typeof e=="string"&&(e=qe.autoCastJSON(e));try{return f3.default(e)}catch(t){return Zi.trace(t,e),NaN}}a(A3,"geoArea");function R3(e,t){if(qe.isEmpty(e))return NaN;typeof e=="string"&&(e=qe.autoCastJSON(e));try{return _3.default(e,{units:t||"kilometers"})}catch(r){return Zi.trace(r,e),NaN}}a(R3,"geoLength");function y3(e,t,r){if(qe.isEmpty(e))return NaN;if(qe.isEmpty(t))return NaN;typeof e=="string"&&(e=qe.autoCastJSON(e));try{return h3.default(e,t,{units:r||"kilometers"})}catch(n){return Zi.trace(n,e,t),NaN}}a(y3,"geoCircle");function b3(e,t){if(qe.isEmpty(e))return NaN;if(qe.isEmpty(t))return NaN;typeof e=="string"&&(e=qe.autoCastJSON(e)),typeof t=="string"&&(t=qe.autoCastJSON(t));try{return m3(e,t)}catch(r){return Zi.trace(r,e,t),NaN}}a(b3,"geoDifference");function EM(e,t,r){if(qe.isEmpty(e))return NaN;if(qe.isEmpty(t))return NaN;typeof e=="string"&&(e=qe.autoCastJSON(e)),typeof t=="string"&&(t=qe.autoCastJSON(t));try{return p3.default(e,t,{units:r||"kilometers"})}catch(n){return Zi.trace(n,e,t),NaN}}a(EM,"geoDistance");function O3(e,t,r,n){if(qe.isEmpty(e)||qe.isEmpty(t))return!1;if(qe.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=qe.autoCastJSON(e)),typeof t=="string"&&(t=qe.autoCastJSON(t)),isNaN(r))throw new Error("distance must be a number");try{return EM(e,t,n)<=r}catch(s){return Zi.trace(s,e,t),!1}}a(O3,"geoNear");function N3(e,t){if(qe.isEmpty(e)||qe.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=qe.autoCastJSON(e)),typeof t=="string"&&(t=qe.autoCastJSON(t));try{return E3.default(e,t)}catch(r){return Zi.trace(r,e,t),!1}}a(N3,"geoContains");function w3(e,t){if(qe.isEmpty(e)||qe.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=qe.autoCastJSON(e)),typeof t=="string"&&(t=qe.autoCastJSON(t));try{return g3.default(e,t)}catch(r){return Zi.trace(r,e,t),!1}}a(w3,"geoEqual");function I3(e,t){if(qe.isEmpty(e)||qe.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=qe.autoCastJSON(e)),typeof t=="string"&&(t=qe.autoCastJSON(t));try{return!S3.default(e,t)}catch(r){return Zi.trace(r,e,t),!1}}a(I3,"geoCrosses");function C3(e,t,r){if(qe.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if(qe.isEmpty(t))throw new Error("geo_type is required");if(qe.isEmpty(pM.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(pM.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=qe.autoCastJSON(e)),T3[t](e,r)}a(C3,"geoConvert")});var mp=C(($Re,TM)=>{var Ac=_M(),xn=mM(),Ti=SM();TM.exports=e=>{e.aggr.mad=e.aggr.MAD=Ac.mad,e.aggr.mean=e.aggr.MEAN=Ac.mean,e.aggr.mode=e.aggr.MODE=Ac.mode,e.aggr.prod=e.aggr.PROD=Ac.prod,e.aggr.median=e.aggr.MEDIAN=Ac.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=Ac.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=Ac.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=xn.current_date,e.fn.current_time=e.fn.CURRENT_TIME=xn.current_time,e.fn.extract=e.fn.EXTRACT=xn.extract,e.fn.date=e.fn.DATE=xn.date,e.fn.date_format=e.fn.DATE_FORMAT=xn.date_format,e.fn.date_add=e.fn.DATE_ADD=xn.date_add,e.fn.date_sub=e.fn.DATE_SUB=xn.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=xn.date_diff,e.fn.now=e.fn.NOW=xn.now,e.fn.offset_utc=e.fn.OFFSET_UTC=xn.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=xn.get_server_time,e.fn.getdate=e.fn.GETDATE=xn.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=xn.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=Ti.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=Ti.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=Ti.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=Ti.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=Ti.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=Ti.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=Ti.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=Ti.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=Ti.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=Ti.geoNear}});var bM=C((VRe,yM)=>{"use strict";var vf=require("lodash"),hn=require("alasql");hn.options.cache=!1;var P3=mp(),AM=require("clone"),pp=require("recursive-iterator"),Be=J(),ze=ae(),eu=Bn(),D3=(H(),P($)),{hdb_errors:L3}=he(),{getDatabases:RM}=(ve(),P(it)),M3="IS NULL",xs="There was a problem performing this search. Please check the logs and try again.";P3(hn);var RR=class{static{a(this,"SQLSearch")}constructor(t,r){if(ze.isEmpty(t))throw Be.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(),ze.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!ze.isEmptyOrZeroLength(n))return Be.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw Be.error("Error thrown from checkEmptySQL in SQLSearch class method search."),Be.error(n),new Error(xs)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw Be.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),Be.error(n),new Error(xs)}if(Object.keys(this.data).length===0)return Be.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw Be.error("Error thrown from processJoins in SQLSearch class method search."),Be.error(n),new Error(xs)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw Be.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),Be.error(n),new Error(xs)}try{return t=await this._finalSQL(),t}catch(n){throw Be.error("Error thrown from finalSQL in SQLSearch class method search."),Be.error(n),new Error(xs)}}_getColumns(){let t=new pp(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(AM(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=vf.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=RM()[r.databaseid][r.tableid].primaryKey,this.data[n].__merged_data={},this.data[n].__merged_attributes=[],this.data[n].__merged_attr_map={}})}_conditionsToFetchAttributeValues(){if(ze.isEmpty(this.statement.where)){Be.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new pp(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!ze.isEmpty(r)&&r.right)if(ze.isNotEmptyAndHasValue(r.right.value)){let n=ze.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new hn.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=ze.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new hn.yy.LogicValue({value:i}):n instanceof hn.yy.StringValue&&ze.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new hn.yy.NumValue({value:i}))});if(t){Be.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new pp(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(!ze.isEmpty(D3.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(ze.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(ze.isEmptyOrZeroLength(r.left.columnid)||ze.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(ze.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"=":!ze.isEmpty(r.right.value)||!ze.isEmpty(r.left.value)?n.add(ze.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(ze.isEmptyOrZeroLength(this.all_table_attributes)&&ze.isEmptyOrZeroLength(this.statement.from)&&ze.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&&vf.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(ze.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);ze.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(ze.isEmptyOrZeroLength(this.all_table_attributes)&&!ze.isEmptyOrZeroLength(this.columns.columns))return t;if(ze.isEmptyOrZeroLength(this.all_table_attributes)&&ze.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await hn.promise(r)}catch(r){throw Be.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),Be.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(AM(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(ze.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(M3)>-1&&this.tables.forEach(s=>{let i={columnid:RM()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=vf.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),!ze.isEmpty(this.exact_search_values[u])&&!this.exact_search_values[u].ignore&&!ze.isEmptyOrZeroLength(this.exact_search_values[u].values))if(l)try{c.hash_values=Array.from(this.exact_search_values[u].values);let f=await eu.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 Be.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),Be.error(f),new Error(xs)}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 h=await eu.getDataByValue(d);for(let[_,m]of h)this.data[i].__merged_data[_]?this._updateMergedAttribute(i,_,s.attribute,m[s.attribute]):(this.data[i].__merged_data[_]=[...n[i]],this._updateMergedAttribute(i,_,s.attribute,m[s.attribute]),this._setMergedHashAttribute(i,_))}))}catch(f){throw Be.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),Be.error(f),new Error(xs)}else if(!ze.isEmpty(this.comparator_search_values[u])&&!this.comparator_search_values[u].ignore&&!ze.isEmptyOrZeroLength(this.comparator_search_values[u].comparators))try{let f=this.comparator_search_values[u].comparators;for(let d=0,h=f.length;d<h;d++){let _=f[d];c.search_attribute=_.attribute,c.search_value=_.search_value;let m=await eu.getDataByValue(c,_.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 Be.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),Be.error(f),new Error(xs)}else try{c.search_attribute=s.attribute,c.search_value="*";let f=await eu.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,h]of f)this.data[i].__merged_data[d]?this._updateMergedAttribute(i,d,s.attribute,h[s.attribute]):(this.data[i].__merged_data[d]=[...n[i]],this._updateMergedAttribute(i,d,s.attribute,h[s.attribute]),this._setMergedHashAttribute(i,d))}catch(f){throw Be.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),Be.error(f),new Error(xs)}}}_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 hn.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 hn.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new hn.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 hn.yy.FuncValue:new hn.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(_=>{_.joinmode&&_.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(_.table);let m=_.joinmode+" JOIN ? AS "+(_.as?_.as:_.table.tableid);_.on&&(m+=" ON "+_.on.toString()),i.push(m),t.push(Object.values(this.data[`${_.table.databaseid_orig}_${_.table.as?_.table.as_orig:_.table.tableid_orig}`].__merged_data))});let o=[],c={};s.forEach(_=>{let m=this.data[`${_.databaseid_orig}_${_.as?_.as_orig:_.tableid_orig}`].__hash_name,S=_.as?_.as_orig:_.tableid_orig;o.push({key:`'${S}.${m}'`,schema:_.databaseid_orig,table:_.as?_.as_orig:_.tableid_orig,keys:new Set}),r.push(`${_.as?_.as:_.tableid}.\`${m}\` AS "${S}.${m}"`),c[_.as?_.as_orig:_.tableid_orig]=this.data[`${_.databaseid_orig}_${_.as?_.as_orig:_.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(_=>{_.is_func?r.push(_.initial_select_column.toString()):_.initial_select_column.tableid?r.push(`${_.initial_select_column.tableid}.${_.initial_select_column.columnid} AS ${_.expression.columnid}`):r.push(`${_.initial_select_column.columnid} AS ${_.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 h=[];try{let _=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${l} ${u} ${f} ${d}`,m=this._convertColumnsToIndexes(_,s);h=await hn.promise(m,t),t=null}catch(_){throw Be.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),Be.error(_),new Error("There was a problem processing the data.")}if(h&&h.length>0){for(let _=0,m=h.length;_<m;_++){let S=h[_];o.forEach(g=>{S[g.key]!==null&&S[g.key]!==void 0&&g.keys.add(S[g.key])})}o.forEach(_=>{let m=Object.keys(this.data[`${_.schema}_${_.table}`].__merged_data),S=vf.difference(m,[..._.keys].map(g=>g.toString()));for(let g=0,R=S.length;g<R;g++){let E=S[g];delete this.data[`${_.schema}_${_.table}`].__merged_data[E]}})}return{existing_attributes:c,joined_length:h?h.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new pp(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=vf.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 Be.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),Be.error(i),new Error(xs)}}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 eu.getDataByHash(c),u=s.columns.length;for(let f=0,d=o.length;f<d;f++){let h=o[f],_=l.get(h);for(let m=0;m<u;m++){let S=s.columns[m],g=_[S]===void 0?null:_[S];this.data[n].__merged_data[h].push(g)}}}}catch(r){throw Be.error("Error thrown from getDataByHash function in SQLSearch class method getData."),Be.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();Be.trace(`Final SQL: ${s}`),n=await hn.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),Be.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw Be.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),Be.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 Be.error(L3.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),Be.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 eu.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 Be.error("There was an error when processing this SQL operation. Check your logs"),Be.error(o),new Error(xs)}}return Object.values(Object.values(this.data)[0].__merged_data)}};yM.exports=RR});var Vr=C((YRe,OM)=>{"use strict";var v3=lM();OM.exports={searchByConditions:x3,searchByHash:B3,searchByValue:H3,search:k3};var yR=Bn(),{transformReq:bR}=ae(),U3=bM();async function x3(e){return bR(e),yR.searchByConditions(e)}a(x3,"searchByConditions");async function B3(e){bR(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of yR.searchByHash(e))r&&t.push(r);return t}a(B3,"searchByHash");async function H3(e){bR(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of yR.searchByValue(e))t.push(r);return t}a(H3,"searchByValue");function k3(e,t){try{let r=new v3(e);r.validate(),new U3(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(k3,"search")});var eo=C((zRe,CM)=>{"use strict";var Uf=require("crypto"),F3=ce(),{CONFIG_PARAMS:G3}=(H(),P($)),wM="aes-256-cbc",q3=32,$3=16,OR=64,IM=32,V3=OR+IM,NM=new Map;CM.exports={encrypt:K3,decrypt:Y3,createNatsTableStreamName:W3};function K3(e){let t=Uf.randomBytes(q3),r=Uf.randomBytes($3),n=Uf.createCipheriv(wM,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(K3,"encrypt");function Y3(e){let t=e.substr(0,OR),r=e.substr(OR,IM),n=e.substr(V3,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=Uf.createDecipheriv(wM,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(Y3,"decrypt");function W3(e,t){let r=F3.get(G3.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=NM.get(r);return n||(n=Uf.createHash("md5").update(r).digest("hex"),NM.set(r,n)),n}a(W3,"createNatsTableStreamName")});var to=C((JRe,MM)=>{"use strict";var jRe=Vr(),xf=J(),{validateBySchema:PM}=nt(),Rc=require("joi"),z3=eo(),Ep=ae(),{handleHDBError:gp,hdb_errors:Q3,ClientError:DM}=he(),{HDB_ERROR_MSGS:Sp,HTTP_STATUS_CODES:NR}=Q3,LM=ce();LM.initSync();var{getDatabases:wR}=(ve(),P(it)),j3=require("fs-extra"),J3=(H(),P($));MM.exports={describeAll:X3,describeTable:Tp,describeSchema:Z3};async function X3(e={}){try{let t=Ep.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=wR(),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 h=i[d];for(let _ in h)try{let m;if(t||s||r)m=await Tp({schema:d,table:_,exact_count:u});else if(n&&n[d].describe&&n[d].tables[_].describe){let S=n[d].tables[_].attribute_permissions;m=await Tp({schema:d,table:_,exact_count:u},S)}m&&l.push(m)}catch(m){xf.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 xf.error("Got an error in describeAll"),xf.error(t),gp(new Error,Sp.DESCRIBE_ALL_ERR)}}a(X3,"describeAll");async function Tp(e,t){Ep.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=PM(e,Rc.object({database:Rc.string(),table:Rc.string().required(),exact_count:Rc.boolean().strict()}));if(i)throw new DM(i.message);let c=wR()[r];if(!c)throw gp(new Error,Sp.SCHEMA_NOT_FOUND(e.schema),NR.NOT_FOUND);let l=c[n];if(!l)throw gp(new Error,Sp.TABLE_NOT_FOUND(e.schema,e.table),NR.NOT_FOUND);function u(_){f.push({attribute:_.attribute,type:_.type,elements:_.elements?.type,indexed:_.indexed,is_primary_key:_.isPrimaryKey,assigned_created_time:_.assignCreatedTime,assigned_updated_time:_.assignUpdatedTime,nullable:_.nullable,properties:_.properties?_.properties.map(m=>({type:m.type,name:m.name})):void 0})}a(u,"pushAtt");let f=[];if(s){let _={};s.forEach(m=>{m.describe&&(_[m.attribute_name]=!0)}),l.attributes.forEach(m=>{_[m.name]&&u(m)})}else l.attributes?.forEach(_=>u(_));let d;try{d=(await j3.stat(l.primaryStore.env.path)).size}catch(_){xf.warn("unable to get database size",_)}let h={schema:r,name:l.tableName,hash_attribute:l.attributes.find(_=>_.isPrimaryKey||_.is_hash_attribute)?.name,audit:l.audit,schema_defined:l.schemaDefined,attributes:f,db_size:d};l.replicate!==void 0&&(h.replicate=l.replicate),l.expirationMS!==void 0&&(h.expiration=l.expirationMS/1e3+"s"),l.sealed!==void 0&&(h.sealed=l.sealed),l.sources?.length>0&&(h.sources=l.sources.map(_=>_.name).filter(_=>_&&_!=="NATSReplicator"&&_!=="Replicator")),LM.get(J3.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(h.clustering_stream_name=z3.createNatsTableStreamName(h.schema,h.name));try{let _=await l.getRecordCount({exactCount:!!e.exact_count});h.record_count=_.recordCount,h.table_size=l.getSize(),h.db_audit_size=l.getAuditSize(),h.estimated_record_range=_.estimatedRange;let m=l.auditStore;if(m)for(let S of m.getKeys({reverse:!0,limit:1}))h.last_updated_record=S[0];if(!h.last_updated_record&&l.indices.__updatedtime__)for(let S of l.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))h.last_updated_record=S}catch(_){xf.warn(`unable to stat table dbi due to ${_}`)}return h}a(Tp,"descTable");async function Z3(e){Ep.transformReq(e);let t=PM(e,Rc.object({database:Rc.string(),exact_count:Rc.boolean().strict()}));if(t)throw new DM(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=wR()[n];if(!i)throw gp(new Error,Sp.SCHEMA_NOT_FOUND(e.schema),NR.NOT_FOUND);let o={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),Ep.isEmpty(l)||l.describe){let u=await Tp({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);u&&(o[u.name]=u)}}return o}a(Z3,"describeSchema")});var Bs=C((tye,HM)=>{var eX=Ji(),{callbackify:UM,promisify:tX}=require("util"),{getDatabases:xM}=(ve(),P(it));HM.exports={setSchemaDataToGlobal:vM,getTableSchema:rX,getSystemSchema:nX,setSchemaDataToGlobalAsync:tX(vM)};var BM=to(),ZRe=UM(BM.describeAll),eye=UM(BM.describeTable);function vM(e){global.hdb_schema=xM(),e&&e()}a(vM,"setSchemaDataToGlobal");function rX(e,t,r){let n=xM()[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(rX,"getTableSchema");function nX(){return eX}a(nX,"getSystemSchema")});var CR=C((nye,GM)=>{var sX=nt(),IR=require("joi"),{hdb_table:iX,hdb_database:kM}=gi(),FM={schema:kM,database:kM,table:iX},oX={date:IR.date().iso().required()},aX={timestamp:IR.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};GM.exports=function(e,t){let r=t==="timestamp"?{...FM,...aX}:{...FM,...oX},n=IR.object(r);return sX.validateBySchema(e,n)}});var VM=C((sye,$M)=>{var cX=nt(),PR=require("joi"),{hdb_table:lX,hdb_database:qM}=gi(),uX=PR.object({schema:qM,database:qM,table:lX,hash_values:PR.array().required(),ids:PR.array()});$M.exports=function(e){return cX.validateBySchema(e,uX)}});var vR=C((iye,KM)=>{"use strict";var DR=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}},LR=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}},MR=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};KM.exports={InsertObject:DR,NoSQLSeachObject:LR,DeleteResponseObject:MR}});var Oc=C((aye,jM)=>{"use strict";var WM=CR(),dX=VM(),yc=ae(),YM=require("moment"),zM=J(),{promisify:fX,callbackify:_X}=require("util"),bc=(H(),P($)),hX=Bs(),UR=fX(hX.getTableSchema),xR=Bn(),{DeleteResponseObject:mX}=vR(),{handleHDBError:na,hdb_errors:pX}=he(),{HDB_ERROR_MSGS:Ap,HTTP_STATUS_CODES:sa}=pX,EX="records successfully deleted",gX=_X(QM);jM.exports={delete:gX,deleteRecord:QM,deleteFilesBefore:SX,deleteAuditLogsBefore:TX};async function SX(e){let t=WM(e,"date");if(t)throw na(t,t.message,sa.BAD_REQUEST,void 0,void 0,!0);if(yc.transformReq(e),!YM(e.date,YM.ISO_8601).isValid())throw na(new Error,Ap.INVALID_DATE,sa.BAD_REQUEST,bc.LOG_LEVELS.ERROR,Ap.INVALID_DATE,!0);let n=yc.checkSchemaTableExist(e.schema,e.table);if(n)throw na(new Error,n,sa.NOT_FOUND,bc.LOG_LEVELS.ERROR,n,!0);let s=await xR.deleteRecordsBefore(e);if(await UR(e.schema,e.table),zM.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(SX,"deleteFilesBefore");async function TX(e){let t=WM(e,"timestamp");if(t)throw na(t,t.message,sa.BAD_REQUEST,void 0,void 0,!0);if(yc.transformReq(e),isNaN(e.timestamp))throw na(new Error,Ap.INVALID_VALUE("Timestamp"),sa.BAD_REQUEST,bc.LOG_LEVELS.ERROR,Ap.INVALID_VALUE("Timestamp"),!0);let r=yc.checkSchemaTableExist(e.schema,e.table);if(r)throw na(new Error,r,sa.NOT_FOUND,bc.LOG_LEVELS.ERROR,r,!0);let n=await xR.deleteAuditLogsBefore(e);return await UR(e.schema,e.table),zM.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(TX,"deleteAuditLogsBefore");async function QM(e){e.ids&&(e.hash_values=e.ids);let t=dX(e);if(t)throw na(t,t.message,sa.BAD_REQUEST,void 0,void 0,!0);yc.transformReq(e);let r=yc.checkSchemaTableExist(e.schema,e.table);if(r)throw na(new Error,r,sa.NOT_FOUND,bc.LOG_LEVELS.ERROR,r,!0);try{await UR(e.schema,e.table);let n=await xR.deleteRecords(e);return yc.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${EX}`),n}catch(n){if(n.message===bc.SEARCH_NOT_FOUND_MESSAGE){let s=new mX;return s.message=bc.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(QM,"deleteRecord")});var Rp={};Ue(Rp,{HASH_FUNCTION:()=>kf,hash:()=>kR,validate:()=>FR});function BR(e=Hf){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ";return Array.from(Bf.randomBytes(e)).map(r=>t[r%t.length]).join("")}function kR(e,t=kf[XM?.toUpperCase()]??"sha256"){return HR[t](e)}function FR(e,t,r=kf[XM?.toUpperCase()]??"sha256"){return e?AX[r](e,t):!1}var Bf,tu,JM,XM,Hf,ZM,kf,HR,AX,yp=be(()=>{Bf=M(require("node:crypto")),tu=M(require("argon2")),JM=M(ce());H();XM=(0,JM.get)(x.AUTHENTICATION_HASHFUNCTION)?.toLowerCase(),Hf=16,ZM=9,kf=(n=>(n.MD5="md5",n.SHA256="sha256",n.ARGON2ID="argon2id",n))(kf||{});a(BR,"generateSalt");HR={md5:a((e,t=void 0)=>{t=t??BR(ZM);let r=Bf.createHash("md5").update(e+t).digest("hex");return t+r},"md5"),sha256:a((e,t=void 0)=>{t=t??BR(Hf);let r=Bf.createHash("sha256").update(e+t).digest("hex");return t+r},"sha256"),argon2id:a(async e=>{let t=BR(Hf),r=await tu.hash(e,{type:tu.argon2id,salt:Buffer.from(t)});return t+r},"argon2id")},AX={md5:a((e,t)=>{let r=e.slice(0,ZM);return e===HR.md5(t,r)},"md5"),sha256:a((e,t)=>{let r=e.slice(0,Hf);return e===HR.sha256(t,r)},"sha256"),argon2id:a(async(e,t)=>await tu.verify(e.slice(Hf),t),"argon2id")};a(kR,"hash");a(FR,"validate")});var tv=C((dye,ev)=>{var GR=nt(),Kr={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 RX(e){return Kr.password.presence=!0,Kr.username.presence=!0,Kr.role.presence=!0,Kr.active.presence=!0,GR.validateObject(e,Kr)}a(RX,"addUserValidation");function yX(e){return Kr.password.presence=!1,Kr.username.presence=!0,Kr.role.presence=!1,Kr.active.presence=!1,GR.validateObject(e,Kr)}a(yX,"alterUserValidation");function bX(e){return Kr.password.presence=!1,Kr.username.presence=!0,Kr.role.presence=!1,Kr.active.presence=!1,GR.validateObject(e,Kr)}a(bX,"dropUserValidation");ev.exports={addUserValidation:RX,alterUserValidation:yX,dropUserValidation:bX}});var Nt=C((hye,nv)=>{"use strict";var{platform:_ye}=require("os"),OX="nats-server.zip",qR="nats-server",NX=process.platform==="win32"?`${qR}.exe`:qR,wX=/^[^\s.,*>]+$/,rv="__request__",IX=a(e=>`${e}.${rv}`,"REQUEST_SUBJECT"),CX={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},PX={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},DX={HUB:"hub.pid",LEAF:"leaf.pid"},LX={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},MX={SUCCESS:"success",ERROR:"error"},vX={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},UX={TXN:"txn",MSGID:"msgid"},ru={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},xX={[ru.ERR]:1,[ru.WRN]:2,[ru.INF]:3,[ru.DBG]:4,[ru.TRC]:5},BX={debug:"-D",trace:"-DVV"};nv.exports={NATS_SERVER_ZIP:OX,NATS_SERVER_NAME:qR,NATS_BINARY_NAME:NX,PID_FILES:DX,NATS_CONFIG_FILES:PX,SERVER_SUFFIX:LX,NATS_TERM_CONSTRAINTS_RX:wX,REQUEST_SUFFIX:rv,UPDATE_REMOTE_RESPONSE_STATUSES:MX,CLUSTER_STATUS_STATUSES:vX,REQUEST_SUBJECT:IX,SUBJECT_PREFIXES:UX,MSG_HEADERS:CX,LOG_LEVELS:ru,LOG_LEVEL_FLAGS:BX,LOG_LEVEL_HIERARCHY:xX}});var $R=C(sv=>{"use strict";var HX={cert:"-----BEGIN CERTIFICATE-----\rMIIDXDCCAkSgAwIBAgIFNTE4MzQwDQYJKoZIhvcNAQELBQAwXTEXMBUGA1UEAxMO\rSGFycGVyREIsIEluYy4xCzAJBgNVBAYTAlVTMQswCQYDVQQIEwJDTzEPMA0GA1UE\rBxMGRGVudmVyMRcwFQYDVQQKEw5IYXJwZXJEQiwgSW5jLjAeFw0yMjAzMTEyMzAz\rNDlaFw0yNzAzMTAyMzAzNDlaMF0xFzAVBgNVBAMTDkhhcnBlckRCLCBJbmMuMQsw\rCQYDVQQGEwJVUzELMAkGA1UECBMCQ08xDzANBgNVBAcTBkRlbnZlcjEXMBUGA1UE\rChMOSGFycGVyREIsIEluYy4wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIB\rAQCsEUlBF8WImS78rCFXVKyntxfrW++4qZ3hGnoD2MHZAuDHyeP/5eGnaE9GQhKc\r4DwG4DGvh0wP2zIYnBfiQ3L2ZtnlDR9ZkKIQYGlVxTUn6T43krhK5nZKqDF43Yg3\rZEvO3cbJBjiKZx0eA2/toehdSsTAHHQx5gTDcggNe2tgoJHYPwi9YF/AxSBZrbgb\ryWlYgtYDmF32ytHP03GUCIdKOFuBPsHTGu4SkdEIdLIqO9oglW1YFH5qZ6NiwApW\rsP+GCuqOwDXXbdjr75iq9Tq/CDrjGFLaTPmvd2Q0qG/BtaCll0ghpG+yIHvt/iQs\rajS+LxEWAnVlGMaDdFErbDUtAgMBAAGjIzAhMA8GA1UdEwEB/wQFMAMBAf8wDgYD\rVR0PAQH/BAQDAgIEMA0GCSqGSIb3DQEBCwUAA4IBAQASR4YW/rPK7PNArHVe9zzM\rb0rKNX/2T9/0nybRhmE/+hdlSgliTAeebmwkUS2APckmekYt/q2ZY2NS65Fo/jjp\rG8TJrtcF4h+ylVqUp0ZXQLFtIsr7r2JZA7hJ6njW6G4DHSZ0gxtECLi4CBlTjzm5\rNmnmIDObvGRTuqmcdAZmXeObbta/He2XIzietukPAYX062pNM+G5XT5UM1eG/Vlp\rN86vjhpyI+ffKy+C60SJqxmKM3ydgN7oLscE7+2wLPN25XqN4W99OwGsp5dTdu/f\r5lPtFayXdJ55e/sNQKmGN+UGLrL05c2MWgjb8U/LFilnupUianceoeSERZmVjzKX\r-----END CERTIFICATE-----\r".replace(/\r/g,`\r
|
|
17
17
|
`),key:"-----BEGIN RSA PRIVATE KEY-----\rMIIEowIBAAKCAQEArBFJQRfFiJku/KwhV1Ssp7cX61vvuKmd4Rp6A9jB2QLgx8nj\r/+Xhp2hPRkISnOA8BuAxr4dMD9syGJwX4kNy9mbZ5Q0fWZCiEGBpVcU1J+k+N5K4\rSuZ2SqgxeN2IN2RLzt3GyQY4imcdHgNv7aHoXUrEwBx0MeYEw3IIDXtrYKCR2D8I\rvWBfwMUgWa24G8lpWILWA5hd9srRz9NxlAiHSjhbgT7B0xruEpHRCHSyKjvaIJVt\rWBR+amejYsAKVrD/hgrqjsA1123Y6++YqvU6vwg64xhS2kz5r3dkNKhvwbWgpZdI\rIaRvsiB77f4kLGo0vi8RFgJ1ZRjGg3RRK2w1LQIDAQABAoIBAQCEOmh78EOpnGZC\rYBjjHrvrysVD5gvLcfVUtl8Ls7gMB60re1eOIF+PoZZCHKZnDd6zPfiQtj1adg0C\rYnnsM/8VoaZS4gm0b3RLd3ubIQifWhuo40RissY2yxfxlPSH9LhZCY8ojnJG0cTL\resK579E8WCfopjUY33XLqEbN7Ylv39J+DSqInjqV3efJZUa+HqUJ98VxxzodcKMD\rP3bwUU4gHoSSp4pAsOFH5sQhaIWH1IcNjrAwpee2cJQuh4G157RRIuuUpagtaEG/\rXJIiAyBguJyu3JQFnIBQF01N5+omJgXYJ1L0m54543/iIRThmF3zDCDgCyUzmOk+\rH6As9fv1AoGBANOpOtOZLSAScjGsgJamT3ceJ2wCa86g2j8Oxu8lJUmUp5s3tA0v\rBFW5O3S4KR1EXwkLMBUMrfFM8YvzHWxsXBI6XV8azGLvyqPHxr65OhmpGYkGZMXu\rn9okgjkqlewnY2I073gvyK7ppX51UL5y9fF1vlsk+UlW+Rgx/vMHbdcjAoGBANAc\rxRUsxs4QJpbS4zD3JOkHjr24a97TrS3kCybAHUMpR2NrEHPZw9zex0/aphOJUHfL\rIMkOZdpfDqMfxWy4FAEmqBEMkO2SB+h0Wp4P+qp81ax4vGFiB0cD3wtixr11U1tt\rlZ/ZTdv4VDpDFNK1KaplhTDeyuCjeYfS3/GJia9vAoGAcOsAgjBevZR5rXx84WH6\rVO8WUu37u7FenXNxt9VWTinrPMh72uixZFY8nOk+rely1e1NCn3IMko9Ns9NbDFm\r8SaH95vhXArXTYbfxZIlp9jp0YtCqcHDL+p4Oq04bFMbFyJseu7rHj1x18QYfnHw\rOY/6LL/N6k1m+Hx7qgXVmIcCgYB/w0nTCBw84XlvWqSTqQaF8VfWbWP79mP5KmkW\rLxdH5g2noVEGbohqDnK6OXd/wusdwByukiJBf94Skyy25AOT+VFwthA7aU1ljhkb\rtJ+lDuJ28eBkwLPLCzthWBC+u0qjdJFJAzVjd/7tjcU43nNn4s90AzL12iaAFhvZ\rwyA+DQKBgGc/4cdyGJ3YkcA8150gQBawgJZ7q8V1JND87ggWA8wnK3cHn7rMZQl2\r3emDp9HEFXFex5dbGDDqZFAoesZCDxjknIn9oNfW4PvaWS8q7b6ZKLZG1p03Pu7/\rtYaD0kPbo0kysfFT/co+NgHbdykvIyboomfGdNLTUjYuy6lpwpvs\r-----END RSA PRIVATE KEY-----\r".replace(/\r/g,`\r
|
|
18
18
|
`)},kX="certificate.pem",FX="privateKey.pem",GX="caCertificate.pem",qX="natsCertificate.pem",$X="natsCaCertificate.pem",St={DEFAULT:"default","DEFAULT-CA":"default-ca",SERVER:"server",CA:"ca","OPERATIONS-API":"operations-api","OPERATIONS-CA":"operations-ca"},VX={tls_certificate:St.SERVER,tls_certificateAuthority:St.CA,customFunctions_tls_certificate:St.SERVER,customFunctions_tls_certificateAuthority:St.CA,operationsApi_tls_certificate:St["OPERATIONS-API"],operationsApi_tls_certificateAuthority:St["OPERATIONS-CA"]},KX={[St.SERVER]:2,[St.DEFAULT]:1},YX={[St["OPERATIONS-API"]]:3,[St.SERVER]:2,[St.DEFAULT]:1},WX={[St["OPERATIONS-API"]]:3,[St.SERVER]:2,[St.DEFAULT]:1},zX={[St["OPERATIONS-CA"]]:3,[St.CA]:2,[St["DEFAULT-CA"]]:1},QX={[St["OPERATIONS-CA"]]:3,[St.CA]:2,[St["DEFAULT-CA"]]:1},jX={[St.CA]:2,[St["DEFAULT-CA"]]:1};Object.assign(sv,{CERTIFICATE_PEM_NAME:kX,PRIVATEKEY_PEM_NAME:FX,CA_PEM_NAME:GX,CERT_NAME:St,CERT_CONFIG_NAME_MAP:VX,CERT_PREFERENCE_APP:KX,CERT_PREFERENCE_OPS:YX,CERT_PREFERENCE_REP:WX,CA_CERT_PREFERENCE_REP:zX,CA_CERT_PREFERENCE_OPS:QX,CA_CERT_PREFERENCE_APP:jX,CERTIFICATE_VALUES:HX,NATS_CERTIFICATE_PEM_NAME:qX,NATS_CA_PEM_NAME:$X})});var KR=C((gye,uv)=>{"use strict";var cv=require("fs-extra"),Se=require("joi"),JX=require("os"),{boolean:He,string:Tt,number:Zt,array:wc}=Se.types(),{totalmem:iv}=require("os"),Nc=require("path"),XX=J(),VR=ae(),Eye=$R(),ov=(H(),P($)),ZX=nt(),av="log",e6="components",t6="Invalid logging.rotation.maxSize unit. Available units are G, M or K",r6="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",n6="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",s6="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",i6="rootPath config parameter is undefined",mn=Se.alternatives([Zt.min(0),Tt]).optional().empty(null),bp=Se.alternatives([wc.items(Tt,{host:Tt.required(),port:mn},{hostname:Tt.required(),port:mn}).empty(null),wc.items(Tt)]),Ai,lv=!1;uv.exports={configValidator:o6,routesValidator:f6,route_constraints:bp};function o6(e,t=!1){if(lv=t,Ai=e.rootPath,VR.isEmpty(Ai))throw i6;let r=He.optional(),n=Zt.min(0).max(1e3).empty(null).default(d6),s=Tt.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(Ff),i=Tt.optional().empty(null),o=Tt.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null).required(),c=Se.string().empty(null).default(Ff),l=Se.custom(c6).empty(null).default(Ff),u=e.clustering?.enabled,f=Se.object({certificate:i,certificateAuthority:i,privateKey:i}),d;return u===!0?d=Se.object({enabled:r,hubServer:Se.object({cluster:Se.object({name:Se.required().empty(null),network:Se.object({port:mn,routes:bp}).required()}).required(),leafNodes:Se.object({network:Se.object({port:mn}).required()}).required(),network:Se.object({port:mn}).required()}).required(),leafServer:Se.object({network:Se.object({port:mn,routes:bp}).required(),streams:Se.object({maxAge:Zt.min(120).allow(null).optional(),maxBytes:Zt.min(1).allow(null).optional(),maxMsgs:Zt.min(1).allow(null).optional(),path:c}).required()}).required(),logLevel:Se.valid("error","warn","info","debug","trace"),nodeName:o,republishMessages:He.optional(),databaseLevel:He.optional(),tls:Se.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:He.required(),verify:He.optional()}),user:Tt.optional().empty(null)}).optional():d=Se.object({enabled:r,tls:Se.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:He.optional()})}).optional(),Se.object({authentication:Se.alternatives(Se.object({authorizeLocal:He,cacheTTL:Zt.required(),enableSessions:He,hashFunction:Tt.valid("md5","sha256","argon2id").optional().empty(null)}),He).optional(),analytics:Se.object({aggregatePeriod:Zt}),replication:Se.object({hostname:Se.alternatives(Tt,Zt).optional().empty(null),url:Tt.optional().empty(null),port:mn,securePort:mn,routes:wc.optional().empty(null),databases:Se.alternatives(Tt,wc),enableRootCAs:He.optional(),copyTablesToCatchUp:He.optional()}).optional(),componentsRoot:s.optional(),clustering:d,localStudio:Se.object({enabled:r}).required(),logging:Se.object({auditAuthEvents:Se.object({logFailed:He,logSuccessful:He}),file:He.required(),level:Se.valid("notify","fatal","error","warn","info","debug","trace"),rotation:Se.object({enabled:He.optional(),compress:He.optional(),interval:Tt.custom(u6).optional().empty(null),maxSize:Tt.custom(l6).optional().empty(null),path:Tt.optional().empty(null).default(Ff)}).required(),root:s,stdStreams:He.required(),auditLog:He.required()}).required(),operationsApi:Se.object({network:Se.object({cors:He.optional(),corsAccessList:wc.optional(),headersTimeout:Zt.min(1).optional(),keepAliveTimeout:Zt.min(1).optional(),port:mn,domainSocket:Se.optional().empty("hdb/operations-server").default(Ff),securePort:mn,timeout:Zt.min(1).optional()}).optional(),tls:Se.alternatives([Se.array().items(f),f])}).required(),rootPath:Tt.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").required(),mqtt:Se.object({network:Se.object({port:mn,securePort:mn,mtls:Se.alternatives([He.optional(),Se.object({user:Tt.optional(),certificateAuthority:i,required:He.optional()})])}).required(),webSocket:He.optional(),requireAuthentication:He.optional()}),http:Se.object({compressionThreshold:Zt.optional(),cors:He.optional(),corsAccessList:wc.optional(),headersTimeout:Zt.min(1).optional(),port:mn,securePort:mn,maxHeaderSize:Zt.optional(),mtls:Se.alternatives([He.optional(),Se.object({user:Tt.optional(),certificateAuthority:i,required:He.optional()})]),threadRange:Se.alternatives([wc.optional(),Tt.optional()])}).required(),threads:Se.alternatives(n.optional(),Se.object({count:n.optional(),debug:Se.alternatives(He.optional(),Se.object({startingPort:Zt.min(1).optional(),host:Tt.optional(),waitForDebugger:He.optional()})),maxHeapMemory:Zt.min(0).optional()})),storage:Se.object({writeAsync:He.required(),overlappingSync:He.optional(),caching:He.optional(),compression:Se.alternatives([He.optional(),Se.object({dictionary:Tt.optional(),threshold:Zt.optional()})]),compactOnStart:He.optional(),compactOnStartKeepBackup:He.optional(),noReadAhead:He.optional(),path:l,prefetchWrites:He.optional(),maxFreeSpaceToLoad:Zt.optional(),maxFreeSpaceToRetain:Zt.optional()}).required(),ignoreScripts:He.optional(),tls:Se.alternatives([Se.array().items(f),f])}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(o6,"configValidator");function a6(e){return lv||cv.existsSync(e)?null:`Specified path ${e} does not exist.`}a(a6,"doesPathExist");function c6(e,t){Se.assert(e,Tt.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=a6(e);if(r)return t.message(r)}a(c6,"validatePath");function l6(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(t6);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(n6):e}a(l6,"validateRotationMaxSize");function u6(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message(r6);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(s6):e}a(u6,"validateRotationInterval");function d6(e,t){let r=t.state.path.join("."),n=JX.cpus().length,s=n-1;s<=2&&(s=2);let i=process.constrainedMemory?.()||iv();return i=Math.round(Math.min(i,iv())/1e6),s=Math.max(Math.min(s,Math.round((i-750)/300)),1),XX.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}a(d6,"setDefaultThreads");function Ff(e,t){let r=t.state.path.join(".");if(!VR.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if(VR.isEmpty(Ai))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return Nc.join(Ai,e6);case"logging.root":return Nc.join(Ai,av);case"clustering.leafServer.streams.path":return Nc.join(Ai,"clustering","leaf");case"storage.path":let n=Nc.join(Ai,ov.LEGACY_DATABASES_DIR_NAME);return cv.existsSync(n)?n:Nc.join(Ai,ov.DATABASES_DIR_NAME);case"logging.rotation.path":return Nc.join(Ai,av);case"operationsApi.network.domainSocket":return r==null?null:Nc.join(Ai,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(Ff,"setDefaultRoot");function f6(e){let t=Se.object({routes:bp});return ZX.validateBySchema({routes:e},t)}a(f6,"routesValidator")});var It=C(Av=>{"use strict";var us=(H(),P($)),mr=ae(),er=J(),{configValidator:_6,routesValidator:dv}=KR(),Yr=require("fs-extra"),_v=require("yaml"),kn=require("path"),h6=require("is-number"),hv=require("properties-reader"),m6=require("lodash"),{handleHDBError:p6}=he(),{HTTP_STATUS_CODES:E6,HDB_ERROR_MSGS:nu}=Cn(),{server:g6}=(qr(),P(Ql)),{PACKAGE_ROOT:mv}=pt(),{DATABASES_PARAM_CONFIG:Gf,CONFIG_PARAMS:Hn,CONFIG_PARAM_MAP:Hs}=us,S6="Unable to get config value because config is uninitialized",T6="Config successfully initialized",A6="Error backing up config file",R6="Empty parameter sent to getConfigValue",pv=kn.join(mv,"config","yaml",us.HDB_DEFAULT_CONFIG_FILE),y6=kn.join(mv,"config","yaml","defaultNatsConfig.yaml"),b6="Configuration successfully set. You must restart HarperDB for new config settings to take effect.",fv={logging_rotation_retain:"logging.rotation.retain",logging_rotation_rotate:"logging.rotation.rotate",logging_rotation_rotateinterval:"logging.rotation.rotateInterval",logging_rotation_rotatemodule:"logging.rotation.rotateModule",logging_rotation_timezone:"logging.rotation.timezone",logging_rotation_workerinterval:"logging.rotation.workerInterval"},Op,wt,Np;Object.assign(Av,{createConfigFile:O6,getDefaultConfig:N6,getConfigValue:gv,initConfig:wp,flattenConfig:su,updateConfigValue:Sv,updateConfigObject:I6,getConfiguration:D6,setConfiguration:L6,readConfigFile:QR,getClusteringRoutes:M6,initOldConfig:Tv,getConfigFromFile:v6,getConfigFilePath:Ic,addConfig:U6,deleteConfigFromFile:x6,getConfigObj:B6,resolvePath:YR,getFlatConfigObj:H6});function YR(e){if(e?.startsWith("~/"))return kn.join(mr.getHomeDir(),e.slice(1));let t=ce();return kn.resolve(t.getHdbBasePath(),e)}a(YR,"resolvePath");function O6(e,t=!1){let r=ia(pv);if(e.clustering_enabled||e.CLUSTERING_ENABLED||e.clustering){let c=_v.parseDocument(Yr.readFileSync(y6,"utf8"),{simpleKeys:!0});r.addIn(["clustering"],c.toJSON().clustering)}Op=su(r.toJSON());let n;for(let c in e){let l=Hs[c.toLowerCase()];if(l===Hn.DATABASES){Array.isArray(e[c])?n=e[c]:n=Object.keys(e[c]).map(u=>({[u]:e[c][u]}));continue}if(!l&&(c.endsWith("_package")||c.endsWith("_port"))&&(l=c),l!==void 0){let u=l.split("_"),f=WR(l,e[c]);l==="rootPath"&&f?.endsWith("/")&&(f=f.slice(0,-1));try{r.setIn([...u],f)}catch(d){er.error(d)}}}n&&Ev(r,n),zR(r,t);let s=r.toJSON();wt=su(s);let i=r.getIn(["rootPath"]),o=kn.join(i,us.HDB_CONFIG_FILE);if(Yr.createFileSync(o),r.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${r.errors}`);Yr.writeFileSync(o,String(r)),er.trace(`Config file written to ${o}`)}a(O6,"createConfigFile");function Ev(e,t){let r;try{try{r=JSON.parse(t)}catch(n){if(!mr.isObject(t))throw n;r=t}for(let n of r){let s=Object.keys(n)[0];if(n[s].hasOwnProperty(Gf.TABLES))for(let i in n[s][Gf.TABLES])for(let o in n[s][Gf.TABLES][i]){let c=n[s][Gf.TABLES][i][o],l=[Hn.DATABASES,s,Gf.TABLES,i,o];e.hasIn(l)?e.setIn(l,c):e.addIn(l,c)}else for(let i in n[s]){let o=n[s][i],c=[Hn.DATABASES,s,i];e.hasIn(c)?e.setIn(c,o):e.addIn(c,o)}}}catch(n){er.error("Error parsing schemas CLI/env config arguments",n)}}a(Ev,"setSchemasConfig");function N6(e){if(Op===void 0){let r=ia(pv);Op=su(r.toJSON())}let t=Hs[e.toLowerCase()];if(t!==void 0)return Op[t.toLowerCase()]}a(N6,"getDefaultConfig");function gv(e){if(e==null){er.info(R6);return}if(wt===void 0){er.trace(S6);return}let t=Hs[e.toLowerCase()];if(t!==void 0)return wt[t.toLowerCase()]}a(gv,"getConfigValue");function Ic(e=mr.getPropsFilePath()){let t=mr.getEnvCliRootPath();if(t)return YR(kn.join(t,us.HDB_CONFIG_FILE));let r=hv(e);return YR(r.get(us.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}a(Ic,"getConfigFilePath");function wp(e=!1){if(wt===void 0||e){let t;if(!mr.noBootFile()){t=mr.getPropsFilePath();try{Yr.accessSync(t,Yr.constants.F_OK|Yr.constants.R_OK)}catch(i){throw er.error(i),new Error(`HarperDB properties file at path ${t} does not exist`)}}let r=Ic(t),n;if(r.includes("config/settings.js"))try{Tv(r);return}catch(i){if(i.code!==us.NODE_ERROR_CODES.ENOENT)throw i}try{n=ia(r)}catch(i){if(i.code===us.NODE_ERROR_CODES.ENOENT){er.trace(`HarperDB config file not found at ${r}.
|
|
19
|
-
This can occur during early stages of install where the config file has not yet been created`);return}else throw er.error(i),new Error(`Error reading HarperDB config file at ${r}`)}w6(n,r),zR(n);let s=n.toJSON();if(g6.config=s,wt=su(s),wt.logging_rotation_rotate)for(let i in fv)wt[i]&&er.error(`Config ${fv[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);er.trace(T6)}}a(wp,"initConfig");function w6(e,t){let r=e.getIn(["rootPath"]),n=!1;if(e.hasIn(["storage","path"])||(e.setIn(["storage","path"],kn.join(r,"database")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],kn.join(r,"log")),n=!0),e.hasIn(["authentication"])||(e.addIn(["authentication"],{cacheTTL:3e4,enableSessions:!0,operationTokenTimeout:e.getIn(["operationsApi","authentication","operationTokenTimeout"])??"1d",refreshTokenTimeout:e.getIn(["operationsApi","authentication","refreshTokenTimeout"])??"30d"}),n=!0),e.hasIn(["analytics"])||(e.addIn(["analytics"],{aggregatePeriod:60}),n=!0),n){if(er.trace("Updating config file with missing config params"),e.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${e.errors}`);Yr.writeFileSync(t,String(e))}}a(w6,"checkForUpdatedConfig");function zR(e,t=!1){let r=e.toJSON();if(r.componentsRoot=r.componentsRoot??r?.customFunctions?.root,r?.http?.threads&&(r.threads=r?.http?.threads),r.http?.port&&r.http?.port===r.http?.securePort)throw nu.CONFIG_VALIDATION("http.port and http.securePort cannot be the same value");if(r.operationsApi?.network?.port&&r.operationsApi?.network?.port===r.operationsApi?.network?.securePort)throw nu.CONFIG_VALIDATION("operationsApi.network.port and operationsApi.network.securePort cannot be the same value");let n=_6(r,t);if(n.error)throw nu.CONFIG_VALIDATION(n.error.message);typeof n.value.threads=="object"?e.setIn(["threads","count"],n.value.threads.count):e.setIn(["threads"],n.value.threads),e.setIn(["componentsRoot"],n.value.componentsRoot),e.setIn(["logging","root"],n.value.logging.root),e.setIn(["storage","path"],n.value.storage.path),e.setIn(["logging","rotation","path"],n.value.logging.rotation.path),e.setIn(["operationsApi","network","domainSocket"],n.value?.operationsApi?.network?.domainSocket),r?.clustering?.enabled&&e.setIn(["clustering","leafServer","streams","path"],n.value.clustering.leafServer.streams?.path)}a(zR,"validateConfig");function I6(e,t){wt===void 0&&(wt={});let r=Hs[e.toLowerCase()];if(r===void 0){er.trace(`Unable to update config object because config param '${e}' does not exist`);return}wt[r.toLowerCase()]=t}a(I6,"updateConfigObject");function Sv(e,t,r=void 0,n=!1,s=!1,i=!1){wt===void 0&&wp();let o=gv(Hs.hdb_root),c=kn.join(o,us.HDB_CONFIG_FILE),l=ia(c),u;if(r&&wt){let h=!1;for(let _ in r)if(r[_]!=wt[_.toLowerCase()]){h=!0;break}if(!h){er.trace("No changes detected in config parameters, skipping update");return}}if(r===void 0&&e.toLowerCase()===Hn.DATABASES)u=t;else if(r===void 0){let h;if(i)h=e;else if(h=Hs[e.toLowerCase()],h===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let _=h.split("_"),m=WR(h,t);l.setIn([..._],m)}else for(let h in r){let _=Hs[h.toLowerCase()];if(_===Hn.HTTP_SECUREPORT&&r[h]===wt[Hn.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),_===Hn.OPERATIONSAPI_NETWORK_SECUREPORT&&r[h]===wt[Hn.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&l.setIn(["operationsApi","network","port"],null),_===Hn.DATABASES){u=r[h];continue}if(_?.startsWith("threads_")){let m=l.getIn(["threads"]);m>=0&&(l.deleteIn(["threads"]),l.setIn(["threads","count"],m))}if(!_&&(h.endsWith("_package")||h.endsWith("_port"))&&(_=h),_!==void 0){let m=_.split("_"),S=us.LEGACY_CONFIG_PARAMS[h.toUpperCase()];S&&S.startsWith("customFunctions")&&l.hasIn(S.split("_"))&&(_=S,m=S.split("_"));let g=WR(_,r[h]);_==="rootPath"&&g?.endsWith("/")&&(g=g.slice(0,-1));try{m.length>1&&typeof l.getIn(m.slice(0,-1))=="boolean"&&l.deleteIn(m.slice(0,-1)),l.setIn([...m],g)}catch(R){er.error(R)}}}u&&Ev(l,u),zR(l);let f=l.getIn(["rootPath"]),d=kn.join(f,us.HDB_CONFIG_FILE);if(n===!0&&C6(c,f),l.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${l.errors}`);Yr.writeFileSync(d,String(l)),s&&(wt=su(l.toJSON())),er.trace(`Config parameter: ${e} updated with value: ${t}`)}a(Sv,"updateConfigValue");function C6(e,t){try{let r=kn.join(t,"backup",`${new Date(Date.now()).toISOString().replaceAll(":","-")}-${us.HDB_CONFIG_FILE}.bak`);Yr.copySync(e,r),er.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){er.error(A6),er.error(r)}}a(C6,"backupConfigFile");var P6=["databases"];function su(e){return e.http&&Object.assign(e.http,e?.customFunctions?.network),e?.operationsApi?.network&&(e.operationsApi.network={...e.http,...e.operationsApi.network}),e?.operationsApi&&(e.operationsApi.tls={...e.tls,...e.operationsApi.tls}),Np=e,r(e);function r(n){let s={};for(let i in n)if(n.hasOwnProperty(i)){if(typeof n[i]=="object"&&n[i]!==null&&!Array.isArray(n[i])&&!P6.includes(i)){let o=r(n[i]);for(let c in o){if(!o.hasOwnProperty(c))continue;c!=="package"&&(i=i.toLowerCase());let l=i+"_"+c;!Hn[l.toUpperCase()]&&Hs[l]&&(s[Hs[l].toLowerCase()]=o[c]),s[l]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(su,"flattenConfig");function WR(e,t){if(e===Hn.CLUSTERING_NODENAME||e===Hn.CLUSTERING_USER){if(t==null)return t;if(!isNaN(t))return t.toString();if(typeof t=="string"&&t.toLowerCase()==="true"||typeof t=="string"&&t.toLowerCase()==="false")return t}else{if(h6(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||mr.isObject(t)||t===null)return t;if(typeof t=="string"&&t.toLowerCase()==="true")return!0;if(typeof t=="string"&&t.toLowerCase()==="false")return!1}if(t===void 0||t.toLowerCase()==="undefined")return null;if(typeof t=="string"&&(t.startsWith("{")&&t.endsWith("}")||t.startsWith("[")&&t.endsWith("]")))try{return JSON.parse(t)}catch{}return mr.autoCast(t)}a(WR,"castConfigValue");function D6(){let e=mr.getPropsFilePath(),t=Ic(e);return ia(t).toJSON()}a(D6,"getConfiguration");async function L6(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return Sv(void 0,void 0,s,!0),b6}catch(i){throw typeof i=="string"||i instanceof String?p6(i,i,E6.BAD_REQUEST,void 0,void 0,!0):i}}a(L6,"setConfiguration");function QR(){let e=mr.getPropsFilePath();try{Yr.accessSync(e,Yr.constants.F_OK|Yr.constants.R_OK)}catch(n){if(!mr.noBootFile())throw er.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=Ic(e);return ia(t).toJSON()}a(QR,"readConfigFile");function ia(e){return _v.parseDocument(Yr.readFileSync(e,"utf8"),{simpleKeys:!0})}a(ia,"parseYamlDoc");function M6(){let e=QR(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=mr.isEmptyOrZeroLength(t)?[]:t;let r=dv(t);if(r)throw nu.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=mr.isEmptyOrZeroLength(n)?[]:n;let s=dv(n);if(s)throw nu.CONFIG_VALIDATION(s.message);if(!mr.isEmptyOrZeroLength(n)&&!mr.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!mr.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw nu.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(M6,"getClusteringRoutes");function Tv(e){let t=hv(e);wt={};for(let r in Hs){let n=t.get(r.toUpperCase());if(mr.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=Hs[r].toLowerCase();s===Hn.LOGGING_ROOT?wt[s]=kn.dirname(n):wt[s]=n}return wt}a(Tv,"initOldConfig");function v6(e){let t=QR();return m6.get(t,e.replaceAll("_","."))}a(v6,"getConfigFromFile");async function U6(e,t){let r=ia(Ic());if(r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),r.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${r.errors}`);await Yr.writeFile(Ic(),String(r))}a(U6,"addConfig");function x6(e){let t=Ic(mr.getPropsFilePath()),r=ia(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=kn.join(n,us.HDB_CONFIG_FILE);Yr.writeFileSync(s,String(r))}a(x6,"deleteConfigFromFile");function B6(){return Np||(wp(),Np)}a(B6,"getConfigObj");function H6(){return wt||wp(),wt}a(H6,"getFlatConfigObj")});var Fn=C((Rye,br)=>{"use strict";var bv="username is required",Ov="nothing to update, must supply active, role or password to update",Nv="password cannot be an empty string",wv="If role is specified, it cannot be empty.",Iv="active must be true or false";br.exports.addUser=W6;br.exports.alterUser=z6;br.exports.dropUser=j6;br.exports.getSuperUser=tZ;br.exports.userInfo=J6;br.exports.listUsers=Cp;br.exports.listUsersExternal=X6;br.exports.setUsersWithRolesCache=Cc;br.exports.findAndValidateUser=sy;br.exports.getClusterUser=rZ;br.exports.getUsersWithRolesCache=eZ;br.exports.USERNAME_REQUIRED=bv;br.exports.ALTERUSER_NOTHING_TO_UPDATE=Ov;br.exports.EMPTY_PASSWORD=Nv;br.exports.EMPTY_ROLE=wv;br.exports.ACTIVE_BOOLEAN=Iv;var Cv=pn(),k6=Oc(),qf=(yp(),P(Rp)),Pv=tv(),$f=Vr(),ey=no(),Ri=ae(),Dv=require("validate.js"),ty=J(),{promisify:F6}=require("util"),ry=eo(),JR=(H(),P($)),Rv=Nt(),G6=It(),q6=ce(),$6=Ji(),{hdb_errors:V6,ClientError:ks}=he(),{HTTP_STATUS_CODES:ro,AUTHENTICATION_ERROR_MSGS:jR,HDB_ERROR_MSGS:iu}=V6,{UserEventMsg:ny}=Fs(),XR=require("lodash"),{server:Ip}=(qr(),P(Ql)),K6=J();Ip.getUser=(e,t)=>sy(e,t,t!=null);Ip.authenticateUser=(e,t)=>sy(e,t);var Lv={username:!0,active:!0,role:!0,password:!0},yv=new Map,Y6=F6(k6.delete),ZR=q6.get(JR.CONFIG_PARAMS.AUTHENTICATION_HASHFUNCTION)??qf.HASH_FUNCTION.SHA256,yi;async function W6(e){let t=Dv.cleanAttributes(e,Lv),r=Pv.addUserValidation(t);if(r)throw new ks(r.message);let n=await $f.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(iu.ROLE_NAME_NOT_FOUND(t.role),ro.NOT_FOUND);if(n.length>1)throw new ks(iu.DUP_ROLES_FOUND(t.role),ro.CONFLICT);n[0].permission.cluster_user===!0&&(t.hash=ry.encrypt(t.password)),t.password=await qf.hash(t.password,ZR),t.hash_function=ZR,t.role=n[0].id;let s=await Cv.insert({operation:"insert",schema:"system",table:"hdb_user",records:[t]});if(ty.debug(s),await Cc(),s.skipped_hashes.length===1)throw new ks(iu.USER_ALREADY_EXISTS(t.username),ro.CONFLICT);return ey.signalUserChange(new ny(process.pid)),`${t.username} successfully added`}a(W6,"addUser");async function z6(e){let t=Dv.cleanAttributes(e,Lv);if(Ri.isEmptyOrZeroLength(t.username))throw new Error(bv);if(Ri.isEmptyOrZeroLength(t.password)&&Ri.isEmptyOrZeroLength(t.role)&&Ri.isEmptyOrZeroLength(t.active))throw new Error(Ov);if(!Ri.isEmpty(t.password)&&Ri.isEmptyOrZeroLength(t.password.trim()))throw new Error(Nv);if(!Ri.isEmpty(t.active)&&!Ri.isBoolean(t.active))throw new Error(Iv);if(!Ri.isEmpty(t.password)&&!Ri.isEmptyOrZeroLength(t.password.trim())&&(Q6(t.username)&&(t.hash=ry.encrypt(t.password)),t.password=await qf.hash(t.password,ZR)),t.role==="")throw new Error(wv);if(t.role){let n=await $f.searchByValue({schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]});if(!n||n.length===0)throw new ks(iu.ALTER_USER_ROLE_NOT_FOUND(t.role),ro.NOT_FOUND);if(n.length>1)throw new ks(iu.DUP_ROLES_FOUND(t.role),ro.CONFLICT);t.role=n[0].id}let r=await Cv.update({operation:"update",schema:"system",table:"hdb_user",records:[t]});return await Cc(),ey.signalUserChange(new ny(process.pid)),r}a(z6,"alterUser");function Q6(e){let t=!1,r=yi.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(Q6,"isClusterUser");async function j6(e){let t=Pv.dropUserValidation(e);if(t)throw new ks(t.message);if(yi.get(e.username)===void 0)throw new ks(iu.USER_NOT_EXIST(e.username),ro.NOT_FOUND);let r=await Y6({table:"hdb_user",schema:"system",hash_values:[e.username]});return ty.debug(r),await Cc(),ey.signalUserChange(new ny(process.pid)),`${e.username} successfully deleted`}a(j6,"dropUser");async function J6(e){let t={};if(!e||!e.hdb_user)return"There was no user info in the body";t=XR.cloneDeep(e.hdb_user);let r=await $f.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(J6,"userInfo");async function X6(){let e=await Cp();return e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token,delete t.hash_function}),[...e.values()]}a(X6,"listUsersExternal");async function Cp(){let e=await $f.searchByValue({schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]}),t={};for(let s of e)t[s.id]=XR.cloneDeep(s);if(Object.keys(t).length===0)return null;let r=await $f.searchByValue({schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]}),n=new Map;for(let s of r)s=XR.cloneDeep(s),s.role=t[s.role],Z6(s.role),n.set(s.username,s);return n}a(Cp,"listUsers");function Z6(e){if(!e){ty.error("invalid user role found.");return}e.permission.system||(e.permission.system={}),e.permission.system.tables||(e.permission.system.tables={});for(let t of Object.keys($6)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}a(Z6,"appendSystemTablesToRole");async function Cc(e=void 0){e?yi=e:yi=await Cp()}a(Cc,"setUsersWithRolesCache");async function eZ(){return yi||await Cc(),yi}a(eZ,"getUsersWithRolesCache");async function sy(e,t,r=!0){yi||await Cc();let n=yi.get(e);if(!n){if(!r)return{username:e};throw new ks(jR.GENERIC_AUTH_FAIL,ro.UNAUTHORIZED)}if(n&&!n.active)throw new ks(jR.USER_INACTIVE,ro.UNAUTHORIZED);let s={active:n.active,username:n.username};if(n.refresh_token&&(s.refresh_token=n.refresh_token),n.role&&(s.role=n.role),r===!0){if(yv.get(t)===n.password)return s;{let i=qf.validate(n.password,t,n.hash_function||qf.HASH_FUNCTION.MD5);if(i?.then&&(i=await i),i===!0)yv.set(t,n.password);else throw new ks(jR.GENERIC_AUTH_FAIL,ro.UNAUTHORIZED)}}return s}a(sy,"findAndValidateUser");async function tZ(){yi||await Cc();for(let[,e]of yi)if(e.role.role==="super_user")return e}a(tZ,"getSuperUser");async function rZ(){let e=await Cp(),t=G6.getConfigFromFile(JR.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!(r==null||r?.role?.role!==JR.ROLE_TYPES_ENUM.CLUSTER_USER))return r.decrypt_hash=ry.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+Rv.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+Rv.SERVER_SUFFIX.ADMIN,r}a(rZ,"getClusterUser");var Mv=[];Ip.invalidateUser=function(e){for(let t of Mv)try{t(e)}catch(r){K6.error("Error invalidating user",r)}};Ip.onInvalidatedUser=function(e){Mv.push(e)}});var Kf=C((Nye,Bv)=>{"use strict";var Pc=J(),Gn=(H(),P($)),nZ=jL(),bye=Bs(),Oye=to(),sZ=Fn(),{validateEvent:vv}=Fs(),Vf=Bn(),iZ=require("process"),{resetDatabases:oZ}=(ve(),P(it)),aZ={[Gn.ITC_EVENT_TYPES.SCHEMA]:cZ,[Gn.ITC_EVENT_TYPES.USER]:xv};async function cZ(e){let t=vv(e);if(t){Pc.error(t);return}Pc.trace("ITC schemaHandler received schema event:",e),await nZ(e.message),await lZ(e.message)}a(cZ,"schemaHandler");async function lZ(e){try{Vf.resetReadTxn(Gn.SYSTEM_SCHEMA_NAME,Gn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),Vf.resetReadTxn(Gn.SYSTEM_SCHEMA_NAME,Gn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),Vf.resetReadTxn(Gn.SYSTEM_SCHEMA_NAME,Gn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=oZ();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){Pc.error(t)}}a(lZ,"syncSchemaMetadata");var Uv=[];async function xv(e){try{try{Vf.resetReadTxn(Gn.SYSTEM_SCHEMA_NAME,Gn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),Vf.resetReadTxn(Gn.SYSTEM_SCHEMA_NAME,Gn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){Pc.warn(r)}let t=vv(e);if(t){Pc.error(t);return}Pc.trace(`ITC userHandler ${Gn.HDB_ITC_CLIENT_PREFIX}${iZ.pid} received user event:`,e),await sZ.setUsersWithRolesCache();for(let r of Uv)r()}catch(t){Pc.error(t)}}a(xv,"userHandler");xv.addListener=function(e){Uv.push(e)};Bv.exports=aZ});var Fs=C((Lye,kv)=>{"use strict";var Iye=J(),iy=ae(),uZ=(H(),P($)),{ITC_ERRORS:Yf}=Cn(),{parentPort:Cye,threadId:dZ,isMainThread:fZ,workerData:Pye}=require("worker_threads"),{onMessageFromWorkers:_Z,broadcast:Dye,broadcastWithAcknowledgement:hZ}=rt();kv.exports={sendItcEvent:mZ,validateEvent:Hv,SchemaEventMsg:pZ,UserEventMsg:EZ};var Pp;_Z(async(e,t)=>{Pp=Pp||Kf(),Hv(e),Pp[e.type]&&await Pp[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function mZ(e){return!fZ&&e.message&&(e.message.originator=dZ),hZ(e)}a(mZ,"sendItcEvent");function Hv(e){if(typeof e!="object")return Yf.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||iy.isEmpty(e.type))return Yf.MISSING_TYPE;if(!e.hasOwnProperty("message")||iy.isEmpty(e.message))return Yf.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||iy.isEmpty(e.message.originator))return Yf.MISSING_ORIGIN;if(uZ.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return Yf.INVALID_EVENT(e.type)}a(Hv,"validateEvent");function pZ(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(pZ,"SchemaEventMsg");function EZ(e){this.originator=e}a(EZ,"UserEventMsg")});var no=C((Uye,$v)=>{"use strict";var Fv=(H(),P($)),vye=ae(),Dp=J(),Gv=WL(),ou,{sendItcEvent:qv}=Fs();function gZ(e){try{Dp.info("signalSchemaChange called with message:",e),ou=ou||Kf();let t=new Gv(Fv.ITC_EVENT_TYPES.SCHEMA,e);return ou.schema(t),qv(t)}catch(t){Dp.error(t)}}a(gZ,"signalSchemaChange");function SZ(e){try{Dp.trace("signalUserChange called with message:",e),ou=ou||Kf();let t=new Gv(Fv.ITC_EVENT_TYPES.USER,e);return ou.user(t),qv(t)}catch(t){Dp.error(t)}}a(SZ,"signalUserChange");$v.exports={signalSchemaChange:gZ,signalUserChange:SZ}});var Lp=C((Bye,Kv)=>{"use strict";var Vv=ae(),TZ=(H(),P($)),AZ=J(),RZ=_p(),yZ=fp(),bZ=no(),{SchemaEventMsg:OZ}=Fs(),NZ="already exists in";Kv.exports=wZ;async function wZ(e,t,r){if(Vv.isEmptyOrZeroLength(r))return r;let n=[];Vv.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 IZ(e,t.schema,t.name,i)})),s}a(wZ,"lmdbCheckForNewAttributes");async function IZ(e,t,r,n){let s=new yZ(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await CZ(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(NZ))AZ.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(IZ,"createNewAttribute");async function CZ(e){let t;return t=await RZ(e),bZ.signalSchemaChange(new OZ(process.pid,TZ.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(CZ,"createAttribute")});var au=C((kye,Yv)=>{"use strict";var oy=class{static{a(this,"LMDBTransactionObject")}constructor(t,r,n,s,i=void 0){this.operation=t,this.user_name=r,this.timestamp=n,this.hash_values=s,this.origin=i}};Yv.exports=oy});var zv=C((Gye,Wv)=>{"use strict";var PZ=au(),DZ=(H(),P($)).OPERATIONS_ENUM,ay=class extends PZ{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(DZ.INSERT,r,n,s,i),this.records=t}};Wv.exports=ay});var jv=C(($ye,Qv)=>{"use strict";var LZ=au(),MZ=(H(),P($)).OPERATIONS_ENUM,cy=class extends LZ{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(MZ.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};Qv.exports=cy});var Xv=C((Kye,Jv)=>{"use strict";var vZ=au(),UZ=(H(),P($)).OPERATIONS_ENUM,ly=class extends vZ{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(UZ.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};Jv.exports=ly});var eU=C((Wye,Zv)=>{"use strict";var xZ=au(),BZ=(H(),P($)).OPERATIONS_ENUM,uy=class extends xZ{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(BZ.DELETE,n,s,t,i),this.original_records=r}};Zv.exports=uy});var Wf=C((jye,sU)=>{"use strict";var Qye=require("path"),tU=dt(),HZ=zv(),kZ=jv(),FZ=Xv(),GZ=eU(),cu=Ut(),rU=ae(),{CONFIG_PARAMS:qZ}=(H(),P($)),nU=ce();nU.initSync();var Mp=(H(),P($)).OPERATIONS_ENUM,{getTransactionAuditStorePath:$Z}=Et();sU.exports=VZ;async function VZ(e,t){if(nU.get(qZ.LOGGING_AUDITLOG)===!1)return;let r=$Z(e.schema,e.table),n=await tU.openEnvironment(r,e.table,!0),s=KZ(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){tU.initializeDBIs(n,cu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,cu.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[cu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[cu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),rU.isEmpty(s.user_name)||n.dbis[cu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[cu.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(VZ,"writeTransaction");function KZ(e,t){let r=rU.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===Mp.INSERT)return new HZ(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Mp.UPDATE)return new kZ(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Mp.UPSERT)return new FZ(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Mp.DELETE)return new GZ(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(KZ,"createTransactionObject")});var dy=C((Zye,iU)=>{"use strict";var YZ=Pf(),Xye=sf(),zf=(H(),P($)),WZ=of(),zZ=Sc().insertRecords,QZ=dt(),jZ=J(),JZ=Lp(),{getSchemaPath:XZ}=Et(),ZZ=Wf();iU.exports=e8;async function e8(e){try{let{schema_table:t,attributes:r}=YZ(e);WZ(e,r,t.hash_attribute),e.schema!==zf.SYSTEM_SCHEMA_NAME&&(r.includes(zf.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(zf.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(zf.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(zf.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await JZ(e.hdb_auth_header,t,r),s=XZ(e.schema,e.table),i=await QZ.openEnvironment(s,e.table),o=await zZ(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await ZZ(e,o)}catch(c){jZ.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(e8,"lmdbCreateRecords")});var cU=C((tbe,aU)=>{"use strict";var oU=(H(),P($)),t8=dy(),r8=sf(),n8=require("fs-extra"),{getSchemaPath:s8}=Et();aU.exports=i8;async function i8(e){let t=[{name:e.schema,createddate:Date.now()}],r=new r8(oU.SYSTEM_SCHEMA_NAME,oU.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await t8(r),await n8.mkdirp(s8(e.schema))}a(i8,"lmdbCreateSchema")});var uU=C((nbe,lU)=>{"use strict";var fy=class{static{a(this,"DeleteRecordsResponseObject")}constructor(t=[],r=[],n=void 0,s=[]){this.deleted=t,this.skipped=r,this.txn_time=n,this.original_records=s}};lU.exports=fy});var hU=C((cbe,_U)=>{"use strict";var dU=dt(),_y=cn(),hy=Cn().LMDB_ERRORS_ENUM,o8=Ut(),fU=J(),ibe=ae(),a8=require("lmdb"),c8=uU(),l8=(H(),P($)),{OVERFLOW_MARKER:obe,MAX_SEARCH_KEY_LENGTH:abe}=o8,u8=l8.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function d8(e,t,r,n){if(_y.validateEnv(e),t===void 0)throw new Error(hy.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(hy.IDS_REQUIRED):new Error(hy.IDS_MUST_BE_ITERABLE);try{let s=dU.listDBIs(e);dU.initializeDBIs(e,t,s);let i=new c8,o,c=[],l=[];for(let h=0,_=r.length;h<_;h++)try{o=r[h];let m=e.dbis[t].get(o);if(!m||n&&m[u8]>n){i.skipped.push(o);continue}let S=e.dbis[t].ifVersion(o,a8.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],A=m[R];if(A!=null)try{let N=_y.getIndexedValues(A);if(N)for(let v=0,F=N.length;v<F;v++)E.remove(N[v],o)}catch{fU.warn(`cannot delete from attribute: ${R}, ${A}:${o}`)}}});c.push(S),l.push(o),i.original_records.push(m)}catch(m){fU.warn(m),i.skipped.push(o)}let u=[],f=await Promise.all(c);for(let h=0,_=f.length;h<_;h++)f[h]===!0?i.deleted.push(l[h]):(i.skipped.push(l[h]),u.push(h));let d=0;for(let h=0;h<u.length;h++){let _=u[h];i.original_records.splice(_-d,1),d++}return i.txn_time=_y.getNextMonotonicTime(),i}catch(s){throw s}}a(d8,"deleteRecords");_U.exports={deleteRecords:d8}});var Qf=C((ube,pU)=>{"use strict";var lu=ae(),f8=hU(),_8=dt(),{getSchemaPath:h8}=Et(),m8=Wf(),p8=J();pU.exports=E8;async function E8(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(lu.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(lu.isEmptyOrZeroLength(e.hash_values)&&!lu.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];lu.isEmpty(l)||e.hash_values.push(l)}}if(lu.isEmptyOrZeroLength(e.hash_values))return mU([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(lu.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=h8(e.schema,e.table),i=await _8.openEnvironment(s,e.table),o=await f8.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await m8(e,o)}catch(c){p8.error(`unable to write transaction due to ${c.message}`)}return mU(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(E8,"lmdbDeleteRecords");function mU(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(mU,"createDeleteResponse")});var py=C((_be,EU)=>{"use strict";var g8=(H(),P($)),fbe=cn();function my(e,t){let r=Object.create(null);if(t.length===1&&g8.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(my,"parseRow");function S8(e,t,r,n){let s=my(r,e);n.push(s)}a(S8,"searchAll");function T8(e,t,r,n){let s=my(r,e);n[t]=s}a(T8,"searchAllToMap");function A8(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(A8,"iterateDBI");function Dc(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(Dc,"pushResults");function R8(e,t,r,n,s,i){t.toString().endsWith(e)&&Dc(t,r,n,s,i)}a(R8,"endsWith");function y8(e,t,r,n,s,i){t.toString().includes(e)&&Dc(t,r,n,s,i)}a(y8,"contains");function b8(e,t,r,n,s,i){t>e&&Dc(t,r,n,s,i)}a(b8,"greaterThanCompare");function O8(e,t,r,n,s,i){t>=e&&Dc(t,r,n,s,i)}a(O8,"greaterThanEqualCompare");function N8(e,t,r,n,s,i){t<e&&Dc(t,r,n,s,i)}a(N8,"lessThanCompare");function w8(e,t,r,n,s,i){t<=e&&Dc(t,r,n,s,i)}a(w8,"lessThanEqualCompare");EU.exports={parseRow:my,searchAll:S8,searchAllToMap:T8,iterateDBI:A8,endsWith:R8,contains:y8,greaterThanCompare:b8,greaterThanEqualCompare:O8,lessThanCompare:N8,lessThanEqualCompare:w8,pushResults:Dc}});var uu=C((gbe,bU)=>{"use strict";var oa=dt(),mbe=J(),qn=cn(),vp=Ut(),Kt=Cn().LMDB_ERRORS_ENUM,pbe=ae(),I8=(H(),P($)),Up=py(),{parseRow:C8}=Up,Ebe=require("lmdb"),{OVERFLOW_MARKER:gU,MAX_SEARCH_KEY_LENGTH:P8}=vp;function SU(e,t,r,n=!1,s=void 0,i=void 0){return Lc(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(SU,"iterateFullIndex");function jf(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,u=!1){return Lc(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 _===r?(E.values=!1,d.getRange(E).map(A=>({value:A}))):d.getRange(E)})}a(jf,"iterateRangeBetween");function Lc(e,t,r,n){let s=e.database||e,i=oa.openDBI(s,r);i[vp.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&oa.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(Lc,"setupTransaction");function TU(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(gU)){if(!s)if(r)s=oa.openDBI(e,r);else{let l=oa.listDBIs(e);for(let u=0,f=l.length;u<f&&(s=oa.openDBI(e,l[u]),!s[vp.DBI_DEFINITION_NAME].is_hash_attribute);u++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(TU,"getOverflowCheck");function D8(e,t,r,n=!1,s=void 0,i=void 0){if(qn.validateEnv(e),t===void 0)throw new Error(Kt.HASH_ATTRIBUTE_REQUIRED);return Lc(e,t,t,(o,c,l)=>(xp(r),r=Jf(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(u=>C8(u.value,r))))}a(D8,"searchAll");function L8(e,t,r,n=!1,s=void 0,i=void 0){if(qn.validateEnv(e),t===void 0)throw new Error(Kt.HASH_ATTRIBUTE_REQUIRED);xp(r),r=Jf(e.database||e,r);let o=new Map;for(let{key:c,value:l}of SU(e,t,t,n,s,i))o.set(c,Up.parseRow(l,r));return o}a(L8,"searchAllToMap");function M8(e,t,r=!1,n=void 0,s=void 0){if(qn.validateEnv(e),t===void 0)throw new Error(Kt.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=SU(e,void 0,t,r,n,s),c=o.transaction,l=TU(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(M8,"iterateDBI");function v8(e,t){if(qn.validateEnv(e),t===void 0)throw new Error(Kt.HASH_ATTRIBUTE_REQUIRED);return oa.statDBI(e,t).entryCount}a(v8,"countAll");function U8(e,t,r,n,s=!1,i=void 0,o=void 0){return aa(e,r,n),Lc(e,t,r,(c,l,u,f)=>(n=qn.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(U8,"equals");function x8(e,t,r){return aa(e,t,r),oa.openDBI(e,t).getValuesCount(r)}a(x8,"count");function B8(e,t,r,n,s=!1,i=void 0,o=void 0){return aa(e,r,n),Lc(e,null,r,(c,l)=>{n=qn.convertKeyValueToWrite(n);let u=!0;typeof n=="number"&&(u=!1);let f;if(s===!0){let d;for(let h of l.getKeys({transaction:c,start:n}))if(!h.startsWith(n)){d=h;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(h=>{let{key:_}=h;if(_!==d){if(_.toString().startsWith(n))return h;if(u===!0)return f.DONE}}),f.filter(h=>h)}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(B8,"startsWith");function H8(e,t,r,n,s=!1,i=void 0,o=void 0){return AU(e,t,r,n,s,i,o,!0)}a(H8,"endsWith");function AU(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return aa(e,r,n),Lc(e,null,r,(l,u,f,d)=>{let h=TU(f,l,d,r);return o=Number.isInteger(o)?o:0,u.getKeys({transaction:l,end:s?!1:void 0,reverse:s}).flatMap(_=>{let m=_.toString();return m.endsWith(gU)?u.getValues(_,{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[vp.DBI_DEFINITION_NAME].is_hash_attribute?{key:_,value:_}:u.getValues(_,{transaction:l}).map(S=>({key:_,value:S})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a(AU,"contains");function k8(e,t,r,n,s=!1,i=void 0,o=void 0){aa(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),jf(e,t,r,n,l,s,i,o,!0,!1)}a(k8,"greaterThan");function F8(e,t,r,n,s=!1,i=void 0,o=void 0){aa(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),jf(e,t,r,n,l,s,i,o,!1,!1)}a(F8,"greaterThanEqual");function G8(e,t,r,n,s=!1,i=void 0,o=void 0){aa(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),jf(e,t,r,l,n,s,i,o,!1,!0)}a(G8,"lessThan");function q8(e,t,r,n,s=!1,i=void 0,o=void 0){aa(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),jf(e,t,r,l,n,s,i,o,!1,!1)}a(q8,"lessThanEqual");function $8(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(qn.validateEnv(e),r===void 0)throw new Error(Kt.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(Kt.START_VALUE_REQUIRED);if(s===void 0)throw new Error(Kt.END_VALUE_REQUIRED);if(n=qn.convertKeyValueToWrite(n),s=qn.convertKeyValueToWrite(s),n>s)throw new Error(Kt.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return jf(e,t,r,n,s,i,o,c)}a($8,"between");function V8(e,t,r,n){qn.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(Kt.HASH_ATTRIBUTE_REQUIRED);if(xp(r),r=Jf(s,r),n===void 0)throw new Error(Kt.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=Up.parseRow(c,r)),o}a(V8,"searchByHash");function K8(e,t,r){qn.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(Kt.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Kt.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(K8,"checkHashExists");function Y8(e,t,r,n,s=[]){return yU(e,t,r,n,s),RU(e,t,r,n,s).map(i=>i[1])}a(Y8,"batchSearchByHash");function W8(e,t,r,n,s=[]){yU(e,t,r,n,s);let i=new Map;for(let[o,c]of RU(e,t,r,n,s))i.set(o,c);return i}a(W8,"batchSearchByHashToMap");function RU(e,t,r,n,s=[]){return Lc(e,t,t,(i,o,c)=>{r=Jf(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,Up.parseRow(f,r)];s.push(u)}).filter(u=>u)})}a(RU,"batchHashSearch");function yU(e,t,r,n,s){if(qn.validateEnv(e),t===void 0)throw new Error(Kt.HASH_ATTRIBUTE_REQUIRED);if(xp(r),n==null)throw new Error(Kt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(Kt.IDS_MUST_BE_ITERABLE)}a(yU,"initializeBatchSearchByHash");function xp(e){if(!Array.isArray(e))throw e===void 0?new Error(Kt.FETCH_ATTRIBUTES_REQUIRED):new Error(Kt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(xp,"validateFetchAttributes");function aa(e,t,r){if(qn.validateEnv(e),t===void 0)throw new Error(Kt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Kt.SEARCH_VALUE_REQUIRED);if(r?.length>P8)throw new Error(Kt.SEARCH_VALUE_TOO_LARGE)}a(aa,"validateComparisonFunctions");function Jf(e,t){return t.length===1&&I8.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=oa.listDBIs(e)),t}a(Jf,"setGetWholeRowAttributes");bU.exports={searchAll:D8,searchAllToMap:L8,count:x8,countAll:v8,equals:U8,startsWith:B8,endsWith:H8,contains:AU,searchByHash:V8,setGetWholeRowAttributes:Jf,batchSearchByHash:Y8,batchSearchByHashToMap:W8,checkHashExists:K8,iterateDBI:M8,greaterThan:k8,greaterThanEqual:F8,lessThan:G8,lessThanEqual:q8,between:$8}});var du=C((Tbe,CU)=>{var OU=require("lodash"),NU=nt(),ke=require("joi"),z8=ae(),{hdb_schema_table:Xf,checkValidTable:wU,hdb_table:IU,hdb_database:Bp}=gi(),{handleHDBError:Q8,hdb_errors:j8}=he(),{getDatabases:J8}=(ve(),P(it)),{HTTP_STATUS_CODES:X8}=j8,Z8=ke.object({database:Bp,schema:Bp,table:IU,search_attribute:Xf,search_value:ke.any().required(),get_attributes:ke.array().min(1).items(ke.alternatives(Xf,ke.object())).optional(),desc:ke.bool(),limit:ke.number().integer().min(1),offset:ke.number().integer().min(0)}),e5=ke.object({database:Bp,schema:Bp,table:IU,operator:ke.string().valid("and","or").default("and").lowercase(),offset:ke.number().integer().min(0),limit:ke.number().integer().min(1),get_attributes:ke.array().min(1).items(ke.alternatives(Xf,ke.object())).optional(),sort:ke.object({attribute:ke.alternatives(Xf,ke.array().min(1)),descending:ke.bool().optional()}).optional(),conditions:ke.array().min(1).items(ke.alternatives(ke.object({operator:ke.string().valid("and","or").default("and").lowercase(),conditions:ke.array()}),ke.object({search_attribute:ke.alternatives(Xf,ke.array().min(1)),search_type:ke.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:ke.when("search_type",{switch:[{is:"equals",then:ke.any()},{is:"between",then:ke.array().items(ke.alternatives([ke.string(),ke.number()])).length(2)}],otherwise:ke.alternatives(ke.string(),ke.number())}).required()}))).required()});CU.exports=function(e,t){let r=null;switch(t){case"value":r=NU.validateBySchema(e,Z8);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(wU("database",e.schema)),i(wU("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=NU.validateBySchema(e,e5);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=z8.checkGlobalSchemaTable(e.schema,e.table);if(s)return Q8(new Error,s,X8.NOT_FOUND);let o=J8()[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,h=f.conditions.length;d<h;d++){let _=f.conditions[d];_.conditions?l(_):c.push(_.search_attribute)}},"addConditions");t==="conditions"&&l(e);let u=OU.filter(c,f=>f!=="*"&&!f.startsWith?.("$")&&f.attribute!=="*"&&!Array.isArray(f)&&!f.name&&!OU.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 Ey=C((Rbe,PU)=>{"use strict";var t5=dt(),r5=du(),{getSchemaPath:n5}=Et();PU.exports=s5;function s5(e){let t=r5(e,"hashes");if(t)throw t;let r=n5(e.schema,e.table);return t5.openEnvironment(r,e.table)}a(s5,"initialize")});var gy=C((bbe,DU)=>{"use strict";var i5=uu(),o5=Ey();DU.exports=a5;async function a5(e){let t=await o5(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return i5.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(a5,"lmdbGetDataByHash")});var fu=C((Nbe,LU)=>{"use strict";var Sy=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};LU.exports=Sy});var vU=C((Cbe,MU)=>{"use strict";var Ibe=fu(),c5=uu(),l5=Ey();MU.exports=u5;async function u5(e){let t=await l5(e),r=global.hdb_schema[e.schema][e.table];return c5.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(u5,"lmdbSearchByHash")});var Gs=C((Dbe,UU)=>{"use strict";var Ty=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}};UU.exports=Ty});var Hp=C((Mbe,GU)=>{"use strict";var Wr=uu(),d5=dt(),f5=ae(),Fe=Ut(),Mc=(H(),P($)),_5=Ji(),xU=Cn().LMDB_ERRORS_ENUM,{getSchemaPath:h5}=Et(),so=Mc.SEARCH_WILDCARDS;async function m5(e,t,r){let n;e.schema===Mc.SYSTEM_SCHEMA_NAME?n=_5[e.table]:n=global.hdb_schema[e.schema][e.table];let s=FU(e,n.hash_attribute,r,t);return HU(e,s,n.hash_attribute,r)}a(m5,"prepSearch");async function HU(e,t,r,n){let s=h5(e.schema,e.table),i=await d5.openEnvironment(s,e.table),o=kU(i,e,t,r),c=o.transaction||i;if([Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,Fe.SEARCH_TYPES.SEARCH_ALL,Fe.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(p5(e,r)===!1){let f=e.search_attribute;if(f===r)return n?BU(o,()=>!0):o.map(h=>({[r]:h.key}));let d=a(h=>({[r]:h.value,[f]:h.key}),"toObject");return n?BU(o,d):o.map(d)}let u=e.search_attribute===r?o.map(f=>f.key):o.map(f=>f.value);return n===!0?Wr.batchSearchByHashToMap(c,r,e.get_attributes,u):Wr.batchSearchByHash(c,r,e.get_attributes,u)}a(HU,"executeSearch");function kU(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 Fe.SEARCH_TYPES.EQUALS:s=Wr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.CONTAINS:s=Wr.contains(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.ENDS_WITH:case Fe.SEARCH_TYPES._ENDS_WITH:s=Wr.endsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.STARTS_WITH:case Fe.SEARCH_TYPES._STARTS_WITH:s=Wr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return Wr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return Wr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case Fe.SEARCH_TYPES.SEARCH_ALL:return Wr.searchAll(e,n,t.get_attributes,o,c,l);case Fe.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return Wr.searchAllToMap(e,n,t.get_attributes,o,c,l);case Fe.SEARCH_TYPES.BETWEEN:s=Wr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,l);break;case Fe.SEARCH_TYPES.GREATER_THAN:case Fe.SEARCH_TYPES._GREATER_THAN:s=Wr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.GREATER_THAN_EQUAL:case Fe.SEARCH_TYPES._GREATER_THAN_EQUAL:s=Wr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.LESS_THAN:case Fe.SEARCH_TYPES._LESS_THAN:s=Wr.lessThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.LESS_THAN_EQUAL:case Fe.SEARCH_TYPES._LESS_THAN_EQUAL:s=Wr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;default:return Object.create(null)}return s}a(kU,"searchByType");function BU(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(BU,"createMapFromIterable");function p5(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(p5,"checkToFetchMore");function FU(e,t,r,n){if(f5.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?Fe.SEARCH_TYPES.SEARCH_ALL_TO_MAP:Fe.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(so[0])<0&&s.indexOf(so[1])<0)return c===!0?r===!0?Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:Fe.SEARCH_TYPES.EQUALS;if(so.indexOf(i)>=0&&so.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),Fe.SEARCH_TYPES.CONTAINS;if(so.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),Fe.SEARCH_TYPES.ENDS_WITH;if(so.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),Fe.SEARCH_TYPES.STARTS_WITH;if(s.includes(so[0])||s.includes(so[1]))return Fe.SEARCH_TYPES.EQUALS;throw new Error(xU.UNKNOWN_SEARCH_TYPE)}else switch(n){case Mc.VALUE_SEARCH_COMPARATORS.BETWEEN:return Fe.SEARCH_TYPES.BETWEEN;case Mc.VALUE_SEARCH_COMPARATORS.GREATER:return Fe.SEARCH_TYPES.GREATER_THAN;case Mc.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return Fe.SEARCH_TYPES.GREATER_THAN_EQUAL;case Mc.VALUE_SEARCH_COMPARATORS.LESS:return Fe.SEARCH_TYPES.LESS_THAN;case Mc.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return Fe.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(xU.UNKNOWN_SEARCH_TYPE)}}a(FU,"createSearchTypeFromSearchObject");GU.exports={executeSearch:HU,createSearchTypeFromSearchObject:FU,prepSearch:m5,searchByType:kU}});var $U=C((xbe,qU)=>{"use strict";var Ube=Gs(),E5=du(),g5=ae(),S5=(H(),P($)),T5=Hp();qU.exports=A5;function A5(e,t){if(!g5.isEmpty(t)&&S5.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=E5(e,"value");if(n)throw n;return T5.prepSearch(e,t,!0)}a(A5,"lmdbGetDataByValue")});var Zf=C((kbe,VU)=>{"use strict";var Hbe=Gs(),R5=du(),y5=ae(),b5=(H(),P($)),O5=Hp();VU.exports=N5;async function N5(e,t){if(!y5.isEmpty(t)&&b5.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=R5(e,"value");if(n)throw n;return O5.prepSearch(e,t,!1)}a(N5,"lmdbSearchByValue")});var YU=C((qbe,KU)=>{"use strict";var Gbe=Ut(),Ay=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}},Ry=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},yy=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};KU.exports={SearchByConditionsObject:Ay,SearchCondition:Ry,SortAttribute:yy}});var JU=C((Ybe,jU)=>{"use strict";var Vbe=YU().SearchByConditionsObject,w5=Gs(),I5=du(),by=uu(),kp=Ut(),{Resource:Kbe}=(Jo(),P(RA)),QU=Hp(),C5=py(),P5=require("lodash"),{getSchemaPath:D5}=Et(),WU=dt(),{handleHDBError:L5,hdb_errors:M5}=he(),{HTTP_STATUS_CODES:v5}=M5,U5=1e8;jU.exports=x5;async function x5(e){let t=I5(e,"conditions");if(t)throw L5(t,t.message,v5.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=D5(e.schema,e.table),n=await WU.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let u of e.conditions)WU.openDBI(n,u.search_attribute);let i=P5.sortBy(e.conditions,u=>{if(u.estimated_count===void 0){let f=u.search_type;f===kp.SEARCH_TYPES.EQUALS?u.estimated_count=by.count(n,u.search_attribute,u.search_value):f===kp.SEARCH_TYPES.CONTAINS||f===kp.SEARCH_TYPES.ENDS_WITH?u.estimated_count=1/0:u.estimated_count=U5}return u.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await zU(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(QU.filterByType),d=f.length,h=by.setGetWholeRowAttributes(n,e.get_attributes);l=c.map(_=>u.get(_,{transaction:o,lazy:!0})),d>0&&(l=l.filter(_=>{for(let m=0;m<d;m++)if(!f[m](_))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(_=>C5.parseRow(_,h))}else{for(let d=1;d<i.length;d++){let h=i[d],_=await zU(o,e,h,s.hash_attribute);c=c.concat(_)}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=by.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(x5,"lmdbSearchByConditions");async function zU(e,t,r,n){let s=new w5(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===kp.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,QU.searchByType(e,s,i,n).map(o=>o.value)}a(zU,"executeConditionSearch")});var e_=C((zbe,XU)=>{"use strict";var B5=(H(),P($)).OPERATIONS_ENUM,Oy=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=B5.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};XU.exports=Oy});var Ny=C((jbe,o0)=>{"use strict";var r0=Gs(),n0=e_(),s0=Zf(),i0=Qf(),En=(H(),P($)),ZU=ae(),e0=dt(),{getTransactionAuditStorePath:H5,getSchemaPath:k5}=Et(),t0=J();o0.exports=F5;async function F5(e){try{if(ZU.isEmpty(global.hdb_schema[e.schema])||ZU.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await G5(e),await q5(e);let t=k5(e.schema,e.table);try{await e0.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")t0.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=H5(e.schema,e.table);await e0.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")t0.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(F5,"lmdbDropTable");async function G5(e){let t=new r0(En.SYSTEM_SCHEMA_NAME,En.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,En.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[En.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await s0(t)),n=[];for(let i=0;i<r.length;i++){let o=r[i];n.push(o.id)}if(n.length===0)return;let s=new n0(En.SYSTEM_SCHEMA_NAME,En.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await i0(s)}a(G5,"deleteAttributesFromSystem");async function q5(e){let t=new r0(En.SYSTEM_SCHEMA_NAME,En.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,En.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[En.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,En.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,En.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await s0(t))}catch(i){throw i}for(let i=0;i<r.length;i++){let o=r[i];o.name===e.table&&o.schema===e.schema&&(n=o)}if(!n)throw new Error(`${e.schema}.${e.table} was not found`);let s=new n0(En.SYSTEM_SCHEMA_NAME,En.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await i0(s)}catch(i){throw i}}a(q5,"dropTableFromSystem")});var c0=C((Xbe,a0)=>{"use strict";var $5=require("fs-extra"),V5=Gs(),K5=fu(),Y5=e_(),W5=Ny(),z5=Qf(),Q5=gy(),j5=Zf(),io=(H(),P($)),{getSchemaPath:J5}=Et(),{handleHDBError:X5,hdb_errors:Z5}=he(),{HDB_ERROR_MSGS:e9,HTTP_STATUS_CODES:t9}=Z5;a0.exports=r9;async function r9(e){let t;try{t=await n9(e.schema);let r=new V5(io.SYSTEM_SCHEMA_NAME,io.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,io.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[io.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await j5(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await W5(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new Y5(io.SYSTEM_SCHEMA_NAME,io.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await z5(s);let i=J5(t);await $5.remove(i)}catch(r){throw r}}a(r9,"lmdbDropSchema");async function n9(e){let t=new K5(io.SYSTEM_SCHEMA_NAME,io.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[io.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await Q5(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw X5(new Error,e9.SCHEMA_NOT_FOUND(e),t9.NOT_FOUND,void 0,void 0,!0);return n}a(n9,"validateDropSchema")});var t_=C((eOe,l0)=>{"use strict";var wy=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};l0.exports=wy});var Cy=C((nOe,u0)=>{"use strict";var s9=require("fs-extra"),Fp=dt(),{getTransactionAuditStorePath:i9}=Et(),Iy=Ut(),rOe=t_();u0.exports=o9;async function o9(e){let t;try{let r=i9(e.schema,e.table);await s9.mkdirp(r),t=await Fp.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{Fp.createDBI(t,Iy.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),Fp.createDBI(t,Iy.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),Fp.createDBI(t,Iy.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(o9,"createTransactionsAuditEnvironment")});var _0=C((oOe,f0)=>{"use strict";var Py=(H(),P($)),d0=dt(),a9=Sc(),{getSystemSchemaPath:c9,getSchemaPath:l9}=Et(),iOe=Ji(),u9=_p(),Dy=fp(),d9=J(),f9=Cy();f0.exports=_9;async function _9(e,t){let r=l9(t.schema,t.table),n=new Dy(t.schema,t.table,Py.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new Dy(t.schema,t.table,Py.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new Dy(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await d0.createEnvironment(r,t.table),e!==void 0){let o=await d0.openEnvironment(c9(),Py.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await a9.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 Ly(n),await Ly(s),await Ly(i)}await f9(t)}catch(o){throw o}}a(_9,"lmdbCreateTable");async function Ly(e){try{await u9(e)}catch(t){d9.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(Ly,"createAttribute")});var m0=C((cOe,h0)=>{"use strict";var h9=Pf(),m9=of(),p9=Lp(),r_=(H(),P($)),E9=Sc().updateRecords,g9=dt(),{getSchemaPath:S9}=Et(),T9=Wf(),A9=J();h0.exports=R9;async function R9(e){try{let{schema_table:t,attributes:r}=h9(e);m9(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 p9(e.hdb_auth_header,t,r),s=S9(e.schema,e.table),i=await g9.openEnvironment(s,e.table),o=await E9(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await T9(e,o)}catch(c){A9.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(R9,"lmdbUpdateRecords")});var E0=C((uOe,p0)=>{"use strict";var y9=(H(),P($)).OPERATIONS_ENUM,My=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=y9.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};p0.exports=My});var S0=C((_Oe,g0)=>{"use strict";var fOe=E0(),b9=Pf(),O9=of(),N9=Lp(),n_=(H(),P($)),w9=Sc().upsertRecords,I9=dt(),{getSchemaPath:C9}=Et(),P9=Wf(),D9=J(),{handleHDBError:L9,hdb_errors:M9}=he();g0.exports=v9;async function v9(e){let t;try{t=b9(e)}catch(l){throw L9(l,l.message,M9.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;O9(e,n,r.hash_attribute),e.schema!==n_.SYSTEM_SCHEMA_NAME&&(n.includes(n_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(n_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(n_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(n_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await N9(e.hdb_auth_header,r,n),i=C9(e.schema,e.table),o=await I9.openEnvironment(i,e.table),c=await w9(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await P9(e,c)}catch(l){D9.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(v9,"lmdbUpsertRecords")});var A0=C((mOe,T0)=>{"use strict";var vy=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};T0.exports=vy});var y0=C((EOe,R0)=>{"use strict";var Uy=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}};R0.exports=Uy});var N0=C((TOe,O0)=>{"use strict";var xy=dt(),{getTransactionAuditStorePath:U9}=Et(),SOe=A0(),s_=Ut(),x9=ae(),b0=y0(),B9=require("util").promisify,H9=B9(setTimeout),k9=1e4,F9=100;O0.exports=G9;async function G9(e){let t=U9(e.schema,e.table),r=await xy.openEnvironment(t,e.table,!0),n=xy.listDBIs(r);xy.initializeDBIs(r,s_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new b0;do s=await q9(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 H9(F9);while(s.transactions_deleted>0);return i}a(G9,"deleteAuditLogsBefore");async function q9(e,t){let r=new b0;try{let n=e.dbis[s_.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[s_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];x9.isEmpty(c)||(s=e.dbis[s_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[s_.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>k9)break}return await s,r}catch(n){throw n}}a(q9,"deleteTransactions")});var I0=C((ROe,w0)=>{"use strict";var By=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};w0.exports=By});var P0=C((OOe,C0)=>{"use strict";var $9=Gs(),V9=e_(),bOe=I0(),bi=(H(),P($)),K9=ae(),Hy=dt(),Y9=Ji(),W9=Zf(),z9=Qf(),{getSchemaPath:Q9}=Et();C0.exports=j9;async function j9(e,t=!0){let r;e.schema===bi.SYSTEM_SCHEMA_NAME?r=Y9[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await X9(e),s=Q9(e.schema,e.table),i=await Hy.openEnvironment(s,e.table);return t===!0&&await J9(e,i,r.hash_attribute),Hy.dropDBI(i,e.attribute),n}a(j9,"lmdbDropAttribute");async function J9(e,t,r){let n=Hy.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(J9,"removeAttributeFromAllObjects");async function X9(e){let t=new $9(bi.SYSTEM_SCHEMA_NAME,bi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await W9(t)).filter(o=>o[bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(K9.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new V9(bi.SYSTEM_SCHEMA_NAME,bi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return z9(i)}a(X9,"dropAttributeFromSystem")});var x0=C((IOe,U0)=>{"use strict";var ky=dt(),_u=Ut(),wOe=cn(),Fy=(H(),P($)),D0=ae(),{getTransactionAuditStorePath:Z9}=Et(),e7=uu(),Gp=au(),t7=J();U0.exports=r7;async function r7(e){let t=Z9(e.schema,e.table),r=await ky.openEnvironment(t,e.table,!0),n=ky.listDBIs(r);ky.initializeDBIs(r,_u.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case Fy.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return L0(r,e.search_values);case Fy.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,s7(r,e.search_values,s);case Fy.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return n7(r,e.search_values);default:return L0(r)}}a(r7,"readAuditLog");function L0(e,t=[0,Date.now()]){D0.isEmpty(t[0])&&(t[0]=0),D0.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[_u.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 Gp,s))}a(L0,"searchTransactionsByTimestamp");function n7(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[_u.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,v0(e,i))}return Object.fromEntries(r)}a(n7,"searchTransactionsByUsername");function s7(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let u=t[c],f=e7.equals(e,_u.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,_u.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,u);for(let{value:d}of f){let h=Number(d);n.has(h)?n.get(h).push(u.toString()):n.set(h,[u.toString()])}}let s=Array.from(n.keys()),i=v0(e,s),o=new Map;for(let c=0;c<i.length;c++){let l=i[c],u=l.timestamp,f=n.get(u);M0(l,"records",r,f,o),M0(l,"original_records",r,f,o)}return Object.fromEntries(o)}a(s7,"searchTransactionsByHashValues");function M0(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 Gp(e.operation,e.user_name,i,void 0);d[t]=[c],u.push(d)}}else{let u=new Gp(e.operation,e.user_name,i,void 0);u[t]=[c],s.set(l,[u])}}}a(M0,"loopRecords");function v0(e,t){let r=[];try{let n=e.dbis[_u.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 Gp,i);r.push(o)}}catch(i){t7.warn(i)}return r}catch(n){throw n}}a(v0,"batchSearchTransactions")});var H0=C((LOe,B0)=>{"use strict";var{getSchemaPath:POe}=Et(),DOe=dt(),{database:i7}=(ve(),P(it));B0.exports={writeTransaction:o7};async function o7(e,t,r){return i7({database:e,table:t}).transaction(r)}a(o7,"writeTransaction")});var q0=C((vOe,G0)=>{"use strict";var{getSchemaPath:k0}=Et(),F0=dt();G0.exports={flush:a7,resetReadTxn:c7};async function a7(e,t){return(await F0.openEnvironment(k0(e,t),t.toString())).flushed}a(a7,"flush");async function c7(e,t){try{(await F0.openEnvironment(k0(e,t),t.toString())).resetReadTxn()}catch{}}a(c7,"resetReadTxn")});var Y0=C((xOe,K0)=>{"use strict";var{Readable:l7}=require("stream"),{getDatabases:u7}=(ve(),P(it)),{readSync:d7,openSync:f7,createReadStream:$0}=require("fs"),{open:_7}=require("lmdb"),V0=Of(),h7=Nf(),{AUDIT_STORE_OPTIONS:m7}=(Qi(),P(W0)),{INTERNAL_DBIS_NAME:p7,AUDIT_STORE_NAME:E7}=Ut();K0.exports=S7;var Gy=32768,g7=100;async function S7(e){let t=e.database||e.schema||"data",r=u7()[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=_7({noSync:!0,maxDbs:h7.MAX_DBS}),h,_=d.openDB(p7,new V0(!1)),m=f.useReadTransaction(),S=0,g=a(async function(E,A){A.encoding="binary",A.encoder=void 0;let N=d.openDB(E,A),v=f.openDB(E,A);for(let{key:F,version:q,value:Y}of v.getRange({start:null,transaction:m,versions:v.useVersions}))h=N.put(F,Y,q),S++%g7===0&&(await new Promise(ee=>setTimeout(ee,20)),m.openTimer&&(m.openTimer=0))},"copyDatabase");for(let{key:E,value:A}of f.getRange({transaction:m,start:!1}))if(s.some(N=>E.startsWith?.(N+"/"))){_.put(E,A);let[,N]=E.split("/"),v=!N,F=new V0(!v,v);await g(E,F)}e.include_audit&&await g(E7,{...m7}),await h;let R=$0(d.path);return R.headers=l(),R.on("close",()=>{m.done(),d.close()}),R}let o=r[Object.keys(r)[0]].primaryStore,c=f7(o.path);return o.transaction(()=>{let u=Buffer.alloc(Gy);d7(c,u,0,Gy),o.resetReadTxn();let f=o.useReadTransaction();f.renew();let d=$0(null,{fd:c,start:Gy}),h=new l7.from(async function*(){yield u;for await(let _ of d)f.openTimer&&(f.openTimer=0),yield _;f.done()}());return h.headers=l(),h});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(S7,"getBackup")});var j0=C((HOe,Q0)=>{"use strict";var T7=J(),{handleHDBError:A7}=he(),R7=aL(),y7=_p(),b7=dy(),O7=cU(),N7=Qf(),w7=gy(),I7=vU(),C7=$U(),P7=Zf(),D7=JU(),L7=c0(),M7=_0(),v7=m0(),U7=S0(),x7=N0(),B7=Ny(),H7=P0(),k7=x0(),F7=H0(),z0=q0(),G7=Y0(),qy=class extends R7{static{a(this,"LMDBBridge")}async searchByConditions(t){return D7(t)}async getDataByHash(t){return await w7(t)}async searchByHash(t){return await I7(t)}async getDataByValue(t,r){return await C7(t,r)}async searchByValue(t){return await P7(t)}async createSchema(t){return await O7(t)}async dropSchema(t){return await L7(t)}async createTable(t,r){return await M7(t,r)}async dropTable(t){return await B7(t)}async createAttribute(t){return await y7(t)}async createRecords(t){return await b7(t)}async updateRecords(t){return await v7(t)}async upsertRecords(t){try{return await U7(t)}catch(r){throw A7(r,null,null,T7.ERR,r)}}async deleteRecords(t){return await N7(t)}async dropAttribute(t){return await H7(t)}async deleteAuditLogsBefore(t){return await x7(t)}async readAuditLog(t){return await k7(t)}writeTransaction(t,r,n){return F7.writeTransaction(t,r,n)}flush(t,r){return z0.flush(t,r)}resetReadTxn(t,r){return z0.resetReadTxn(t,r)}getBackup(t){return G7(t)}};Q0.exports=qy});var Vy={};Ue(Vy,{add:()=>qp,applyReverse:()=>J0,getRecordAtTime:()=>$y,rebuildUpdateBefore:()=>$p});function qp(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 $p(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,qp(n,s,i)}else r&&(n||(n={}),n[s]=i)}else n||(n={}),n[s]=e[s];return n}function J0(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=q7[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=X0}}function $y(e,t,r){let n=r.rootStore.auditStore,s={...e.value},i=e.localTime;for(;i>t;){let l=n.get(i),u=Ot(l);switch(u.type){case"put":s=u.getValue(r);break;case"patch":J0(s,u.getValue(r));break;case"delete":s=null}i=u.previousLocalTime}let o={},c=0;for(let l in s)s[l]===X0&&(o[l]=!0,c++);for(;c>0&&i>0;){let l=n.get(i),u=Ot(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 q7,X0,Vp=be(()=>{Qi();a(qp,"add");qp.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)};q7={add:qp};a($p,"rebuildUpdateBefore");a(J0,"applyReverse");X0={};a($y,"getRecordAtTime")});function gn(e){let t=e.getChanges();return t||(t=Object.create(null),e._setChanges(t)),t}function zp(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 $n.ClientError(`${l} must be a string, attempt to assign ${d}`);gn(this)[l]=d},"set");break;case"ID":u=a(function(d){if(!(typeof d=="string"||d?.length>0&&d.every?.(h=>typeof h=="string")||d==null&&c.nullable!==!1))throw new $n.ClientError(`${l} must be a string, attempt to assign ${d}`);gn(this)[l]=d},"set");break;case"Float":case"Number":u=a(function(d){let h=d?.__op__?d.value:d;if(!(typeof h=="number"||d==null&&c.nullable!==!1))throw new $n.ClientError(`${l} must be a number, attempt to assign ${h}`);gn(this)[l]=d},"set");break;case"Int":u=a(function(d){let h=d?.__op__?d.value:d;if(!(h>>0===h||d==null&&c.nullable!==!1))if(typeof h=="number"&&Math.abs((h>>0)-h)<=1)h=Math.round(h),d?.__op__?d.value=h:d=h;else throw new $n.ClientError(`${l} must be an integer between -2147483648 and 2147483647, attempt to assign ${d}`);gn(this)[l]=d},"set");break;case"Long":u=a(function(d){let h=d?.__op__?d.value:d;if(!(Math.round(h)===d&&Math.abs(h)<=9007199254740992||d==null&&c.nullable!==!1))if(typeof h=="number"&&Math.abs(h)<=9007199254740992)h=Math.round(h),d?.__op__?d.value=h:d=h;else throw new $n.ClientError(`${l} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${d}`);gn(this)[l]=d},"set");break;case"BigInt":u=a(function(d){let h=d?.__op__?d.value:d;if(!(typeof h=="bigint"||d==null&&c.nullable!==!1))if(typeof h=="string"||typeof h=="number")h=BigInt(h),d?.__op__?d.value=h:d=h;else throw new $n.ClientError(`${l} must be a number, attempt to assign ${d}`);gn(this)[l]=d},"set");break;case"Boolean":u=a(function(d){if(!(typeof d=="boolean"||d==null&&c.nullable!==!1))throw new $n.ClientError(`${l} must be a boolean, attempt to assign ${d}`);gn(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 $n.ClientError(`${l} must be a Date, attempt to assign ${d}`);gn(this)[l]=d},"set");break;case"Bytes":u=a(function(d){if(!(d instanceof Uint8Array||d==null&&c.nullable!==!1))throw new $n.ClientError(`${l} must be a Buffer or Uint8Array, attempt to assign ${d}`);gn(this)[l]=d},"set");break;case"Blob":u=a(function(d){if(!(d instanceof mi||d==null&&c.nullable!==!1))throw new $n.ClientError(`${l} must be a Blob, attempt to assign ${d}`);gn(this)[l]=d},"set");break;case"Any":case void 0:u=a(function(d){gn(this)[l]=d},"set");break;default:u=a(function(d){if(!(typeof d=="object"||d==null&&c.nullable!==!1))throw new $n.ClientError(`${l} must be an object, attempt to assign ${d}`);gn(this)[l]=d},"set")}f={get(){let d=this.getChanges?.();if(d&&l in d){let _=d[l];if(_?.__op__){let m=this.getRecord()?.[l];return _.update(m)}return _}let h=this.getRecord()?.[l];if(h&&typeof h=="object"){let _=Ky(h,c);if(_)return d||this._setChanges(d=Object.create(null)),d[l]=_}return h},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 $n.ClientError("Can not add a property to a sealed table schema");gn(this)[c]=l}),i("deleteProperty",function(c){gn(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 h=l[f];d=d.update(h)}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,ex);break}o=c}while(o&&o!==ex)}function Ky(e,t){let r;switch(e.constructor){case Object:return t?(r=t.TrackedObject,r||(t.TrackedObject=r=class extends i_{static{a(this,"TrackedObject")}},zp(r,t)),new r(e)):new i_(e);case Array:let n=new Yp(e.length,e);for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=Ky(o,t?.elements)),n[s]=o}return n;default:return e}}function Qp(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=Qp(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 Uc(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=Uc(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=Vy[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=Uc(s);r[n]=s}if(!Array.isArray(e))for(let n in e)$7.call(e,n)&&(r||(r={...e.getRecord?.()}),r[n]=e[n]);return r?Object.freeze(r):e.getRecord?.()??e}function Kp(e){let t=e.getRecord?.();if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[vc]||e.length!==t.length)return!0;for(let r=0,n=e.length;r<n;r++){let s=t[r],i=e[r];if(s&&i?.getRecord?.()===s){if(Kp(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(Kp(s))return!0}else return!0}else return!0}}return!1}var $n,Z0,ex,i_,$7,vc,Yp,Wp,Yy=be(()=>{$n=M(he());Vp();as();a(gn,"getChanges");a(zp,"assignTrackedAccessors");Z0=Object.prototype,ex=new Proxy({},{get(e,t,r){if(typeof t=="string"){if(t==="then"||t==="getRecord"||t==="getChanges")return;if(Z0[t])return Z0[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=Ky(s);if(i)return n||(n=Object.create(null),r._setChanges(n)),n[t]=i,i}return s}}});a(Ky,"trackObject");i_=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}};zp(i_,{});a(Qp,"collapseData");$7=Object.prototype.hasOwnProperty;a(Uc,"updateAndFreeze");a(Kp,"hasChanges");vc=Symbol.for("has-array-changes"),Yp=class extends Array{static{a(this,"TrackedArray")}#e;[vc];constructor(t,r){super(t),this.#e=r}getRecord(){return this.#e}splice(...t){return this[vc]=!0,super.splice(...t)}push(...t){return this[vc]=!0,super.push(...t)}pop(){return this[vc]=!0,super.pop()}unshift(...t){return this[vc]=!0,super.unshift(...t)}shift(){return this[vc]=!0,super.shift()}};Yp.prototype.constructor=Array;Wp=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var cx={};Ue(cx,{ResourceBridge:()=>Qy});function jy({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 rx(e,t){let r=Oi(e),n=jy(e,r);if(!r)throw new qs.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;bt(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&&Qp(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 Oi(e){let t=e.database||e.schema||K7,r=Xe()[t];if(!r)throw(0,qs.handleHDBError)(new Error,V7.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function nx(e,t,r){let n=e.length+t.length,s=n===1?"record":"records";return{message:`${e.length} of ${n} ${s} successfully deleted`,deleted_hashes:e,skipped_hashes:t,txn_time:r}}async function*sx(e,t,r,n){let s,i=0;for await(let o of e.getHistory(t,r)){let c=o.operation??o.type;c==="put"&&(c="upsert");let{id:l,version:u,value:f}=o;if(s?.timestamp===u)s.hash_values.push(l),s.records.push(f);else{if(s&&(yield s,i++,n&&n<=i)){s=void 0;break}s={operation:c,user_name:o.user,timestamp:u,hash_values:[l],records:[f]}}}s&&(yield s)}var ix,jp,qs,ox,Wy,zy,ax,V7,K7,Y7,W7,tx,Qy,lx=be(()=>{"use strict";ix=M(j0()),jp=M(du()),qs=M(he());ve();ox=M(Pf());H();Wy=M(no()),zy=M(Fs()),ax=M(ae());oc();Yy();({HDB_ERROR_MSGS:V7}=qs.hdb_errors),K7="data",Y7=1e4,W7=10,Qy=class extends ix.default{static{a(this,"ResourceBridge")}constructor(t){super(t),tx=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,jp.default)(t,"conditions");if(r)throw(0,qs.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=Oi(t);if(!n)throw new qs.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:jy(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 qs.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}]}ut({database:r.database??r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration,audit:r.audit})}async createAttribute(t){return await Oi(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=Oi(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){Oi(t).dropTable()}createSchema(t){return hu({database:t.schema,table:null}),Wy.signalSchemaChange(new zy.SchemaEventMsg(process.pid,$t.CREATE_SCHEMA,t.schema))}async dropSchema(t){await Jy(t.schema),Wy.signalSchemaChange(new zy.SchemaEventMsg(process.pid,$t.DROP_SCHEMA,t.schema))}async updateRecords(t){return t.requires_existing=!0,this.upsertRecords(t)}async createRecords(t){return t.requires_no_existing=!0,tx.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,ox.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),bt(o,async c=>{if(!i.schemaDefined){s=[];for(let f of n)i.attributes.find(h=>h.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],h=d!=null&&await i.get(d,o);if(t.requires_existing&&!h||t.requires_no_existing&&h){u.push(f[i.primaryKey]);continue}h&&(h=Qp(h));for(let _ in f)if(Object.prototype.hasOwnProperty.call(f,_)){let m=f[_];if(typeof m=="function")try{let S=m([[h]]);Array.isArray(S)&&(m=S[0].func_val,f[_]=m)}catch(S){throw S.message+="Trying to set key "+_+" on object"+JSON.stringify(f),S}}if(h)for(let _ in h)Object.prototype.hasOwnProperty.call(f,_)||(f[_]=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),bt(n,async s=>{let i=t.hash_values||t.records.map(l=>l[r.primaryKey]),o=[],c=[];for(let l of i)await r.delete(l,n)?o.push(l):c.push(l);return nx(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=Xe()[t.schema][t.table];if(!r.createdTimeProperty)throw new qs.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:bm.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,ax.async_set_timeout)(W7),l=[],s=!0},"chunkDelete");for await(let f of n)l.push(f[r.primaryKey]),c++,c%Y7===0&&await u();return l.length>0&&await u(),s?nx(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,jp.default)(t,"hashes");if(r)throw r;return rx(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of rx(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&tA[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,jp.default)(t,"value");if(n)throw n;let s=Oi(t);if(!s)throw new qs.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===bm.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:jy(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async getDataByValue(t,r){let n=new Map,s=Oi(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){Oi({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return Oi(t).deleteHistory(t.timestamp,t.cleanup_deleted_records)}async readAuditLog(t){let r=Oi(t),n={};switch(t.search_type){case Om.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 Om.USERNAME:let s=t.search_values;for await(let i of sx(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return sx(r,t.search_values?.[0],t.search_values?.[1],t.limit)}}};a(jy,"getSelect");a(rx,"getRecords");a(Oi,"getTable");a(nx,"createDeleteResponse");a(sx,"groupRecordsInHistory")});var Bn=C((JOe,ux)=>{"use strict";var{ResourceBridge:z7}=(lx(),P(cx)),Q7=ce();Q7.initSync();var Jp;function j7(){return Jp||(Jp=new z7,Jp)}a(j7,"getBridge");ux.exports=j7()});var pn=C((ZOe,hx)=>{"use strict";var Zp=kA(),Cr=ae(),J7=require("util"),eE=Bn(),X7=Bs(),dx=J(),{handleHDBError:xc,hdb_errors:Z7}=he(),{HTTP_STATUS_CODES:Bc}=Z7,eee=J7.promisify(X7.getTableSchema),tee="updated",fx="inserted",_x="upserted";hx.exports={insert:nee,update:see,upsert:iee,validation:ree,flush:oee};async function ree(e){if(Cr.isEmpty(e))throw new Error("invalid update parameters defined.");if(Cr.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if(Cr.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await eee(e.schema,e.table),r=Zp(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&&Cr.isEmptyOrZeroLength(c[n]))throw dx.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(!Cr.isEmptyOrZeroLength(c[n])&&(c[n]==="null"||c[n]==="undefined"))throw dx.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[n]}" is not a valid hash attribute value`);!Cr.isEmpty(c[n])&&c[n]!==""&&s.has(Cr.autoCast(c[n]))&&(c.skip=!0),s.add(Cr.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(ree,"validation");async function nee(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=Zp(e);if(t)throw xc(new Error,t.message,Bc.BAD_REQUEST);Cr.transformReq(e);let r=Cr.checkSchemaTableExist(e.schema,e.table);if(r)throw xc(new Error,r,Bc.BAD_REQUEST);let n=await eE.createRecords(e);return Xp(fx,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(nee,"insertData");async function see(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=Zp(e);if(t)throw xc(new Error,t.message,Bc.BAD_REQUEST);Cr.transformReq(e);let r=Cr.checkSchemaTableExist(e.schema,e.table);if(r)throw xc(new Error,r,Bc.BAD_REQUEST);let n=await eE.updateRecords(e);return Cr.isEmpty(n.existing_rows)?Xp(tee,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):Xp(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(see,"updateData");async function iee(e){if(e.operation!=="upsert")throw xc(new Error,"invalid operation, must be upsert",Bc.INTERNAL_SERVER_ERROR);let t=Zp(e);if(t)throw xc(new Error,t.message,Bc.BAD_REQUEST);Cr.transformReq(e);let r=Cr.checkSchemaTableExist(e.schema,e.table);if(r)throw xc(new Error,r,Bc.BAD_REQUEST);let n=await eE.upsertRecords(e);return Xp(_x,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(iee,"upsertData");function Xp(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===fx?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===_x?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(Xp,"returnObject");function oee(e){return Cr.transformReq(e),eE.flush(e.schema,e.table)}a(oee,"flush")});var Tx=C((tNe,Sx)=>{var mu=require("validate.js"),px=nt(),pu=(H(),P($)),{handleHDBError:aee,hdb_errors:cee}=he(),{HDB_ERROR_MSGS:Yt,HTTP_STATUS_CODES:lee}=cee,Xy=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),uee={STRUCTURE_USER:"structure_user"},mx=Object.values(pu.ROLE_TYPES_ENUM),dee="attribute_permissions",fee="attribute_name",{PERMS_CRUD_ENUM:Eu}=pu,_ee=[dee,...Object.values(Eu)],Ex=[Eu.READ,Eu.INSERT,Eu.UPDATE],hee=[fee,...Ex];function mee(e){let t=Xy();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,gx(e,t)}a(mee,"addRoleValidation");function pee(e){let t=Xy();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,gx(e,t)}a(pee,"alterRoleValidation");function Eee(e){let t=Xy();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,px.validateObject(e,t)}a(Eee,"dropRoleValidation");var gee=["operation","role","id","permission","hdb_user","access"];function gx(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)gee.includes(n[o])||s.push(n[o]);s.length>0&&tr(Yt.INVALID_ROLE_JSON_KEYS(s),r);let i=px.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{tr(o,r)}),e.permission){let o=See(e);o&&tr(o,r),mx.forEach(c=>{e.permission[c]&&!mu.isBoolean(e.permission[c])&&tr(Yt.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(mx.indexOf(o)<0){if(o===uee.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]||tr(Yt.SCHEMA_NOT_FOUND(d),r)}continue}tr(Yt.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){tr(Yt.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]){tr(Yt.TABLE_NOT_FOUND(o,l),r);continue}if(Object.keys(u).forEach(f=>{_ee.includes(f)||tr(Yt.INVALID_PERM_KEY(f),r,o,l)}),Object.values(Eu).forEach(f=>{mu.isDefined(u[f])?mu.isBoolean(u[f])||tr(Yt.TABLE_PERM_NOT_BOOLEAN(f),r,o,l):tr(Yt.TABLE_PERM_MISSING(f),r,o,l)}),u.attribute_permissions===void 0){tr(Yt.ATTR_PERMS_ARRAY_MISSING,r,o,l);continue}else if(!(Array.isArray(u.attribute_permissions)||u.attribute_permissions===null)){tr(Yt.ATTR_PERMS_NOT_ARRAY,r,o,l);continue}if(u.attribute_permissions){let f=global.hdb_schema[o][l].attributes.map(({attribute:h})=>h),d={read:!1,insert:!1,update:!1};for(let h in u.attribute_permissions){let _=u.attribute_permissions[h];if(Object.keys(_).forEach(S=>{!hee.includes(S)&&S!==Eu.DELETE&&tr(Yt.INVALID_ATTR_PERM_KEY(S),r,o,l)}),!mu.isDefined(_.attribute_name)){tr(Yt.ATTR_PERM_MISSING_NAME,r,o,l);continue}let m=_.attribute_name;if(!f.includes(m)){tr(Yt.INVALID_ATTRIBUTE_IN_PERMS(m),r,o,l);continue}Ex.forEach(S=>{mu.isDefined(_[S])?mu.isBoolean(_[S])||tr(Yt.ATTR_PERM_NOT_BOOLEAN(S,m),r,o,l):tr(Yt.ATTR_PERM_MISSING(S,m),r,o,l)}),!d.read&&_.read===!0&&(d.read=!0),!d.insert&&_.insert===!0&&(d.insert=!0),!d.update&&_.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 h=`${o}.${l}`;tr(Yt.MISMATCHED_TABLE_ATTR_PERMS(h),r,o,l)}}}}return Tee(r)}a(gx,"customValidate");Sx.exports={addRoleValidation:mee,alterRoleValidation:pee,dropRoleValidation:Eee};function See(e){let{operation:t,permission:r}=e;if(t===pu.OPERATIONS_ENUM.ADD_ROLE||t===pu.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 Yt.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?pu.ROLE_TYPES_ENUM.SUPER_USER:pu.ROLE_TYPES_ENUM.CLUSTER_USER;return Yt.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(See,"validateNoSUPerms");function Tee(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:Yt.ROLE_PERMS_ERROR,...e};return aee(new Error,n,lee.BAD_REQUEST)}else return null}a(Tee,"generateRolePermResponse");function tr(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(tr,"addPermError")});var a_=C((sNe,bx)=>{"use strict";var Ax=pn(),Rx=Vr(),Aee=Oc(),eb=Tx(),tb=no(),nNe=require("uuid").v4,Ree=require("util"),tE=(H(),P($)),yee=ae(),rb=Rx.searchByValue,bee=Rx.searchByHash,Oee=Ree.promisify(Aee.delete),Nee=Gs(),wee=fu(),{hdb_errors:Iee,handleHDBError:Hc}=he(),{HDB_ERROR_MSGS:yx,HTTP_STATUS_CODES:o_}=Iee,{UserEventMsg:nb}=Fs();bx.exports={addRole:Cee,alterRole:Pee,dropRole:Dee,listRoles:Lee};function Zy(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(Zy,"scrubRoleDetails");async function Cee(e){let t=eb.addRoleValidation(e);if(t)throw t;e=Zy(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 rb(r)||[])}catch(i){throw Hc(i)}if(n&&n.length>0)throw Hc(new Error,yx.ROLE_ALREADY_EXISTS(e.role),o_.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 Ax.insert(s),tb.signalUserChange(new nb(process.pid)),e=Zy(e),e}a(Cee,"addRole");async function Pee(e){let t=eb.alterRoleValidation(e);if(t)throw t;e=Zy(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await Ax.update(r)}catch(s){throw Hc(s)}if(n&&n?.message==="updated 0 of 1 records")throw Hc(new Error,"Invalid role id",o_.BAD_REQUEST,void 0,void 0,!0);return await tb.signalUserChange(new nb(process.pid)),e}a(Pee,"alterRole");async function Dee(e){let t=eb.dropRoleValidation(e);if(t)throw Hc(new Error,t,o_.BAD_REQUEST,void 0,void 0,!0);let r=new wee(tE.SYSTEM_SCHEMA_NAME,tE.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await bee(r));if(n.length===0)throw Hc(new Error,yx.ROLE_NOT_FOUND,o_.NOT_FOUND,void 0,void 0,!0);let s=new Nee(tE.SYSTEM_SCHEMA_NAME,tE.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await rb(s)),o=!1;if(yee.isEmptyOrZeroLength(i)===!1){for(let l=0;l<i.length;l++)if(i[l].active===!0){o=!0;break}}if(o===!0)throw Hc(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,o_.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await Oee(c),tb.signalUserChange(new nb(process.pid)),`${n[0].role} successfully deleted`}a(Dee,"dropRole");async function Lee(){return rb({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(Lee,"listRoles")});var sb={};Ue(sb,{start:()=>wx,startOnMainThread:()=>Uee});function wx({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r){let n=(0,Ox.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(Mee.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 h=u.attributes[d];h.attribute_name=d,f.push(h)}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 vee(i)}}}async function vee(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,Nx.isEqual)(i,e)?void 0:(e.id=r.id,(0,rE.alterRole)(e))}return(0,rE.addRole)(e)}var rE,Ox,Nx,Mee,Uee,Ix=be(()=>{ve();rE=M(a_()),Ox=require("yaml"),Nx=require("lodash"),Mee=["super_user","cluster_user","structure_user"];a(wx,"start");a(vee,"ensureRole");Uee=wx});async function nE(e){let t=(0,Dx.pathToFileURL)(e).toString();if(xee)return c_||(c_=Bee(kee)),(await(await c_).import(t)).namespace;try{return await import(t)}catch(r){try{(await import("internal/util")).default.decorateErrorStack(r)}catch{}throw r}}async function Bee(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),c_=new Compartment({console,Math,Date,fetch:Hee,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,Px.extname)(r)||(r+=".js"),r)},importHook:a(async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){Object.assign(s,{Resource:Gr,tables:Vn,databases:$e})}};let n=await(0,Cx.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)},"importHook")}),c_}function Hee(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 kee(){return{Resource:Gr,tables:Vn}}var Cx,Px,Dx,xee,c_,ib=be(()=>{Jo();ve();Cx=require("fs/promises"),Px=require("path"),Dx=require("url"),xee=!1;a(nE,"secureImport");a(Bee,"getCompartment");a(Hee,"secureOnlyFetch");a(kee,"getGlobalVars")});var ab={};Ue(ab,{handleFile:()=>Fee});async function Fee(e,t,r,n){let s=new Map,i=await nE(r);c(i.default)&&n.set((0,ob.dirname)(t),i.default),o(i,(0,ob.dirname)(t));function o(l,u){for(let f in l){let d=l[f];c(d)?n.set(u+"/"+f,d):typeof d=="object"&&o(d,u+"/"+f)}}a(o,"recurseForResources");function c(l){return typeof l=="function"&&(l.get||l.put||l.post||l.delete)}return a(c,"isResource"),s}var ob,Lx=be(()=>{ib();ob=require("path");a(Fee,"handleFile")});var lb={};Ue(lb,{start:()=>Gee});function Gee({resources:e}){e.set("login",cb),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var cb,Mx=be(()=>{Jo();a(Gee,"start");cb=class extends Gr{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 h_={};Ue(h_,{addAnalyticsListener:()=>__,calculateCPUUtilization:()=>Xx,diffResourceUsage:()=>Zx,recordAction:()=>rr,recordActionBinary:()=>Kn,setAnalyticsEnabled:()=>qee});function qee(e){Wx=e}function $ee(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 Vee(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 rr(e,t,r,n,s){if(!Wx)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=iE.get(i);o?$ee(e,o):Vee(i,e,t,r,n,s),sE||Kee()}function Kn(e,t,r,n,s){rr(!!e,t,r,n,s)}function __(e){jx.push(e)}function Kee(){sE=performance.now(),setTimeout(async()=>{let e=performance.now()-sE;sE=0;let t=[],r={time:Date.now(),period:e,threadId:kc.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 Jx){let h=Math.floor(c*d),_=o[h-1];if(h>l){let m=h-l;if(_===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:_,count:m}:_),f=_;l=h}}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 eB()}let n=process.memoryUsage();t.push({metric:"memory",threadId:kc.threadId,byThread:!0,...n});for(let s of jx)s(t);iE=new Map,kc.parentPort?kc.parentPort.postMessage({type:Qx,report:r}):nB({report:r})},zx).unref()}function oE(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 Xx(e,t){let r=e.userCPUTime+e.systemCPUTime;return Math.round(r/t*100)/100}function Zx(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 Yee(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};oE(e,"table-size",l),Fc.trace?.(`table ${o} size metric: ${JSON.stringify(l)}`),n+=c}return n}function vx(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s.getAuditSize(),o=Yx.default.statSync(s.primaryStore.env.path).size,c=Yee(e,r,n),l=o-c,u={database:r,size:o,used:c,free:l,audit:i};oE(e,"database-size",u),Fc.trace?.(`database ${r} size metric: ${JSON.stringify(u)}`)}catch(s){Fc.warn?.("Error getting DB size metrics",s)}}function Ux(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s.getStorageStats(),o={database:r,...i};oE(e,"storage-volume",o),Fc.trace?.(`db ${r} storage volume metrics: ${JSON.stringify(o)}`)}catch(s){Fc.warn?.("Error getting DB volumne metrics",s)}}async function Wee(e,t=6e4){let r=db(),n=tB(),s=new Promise(E=>{let A=performance.now();setImmediate(()=>{let N=performance.now();N-A>5e3&&Fc.warn?.("Unusually high event queue latency on the main thread of "+Math.round(N-A)+"ms"),A=performance.now()}),n.primaryStore.prefetch([1],()=>{let N=performance.now();N-A>5e3&&Fc.warn?.("Unusually high task queue latency on the main thread of "+Math.round(N-A)+"ms"),E(N-A)})}),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:A}of r.primaryStore.getRange({start:i||!1,exclusiveStart:!0,end:1/0})){if(!A)continue;if(o){if(E>o+t)break}else o=E;f=E;let{metrics:N,threadId:v}=A;for(let F of N||[]){let{path:q,method:Y,type:ee,metric:oe,count:z,total:se,distribution:W,threads:pe,...Ae}=F;z||(z=1);let Pe=oe+(q?"-"+q:"");Y!==void 0&&(Pe+="-"+Y),ee!==void 0&&(Pe+="-"+ee);let me=c.get(Pe);if(me){if(me.threads){let lt=me.threads[v];if(lt)me=lt;else{me.threads[v]={...Ae};continue}}me.count||(me.count=1);let yt=me.count;for(let lt in Ae){let Rr=Ae[lt];typeof Rr=="number"&&(me[lt]=(me[lt]*yt+Rr*z)/(yt+z))}me.count+=z,se>=0&&(me.total+=se,me.ratio=me.total/me.count)}else me={period:t,...F},delete me.distribution,c.set(Pe,me),me.byThread&&(me.threads=[],me.threads[v]={...Ae},u.push(me));if(W){W=W.map(lt=>typeof lt=="number"?{value:lt,count:1}:lt);let yt=l.get(Pe);yt?yt.push(...W):l.set(Pe,W)}}await eB()}for(let E of u){let{path:A,method:N,type:v,metric:F,count:q,total:Y,distribution:ee,threads:oe,...z}=E;oe=oe.filter(se=>se);for(let se in z){if(typeof E[se]!="number")continue;let W=0;for(let pe of oe){let Ae=pe[se];typeof Ae=="number"&&(W+=Ae)}E[se]=W}E.count=oe.length,delete E.threads,delete E.byThread}for(let[E,A]of l){let N=c.get(E);A.sort((lt,Rr)=>lt.value>Rr.value?1:-1);let v=N.count-1,F=[],q=0,Y=0,ee;for(let lt of Jx){let Rr=v*lt;for(;q<Rr;)ee=A[Y++],q+=ee.count,Y===1&&q--;let ss=A[Y>1?Y-2:0];ee||(ee=A[0]),F.push(ee.value-(ee.value-ss.value)*(q-Rr)/ee.count)}let[oe,z,se,W,pe,Ae,Pe,me,yt]=F;Object.assign(N,{p1:oe,p10:z,p25:se,median:W,p75:pe,p90:Ae,p95:Pe,p99:me,p999:yt})}let d;for(let[E,A]of c)A.id=(0,d_.getNextMonotonicTime)(),A.time=f,n.primaryStore.put(A.id,A,{append:!0}).then(N=>{N||n.primaryStore.put(A.id,A)}),d=!0;let h=Date.now(),{idle:_,active:m}=performance.eventLoopUtilization();if(d||m*10>_){let E=(0,d_.getNextMonotonicTime)(),A={id:E,metric:"main-thread-utilization",idle:_-xx,active:m-Bx,taskQueueLatency:await s,time:h,...process.memoryUsage()};n.primaryStore.put(E,A,{append:!0}).then(N=>{N||n.primaryStore.put(E,A)})}xx=_,Bx=m;let S=process.resourceUsage(),g=Zx(l_,S);g.time=h,g.period=l_.time?h-l_.time:t,g.cpuUtilization=Xx(l_,g.period),oE(n,"resource-usage",g),l_=g;let R=Xe();vx(n,R),vx(n,{system:R.system}),Ux(n,R),Ux(n,{system:R.system})}async function Hx(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function db(){return kx||(kx=ut({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function tB(){return Fx||(Fx=ut({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function jee(){rB=!0;let e=(0,f_.get)(x.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await Wee(zx,e),await Hx(db(),zee),await Hx(tB(),Qee)},Math.min(e/2,2147483647)).unref()}function nB(e,t){let r=e.report;r.threadId=t?.threadId||kc.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(Gx+=n.mean*n.count);r.totalBytesProcessed=Gx,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(qx.get(t))}),qx.set(t,t.performance.eventLoopUtilization())),r.id=(0,d_.getNextMonotonicTime)(),db().primaryStore.put(r.id,r),rB||jee(),Jee&&(sB=Zee(r))}async function Zee(e){if(await sB,!ca){let r=(0,u_.dirname)((0,Vx.getLogFilePath)());try{ca=await(0,ub.open)((0,u_.join)(r,"analytics.log"),"r+")}catch{ca=await(0,ub.open)((0,u_.join)(r,"analytics.log"),"w+")}}let t=(await ca.stat()).size;if(t>Xee){let r=Buffer.alloc(t);await ca.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await ca.write(r,{position:0}),await ca.truncate(r.length),t=r.length}await ca.write(JSON.stringify(e)+`
|
|
19
|
+
This can occur during early stages of install where the config file has not yet been created`);return}else throw er.error(i),new Error(`Error reading HarperDB config file at ${r}`)}w6(n,r),zR(n);let s=n.toJSON();if(g6.config=s,wt=su(s),wt.logging_rotation_rotate)for(let i in fv)wt[i]&&er.error(`Config ${fv[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);er.trace(T6)}}a(wp,"initConfig");function w6(e,t){let r=e.getIn(["rootPath"]),n=!1;if(e.hasIn(["storage","path"])||(e.setIn(["storage","path"],kn.join(r,"database")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],kn.join(r,"log")),n=!0),e.hasIn(["authentication"])||(e.addIn(["authentication"],{cacheTTL:3e4,enableSessions:!0,operationTokenTimeout:e.getIn(["operationsApi","authentication","operationTokenTimeout"])??"1d",refreshTokenTimeout:e.getIn(["operationsApi","authentication","refreshTokenTimeout"])??"30d"}),n=!0),e.hasIn(["analytics"])||(e.addIn(["analytics"],{aggregatePeriod:60}),n=!0),n){if(er.trace("Updating config file with missing config params"),e.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${e.errors}`);Yr.writeFileSync(t,String(e))}}a(w6,"checkForUpdatedConfig");function zR(e,t=!1){let r=e.toJSON();if(r.componentsRoot=r.componentsRoot??r?.customFunctions?.root,r?.http?.threads&&(r.threads=r?.http?.threads),r.http?.port&&r.http?.port===r.http?.securePort)throw nu.CONFIG_VALIDATION("http.port and http.securePort cannot be the same value");if(r.operationsApi?.network?.port&&r.operationsApi?.network?.port===r.operationsApi?.network?.securePort)throw nu.CONFIG_VALIDATION("operationsApi.network.port and operationsApi.network.securePort cannot be the same value");let n=_6(r,t);if(n.error)throw nu.CONFIG_VALIDATION(n.error.message);typeof n.value.threads=="object"?e.setIn(["threads","count"],n.value.threads.count):e.setIn(["threads"],n.value.threads),e.setIn(["componentsRoot"],n.value.componentsRoot),e.setIn(["logging","root"],n.value.logging.root),e.setIn(["storage","path"],n.value.storage.path),e.setIn(["logging","rotation","path"],n.value.logging.rotation.path),e.setIn(["operationsApi","network","domainSocket"],n.value?.operationsApi?.network?.domainSocket),r?.clustering?.enabled&&e.setIn(["clustering","leafServer","streams","path"],n.value.clustering.leafServer.streams?.path)}a(zR,"validateConfig");function I6(e,t){wt===void 0&&(wt={});let r=Hs[e.toLowerCase()];if(r===void 0){er.trace(`Unable to update config object because config param '${e}' does not exist`);return}wt[r.toLowerCase()]=t}a(I6,"updateConfigObject");function Sv(e,t,r=void 0,n=!1,s=!1,i=!1){wt===void 0&&wp();let o=gv(Hs.hdb_root),c=kn.join(o,us.HDB_CONFIG_FILE),l=ia(c),u;if(r&&wt){let h=!1;for(let _ in r)if(r[_]!=wt[_.toLowerCase()]){h=!0;break}if(!h){er.trace("No changes detected in config parameters, skipping update");return}}if(r===void 0&&e.toLowerCase()===Hn.DATABASES)u=t;else if(r===void 0){let h;if(i)h=e;else if(h=Hs[e.toLowerCase()],h===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let _=h.split("_"),m=WR(h,t);l.setIn([..._],m)}else for(let h in r){let _=Hs[h.toLowerCase()];if(_===Hn.HTTP_SECUREPORT&&r[h]===wt[Hn.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),_===Hn.OPERATIONSAPI_NETWORK_SECUREPORT&&r[h]===wt[Hn.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&l.setIn(["operationsApi","network","port"],null),_===Hn.DATABASES){u=r[h];continue}if(_?.startsWith("threads_")){let m=l.getIn(["threads"]);m>=0&&(l.deleteIn(["threads"]),l.setIn(["threads","count"],m))}if(!_&&(h.endsWith("_package")||h.endsWith("_port"))&&(_=h),_!==void 0){let m=_.split("_"),S=us.LEGACY_CONFIG_PARAMS[h.toUpperCase()];S&&S.startsWith("customFunctions")&&l.hasIn(S.split("_"))&&(_=S,m=S.split("_"));let g=WR(_,r[h]);_==="rootPath"&&g?.endsWith("/")&&(g=g.slice(0,-1));try{m.length>1&&typeof l.getIn(m.slice(0,-1))=="boolean"&&l.deleteIn(m.slice(0,-1)),l.setIn([...m],g)}catch(R){er.error(R)}}}u&&Ev(l,u),zR(l);let f=l.getIn(["rootPath"]),d=kn.join(f,us.HDB_CONFIG_FILE);if(n===!0&&C6(c,f),l.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${l.errors}`);Yr.writeFileSync(d,String(l)),s&&(wt=su(l.toJSON())),er.trace(`Config parameter: ${e} updated with value: ${t}`)}a(Sv,"updateConfigValue");function C6(e,t){try{let r=kn.join(t,"backup",`${new Date(Date.now()).toISOString().replaceAll(":","-")}-${us.HDB_CONFIG_FILE}.bak`);Yr.copySync(e,r),er.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){er.error(A6),er.error(r)}}a(C6,"backupConfigFile");var P6=["databases"];function su(e){return e.http&&Object.assign(e.http,e?.customFunctions?.network),e?.operationsApi?.network&&(e.operationsApi.network={...e.http,...e.operationsApi.network}),e?.operationsApi&&(e.operationsApi.tls={...e.tls,...e.operationsApi.tls}),Np=e,r(e);function r(n){let s={};for(let i in n)if(n.hasOwnProperty(i)){if(typeof n[i]=="object"&&n[i]!==null&&!Array.isArray(n[i])&&!P6.includes(i)){let o=r(n[i]);for(let c in o){if(!o.hasOwnProperty(c))continue;c!=="package"&&(i=i.toLowerCase());let l=i+"_"+c;!Hn[l.toUpperCase()]&&Hs[l]&&(s[Hs[l].toLowerCase()]=o[c]),s[l]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(su,"flattenConfig");function WR(e,t){if(e===Hn.CLUSTERING_NODENAME||e===Hn.CLUSTERING_USER){if(t==null)return t;if(!isNaN(t))return t.toString();if(typeof t=="string"&&t.toLowerCase()==="true"||typeof t=="string"&&t.toLowerCase()==="false")return t}else{if(h6(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||mr.isObject(t)||t===null)return t;if(typeof t=="string"&&t.toLowerCase()==="true")return!0;if(typeof t=="string"&&t.toLowerCase()==="false")return!1}if(t===void 0||t.toLowerCase()==="undefined")return null;if(typeof t=="string"&&(t.startsWith("{")&&t.endsWith("}")||t.startsWith("[")&&t.endsWith("]")))try{return JSON.parse(t)}catch{}return mr.autoCast(t)}a(WR,"castConfigValue");function D6(){let e=mr.getPropsFilePath(),t=Ic(e);return ia(t).toJSON()}a(D6,"getConfiguration");async function L6(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return Sv(void 0,void 0,s,!0),b6}catch(i){throw typeof i=="string"||i instanceof String?p6(i,i,E6.BAD_REQUEST,void 0,void 0,!0):i}}a(L6,"setConfiguration");function QR(){let e=mr.getPropsFilePath();try{Yr.accessSync(e,Yr.constants.F_OK|Yr.constants.R_OK)}catch(n){if(!mr.noBootFile())throw er.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=Ic(e);return ia(t).toJSON()}a(QR,"readConfigFile");function ia(e){return _v.parseDocument(Yr.readFileSync(e,"utf8"),{simpleKeys:!0})}a(ia,"parseYamlDoc");function M6(){let e=QR(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=mr.isEmptyOrZeroLength(t)?[]:t;let r=dv(t);if(r)throw nu.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=mr.isEmptyOrZeroLength(n)?[]:n;let s=dv(n);if(s)throw nu.CONFIG_VALIDATION(s.message);if(!mr.isEmptyOrZeroLength(n)&&!mr.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!mr.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw nu.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(M6,"getClusteringRoutes");function Tv(e){let t=hv(e);wt={};for(let r in Hs){let n=t.get(r.toUpperCase());if(mr.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=Hs[r].toLowerCase();s===Hn.LOGGING_ROOT?wt[s]=kn.dirname(n):wt[s]=n}return wt}a(Tv,"initOldConfig");function v6(e){let t=QR();return m6.get(t,e.replaceAll("_","."))}a(v6,"getConfigFromFile");async function U6(e,t){let r=ia(Ic());if(r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),r.errors?.length>0)throw new Error(`Error parsing harperdb-config.yaml ${r.errors}`);await Yr.writeFile(Ic(),String(r))}a(U6,"addConfig");function x6(e){let t=Ic(mr.getPropsFilePath()),r=ia(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=kn.join(n,us.HDB_CONFIG_FILE);Yr.writeFileSync(s,String(r))}a(x6,"deleteConfigFromFile");function B6(){return Np||(wp(),Np)}a(B6,"getConfigObj");function H6(){return wt||wp(),wt}a(H6,"getFlatConfigObj")});var Fn=C((Rye,br)=>{"use strict";var bv="username is required",Ov="nothing to update, must supply active, role or password to update",Nv="password cannot be an empty string",wv="If role is specified, it cannot be empty.",Iv="active must be true or false";br.exports.addUser=W6;br.exports.alterUser=z6;br.exports.dropUser=j6;br.exports.getSuperUser=tZ;br.exports.userInfo=J6;br.exports.listUsers=Cp;br.exports.listUsersExternal=X6;br.exports.setUsersWithRolesCache=Cc;br.exports.findAndValidateUser=sy;br.exports.getClusterUser=rZ;br.exports.getUsersWithRolesCache=eZ;br.exports.USERNAME_REQUIRED=bv;br.exports.ALTERUSER_NOTHING_TO_UPDATE=Ov;br.exports.EMPTY_PASSWORD=Nv;br.exports.EMPTY_ROLE=wv;br.exports.ACTIVE_BOOLEAN=Iv;var Cv=pn(),k6=Oc(),qf=(yp(),P(Rp)),Pv=tv(),$f=Vr(),ey=no(),Ri=ae(),Dv=require("validate.js"),ty=J(),{promisify:F6}=require("util"),ry=eo(),JR=(H(),P($)),Rv=Nt(),G6=It(),q6=ce(),$6=Ji(),{hdb_errors:V6,ClientError:ks}=he(),{HTTP_STATUS_CODES:ro,AUTHENTICATION_ERROR_MSGS:jR,HDB_ERROR_MSGS:iu}=V6,{UserEventMsg:ny}=Fs(),XR=require("lodash"),{server:Ip}=(qr(),P(Ql)),K6=J();Ip.getUser=(e,t)=>sy(e,t,t!=null);Ip.authenticateUser=(e,t)=>sy(e,t);var Lv={username:!0,active:!0,role:!0,password:!0},yv=new Map,Y6=F6(k6.delete),ZR=q6.get(JR.CONFIG_PARAMS.AUTHENTICATION_HASHFUNCTION)??qf.HASH_FUNCTION.SHA256,yi;async function W6(e){let t=Dv.cleanAttributes(e,Lv),r=Pv.addUserValidation(t);if(r)throw new ks(r.message);let n=await $f.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(iu.ROLE_NAME_NOT_FOUND(t.role),ro.NOT_FOUND);if(n.length>1)throw new ks(iu.DUP_ROLES_FOUND(t.role),ro.CONFLICT);n[0].permission.cluster_user===!0&&(t.hash=ry.encrypt(t.password)),t.password=await qf.hash(t.password,ZR),t.hash_function=ZR,t.role=n[0].id;let s=await Cv.insert({operation:"insert",schema:"system",table:"hdb_user",records:[t]});if(ty.debug(s),await Cc(),s.skipped_hashes.length===1)throw new ks(iu.USER_ALREADY_EXISTS(t.username),ro.CONFLICT);return ey.signalUserChange(new ny(process.pid)),`${t.username} successfully added`}a(W6,"addUser");async function z6(e){let t=Dv.cleanAttributes(e,Lv);if(Ri.isEmptyOrZeroLength(t.username))throw new Error(bv);if(Ri.isEmptyOrZeroLength(t.password)&&Ri.isEmptyOrZeroLength(t.role)&&Ri.isEmptyOrZeroLength(t.active))throw new Error(Ov);if(!Ri.isEmpty(t.password)&&Ri.isEmptyOrZeroLength(t.password.trim()))throw new Error(Nv);if(!Ri.isEmpty(t.active)&&!Ri.isBoolean(t.active))throw new Error(Iv);if(!Ri.isEmpty(t.password)&&!Ri.isEmptyOrZeroLength(t.password.trim())&&(Q6(t.username)&&(t.hash=ry.encrypt(t.password)),t.password=await qf.hash(t.password,ZR)),t.role==="")throw new Error(wv);if(t.role){let n=await $f.searchByValue({schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]});if(!n||n.length===0)throw new ks(iu.ALTER_USER_ROLE_NOT_FOUND(t.role),ro.NOT_FOUND);if(n.length>1)throw new ks(iu.DUP_ROLES_FOUND(t.role),ro.CONFLICT);t.role=n[0].id}let r=await Cv.update({operation:"update",schema:"system",table:"hdb_user",records:[t]});return await Cc(),ey.signalUserChange(new ny(process.pid)),r}a(z6,"alterUser");function Q6(e){let t=!1,r=yi.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(Q6,"isClusterUser");async function j6(e){let t=Pv.dropUserValidation(e);if(t)throw new ks(t.message);if(yi.get(e.username)===void 0)throw new ks(iu.USER_NOT_EXIST(e.username),ro.NOT_FOUND);let r=await Y6({table:"hdb_user",schema:"system",hash_values:[e.username]});return ty.debug(r),await Cc(),ey.signalUserChange(new ny(process.pid)),`${e.username} successfully deleted`}a(j6,"dropUser");async function J6(e){let t={};if(!e||!e.hdb_user)return"There was no user info in the body";t=XR.cloneDeep(e.hdb_user);let r=await $f.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(J6,"userInfo");async function X6(){let e=await Cp();return e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token,delete t.hash_function}),[...e.values()]}a(X6,"listUsersExternal");async function Cp(){let e=await $f.searchByValue({schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]}),t={};for(let s of e)t[s.id]=XR.cloneDeep(s);if(Object.keys(t).length===0)return null;let r=await $f.searchByValue({schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]}),n=new Map;for(let s of r)s=XR.cloneDeep(s),s.role=t[s.role],Z6(s.role),n.set(s.username,s);return n}a(Cp,"listUsers");function Z6(e){if(!e){ty.error("invalid user role found.");return}e.permission.system||(e.permission.system={}),e.permission.system.tables||(e.permission.system.tables={});for(let t of Object.keys($6)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}a(Z6,"appendSystemTablesToRole");async function Cc(e=void 0){e?yi=e:yi=await Cp()}a(Cc,"setUsersWithRolesCache");async function eZ(){return yi||await Cc(),yi}a(eZ,"getUsersWithRolesCache");async function sy(e,t,r=!0){yi||await Cc();let n=yi.get(e);if(!n){if(!r)return{username:e};throw new ks(jR.GENERIC_AUTH_FAIL,ro.UNAUTHORIZED)}if(n&&!n.active)throw new ks(jR.USER_INACTIVE,ro.UNAUTHORIZED);let s={active:n.active,username:n.username};if(n.refresh_token&&(s.refresh_token=n.refresh_token),n.role&&(s.role=n.role),r===!0){if(yv.get(t)===n.password)return s;{let i=qf.validate(n.password,t,n.hash_function||qf.HASH_FUNCTION.MD5);if(i?.then&&(i=await i),i===!0)yv.set(t,n.password);else throw new ks(jR.GENERIC_AUTH_FAIL,ro.UNAUTHORIZED)}}return s}a(sy,"findAndValidateUser");async function tZ(){yi||await Cc();for(let[,e]of yi)if(e.role.role==="super_user")return e}a(tZ,"getSuperUser");async function rZ(){let e=await Cp(),t=G6.getConfigFromFile(JR.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!(r==null||r?.role?.role!==JR.ROLE_TYPES_ENUM.CLUSTER_USER))return r.decrypt_hash=ry.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+Rv.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+Rv.SERVER_SUFFIX.ADMIN,r}a(rZ,"getClusterUser");var Mv=[];Ip.invalidateUser=function(e){for(let t of Mv)try{t(e)}catch(r){K6.error("Error invalidating user",r)}};Ip.onInvalidatedUser=function(e){Mv.push(e)}});var Kf=C((Nye,Bv)=>{"use strict";var Pc=J(),Gn=(H(),P($)),nZ=jL(),bye=Bs(),Oye=to(),sZ=Fn(),{validateEvent:vv}=Fs(),Vf=Bn(),iZ=require("process"),{resetDatabases:oZ}=(ve(),P(it)),aZ={[Gn.ITC_EVENT_TYPES.SCHEMA]:cZ,[Gn.ITC_EVENT_TYPES.USER]:xv};async function cZ(e){let t=vv(e);if(t){Pc.error(t);return}Pc.trace("ITC schemaHandler received schema event:",e),await nZ(e.message),await lZ(e.message)}a(cZ,"schemaHandler");async function lZ(e){try{Vf.resetReadTxn(Gn.SYSTEM_SCHEMA_NAME,Gn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),Vf.resetReadTxn(Gn.SYSTEM_SCHEMA_NAME,Gn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),Vf.resetReadTxn(Gn.SYSTEM_SCHEMA_NAME,Gn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=oZ();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){Pc.error(t)}}a(lZ,"syncSchemaMetadata");var Uv=[];async function xv(e){try{try{Vf.resetReadTxn(Gn.SYSTEM_SCHEMA_NAME,Gn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),Vf.resetReadTxn(Gn.SYSTEM_SCHEMA_NAME,Gn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){Pc.warn(r)}let t=vv(e);if(t){Pc.error(t);return}Pc.trace(`ITC userHandler ${Gn.HDB_ITC_CLIENT_PREFIX}${iZ.pid} received user event:`,e),await sZ.setUsersWithRolesCache();for(let r of Uv)r()}catch(t){Pc.error(t)}}a(xv,"userHandler");xv.addListener=function(e){Uv.push(e)};Bv.exports=aZ});var Fs=C((Lye,kv)=>{"use strict";var Iye=J(),iy=ae(),uZ=(H(),P($)),{ITC_ERRORS:Yf}=Cn(),{parentPort:Cye,threadId:dZ,isMainThread:fZ,workerData:Pye}=require("worker_threads"),{onMessageFromWorkers:_Z,broadcast:Dye,broadcastWithAcknowledgement:hZ}=rt();kv.exports={sendItcEvent:mZ,validateEvent:Hv,SchemaEventMsg:pZ,UserEventMsg:EZ};var Pp;_Z(async(e,t)=>{Pp=Pp||Kf(),Hv(e),Pp[e.type]&&await Pp[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function mZ(e){return!fZ&&e.message&&(e.message.originator=dZ),hZ(e)}a(mZ,"sendItcEvent");function Hv(e){if(typeof e!="object")return Yf.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||iy.isEmpty(e.type))return Yf.MISSING_TYPE;if(!e.hasOwnProperty("message")||iy.isEmpty(e.message))return Yf.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||iy.isEmpty(e.message.originator))return Yf.MISSING_ORIGIN;if(uZ.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return Yf.INVALID_EVENT(e.type)}a(Hv,"validateEvent");function pZ(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(pZ,"SchemaEventMsg");function EZ(e){this.originator=e}a(EZ,"UserEventMsg")});var no=C((Uye,$v)=>{"use strict";var Fv=(H(),P($)),vye=ae(),Dp=J(),Gv=WL(),ou,{sendItcEvent:qv}=Fs();function gZ(e){try{Dp.info("signalSchemaChange called with message:",e),ou=ou||Kf();let t=new Gv(Fv.ITC_EVENT_TYPES.SCHEMA,e);return ou.schema(t),qv(t)}catch(t){Dp.error(t)}}a(gZ,"signalSchemaChange");function SZ(e){try{Dp.trace("signalUserChange called with message:",e),ou=ou||Kf();let t=new Gv(Fv.ITC_EVENT_TYPES.USER,e);return ou.user(t),qv(t)}catch(t){Dp.error(t)}}a(SZ,"signalUserChange");$v.exports={signalSchemaChange:gZ,signalUserChange:SZ}});var Lp=C((Bye,Kv)=>{"use strict";var Vv=ae(),TZ=(H(),P($)),AZ=J(),RZ=_p(),yZ=fp(),bZ=no(),{SchemaEventMsg:OZ}=Fs(),NZ="already exists in";Kv.exports=wZ;async function wZ(e,t,r){if(Vv.isEmptyOrZeroLength(r))return r;let n=[];Vv.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 IZ(e,t.schema,t.name,i)})),s}a(wZ,"lmdbCheckForNewAttributes");async function IZ(e,t,r,n){let s=new yZ(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await CZ(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(NZ))AZ.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(IZ,"createNewAttribute");async function CZ(e){let t;return t=await RZ(e),bZ.signalSchemaChange(new OZ(process.pid,TZ.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(CZ,"createAttribute")});var au=C((kye,Yv)=>{"use strict";var oy=class{static{a(this,"LMDBTransactionObject")}constructor(t,r,n,s,i=void 0){this.operation=t,this.user_name=r,this.timestamp=n,this.hash_values=s,this.origin=i}};Yv.exports=oy});var zv=C((Gye,Wv)=>{"use strict";var PZ=au(),DZ=(H(),P($)).OPERATIONS_ENUM,ay=class extends PZ{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(DZ.INSERT,r,n,s,i),this.records=t}};Wv.exports=ay});var jv=C(($ye,Qv)=>{"use strict";var LZ=au(),MZ=(H(),P($)).OPERATIONS_ENUM,cy=class extends LZ{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(MZ.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};Qv.exports=cy});var Xv=C((Kye,Jv)=>{"use strict";var vZ=au(),UZ=(H(),P($)).OPERATIONS_ENUM,ly=class extends vZ{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(UZ.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};Jv.exports=ly});var eU=C((Wye,Zv)=>{"use strict";var xZ=au(),BZ=(H(),P($)).OPERATIONS_ENUM,uy=class extends xZ{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(BZ.DELETE,n,s,t,i),this.original_records=r}};Zv.exports=uy});var Wf=C((jye,sU)=>{"use strict";var Qye=require("path"),tU=dt(),HZ=zv(),kZ=jv(),FZ=Xv(),GZ=eU(),cu=Ut(),rU=ae(),{CONFIG_PARAMS:qZ}=(H(),P($)),nU=ce();nU.initSync();var Mp=(H(),P($)).OPERATIONS_ENUM,{getTransactionAuditStorePath:$Z}=Et();sU.exports=VZ;async function VZ(e,t){if(nU.get(qZ.LOGGING_AUDITLOG)===!1)return;let r=$Z(e.schema,e.table),n=await tU.openEnvironment(r,e.table,!0),s=KZ(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){tU.initializeDBIs(n,cu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,cu.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[cu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[cu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),rU.isEmpty(s.user_name)||n.dbis[cu.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[cu.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(VZ,"writeTransaction");function KZ(e,t){let r=rU.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===Mp.INSERT)return new HZ(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Mp.UPDATE)return new kZ(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Mp.UPSERT)return new FZ(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Mp.DELETE)return new GZ(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(KZ,"createTransactionObject")});var dy=C((Zye,iU)=>{"use strict";var YZ=Pf(),Xye=sf(),zf=(H(),P($)),WZ=of(),zZ=Sc().insertRecords,QZ=dt(),jZ=J(),JZ=Lp(),{getSchemaPath:XZ}=Et(),ZZ=Wf();iU.exports=e8;async function e8(e){try{let{schema_table:t,attributes:r}=YZ(e);WZ(e,r,t.hash_attribute),e.schema!==zf.SYSTEM_SCHEMA_NAME&&(r.includes(zf.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(zf.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(zf.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(zf.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await JZ(e.hdb_auth_header,t,r),s=XZ(e.schema,e.table),i=await QZ.openEnvironment(s,e.table),o=await zZ(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await ZZ(e,o)}catch(c){jZ.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(e8,"lmdbCreateRecords")});var cU=C((tbe,aU)=>{"use strict";var oU=(H(),P($)),t8=dy(),r8=sf(),n8=require("fs-extra"),{getSchemaPath:s8}=Et();aU.exports=i8;async function i8(e){let t=[{name:e.schema,createddate:Date.now()}],r=new r8(oU.SYSTEM_SCHEMA_NAME,oU.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await t8(r),await n8.mkdirp(s8(e.schema))}a(i8,"lmdbCreateSchema")});var uU=C((nbe,lU)=>{"use strict";var fy=class{static{a(this,"DeleteRecordsResponseObject")}constructor(t=[],r=[],n=void 0,s=[]){this.deleted=t,this.skipped=r,this.txn_time=n,this.original_records=s}};lU.exports=fy});var hU=C((cbe,_U)=>{"use strict";var dU=dt(),_y=cn(),hy=Cn().LMDB_ERRORS_ENUM,o8=Ut(),fU=J(),ibe=ae(),a8=require("lmdb"),c8=uU(),l8=(H(),P($)),{OVERFLOW_MARKER:obe,MAX_SEARCH_KEY_LENGTH:abe}=o8,u8=l8.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function d8(e,t,r,n){if(_y.validateEnv(e),t===void 0)throw new Error(hy.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(hy.IDS_REQUIRED):new Error(hy.IDS_MUST_BE_ITERABLE);try{let s=dU.listDBIs(e);dU.initializeDBIs(e,t,s);let i=new c8,o,c=[],l=[];for(let h=0,_=r.length;h<_;h++)try{o=r[h];let m=e.dbis[t].get(o);if(!m||n&&m[u8]>n){i.skipped.push(o);continue}let S=e.dbis[t].ifVersion(o,a8.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],A=m[R];if(A!=null)try{let N=_y.getIndexedValues(A);if(N)for(let v=0,F=N.length;v<F;v++)E.remove(N[v],o)}catch{fU.warn(`cannot delete from attribute: ${R}, ${A}:${o}`)}}});c.push(S),l.push(o),i.original_records.push(m)}catch(m){fU.warn(m),i.skipped.push(o)}let u=[],f=await Promise.all(c);for(let h=0,_=f.length;h<_;h++)f[h]===!0?i.deleted.push(l[h]):(i.skipped.push(l[h]),u.push(h));let d=0;for(let h=0;h<u.length;h++){let _=u[h];i.original_records.splice(_-d,1),d++}return i.txn_time=_y.getNextMonotonicTime(),i}catch(s){throw s}}a(d8,"deleteRecords");_U.exports={deleteRecords:d8}});var Qf=C((ube,pU)=>{"use strict";var lu=ae(),f8=hU(),_8=dt(),{getSchemaPath:h8}=Et(),m8=Wf(),p8=J();pU.exports=E8;async function E8(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(lu.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(lu.isEmptyOrZeroLength(e.hash_values)&&!lu.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];lu.isEmpty(l)||e.hash_values.push(l)}}if(lu.isEmptyOrZeroLength(e.hash_values))return mU([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(lu.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=h8(e.schema,e.table),i=await _8.openEnvironment(s,e.table),o=await f8.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await m8(e,o)}catch(c){p8.error(`unable to write transaction due to ${c.message}`)}return mU(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(E8,"lmdbDeleteRecords");function mU(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(mU,"createDeleteResponse")});var py=C((_be,EU)=>{"use strict";var g8=(H(),P($)),fbe=cn();function my(e,t){let r=Object.create(null);if(t.length===1&&g8.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(my,"parseRow");function S8(e,t,r,n){let s=my(r,e);n.push(s)}a(S8,"searchAll");function T8(e,t,r,n){let s=my(r,e);n[t]=s}a(T8,"searchAllToMap");function A8(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(A8,"iterateDBI");function Dc(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(Dc,"pushResults");function R8(e,t,r,n,s,i){t.toString().endsWith(e)&&Dc(t,r,n,s,i)}a(R8,"endsWith");function y8(e,t,r,n,s,i){t.toString().includes(e)&&Dc(t,r,n,s,i)}a(y8,"contains");function b8(e,t,r,n,s,i){t>e&&Dc(t,r,n,s,i)}a(b8,"greaterThanCompare");function O8(e,t,r,n,s,i){t>=e&&Dc(t,r,n,s,i)}a(O8,"greaterThanEqualCompare");function N8(e,t,r,n,s,i){t<e&&Dc(t,r,n,s,i)}a(N8,"lessThanCompare");function w8(e,t,r,n,s,i){t<=e&&Dc(t,r,n,s,i)}a(w8,"lessThanEqualCompare");EU.exports={parseRow:my,searchAll:S8,searchAllToMap:T8,iterateDBI:A8,endsWith:R8,contains:y8,greaterThanCompare:b8,greaterThanEqualCompare:O8,lessThanCompare:N8,lessThanEqualCompare:w8,pushResults:Dc}});var uu=C((gbe,bU)=>{"use strict";var oa=dt(),mbe=J(),qn=cn(),vp=Ut(),Kt=Cn().LMDB_ERRORS_ENUM,pbe=ae(),I8=(H(),P($)),Up=py(),{parseRow:C8}=Up,Ebe=require("lmdb"),{OVERFLOW_MARKER:gU,MAX_SEARCH_KEY_LENGTH:P8}=vp;function SU(e,t,r,n=!1,s=void 0,i=void 0){return Lc(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(SU,"iterateFullIndex");function jf(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,u=!1){return Lc(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 _===r?(E.values=!1,d.getRange(E).map(A=>({value:A}))):d.getRange(E)})}a(jf,"iterateRangeBetween");function Lc(e,t,r,n){let s=e.database||e,i=oa.openDBI(s,r);i[vp.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&oa.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(Lc,"setupTransaction");function TU(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(gU)){if(!s)if(r)s=oa.openDBI(e,r);else{let l=oa.listDBIs(e);for(let u=0,f=l.length;u<f&&(s=oa.openDBI(e,l[u]),!s[vp.DBI_DEFINITION_NAME].is_hash_attribute);u++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(TU,"getOverflowCheck");function D8(e,t,r,n=!1,s=void 0,i=void 0){if(qn.validateEnv(e),t===void 0)throw new Error(Kt.HASH_ATTRIBUTE_REQUIRED);return Lc(e,t,t,(o,c,l)=>(xp(r),r=Jf(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(u=>C8(u.value,r))))}a(D8,"searchAll");function L8(e,t,r,n=!1,s=void 0,i=void 0){if(qn.validateEnv(e),t===void 0)throw new Error(Kt.HASH_ATTRIBUTE_REQUIRED);xp(r),r=Jf(e.database||e,r);let o=new Map;for(let{key:c,value:l}of SU(e,t,t,n,s,i))o.set(c,Up.parseRow(l,r));return o}a(L8,"searchAllToMap");function M8(e,t,r=!1,n=void 0,s=void 0){if(qn.validateEnv(e),t===void 0)throw new Error(Kt.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=SU(e,void 0,t,r,n,s),c=o.transaction,l=TU(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(M8,"iterateDBI");function v8(e,t){if(qn.validateEnv(e),t===void 0)throw new Error(Kt.HASH_ATTRIBUTE_REQUIRED);return oa.statDBI(e,t).entryCount}a(v8,"countAll");function U8(e,t,r,n,s=!1,i=void 0,o=void 0){return aa(e,r,n),Lc(e,t,r,(c,l,u,f)=>(n=qn.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(U8,"equals");function x8(e,t,r){return aa(e,t,r),oa.openDBI(e,t).getValuesCount(r)}a(x8,"count");function B8(e,t,r,n,s=!1,i=void 0,o=void 0){return aa(e,r,n),Lc(e,null,r,(c,l)=>{n=qn.convertKeyValueToWrite(n);let u=!0;typeof n=="number"&&(u=!1);let f;if(s===!0){let d;for(let h of l.getKeys({transaction:c,start:n}))if(!h.startsWith(n)){d=h;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(h=>{let{key:_}=h;if(_!==d){if(_.toString().startsWith(n))return h;if(u===!0)return f.DONE}}),f.filter(h=>h)}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(B8,"startsWith");function H8(e,t,r,n,s=!1,i=void 0,o=void 0){return AU(e,t,r,n,s,i,o,!0)}a(H8,"endsWith");function AU(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return aa(e,r,n),Lc(e,null,r,(l,u,f,d)=>{let h=TU(f,l,d,r);return o=Number.isInteger(o)?o:0,u.getKeys({transaction:l,end:s?!1:void 0,reverse:s}).flatMap(_=>{let m=_.toString();return m.endsWith(gU)?u.getValues(_,{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[vp.DBI_DEFINITION_NAME].is_hash_attribute?{key:_,value:_}:u.getValues(_,{transaction:l}).map(S=>({key:_,value:S})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a(AU,"contains");function k8(e,t,r,n,s=!1,i=void 0,o=void 0){aa(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),jf(e,t,r,n,l,s,i,o,!0,!1)}a(k8,"greaterThan");function F8(e,t,r,n,s=!1,i=void 0,o=void 0){aa(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),jf(e,t,r,n,l,s,i,o,!1,!1)}a(F8,"greaterThanEqual");function G8(e,t,r,n,s=!1,i=void 0,o=void 0){aa(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),jf(e,t,r,l,n,s,i,o,!1,!0)}a(G8,"lessThan");function q8(e,t,r,n,s=!1,i=void 0,o=void 0){aa(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),jf(e,t,r,l,n,s,i,o,!1,!1)}a(q8,"lessThanEqual");function $8(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(qn.validateEnv(e),r===void 0)throw new Error(Kt.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(Kt.START_VALUE_REQUIRED);if(s===void 0)throw new Error(Kt.END_VALUE_REQUIRED);if(n=qn.convertKeyValueToWrite(n),s=qn.convertKeyValueToWrite(s),n>s)throw new Error(Kt.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return jf(e,t,r,n,s,i,o,c)}a($8,"between");function V8(e,t,r,n){qn.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(Kt.HASH_ATTRIBUTE_REQUIRED);if(xp(r),r=Jf(s,r),n===void 0)throw new Error(Kt.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=Up.parseRow(c,r)),o}a(V8,"searchByHash");function K8(e,t,r){qn.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(Kt.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Kt.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(K8,"checkHashExists");function Y8(e,t,r,n,s=[]){return yU(e,t,r,n,s),RU(e,t,r,n,s).map(i=>i[1])}a(Y8,"batchSearchByHash");function W8(e,t,r,n,s=[]){yU(e,t,r,n,s);let i=new Map;for(let[o,c]of RU(e,t,r,n,s))i.set(o,c);return i}a(W8,"batchSearchByHashToMap");function RU(e,t,r,n,s=[]){return Lc(e,t,t,(i,o,c)=>{r=Jf(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,Up.parseRow(f,r)];s.push(u)}).filter(u=>u)})}a(RU,"batchHashSearch");function yU(e,t,r,n,s){if(qn.validateEnv(e),t===void 0)throw new Error(Kt.HASH_ATTRIBUTE_REQUIRED);if(xp(r),n==null)throw new Error(Kt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(Kt.IDS_MUST_BE_ITERABLE)}a(yU,"initializeBatchSearchByHash");function xp(e){if(!Array.isArray(e))throw e===void 0?new Error(Kt.FETCH_ATTRIBUTES_REQUIRED):new Error(Kt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(xp,"validateFetchAttributes");function aa(e,t,r){if(qn.validateEnv(e),t===void 0)throw new Error(Kt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Kt.SEARCH_VALUE_REQUIRED);if(r?.length>P8)throw new Error(Kt.SEARCH_VALUE_TOO_LARGE)}a(aa,"validateComparisonFunctions");function Jf(e,t){return t.length===1&&I8.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=oa.listDBIs(e)),t}a(Jf,"setGetWholeRowAttributes");bU.exports={searchAll:D8,searchAllToMap:L8,count:x8,countAll:v8,equals:U8,startsWith:B8,endsWith:H8,contains:AU,searchByHash:V8,setGetWholeRowAttributes:Jf,batchSearchByHash:Y8,batchSearchByHashToMap:W8,checkHashExists:K8,iterateDBI:M8,greaterThan:k8,greaterThanEqual:F8,lessThan:G8,lessThanEqual:q8,between:$8}});var du=C((Tbe,CU)=>{var OU=require("lodash"),NU=nt(),ke=require("joi"),z8=ae(),{hdb_schema_table:Xf,checkValidTable:wU,hdb_table:IU,hdb_database:Bp}=gi(),{handleHDBError:Q8,hdb_errors:j8}=he(),{getDatabases:J8}=(ve(),P(it)),{HTTP_STATUS_CODES:X8}=j8,Z8=ke.object({database:Bp,schema:Bp,table:IU,search_attribute:Xf,search_value:ke.any().required(),get_attributes:ke.array().min(1).items(ke.alternatives(Xf,ke.object())).optional(),desc:ke.bool(),limit:ke.number().integer().min(1),offset:ke.number().integer().min(0)}),e5=ke.object({database:Bp,schema:Bp,table:IU,operator:ke.string().valid("and","or").default("and").lowercase(),offset:ke.number().integer().min(0),limit:ke.number().integer().min(1),get_attributes:ke.array().min(1).items(ke.alternatives(Xf,ke.object())).optional(),sort:ke.object({attribute:ke.alternatives(Xf,ke.array().min(1)),descending:ke.bool().optional()}).optional(),conditions:ke.array().min(1).items(ke.alternatives(ke.object({operator:ke.string().valid("and","or").default("and").lowercase(),conditions:ke.array()}),ke.object({search_attribute:ke.alternatives(Xf,ke.array().min(1)),search_type:ke.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:ke.when("search_type",{switch:[{is:"equals",then:ke.any()},{is:"between",then:ke.array().items(ke.alternatives([ke.string(),ke.number()])).length(2)}],otherwise:ke.alternatives(ke.string(),ke.number())}).required()}))).required()});CU.exports=function(e,t){let r=null;switch(t){case"value":r=NU.validateBySchema(e,Z8);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(wU("database",e.schema)),i(wU("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=NU.validateBySchema(e,e5);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=z8.checkGlobalSchemaTable(e.schema,e.table);if(s)return Q8(new Error,s,X8.NOT_FOUND);let o=J8()[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,h=f.conditions.length;d<h;d++){let _=f.conditions[d];_.conditions?l(_):c.push(_.search_attribute)}},"addConditions");t==="conditions"&&l(e);let u=OU.filter(c,f=>f!=="*"&&!f.startsWith?.("$")&&f.attribute!=="*"&&!Array.isArray(f)&&!f.name&&!OU.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 Ey=C((Rbe,PU)=>{"use strict";var t5=dt(),r5=du(),{getSchemaPath:n5}=Et();PU.exports=s5;function s5(e){let t=r5(e,"hashes");if(t)throw t;let r=n5(e.schema,e.table);return t5.openEnvironment(r,e.table)}a(s5,"initialize")});var gy=C((bbe,DU)=>{"use strict";var i5=uu(),o5=Ey();DU.exports=a5;async function a5(e){let t=await o5(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return i5.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(a5,"lmdbGetDataByHash")});var fu=C((Nbe,LU)=>{"use strict";var Sy=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};LU.exports=Sy});var vU=C((Cbe,MU)=>{"use strict";var Ibe=fu(),c5=uu(),l5=Ey();MU.exports=u5;async function u5(e){let t=await l5(e),r=global.hdb_schema[e.schema][e.table];return c5.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(u5,"lmdbSearchByHash")});var Gs=C((Dbe,UU)=>{"use strict";var Ty=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}};UU.exports=Ty});var Hp=C((Mbe,GU)=>{"use strict";var Wr=uu(),d5=dt(),f5=ae(),Fe=Ut(),Mc=(H(),P($)),_5=Ji(),xU=Cn().LMDB_ERRORS_ENUM,{getSchemaPath:h5}=Et(),so=Mc.SEARCH_WILDCARDS;async function m5(e,t,r){let n;e.schema===Mc.SYSTEM_SCHEMA_NAME?n=_5[e.table]:n=global.hdb_schema[e.schema][e.table];let s=FU(e,n.hash_attribute,r,t);return HU(e,s,n.hash_attribute,r)}a(m5,"prepSearch");async function HU(e,t,r,n){let s=h5(e.schema,e.table),i=await d5.openEnvironment(s,e.table),o=kU(i,e,t,r),c=o.transaction||i;if([Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,Fe.SEARCH_TYPES.SEARCH_ALL,Fe.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(p5(e,r)===!1){let f=e.search_attribute;if(f===r)return n?BU(o,()=>!0):o.map(h=>({[r]:h.key}));let d=a(h=>({[r]:h.value,[f]:h.key}),"toObject");return n?BU(o,d):o.map(d)}let u=e.search_attribute===r?o.map(f=>f.key):o.map(f=>f.value);return n===!0?Wr.batchSearchByHashToMap(c,r,e.get_attributes,u):Wr.batchSearchByHash(c,r,e.get_attributes,u)}a(HU,"executeSearch");function kU(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 Fe.SEARCH_TYPES.EQUALS:s=Wr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.CONTAINS:s=Wr.contains(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.ENDS_WITH:case Fe.SEARCH_TYPES._ENDS_WITH:s=Wr.endsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.STARTS_WITH:case Fe.SEARCH_TYPES._STARTS_WITH:s=Wr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return Wr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return Wr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case Fe.SEARCH_TYPES.SEARCH_ALL:return Wr.searchAll(e,n,t.get_attributes,o,c,l);case Fe.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return Wr.searchAllToMap(e,n,t.get_attributes,o,c,l);case Fe.SEARCH_TYPES.BETWEEN:s=Wr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,l);break;case Fe.SEARCH_TYPES.GREATER_THAN:case Fe.SEARCH_TYPES._GREATER_THAN:s=Wr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.GREATER_THAN_EQUAL:case Fe.SEARCH_TYPES._GREATER_THAN_EQUAL:s=Wr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.LESS_THAN:case Fe.SEARCH_TYPES._LESS_THAN:s=Wr.lessThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case Fe.SEARCH_TYPES.LESS_THAN_EQUAL:case Fe.SEARCH_TYPES._LESS_THAN_EQUAL:s=Wr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;default:return Object.create(null)}return s}a(kU,"searchByType");function BU(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(BU,"createMapFromIterable");function p5(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(p5,"checkToFetchMore");function FU(e,t,r,n){if(f5.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?Fe.SEARCH_TYPES.SEARCH_ALL_TO_MAP:Fe.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(so[0])<0&&s.indexOf(so[1])<0)return c===!0?r===!0?Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:Fe.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:Fe.SEARCH_TYPES.EQUALS;if(so.indexOf(i)>=0&&so.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),Fe.SEARCH_TYPES.CONTAINS;if(so.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),Fe.SEARCH_TYPES.ENDS_WITH;if(so.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),Fe.SEARCH_TYPES.STARTS_WITH;if(s.includes(so[0])||s.includes(so[1]))return Fe.SEARCH_TYPES.EQUALS;throw new Error(xU.UNKNOWN_SEARCH_TYPE)}else switch(n){case Mc.VALUE_SEARCH_COMPARATORS.BETWEEN:return Fe.SEARCH_TYPES.BETWEEN;case Mc.VALUE_SEARCH_COMPARATORS.GREATER:return Fe.SEARCH_TYPES.GREATER_THAN;case Mc.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return Fe.SEARCH_TYPES.GREATER_THAN_EQUAL;case Mc.VALUE_SEARCH_COMPARATORS.LESS:return Fe.SEARCH_TYPES.LESS_THAN;case Mc.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return Fe.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(xU.UNKNOWN_SEARCH_TYPE)}}a(FU,"createSearchTypeFromSearchObject");GU.exports={executeSearch:HU,createSearchTypeFromSearchObject:FU,prepSearch:m5,searchByType:kU}});var $U=C((xbe,qU)=>{"use strict";var Ube=Gs(),E5=du(),g5=ae(),S5=(H(),P($)),T5=Hp();qU.exports=A5;function A5(e,t){if(!g5.isEmpty(t)&&S5.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=E5(e,"value");if(n)throw n;return T5.prepSearch(e,t,!0)}a(A5,"lmdbGetDataByValue")});var Zf=C((kbe,VU)=>{"use strict";var Hbe=Gs(),R5=du(),y5=ae(),b5=(H(),P($)),O5=Hp();VU.exports=N5;async function N5(e,t){if(!y5.isEmpty(t)&&b5.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=R5(e,"value");if(n)throw n;return O5.prepSearch(e,t,!1)}a(N5,"lmdbSearchByValue")});var YU=C((qbe,KU)=>{"use strict";var Gbe=Ut(),Ay=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}},Ry=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},yy=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};KU.exports={SearchByConditionsObject:Ay,SearchCondition:Ry,SortAttribute:yy}});var JU=C((Ybe,jU)=>{"use strict";var Vbe=YU().SearchByConditionsObject,w5=Gs(),I5=du(),by=uu(),kp=Ut(),{Resource:Kbe}=(Jo(),P(RA)),QU=Hp(),C5=py(),P5=require("lodash"),{getSchemaPath:D5}=Et(),WU=dt(),{handleHDBError:L5,hdb_errors:M5}=he(),{HTTP_STATUS_CODES:v5}=M5,U5=1e8;jU.exports=x5;async function x5(e){let t=I5(e,"conditions");if(t)throw L5(t,t.message,v5.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=D5(e.schema,e.table),n=await WU.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let u of e.conditions)WU.openDBI(n,u.search_attribute);let i=P5.sortBy(e.conditions,u=>{if(u.estimated_count===void 0){let f=u.search_type;f===kp.SEARCH_TYPES.EQUALS?u.estimated_count=by.count(n,u.search_attribute,u.search_value):f===kp.SEARCH_TYPES.CONTAINS||f===kp.SEARCH_TYPES.ENDS_WITH?u.estimated_count=1/0:u.estimated_count=U5}return u.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await zU(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(QU.filterByType),d=f.length,h=by.setGetWholeRowAttributes(n,e.get_attributes);l=c.map(_=>u.get(_,{transaction:o,lazy:!0})),d>0&&(l=l.filter(_=>{for(let m=0;m<d;m++)if(!f[m](_))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(_=>C5.parseRow(_,h))}else{for(let d=1;d<i.length;d++){let h=i[d],_=await zU(o,e,h,s.hash_attribute);c=c.concat(_)}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=by.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(x5,"lmdbSearchByConditions");async function zU(e,t,r,n){let s=new w5(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===kp.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,QU.searchByType(e,s,i,n).map(o=>o.value)}a(zU,"executeConditionSearch")});var e_=C((zbe,XU)=>{"use strict";var B5=(H(),P($)).OPERATIONS_ENUM,Oy=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=B5.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};XU.exports=Oy});var Ny=C((jbe,o0)=>{"use strict";var r0=Gs(),n0=e_(),s0=Zf(),i0=Qf(),En=(H(),P($)),ZU=ae(),e0=dt(),{getTransactionAuditStorePath:H5,getSchemaPath:k5}=Et(),t0=J();o0.exports=F5;async function F5(e){try{if(ZU.isEmpty(global.hdb_schema[e.schema])||ZU.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await G5(e),await q5(e);let t=k5(e.schema,e.table);try{await e0.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")t0.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=H5(e.schema,e.table);await e0.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")t0.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(F5,"lmdbDropTable");async function G5(e){let t=new r0(En.SYSTEM_SCHEMA_NAME,En.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,En.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[En.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await s0(t)),n=[];for(let i=0;i<r.length;i++){let o=r[i];n.push(o.id)}if(n.length===0)return;let s=new n0(En.SYSTEM_SCHEMA_NAME,En.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await i0(s)}a(G5,"deleteAttributesFromSystem");async function q5(e){let t=new r0(En.SYSTEM_SCHEMA_NAME,En.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,En.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[En.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,En.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,En.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await s0(t))}catch(i){throw i}for(let i=0;i<r.length;i++){let o=r[i];o.name===e.table&&o.schema===e.schema&&(n=o)}if(!n)throw new Error(`${e.schema}.${e.table} was not found`);let s=new n0(En.SYSTEM_SCHEMA_NAME,En.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await i0(s)}catch(i){throw i}}a(q5,"dropTableFromSystem")});var c0=C((Xbe,a0)=>{"use strict";var $5=require("fs-extra"),V5=Gs(),K5=fu(),Y5=e_(),W5=Ny(),z5=Qf(),Q5=gy(),j5=Zf(),io=(H(),P($)),{getSchemaPath:J5}=Et(),{handleHDBError:X5,hdb_errors:Z5}=he(),{HDB_ERROR_MSGS:e9,HTTP_STATUS_CODES:t9}=Z5;a0.exports=r9;async function r9(e){let t;try{t=await n9(e.schema);let r=new V5(io.SYSTEM_SCHEMA_NAME,io.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,io.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[io.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await j5(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await W5(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new Y5(io.SYSTEM_SCHEMA_NAME,io.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await z5(s);let i=J5(t);await $5.remove(i)}catch(r){throw r}}a(r9,"lmdbDropSchema");async function n9(e){let t=new K5(io.SYSTEM_SCHEMA_NAME,io.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[io.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await Q5(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw X5(new Error,e9.SCHEMA_NOT_FOUND(e),t9.NOT_FOUND,void 0,void 0,!0);return n}a(n9,"validateDropSchema")});var t_=C((eOe,l0)=>{"use strict";var wy=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};l0.exports=wy});var Cy=C((nOe,u0)=>{"use strict";var s9=require("fs-extra"),Fp=dt(),{getTransactionAuditStorePath:i9}=Et(),Iy=Ut(),rOe=t_();u0.exports=o9;async function o9(e){let t;try{let r=i9(e.schema,e.table);await s9.mkdirp(r),t=await Fp.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{Fp.createDBI(t,Iy.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),Fp.createDBI(t,Iy.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),Fp.createDBI(t,Iy.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(o9,"createTransactionsAuditEnvironment")});var _0=C((oOe,f0)=>{"use strict";var Py=(H(),P($)),d0=dt(),a9=Sc(),{getSystemSchemaPath:c9,getSchemaPath:l9}=Et(),iOe=Ji(),u9=_p(),Dy=fp(),d9=J(),f9=Cy();f0.exports=_9;async function _9(e,t){let r=l9(t.schema,t.table),n=new Dy(t.schema,t.table,Py.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new Dy(t.schema,t.table,Py.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new Dy(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await d0.createEnvironment(r,t.table),e!==void 0){let o=await d0.openEnvironment(c9(),Py.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await a9.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 Ly(n),await Ly(s),await Ly(i)}await f9(t)}catch(o){throw o}}a(_9,"lmdbCreateTable");async function Ly(e){try{await u9(e)}catch(t){d9.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(Ly,"createAttribute")});var m0=C((cOe,h0)=>{"use strict";var h9=Pf(),m9=of(),p9=Lp(),r_=(H(),P($)),E9=Sc().updateRecords,g9=dt(),{getSchemaPath:S9}=Et(),T9=Wf(),A9=J();h0.exports=R9;async function R9(e){try{let{schema_table:t,attributes:r}=h9(e);m9(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 p9(e.hdb_auth_header,t,r),s=S9(e.schema,e.table),i=await g9.openEnvironment(s,e.table),o=await E9(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await T9(e,o)}catch(c){A9.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(R9,"lmdbUpdateRecords")});var E0=C((uOe,p0)=>{"use strict";var y9=(H(),P($)).OPERATIONS_ENUM,My=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=y9.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};p0.exports=My});var S0=C((_Oe,g0)=>{"use strict";var fOe=E0(),b9=Pf(),O9=of(),N9=Lp(),n_=(H(),P($)),w9=Sc().upsertRecords,I9=dt(),{getSchemaPath:C9}=Et(),P9=Wf(),D9=J(),{handleHDBError:L9,hdb_errors:M9}=he();g0.exports=v9;async function v9(e){let t;try{t=b9(e)}catch(l){throw L9(l,l.message,M9.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;O9(e,n,r.hash_attribute),e.schema!==n_.SYSTEM_SCHEMA_NAME&&(n.includes(n_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(n_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(n_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(n_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await N9(e.hdb_auth_header,r,n),i=C9(e.schema,e.table),o=await I9.openEnvironment(i,e.table),c=await w9(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await P9(e,c)}catch(l){D9.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(v9,"lmdbUpsertRecords")});var A0=C((mOe,T0)=>{"use strict";var vy=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};T0.exports=vy});var y0=C((EOe,R0)=>{"use strict";var Uy=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}};R0.exports=Uy});var N0=C((TOe,O0)=>{"use strict";var xy=dt(),{getTransactionAuditStorePath:U9}=Et(),SOe=A0(),s_=Ut(),x9=ae(),b0=y0(),B9=require("util").promisify,H9=B9(setTimeout),k9=1e4,F9=100;O0.exports=G9;async function G9(e){let t=U9(e.schema,e.table),r=await xy.openEnvironment(t,e.table,!0),n=xy.listDBIs(r);xy.initializeDBIs(r,s_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new b0;do s=await q9(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 H9(F9);while(s.transactions_deleted>0);return i}a(G9,"deleteAuditLogsBefore");async function q9(e,t){let r=new b0;try{let n=e.dbis[s_.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[s_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];x9.isEmpty(c)||(s=e.dbis[s_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[s_.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>k9)break}return await s,r}catch(n){throw n}}a(q9,"deleteTransactions")});var I0=C((ROe,w0)=>{"use strict";var By=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};w0.exports=By});var P0=C((OOe,C0)=>{"use strict";var $9=Gs(),V9=e_(),bOe=I0(),bi=(H(),P($)),K9=ae(),Hy=dt(),Y9=Ji(),W9=Zf(),z9=Qf(),{getSchemaPath:Q9}=Et();C0.exports=j9;async function j9(e,t=!0){let r;e.schema===bi.SYSTEM_SCHEMA_NAME?r=Y9[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await X9(e),s=Q9(e.schema,e.table),i=await Hy.openEnvironment(s,e.table);return t===!0&&await J9(e,i,r.hash_attribute),Hy.dropDBI(i,e.attribute),n}a(j9,"lmdbDropAttribute");async function J9(e,t,r){let n=Hy.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(J9,"removeAttributeFromAllObjects");async function X9(e){let t=new $9(bi.SYSTEM_SCHEMA_NAME,bi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await W9(t)).filter(o=>o[bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(K9.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[bi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new V9(bi.SYSTEM_SCHEMA_NAME,bi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return z9(i)}a(X9,"dropAttributeFromSystem")});var x0=C((IOe,U0)=>{"use strict";var ky=dt(),_u=Ut(),wOe=cn(),Fy=(H(),P($)),D0=ae(),{getTransactionAuditStorePath:Z9}=Et(),e7=uu(),Gp=au(),t7=J();U0.exports=r7;async function r7(e){let t=Z9(e.schema,e.table),r=await ky.openEnvironment(t,e.table,!0),n=ky.listDBIs(r);ky.initializeDBIs(r,_u.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case Fy.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return L0(r,e.search_values);case Fy.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,s7(r,e.search_values,s);case Fy.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return n7(r,e.search_values);default:return L0(r)}}a(r7,"readAuditLog");function L0(e,t=[0,Date.now()]){D0.isEmpty(t[0])&&(t[0]=0),D0.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[_u.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 Gp,s))}a(L0,"searchTransactionsByTimestamp");function n7(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[_u.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,v0(e,i))}return Object.fromEntries(r)}a(n7,"searchTransactionsByUsername");function s7(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let u=t[c],f=e7.equals(e,_u.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,_u.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,u);for(let{value:d}of f){let h=Number(d);n.has(h)?n.get(h).push(u.toString()):n.set(h,[u.toString()])}}let s=Array.from(n.keys()),i=v0(e,s),o=new Map;for(let c=0;c<i.length;c++){let l=i[c],u=l.timestamp,f=n.get(u);M0(l,"records",r,f,o),M0(l,"original_records",r,f,o)}return Object.fromEntries(o)}a(s7,"searchTransactionsByHashValues");function M0(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 Gp(e.operation,e.user_name,i,void 0);d[t]=[c],u.push(d)}}else{let u=new Gp(e.operation,e.user_name,i,void 0);u[t]=[c],s.set(l,[u])}}}a(M0,"loopRecords");function v0(e,t){let r=[];try{let n=e.dbis[_u.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 Gp,i);r.push(o)}}catch(i){t7.warn(i)}return r}catch(n){throw n}}a(v0,"batchSearchTransactions")});var H0=C((LOe,B0)=>{"use strict";var{getSchemaPath:POe}=Et(),DOe=dt(),{database:i7}=(ve(),P(it));B0.exports={writeTransaction:o7};async function o7(e,t,r){return i7({database:e,table:t}).transaction(r)}a(o7,"writeTransaction")});var q0=C((vOe,G0)=>{"use strict";var{getSchemaPath:k0}=Et(),F0=dt();G0.exports={flush:a7,resetReadTxn:c7};async function a7(e,t){return(await F0.openEnvironment(k0(e,t),t.toString())).flushed}a(a7,"flush");async function c7(e,t){try{(await F0.openEnvironment(k0(e,t),t.toString())).resetReadTxn()}catch{}}a(c7,"resetReadTxn")});var Y0=C((xOe,K0)=>{"use strict";var{Readable:l7}=require("stream"),{getDatabases:u7}=(ve(),P(it)),{readSync:d7,openSync:f7,createReadStream:$0}=require("fs"),{open:_7}=require("lmdb"),V0=Of(),h7=Nf(),{AUDIT_STORE_OPTIONS:m7}=(Qi(),P(W0)),{INTERNAL_DBIS_NAME:p7,AUDIT_STORE_NAME:E7}=Ut();K0.exports=S7;var Gy=32768,g7=100;async function S7(e){let t=e.database||e.schema||"data",r=u7()[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=_7({noSync:!0,maxDbs:h7.MAX_DBS}),h,_=d.openDB(p7,new V0(!1)),m=f.useReadTransaction(),S=0,g=a(async function(E,A){A.encoding="binary",A.encoder=void 0;let N=d.openDB(E,A),v=f.openDB(E,A);for(let{key:F,version:q,value:Y}of v.getRange({start:null,transaction:m,versions:v.useVersions}))h=N.put(F,Y,q),S++%g7===0&&(await new Promise(ee=>setTimeout(ee,20)),m.openTimer&&(m.openTimer=0))},"copyDatabase");for(let{key:E,value:A}of f.getRange({transaction:m,start:!1}))if(s.some(N=>E.startsWith?.(N+"/"))){_.put(E,A);let[,N]=E.split("/"),v=!N,F=new V0(!v,v);await g(E,F)}e.include_audit&&await g(E7,{...m7}),await h;let R=$0(d.path);return R.headers=l(),R.on("close",()=>{m.done(),d.close()}),R}let o=r[Object.keys(r)[0]].primaryStore,c=f7(o.path);return o.transaction(()=>{let u=Buffer.alloc(Gy);d7(c,u,0,Gy),o.resetReadTxn();let f=o.useReadTransaction();f.renew();let d=$0(null,{fd:c,start:Gy}),h=new l7.from(async function*(){yield u;for await(let _ of d)f.openTimer&&(f.openTimer=0),yield _;f.done()}());return h.headers=l(),h});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(S7,"getBackup")});var j0=C((HOe,Q0)=>{"use strict";var T7=J(),{handleHDBError:A7}=he(),R7=aL(),y7=_p(),b7=dy(),O7=cU(),N7=Qf(),w7=gy(),I7=vU(),C7=$U(),P7=Zf(),D7=JU(),L7=c0(),M7=_0(),v7=m0(),U7=S0(),x7=N0(),B7=Ny(),H7=P0(),k7=x0(),F7=H0(),z0=q0(),G7=Y0(),qy=class extends R7{static{a(this,"LMDBBridge")}async searchByConditions(t){return D7(t)}async getDataByHash(t){return await w7(t)}async searchByHash(t){return await I7(t)}async getDataByValue(t,r){return await C7(t,r)}async searchByValue(t){return await P7(t)}async createSchema(t){return await O7(t)}async dropSchema(t){return await L7(t)}async createTable(t,r){return await M7(t,r)}async dropTable(t){return await B7(t)}async createAttribute(t){return await y7(t)}async createRecords(t){return await b7(t)}async updateRecords(t){return await v7(t)}async upsertRecords(t){try{return await U7(t)}catch(r){throw A7(r,null,null,T7.ERR,r)}}async deleteRecords(t){return await N7(t)}async dropAttribute(t){return await H7(t)}async deleteAuditLogsBefore(t){return await x7(t)}async readAuditLog(t){return await k7(t)}writeTransaction(t,r,n){return F7.writeTransaction(t,r,n)}flush(t,r){return z0.flush(t,r)}resetReadTxn(t,r){return z0.resetReadTxn(t,r)}getBackup(t){return G7(t)}};Q0.exports=qy});var Vy={};Ue(Vy,{add:()=>qp,applyReverse:()=>J0,getRecordAtTime:()=>$y,rebuildUpdateBefore:()=>$p});function qp(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 $p(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,qp(n,s,i)}else r&&(n||(n={}),n[s]=i)}else n||(n={}),n[s]=e[s];return n}function J0(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=q7[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=X0}}function $y(e,t,r){let n=r.rootStore.auditStore,s={...e.value},i=e.localTime;for(;i>t;){let l=n.get(i),u=Ot(l);switch(u.type){case"put":s=u.getValue(r);break;case"patch":J0(s,u.getValue(r));break;case"delete":s=null}i=u.previousLocalTime}let o={},c=0;for(let l in s)s[l]===X0&&(o[l]=!0,c++);for(;c>0&&i>0;){let l=n.get(i),u=Ot(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 q7,X0,Vp=be(()=>{Qi();a(qp,"add");qp.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)};q7={add:qp};a($p,"rebuildUpdateBefore");a(J0,"applyReverse");X0={};a($y,"getRecordAtTime")});function gn(e){let t=e.getChanges();return t||(t=Object.create(null),e._setChanges(t)),t}function zp(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 $n.ClientError(`${l} must be a string, attempt to assign ${d}`);gn(this)[l]=d},"set");break;case"ID":u=a(function(d){if(!(typeof d=="string"||d?.length>0&&d.every?.(h=>typeof h=="string")||d==null&&c.nullable!==!1))throw new $n.ClientError(`${l} must be a string, attempt to assign ${d}`);gn(this)[l]=d},"set");break;case"Float":case"Number":u=a(function(d){let h=d?.__op__?d.value:d;if(!(typeof h=="number"||d==null&&c.nullable!==!1))throw new $n.ClientError(`${l} must be a number, attempt to assign ${h}`);gn(this)[l]=d},"set");break;case"Int":u=a(function(d){let h=d?.__op__?d.value:d;if(!(h>>0===h||d==null&&c.nullable!==!1))if(typeof h=="number"&&Math.abs((h>>0)-h)<=1)h=Math.round(h),d?.__op__?d.value=h:d=h;else throw new $n.ClientError(`${l} must be an integer between -2147483648 and 2147483647, attempt to assign ${d}`);gn(this)[l]=d},"set");break;case"Long":u=a(function(d){let h=d?.__op__?d.value:d;if(!(Math.round(h)===d&&Math.abs(h)<=9007199254740992||d==null&&c.nullable!==!1))if(typeof h=="number"&&Math.abs(h)<=9007199254740992)h=Math.round(h),d?.__op__?d.value=h:d=h;else throw new $n.ClientError(`${l} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${d}`);gn(this)[l]=d},"set");break;case"BigInt":u=a(function(d){let h=d?.__op__?d.value:d;if(!(typeof h=="bigint"||d==null&&c.nullable!==!1))if(typeof h=="string"||typeof h=="number")h=BigInt(h),d?.__op__?d.value=h:d=h;else throw new $n.ClientError(`${l} must be a number, attempt to assign ${d}`);gn(this)[l]=d},"set");break;case"Boolean":u=a(function(d){if(!(typeof d=="boolean"||d==null&&c.nullable!==!1))throw new $n.ClientError(`${l} must be a boolean, attempt to assign ${d}`);gn(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 $n.ClientError(`${l} must be a Date, attempt to assign ${d}`);gn(this)[l]=d},"set");break;case"Bytes":u=a(function(d){if(!(d instanceof Uint8Array||d==null&&c.nullable!==!1))throw new $n.ClientError(`${l} must be a Buffer or Uint8Array, attempt to assign ${d}`);gn(this)[l]=d},"set");break;case"Blob":u=a(function(d){if(!(d instanceof mi||d==null&&c.nullable!==!1))throw new $n.ClientError(`${l} must be a Blob, attempt to assign ${d}`);gn(this)[l]=d},"set");break;case"Any":case void 0:u=a(function(d){gn(this)[l]=d},"set");break;default:u=a(function(d){if(!(typeof d=="object"||d==null&&c.nullable!==!1))throw new $n.ClientError(`${l} must be an object, attempt to assign ${d}`);gn(this)[l]=d},"set")}f={get(){let d=this.getChanges?.();if(d&&l in d){let _=d[l];if(_?.__op__){let m=this.getRecord()?.[l];return _.update(m)}return _}let h=this.getRecord()?.[l];if(h&&typeof h=="object"){let _=Ky(h,c);if(_)return d||this._setChanges(d=Object.create(null)),d[l]=_}return h},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 $n.ClientError("Can not add a property to a sealed table schema");gn(this)[c]=l}),i("deleteProperty",function(c){gn(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 h=l[f];d=d.update(h)}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,ex);break}o=c}while(o&&o!==ex)}function Ky(e,t){let r;switch(e.constructor){case Object:return t?(r=t.TrackedObject,r||(t.TrackedObject=r=class extends i_{static{a(this,"TrackedObject")}},zp(r,t)),new r(e)):new i_(e);case Array:let n=new Yp(e.length,e);for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=Ky(o,t?.elements)),n[s]=o}return n;default:return e}}function Qp(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=Qp(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 Uc(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=Uc(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=Vy[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=Uc(s);r[n]=s}if(!Array.isArray(e))for(let n in e)$7.call(e,n)&&(r||(r={...e.getRecord?.()}),r[n]=e[n]);return r?Object.freeze(r):e.getRecord?.()??e}function Kp(e){let t=e.getRecord?.();if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[vc]||e.length!==t.length)return!0;for(let r=0,n=e.length;r<n;r++){let s=t[r],i=e[r];if(s&&i?.getRecord?.()===s){if(Kp(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(Kp(s))return!0}else return!0}else return!0}}return!1}var $n,Z0,ex,i_,$7,vc,Yp,Wp,Yy=be(()=>{$n=M(he());Vp();as();a(gn,"getChanges");a(zp,"assignTrackedAccessors");Z0=Object.prototype,ex=new Proxy({},{get(e,t,r){if(typeof t=="string"){if(t==="then"||t==="getRecord"||t==="getChanges")return;if(Z0[t])return Z0[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=Ky(s);if(i)return n||(n=Object.create(null),r._setChanges(n)),n[t]=i,i}return s}}});a(Ky,"trackObject");i_=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}};zp(i_,{});a(Qp,"collapseData");$7=Object.prototype.hasOwnProperty;a(Uc,"updateAndFreeze");a(Kp,"hasChanges");vc=Symbol.for("has-array-changes"),Yp=class extends Array{static{a(this,"TrackedArray")}#e;[vc];constructor(t,r){super(t),this.#e=r}getRecord(){return this.#e}splice(...t){return this[vc]=!0,super.splice(...t)}push(...t){return this[vc]=!0,super.push(...t)}pop(){return this[vc]=!0,super.pop()}unshift(...t){return this[vc]=!0,super.unshift(...t)}shift(){return this[vc]=!0,super.shift()}};Yp.prototype.constructor=Array;Wp=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var cx={};Ue(cx,{ResourceBridge:()=>Qy});function jy({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 rx(e,t){let r=Oi(e),n=jy(e,r);if(!r)throw new qs.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;bt(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&&Qp(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 Oi(e){let t=e.database||e.schema||K7,r=Xe()[t];if(!r)throw(0,qs.handleHDBError)(new Error,V7.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function nx(e,t,r){let n=e.length+t.length,s=n===1?"record":"records";return{message:`${e.length} of ${n} ${s} successfully deleted`,deleted_hashes:e,skipped_hashes:t,txn_time:r}}async function*sx(e,t,r,n){let s,i=0;for await(let o of e.getHistory(t,r)){let c=o.operation??o.type;c==="put"&&(c="upsert");let{id:l,version:u,value:f}=o;if(s?.timestamp===u)s.hash_values.push(l),s.records.push(f);else{if(s&&(yield s,i++,n&&n<=i)){s=void 0;break}s={operation:c,user_name:o.user,timestamp:u,hash_values:[l],records:[f]}}}s&&(yield s)}var ix,jp,qs,ox,Wy,zy,ax,V7,K7,Y7,W7,tx,Qy,lx=be(()=>{"use strict";ix=M(j0()),jp=M(du()),qs=M(he());ve();ox=M(Pf());H();Wy=M(no()),zy=M(Fs()),ax=M(ae());oc();Yy();({HDB_ERROR_MSGS:V7}=qs.hdb_errors),K7="data",Y7=1e4,W7=10,Qy=class extends ix.default{static{a(this,"ResourceBridge")}constructor(t){super(t),tx=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,jp.default)(t,"conditions");if(r)throw(0,qs.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=Oi(t);if(!n)throw new qs.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:jy(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 qs.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}]}ut({database:r.database??r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration,audit:r.audit})}async createAttribute(t){return await Oi(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=Oi(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){Oi(t).dropTable()}createSchema(t){return hu({database:t.schema,table:null}),Wy.signalSchemaChange(new zy.SchemaEventMsg(process.pid,$t.CREATE_SCHEMA,t.schema))}async dropSchema(t){await Jy(t.schema),Wy.signalSchemaChange(new zy.SchemaEventMsg(process.pid,$t.DROP_SCHEMA,t.schema))}async updateRecords(t){return t.requires_existing=!0,this.upsertRecords(t)}async createRecords(t){return t.requires_no_existing=!0,tx.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,ox.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),bt(o,async c=>{if(!i.schemaDefined){s=[];for(let f of n)i.attributes.find(h=>h.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],h=d!=null&&await i.get(d,o);if(t.requires_existing&&!h||t.requires_no_existing&&h){u.push(f[i.primaryKey]);continue}h&&(h=Qp(h));for(let _ in f)if(Object.prototype.hasOwnProperty.call(f,_)){let m=f[_];if(typeof m=="function")try{let S=m([[h]]);Array.isArray(S)&&(m=S[0].func_val,f[_]=m)}catch(S){throw S.message+="Trying to set key "+_+" on object"+JSON.stringify(f),S}}if(h)for(let _ in h)Object.prototype.hasOwnProperty.call(f,_)||(f[_]=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),bt(n,async s=>{let i=t.hash_values||t.records.map(l=>l[r.primaryKey]),o=[],c=[];for(let l of i)await r.delete(l,n)?o.push(l):c.push(l);return nx(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=Xe()[t.schema][t.table];if(!r.createdTimeProperty)throw new qs.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:bm.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,ax.async_set_timeout)(W7),l=[],s=!0},"chunkDelete");for await(let f of n)l.push(f[r.primaryKey]),c++,c%Y7===0&&await u();return l.length>0&&await u(),s?nx(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,jp.default)(t,"hashes");if(r)throw r;return rx(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of rx(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&tA[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,jp.default)(t,"value");if(n)throw n;let s=Oi(t);if(!s)throw new qs.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===bm.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:jy(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async getDataByValue(t,r){let n=new Map,s=Oi(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){Oi({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return Oi(t).deleteHistory(t.timestamp,t.cleanup_deleted_records)}async readAuditLog(t){let r=Oi(t),n={};switch(t.search_type){case Om.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 Om.USERNAME:let s=t.search_values;for await(let i of sx(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return sx(r,t.search_values?.[0],t.search_values?.[1],t.limit)}}};a(jy,"getSelect");a(rx,"getRecords");a(Oi,"getTable");a(nx,"createDeleteResponse");a(sx,"groupRecordsInHistory")});var Bn=C((JOe,ux)=>{"use strict";var{ResourceBridge:z7}=(lx(),P(cx)),Q7=ce();Q7.initSync();var Jp;function j7(){return Jp||(Jp=new z7,Jp)}a(j7,"getBridge");ux.exports=j7()});var pn=C((ZOe,hx)=>{"use strict";var Zp=kA(),Cr=ae(),J7=require("util"),eE=Bn(),X7=Bs(),dx=J(),{handleHDBError:xc,hdb_errors:Z7}=he(),{HTTP_STATUS_CODES:Bc}=Z7,eee=J7.promisify(X7.getTableSchema),tee="updated",fx="inserted",_x="upserted";hx.exports={insert:nee,update:see,upsert:iee,validation:ree,flush:oee};async function ree(e){if(Cr.isEmpty(e))throw new Error("invalid update parameters defined.");if(Cr.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if(Cr.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await eee(e.schema,e.table),r=Zp(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&&Cr.isEmptyOrZeroLength(c[n]))throw dx.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(!Cr.isEmptyOrZeroLength(c[n])&&(c[n]==="null"||c[n]==="undefined"))throw dx.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[n]}" is not a valid hash attribute value`);!Cr.isEmpty(c[n])&&c[n]!==""&&s.has(Cr.autoCast(c[n]))&&(c.skip=!0),s.add(Cr.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(ree,"validation");async function nee(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=Zp(e);if(t)throw xc(new Error,t.message,Bc.BAD_REQUEST);Cr.transformReq(e);let r=Cr.checkSchemaTableExist(e.schema,e.table);if(r)throw xc(new Error,r,Bc.BAD_REQUEST);let n=await eE.createRecords(e);return Xp(fx,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(nee,"insertData");async function see(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=Zp(e);if(t)throw xc(new Error,t.message,Bc.BAD_REQUEST);Cr.transformReq(e);let r=Cr.checkSchemaTableExist(e.schema,e.table);if(r)throw xc(new Error,r,Bc.BAD_REQUEST);let n=await eE.updateRecords(e);return Cr.isEmpty(n.existing_rows)?Xp(tee,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):Xp(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(see,"updateData");async function iee(e){if(e.operation!=="upsert")throw xc(new Error,"invalid operation, must be upsert",Bc.INTERNAL_SERVER_ERROR);let t=Zp(e);if(t)throw xc(new Error,t.message,Bc.BAD_REQUEST);Cr.transformReq(e);let r=Cr.checkSchemaTableExist(e.schema,e.table);if(r)throw xc(new Error,r,Bc.BAD_REQUEST);let n=await eE.upsertRecords(e);return Xp(_x,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(iee,"upsertData");function Xp(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===fx?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===_x?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(Xp,"returnObject");function oee(e){return Cr.transformReq(e),eE.flush(e.schema,e.table)}a(oee,"flush")});var Tx=C((tNe,Sx)=>{var mu=require("validate.js"),px=nt(),pu=(H(),P($)),{handleHDBError:aee,hdb_errors:cee}=he(),{HDB_ERROR_MSGS:Yt,HTTP_STATUS_CODES:lee}=cee,Xy=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),uee={STRUCTURE_USER:"structure_user"},mx=Object.values(pu.ROLE_TYPES_ENUM),dee="attribute_permissions",fee="attribute_name",{PERMS_CRUD_ENUM:Eu}=pu,_ee=[dee,...Object.values(Eu)],Ex=[Eu.READ,Eu.INSERT,Eu.UPDATE],hee=[fee,...Ex];function mee(e){let t=Xy();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,gx(e,t)}a(mee,"addRoleValidation");function pee(e){let t=Xy();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,gx(e,t)}a(pee,"alterRoleValidation");function Eee(e){let t=Xy();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,px.validateObject(e,t)}a(Eee,"dropRoleValidation");var gee=["operation","role","id","permission","hdb_user","access"];function gx(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)gee.includes(n[o])||s.push(n[o]);s.length>0&&tr(Yt.INVALID_ROLE_JSON_KEYS(s),r);let i=px.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{tr(o,r)}),e.permission){let o=See(e);o&&tr(o,r),mx.forEach(c=>{e.permission[c]&&!mu.isBoolean(e.permission[c])&&tr(Yt.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(mx.indexOf(o)<0){if(o===uee.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]||tr(Yt.SCHEMA_NOT_FOUND(d),r)}continue}tr(Yt.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){tr(Yt.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]){tr(Yt.TABLE_NOT_FOUND(o,l),r);continue}if(Object.keys(u).forEach(f=>{_ee.includes(f)||tr(Yt.INVALID_PERM_KEY(f),r,o,l)}),Object.values(Eu).forEach(f=>{mu.isDefined(u[f])?mu.isBoolean(u[f])||tr(Yt.TABLE_PERM_NOT_BOOLEAN(f),r,o,l):tr(Yt.TABLE_PERM_MISSING(f),r,o,l)}),u.attribute_permissions===void 0){tr(Yt.ATTR_PERMS_ARRAY_MISSING,r,o,l);continue}else if(!(Array.isArray(u.attribute_permissions)||u.attribute_permissions===null)){tr(Yt.ATTR_PERMS_NOT_ARRAY,r,o,l);continue}if(u.attribute_permissions){let f=global.hdb_schema[o][l].attributes.map(({attribute:h})=>h),d={read:!1,insert:!1,update:!1};for(let h in u.attribute_permissions){let _=u.attribute_permissions[h];if(Object.keys(_).forEach(S=>{!hee.includes(S)&&S!==Eu.DELETE&&tr(Yt.INVALID_ATTR_PERM_KEY(S),r,o,l)}),!mu.isDefined(_.attribute_name)){tr(Yt.ATTR_PERM_MISSING_NAME,r,o,l);continue}let m=_.attribute_name;if(!f.includes(m)){tr(Yt.INVALID_ATTRIBUTE_IN_PERMS(m),r,o,l);continue}Ex.forEach(S=>{mu.isDefined(_[S])?mu.isBoolean(_[S])||tr(Yt.ATTR_PERM_NOT_BOOLEAN(S,m),r,o,l):tr(Yt.ATTR_PERM_MISSING(S,m),r,o,l)}),!d.read&&_.read===!0&&(d.read=!0),!d.insert&&_.insert===!0&&(d.insert=!0),!d.update&&_.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 h=`${o}.${l}`;tr(Yt.MISMATCHED_TABLE_ATTR_PERMS(h),r,o,l)}}}}return Tee(r)}a(gx,"customValidate");Sx.exports={addRoleValidation:mee,alterRoleValidation:pee,dropRoleValidation:Eee};function See(e){let{operation:t,permission:r}=e;if(t===pu.OPERATIONS_ENUM.ADD_ROLE||t===pu.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 Yt.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?pu.ROLE_TYPES_ENUM.SUPER_USER:pu.ROLE_TYPES_ENUM.CLUSTER_USER;return Yt.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(See,"validateNoSUPerms");function Tee(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:Yt.ROLE_PERMS_ERROR,...e};return aee(new Error,n,lee.BAD_REQUEST)}else return null}a(Tee,"generateRolePermResponse");function tr(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(tr,"addPermError")});var a_=C((sNe,bx)=>{"use strict";var Ax=pn(),Rx=Vr(),Aee=Oc(),eb=Tx(),tb=no(),nNe=require("uuid").v4,Ree=require("util"),tE=(H(),P($)),yee=ae(),rb=Rx.searchByValue,bee=Rx.searchByHash,Oee=Ree.promisify(Aee.delete),Nee=Gs(),wee=fu(),{hdb_errors:Iee,handleHDBError:Hc}=he(),{HDB_ERROR_MSGS:yx,HTTP_STATUS_CODES:o_}=Iee,{UserEventMsg:nb}=Fs();bx.exports={addRole:Cee,alterRole:Pee,dropRole:Dee,listRoles:Lee};function Zy(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(Zy,"scrubRoleDetails");async function Cee(e){let t=eb.addRoleValidation(e);if(t)throw t;e=Zy(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 rb(r)||[])}catch(i){throw Hc(i)}if(n&&n.length>0)throw Hc(new Error,yx.ROLE_ALREADY_EXISTS(e.role),o_.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 Ax.insert(s),tb.signalUserChange(new nb(process.pid)),e=Zy(e),e}a(Cee,"addRole");async function Pee(e){let t=eb.alterRoleValidation(e);if(t)throw t;e=Zy(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await Ax.update(r)}catch(s){throw Hc(s)}if(n&&n?.message==="updated 0 of 1 records")throw Hc(new Error,"Invalid role id",o_.BAD_REQUEST,void 0,void 0,!0);return await tb.signalUserChange(new nb(process.pid)),e}a(Pee,"alterRole");async function Dee(e){let t=eb.dropRoleValidation(e);if(t)throw Hc(new Error,t,o_.BAD_REQUEST,void 0,void 0,!0);let r=new wee(tE.SYSTEM_SCHEMA_NAME,tE.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await bee(r));if(n.length===0)throw Hc(new Error,yx.ROLE_NOT_FOUND,o_.NOT_FOUND,void 0,void 0,!0);let s=new Nee(tE.SYSTEM_SCHEMA_NAME,tE.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await rb(s)),o=!1;if(yee.isEmptyOrZeroLength(i)===!1){for(let l=0;l<i.length;l++)if(i[l].active===!0){o=!0;break}}if(o===!0)throw Hc(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,o_.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await Oee(c),tb.signalUserChange(new nb(process.pid)),`${n[0].role} successfully deleted`}a(Dee,"dropRole");async function Lee(){return rb({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(Lee,"listRoles")});var sb={};Ue(sb,{start:()=>wx,startOnMainThread:()=>Uee});function wx({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r){let n=(0,Ox.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(Mee.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 h=u.attributes[d];h.attribute_name=d,f.push(h)}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 vee(i)}}}async function vee(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,Nx.isEqual)(i,e)?void 0:(e.id=r.id,(0,rE.alterRole)(e))}return(0,rE.addRole)(e)}var rE,Ox,Nx,Mee,Uee,Ix=be(()=>{ve();rE=M(a_()),Ox=require("yaml"),Nx=require("lodash"),Mee=["super_user","cluster_user","structure_user"];a(wx,"start");a(vee,"ensureRole");Uee=wx});async function nE(e){let t=(0,Dx.pathToFileURL)(e).toString();if(xee)return c_||(c_=Bee(kee)),(await(await c_).import(t)).namespace;try{return await import(t)}catch(r){try{(await import("internal/util")).default.decorateErrorStack(r)}catch{}throw r}}async function Bee(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),c_=new Compartment({console,Math,Date,fetch:Hee,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,Px.extname)(r)||(r+=".js"),r)},importHook:a(async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){Object.assign(s,{Resource:Gr,tables:Vn,databases:$e})}};let n=await(0,Cx.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)},"importHook")}),c_}function Hee(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 kee(){return{Resource:Gr,tables:Vn}}var Cx,Px,Dx,xee,c_,ib=be(()=>{Jo();ve();Cx=require("fs/promises"),Px=require("path"),Dx=require("url"),xee=!1;a(nE,"secureImport");a(Bee,"getCompartment");a(Hee,"secureOnlyFetch");a(kee,"getGlobalVars")});var ab={};Ue(ab,{handleFile:()=>Fee});async function Fee(e,t,r,n){let s=new Map,i=await nE(r);c(i.default)&&n.set((0,ob.dirname)(t),i.default),o(i,(0,ob.dirname)(t));function o(l,u){for(let f in l){let d=l[f];c(d)?n.set(u+"/"+f,d):typeof d=="object"&&o(d,u+"/"+f)}}a(o,"recurseForResources");function c(l){return typeof l=="function"&&(l.get||l.put||l.post||l.delete)}return a(c,"isResource"),s}var ob,Lx=be(()=>{ib();ob=require("path");a(Fee,"handleFile")});var lb={};Ue(lb,{start:()=>Gee});function Gee({resources:e}){e.set("login",cb),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var cb,Mx=be(()=>{Jo();a(Gee,"start");cb=class extends Gr{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 h_={};Ue(h_,{addAnalyticsListener:()=>__,calculateCPUUtilization:()=>Xx,diffResourceUsage:()=>Zx,recordAction:()=>rr,recordActionBinary:()=>Kn,setAnalyticsEnabled:()=>qee});function qee(e){Wx=e}function $ee(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 Vee(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 rr(e,t,r,n,s){if(!Wx)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=iE.get(i);o?$ee(e,o):Vee(i,e,t,r,n,s),sE||Kee()}function Kn(e,t,r,n,s){rr(!!e,t,r,n,s)}function __(e){jx.push(e)}function Kee(){sE=performance.now(),setTimeout(async()=>{let e=performance.now()-sE;sE=0;let t=[],r={time:Date.now(),period:e,threadId:kc.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 Jx){let h=Math.floor(c*d),_=o[h-1];if(h>l){let m=h-l;if(_===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:_,count:m}:_),f=_;l=h}}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 eB()}let n=process.memoryUsage();t.push({metric:"memory",threadId:kc.threadId,byThread:!0,...n});for(let s of jx)s(t);iE=new Map,kc.parentPort?kc.parentPort.postMessage({type:Qx,report:r}):nB({report:r})},zx).unref()}function oE(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 Xx(e,t){let r=e.userCPUTime+e.systemCPUTime;return Math.round(r/t*100)/100}function Zx(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 Yee(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};oE(e,"table-size",l),Fc.trace?.(`table ${o} size metric: ${JSON.stringify(l)}`),n+=c}return n}function vx(e,t){for(let[r,n]of Object.entries(t))try{let[s]=Object.values(n),i=s?.getAuditSize();if(!i)return;let o=Yx.default.statSync(s.primaryStore.env.path).size,c=Yee(e,r,n),l=o-c,u={database:r,size:o,used:c,free:l,audit:i};oE(e,"database-size",u),Fc.trace?.(`database ${r} size metric: ${JSON.stringify(u)}`)}catch(s){Fc.warn?.("Error getting DB size metrics",s)}}function Ux(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};oE(e,"storage-volume",o),Fc.trace?.(`db ${r} storage volume metrics: ${JSON.stringify(o)}`)}catch(s){Fc.warn?.("Error getting DB volume metrics",s)}}async function Wee(e,t=6e4){let r=db(),n=tB(),s=new Promise(E=>{let A=performance.now();setImmediate(()=>{let N=performance.now();N-A>5e3&&Fc.warn?.("Unusually high event queue latency on the main thread of "+Math.round(N-A)+"ms"),A=performance.now()}),n.primaryStore.prefetch([1],()=>{let N=performance.now();N-A>5e3&&Fc.warn?.("Unusually high task queue latency on the main thread of "+Math.round(N-A)+"ms"),E(N-A)})}),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:A}of r.primaryStore.getRange({start:i||!1,exclusiveStart:!0,end:1/0})){if(!A)continue;if(o){if(E>o+t)break}else o=E;f=E;let{metrics:N,threadId:v}=A;for(let F of N||[]){let{path:q,method:Y,type:ee,metric:oe,count:z,total:se,distribution:W,threads:pe,...Ae}=F;z||(z=1);let Pe=oe+(q?"-"+q:"");Y!==void 0&&(Pe+="-"+Y),ee!==void 0&&(Pe+="-"+ee);let me=c.get(Pe);if(me){if(me.threads){let lt=me.threads[v];if(lt)me=lt;else{me.threads[v]={...Ae};continue}}me.count||(me.count=1);let yt=me.count;for(let lt in Ae){let Rr=Ae[lt];typeof Rr=="number"&&(me[lt]=(me[lt]*yt+Rr*z)/(yt+z))}me.count+=z,se>=0&&(me.total+=se,me.ratio=me.total/me.count)}else me={period:t,...F},delete me.distribution,c.set(Pe,me),me.byThread&&(me.threads=[],me.threads[v]={...Ae},u.push(me));if(W){W=W.map(lt=>typeof lt=="number"?{value:lt,count:1}:lt);let yt=l.get(Pe);yt?yt.push(...W):l.set(Pe,W)}}await eB()}for(let E of u){let{path:A,method:N,type:v,metric:F,count:q,total:Y,distribution:ee,threads:oe,...z}=E;oe=oe.filter(se=>se);for(let se in z){if(typeof E[se]!="number")continue;let W=0;for(let pe of oe){let Ae=pe[se];typeof Ae=="number"&&(W+=Ae)}E[se]=W}E.count=oe.length,delete E.threads,delete E.byThread}for(let[E,A]of l){let N=c.get(E);A.sort((lt,Rr)=>lt.value>Rr.value?1:-1);let v=N.count-1,F=[],q=0,Y=0,ee;for(let lt of Jx){let Rr=v*lt;for(;q<Rr;)ee=A[Y++],q+=ee.count,Y===1&&q--;let ss=A[Y>1?Y-2:0];ee||(ee=A[0]),F.push(ee.value-(ee.value-ss.value)*(q-Rr)/ee.count)}let[oe,z,se,W,pe,Ae,Pe,me,yt]=F;Object.assign(N,{p1:oe,p10:z,p25:se,median:W,p75:pe,p90:Ae,p95:Pe,p99:me,p999:yt})}let d;for(let[E,A]of c)A.id=(0,d_.getNextMonotonicTime)(),A.time=f,n.primaryStore.put(A.id,A,{append:!0}).then(N=>{N||n.primaryStore.put(A.id,A)}),d=!0;let h=Date.now(),{idle:_,active:m}=performance.eventLoopUtilization();if(d||m*10>_){let E=(0,d_.getNextMonotonicTime)(),A={id:E,metric:"main-thread-utilization",idle:_-xx,active:m-Bx,taskQueueLatency:await s,time:h,...process.memoryUsage()};n.primaryStore.put(E,A,{append:!0}).then(N=>{N||n.primaryStore.put(E,A)})}xx=_,Bx=m;let S=process.resourceUsage(),g=Zx(l_,S);g.time=h,g.period=l_.time?h-l_.time:t,g.cpuUtilization=Xx(l_,g.period),oE(n,"resource-usage",g),l_=g;let R=Xe();vx(n,R),vx(n,{system:R.system}),Ux(n,R),Ux(n,{system:R.system})}async function Hx(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function db(){return kx||(kx=ut({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function tB(){return Fx||(Fx=ut({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function jee(){rB=!0;let e=(0,f_.get)(x.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await Wee(zx,e),await Hx(db(),zee),await Hx(tB(),Qee)},Math.min(e/2,2147483647)).unref()}function nB(e,t){let r=e.report;r.threadId=t?.threadId||kc.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(Gx+=n.mean*n.count);r.totalBytesProcessed=Gx,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(qx.get(t))}),qx.set(t,t.performance.eventLoopUtilization())),r.id=(0,d_.getNextMonotonicTime)(),db().primaryStore.put(r.id,r),rB||jee(),Jee&&(sB=Zee(r))}async function Zee(e){if(await sB,!ca){let r=(0,u_.dirname)((0,Vx.getLogFilePath)());try{ca=await(0,ub.open)((0,u_.join)(r,"analytics.log"),"r+")}catch{ca=await(0,ub.open)((0,u_.join)(r,"analytics.log"),"w+")}}let t=(await ca.stat()).size;if(t>Xee){let r=Buffer.alloc(t);await ca.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await ca.write(r,{position:0}),await ca.truncate(r.length),t=r.length}await ca.write(JSON.stringify(e)+`
|
|
20
20
|
`,t)}var kc,$x,Vx,Kx,u_,ub,d_,f_,Yx,Fc,iE,Wx,sE,zx,Qx,jx,Jx,xx,Bx,l_,eB,zee,Qee,kx,Fx,rB,Gx,qx,Jee,sB,ca,Xee,Ni=be(()=>{kc=require("worker_threads"),$x=M(rt());ve();Vx=M(J()),Kx=M(_i()),u_=require("path"),ub=require("fs/promises"),d_=M(cn()),f_=M(ce());H();qr();Yx=M(require("node:fs")),Fc=(0,Kx.loggerWithTag)("analytics");(0,f_.initSync)();iE=new Map,Wx=(0,f_.get)(x.ANALYTICS_AGGREGATEPERIOD)>-1;a(qee,"setAnalyticsEnabled");a($ee,"recordExistingAction");a(Vee,"recordNewAction");a(rr,"recordAction");We.recordAnalytics=rr;a(Kn,"recordActionBinary");sE=0,zx=1e3,Qx="analytics-report",jx=[];a(__,"addAnalyticsListener");Jx=[.01,.1,.25,.5,.75,.9,.95,.99,.999,1];a(Kee,"sendAnalytics");a(oE,"storeMetric");a(Xx,"calculateCPUUtilization");a(Zx,"diffResourceUsage");a(Yee,"storeTableSizeMetrics");a(vx,"storeDBSizeMetrics");a(Ux,"storeVolumeMetrics");a(Wee,"aggregation");xx=0,Bx=0,l_={},eB=a(()=>new Promise(setImmediate),"rest");a(Hx,"cleanup");zee=36e5,Qee=31536e6;a(db,"getRawAnalyticsTable");a(tB,"getAnalyticsTable");(0,$x.setChildListenerByType)(Qx,nB);a(jee,"startScheduledTasks");Gx=0,qx=new Map,Jee=!1;a(nB,"recordAnalytics");Xee=1e6;a(Zee,"logAnalytics")});var iB={};Ue(iB,{Headers:()=>oo,appendHeader:()=>aE,mergeHeaders:()=>fb});function aE(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 fb(e,t){(typeof e.set!="function"||typeof e.has!="function")&&(e=new oo(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 oo,m_=be(()=>{oo=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(aE,"appendHeader");a(fb,"mergeHeaders")});function uB(e){let t={openapi:ete,info:{title:"HarperDB HTTP REST interface",version:lB.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:A,name:N,elements:v,relationship:F,definition:q}of o){if(F)A==="array"?u[N]={type:"array",items:{$ref:la+v.type}}:u[N]={$ref:la+A};else{let Y=q??v?.definition;if(Y){if(!t.components.schemas[Y.type]){let ee={};Y.properties.forEach(oe=>{ee[oe.name]=new pb(_b[oe.type],oe.type)}),t.components.schemas[Y.type]=new cB(ee)}A==="array"?u[N]={type:"array",items:{$ref:la+Y.type}}:u[N]={$ref:la+Y.type}}else A==="array"?v.type==="Any"||v.type=="ID"?u[N]={type:"array",items:{format:v.type}}:u[N]={type:"array",items:new pb(_b[v.type],v.type)}:A==="Any"||A=="ID"?u[N]={format:A}:u[N]=new pb(_b[A],A)}f.push(new Eb(N,"query",u[N]))}let d=Object.keys(u),h=new Eb(c,"path",{format:"ID"});h.required=!0,h.description="primary key of record";let _=new Eb("property","path",{enum:d});_.required=!0,t.components.schemas[i]=new cB(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 tte(i,r,"create a new record auto-assigning a primary key")),g&&(t.paths[E]||(t.paths[E]={}),t.paths[E].get=new hb(f,r,{200:new mb({$ref:la+i})},"search for records by the specified property name and value pairs")),R&&(t.paths[E]||(t.paths[E]={}),t.paths[E].delete=new aB(f,r,"delete all the records that match the provided query",{204:new oB})),E="/"+s+"/{"+c+"}",g&&(t.paths[E]={},t.paths[E].get=new hb([h],r,{200:new mb({$ref:la+i})},"retrieve a record by its primary key")),S&&(t.paths[E]||(t.paths[E]={}),t.paths[E].put=new rte([h],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 aB([h],r,"delete a record with the given primary key",{204:new oB})),g&&_.schema.enum.length>0&&(E="/"+s+"/{"+c+"}.{property}",t.paths[E]={},t.paths[E].get=new hb([h,_],r,{200:new mb({enum:d})},"used to retrieve the specified property of the specified record"))}return t}function tte(e,t,r){this.description=r,this.requestBody={content:{"application/json":{schema:{$ref:la+e}}}},this.security=t,this.responses={200:{description:gb,headers:{Location:{description:"primary key of new record",schema:{type:"string",format:"ID"}}},content:{"application/json":{schema:{type:"string",format:"ID"}}}}}}function hb(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.responses=r}function mb(e){this.description=gb,this.content={"application/json":{schema:e}}}function oB(){this.description="successfully processed request, no content returned to client"}function rte(e,t,r,n){this.description=n,this.parameters=e,this.security=t,this.requestBody={content:{"application/json":{schema:{$ref:la+r}}}},this.responses={200:{description:gb}}}function aB(e,t,r,n){this.description=r,this.parameters=e,this.security=t,this.responses=n}function cB(e){this.type="object",this.properties=e}function pb(e,t){this.type=e,this.format=t}function Eb(e,t,r){this.name=e,this.in=t,this.schema=r}var lB,ete,_b,la,gb,dB=be(()=>{lB=M(pt()),ete="3.0.3",_b={Int:"integer",Float:"number",Long:"integer",String:"string",Boolean:"boolean",Date:"string",Bytes:"string",BigInt:"integer",array:"array"},la="#/components/schemas/",gb="successful operation";a(uB,"generateJsonApi");a(tte,"Post");a(hb,"Get");a(mb,"Response200");a(oB,"Response204");a(rte,"Put");a(aB,"Delete");a(cB,"ResourceSchema");a(pb,"Type");a(Eb,"Parameter")});var lE={};Ue(lE,{parseHeaderValue:()=>Tb,start:()=>ite});async function ste(e,t){let r=e.headers.asObject,n=r.accept==="text/event-stream",s=n?"CONNECT":e.method;e.search&&qm(e);let i=new oo;try{e.responseHeaders=i;let o=e.url.slice(1),c,l;if(o!==fB){let g=cE.getMatch(o,n?"sse":"rest");if(!g)return t(e);e.handlerPath=g.path,c=new ac(g.relativeURL),c.async=!0,l=g.Resource}if(l?.isCaching){let g=r["cache-control"];if(g){let R=Tb(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=Tb(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 bt(e,()=>{if(r["content-length"]||r["transfer-encoding"])try{e.data=Wi(r["content-type"],!0)(e.body,e.headers)}catch(g){throw new gu.ClientError(g,400)}if(e.authorize=!0,o===fB&&s==="GET"){if(e?.user?.role?.permission?.super_user)return uB(cE);throw new gu.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 gu.ClientError("HarperDB is short and stout and can't brew coffee",418);default:throw new gu.ServerError(`Method ${s} is not recognized`,501)}}),h=200,_;if(d==null)h=s==="GET"||s==="HEAD"?404:204,Sb.lastModified&&e.lastModified&&i.setIfNone("Last-Modified",new Date(e.lastModified).toUTCString());else if(d.status>0&&d.headers){let g=fb(d.headers,i);return d.headers!==g&&(d.headers=g),d.data!==void 0&&(d.body=Ef(d.data,e,d)),d}else if(_=e.lastModified){nte[0]=_;let g=String.fromCharCode(34,(Pr[0]&63)+62,(Pr[0]>>6)+(Pr[1]<<2&63)+62,(Pr[1]>>4)+(Pr[2]<<4&63)+62,(Pr[2]>>2)+62,(Pr[3]&63)+62,(Pr[3]>>6)+(Pr[4]<<2&63)+62,(Pr[4]>>4)+(Pr[5]<<4&63)+62,(Pr[5]>>2)+62,(Pr[6]&63)+62,(Pr[6]>>6)+(Pr[7]<<2&63)+62,34),R=r["if-none-match"];R&&g==R?(d?.onDone&&d.onDone(),h=304,d=void 0):i.setIfNone("ETag",g),Sb.lastModified&&i.setIfNone("Last-Modified",new Date(_).toUTCString())}e.createdResource&&(h=201),e.newLocation&&i.setIfNone("Location",e.newLocation);let m={status:h,headers:i,body:void 0},S=d?.wasLoadedFromSource?.();return S!==void 0&&(m.wasCacheMiss=S,!S&&_&&i.setIfNone("Age",Math.round((Date.now()-(e.lastRefreshed||_))/1e3))),d!==void 0&&(m.body=Ef(d,e,m),s==="HEAD"&&(m.body=void 0)),m}catch(o){o.statusCode?o.statusCode===500?wi.warn(o):wi.info(o):wi.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=Ef(o.contentType?o:o.toString(),e,c),c}}function ite(e){Sb=e,!_B&&(_B=!0,cE=e.resources,e.server.http(async(t,r)=>{if(!t.isWebSocket)return ste(t,r)},e),e.webSocket!==!1&&e.server.ws(async(t,r,n)=>{p_++;let s=new Pn;hB||(hB=!0,__(l=>{p_>0&&l.push({metric:"ws-connections",connections:p_,byThread:!0})}));let i;t.on("error",l=>{i=!0,wi.warn(l)});let o;t.on("message",a(function(u){o||(o=Wi(r.requestedContentType??r.headers.asObject["content-type"],!1));let f=o(u);rr(u.length,"bytes-received",r.handlerPath,"message","ws"),s.push(f)},"message"));let c;t.on("close",()=>{p_--,Kn(!i,"connection","ws","disconnect"),s.emit("close"),c&&c.return()});try{await n;let l=r.url.slice(1),u=cE.getMatch(l,"ws");if(Kn(!!u,"connection","ws","connect"),u){r.handlerPath=u.path,rr(m=>({count:m.count,total:p_}),"connections",r.handlerPath,"connect","ws"),r.authorize=!0;let f=new ac(u.relativeURL),d=u.Resource;c=(await bt(r,()=>d.connect(f,s,r)))[Symbol.asyncIterator]();let _;for(;!(_=await c.next()).done;){let m=await Zo(_.value,r);t.send(m),rr(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?wi.warn(l):wi.info(l):wi.error(l),t.close(ote[l.statusCode]||1011,l.toString())}t.close()},e))}function Tb(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 wi,gu,Pr,nte,Sb,fB,_B,cE,hB,p_,ote,mB=be(()=>{zi();Ni();wi=M(J()),gu=M(he());df();ql();oc();m_();dB();df();Pr=new Uint8Array(8),nte=new Float64Array(Pr.buffer,0,1),Sb={},fB="openapi";a(ste,"http");p_=0;a(ite,"start");ote={401:3e3,403:3003};a(Tb,"parseHeaderValue")});var Ab=C((MNe,EB)=>{var{recordAction:uE,recordActionBinary:pB}=(Ni(),P(h_)),ate=require("fastify-plugin"),cte=200;EB.exports=ate(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),pB(s.raw.statusCode<400,"success",u,d,f),pB(1,"response_"+s.raw.statusCode,u,d,f);let h=cte;i?.pipe?(i.on("data",g=>{h+=g.length}),i.on("end",()=>{uE(performance.now()-c,"transfer",u,d,f),uE(h,"bytes-sent",u,d,f)})):(h+=i?.length||0,uE(h,"bytes-sent",u,d,f));let _=o.toFixed(3),m=s.getHeader("Server-Timing"),S=`db;dur=${_}`;s.header("Server-Timing",m?`${m}, ${S}`:S)}),r()},{name:"hdb-request-time"})});var SB=C((vNe,gB)=>{var lte=nt(),ute={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};gB.exports=function(e){return lte.validateObject(e,ute)}});var dE=C((UNe,TB)=>{"use strict";var dte=(H(),P($)).OPERATIONS_ENUM,Rb=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=dte.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};TB.exports=Rb});var S_={};Ue(S_,{createTokens:()=>_te,getJWTRSAKeys:()=>pE,refreshOperationToken:()=>hte,validateOperationToken:()=>Ob,validateRefreshToken:()=>EE});async function pE(){if(fE)return fE;try{let e=E_.default.join(g_.default.getHdbBasePath(),XT),t=await _E.default.readFile(E_.default.join(e,zd.JWT_PASSPHRASE_NAME),"utf8"),r=await _E.default.readFile(E_.default.join(e,zd.JWT_PRIVATE_KEY_NAME),"utf8");return fE={publicKey:await _E.default.readFile(E_.default.join(e,zd.JWT_PUBLIC_KEY_NAME),"utf8"),privateKey:r,passphrase:t},fE}catch(e){throw mE.default.error(e),new $s.ClientError(Tu.NO_ENCRYPTION_KEYS,Su.INTERNAL_SERVER_ERROR)}}async function _te(e){let t=(0,yb.validateBySchema)(e,Ii.default.object({username:Ii.default.string().optional(),password:Ii.default.string().optional(),role:Ii.default.string().optional(),expires_in:Ii.default.alternatives(Ii.default.string(),Ii.default.number()).optional()}));if(t)throw new $s.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,bb.findAndValidateUser)(e.username,e.password,d)}catch(d){throw mE.default.error(d),new $s.ClientError(Tu.INVALID_CREDENTIALS,Su.UNAUTHORIZED)}if(!r)throw new $s.ClientError(Tu.INVALID_CREDENTIALS,Su.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 pE(),c=await Au.default.sign(i,{key:o.privateKey,passphrase:o.passphrase},{expiresIn:e.expires_in??OB,algorithm:hE,subject:"operation"}),l=await Au.default.sign(i,{key:o.privateKey,passphrase:o.passphrase},{expiresIn:fte,algorithm:hE,subject:"refresh"}),u=kR(l,"sha256");if((await(0,AB.update)(new RB.default(Wd,Fl.USER_TABLE_NAME,[{username:e.username,refresh_token:u}]))).skipped_hashes.length>0)throw new $s.ClientError(Tu.REFRESH_TOKEN_SAVE_FAILED,Su.INTERNAL_SERVER_ERROR);return yB.default.signalUserChange(new bB.UserEventMsg(process.pid)),{operation_token:c,refresh_token:l}}async function hte(e){let t=(0,yb.validateBySchema)(e,Ii.default.object({refresh_token:Ii.default.string().required()}).required());if(t)throw new $s.ClientError(t.message);let{refresh_token:r}=e;await EE(r);let n=await pE(),s=await Au.default.decode(r);return{operation_token:await Au.default.sign({username:s.username,super_user:s.super_user,cluster_user:s.cluster_user},{key:n.privateKey,passphrase:n.passphrase},{expiresIn:OB,algorithm:hE,subject:"operation"})}}async function Ob(e){return NB(e,"operation")}async function EE(e){return NB(e,"refresh")}async function NB(e,t){try{let r=await pE(),n=await Au.default.verify(e,r.publicKey,{algorithms:hE,subject:t});if(n.role)throw new Error("Invalid token");let s=await(0,bb.findAndValidateUser)(n.username,void 0,!1);if(t==="refresh"&&!FR(s.refresh_token,e))throw new Error("Invalid token");return s}catch(r){throw mE.default.warn(r),r?.name==="TokenExpiredError"?new $s.ClientError(Tu.TOKEN_EXPIRED,Su.FORBIDDEN):new $s.ClientError(Tu.INVALID_TOKEN,Su.UNAUTHORIZED)}}var Au,_E,E_,Ii,yb,$s,mE,bb,AB,RB,yB,bB,g_,Su,Tu,OB,fte,hE,fE,Ru=be(()=>{Au=M(require("jsonwebtoken")),_E=M(require("fs-extra")),E_=M(require("node:path")),Ii=M(require("joi")),yb=M(nt());H();$s=M(he()),mE=M(J());yp();bb=M(Fn()),AB=M(pn()),RB=M(dE()),yB=M(no()),bB=M(Fs()),g_=M(ce()),{HTTP_STATUS_CODES:Su,AUTHENTICATION_ERROR_MSGS:Tu}=$s.hdb_errors;g_.default.initSync();OB=g_.default.get(x.AUTHENTICATION_OPERATIONTOKENTIMEOUT)||"1d",fte=g_.default.get(x.AUTHENTICATION_REFRESHTOKENTIMEOUT)||"30d",hE="RS256";a(pE,"getJWTRSAKeys");a(_te,"createTokens");a(hte,"refreshOperationToken");a(Ob,"validateOperationToken");a(EE,"validateRefreshToken");a(NB,"validateToken")});var Nb=C((FNe,CB)=>{"use strict";var mte=SB(),yu=require("passport"),pte=require("passport-local").Strategy,Ete=require("passport-http").BasicStrategy,gte=require("util"),Ste=Fn(),IB=gte.callbackify(Ste.findAndValidateUser),kNe=Cn(),Tte=(H(),P($)),wB=(Ru(),P(S_));yu.use(new pte(function(e,t,r){IB(e,t,r)}));yu.use(new Ete(function(e,t,r){IB(e,t,r)}));yu.serializeUser(function(e,t){t(null,e)});yu.deserializeUser(function(e,t){t(null,e)});function Ate(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":yu.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===Tte.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?wB.validateRefreshToken(s).then(o=>{e.body.refresh_token=s,r(null,o)}).catch(o=>{r(o)}):wB.validateOperationToken(s).then(o=>{r(null,o)}).catch(o=>{r(o)});break;default:yu.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(Ate,"authorize");function Rte(e,t){let r=mte(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(Rte,"checkPermissions");CB.exports={authorize:Ate,checkPermissions:Rte}});var gE=C((qNe,PB)=>{"use strict";var yte=Bn();PB.exports={writeTransaction:bte};function bte(e,t,r){return yte.writeTransaction(e,t,r)}a(bte,"writeTransaction")});var vB=C((KNe,MB)=>{"use strict";var Ote=Vr(),Nte=Bs(),DB=J(),wte=pn(),VNe=gE(),Ite=require("clone"),Ib=require("alasql"),Cte=mp(),LB=require("util"),Pte=LB.promisify(Nte.getTableSchema),Dte=LB.promisify(Ote.search),Lte=(H(),P($)),wb=ae();Cte(Ib);MB.exports={update:vte};var Mte="There was a problem performing this update. Please check the logs and try again.";async function vte({statement:e,hdb_user:t}){let r=await Pte(e.table.databaseid,e.table.tableid),n=Ute(e.columns);wb.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=Ite(s),c=wb.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,u=Ib.parse(l).statements[0],f=await Dte(u),d=xte(n,f);return Bte(o,d,t)}a(vte,"update");function Ute(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=Ib.compile(`SELECT ${r.expression.toString()} AS [${Lte.FUNC_VAL}] FROM ?`)}),t}catch(t){throw DB.error(t),new Error(Mte)}}a(Ute,"createUpdateRecord");function xte(e,t){return wb.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(xte,"buildUpdateRecords");async function Bte(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await wte.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){DB.error(`Error delete new_attributes from update response: ${i}`)}return s}a(Bte,"updateRecords")});var xB=C((QNe,UB)=>{var Hte=require("alasql"),kte=Vr(),Fte=J(),Gte=Bn(),Pb=require("util"),Cb=ae(),qte=(H(),P($)),$te=Bs(),WNe=gE(),zNe=pn(),Vte="record",Kte="successfully deleted",Yte=Pb.callbackify(jte),Wte=Pb.promisify(kte.search),zte=Pb.promisify($te.getTableSchema);UB.exports={convertDelete:Yte};function Qte(e){return`${e.deleted_hashes.length} ${Vte}${e.deleted_hashes.length===1?"":"s"} ${Kte}`}a(Qte,"generateReturnMessage");async function jte({statement:e,hdb_user:t}){let r=await zte(e.table.databaseid,e.table.tableid);Cb.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=Cb.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=Hte.parse(o).statements[0],l={operation:qte.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await Wte(c);let u=await Gte.deleteRecords(l);return Cb.isEmptyOrZeroLength(u.message)&&(u.message=Qte(u)),delete u.txn_time,u}catch(u){throw Fte.error(u),u.hdb_code?u.message:u}}a(jte,"convertDelete")});var GB=C((JNe,FB)=>{"use strict";var Jte=to(),{hdb_errors:BB}=he(),{getDatabases:HB}=(ve(),P(it));FB.exports={checkSchemaExists:kB,checkSchemaTableExists:Xte,schema_describe:Jte};async function kB(e){if(!HB()[e])return BB.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(kB,"checkSchemaExists");async function Xte(e,t){let r=await kB(e);if(r)return r;if(!HB()[e][t])return BB.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(Xte,"checkSchemaTableExists")});var Ub=C((rwe,ZB)=>{"use strict";var{decode:Zte}=require("msgpackr"),{isMainThread:ZNe,parentPort:ewe,threadId:twe}=require("worker_threads"),AE=pr(),bu=Nt(),Mb=(H(),P($)),zr=J(),Lb=ce(),ere=(H(),P($)),{onMessageByType:tre}=rt(),KB=eo(),{recordAction:qB,recordActionBinary:rre}=(Ni(),P(h_)),{publishToStream:nre}=AE,{ConsumerEvents:$B}=require("nats"),sre=Vr(),{promisify:ire}=require("util"),{decodeBlobsWithWrites:ore}=(as(),P(OE)),YB=ire(setTimeout),RE=1e4,yE,TE,are,cre,WB,T_=new Map,Ou=new Map;ZB.exports={initialize:zB,ingestConsumer:vb,setSubscription:lre,setIgnoreOrigin:fre,getDatabaseSubscriptions:dre,updateConsumer:QB};async function zB(){tre(Mb.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,async n=>{await QB(n)}),WB=!0,zr.notify("Initializing clustering ingest service.");let{connection:e,jsm:t,js:r}=await AE.getNATSReferences();yE=e,TE=e.info.server_name,are=t,cre=r}a(zB,"initialize");async function QB(e){if(e.status==="start"){let{js:t,jsm:r}=await jB(e.node_domain_name);vb(e.stream_name,t,r,e.node_domain_name)}else if(e.status==="stop"){let t=T_.get(e.stream_name+e.node_domain_name);t&&(zr.notify("Closing ingest consumer for node:",e.node_domain_name,"stream:",e.stream_name),await t.close?.(),T_.set(e.stream_name+e.node_domain_name,"close")),Ou.get(e.node_domain_name)==="failed"&&Ou.set(e.node_domain_name,"close")}}a(QB,"updateConsumer");var bE=new Map;function lre(e,t,r){let n=bE.get(e);n||bE.set(e,n=new Map),n.set(t,r),WB||zB().then(ure)}a(lre,"setSubscription");async function ure(){let e=await sre.searchByValue({database:"system",table:"hdb_nodes",search_attribute:"name",search_value:"*"});for await(let t of e){let r=t.name+bu.SERVER_SUFFIX.LEAF,n,s;for(let i of t.subscriptions||[])if(i.subscribe===!0){if(!n&&({js:n,jsm:s}=await jB(r),!n))break;let{schema:o,table:c}=i,l=KB.createNatsTableStreamName(o,c);vb(l,n,s,r)}}}a(ure,"accessConsumers");async function jB(e){let t,r,n=1;for(;!r;)try{t=await yE.jetstream({domain:e}),r=await yE.jetstreamManager({domain:e,checkAPI:!1})}catch(s){if(Ou.get(e)==="close")break;Ou.set(e,"failed"),n%10===1&&zr.warn("Nats ingest attempting to connect to:",e,"Nats error:",s.message);let i=n++*100<RE?n++*100:RE;await YB(i)}return{js:t,jsm:r}}a(jB,"connectToRemoteJS");function dre(){return bE}a(dre,"getDatabaseSubscriptions");var JB;function fre(e){JB=e}a(fre,"setIgnoreOrigin");var XB=100,VB=new Array(XB),SE=0;async function vb(e,t,r,n){let{connection:s}=await AE.getNATSReferences();yE=s,TE=s.info.server_name;let i,o=1;for(;!i;)try{i=await t.consumers.get(e,TE),zr.notify("Initializing ingest consumer for node:",n,"stream:",e)}catch(u){if(Ou.get(n)==="close")break;o%10===1&&zr.warn("Nats ingest error getting consumer:",n,"stream:",e,"Nats error:",u.message),u.code==="404"&&(zr.notify("Nats ingest creating consumer for node:",n,"stream:",e),i=await AE.createConsumer(r,e,TE,new Date(Date.now()).toISOString()));let f=o++*100<RE?o++*100:RE;await YB(f)}let c=!1,l;for(;!c;){if(T_.get(e+n)==="close"||Ou.get(n)==="close"){T_.delete(e+n),c=!0;continue}l=await i.consume({max_messages:Lb.get(Mb.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS)??100,bind:!0}),T_.set(e+n,l);let u=!1;(async()=>{for await(let f of await l.status())if(f.type===$B.ConsumerDeleted&&(await l.close(),c=!0),f.type===$B.HeartbeatsMissed){let d=f.data;zr.trace(`${d} clustering ingest consumer heartbeats missed, node: ${n} stream: ${l.consumer.stream}`),d===100&&(zr.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 VB[SE],VB[SE]=_re(f).catch(d=>{zr.error(d)}),++SE>=XB&&(SE=0)}catch(f){f.message==="consumer deleted"?(zr.notify("Nats consumer deleted, closing messages for node:",n,"stream:",l.consumer.stream),await l.close(),c=!0):zr.error("Error consuming clustering ingest, restarting consumer",f)}}}a(vb,"ingestConsumer");async function _re(e){let t;await ore(()=>{t=Zte(e.data)}),qB(e.data.length,"bytes-received",e.subject,t.operation,"ingest"),zr.trace("Nats message processor message size:",e?.msg?._msg?.size,"bytes");let r=e.headers,n=!1,s=Lb.get(Mb.CONFIG_PARAMS.CLUSTERING_NODENAME);r.has(bu.MSG_HEADERS.TRANSACTED_NODES)&&r.values(bu.MSG_HEADERS.TRANSACTED_NODES).indexOf(s)>-1&&(n=!0);let i=r.get(bu.MSG_HEADERS.ORIGIN);if(n||(n=i===s&&!JB),rre(n,"echo",e.subject,t.operation,"ingest"),n){e.ack();return}r.append(bu.MSG_HEADERS.TRANSACTED_NODES,s);try{let{operation:o,schema:c,next:l,table:u,records:f,hash_values:d,__origin:h,expiresAt:_}=t;zr.trace("processing message:",o,c,u,(f?"records: "+f.map(v=>v?.id):"")+(d?"ids: "+d:""),"with sequence:",e.seq),zr.trace(`messageProcessor nats msg id: ${e.headers.get(bu.MSG_HEADERS.NATS_MSG_ID)}`);let m;f||(f=d);let S=new Promise(v=>m=v),{timestamp:g,user:R,node_name:E}=h||{},A=bE.get(c)?.get(u);if(!A)throw new Error(`Missing table for replication message: ${u}`);if(o==="define_schema")t.type=o,t.onCommit=m,A.send(t);else if(f.length===1&&!l)A.send({type:Db(o),value:f[0],id:d?.[0],expiresAt:_,timestamp:g,table:u,onCommit:m,user:R,nodeName:E});else{let v=f.map((F,q)=>({type:Db(o),value:F,expiresAt:_,id:d?.[q],table:u}));for(;l;)v.push({type:Db(l.operation),value:l.record,expiresAt:l.expiresAt,id:l.id,table:l.table}),l=l.next;A.send({type:"transaction",writes:v,table:u,timestamp:g,onCommit:m,user:R,nodeName:E})}Lb.get(ere.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&nre(e.subject.split(".").slice(0,-1).join("."),KB.createNatsTableStreamName(c,u),e.headers,e.data),await S;let N=Date.now()-g;g&&qB(N,"replication-latency",e.subject,o,"ingest")}catch(o){zr.error(o)}e.ack()}a(_re,"messageProcessor");function Db(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}a(Db,"convertOperation")});var pr=C((lwe,pH)=>{"use strict";var Or=ce();Or.initSync();var hre=require("fs-extra"),mre=require("semver"),y_=require("path"),{monotonicFactory:pre}=require("ulidx"),tH=pre(),Ere=require("util"),rH=require("child_process"),gre=Ere.promisify(rH.exec),Sre=rH.spawn,Dr=Nt(),Ve=(H(),P($)),{packageJson:Tre,PACKAGE_ROOT:Are}=pt(),NE=ae(),Vs=J(),wE=eo(),Rre=gE(),A_=It(),{broadcast:yre,onMessageByType:bre,getWorkerIndex:Ore}=rt(),{isMainThread:nH}=require("worker_threads"),{Encoder:Nre,decode:kb}=require("msgpackr"),sH=new Nre,{isEmpty:Vc}=NE,iH=Fn(),swe=48*36e11;nH&&bre(Ve.ITC_EVENT_TYPES.RESTART,()=>{Qr=void 0,$c=void 0});var{connect:wre,StorageType:Ire,RetentionPolicy:Cre,AckPolicy:Fb,DeliverPolicy:Gb,DiscardPolicy:Pre,NatsConnection:iwe,JetStreamManager:owe,JetStreamClient:awe,StringCodec:cwe,JSONCodec:Dre,createInbox:qb,headers:Lre,ErrorCode:eH}=require("nats"),{recordAction:Mre}=(Ni(),P(h_)),{encodeBlobsAsBuffers:vre}=(as(),P(OE)),oH=Dre(),Ure="clustering",xre=Tre.engines[Dr.NATS_SERVER_NAME],Bre=y_.join(Are,"dependencies"),Hb=y_.join(Bre,`${process.platform}-${process.arch}`,Dr.NATS_BINARY_NAME),xb,Bb,R_,Gc,qc;pH.exports={runCommand:aH,checkNATSServerInstalled:Hre,createConnection:$b,getConnection:b_,getJetStreamManager:O_,getJetStream:lH,getNATSReferences:Ci,getServerList:Fre,createLocalStream:Vb,listStreams:uH,deleteLocalStream:Gre,getServerConfig:Nu,listRemoteStreams:qre,viewStream:$re,viewStreamIterator:Vre,publishToStream:Kre,request:zre,reloadNATS:Kb,reloadNATSHub:Qre,reloadNATSLeaf:jre,extractServerName:Wre,requestErrorHandler:Jre,createLocalTableStream:hH,createTableStreams:ene,purgeTableStream:mH,purgeSchemaTableStreams:tne,getStreamInfo:rne,updateLocalStreams:sne,closeConnection:kre,getJsmServerName:IE,addNatsMsgHeader:dH,clearClientCache:cH,updateRemoteConsumer:Xre,createConsumer:fH,updateConsumerIterator:Zre};async function aH(e,t=void 0){let{stdout:r,stderr:n}=await gre(e,{cwd:t});if(n)throw new Error(n.replace(`
|
|
21
21
|
`,""));return r.replace(`
|
|
22
|
-
`,"")}a(aH,"runCommand");async function Hre(){try{await hre.access(Hb)}catch{return!1}let e=await aH(`${Hb} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return mre.eq(t,xre)}a(Hre,"checkNATSServerInstalled");async function $b(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let o=await iH.getClusterUser();if(Vc(o))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=o.username,r=o.decrypt_hash}Vs.trace("create nats connection called");let i=await wre({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:Or.get(Ve.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:Or.get(Ve.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:Or.get(Ve.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),Vs.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(o=>{o&&Vs.error("Error with Nats client connection, connection closed",o),i===Qr&&cH()}),i}a($b,"createConnection");function cH(){Qr=void 0,Gc=void 0,qc=void 0,$c=void 0}a(cH,"clearClientCache");async function kre(){Qr&&(await Qr.drain(),Qr=void 0,Gc=void 0,qc=void 0,$c=void 0)}a(kre,"closeConnection");var Qr,$c;async function b_(){return $c||($c=$b(Or.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),Qr=await $c),Qr||$c}a(b_,"getConnection");async function O_(){if(Gc)return Gc;Vc(Qr)&&await b_();let{domain:e}=Nu(Ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(Vc(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return Gc=await Qr.jetstreamManager({domain:e,timeout:6e4}),Gc}a(O_,"getJetStreamManager");async function lH(){if(qc)return qc;Vc(Qr)&&await b_();let{domain:e}=Nu(Ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(Vc(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return qc=Qr.jetstream({domain:e,timeout:6e4}),qc}a(lH,"getJetStream");async function Ci(){let e=Qr||await b_(),t=Gc||await O_(),r=qc||await lH();return{connection:e,jsm:t,js:r}}a(Ci,"getNATSReferences");async function Fre(e){let t=Or.get(Ve.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await iH.getClusterUser(),s=await $b(t,r,n),i=qb(),o=s.subscribe(i),c=[],l,u=(async()=>{for await(let f of o){let d=oH.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 NE.async_set_timeout(e),await o.drain(),await s.close(),await u,c}a(Fre,"getServerList");async function Vb(e,t){let{jsm:r}=await Ci(),n=Or.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Or.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=Or.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:Ire.File,retention:Cre.Limits,subjects:t,discard:Pre.Old,max_msgs:s,max_bytes:i,max_age:n})}a(Vb,"createLocalStream");async function uH(){let{jsm:e}=await Ci(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}a(uH,"listStreams");async function Gre(e){let{jsm:t}=await Ci();await t.streams.delete(e)}a(Gre,"deleteLocalStream");async function qre(e){let{connection:t}=await Ci(),r=[],n=qb(),s=t.subscribe(n),i=(async()=>{for await(let o of s)r.push(oH.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(qre,"listRemoteStreams");async function $re(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Ci(),i=tH(),o={durable_name:i,ack_policy:Fb.Explicit};t&&(o.deliver_policy=Gb.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=kb(f.data),h={nats_timestamp:f.info.timestampNanos,nats_sequence:f.info.streamSequence,entry:d};if(f.headers&&(h.origin=f.headers.get(Dr.MSG_HEADERS.ORIGIN)),u.push(h),f.ack(),f.info.pending===0)break}return await c.delete(),u}a($re,"viewStream");async function*Vre(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Ci(),i=tH(),o={durable_name:i,ack_policy:Fb.Explicit};t&&(o.deliver_policy=Gb.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=kb(u.data);f[0]||(f=[f]);for(let d of f){let h={nats_timestamp:u.info.timestampNanos,nats_sequence:u.info.streamSequence,entry:d};u.headers&&(h.origin=u.headers.get(Dr.MSG_HEADERS.ORIGIN)),yield h}if(u.ack(),u.info.pending===0)break}await c.delete()}a(Vre,"viewStreamIterator");async function Kre(e,t,r,n){Vs.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=dH(n,r);let{js:s}=await Ci(),i=await IE(),o=`${e}.${i}`,c=await vre(()=>n instanceof Uint8Array?n:sH.encode(n));try{Vs.trace(`publishToStream publishing to subject: ${o}`),Mre(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 _H(async()=>{try{await s.publish(o,c,{headers:r})}catch{if(l.code&&l.code.toString()==="503"){Vs.trace(`publishToStream creating stream: ${t}`);let f=o.split(".");f[2]="*",await Vb(t,[o]),await s.publish(o,c,{headers:r})}else throw l}});throw l}}a(Kre,"publishToStream");function dH(e,t){t===void 0&&(t=Lre());let r=Or.get(Ve.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(Dr.MSG_HEADERS.ORIGIN)&&r&&t.append(Dr.MSG_HEADERS.ORIGIN,r),t}a(dH,"addNatsMsgHeader");function Nu(e){e=e.toLowerCase();let t=y_.join(Or.get(Ve.CONFIG_PARAMS.ROOTPATH),Ure);if(e===Ve.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return Vc(Bb)&&(Bb={port:A_.getConfigFromFile(Ve.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:A_.getConfigFromFile(Ve.CONFIG_PARAMS.CLUSTERING_NODENAME)+Dr.SERVER_SUFFIX.HUB,config_file:Dr.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:y_.join(t,Dr.PID_FILES.HUB),hdb_nats_path:t}),Bb;if(e===Ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return Vc(xb)&&(xb={port:A_.getConfigFromFile(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:A_.getConfigFromFile(Ve.CONFIG_PARAMS.CLUSTERING_NODENAME)+Dr.SERVER_SUFFIX.LEAF,config_file:Dr.NATS_CONFIG_FILES.LEAF_SERVER,domain:A_.getConfigFromFile(Ve.CONFIG_PARAMS.CLUSTERING_NODENAME)+Dr.SERVER_SUFFIX.LEAF,pid_file_path:y_.join(t,Dr.PID_FILES.LEAF),hdb_nats_path:t}),xb;Vs.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(Nu,"getServerConfig");async function fH(e,t,r,n){try{await e.consumers.add(t,{ack_policy:Fb.Explicit,durable_name:r,deliver_policy:Gb.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}a(fH,"createConsumer");async function Yre(e,t,r){await e.consumers.delete(t,r)}a(Yre,"removeConsumer");function Wre(e){return e.split(".")[1]}a(Wre,"extractServerName");async function zre(e,t,r=6e4,n=qb()){if(!NE.isObject(t))throw new Error("data param must be an object");let s=sH.encode(t),{connection:i}=await Ci(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return kb(c.data)}a(zre,"request");function Kb(e){return new Promise(async(t,r)=>{let n=Sre(Hb,["--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(Kb,"reloadNATS");async function Qre(){let{pid_file_path:e}=Nu(Ve.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await Kb(e)}a(Qre,"reloadNATSHub");async function jre(){let{pid_file_path:e}=Nu(Ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await Kb(e)}a(jre,"reloadNATSLeaf");function Jre(e,t,r){let n;switch(e.code){case eH.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case eH.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}a(Jre,"requestErrorHandler");async function Xre(e,t){let r=t+Dr.SERVER_SUFFIX.LEAF,{connection:n}=await Ci(),{jsm:s}=await one(r),{schema:i,table:o}=e,c=wE.createNatsTableStreamName(i,o),l=e.start_time?e.start_time:new Date(Date.now()).toISOString();await _H(async()=>{if(e.subscribe===!0)await fH(s,c,n.info.server_name,l);else try{await Yre(s,c,n.info.server_name)}catch(u){Vs.trace(u)}})}a(Xre,"updateRemoteConsumer");async function Zre(e,t,r,n){let s=wE.createNatsTableStreamName(e,t),i=r+Dr.SERVER_SUFFIX.LEAF,o={type:Ve.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!nH&&Ore()<Or.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=Ub();await c(o)}await yre(o),n==="stop"&&await NE.async_set_timeout(1e3)}a(Zre,"updateConsumerIterator");function _H(e){return Rre.writeTransaction(Ve.SYSTEM_SCHEMA_NAME,Ve.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(_H,"exclusiveLock");async function hH(e,t){let r=wE.createNatsTableStreamName(e,t),n=await IE(),s=nne(e,t,n);await Vb(r,[s])}a(hH,"createLocalTableStream");async function ene(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await hH(n,s)}}a(ene,"createTableStreams");async function mH(e,t,r=void 0){if(Or.get(Ve.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=wE.createNatsTableStreamName(e,t),{domain:s}=Nu(Ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await b_()).jetstreamManager({domain:s,timeout:24e4})).streams.purge(n,r)}catch(n){if(n.message==="stream not found")Vs.warn(n);else throw n}}a(mH,"purgeTableStream");async function tne(e,t){if(Or.get(Ve.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await mH(e,t[r])}a(tne,"purgeSchemaTableStreams");async function rne(e){return(await O_()).streams.info(e)}a(rne,"getStreamInfo");function nne(e,t,r){return`${Dr.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}a(nne,"createSubjectName");async function IE(){if(R_)return R_;if(R_=(await O_())?.nc?.info?.server_name,R_===void 0)throw new Error("Unable to get jetstream manager server name");return R_}a(IE,"getJsmServerName");async function sne(){let e=await O_(),t=await IE(),r=await uH();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let o=ine(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(".");Vs.trace(`Updating stream subject name from: ${i} to: ${f}`),s.subjects[0]=f,await e.streams.update(s.name,s)}}a(sne,"updateLocalStreams");function ine(e){let{config:t}=e,r=!1,n=Or.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Or.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=Or.get(Ve.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(ine,"updateStreamLimits");async function one(e){let t,r;try{t=await Qr.jetstream({domain:e}),r=await Qr.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw Vs.error("Unable to connect to:",e),n}return{js:t,jsm:r}}a(one,"connectToRemoteJS")});function Yb(e){let t=e.get(CE),r=t?(0,wu.unpack)(t):null;r||(r={remoteNameToId:{}});let n=Ze(),s=!1;r.nodeName=Ze();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:w_(e)??1,nodes:[]})})}i[n]=0,e.putSync(CE,(0,wu.pack)(r))}return r}function N_(e){return Yb(e).remoteNameToId}function gH(e,t){let r=Yb(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(CE,(0,wu.pack)(r)),s}function PE(e,t){let r=Yb(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(CE,(0,wu.pack)(r))}return EH.trace?.("The remote node name map",e,n,s),s}var EH,wu,CE,Wb=be(()=>{EH=M(_i());ds();wu=require("msgpackr"),CE=Symbol.for("remote-ids");a(Yb,"getIdMappingRecord");a(N_,"exportIdMapping");a(gH,"remoteToLocalNodeId");a(PE,"getIdOfRemoteNode")});var zb={};Ue(zb,{commits_awaiting_replication:()=>Cu,getHDBNodeTable:()=>nr,getReplicationSharedStatus:()=>DE,iterateRoutes:()=>C_,shouldReplicateToNode:()=>I_,subscribeToNodeUpdates:()=>Pu});function nr(){return SH||(SH=ut({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 DE(e,t,r,n){return new Float64Array(e.getUserSharedBuffer(["replicated",t,r],new ArrayBuffer(32),n&&{callback:n}))}function Pu(e){nr().subscribe({}).then(async t=>{for await(let r of t){let n=r?.value?.name;yH.debug?.("adding node",n,"on node",Ze()," on process",process.pid),server.nodes=server.nodes.filter(i=>i.name!==n),r.type==="put"&&n!==Ze()&&(r.value?server.nodes.push(r.value):console.error("Invalid node update event",r));let s=new Map;for await(let i of nr().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 I_(e,t){return(e.replicates===!0||e.replicates?.sends)&&databases[t]&&nr().primaryStore.get(Ze())?.replicates||e.subscriptions?.some(r=>(r.database||r.schema)===t&&r.subscribe)}function ane(){Pu(e=>{ua({},(t,r)=>{let n=e.name,s=TH.get(n);if(s||TH.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=DE(i,r,n,()=>{let c=o[0],l=o.lastTime;for(let{txnTime:u,onConfirm:f}of Cu.get(r)||[])u>l&&u<=c&&f();o.lastTime=c});o.lastTime=0,s.set(r,o)}})})}function*C_(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=Iu.default.get(x.REPLICATION_SECUREPORT)??(!Iu.default.get(x.REPLICATION_PORT)&&Iu.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||Iu.default.get(x.REPLICATION_PORT)||Iu.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){AH.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,shard:t.shard}}}var AH,RH,Iu,yH,SH,TH,Cu,Kc=be(()=>{ve();ds();km();AH=require("worker_threads"),RH=M(he()),Iu=M(ce());H();yH=M(_i());server.nodes=[];a(nr,"getHDBNodeTable");a(DE,"getReplicationSharedStatus");a(Pu,"subscribeToNodeUpdates");a(I_,"shouldReplicateToNode");TH=new Map;fD((e,t,r)=>{if(r>server.nodes.length)throw new RH.ClientError(`Cannot confirm replication to more nodes (${r}) than are in the network (${server.nodes.length})`);Cu||(Cu=new Map,ane());let n=Cu.get(e);return n||(n=[],Cu.set(e,n)),new Promise(s=>{let i=0;n.push({txnTime:t,onConfirm:a(()=>{++i===r&&s()},"onConfirm")})})});a(ane,"startSubscriptionToReplications");a(C_,"iterateRoutes")});var wH={};Ue(wH,{connectedToNode:()=>Yc,disconnectedFromNode:()=>Mu,ensureNode:()=>co,requestClusterStatus:()=>NH,startOnMainThread:()=>jb});async function jb(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){LE.set(i,w_(l.auditStore));break}}}Pi.whenThreadsStarted.then(async()=>{let i=[];for await(let o of r.system.hdb_nodes?.search([])||[])i.push(o);for(let o of C_(e))try{let c=!o.subscriptions;if(c){let u=Ze(),f=nr().primaryStore.get(u);if(f!==null){let d=e.url??da();(f===void 0||f.url!==d||f.shard!==e.shard)&&await co(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)}Pu(s)});let n;function s(i,o=i?.name){let c=Ze()&&o===Ze()||da()&&i?.url===da();if(c){let d=!!i?.replicates;if(n!==void 0&&n!==d)for(let h of nr().search([]))h.replicates&&h.name!==o&&s(h,h.name);n=d}if(ot.trace("Setting up node replication for",i),!i){for(let[d,h]of ao){let _;for(let[m,{worker:S,nodes:g}]of h){let R=g[0];if(R&&R.name==o){_=!0;for(let[E,{worker:A}]of h)h.delete(E),ot.warn("Node was deleted, unsubscribing from node",o,E,d),A?.postMessage({type:"unsubscribe-from-node",node:o,database:E,url:d});break}}if(_){ao.get(d).iterator.remove(),ao.delete(d);return}}return}if(c)return;if(!i.url){ot.info(`Node ${i.name} is missing url`);return}let l=ao.get(i.url);if(l&&l.iterator.remove(),!(i.replicates===!0||i.replicates?.sends)&&!i.subscriptions?.length&&!l)return;if(ot.info(`Added node ${i.name} at ${i.url} for process ${Ze()}`),i.replicates&&i.subscriptions&&(i={...i,subscriptions:null}),i.name){for(let[d,h]of Du)if(i.url===h.url){Du.delete(d);break}Du.set(i.name,i)}let u=Xe();if(l||(l=new Map,ao.set(i.url,l)),l.iterator=ua(e,(d,h,_)=>{_?f(h,!0):f(h,!1)}),i.subscriptions)for(let d of i.subscriptions){let h=d.database||d.schema;u[h]||(ot.warn(`Database ${h} not found for node ${i.name}, making a subscription anyway`),f(h,!1))}function f(d,h){ot.trace("Setting up replication for database",d,"on node",i.name);let _=l.get(d),m,S=[{replicateByDefault:h,...i}];LE.has(d)&&(S.push({replicateByDefault:h,name:Ze(),start_time:LE.get(d),end_time:Date.now(),replicates:!0}),LE.delete(d));let g=I_(i,d),R=Pi.workers.filter(E=>E.name==="http");if(_?(m=_.worker,_.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,h))})),g)setTimeout(()=>{let E={type:"subscribe-to-node",database:d,nodes:S};m?m.postMessage(E):Lu(E)},cne);else{ot.info("Node no longer should be used, unsubscribing from node",i.replicates,!!u[d],nr().primaryStore.get(Ze())?.replicates),nr().primaryStore.get(Ze())?.replicates||(n=!1);let E={type:"unsubscribe-from-node",database:d,url:i.url,name:i.name};m?m.postMessage(E):vE(E)}}a(f,"onDatabase")}a(s,"onNodeUpdate"),Mu=a(function(i){try{ot.info("Disconnected from node",i.name,i.url,"finished",!!i.finished);let o=Array.from(Du.keys()),c=o.sort(),l=c.indexOf(i.name||Ks(i.url));if(l===-1){ot.warn("Disconnected node not found in node map",i.name,o);return}let u=ao.get(i.url),f=u?.get(i.database);if(!f){ot.warn("Disconnected node not found in replication map",i.database,u);return}if(f.connected=!1,i.finished)return;let d=f.nodes[0];if(!(d.replicates===!0||d.replicates?.sends||d.subscriptions?.length))return;let h=(l+1)%c.length;for(;l!==h;){let _=c[h],m=Du.get(_);u=ao.get(m.url);let S=u?.get(i.database);if(!S){h=(h+1)%c.length;continue}let{worker:g,nodes:R}=S,E=!1;for(let A of f.nodes){if(R.some(N=>N.name===A.name)){ot.info(`Disconnected node is already failing over to ${_} for ${i.database}`);continue}R.push(A),E=!0}if(!E){ot.info(`Disconnected node ${i.name} has no nodes to fail over to ${_}`);return}f.redirectingTo=S,ot.info(`Failing over ${i.database} from ${i.name} to ${_}`),g?g.postMessage({type:"subscribe-to-node",database:i.database,nodes:R}):Lu({database:i.database,nodes:R});return}ot.warn("Unable to find any other node to fail over to",i.name,i.url)}catch(o){ot.error("Error failing over node",o)}},"disconnectedFromNode"),Yc=a(function(i){let o=ao.get(i.url),c=o?.get(i.database);if(!c){ot.warn("Connected node not found in replication map, this may be because the node is being removed",i.database,o);return}if(c.connected=!0,c.latency=i.latency,c.redirectingTo){let{worker:l,nodes:u}=c.redirectingTo,f=u.find(d=>d.name===i.name);c.redirectingTo=null,f&&(u.splice(u.indexOf(f),1),l?l.postMessage({type:"subscribe-to-node",database:i.database,nodes:u}):Lu({database:i.database,nodes:u}))}},"connectedToNode"),(0,Pi.onMessageByType)("disconnected-from-node",Mu),(0,Pi.onMessageByType)("connected-to-node",Yc),(0,Pi.onMessageByType)("request-cluster-status",NH)}function NH(e,t){let r=[];for(let[n,s]of Du)try{let i=ao.get(s.url);ot.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:h}]of i)o.push({database:l,connected:f,latency:h,thread_id:u?.threadId,nodes:d.map(_=>_.name)});let c=(0,Qb.cloneDeep)(s);c.database_sockets=o,delete c.ca,delete c.node_name,delete c.__updatedtime__,delete c.__createdtime__,r.push(c)}}catch(i){ot.warn("Error getting cluster status for",s?.url,i)}return t?.postMessage({type:"cluster-status",connections:r}),{connections:r}}async function co(e,t){let r=nr();e=e??Ks(t.url),t.name=e;try{if(t.ca){let s=new OH.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){ot.error("Error parsing replication CA info for hdb_nodes table",s.message)}let n=r.primaryStore.get(e);if(ot.debug(`Ensuring node ${e} at ${t.url}, existing record:`,n,"new record:",t),!n)await r.put(t);else{t.replicates&&!bH.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,Qb.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])]}ot.info(`Updating node ${e} at ${t.url}`),await r.patch(t)}}var Pi,ME,ot,Qb,bH,OH,cne,ao,Mu,Yc,Du,LE,P_=be(()=>{ve();Pi=M(rt());ds();ME=require("worker_threads");Kc();ot=M(J()),Qb=require("lodash"),bH=M(ce());H();OH=require("crypto"),cne=200,ao=new Map,Du=new Map,LE=new Map;a(jb,"startOnMainThread");a(NH,"requestClusterStatus");ME.parentPort&&(Mu=a(e=>{ME.parentPort.postMessage({type:"disconnected-from-node",...e})},"disconnectedFromNode"),Yc=a(e=>{ME.parentPort.postMessage({type:"connected-to-node",...e})},"connectedToNode"),(0,Pi.onMessageByType)("subscribe-to-node",e=>{Lu(e)}),(0,Pi.onMessageByType)("unsubscribe-from-node",e=>{vE(e)}));a(co,"ensureNode")});var zs=C(jH=>{"use strict";var sr=require("path"),Sn=require("fs-extra"),vu=require("node-forge"),MH=require("net"),{generateKeyPair:Xb,X509Certificate:lo,createPrivateKey:vH}=require("crypto"),lne=require("util");Xb=lne.promisify(Xb);var At=vu.pki,Ys=require("joi"),{v4:UH}=require("uuid"),{validateBySchema:rO}=nt(),ft=J(),fs=ce(),_s=(H(),P($)),{CONFIG_PARAMS:Uu}=_s,Ws=$R(),{ClientError:_a}=he(),UE=require("node:tls"),{relative:xH,join:une}=require("node:path"),{CERT_PREFERENCE_APP:Nwe,CERTIFICATE_VALUES:IH}=Ws,dne=sc(),Zb=It(),{table:fne,getDatabases:_ne,databases:Jb}=(ve(),P(it)),{getJWTRSAKeys:CH}=(Ru(),P(S_));Object.assign(jH,{generateKeys:iO,updateConfigCert:VH,createCsr:Ane,signCertificate:Rne,setCertTable:xu,loadCertificates:GH,reviewSelfSignedCert:aO,createTLSSelector:YH,listCertificates:zH,addCertificate:Ine,removeCertificate:Pne,createNatsCerts:One,generateCertsKeys:bne,getReplicationCert:L_,getReplicationCertAuth:Tne,renewSelfSigned:Nne,hostnamesFromCert:QH,getKey:Dne});var{urlToNodeName:BH,getThisNodeUrl:hne,getThisNodeName:BE,clearThisNodeName:mne}=(ds(),P(pa)),{readFileSync:pne,watchFile:Ene,statSync:HH}=require("node:fs"),wwe=ce(),{getTicketKeys:gne,onMessageFromWorkers:Sne}=rt(),fa=J(),{isMainThread:kH}=require("worker_threads"),{TLSSocket:FH,createSecureContext:Iwe}=require("node:tls"),nO=3650,D_=["127.0.0.1","localhost","::1"],sO=[{name:"countryName",value:"USA"},{name:"stateOrProvinceName",value:"Colorado"},{name:"localityName",value:"Denver"},{name:"organizationName",value:"HarperDB, Inc."}];Sne(async e=>{e.type===_s.ITC_EVENT_TYPES.RESTART&&(fs.initSync(!0),await aO())});var Lr;function ma(){return Lr||(Lr=_ne().system.hdb_certificate,Lr||(Lr=fne({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__"}]}))),Lr}a(ma,"getCertTable");async function L_(){let e=YH("operations-api"),t={secureContexts:null,setSecureContext:a(s=>{},"setSecureContext")};await e.initialize(t);let r=t.secureContexts.get(BE());if(!r)return;let n=new lo(r.options.cert);return r.cert_parsed=n,r.issuer=n.issuer,r}a(L_,"getReplicationCert");async function Tne(){ma();let e=(await L_()).options.cert,r=new lo(e).issuer.match(/CN=(.*)/)?.[1];return Lr.get(r)}a(Tne,"getReplicationCertAuth");var PH,ha=new Map;function GH(){if(PH)return;PH=!0;let e=[{configKey:Uu.TLS},{configKey:Uu.OPERATIONSAPI_TLS}];ma();let t=sr.dirname(Zb.getConfigFilePath()),r;for(let{configKey:n}of e){let s=Zb.getConfigFromFile(n);if(s){Array.isArray(s)||(s=[s]);for(let i of s){let o=i.privateKey,c=o&&xH(une(t,"keys"),o);c&&DH(o,l=>{ha.set(c,l)},"private key");for(let l of[!1,!0]){let u=i[l?"certificateAuthority":"certificate"];if(u&&kH){let f;DH(u,d=>{if(IH.cert===d)return;let h=i.hostname??i.hostnames??i.host??i.hosts;h&&!Array.isArray(h)&&(h=[h]);let _=KH(u),m=new lo(_),S;try{S=cO(m)}catch(A){ft.error("error extracting common name from certificate",A);return}if(S==null){ft.error("error extracting common name from certificate");return}if(m.checkIssued(new lo(IH.cert)))return;let g=Lr.primaryStore.get(S),R=HH(u).mtimeMs,E=!g||g.is_self_signed?1:g.file_timestamp??g.__updatedtime__;if(g&&R<=E){R<E&&ft.info(`Certificate ${S} at ${u} is older (${new Date(R)}) than the certificate in the database (${E>1?new Date(E):"only self signed certificate available"})`);return}r=Lr.put({name:S,uses:["https",...n.includes("operations")?["operations"]:[]],ciphers:i.ciphers,certificate:_,private_key_name:c,is_authority:l,hostnames:h,file_timestamp:R,details:{issuer:m.issuer.replace(/\n/g," "),subject:m.subject.replace(/\n/g," "),subject_alt_name:m.subjectAltName,serial_number:m.serialNumber,valid_from:m.validFrom,valid_to:m.validTo}})},l?"certificate authority":"certificate")}}}}}return r}a(GH,"loadCertificates");function DH(e,t,r){let n,s=a((i,o)=>{try{let c=i.mtimeMs;c&&c!==n&&(o&&kH&&ft.warn(`Reloading ${r}:`,e),n=c,t(KH(e)))}catch(c){ft.error(`Error loading ${r}:`,e,c)}},"loadFile");Sn.existsSync(e)?s(HH(e)):ft.error(`${r} file not found:`,e),Ene(e,{persistent:!1},s)}a(DH,"loadAndWatch");function eO(){let e=hne();if(e==null){let t=D_[0];return ft.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return BH(e)}a(eO,"getHost");function xE(){let e=BE();if(e==null){let t=D_[0];return ft.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return e}a(xE,"getCommonName");async function Ane(){let e=await L_(),t=At.certificateFromPem(e.options.cert),r=At.privateKeyFromPem(e.options.key);ft.info("Creating CSR with cert named:",e.name);let n=At.createCertificationRequest();n.publicKey=t.publicKey;let s=[{name:"commonName",value:xE()},...sO];ft.info("Creating CSR with subject",s),n.setSubject(s);let i=[{name:"unstructuredName",value:"HarperDB, Inc."},{name:"extensionRequest",extensions:qH()}];return ft.info("Creating CSR with attributes",i),n.setAttributes(i),n.sign(r),vu.pki.certificationRequestToPem(n)}a(Ane,"createCsr");function qH(){let e=D_.includes(xE())?D_:[...D_,xE()];return e.includes(eO())||e.push(eO()),[{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=>MH.isIP(t)?{type:7,ip:t}:{type:2,value:t})}]}a(qH,"certExtensions");async function Rne(e){let t={},r=sr.join(fs.getHdbBasePath(),_s.LICENSE_KEY_DIR_NAME);if(e.csr){let n,s;ma();for await(let f of Lr.search([]))if(f.is_authority&&!f.details.issuer.includes("HarperDB-Certificate-Authority")){if(ha.has(f.private_key_name)){n=ha.get(f.private_key_name),s=f;break}else if(f.private_key_name&&await Sn.exists(sr.join(r,f.private_key_name))){n=Sn.readFile(sr.join(r,f.private_key_name)),s=f;break}}if(!n){let f=await tO();s=f.ca,n=f.private_key}n=At.privateKeyFromPem(n),t.signingCA=s.certificate;let i=At.certificateFromPem(s.certificate);ft.info("Signing CSR with cert named",s.name);let o=At.certificationRequestFromPem(e.csr);try{o.verify()}catch(f){return ft.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()+nO),ft.info("sign cert setting validity:",c.validity),ft.info("sign cert setting subject from CSR:",o.subject.attributes),c.setSubject(o.subject.attributes),ft.info("sign cert setting issuer:",i.subject.attributes),c.setIssuer(i.subject.attributes);let u=o.getAttribute({name:"extensionRequest"}).extensions;ft.info("sign cert adding extensions from CSR:",u),c.setExtensions(u),c.publicKey=o.publicKey,c.sign(n,vu.md.sha256.create()),t.certificate=At.certificateToPem(c)}else ft.info("Sign cert did not receive a CSR from:",e.url,"only the CA will be returned");return t}a(Rne,"signCertificate");async function yne(e,t){await xu({name:BE(),uses:["https","wss"],certificate:e,private_key_name:"privateKey.pem",is_authority:!1,is_self_signed:!0}),await xu({name:t.subject.getField("CN").value,uses:["https","wss"],certificate:At.certificateToPem(t),private_key_name:"privateKey.pem",is_authority:!0,is_self_signed:!0})}a(yne,"createCertificateTable");async function xu(e){let t=new lo(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},ma(),await Lr.patch(e)}a(xu,"setCertTable");async function iO(){let e=await Xb("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}});return{public_key:At.publicKeyFromPem(e.publicKey),private_key:At.privateKeyFromPem(e.privateKey)}}a(iO,"generateKeys");async function oO(e,t,r){let n=At.createCertificate();if(!t){let o=await L_();t=At.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()+nO);let i=[{name:"commonName",value:xE()},...sO];return n.setSubject(i),n.setIssuer(r.subject.attributes),n.setExtensions(qH()),n.sign(e,vu.md.sha256.create()),At.certificateToPem(n)}a(oO,"generateCertificates");async function tO(){let e=await zH(),t;for(let r of e){if(!r.is_authority)continue;let n=await WH(r.private_key_name);if(r.private_key_name&&n&&new lo(r.certificate).checkPrivateKey(vH(n))){ft.trace(`CA named: ${r.name} found with matching private key`),t={ca:r,private_key:n};break}}if(t)return t;ft.trace("No CA found with matching private key")}a(tO,"getCertAuthority");async function $H(e,t,r=!0){let n=At.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()+nO);let i=[{name:"commonName",value:`HarperDB-Certificate-Authority-${fs.get(Uu.REPLICATION_HOSTNAME)??BH(fs.get(Uu.REPLICATION_URL))??UH().split("-")[0]}`},...sO];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=sr.join(fs.getHdbBasePath(),_s.LICENSE_KEY_DIR_NAME),c=sr.join(o,Ws.PRIVATEKEY_PEM_NAME);return r&&await Sn.writeFile(c,At.privateKeyToPem(e)),n}a($H,"generateCertAuthority");async function bne(){let{private_key:e,public_key:t}=await iO(),r=await $H(e,t),n=await oO(e,t,r);await yne(n,r),VH()}a(bne,"generateCertsKeys");async function One(){let e=await oO(At.privateKeyFromPem(Ws.CERTIFICATE_VALUES.key),void 0,At.certificateFromPem(Ws.CERTIFICATE_VALUES.cert)),t=sr.join(fs.getHdbBasePath(),_s.LICENSE_KEY_DIR_NAME),r=sr.join(t,Ws.NATS_CERTIFICATE_PEM_NAME);await Sn.exists(r)||await Sn.writeFile(r,e);let n=sr.join(t,Ws.NATS_CA_PEM_NAME);await Sn.exists(n)||await Sn.writeFile(n,Ws.CERTIFICATE_VALUES.cert)}a(One,"createNatsCerts");async function Nne(){ma();for await(let e of Lr.search([{attribute:"is_self_signed",value:!0}]))await Lr.delete(e.name);await aO()}a(Nne,"renewSelfSigned");async function aO(){mne(),await GH(),ma();let e=await tO();if(!e){ft.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=fs.get(Uu.TLS_PRIVATEKEY),n=sr.join(fs.getHdbBasePath(),_s.LICENSE_KEY_DIR_NAME),s,i=xH(n,r);try{s=At.privateKeyFromPem(await Sn.readFile(r))}catch(c){ft.warn("Unable to parse the TLS key",r,"A new key will be generated and used to create Certificate Authority",c),{private_key:s}=await iO(),await Sn.exists(sr.join(n,Ws.PRIVATEKEY_PEM_NAME))&&(i=`privateKey${UH().split("-")[0]}.pem`),await Sn.writeFile(sr.join(n,i),At.privateKeyToPem(s))}let o=await $H(s,At.setRsaPublicKey(s.n,s.e),!1);await xu({name:o.subject.getField("CN").value,uses:["https"],certificate:At.certificateToPem(o),private_key_name:i,is_authority:!0,is_self_signed:!0})}if(!await L_()){let r=BE();ft.notify(`A suitable replication certificate was not found, creating new self singed cert named: ${r}`),e=e??await tO();let n=At.certificateFromPem(e.ca.certificate),s=n.publicKey,i=await oO(At.privateKeyFromPem(e.private_key),s,n);await xu({name:r,uses:["https","operations","wss"],certificate:i,is_authority:!1,private_key_name:e.ca.private_key_name,is_self_signed:!0})}}a(aO,"reviewSelfSignedCert");function VH(){let e=dne(Object.keys(_s.CONFIG_PARAM_MAP),!0),t=sr.join(fs.getHdbBasePath(),_s.LICENSE_KEY_DIR_NAME),r=sr.join(t,Ws.PRIVATEKEY_PEM_NAME),n=sr.join(t,Ws.NATS_CERTIFICATE_PEM_NAME),s=sr.join(t,Ws.NATS_CA_PEM_NAME),i=_s.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),Zb.updateConfigValue(void 0,void 0,o,!1,!0)}a(VH,"updateConfigCert");function KH(e){return e.startsWith("-----BEGIN")?e:pne(e,"utf8")}a(KH,"readPEM");var LH=UE.createSecureContext;UE.createSecureContext=function(e){if(!e.cert||!e.key)return LH(e);let t={...e};delete t.key,delete t.cert;let r=LH(t);return r.context.setCert(e.cert),r.context.setKey(e.key,void 0),r};var wne=FH.prototype._init;FH.prototype._init=function(e,t){wne.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 Wc=new Map;function YH(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(),Wc.clear();let f=0;for await(let d of Jb.system.hdb_certificate.search([])){let h=d.certificate,_=new lo(h);d.is_authority&&(_.asString=h,Wc.set(_.subject,h))}for await(let d of Jb.system.hdb_certificate.search([]))try{if(d.is_authority)continue;let h=e==="operations-api",_=d.is_self_signed?1:2;h&&d.uses?.includes?.("operations")&&(_+=1);let m=await WH(d.private_key_name),S=d.certificate,g=new lo(S);if(Wc.has(g.issuer)&&(S+=`
|
|
22
|
+
`,"")}a(aH,"runCommand");async function Hre(){try{await hre.access(Hb)}catch{return!1}let e=await aH(`${Hb} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return mre.eq(t,xre)}a(Hre,"checkNATSServerInstalled");async function $b(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let o=await iH.getClusterUser();if(Vc(o))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=o.username,r=o.decrypt_hash}Vs.trace("create nats connection called");let i=await wre({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:Or.get(Ve.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:Or.get(Ve.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:Or.get(Ve.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),Vs.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(o=>{o&&Vs.error("Error with Nats client connection, connection closed",o),i===Qr&&cH()}),i}a($b,"createConnection");function cH(){Qr=void 0,Gc=void 0,qc=void 0,$c=void 0}a(cH,"clearClientCache");async function kre(){Qr&&(await Qr.drain(),Qr=void 0,Gc=void 0,qc=void 0,$c=void 0)}a(kre,"closeConnection");var Qr,$c;async function b_(){return $c||($c=$b(Or.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),Qr=await $c),Qr||$c}a(b_,"getConnection");async function O_(){if(Gc)return Gc;Vc(Qr)&&await b_();let{domain:e}=Nu(Ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(Vc(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return Gc=await Qr.jetstreamManager({domain:e,timeout:6e4}),Gc}a(O_,"getJetStreamManager");async function lH(){if(qc)return qc;Vc(Qr)&&await b_();let{domain:e}=Nu(Ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(Vc(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return qc=Qr.jetstream({domain:e,timeout:6e4}),qc}a(lH,"getJetStream");async function Ci(){let e=Qr||await b_(),t=Gc||await O_(),r=qc||await lH();return{connection:e,jsm:t,js:r}}a(Ci,"getNATSReferences");async function Fre(e){let t=Or.get(Ve.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await iH.getClusterUser(),s=await $b(t,r,n),i=qb(),o=s.subscribe(i),c=[],l,u=(async()=>{for await(let f of o){let d=oH.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 NE.async_set_timeout(e),await o.drain(),await s.close(),await u,c}a(Fre,"getServerList");async function Vb(e,t){let{jsm:r}=await Ci(),n=Or.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Or.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=Or.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:Ire.File,retention:Cre.Limits,subjects:t,discard:Pre.Old,max_msgs:s,max_bytes:i,max_age:n})}a(Vb,"createLocalStream");async function uH(){let{jsm:e}=await Ci(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}a(uH,"listStreams");async function Gre(e){let{jsm:t}=await Ci();await t.streams.delete(e)}a(Gre,"deleteLocalStream");async function qre(e){let{connection:t}=await Ci(),r=[],n=qb(),s=t.subscribe(n),i=(async()=>{for await(let o of s)r.push(oH.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(qre,"listRemoteStreams");async function $re(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Ci(),i=tH(),o={durable_name:i,ack_policy:Fb.Explicit};t&&(o.deliver_policy=Gb.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=kb(f.data),h={nats_timestamp:f.info.timestampNanos,nats_sequence:f.info.streamSequence,entry:d};if(f.headers&&(h.origin=f.headers.get(Dr.MSG_HEADERS.ORIGIN)),u.push(h),f.ack(),f.info.pending===0)break}return await c.delete(),u}a($re,"viewStream");async function*Vre(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Ci(),i=tH(),o={durable_name:i,ack_policy:Fb.Explicit};t&&(o.deliver_policy=Gb.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=kb(u.data);f[0]||(f=[f]);for(let d of f){let h={nats_timestamp:u.info.timestampNanos,nats_sequence:u.info.streamSequence,entry:d};u.headers&&(h.origin=u.headers.get(Dr.MSG_HEADERS.ORIGIN)),yield h}if(u.ack(),u.info.pending===0)break}await c.delete()}a(Vre,"viewStreamIterator");async function Kre(e,t,r,n){Vs.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=dH(n,r);let{js:s}=await Ci(),i=await IE(),o=`${e}.${i}`,c=await vre(()=>n instanceof Uint8Array?n:sH.encode(n));try{Vs.trace(`publishToStream publishing to subject: ${o}`),Mre(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 _H(async()=>{try{await s.publish(o,c,{headers:r})}catch{if(l.code&&l.code.toString()==="503"){Vs.trace(`publishToStream creating stream: ${t}`);let f=o.split(".");f[2]="*",await Vb(t,[o]),await s.publish(o,c,{headers:r})}else throw l}});throw l}}a(Kre,"publishToStream");function dH(e,t){t===void 0&&(t=Lre());let r=Or.get(Ve.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(Dr.MSG_HEADERS.ORIGIN)&&r&&t.append(Dr.MSG_HEADERS.ORIGIN,r),t}a(dH,"addNatsMsgHeader");function Nu(e){e=e.toLowerCase();let t=y_.join(Or.get(Ve.CONFIG_PARAMS.ROOTPATH),Ure);if(e===Ve.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return Vc(Bb)&&(Bb={port:A_.getConfigFromFile(Ve.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:A_.getConfigFromFile(Ve.CONFIG_PARAMS.CLUSTERING_NODENAME)+Dr.SERVER_SUFFIX.HUB,config_file:Dr.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:y_.join(t,Dr.PID_FILES.HUB),hdb_nats_path:t}),Bb;if(e===Ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return Vc(xb)&&(xb={port:A_.getConfigFromFile(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:A_.getConfigFromFile(Ve.CONFIG_PARAMS.CLUSTERING_NODENAME)+Dr.SERVER_SUFFIX.LEAF,config_file:Dr.NATS_CONFIG_FILES.LEAF_SERVER,domain:A_.getConfigFromFile(Ve.CONFIG_PARAMS.CLUSTERING_NODENAME)+Dr.SERVER_SUFFIX.LEAF,pid_file_path:y_.join(t,Dr.PID_FILES.LEAF),hdb_nats_path:t}),xb;Vs.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(Nu,"getServerConfig");async function fH(e,t,r,n){try{await e.consumers.add(t,{ack_policy:Fb.Explicit,durable_name:r,deliver_policy:Gb.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}a(fH,"createConsumer");async function Yre(e,t,r){await e.consumers.delete(t,r)}a(Yre,"removeConsumer");function Wre(e){return e.split(".")[1]}a(Wre,"extractServerName");async function zre(e,t,r=6e4,n=qb()){if(!NE.isObject(t))throw new Error("data param must be an object");let s=sH.encode(t),{connection:i}=await Ci(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return kb(c.data)}a(zre,"request");function Kb(e){return new Promise(async(t,r)=>{let n=Sre(Hb,["--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(Kb,"reloadNATS");async function Qre(){let{pid_file_path:e}=Nu(Ve.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await Kb(e)}a(Qre,"reloadNATSHub");async function jre(){let{pid_file_path:e}=Nu(Ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await Kb(e)}a(jre,"reloadNATSLeaf");function Jre(e,t,r){let n;switch(e.code){case eH.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case eH.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}a(Jre,"requestErrorHandler");async function Xre(e,t){let r=t+Dr.SERVER_SUFFIX.LEAF,{connection:n}=await Ci(),{jsm:s}=await one(r),{schema:i,table:o}=e,c=wE.createNatsTableStreamName(i,o),l=e.start_time?e.start_time:new Date(Date.now()).toISOString();await _H(async()=>{if(e.subscribe===!0)await fH(s,c,n.info.server_name,l);else try{await Yre(s,c,n.info.server_name)}catch(u){Vs.trace(u)}})}a(Xre,"updateRemoteConsumer");async function Zre(e,t,r,n){let s=wE.createNatsTableStreamName(e,t),i=r+Dr.SERVER_SUFFIX.LEAF,o={type:Ve.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!nH&&Ore()<Or.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=Ub();await c(o)}await yre(o),n==="stop"&&await NE.async_set_timeout(1e3)}a(Zre,"updateConsumerIterator");function _H(e){return Rre.writeTransaction(Ve.SYSTEM_SCHEMA_NAME,Ve.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(_H,"exclusiveLock");async function hH(e,t){let r=wE.createNatsTableStreamName(e,t),n=await IE(),s=nne(e,t,n);await Vb(r,[s])}a(hH,"createLocalTableStream");async function ene(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await hH(n,s)}}a(ene,"createTableStreams");async function mH(e,t,r=void 0){if(Or.get(Ve.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=wE.createNatsTableStreamName(e,t),{domain:s}=Nu(Ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await b_()).jetstreamManager({domain:s,timeout:24e4})).streams.purge(n,r)}catch(n){if(n.message==="stream not found")Vs.warn(n);else throw n}}a(mH,"purgeTableStream");async function tne(e,t){if(Or.get(Ve.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await mH(e,t[r])}a(tne,"purgeSchemaTableStreams");async function rne(e){return(await O_()).streams.info(e)}a(rne,"getStreamInfo");function nne(e,t,r){return`${Dr.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}a(nne,"createSubjectName");async function IE(){if(R_)return R_;if(R_=(await O_())?.nc?.info?.server_name,R_===void 0)throw new Error("Unable to get jetstream manager server name");return R_}a(IE,"getJsmServerName");async function sne(){let e=await O_(),t=await IE(),r=await uH();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let o=ine(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(".");Vs.trace(`Updating stream subject name from: ${i} to: ${f}`),s.subjects[0]=f,await e.streams.update(s.name,s)}}a(sne,"updateLocalStreams");function ine(e){let{config:t}=e,r=!1,n=Or.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Or.get(Ve.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=Or.get(Ve.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(ine,"updateStreamLimits");async function one(e){let t,r;try{t=await Qr.jetstream({domain:e}),r=await Qr.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw Vs.error("Unable to connect to:",e),n}return{js:t,jsm:r}}a(one,"connectToRemoteJS")});function Yb(e){let t=e.get(CE),r=t?(0,wu.unpack)(t):null;r||(r={remoteNameToId:{}});let n=Ze(),s=!1;r.nodeName=Ze();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:w_(e)??1,nodes:[]})})}i[n]=0,e.putSync(CE,(0,wu.pack)(r))}return r}function N_(e){return Yb(e).remoteNameToId}function gH(e,t){let r=Yb(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(CE,(0,wu.pack)(r)),s}function PE(e,t){let r=Yb(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(CE,(0,wu.pack)(r))}return EH.trace?.("The remote node name map",e,n,s),s}var EH,wu,CE,Wb=be(()=>{EH=M(_i());ds();wu=require("msgpackr"),CE=Symbol.for("remote-ids");a(Yb,"getIdMappingRecord");a(N_,"exportIdMapping");a(gH,"remoteToLocalNodeId");a(PE,"getIdOfRemoteNode")});var zb={};Ue(zb,{commits_awaiting_replication:()=>Cu,getHDBNodeTable:()=>nr,getReplicationSharedStatus:()=>DE,iterateRoutes:()=>C_,shouldReplicateToNode:()=>I_,subscribeToNodeUpdates:()=>Pu});function nr(){return SH||(SH=ut({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 DE(e,t,r,n){return new Float64Array(e.getUserSharedBuffer(["replicated",t,r],new ArrayBuffer(32),n&&{callback:n}))}function Pu(e){nr().subscribe({}).then(async t=>{for await(let r of t){let n=r?.value?.name;yH.debug?.("adding node",n,"on node",Ze()," on process",process.pid),server.nodes=server.nodes.filter(i=>i.name!==n),r.type==="put"&&n!==Ze()&&(r.value?server.nodes.push(r.value):console.error("Invalid node update event",r));let s=new Map;for await(let i of nr().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 I_(e,t){return(e.replicates===!0||e.replicates?.sends)&&databases[t]&&nr().primaryStore.get(Ze())?.replicates||e.subscriptions?.some(r=>(r.database||r.schema)===t&&r.subscribe)}function ane(){Pu(e=>{ua({},(t,r)=>{let n=e.name,s=TH.get(n);if(s||TH.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=DE(i,r,n,()=>{let c=o[0],l=o.lastTime;for(let{txnTime:u,onConfirm:f}of Cu.get(r)||[])u>l&&u<=c&&f();o.lastTime=c});o.lastTime=0,s.set(r,o)}})})}function*C_(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=Iu.default.get(x.REPLICATION_SECUREPORT)??(!Iu.default.get(x.REPLICATION_PORT)&&Iu.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||Iu.default.get(x.REPLICATION_PORT)||Iu.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){AH.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,shard:t.shard}}}var AH,RH,Iu,yH,SH,TH,Cu,Kc=be(()=>{ve();ds();km();AH=require("worker_threads"),RH=M(he()),Iu=M(ce());H();yH=M(_i());server.nodes=[];a(nr,"getHDBNodeTable");a(DE,"getReplicationSharedStatus");a(Pu,"subscribeToNodeUpdates");a(I_,"shouldReplicateToNode");TH=new Map;fD((e,t,r)=>{if(r>server.nodes.length)throw new RH.ClientError(`Cannot confirm replication to more nodes (${r}) than are in the network (${server.nodes.length})`);Cu||(Cu=new Map,ane());let n=Cu.get(e);return n||(n=[],Cu.set(e,n)),new Promise(s=>{let i=0;n.push({txnTime:t,onConfirm:a(()=>{++i===r&&s()},"onConfirm")})})});a(ane,"startSubscriptionToReplications");a(C_,"iterateRoutes")});var wH={};Ue(wH,{connectedToNode:()=>Yc,disconnectedFromNode:()=>Mu,ensureNode:()=>co,requestClusterStatus:()=>NH,startOnMainThread:()=>jb});async function jb(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){LE.set(i,w_(l.auditStore));break}}}Pi.whenThreadsStarted.then(async()=>{let i=[];for await(let o of r.system.hdb_nodes?.search([])||[])i.push(o);for(let o of C_(e))try{let c=!o.subscriptions;if(c){let u=Ze(),f=nr().primaryStore.get(u);if(f!==null){let d=e.url??da();(f===void 0||f.url!==d||f.shard!==e.shard)&&await co(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)}Pu(s)});let n;function s(i,o=i?.name){let c=Ze()&&o===Ze()||da()&&i?.url===da();if(c){let d=!!i?.replicates;if(n!==void 0&&n!==d)for(let h of nr().search([]))h.replicates&&h.name!==o&&s(h,h.name);n=d}if(ot.trace("Setting up node replication for",i),!i){for(let[d,h]of ao){let _;for(let[m,{worker:S,nodes:g}]of h){let R=g[0];if(R&&R.name==o){_=!0;for(let[E,{worker:A}]of h)h.delete(E),ot.warn("Node was deleted, unsubscribing from node",o,E,d),A?.postMessage({type:"unsubscribe-from-node",node:o,database:E,url:d});break}}if(_){ao.get(d).iterator.remove(),ao.delete(d);return}}return}if(c)return;if(!i.url){ot.info(`Node ${i.name} is missing url`);return}let l=ao.get(i.url);if(l&&l.iterator.remove(),!(i.replicates===!0||i.replicates?.sends)&&!i.subscriptions?.length&&!l)return;if(ot.info(`Added node ${i.name} at ${i.url} for process ${Ze()}`),i.replicates&&i.subscriptions&&(i={...i,subscriptions:null}),i.name){for(let[d,h]of Du)if(i.url===h.url){Du.delete(d);break}Du.set(i.name,i)}let u=Xe();if(l||(l=new Map,ao.set(i.url,l)),l.iterator=ua(e,(d,h,_)=>{_?f(h,!0):f(h,!1)}),i.subscriptions)for(let d of i.subscriptions){let h=d.database||d.schema;u[h]||(ot.warn(`Database ${h} not found for node ${i.name}, making a subscription anyway`),f(h,!1))}function f(d,h){ot.trace("Setting up replication for database",d,"on node",i.name);let _=l.get(d),m,S=[{replicateByDefault:h,...i}];LE.has(d)&&(S.push({replicateByDefault:h,name:Ze(),start_time:LE.get(d),end_time:Date.now(),replicates:!0}),LE.delete(d));let g=I_(i,d),R=Pi.workers.filter(E=>E.name==="http");if(_?(m=_.worker,_.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,h))})),g)setTimeout(()=>{let E={type:"subscribe-to-node",database:d,nodes:S};m?m.postMessage(E):Lu(E)},cne);else{ot.info("Node no longer should be used, unsubscribing from node",i.replicates,!!u[d],nr().primaryStore.get(Ze())?.replicates),nr().primaryStore.get(Ze())?.replicates||(n=!1);let E={type:"unsubscribe-from-node",database:d,url:i.url,name:i.name};m?m.postMessage(E):vE(E)}}a(f,"onDatabase")}a(s,"onNodeUpdate"),Mu=a(function(i){try{ot.info("Disconnected from node",i.name,i.url,"finished",!!i.finished);let o=Array.from(Du.keys()),c=o.sort(),l=c.indexOf(i.name||Ks(i.url));if(l===-1){ot.warn("Disconnected node not found in node map",i.name,o);return}let u=ao.get(i.url),f=u?.get(i.database);if(!f){ot.warn("Disconnected node not found in replication map",i.database,u);return}if(f.connected=!1,i.finished)return;let d=f.nodes[0];if(!(d.replicates===!0||d.replicates?.sends||d.subscriptions?.length))return;let h=(l+1)%c.length;for(;l!==h;){let _=c[h],m=Du.get(_);u=ao.get(m.url);let S=u?.get(i.database);if(!S){h=(h+1)%c.length;continue}let{worker:g,nodes:R}=S,E=!1;for(let A of f.nodes){if(R.some(N=>N.name===A.name)){ot.info(`Disconnected node is already failing over to ${_} for ${i.database}`);continue}R.push(A),E=!0}if(!E){ot.info(`Disconnected node ${i.name} has no nodes to fail over to ${_}`);return}f.redirectingTo=S,ot.info(`Failing over ${i.database} from ${i.name} to ${_}`),g?g.postMessage({type:"subscribe-to-node",database:i.database,nodes:R}):Lu({database:i.database,nodes:R});return}ot.warn("Unable to find any other node to fail over to",i.name,i.url)}catch(o){ot.error("Error failing over node",o)}},"disconnectedFromNode"),Yc=a(function(i){let o=ao.get(i.url),c=o?.get(i.database);if(!c){ot.warn("Connected node not found in replication map, this may be because the node is being removed",i.database,o);return}if(c.connected=!0,c.latency=i.latency,c.redirectingTo){let{worker:l,nodes:u}=c.redirectingTo,f=u.find(d=>d.name===i.name);c.redirectingTo=null,f&&(u.splice(u.indexOf(f),1),l?l.postMessage({type:"subscribe-to-node",database:i.database,nodes:u}):Lu({database:i.database,nodes:u}))}},"connectedToNode"),(0,Pi.onMessageByType)("disconnected-from-node",Mu),(0,Pi.onMessageByType)("connected-to-node",Yc),(0,Pi.onMessageByType)("request-cluster-status",NH)}function NH(e,t){let r=[];for(let[n,s]of Du)try{let i=ao.get(s.url);ot.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:h}]of i)o.push({database:l,connected:f,latency:h,thread_id:u?.threadId,nodes:d.map(_=>_.name)});let c=(0,Qb.cloneDeep)(s);c.database_sockets=o,delete c.ca,delete c.node_name,delete c.__updatedtime__,delete c.__createdtime__,r.push(c)}}catch(i){ot.warn("Error getting cluster status for",s?.url,i)}return t?.postMessage({type:"cluster-status",connections:r}),{connections:r}}async function co(e,t){let r=nr();e=e??Ks(t.url),t.name=e;try{if(t.ca){let s=new OH.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){ot.error("Error parsing replication CA info for hdb_nodes table",s.message)}let n=r.primaryStore.get(e);if(ot.debug(`Ensuring node ${e} at ${t.url}, existing record:`,n,"new record:",t),!n)await r.put(t);else{t.replicates&&!bH.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,Qb.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])]}ot.info(`Updating node ${e} at ${t.url}`),await r.patch(t)}}var Pi,ME,ot,Qb,bH,OH,cne,ao,Mu,Yc,Du,LE,P_=be(()=>{ve();Pi=M(rt());ds();ME=require("worker_threads");Kc();ot=M(J()),Qb=require("lodash"),bH=M(ce());H();OH=require("crypto"),cne=200,ao=new Map,Du=new Map,LE=new Map;a(jb,"startOnMainThread");a(NH,"requestClusterStatus");ME.parentPort&&(Mu=a(e=>{ME.parentPort.postMessage({type:"disconnected-from-node",...e})},"disconnectedFromNode"),Yc=a(e=>{ME.parentPort.postMessage({type:"connected-to-node",...e})},"connectedToNode"),(0,Pi.onMessageByType)("subscribe-to-node",e=>{Lu(e)}),(0,Pi.onMessageByType)("unsubscribe-from-node",e=>{vE(e)}));a(co,"ensureNode")});var zs=C(jH=>{"use strict";var sr=require("path"),{watch:lne}=require("chokidar"),Sn=require("fs-extra"),vu=require("node-forge"),MH=require("net"),{generateKeyPair:Xb,X509Certificate:lo,createPrivateKey:vH}=require("crypto"),une=require("util");Xb=une.promisify(Xb);var At=vu.pki,Ys=require("joi"),{v4:UH}=require("uuid"),{validateBySchema:rO}=nt(),ft=J(),fs=ce(),_s=(H(),P($)),{CONFIG_PARAMS:Uu}=_s,Ws=$R(),{ClientError:_a}=he(),UE=require("node:tls"),{relative:xH,join:dne}=require("node:path"),{CERT_PREFERENCE_APP:Nwe,CERTIFICATE_VALUES:IH}=Ws,fne=sc(),Zb=It(),{table:_ne,getDatabases:hne,databases:Jb}=(ve(),P(it)),{getJWTRSAKeys:CH}=(Ru(),P(S_));Object.assign(jH,{generateKeys:iO,updateConfigCert:VH,createCsr:Ane,signCertificate:Rne,setCertTable:xu,loadCertificates:GH,reviewSelfSignedCert:aO,createTLSSelector:YH,listCertificates:zH,addCertificate:Ine,removeCertificate:Pne,createNatsCerts:One,generateCertsKeys:bne,getReplicationCert:L_,getReplicationCertAuth:Tne,renewSelfSigned:Nne,hostnamesFromCert:QH,getKey:Dne});var{urlToNodeName:BH,getThisNodeUrl:mne,getThisNodeName:BE,clearThisNodeName:pne}=(ds(),P(pa)),{readFileSync:Ene,statSync:HH}=require("node:fs"),wwe=ce(),{getTicketKeys:gne,onMessageFromWorkers:Sne}=rt(),fa=J(),{isMainThread:kH}=require("worker_threads"),{TLSSocket:FH,createSecureContext:Iwe}=require("node:tls"),nO=3650,D_=["127.0.0.1","localhost","::1"],sO=[{name:"countryName",value:"USA"},{name:"stateOrProvinceName",value:"Colorado"},{name:"localityName",value:"Denver"},{name:"organizationName",value:"HarperDB, Inc."}];Sne(async e=>{e.type===_s.ITC_EVENT_TYPES.RESTART&&(fs.initSync(!0),await aO())});var Lr;function ma(){return Lr||(Lr=hne().system.hdb_certificate,Lr||(Lr=_ne({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__"}]}))),Lr}a(ma,"getCertTable");async function L_(){let e=YH("operations-api"),t={secureContexts:null,setSecureContext:a(s=>{},"setSecureContext")};await e.initialize(t);let r=t.secureContexts.get(BE());if(!r)return;let n=new lo(r.options.cert);return r.cert_parsed=n,r.issuer=n.issuer,r}a(L_,"getReplicationCert");async function Tne(){ma();let e=(await L_()).options.cert,r=new lo(e).issuer.match(/CN=(.*)/)?.[1];return Lr.get(r)}a(Tne,"getReplicationCertAuth");var PH,ha=new Map;function GH(){if(PH)return;PH=!0;let e=[{configKey:Uu.TLS},{configKey:Uu.OPERATIONSAPI_TLS}];ma();let t=sr.dirname(Zb.getConfigFilePath()),r;for(let{configKey:n}of e){let s=Zb.getConfigFromFile(n);if(s){Array.isArray(s)||(s=[s]);for(let i of s){let o=i.privateKey,c=o&&xH(dne(t,"keys"),o);c&&DH(o,l=>{ha.set(c,l)},"private key");for(let l of[!1,!0]){let u=i[l?"certificateAuthority":"certificate"];if(u&&kH){let f;DH(u,d=>{if(IH.cert===d)return;let h=i.hostname??i.hostnames??i.host??i.hosts;h&&!Array.isArray(h)&&(h=[h]);let _=KH(u),m=new lo(_),S;try{S=cO(m)}catch(A){ft.error("error extracting common name from certificate",A);return}if(S==null){ft.error("error extracting common name from certificate");return}if(m.checkIssued(new lo(IH.cert)))return;let g=Lr.primaryStore.get(S),R=HH(u).mtimeMs,E=!g||g.is_self_signed?1:g.file_timestamp??g.__updatedtime__;if(g&&R<=E){R<E&&ft.info(`Certificate ${S} at ${u} is older (${new Date(R)}) than the certificate in the database (${E>1?new Date(E):"only self signed certificate available"})`);return}r=Lr.put({name:S,uses:["https",...n.includes("operations")?["operations"]:[]],ciphers:i.ciphers,certificate:_,private_key_name:c,is_authority:l,hostnames:h,file_timestamp:R,details:{issuer:m.issuer.replace(/\n/g," "),subject:m.subject.replace(/\n/g," "),subject_alt_name:m.subjectAltName,serial_number:m.serialNumber,valid_from:m.validFrom,valid_to:m.validTo}})},l?"certificate authority":"certificate")}}}}}return r}a(GH,"loadCertificates");function DH(e,t,r){let n,s=a((i,o)=>{try{let c=o.mtimeMs;c&&c!==n&&(n&&kH&&ft.warn(`Reloading ${r}:`,i),n=c,t(KH(i)))}catch(c){ft.error(`Error loading ${r}:`,i,c)}},"loadFile");Sn.existsSync(e)?s(e,HH(e)):ft.error(`${r} file not found:`,e),lne(e,{persistent:!1}).on("change",s)}a(DH,"loadAndWatch");function eO(){let e=mne();if(e==null){let t=D_[0];return ft.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return BH(e)}a(eO,"getHost");function xE(){let e=BE();if(e==null){let t=D_[0];return ft.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return e}a(xE,"getCommonName");async function Ane(){let e=await L_(),t=At.certificateFromPem(e.options.cert),r=At.privateKeyFromPem(e.options.key);ft.info("Creating CSR with cert named:",e.name);let n=At.createCertificationRequest();n.publicKey=t.publicKey;let s=[{name:"commonName",value:xE()},...sO];ft.info("Creating CSR with subject",s),n.setSubject(s);let i=[{name:"unstructuredName",value:"HarperDB, Inc."},{name:"extensionRequest",extensions:qH()}];return ft.info("Creating CSR with attributes",i),n.setAttributes(i),n.sign(r),vu.pki.certificationRequestToPem(n)}a(Ane,"createCsr");function qH(){let e=D_.includes(xE())?D_:[...D_,xE()];return e.includes(eO())||e.push(eO()),[{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=>MH.isIP(t)?{type:7,ip:t}:{type:2,value:t})}]}a(qH,"certExtensions");async function Rne(e){let t={},r=sr.join(fs.getHdbBasePath(),_s.LICENSE_KEY_DIR_NAME);if(e.csr){let n,s;ma();for await(let f of Lr.search([]))if(f.is_authority&&!f.details.issuer.includes("HarperDB-Certificate-Authority")){if(ha.has(f.private_key_name)){n=ha.get(f.private_key_name),s=f;break}else if(f.private_key_name&&await Sn.exists(sr.join(r,f.private_key_name))){n=Sn.readFile(sr.join(r,f.private_key_name)),s=f;break}}if(!n){let f=await tO();s=f.ca,n=f.private_key}n=At.privateKeyFromPem(n),t.signingCA=s.certificate;let i=At.certificateFromPem(s.certificate);ft.info("Signing CSR with cert named",s.name);let o=At.certificationRequestFromPem(e.csr);try{o.verify()}catch(f){return ft.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()+nO),ft.info("sign cert setting validity:",c.validity),ft.info("sign cert setting subject from CSR:",o.subject.attributes),c.setSubject(o.subject.attributes),ft.info("sign cert setting issuer:",i.subject.attributes),c.setIssuer(i.subject.attributes);let u=o.getAttribute({name:"extensionRequest"}).extensions;ft.info("sign cert adding extensions from CSR:",u),c.setExtensions(u),c.publicKey=o.publicKey,c.sign(n,vu.md.sha256.create()),t.certificate=At.certificateToPem(c)}else ft.info("Sign cert did not receive a CSR from:",e.url,"only the CA will be returned");return t}a(Rne,"signCertificate");async function yne(e,t){await xu({name:BE(),uses:["https","wss"],certificate:e,private_key_name:"privateKey.pem",is_authority:!1,is_self_signed:!0}),await xu({name:t.subject.getField("CN").value,uses:["https","wss"],certificate:At.certificateToPem(t),private_key_name:"privateKey.pem",is_authority:!0,is_self_signed:!0})}a(yne,"createCertificateTable");async function xu(e){let t=new lo(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},ma(),await Lr.patch(e)}a(xu,"setCertTable");async function iO(){let e=await Xb("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}});return{public_key:At.publicKeyFromPem(e.publicKey),private_key:At.privateKeyFromPem(e.privateKey)}}a(iO,"generateKeys");async function oO(e,t,r){let n=At.createCertificate();if(!t){let o=await L_();t=At.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()+nO);let i=[{name:"commonName",value:xE()},...sO];return n.setSubject(i),n.setIssuer(r.subject.attributes),n.setExtensions(qH()),n.sign(e,vu.md.sha256.create()),At.certificateToPem(n)}a(oO,"generateCertificates");async function tO(){let e=await zH(),t;for(let r of e){if(!r.is_authority)continue;let n=await WH(r.private_key_name);if(r.private_key_name&&n&&new lo(r.certificate).checkPrivateKey(vH(n))){ft.trace(`CA named: ${r.name} found with matching private key`),t={ca:r,private_key:n};break}}if(t)return t;ft.trace("No CA found with matching private key")}a(tO,"getCertAuthority");async function $H(e,t,r=!0){let n=At.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()+nO);let i=[{name:"commonName",value:`HarperDB-Certificate-Authority-${fs.get(Uu.REPLICATION_HOSTNAME)??BH(fs.get(Uu.REPLICATION_URL))??UH().split("-")[0]}`},...sO];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=sr.join(fs.getHdbBasePath(),_s.LICENSE_KEY_DIR_NAME),c=sr.join(o,Ws.PRIVATEKEY_PEM_NAME);return r&&await Sn.writeFile(c,At.privateKeyToPem(e)),n}a($H,"generateCertAuthority");async function bne(){let{private_key:e,public_key:t}=await iO(),r=await $H(e,t),n=await oO(e,t,r);await yne(n,r),VH()}a(bne,"generateCertsKeys");async function One(){let e=await oO(At.privateKeyFromPem(Ws.CERTIFICATE_VALUES.key),void 0,At.certificateFromPem(Ws.CERTIFICATE_VALUES.cert)),t=sr.join(fs.getHdbBasePath(),_s.LICENSE_KEY_DIR_NAME),r=sr.join(t,Ws.NATS_CERTIFICATE_PEM_NAME);await Sn.exists(r)||await Sn.writeFile(r,e);let n=sr.join(t,Ws.NATS_CA_PEM_NAME);await Sn.exists(n)||await Sn.writeFile(n,Ws.CERTIFICATE_VALUES.cert)}a(One,"createNatsCerts");async function Nne(){ma();for await(let e of Lr.search([{attribute:"is_self_signed",value:!0}]))await Lr.delete(e.name);await aO()}a(Nne,"renewSelfSigned");async function aO(){pne(),await GH(),ma();let e=await tO();if(!e){ft.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=fs.get(Uu.TLS_PRIVATEKEY),n=sr.join(fs.getHdbBasePath(),_s.LICENSE_KEY_DIR_NAME),s,i=xH(n,r);try{s=At.privateKeyFromPem(await Sn.readFile(r))}catch(c){ft.warn("Unable to parse the TLS key",r,"A new key will be generated and used to create Certificate Authority",c),{private_key:s}=await iO(),await Sn.exists(sr.join(n,Ws.PRIVATEKEY_PEM_NAME))&&(i=`privateKey${UH().split("-")[0]}.pem`),await Sn.writeFile(sr.join(n,i),At.privateKeyToPem(s))}let o=await $H(s,At.setRsaPublicKey(s.n,s.e),!1);await xu({name:o.subject.getField("CN").value,uses:["https"],certificate:At.certificateToPem(o),private_key_name:i,is_authority:!0,is_self_signed:!0})}if(!await L_()){let r=BE();ft.notify(`A suitable replication certificate was not found, creating new self singed cert named: ${r}`),e=e??await tO();let n=At.certificateFromPem(e.ca.certificate),s=n.publicKey,i=await oO(At.privateKeyFromPem(e.private_key),s,n);await xu({name:r,uses:["https","operations","wss"],certificate:i,is_authority:!1,private_key_name:e.ca.private_key_name,is_self_signed:!0})}}a(aO,"reviewSelfSignedCert");function VH(){let e=fne(Object.keys(_s.CONFIG_PARAM_MAP),!0),t=sr.join(fs.getHdbBasePath(),_s.LICENSE_KEY_DIR_NAME),r=sr.join(t,Ws.PRIVATEKEY_PEM_NAME),n=sr.join(t,Ws.NATS_CERTIFICATE_PEM_NAME),s=sr.join(t,Ws.NATS_CA_PEM_NAME),i=_s.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),Zb.updateConfigValue(void 0,void 0,o,!1,!0)}a(VH,"updateConfigCert");function KH(e){return e.startsWith("-----BEGIN")?e:Ene(e,"utf8")}a(KH,"readPEM");var LH=UE.createSecureContext;UE.createSecureContext=function(e){if(!e.cert||!e.key)return LH(e);let t={...e};delete t.key,delete t.cert;let r=LH(t);return r.context.setCert(e.cert),r.context.setKey(e.key,void 0),r};var wne=FH.prototype._init;FH.prototype._init=function(e,t){wne.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 Wc=new Map;function YH(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(),Wc.clear();let f=0;for await(let d of Jb.system.hdb_certificate.search([])){let h=d.certificate,_=new lo(h);d.is_authority&&(_.asString=h,Wc.set(_.subject,h))}for await(let d of Jb.system.hdb_certificate.search([]))try{if(d.is_authority)continue;let h=e==="operations-api",_=d.is_self_signed?1:2;h&&d.uses?.includes?.("operations")&&(_+=1);let m=await WH(d.private_key_name),S=d.certificate,g=new lo(S);if(Wc.has(g.issuer)&&(S+=`
|
|
23
23
|
`+Wc.get(g.issuer)),!m||!S)throw new Error("Missing private key or certificate for secure server");let R={ciphers:d.ciphers,ticketKeys:gne(),availableCAs:Wc,ca:t&&Array.from(Wc.values()),cert:S,key:m,key_file:d.private_key_name,is_self_signed:d.is_self_signed};o&&(R.sessionIdContext=o.sessionIdContext);let E=UE.createSecureContext(R);E.name=d.name,E.options=R,E.quality=_,E.certificateAuthorities=Array.from(Wc),E.certStart=S.toString().slice(0,100);let A=d.hostnames??QH(g);Array.isArray(A)||(A=[A]);let N;for(let v of A)if(v){v[0]==="*"&&(s=!0,v=v.slice(1)),v===eO()&&(_+=2),MH.isIP(v)&&(N=!0);let F=r.get(v)?.quality??0;_>F&&r.set(v,E)}else fa.error("No hostname found for certificate at",UE.certificate);fa.trace("Adding TLS",E.name,"for",o.ports||"client","cert named",d.name,"hostnames",A,"quality",_,"best quality",f),_>f&&(i.defaultContext=n=E,f=_,o&&(o.defaultContext=E))}catch(h){fa.error("Error applying TLS for",d.name,h)}o?.secureContextsListeners.forEach(d=>d()),c(n)}catch(f){l(f)}}a(u,"updateTLS"),Jb.system.hdb_certificate.subscribe({listener:a(()=>setTimeout(()=>u(),1500).unref(),"listener"),omitCurrent:!0}),u()})),i;function i(o,c){fa.info("TLS requested for",o||"(no SNI)");let l=o;for(;;){let f=r.get(l);if(f)return fa.debug("Found certificate for",o,f.certStart),f.updatedContext&&(f=f.updatedContext),c(null,f);if(s&&l){let d=l.indexOf(".",1);d<0?l="":l=l.slice(d)}else break}o?fa.debug("No certificate found to match",o,"using the default certificate"):fa.debug("No SNI, using the default certificate",n?.name);let u=n;u?u.updatedContext&&(u=u.updatedContext):fa.info("No default certificate found"),c(null,u)}a(i,"SNICallback")}a(YH,"createTLSSelector");async function WH(e){let t=ha.get(e);return!t&&e?await Sn.readFile(sr.join(fs.get(Uu.ROOTPATH),_s.LICENSE_KEY_DIR_NAME,e),"utf8"):t}a(WH,"getPrivateKeyByName");async function zH(){ma();let e=[];for await(let t of Lr.search([]))e.push(t);return e}a(zH,"listCertificates");async function Ine(e){let t=rO(e,Ys.object({name:Ys.string().required(),certificate:Ys.string().required(),is_authority:Ys.boolean().required(),private_key:Ys.string(),hosts:Ys.array(),uses:Ys.array()}));if(t)throw new _a(t.message);let{name:r,certificate:n,private_key:s,is_authority:i}=e,o=new lo(n),c=!1,l=!1,u;for(let[_,m]of ha)!s&&!c&&o.checkPrivateKey(vH(m))&&(c=!0,u=_),s&&s===m&&(l=!0,u=_);if(!i&&!s&&!c)throw new _a("A suitable private key was not found for this certificate");let f;if(!r){try{f=cO(o)}catch(_){ft.error(_)}if(f==null)throw new _a("Error extracting certificate common name, please provide a name parameter")}let d=Cne(r??f);s&&!c&&!l&&(await Sn.writeFile(sr.join(fs.getHdbBasePath(),_s.LICENSE_KEY_DIR_NAME,d+".pem"),s),ha.set(d,s));let h={name:r??f,certificate:n,is_authority:i,hosts:e.hosts,uses:e.uses};return(!i||i&&u||i&&s)&&(h.private_key_name=u??d+".pem"),await xu(h),"Successfully added certificate: "+d}a(Ine,"addCertificate");function Cne(e){return e.replace(/[^a-z0-9\.]/gi,"-")}a(Cne,"sanitizeName");async function Pne(e){let t=rO(e,Ys.object({name:Ys.string().required()}));if(t)throw new _a(t.message);let{name:r}=e;ma();let n=await Lr.get(r);if(!n)throw new _a(r+" not found");let{private_key_name:s}=n;if(s){let i=Array.from(await Lr.search([{attribute:"private_key_name",value:s}]));i.length===1&&i[0].name===r&&(ft.info("Removing private key named",s),await Sn.remove(sr.join(fs.getHdbBasePath(),_s.LICENSE_KEY_DIR_NAME,s)))}return await Lr.delete(r),"Successfully removed "+r}a(Pne,"removeCertificate");function cO(e){return e.subject.match(/CN=(.*)/)?.[1]}a(cO,"extractCommonName");function QH(e){return e.subjectAltName?e.subjectAltName.split(",").map(t=>{let r=t.indexOf(":");if(t=t.slice(r+1),t=t.trim(),t[0]==='"')try{t=JSON.parse(t)}catch{}return t.indexOf("=")>-1?t.match(/CN=([^,]*)/)?.[1]:t}).filter(t=>t):[cO(e)]}a(QH,"hostnamesFromCert");async function Dne(e){if(e.bypass_auth!==!0)throw new _a("Unauthorized","401");let t=rO(e,Ys.object({name:Ys.string().required()}));if(t)throw new _a(t.message);let{name:r}=e;if(r===".jwtPrivate")return(await CH()).privateKey;if(r===".jwtPublic")return(await CH()).publicKey;if(ha.get(r))return ha.get(e.name);throw new _a("Key not found")}a(Dne,"getKey")});var mk={};Ue(mk,{CONFIRMATION_STATUS_POSITION:()=>hk,NodeReplicationConnection:()=>M_,OPERATION_REQUEST:()=>fO,RECEIVED_TIME_POSITION:()=>hO,RECEIVED_VERSION_POSITION:()=>_O,SENDING_TIME_POSITION:()=>qE,createWebSocket:()=>KE,database_subscriptions:()=>ga,replicateOverWS:()=>v_,table_update_listeners:()=>pO});async function KE(e,t){let{authorization:r,rejectUnauthorized:n}=t||{},s=Ze(),i;if(e==null)throw new TypeError(`Invalid URL: Expected a string URL for node "${s}" but received ${e}`);if(e.includes("wss://")){if(!uO){let l=(0,dk.createTLSSelector)("operations-api"),u={secureContexts:null};await l.initialize(u),uO=u.secureContexts}if(i=uO.get(s),i&&ue.debug?.("Creating web socket for URL",e,"with certificate named:",i.name),!i&&n!==!1)throw new Error("Unable to find a valid certificate to use for replication to connect to "+e)}let o={};r&&(o.Authorization=r);let c={headers:o,localAddress:s?.startsWith("127.0")?s:void 0,servername:(0,_k.isIP)(t?.serverName)?void 0:t?.serverName,noDelay:!0,highWaterMark:128*1024,rejectUnauthorized:n!==!1,secureContext:void 0};return i&&(c.secureContext=fk.createSecureContext({...i.options,ca:Array.from(Qc)})),new lk.WebSocket(e,"harperdb-replication-v1",c)}function v_(e,t,r){let n=t.port||t.securePort,s=zc.pid%1e3+"-"+uk.threadId+(n?"s:"+n:"c:"+t.url?.slice(-4))+" "+Math.random().toString().slice(2,3),i=0,o=Buffer.allocUnsafeSlow(1024),c=0,l=new DataView(o.buffer,0,1024),u=t.database,f=t.databaseSubscriptions||ga,d,h,_=!1,m=t.subscription;m?.then&&m.then(T=>m=T);let S=t.tables||u&&Xe()[u];if(!r){ue.error?.("No authorization provided"),sn(1008,"Unauthorized");return}let g=new Map,R=[],E=r.name;E&&t.connection&&(t.connection.nodeName=E);let A,N,v,F,q,Y,ee,oe=1e3,z,se=0,W=0,pe=0,Ae=new Map,Pe=[],me=0,yt;if(t.url){let T=a(()=>{q&&W===e._socket?.bytesRead&&pe===e._socket?.bytesWritten?e.terminate():(q=performance.now(),e.ping(),W=e._socket?.bytesRead,pe=e._socket?.bytesWritten)},"send_ping");v=setInterval(T,ok).unref(),T()}else lt();e._socket?.setMaxListeners(200);function lt(){clearTimeout(F),W=e._socket?.bytesRead,pe=e._socket?.bytesWritten,F=setTimeout(()=>{W===e._socket?.bytesRead&&pe===e._socket?.bytesWritten&&(ue.warn?.(`Timeout waiting for ping from ${E}, terminating connection and reconnecting`),e.terminate())},ok*2).unref()}a(lt,"resetPingTimer");function Rr(){return h||(h=DE(d,u,E)),h}a(Rr,"getSharedStatus"),u&&Fo(u);let ss,In,vl=[],Ul=[],GT,qT=[],Lt=[],Fd=[],hm=150,mm=25,Gd=0,pm=0,Ie=!1,qd,nn,wr,xl;e.on("message",T=>{se=performance.now();try{let b=T.dataView=new jc(T.buffer,T.byteOffset,T.byteLength);if(T[0]>127){let O=(0,Qe.decode)(T),[U,L,I]=O;switch(U){case XH:{if(L){if(E){if(E!==L){ue.error?.(s,`Node name mismatch, expecting to connect to ${E}, but peer reported name as ${L}, disconnecting`),e.send((0,Qe.encode)([Bu])),sn(1008,"Node name mismatch");return}}else if(E=L,t.connection?.tentativeNode){let de=t.connection.tentativeNode;de.name=E,t.connection.tentativeNode=null,co(E,de)}if(t.connection&&(t.connection.nodeName=E),ue.debug?.(s,"received node name:",E,"db:",u),!u)try{Fo(u=O[2]),u==="system"&&(ss=ua(t,(de,re)=>{Hl(re)&&Go(re)}),e.on("close",()=>{ss?.remove()}))}catch(de){ue.warn?.(s,"Error setting database",de),e.send((0,Qe.encode)([Bu])),sn(1008,de.message);return}Hr()}break}case sk:{ue.debug?.(s,"Received table definitions for",L.map(de=>de.table));for(let de of L){let re=O[2];de.database=re;let fe;Hl(re)&&(re==="system"?$e[re]?.[de.table]||(fe=p(de,$e[re]?.[de.table])):fe=p(de,$e[re]?.[de.table]),d||(d=fe?.auditStore),S||(S=Xe()?.[re]))}break}case Bu:sn();break;case fO:try{let de=r?.replicates||r?.subscribers||r?.name;server.operation(L,{user:r},!de).then(re=>{Array.isArray(re)&&(re={results:re}),re.requestId=L.requestId,e.send((0,Qe.encode)([kE,re]))},re=>{e.send((0,Qe.encode)([kE,{requestId:L.requestId,error:re instanceof Error?re.toString():re}]))})}catch(de){e.send((0,Qe.encode)([kE,{requestId:L.requestId,error:de instanceof Error?de.toString():de}]))}break;case kE:let{resolve:B,reject:G}=g.get(L.requestId);L.error?G(new Error(L.error)):B(L),g.delete(L.requestId);break;case lO:let j=O[3];S||(u?ue.error?.(s,"No tables found for",u):ue.error?.(s,"Database name never received"));let X=S[j];X=p({table:j,database:u,attributes:L.attributes,schemaDefined:L.schemaDefined},X),vl[I]={name:j,decoder:new Qe.Packr({useBigIntExtension:!0,randomAccessStructure:!0,freezeData:!0,typedStructs:L.typedStructs,structures:L.structures}),getEntry(de){return X.primaryStore.getEntry(de)},rootStore:X.primaryStore.rootStore};break;case ZH:xl=d?gH(L,d):new Map,GT=O[2],ue.debug?.(s,`Acknowledged subscription request, receiving messages for nodes: ${GT}`);break;case ek:let k=I;Fd[k]=L;break;case nk:Rr()[hk]=L,ue.trace?.(s,"received and broadcasting committed update",L),Rr().buffer.notify();break;case rk:A=L,m.send({type:"end_txn",localTime:A,remoteNodeIds:R});break;case FE:{let de=O[1],{fileId:re,size:fe,finished:ie,error:Q}=de,le=Ae.get(re);ue.debug?.("Received blob",re,"has stream",!!le,"connectedToBlob",!!le?.connectedToBlob,"length",O[2].length,"finished",ie),le||(le=new dO.PassThrough,le.expectedSize=fe,Ae.set(re,le)),le.lastChunk=Date.now(),ie?(Q?(le.on("error",()=>{}),le.destroy(new Error("Blob error: "+Q))):le.end(O[2]),le.connectedToBlob&&Ae.delete(re)):le.write(O[2]);break}case tk:{let de=L,re;try{let fe=O[3],ie=Ul[I]||(Ul[I]=S[O[4]]);if(!ie)return ue.warn?.("Unknown table id trying to handle record request",I);let Q=ie.primaryStore.getBinaryFast(Symbol.for("structures")),le=Q.length;if(le!==pm){pm=le;let Te=(0,Qe.decode)(Q);e.send((0,Qe.encode)([lO,{typedStructs:Te.typed,structures:Te.named},I,ie.tableName]))}let Re=ie.primaryStore.getBinaryFast(fe);if(Re){let Te=ie.primaryStore.decoder.decode(Re,{valueAsBuffer:!0});re=(0,Qe.encode)([HE,de,{value:Te.value,expiresAt:Te.expiresAt,version:Te.version,residencyId:Te.residencyId,nodeId:Te.nodeId,user:Te.user}])}else re=(0,Qe.encode)([HE,de])}catch(fe){re=(0,Qe.encode)([HE,de,{error:fe.message}])}e.send(re);break}case HE:{let{resolve:de,reject:re,tableId:fe,key:ie}=g.get(O[1]),Q=O[2];if(Q?.error)re(new Error(Q.error));else if(Q){let le=vl[fe].decoder.decode(Q.value);Q.value=le,Q.key=ie,de(Q)}else de();g.delete(O[1]);break}case JH:{wr=L;let de,re,fe=!1;if(m){if(u!==m.databaseName&&!m.then){ue.error?.("Subscription request for wrong database",u,m.databaseName);return}}else m=f.get(u);if(ue.debug?.(s,"received subscription request for",u,"at",wr),!m){let ye;m=new Promise(tt=>{ue.debug?.("Waiting for subscription to database "+u),ye=tt}),m.ready=ye,ga.set(u,m)}if(r.name)re=nr().subscribe(r.name),re.then(async ye=>{de=ye;for await(let tt of de){let Mt=tt.value;if(!(Mt?.replicates===!0||Mt?.replicates?.receives||Mt?.subscriptions?.some(_r=>(_r.database||_r.schema)===u&&_r.publish!==!1))){fe=!0,e.send((0,Qe.encode)([Bu])),sn(1008,`Unauthorized database subscription to ${u}`);return}}},ye=>{ue.error?.(s,"Error subscribing to HDB nodes",ye)});else if(!(r?.role?.permission?.super_user||r.replicates)){e.send((0,Qe.encode)([Bu])),sn(1008,`Unauthorized database subscription to ${u}`);return}if(nn&&(ue.debug?.(s,"stopping previous subscription",u),nn.emit("close")),wr.length===0)return;let ie=wr[0],Q=a(ye=>{if(ye&&(ie.replicateByDefault?!ie.tables.includes(ye.tableName):ie.tables.includes(ye.tableName)))return{table:ye}},"tableToTableEntry"),le={txnTime:0},Re,Te,Me=1/0,je,Jt=a((ye,tt)=>{if(ye.type==="end_txn"){le.txnTime&&(o[i]!==66&&ue.error?.("Invalid encoding of message"),kl(9),kl($E),Za(je=tt),kr()),i=c,le.txnTime=0;return}let Mt=ye.nodeId,_r=ye.tableId,qt=Te[_r];if(!qt&&(qt=Te[_r]=Q(m.tableById[_r]),!qt))return ue.debug?.("Not subscribed to table",_r);let Fr=qt.table,ec=Fr.primaryStore,vt=ec.encoder;(ye.extendedType&np||!vt.typedStructs)&&(vt._mergeStructures(vt.getStructures()),vt.typedStructs&&(vt.lastTypedStructuresLength=vt.typedStructs.length));let gm=Re[Mt];if(!(gm&&gm.startTime<tt&&(!gm.endTime||gm.endTime>tt)))return GE&&ue.trace?.(s,"skipping replication update",ye.recordId,"to:",E,"from:",Mt,"subscribed:",Re),jC();GE&&ue.trace?.(s,"sending replication update",ye.recordId,"to:",E,"from:",Mt,"subscribed:",Re);let $T=ye.version;le.txnTime!==$T&&(le.txnTime&&(GE&&ue.trace?.(s,"new txn time, sending queued txn",le.txnTime),o[i]!==66&&ue.error?.("Invalid encoding of message"),kr()),le.txnTime=$T,i=c,Za($T));let tc=ye.residencyId,VT=Bl(tc,Fr),Sm;if(VT&&!VT.includes(E)){let rc=Bl(ye.previousResidencyId,Fr);if(rc&&!rc.includes(E)&&(ye.type==="put"||ye.type==="patch")||Fr.getResidencyById)return jC();let Kd=ye.recordId;ue.trace?.(s,"sending invalidation",Kd,E,"from",Mt);let $o=0;tc&&($o|=pc),ye.previousResidencyId&&($o|=Ec);let Ps,on=null;for(let Tm in Fr.indices){if(!on){if(Ps=ye.getValue(ec,!0),!Ps)break;on={}}on[Tm]=Ps[Tm]}Sm=Xl(ye.version,_r,Kd,null,Mt,ye.user,ye.type==="put"||ye.type==="patch"?"invalidate":ye.type,vt.encode(on),$o,tc,ye.previousResidencyId,ye.expiresAt)}function jC(){ue.trace?.(s,"skipping audit record",ye.recordId),Y||(Y=setTimeout(()=>{Y=null,(je||0)+ik/2<Me&&(GE&&ue.trace?.(s,"sending skipped sequence update",Me),e.send((0,Qe.encode)([rk,Me])))},ik).unref())}a(jC,"skipAuditRecord");let KT=vt.typedStructs,YT=vt.structures;if((KT?.length!=qt.typed_length||YT?.length!=qt.structure_length)&&(qt.typed_length=KT?.length,qt.structure_length=YT.length,ue.debug?.(s,"send table struct",qt.typed_length,qt.structure_length),qt.sentName||(qt.sentName=!0),e.send((0,Qe.encode)([lO,{typedStructs:KT,structures:YT,attributes:Fr.attributes,schemaDefined:Fr.schemaDefined},_r,qt.table.tableName]))),tc&&!Lt[tc]&&(e.send((0,Qe.encode)([ek,VT,tc])),Lt[tc]=!0),Sm)kl(Sm.length),Xa(Sm);else{let rc=ye.encoded;ye.extendedType&Mn&&AO(()=>ye.getValue(ec),async $o=>{let Ps=VE($o);try{let on;me++;for await(let Tm of $o.stream()){if(on&&(ue.debug?.("Sending blob chunk",Ps,"length",on.length),e.send((0,Qe.encode)([FE,{fileId:Ps,size:$o.size},on]))),on=Tm,fe)return;e._socket.writableNeedDrain&&(ue.debug?.("draining",Ps),await new Promise(bQ=>e._socket.once("drain",bQ)),ue.debug?.("drained",Ps))}ue.debug?.("Sending final blob chunk",Ps,"length",on.length),e.send((0,Qe.encode)([FE,{fileId:Ps,size:$o.size,finished:!0},on]))}catch(on){ue.debug?.("Error sending blob",on),e.send((0,Qe.encode)([FE,{fileId:Ps,finished:!0,error:on.toString()},Buffer.alloc(0)]))}finally{me--,me<mm&&yt?.()}});let Kd=rc[0]===66?8:0;kl(rc.length-Kd),Xa(rc,Kd),ue.trace?.("wrote record",ye.recordId,"length:",rc.length)}},"sendAuditRecord"),kr=a(()=>{c-i>8?(e.send(o.subarray(i,c)),ue.debug?.(s,"Sent message, size:",c-i)):ue.debug?.(s,"skipping empty transaction")},"sendQueuedData");nn=new mO.EventEmitter,nn.once("close",()=>{fe=!0,de?.end()});for(let{startTime:ye}of wr)ye<Me&&(Me=ye);(re||Promise.resolve()).then(async()=>{m=await m,d=m.auditStore,Te=m.tableById.map(Q),Re=[];for(let{name:tt,startTime:Mt,endTime:_r}of wr){let qt=PE(tt,d);ue.debug?.("subscription to",tt,"using local id",qt,"starting",Mt),Re[qt]={startTime:Mt,endTime:_r}}Go(u),ss||(ss=Jc(tt=>{tt.databaseName===u&&Go(u)}),In=U_(tt=>{tt===u&&(e.send((0,Qe.encode)([Bu])),sn())}),e.on("close",()=>{ss?.remove(),In?.remove()})),e.send((0,Qe.encode)([ZH,N_(m.auditStore),wr.map(({name:tt})=>tt)]));let ye=!0;do{isFinite(Me)||(ue.warn?.("Invalid sequence id "+Me),sn(1008,"Invalid sequence id"+Me));let tt;if(ye&&!fe&&(ye=!1,!(gO(d)<=Me)&&(ck.default.get(x.REPLICATION_COPYTABLESTOCATCHUP)??Lne)&&server.nodes[0]?.name===E)){ue.info?.("Replicating all tables to",E);let _r=Me,qt=YE(d);for(let Fr in S){if(!Q(Fr))continue;let ec=S[Fr];for(let vt of ec.primaryStore.getRange({snapshot:!1})){if(fe)return;vt.localTime>=Me&&(ue.trace?.(s,"Copying record from",u,Fr,vt.key,vt.localTime),_r=Math.max(vt.localTime,_r),tt=!0,Rr()[qE]=1,Jt({recordId:vt.key,tableId:ec.tableId,type:"put",getValue(){return vt.value},encoded:ec.primaryStore.getBinary(vt.key),version:vt.version,residencyId:vt.residencyId,nodeId:qt,extendedType:vt.metadataFlags},vt.localTime))}}Me=_r}for(let{key:Mt,value:_r}of d.getRange({start:Me||1,exclusiveStart:!0,snapshot:!1})){if(fe)return;let qt=Ot(_r);ue.debug?.("sending audit record",new Date(Mt)),Rr()[qE]=Mt,Me=Mt,Jt(qt,Mt),e._socket.writableNeedDrain?await new Promise(Fr=>{ue.debug?.(`Waiting for remote node ${E} to allow more commits ${e._socket.writableNeedDrain?"due to network backlog":"due to requested flow directive"}`),e._socket.once("drain",Fr)}):me>mm?await new Promise(Fr=>{yt=Fr}):await new Promise(setImmediate),nn.startTime=Mt,tt=!0}tt&&Jt({type:"end_txn"},Me),Rr()[qE]=0,await pk(d)}while(!fe)}).catch(ye=>{ue.error?.(s,"Error handling subscription to node",ye),sn(1008,"Error handling subscription to node")});break}}return}b.position=8;let w=!0,y,D;do{Rr();let O=b.readInt();if(O===9&&b.getUint8(b.position)==$E){b.position++,A=D=b.readFloat64(),h[_O]=A,h[hO]=Date.now(),ue.trace?.("received remote sequence update",A,u);break}let U=b.position,L=Ot(T,U,U+O),I=vl[L.tableId];I||ue.error?.(`No table found with an id of ${L.tableId}`);let B;L.residencyId&&(B=Fd[L.residencyId],ue.trace?.(s,"received residency list",B,L.type,L.recordId));try{TO(()=>{y={table:I.name,id:L.recordId,type:L.type,nodeId:xl.get(L.nodeId),residencyList:B,timestamp:L.version,value:L.getValue(I),user:L.user,beginTxn:w,expiresAt:L.expiresAt}},G=>{let j=VE(G),X=Ae.get(j);ue.debug?.("Received transaction with blob",j,"has stream",!!X,"ended",!!X?.writableEnded),X?X.writableEnded&&Ae.delete(j):(X=new dO.PassThrough,Ae.set(j,X)),X.connectedToBlob=!0,X.lastChunk=Date.now(),G.size===void 0&&X.expectedSize&&(G.size=X.expectedSize);let k=createBlob(X,G),de=k.save({primaryStore:m.auditStore});return de&&(de.blobId=j,Pe.push(de),de.finally(()=>{ue.debug?.(`Finished receiving blob stream ${j}`),Pe.splice(Pe.indexOf(de),1)})),k})}catch(G){throw G.message+="typed structures for current decoder"+JSON.stringify(I.decoder.typedStructs),G}w=!1,ue.trace?.(s,"received replication message",L.type,"id",y.id,"version",new Date(L.version),"nodeId",y.nodeId),h[_O]=L.version,h[hO]=Date.now(),m.send(y),b.position=U+O}while(b.position<T.byteLength);Gd++,rr(T.byteLength,"bytes-received",`${E}.${u}.${y?.table||"unknown_table"}`,"replication","ingest"),Gd>hm&&!Ie&&(Ie=!0,e.pause(),ue.debug?.(`Commit backlog causing replication back-pressure, requesting that ${E} pause replication`)),m.send({type:"end_txn",localTime:A,remoteNodeIds:R,async onCommit(){if(y){let O=Date.now()-y.timestamp;rr(O,"replication-latency",E+"."+u+"."+y.table,y.type,"ingest")}Gd--,Ie&&(Ie=!1,e.resume(),ue.debug?.(`Replication resuming ${E}`)),Pe.length>0&&await Promise.all(Pe),ue.trace?.("All blobs finished"),!N&&D&&(ue.trace?.(s,"queuing confirmation of a commit at",D),setTimeout(()=>{e.send((0,Qe.encode)([nk,N])),ue.trace?.(s,"sent confirmation of a commit at",N),N=null},Mne)),N=D,ue.debug?.("last sequence committed",new Date(D),u)}})}catch(b){ue.error?.(s,"Error handling incoming replication message",b)}}),e.on("ping",lt),e.on("pong",()=>{t.connection&&(t.connection.latency=performance.now()-q,Yc({name:E,database:u,url:t.url,latency:t.connection.latency})),q=null}),e.on("close",(T,b)=>{clearInterval(v),clearTimeout(F),clearInterval(ee),nn&&nn.emit("close"),qd&&qd.end();for(let[w,{reject:y}]of g)y(new Error(`Connection closed ${b?.toString()} ${T}`));ue.debug?.(s,"closed",T,b?.toString())});function $d(){}a($d,"recordRemoteNodeSequence");function sn(T,b){e.isFinished=!0,e.close(T,b)}a(sn,"close");function Hr(){if(_||(_=!0,t.connection?.on("subscriptions-updated",Hr)),t.connection?.isFinished)throw new Error("Can not make a subscription request on a connection that is already closed");let T=new Map;try{for(let y of m?.dbisDB?.getRange({start:Symbol.for("seq"),end:[Symbol.for("seq"),Buffer.from([255])]})||[])for(let D of y.value.nodes||[])D.lastTxnTime>(T.get(D.id)??0)&&T.set(D.id,D.lastTxnTime)}catch(y){if(!y.message.includes("Can not re"))throw y}let b=t.connection?.nodeSubscriptions?.[0];R=[];let w=t.connection?.nodeSubscriptions.map((y,D)=>{let O=[],{replicateByDefault:U}=y;if(y.subscriptions){for(let G of y.subscriptions)if(G.subscribe&&(G.schema||G.database)===u){let j=G.table;S?.[j]?.replicate!==!1&&O.push(j)}U=!1}else for(let G in S)(U?S[G].replicate===!1:S[G].replicate)&&O.push(G);let L=d&&PE(y.name,d),I=m?.dbisDB?.get([Symbol.for("seq"),L])??1,B=Math.max(I?.seqId??1,(typeof y.start_time=="string"?new Date(y.start_time).getTime():y.start_time)??1);if(ue.debug?.("Starting time recorded in db",y.name,L,u,I?.seqId,"start time:",B,new Date(B)),b!==y){let G=d&&PE(b.name,d),j=m?.dbisDB?.get([Symbol.for("seq"),G])??1;for(let X of j?.nodes||[])X.name===y.name&&(B=X.seqId,ue.debug?.("Using sequence id from proxy node",b.name,B))}return R.push(L),T.get(L)>B&&(B=T.get(L),ue.debug?.("Updating start time from more recent txn recorded",b.name,B)),{name:y.name,replicateByDefault:U,tables:O,startTime:B,endTime:y.end_time}});if(w)if(ue.debug?.(s,"sending subscription request",w,m?.dbisDB?.path),clearTimeout(z),w.length>0)e.send((0,Qe.encode)([JH,w]));else{let y=a(()=>{let D=performance.now();z=setTimeout(()=>{se<=D?sn(1008,"No nodes to subscribe to"):y()},oe)},"schedule_close");y()}}a(Hr,"sendSubscriptionRequestUpdate");function Bl(T,b){if(!T)return;let w=qT[T];return w||(w=b.getResidencyRecord(T),qT[T]=w),w}a(Bl,"getResidence");function Hl(T){return!(Ea&&Ea!="*"&&!Ea[T]&&!Ea.includes?.(T)&&!Ea.some?.(b=>b.name===T))}a(Hl,"checkDatabaseAccess");function Fo(T){if(m=m||f.get(T),!Hl(T))throw new Error(`Access to database "${T}" is not permitted`);m||ue.warn?.(`No database named "${T}" was declared and registered`),d=m?.auditStore,S||(S=Xe()?.[T]);let b=Ze();if(b===E)throw b?new Error("Should not connect to self",b):new Error("Node name not defined");return Em(b,T),!0}a(Fo,"setDatabase");function Em(T,b){let w=Xe()?.[b],y=[];for(let D in w){let O=w[D];y.push({table:D,schemaDefined:O.schemaDefined,attributes:O.attributes.map(U=>({name:U.name,type:U.type,isPrimaryKey:U.isPrimaryKey}))})}ue.trace?.("Sending database info for node",T,"database name",b),e.send((0,Qe.encode)([XH,T,b,y]))}a(Em,"sendNodeDBName");function Go(T){let b=Xe()?.[T],w=[];for(let y in b){if(wr&&!wr.some(O=>O.replicateByDefault?!O.tables.includes(y):O.tables.includes(y)))continue;let D=b[y];w.push({table:y,schemaDefined:D.schemaDefined,attributes:D.attributes.map(O=>({name:O.name,type:O.type,isPrimaryKey:O.isPrimaryKey}))})}e.send((0,Qe.encode)([sk,w,T]))}a(Go,"sendDBSchema"),ee=setInterval(()=>{for(let[T,b]of Ae)b.lastChunk+3e4<Date.now()&&(ue.warn?.(`Timeout waiting for blob stream to finish ${T} from ${E}`),Ae.delete(T),b.end())},3e4).unref();let qo=1,Vd=[];return{end(){qd&&qd.end(),nn&&nn.emit("close")},getRecord(T){let b=qo++;return new Promise((w,y)=>{let D=[tk,b,T.table.tableId,T.id];Vd[T.table.tableId]||(D.push(T.table.tableName),Vd[T.table.tableId]=!0),e.send((0,Qe.encode)(D)),g.set(b,{tableId:T.table.tableId,key:T.id,resolve(O){let{table:U,entry:L}=T;w(O),O&&U._recordRelocate(L,O)},reject:y})})},sendOperation(T){let b=qo++;return T.requestId=b,e.send((0,Qe.encode)([fO,T])),new Promise((w,y)=>{g.set(b,{resolve:w,reject:y})})}};function kl(T){V(5),T<128?o[c++]=T:T<16384?(l.setUint16(c,T|32768),c+=2):T<1056964608?(l.setUint32(c,T|3221225472),c+=4):(o[c]=255,l.setUint32(c+1,T),c+=5)}function Xa(T,b=0,w=T.length){let y=w-b;V(y),T.copy(o,c,b,w),c+=y}function Za(T){V(8),l.setFloat64(c,T),c+=8}function V(T){if(T+16>o.length-c){let b=Buffer.allocUnsafeSlow(c+T-i+65536>>10<<11);o.copy(b,0,i,c),c=c-i,i=0,o=b,l=new DataView(o.buffer,0,o.length)}}function p(T,b){let w=T.database??"data";if(w!=="data"&&!$e[w]){ue.warn?.("Database not found",T.database);return}b||(b={});let y=b.schemaDefined,D=!1,O=T.schemaDefined,U=b.attributes||[];for(let L=0;L<T.attributes?.length;L++){let I=T.attributes[L],B=U[L];(!B||B.name!==I.name||B.type!==I.type)&&(y?ue.error?.(`Schema for '${u}.${T.table}' is defined locally, but attribute '${I.name}: ${I.type}' from '${E}' does not match local attribute ${B?"'"+B.name+": "+B.type+"'":"which does not exist"}`):(D=!0,O||(I.indexed=!0),U[L]=I))}return D?(ue.debug?.("(Re)creating",T),ut({table:T.table,database:T.database,schemaDefined:T.schemaDefined,attributes:U,...b})):b}}var ck,Qe,lk,uk,ue,mO,dk,fk,zc,_k,dO,JH,XH,ZH,Bu,ek,lO,tk,HE,fO,kE,rk,nk,sk,FE,hk,_O,hO,qE,Lne,pO,ga,GE,ik,Mne,ok,uO,ak,M_,EO=be(()=>{ve();Qi();Wb();SO();ds();ck=M(ce());H();Zl();Qe=require("msgpackr"),lk=require("ws"),uk=require("worker_threads"),ue=M(_i());P_();mO=require("events"),dk=M(zs()),fk=M(require("node:tls"));Kc();zc=M(require("node:process")),_k=require("node:net");Ni();as();dO=require("node:stream"),JH=129,XH=140,ZH=141,Bu=142,ek=130,lO=132,tk=133,HE=134,fO=136,kE=137,rk=143,nk=144,sk=145,FE=146,hk=0,_O=1,hO=2,qE=3,Lne=zc.env.HDB_LEADER_URL||zc.argv.includes("--HDB_LEADER_URL"),pO=new Map,ga=new Map,GE=!0,ik=300,Mne=2,ok=3e4;a(KE,"createWebSocket");ak=1e3,M_=class extends mO.EventEmitter{constructor(r,n,s,i,o){super();this.url=r;this.subscription=n;this.databaseName=s;this.nodeName=i;this.authorization=o;this.nodeName=this.nodeName??Ks(r)}static{a(this,"NodeReplicationConnection")}socket;startTime;retryTime=ak;retries=0;isConnected=!0;isFinished=!1;nodeSubscriptions=[];latency=0;replicateTablesByDefault;session;sessionResolve;sessionReject;async connect(){this.session||this.resetSession();let r=[];this.socket=await KE(this.url,{serverName:this.nodeName,authorization:this.authorization});let n;ue.debug?.(`Connecting to ${this.url}, db: ${this.databaseName}, process ${zc.pid}`),this.socket.on("open",()=>{this.socket._socket.unref(),ue[this.isConnected?"info":"warn"]?.(`Connected to ${this.url}, db: ${this.databaseName}`),this.retries=0,this.retryTime=ak,Yc({name:this.nodeName,database:this.databaseName,url:this.url}),this.isConnected=!0,n=v_(this.socket,{database:this.databaseName,subscription:this.subscription,url:this.url,connection:this},{replicates:!0}),this.sessionResolve(n)}),this.socket.on("error",s=>{s.code==="SELF_SIGNED_CERT_IN_CHAIN"?(ue.warn?.(`Can not connect to ${this.url}, this server does not have a certificate authority for the certificate provided by ${this.url}`),s.isHandled=!0):s.code!=="ECONNREFUSED"&&(s.code==="UNABLE_TO_VERIFY_LEAF_SIGNATURE"?ue.error?.(`Can not connect to ${this.url}, the certificate provided by ${this.url} is not trusted, this node needs to be added to the cluster, or a certificate authority needs to be added`):ue.error?.(`Error in connection to ${this.url} due to ${s.message}`)),this.sessionReject(s)}),this.socket.on("close",(s,i)=>{if(this.isConnected&&(Mu({name:this.nodeName,database:this.databaseName,url:this.url,finished:this.socket.isFinished}),this.isConnected=!1),this.socket.isFinished){this.isFinished=!0,n?.end(),this.emit("finished");return}if(++this.retries%20===1){let o=i?.toString();ue.warn?.(`${n?"Disconnected from":"Failed to connect to"} ${this.url} (db: "${this.databaseName}"), due to ${o?'"'+o+'" ':""}(code: ${s})`)}n=null,this.resetSession(),setTimeout(()=>{this.connect()},this.retryTime).unref(),this.retryTime+=this.retryTime>>3})}resetSession(){this.session=new Promise((r,n)=>{this.sessionResolve=r,this.sessionReject=n})}subscribe(r,n){this.nodeSubscriptions=r,this.replicateTablesByDefault=n,this.emit("subscriptions-updated",r)}unsubscribe(){this.socket.isFinished=!0,this.socket.close(1008,"No longer subscribed")}getRecord(r){return this.session.then(n=>n.getRecord(r))}};a(v_,"replicateOverWS")});var pa={};Ue(pa,{clearThisNodeName:()=>Gne,disableReplication:()=>Bne,enabled_databases:()=>Ea,forEachReplicatedDatabase:()=>ua,getThisNodeId:()=>YE,getThisNodeName:()=>Ze,getThisNodeUrl:()=>da,hostnameToUrl:()=>jE,lastTimeInAuditStore:()=>w_,monitorNodeCAs:()=>bk,replicateOperation:()=>$ne,replication_certificate_authorities:()=>Qc,sendOperationToNode:()=>B_,servers:()=>Une,setReplicator:()=>Nk,start:()=>xne,startOnMainThread:()=>jb,subscribeToNode:()=>Lu,unsubscribeFromNode:()=>vE,urlToNodeName:()=>Ks});function xne(e){if(e.port||(e.port=hs.default.get(x.OPERATIONSAPI_NETWORK_PORT)),e.securePort||(e.securePort=hs.default.get(x.OPERATIONSAPI_NETWORK_SECUREPORT)),!Ze())throw new Error("Can not load replication without a url (see replication.url in the config)");let t=new Map;for(let n of C_(e))t.set(Ks(n.url),n);Hne(e),e={mtls:!0,isOperationsServer:!0,maxPayload:10*1024*1024*1024,...e};let r=We.ws(async(n,s,i,o)=>{if(s.headers.get("sec-websocket-protocol")!=="harperdb-replication-v1")return o(n,s,i);await i,n._socket.unref(),v_(n,e,s?.user),n.on("error",c=>{c.code!=="ECONNREFUSED"&&ir.error("Error in connection to "+this.url,c.message)})},e);e.runFirst=!0,We.http((n,s)=>{if(n.isWebSocket&&n.headers.get("Sec-WebSocket-Protocol")==="harperdb-replication-v1"){!n.authorized&&n._nodeRequest.socket.authorizationError&&ir.error(`Incoming client connection from ${n.ip} did not have valid certificate, you may need turn on enableRootCAs in the config if you are using a publicly signed certificate, or add the CA to the server's trusted CAs`,n._nodeRequest.socket.authorizationError);let i=nr().primaryStore;if(n.authorized&&n.peerCertificate.subject){let o=n.peerCertificate.subject,c=o&&(i.get(o.CN)||t.get(o.CN));if(c)if(c?.revoked_certificates?.includes(n.peerCertificate.serialNumber)){ir.warn("Revoked certificate used in attempt to connect to node",c.name,"certificate serial number",n.peerCertificate.serialNumber);return}else n.user=c;else ir.warn(`No node found for certificate common name ${o.CN}, available nodes are ${Array.from(i.getRange({}).filter(({value:l})=>l).map(({key:l})=>l)).join(", ")} and routes ${Array.from(t.keys()).join(", ")}, connection will require credentials.`)}else{let o=i.get(n.ip)||t.get(n.ip);o?n.user=o:ir.warn(`No node found for IP address ${n.ip}, available nodes are ${Array.from(new Set([...i.getKeys(),...t.keys()])).join(", ")}, connection will require credentials.`)}}return s(n)},e);for(let n of r)if(n.secureContexts){let s=a(()=>{let i=new Set(n.secureContexts.values());n.defaultContext&&i.add(n.defaultContext);for(let o of i)try{let c=Array.from(Qc);o.options.availableCAs&&c.push(...o.options.availableCAs.values());let l={...o.options,ca:c};o.updatedContext=QE.createSecureContext(l)}catch(c){ir.error("Error creating replication TLS config",c)}},"updateContexts");n.secureContextsListeners.push(s),bk(s),hs.default.get(x.REPLICATION_ENABLEROOTCAS)!==!1&&s()}}function bk(e){let t=0;Pu(r=>{r?.ca&&(Qc.add(r.ca),Qc.size!==t&&(t=Qc.size,e?.()))})}function Bne(e=!0){yk=e}function Hne(e){yk||(Xe(),Ea=e.databases,ua(e,(t,r)=>{if(!t){let n=e.databaseSubscriptions||ga;for(let[s,i]of x_){let o=i.get(r);o&&(o.subscribe([],!1),i.delete(r))}n.delete(r);return}for(let n in t){let s=t[n];Nk(r,s,e),pO.get(s)?.forEach(i=>i(s))}}))}function Nk(e,t,r){if(!t)return console.error(`Attempt to replicate non-existent table ${t.name} from database ${e}`);if(t.replicate===!1||t.sources?.some(s=>s.isReplicator))return;let n;t.sourcedFrom(class Ok extends Gr{static{a(this,"Replicator")}static connection;static subscription;static async subscribe(){let i=r.databaseSubscriptions||ga,o=i.get(e),c=o?.tableById||[];c[t.tableId]=t;let l=o?.ready;if(ir.trace("Setting up replicator subscription to database",e),!o?.auditStore)return this.subscription=o=new Pn,i.set(e,o),o.tableById=c,o.auditStore=t.auditStore,o.dbisDB=t.dbisDB,o.databaseName=e,l&&l(o),o;this.subscription=o}static subscribeOnThisThread(i,o){return!0}static async load(i){if(i){let o=i.residencyId,c=i.residency||t.dbisDB.get([Symbol.for("residency_by_id"),o]);if(c){let l,u=new Set;do{let f;for(let h of c){let _=kne(h,Ok.subscription,e);_?.isConnected&&!u.has(_)&&(!f||_.latency<f.latency)&&(f=_)}if(!f)throw l||new Ak.ServerError("No connection to any other nodes are available",502);let d={requestId:vne++,table:t,entry:i,id:i.key};u.add(f);try{return await f.getRecord(d)}catch(h){if(f.isConnected)throw h;ir.warn("Error in load from node",zE,h),l||(l=h)}}while(!0)}}}static isReplicator=!0},{intermediateSource:!0})}function wk(e,t,r,n,s){let i=x_.get(e);i||x_.set(e,i=new Map);let o=i.get(r);if(o)return o;if(t)return i.set(r,o=new M_(e,t,r,n,s)),o.connect(),o.once("finished",()=>i.delete(r)),o}function kne(e,t,r){let n=Ek.get(e)?.get(r);if(n)return n;let s=nr().primaryStore.get(e);return s?.url&&(n=wk(s.url,t,r,e,s.authorization),Ek.set(e,x_.get(s.url))),n}async function B_(e,t,r){r||(r={}),r.serverName=e.name;let n=await KE(e.url,r),s=v_(n,{},{});return new Promise((i,o)=>{n.on("open",()=>{i(s.sendOperation(t))}),n.on("error",c=>{o(c)}),n.on("close",c=>{ir.info("Sending operation connection to "+e.url+" closed",c)})}).finally(()=>{n.close()})}function Lu(e){try{Rk.isMainThread&&ir.trace("Subscribing on main thread (should not happen in multi-threaded instance)",e.nodes[0].url,e.database);let t=ga.get(e.database);if(!t){let n;t=new Promise(s=>{ir.info("Waiting for subscription to database "+e.database),n=s}),t.ready=n,ga.set(e.database,t)}let r=wk(e.nodes[0].url,t,e.database,e.nodes[0].name,e.nodes[0].authorization);e.nodes[0].name===void 0?r.tentativeNode=e.nodes[0]:r.nodeName=e.nodes[0].name,r.subscribe(e.nodes.filter(n=>I_(n,e.database)),e.replicateByDefault)}catch(t){ir.error("Error in subscription to node",e.nodes[0]?.url,t)}}async function vE({name:e,url:t,database:r}){ir.trace("Unsubscribing from node",e,t,r,"nodes",Array.from(nr().primaryStore.getRange({})));let n=x_.get(t);if(n){let s=n.get(r);s&&(s.unsubscribe(),n.delete(r))}}function Fne(){if(RO!==void 0)return RO;let e=hs.default.get(x.OPERATIONSAPI_TLS_CERTIFICATE)||hs.default.get(x.TLS_CERTIFICATE);if(e)return RO=new Sk.X509Certificate((0,Tk.readFileSync)(e)).subject.match(/CN=(.*)/)?.[1]??null}function Ze(){return zE||(zE=hs.default.get("replication_hostname")??Ks(hs.default.get("replication_url"))??Fne()??gk("operationsapi_network_secureport")??gk("operationsapi_network_port")??"127.0.0.1")}function Gne(){zE=void 0}function gk(e){let t=hs.default.get(e),r=t?.lastIndexOf?.(":");if(r>0)return t.slice(0,r)}function WE(e){let t=hs.default.get(e),r=t?.lastIndexOf?.(":");return r>0?+t.slice(r+1).replace(/[\[\]]/g,""):+t}function YE(e){return N_(e)?.[Ze()]}function da(){let e=hs.default.get("replication_url");return e||jE(Ze())}function jE(e){let t=WE("replication_port");if(t)return`ws://${e}:${t}`;if(t=WE("replication_secureport"),t)return`wss://${e}:${t}`;if(t=WE("operationsapi_network_port"),t)return`ws://${e}:${t}`;if(t=WE("operationsapi_network_secureport"),t)return`wss://${e}:${t}`}function Ks(e){if(e)return new URL(e).hostname}function ua(e,t){for(let n of Object.getOwnPropertyNames($e))r(n);return U_(n=>{r(n)}),Jc((n,s)=>{r(n.databaseName)});function r(n){let s=$e[n];ir.trace("Checking replication status of ",n,e?.databases),e?.databases===void 0||e.databases==="*"||e.databases.includes(n)||e.databases.some?.(i=>i.name===n)||!s?t(s,n,!0):qne(n)&&t(s,n,!1)}a(r,"forDatabase")}function qne(e){let t=$e[e];for(let r in t)if(t[r].replicate)return!0}function w_(e){for(let t of e.getKeys({limit:1,reverse:!0}))return t}async function $ne(e){let t={message:""};if(e.replicated){e.replicated=!1,ir.trace?.("Replicating operation",e.operation,"to nodes",We.nodes.map(n=>n.name));let r=await Promise.allSettled(We.nodes.map(n=>B_(n,e)));t.replicated=r.map((n,s)=>{let i=n.status==="rejected"?{status:"failed",reason:n.reason.toString()}:n.value;return i.node=We.nodes[s]?.name,i})}return t}var hs,ir,Sk,Tk,QE,Ak,Rk,yk,vne,Une,Qc,Ea,x_,Ek,RO,zE,ds=be(()=>{ve();Jo();ql();EO();qr();hs=M(ce()),ir=M(J()),Sk=require("crypto"),Tk=require("fs");P_();Kc();H();Wb();QE=M(require("node:tls")),Ak=M(he()),Rk=require("worker_threads"),vne=1,Une=[],Qc=hs.default.get(x.REPLICATION_ENABLEROOTCAS)!==!1?new Set(QE.rootCertificates):new Set;a(xne,"start");a(bk,"monitorNodeCAs");a(Bne,"disableReplication");a(Hne,"assignReplicationSource");a(Nk,"setReplicator");x_=new Map;a(wk,"getConnection");Ek=new Map;a(kne,"getConnectionByName");a(B_,"sendOperationToNode");a(Lu,"subscribeToNode");a(vE,"unsubscribeFromNode");a(Fne,"getCommonNameFromCert");a(Ze,"getThisNodeName");a(Gne,"clearThisNodeName");Object.defineProperty(We,"hostname",{get(){return Ze()}});a(gk,"getHostFromListeningPort");a(WE,"getPortFromListeningPort");a(YE,"getThisNodeId");We.replication={getThisNodeId:YE,exportIdMapping:N_};a(da,"getThisNodeUrl");a(jE,"hostnameToUrl");a(Ks,"urlToNodeName");a(ua,"forEachReplicatedDatabase");a(qne,"hasExplicitlyReplicatedTable");a(w_,"lastTimeInAuditStore");a($ne,"replicateOperation")});var tg=C((eIe,Lk)=>{"use strict";var Hu=GB(),{validateBySchema:H_}=nt(),{common_validators:ku,schema_regex:yO}=gi(),or=require("joi"),Vne=J(),Kne=require("uuid").v4,ZE=no(),Fu=(H(),P($)),Yne=require("util"),Sa=Bn(),{handleHDBError:uo,hdb_errors:Wne,ClientError:k_}=he(),{HDB_ERROR_MSGS:JE,HTTP_STATUS_CODES:fo}=Wne,{SchemaEventMsg:eg}=Fs(),Ik=pr(),{getDatabases:zne}=(ve(),P(it)),{transformReq:Gu}=ae(),{replicateOperation:Ck}=(ds(),P(pa)),XE=or.string().min(1).max(ku.schema_length.maximum).pattern(yO).messages({"string.pattern.base":"{:#label} "+ku.schema_format.message}),Qne=or.string().min(1).max(ku.schema_length.maximum).pattern(yO).messages({"string.pattern.base":"{:#label} "+ku.schema_format.message}).required(),jne=or.string().min(1).max(ku.schema_length.maximum).pattern(yO).messages({"string.pattern.base":"{:#label} "+ku.schema_format.message,"any.required":"'primary_key' is required","string.base":"'primary_key' must be a string"}).required();Lk.exports={createSchema:Jne,createSchemaStructure:Pk,createTable:Xne,createTableStructure:Dk,createAttribute:nse,dropSchema:Zne,dropTable:ese,dropAttribute:tse,getBackup:sse};async function Jne(e){let t=await Pk(e);return ZE.signalSchemaChange(new eg(process.pid,e.operation,e.schema)),t}a(Jne,"createSchema");async function Pk(e){let t=H_(e,or.object({database:XE,schema:XE}));if(t)throw new k_(t.message);if(Gu(e),!await Hu.checkSchemaExists(e.schema))throw uo(new Error,JE.SCHEMA_EXISTS_ERR(e.schema),fo.BAD_REQUEST,Fu.LOG_LEVELS.ERROR,JE.SCHEMA_EXISTS_ERR(e.schema),!0);return await Sa.createSchema(e),`database '${e.schema}' successfully created`}a(Pk,"createSchemaStructure");async function Xne(e){return Gu(e),e.hash_attribute=e.primary_key??e.hash_attribute,await Dk(e)}a(Xne,"createTable");async function Dk(e){let t=H_(e,or.object({database:XE,schema:XE,table:Qne,residence:or.array().items(or.string().min(1)).optional(),hash_attribute:jne}));if(t)throw new k_(t.message);if(!await Hu.checkSchemaTableExists(e.schema,e.table))throw uo(new Error,JE.TABLE_EXISTS_ERR(e.schema,e.table),fo.BAD_REQUEST,Fu.LOG_LEVELS.ERROR,JE.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:Kne(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await Sa.createTable(n,e);else throw uo(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",fo.BAD_REQUEST);else await Sa.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}a(Dk,"createTableStructure");async function Zne(e){let t=H_(e,or.object({database:or.string(),schema:or.string()}).or("database","schema").messages({"object.missing":"'database' is required"}));if(t)throw new k_(t.message);Gu(e);let r=await Hu.checkSchemaExists(e.schema);if(r)throw uo(new Error,r,fo.NOT_FOUND,Fu.LOG_LEVELS.ERROR,r,!0);let n=await Hu.schema_describe.describeSchema({schema:e.schema}),s=Object.keys(global.hdb_schema[e.schema]);await Sa.dropSchema(e),ZE.signalSchemaChange(new eg(process.pid,e.operation,e.schema)),await Ik.purgeSchemaTableStreams(e.schema,s);let i=await Ck(e);return i.message=`successfully deleted '${e.schema}'`,i}a(Zne,"dropSchema");async function ese(e){let t=H_(e,or.object({database:or.string(),schema:or.string(),table:or.string().required()}));if(t)throw new k_(t.message);Gu(e);let r=await Hu.checkSchemaTableExists(e.schema,e.table);if(r)throw uo(new Error,r,fo.NOT_FOUND,Fu.LOG_LEVELS.ERROR,r,!0);await Sa.dropTable(e),await Ik.purgeTableStream(e.schema,e.table);let n=await Ck(e);return n.message=`successfully deleted table '${e.schema}.${e.table}'`,n}a(ese,"dropTable");async function tse(e){let t=H_(e,or.object({database:or.string(),schema:or.string(),table:or.string().required(),attribute:or.string().required()}));if(t)throw new k_(t.message);Gu(e);let r=await Hu.checkSchemaTableExists(e.schema,e.table);if(r)throw uo(new Error,r,fo.NOT_FOUND,Fu.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw uo(new Error,"You cannot drop a hash attribute",fo.BAD_REQUEST,void 0,void 0,!0);if(Fu.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw uo(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,fo.BAD_REQUEST,void 0,void 0,!0);try{return await Sa.dropAttribute(e),rse(e),ZE.signalSchemaChange(new eg(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw Vne.error(`Got an error deleting attribute ${Yne.inspect(e)}.`),n}}a(tse,"dropAttribute");function rse(e){let t=Object.values(global.hdb_schema[e.schema][e.table].attributes);for(let r=0;r<t.length;r++)t[r].attribute===e.attribute&&global.hdb_schema[e.schema][e.table].attributes.splice(r,1)}a(rse,"dropAttributeFromGlobal");async function nse(e){Gu(e);let t=zne()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw uo(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,fo.BAD_REQUEST,void 0,void 0,!0);return await Sa.createAttribute(e),ZE.signalSchemaChange(new eg(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}a(nse,"createAttribute");function sse(e){return Sa.getBackup(e)}a(sse,"getBackup")});var vk=C((rIe,Mk)=>{"use strict";var{OPERATIONS_ENUM:ise}=(H(),P($)),bO=class{static{a(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=ise.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};Mk.exports=bO});var OO=C((iIe,kk)=>{"use strict";var ose=Bn(),sIe=vk(),rg=ae(),ng=(H(),P($)),ase=ce(),{handleHDBError:Uk,hdb_errors:cse}=he(),{HDB_ERROR_MSGS:xk,HTTP_STATUS_CODES:Bk}=cse,lse=Object.values(ng.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),Hk="To use this operation audit log must be enabled in harperdb-config.yaml";kk.exports=use;async function use(e){if(rg.isEmpty(e.schema))throw new Error(xk.SCHEMA_REQUIRED_ERR);if(rg.isEmpty(e.table))throw new Error(xk.TABLE_REQUIRED_ERR);if(!ase.get(ng.CONFIG_PARAMS.LOGGING_AUDITLOG))throw Uk(new Error,Hk,Bk.BAD_REQUEST,ng.LOG_LEVELS.ERROR,Hk,!0);let t=rg.checkSchemaTableExist(e.schema,e.table);if(t)throw Uk(new Error,t,Bk.NOT_FOUND,ng.LOG_LEVELS.ERROR,t,!0);if(!rg.isEmpty(e.search_type)&&lse.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await ose.readAuditLog(e)}a(use,"readAuditLog")});var Gk=C((aIe,Fk)=>{"use strict";var{OPERATIONS_ENUM:dse}=(H(),P($)),NO=class{static{a(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=dse.GET_BACKUP,this.schema=t,this.table=r}};Fk.exports=NO});var Vk=C((dIe,$k)=>{"use strict";var fse=Bn(),lIe=Gk(),wO=ae(),_se=(H(),P($)),uIe=ce(),{handleHDBError:hse,hdb_errors:mse}=he(),{HDB_ERROR_MSGS:qk,HTTP_STATUS_CODES:pse}=mse;$k.exports=Ese;async function Ese(e){if(wO.isEmpty(e.schema))throw new Error(qk.SCHEMA_REQUIRED_ERR);if(wO.isEmpty(e.table))throw new Error(qk.TABLE_REQUIRED_ERR);let t=wO.checkSchemaTableExist(e.schema,e.table);if(t)throw hse(new Error,t,pse.NOT_FOUND,_se.LOG_LEVELS.ERROR,t,!0);return await fse.getBackup(read_audit_log_object)}a(Ese,"getBackup")});var zk=C((_Ie,Wk)=>{"use strict";var gse=ce(),Ta=require("joi"),Sse=nt(),Kk=require("moment"),Tse=require("fs-extra"),IO=require("path"),Ase=require("lodash"),F_=(H(),P($)),{LOG_LEVELS:Xc}=(H(),P($)),Rse="YYYY-MM-DD hh:mm:ss",yse=IO.resolve(__dirname,"../logs");Wk.exports=function(e){return Sse.validateBySchema(e,bse)};var bse=Ta.object({from:Ta.custom(Yk),until:Ta.custom(Yk),level:Ta.valid(Xc.NOTIFY,Xc.FATAL,Xc.ERROR,Xc.WARN,Xc.INFO,Xc.DEBUG,Xc.TRACE),order:Ta.valid("asc","desc"),limit:Ta.number().min(1),start:Ta.number().min(0),log_name:Ta.custom(Ose)});function Yk(e,t){if(Kk(e,Kk.ISO_8601).format(Rse)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(Yk,"validateDatetime");function Ose(e,t){if(Ase.invert(F_.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=gse.get(F_.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?F_.LOG_NAMES.HDB:e,i=s===F_.LOG_NAMES.INSTALL?IO.join(yse,F_.LOG_NAMES.INSTALL):IO.join(n,s);return Tse.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(Ose,"validateReadLogPath")});var PO=C((mIe,jk)=>{"use strict";var sg=(H(),P($)),Nse=J(),wse=ce(),Ise=zk(),CO=require("path"),Qk=require("fs-extra"),{once:Cse}=require("events"),{handleHDBError:Pse,hdb_errors:Dse}=he(),{PACKAGE_ROOT:Lse}=pt(),Mse=CO.join(Lse,"logs"),vse=1e3,Use=200;jk.exports=xse;async function xse(e){let t=Ise(e);if(t)throw Pse(t,t.message,Dse.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=wse.get(sg.HDB_SETTINGS_NAMES.LOG_PATH_KEY),n=e.log_name===void 0?sg.LOG_NAMES.HDB:e.log_name,s=n===sg.LOG_NAMES.INSTALL?CO.join(Mse,sg.LOG_NAMES.INSTALL):CO.join(r,n),i=e.level!==void 0,o=i?e.level:void 0,c=e.from!==void 0,l=c?new Date(e.from):void 0,u=e.until!==void 0,f=u?new Date(e.until):void 0,d=e.limit===void 0?vse:e.limit,h=e.order===void 0?void 0:e.order,_=e.start===void 0?0:e.start,m=_+d,S=0;h==="desc"&&!l&&!f&&(S=Math.max(Qk.statSync(s).size-(m+5)*Use,0));let g=Qk.createReadStream(s,{start:S});g.on("error",F=>{Nse.error(F)});let R=0,E=[],A="",N;g.on("data",F=>{let q=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;F=A+F;let Y=0,ee;for(;(ee=q.exec(F))&&!g.destroyed;){N&&(N.message=F.slice(Y,ee.index),v(N));let[oe,z,se]=ee,W=se.split("] ["),pe=W[0],Ae=W[1];W.splice(0,2),N={timestamp:z,thread:pe,level:Ae,tags:W,message:""},Y=ee.index+oe.length}A=F.slice(Y)}),g.on("end",F=>{g.destroyed||N&&(N.message=A.trim(),v(N))}),g.resume();function v(F){let q,Y,ee;switch(!0){case(i&&c&&u):q=new Date(F.timestamp),Y=new Date(l),ee=new Date(f),F.level===o&&q>=Y&&q<=ee&&R<_?R++:F.level===o&&q>=Y&&q<=ee&&(Aa(F,h,E),R++,R===m&&g.destroy());break;case(i&&c):q=new Date(F.timestamp),Y=new Date(l),F.level===o&&q>=Y&&R<_?R++:F.level===o&&q>=Y&&(Aa(F,h,E),R++,R===m&&g.destroy());break;case(i&&u):q=new Date(F.timestamp),ee=new Date(f),F.level===o&&q<=ee&&R<_?R++:F.level===o&&q<=ee&&(Aa(F,h,E),R++,R===m&&g.destroy());break;case(c&&u):q=new Date(F.timestamp),Y=new Date(l),ee=new Date(f),q>=Y&&q<=ee&&R<_?R++:q>=Y&&q<=ee&&(Aa(F,h,E),R++,R===m&&g.destroy());break;case i:F.level===o&&R<_?R++:F.level===o&&(Aa(F,h,E),R++,R===m&&g.destroy());break;case c:q=new Date(F.timestamp),Y=new Date(l),q>=Y&&R<_?R++:q>=Y&&R>=_&&(Aa(F,h,E),R++,R===m&&g.destroy());break;case u:q=new Date(F.timestamp),ee=new Date(f),q<=ee&&R<_?R++:q<=ee&&R>=_&&(Aa(F,h,E),R++,R===m&&g.destroy());break;default:R<_?R++:(Aa(F,h,E),R++,R===m&&g.destroy())}}return a(v,"onLogMessage"),await Cse(g,"close"),E}a(xse,"readLog");function Aa(e,t,r){t==="desc"?Bse(e,r):t==="asc"?Hse(e,r):r.push(e)}a(Aa,"pushLineToResult");function Bse(e,t){let r=new Date(e.timestamp),n=0,s=t.length;for(;n<s;){let i=n+s>>>1;new Date(t[i].timestamp)>r?n=i+1:s=i}t.splice(n,0,e)}a(Bse,"insertDescending");function Hse(e,t){let r=new Date(e.timestamp),n=0,s=t.length;for(;n<s;){let i=n+s>>>1;new Date(t[i].timestamp)<r?n=i+1:s=i}t.splice(n,0,e)}a(Hse,"insertAscending")});var ig=C((AIe,eF)=>{"use strict";var DO=require("joi"),{string:qu,boolean:Jk,date:kse}=DO.types(),Fse=nt(),{validateSchemaExists:EIe,validateTableExists:gIe,validateSchemaName:SIe}=gi(),Gse=(H(),P($)),qse=Nt(),Xk=ce();Xk.initSync();var TIe=qu.invalid(Xk.get(Gse.CONFIG_PARAMS.CLUSTERING_NODENAME)??"node_name").pattern(qse.NATS_TERM_CONSTRAINTS_RX).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >","any.invalid":"'node_name' cannot be this nodes name"}).empty(null),Zk={operation:qu.valid("add_node","update_node","set_node_replication"),node_name:qu.optional(),subscriptions:DO.array().items({table:qu.optional(),schema:qu.optional(),database:qu.optional(),subscribe:Jk.required(),publish:Jk.required().custom(Vse),start_time:kse.iso()})};function $se(e){return Fse.validateBySchema(e,DO.object(Zk))}a($se,"addUpdateNodeValidator");function Vse(e,t){if(t.state.ancestors[2].operation==="add_node"&&e===!1&&t.state.ancestors[0].subscribe===!1)return t.message(`'subscriptions[${t.state.path[1]}]' subscribe and/or publish must be set to true when adding a node`)}a(Vse,"checkForFalsy");eF.exports={addUpdateNodeValidator:$se,validation_schema:Zk}});var $u=C((yIe,tF)=>{"use strict";var LO=class{static{a(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},MO=class{static{a(this,"NodeSubscription")}constructor(t,r,n,s){this.schema=t,this.table=r,this.publish=n,this.subscribe=s}};tF.exports={Node:LO,NodeSubscription:MO}});var nF=C((OIe,rF)=>{"use strict";var Kse=(H(),P($)).OPERATIONS_ENUM,vO=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=Kse.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};rF.exports=vO});var G_=C((wIe,sF)=>{"use strict";var UO=class{static{a(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},xO=class{static{a(this,"RemotePayloadSubscription")}constructor(t,r,n,s,i,o,c){this.schema=t,this.table=r,this.hash_attribute=n,this.publish=s,this.subscribe=i,this.start_time=o,c!==void 0&&(this.attributes=c)}};sF.exports={RemotePayloadObject:UO,RemotePayloadSubscription:xO}});var oF=C((CIe,iF)=>{"use strict";var BO=class{static{a(this,"TableSizeObject")}constructor(t,r,n=0,s=0,i=0,o=0){this.schema=t,this.table=r,this.table_size=n,this.record_count=s,this.transaction_log_size=i,this.transaction_log_record_count=o}};iF.exports=BO});var cF=C((UIe,aF)=>{"use strict";var Yse=oF(),DIe=Ut(),LIe=dt(),Wse=J(),{getSchemaPath:MIe,getTransactionAuditStorePath:vIe}=Et(),{getDatabases:zse}=(ve(),P(it));aF.exports=Qse;async function Qse(e){let t=new Yse;try{let r=zse()[e.schema]?.[e.name],n=r.primaryStore.getStats(),s=r.auditStore?.getStats();t.schema=e.schema,t.table=e.name,t.record_count=n.entryCount,t.transaction_log_record_count=s.entryCount}catch(r){Wse.warn(`unable to stat table dbi due to ${r}`)}return t}a(Qse,"lmdbGetTableSize")});var uF=C((BIe,lF)=>{"use strict";var HO=class{static{a(this,"SystemInformationObject")}constructor(t,r,n,s,i,o,c){this.system=t,this.time=r,this.cpu=n,this.memory=s,this.disk=i,this.network=o,this.harperdb_processes=c}};lF.exports=HO});var Ku=C(($Ie,hF)=>{"use strict";var jse=require("fs-extra"),Jse=require("path"),jr=require("systeminformation"),Ra=J(),dF=pr(),kIe=Nt(),Vu=(H(),P($)),Xse=cF(),Zse=to(),{getThreadInfo:fF}=rt(),q_=ce();q_.initSync();var eie=uF(),{openEnvironment:FIe}=dt(),{getSchemaPath:GIe}=Et(),{database:qIe,databases:kO}=(ve(),P(it)),og;hF.exports={getHDBProcessInfo:$O,getNetworkInfo:KO,getDiskInfo:VO,getMemoryInfo:qO,getCPUInfo:GO,getTimeInfo:FO,getSystemInformation:YO,systemInformation:tie,getTableSize:WO,getMetrics:zO};function FO(){return jr.time()}a(FO,"getTimeInfo");async function GO(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:o,governor:c,socket:l,cache:u,...f}=await jr.cpu();f.cpu_speed=await jr.cpuCurrentSpeed();let{raw_currentload:d,raw_currentload_idle:h,raw_currentload_irq:_,raw_currentload_nice:m,raw_currentload_system:S,raw_currentload_user:g,cpus:R,...E}=await jr.currentLoad();return E.cpus=[],R.forEach(A=>{let{raw_load:N,raw_load_idle:v,raw_load_irq:F,raw_load_nice:q,raw_load_system:Y,raw_load_user:ee,...oe}=A;E.cpus.push(oe)}),f.current_load=E,f}catch(e){return Ra.error(`error in getCPUInfo: ${e}`),{}}}a(GO,"getCPUInfo");async function qO(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await jr.mem();return Object.assign(s,process.memoryUsage())}catch(e){return Ra.error(`error in getMemoryInfo: ${e}`),{}}}a(qO,"getMemoryInfo");async function $O(){let e={core:[],clustering:[]};try{let t=await jr.processes(),r;try{r=Number.parseInt(await jse.readFile(Jse.join(q_.get(Vu.CONFIG_PARAMS.ROOTPATH),Vu.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===Vu.NODE_ERROR_CODES.ENOENT)Ra.warn("Unable to locate 'hdb.pid' file, try stopping and starting HarperDB. This could be because HarperDB is not running.");else throw n}t.list.forEach(n=>{n.pid===r?e.core.push(n):n.name==="nats-server"&&e.clustering.push(n)});for(let n of e.core)for(let s of t.list)s.pid===n.parentPid&&(s.name==="PM2"||s.command==="PM2")&&(n.parent="PM2");return e}catch(t){return Ra.error(`error in getHDBProcessInfo: ${t}`),e}}a($O,"getHDBProcessInfo");async function VO(){let e={};try{if(!q_.get(Vu.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_DISK))return e;let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await jr.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:l,...u}=await jr.fsStats();return e.read_write=u,e.size=await jr.fsSize(),e}catch(t){return Ra.error(`error in getDiskInfo: ${t}`),e}}a(VO,"getDiskInfo");async function KO(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return q_.get(Vu.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_NETWORK)&&(e.default_interface=await jr.networkInterfaceDefault(),e.latency=await jr.inetChecksite("google.com"),(await jr.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:o,dhcp:c,dnsSuffix:l,ieee8021xAuth:u,ieee8021xState:f,carrier_changes:d,...h}=n;e.interfaces.push(h)}),(await jr.networkStats()).forEach(n=>{let{rx_sec:s,tx_sec:i,ms:o,...c}=n;e.stats.push(c)})),e}catch(t){return Ra.error(`error in getNetworkInfo: ${t}`),e}}a(KO,"getNetworkInfo");async function YO(){if(og!==void 0)return og;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:o,...c}=await jr.osInfo();e=c;let l=await jr.versions("node, npm");return e.node_version=l.node,e.npm_version=l.npm,og=e,og}catch(t){return Ra.error(`error in getSystemInformation: ${t}`),e}}a(YO,"getSystemInformation");async function WO(){let e=[],t=await Zse.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await Xse(n));return e}a(WO,"getTableSize");async function zO(){let e={};for(let t in kO){let r=e[t]={},n=r.tables={};for(let s in kO[t])try{let i=kO[t][s];if(!r.readers&&(Object.assign(r,i.primaryStore.rootStore.getStats()),delete r.root,r.readers=i.primaryStore.rootStore.readerList().split(/\n\s+/).slice(1).map(l=>{let[u,f,d]=l.trim().split(" ");return{pid:u,thread:f,txnid:d}}),i.auditStore)){let{treeDepth:l,treeBranchPageCount:u,treeLeafPageCount:f,entryCount:d,overflowPages:h}=i.auditStore.getStats();r.audit={treeDepth:l,treeBranchPageCount:u,treeLeafPageCount:f,entryCount:d,overflowPages:h}}let o=i.primaryStore.getStats(),c={};for(let l of["treeDepth","treeBranchPageCount","treeLeafPageCount","entryCount","overflowPages"])c[l]=o[l];n[s]=c}catch(i){Ra.notify(`Error getting stats for table ${s}: ${i}`)}}return e}a(zO,"getMetrics");async function _F(){if(q_.get(Vu.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{jsm:e}=await dF.getNATSReferences(),t=await dF.listStreams(),r=[];for(let n of t){let s=[],i=await e.consumers.list(n.config.name);for await(let c of i)s.push({name:c.name,created:c.created,num_ack_pending:c.num_ack_pending,num_redelivered:c.num_redelivered,num_waiting:c.num_waiting,num_pending:c.num_pending});let o={stream_name:n.config.name,database:n.config.subjects[0].split(".")[1],table:n.config.subjects[0].split(".")[2],state:n.state,consumers:s};r.push(o)}return r}}a(_F,"getNatsStreamInfo");async function tie(e){let t=new eie;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await YO(),t.time=FO(),t.cpu=await GO(),t.memory=await qO(),t.disk=await VO(),t.network=await KO(),t.harperdb_processes=await $O(),t.table_size=await WO(),t.metrics=await zO(),t.threads=await fF(),t.replication=await _F(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await YO();break;case"time":t.time=FO();break;case"cpu":t.cpu=await GO();break;case"memory":t.memory=await qO();break;case"disk":t.disk=await VO();break;case"network":t.network=await KO();break;case"harperdb_processes":t.harperdb_processes=await $O();break;case"table_size":t.table_size=await WO();break;case"database_metrics":case"metrics":t.metrics=await zO();break;case"threads":t.threads=await fF();break;case"replication":t.replication=await _F();break;default:break}return t}a(tie,"systemInformation")});var _o=C((zIe,gF)=>{"use strict";var rie=pn(),QO=ae(),nie=require("util"),Zc=(H(),P($)),mF=ce();mF.initSync();var sie=Nb(),pF=Vr(),{Node:KIe,NodeSubscription:YIe}=$u(),iie=fu(),oie=nF(),{RemotePayloadObject:aie,RemotePayloadSubscription:cie}=G_(),{handleHDBError:lie,hdb_errors:uie}=he(),{HTTP_STATUS_CODES:die,HDB_ERROR_MSGS:fie}=uie,_ie=Gs(),hie=Ku(),{packageJson:mie}=pt(),{getDatabases:pie}=(ve(),P(it)),WIe=nie.promisify(sie.authorize),Eie=pF.searchByHash,gie=pF.searchByValue;gF.exports={isEmpty:Sie,getNodeRecord:Tie,upsertNodeRecord:Aie,buildNodePayloads:Rie,checkClusteringEnabled:yie,getAllNodeRecords:bie,getSystemInfo:Oie,reverseSubscription:EF};function Sie(e){return e==null}a(Sie,"isEmpty");async function Tie(e){let t=new iie(Zc.SYSTEM_SCHEMA_NAME,Zc.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return Eie(t)}a(Tie,"getNodeRecord");async function Aie(e){let t=new oie(Zc.SYSTEM_SCHEMA_NAME,Zc.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return rie.upsert(t)}a(Aie,"upsertNodeRecord");function EF(e){if(QO.isEmpty(e.subscribe)||QO.isEmpty(e.publish))throw new Error("Received invalid subscription object");let{schema:t,table:r,hash_attribute:n}=e,s={schema:t,table:r,hash_attribute:n};return e.subscribe===!0&&e.publish===!1?(s.subscribe=!1,s.publish=!0):e.subscribe===!1&&e.publish===!0?(s.subscribe=!0,s.publish=!1):(s.subscribe=e.subscribe,s.publish=e.publish),s}a(EF,"reverseSubscription");function Rie(e,t,r,n){let s=[];for(let i=0,o=e.length;i<o;i++){let c=e[i],{schema:l,table:u}=c,f=QO.getTableHashAttribute(l,u),{subscribe:d,publish:h}=EF(c),_=pie()[l]?.[u],m=new cie(l,u,f,h,d,c.start_time,_.schemaDefined?_.attributes:void 0);s.push(m)}return new aie(r,t,s,n)}a(Rie,"buildNodePayloads");function yie(){if(!mF.get(Zc.CONFIG_PARAMS.CLUSTERING_ENABLED))throw lie(new Error,fie.CLUSTERING_NOT_ENABLED,die.BAD_REQUEST,void 0,void 0,!0)}a(yie,"checkClusteringEnabled");async function bie(){let e=new _ie(Zc.SYSTEM_SCHEMA_NAME,Zc.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await gie(e))}a(bie,"getAllNodeRecords");async function Oie(){let e=await hie.getSystemInformation();return{hdb_version:mie.version,node_version:e.node_version,platform:e.platform}}a(Oie,"getSystemInfo")});var jO=C((jIe,NF)=>{"use strict";var ag=pr(),SF=ae(),TF=Nt(),AF=(H(),P($)),cg=J(),RF=tg(),Nie=t_(),{RemotePayloadObject:wie}=G_(),{handleHDBError:yF,hdb_errors:Iie}=he(),{HTTP_STATUS_CODES:bF}=Iie,{NodeSubscription:OF}=$u();NF.exports=Cie;async function Cie(e,t){let r;try{r=await ag.request(`${t}.${TF.REQUEST_SUFFIX}`,new wie(AF.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),cg.trace("Response from remote describe all request:",r)}catch(o){cg.error(`addNode received error from describe all request to remote node: ${o}`);let c=ag.requestErrorHandler(o,"add_node",t);throw yF(new Error,c,bF.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===TF.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let o=`Error returned from remote node ${t}: ${r.message}`;throw yF(new Error,o,bF.INTERNAL_SERVER_ERROR,"error",o)}let n=r.message,s=[],i=[];for(let o of e){let{table:c}=o,l=o.database??o.schema??"data";if(l===AF.SYSTEM_SCHEMA_NAME){await ag.createLocalTableStream(l,c);let m=new OF(l,c,o.publish,o.subscribe);m.start_time=o.start_time,i.push(m);continue}let u=SF.doesSchemaExist(l),f=n[l]!==void 0,d=c?SF.doesTableExist(l,c):!0,h=c?n?.[l]?.[c]!==void 0:!0;if(!u&&!f||!d&&!h){s.push(o);continue}if(!u&&f&&(cg.trace(`addNode creating schema: ${l}`),await RF.createSchema({operation:"create_schema",schema:l})),!d&&h){cg.trace(`addNode creating table: ${c} in schema: ${l} with attributes ${JSON.stringify(n[l][c].attributes)}`);let m=new Nie(l,c,n[l][c].hash_attribute);n[l][c].attributes&&(m.attributes=n[l][c].attributes),await RF.createTable(m)}await ag.createLocalTableStream(l,c);let _=new OF(l,c,o.publish,o.subscribe);_.start_time=o.start_time,i.push(_)}return{added:i,skipped:s}}a(Cie,"reviewSubscriptions")});var el={};Ue(el,{addNodeBack:()=>vie,removeNodeBack:()=>Uie,setNode:()=>Mie});async function Mie(e){e.node_name&&!e.hostname&&(e.hostname=e.node_name),e.verify_tls!==void 0&&(e.rejectUnauthorized=e.verify_tls);let{url:t,hostname:r}=e;t?r||(r=e.hostname=Ks(t)):t=jE(r);let n=(0,IF.validateBySchema)(e,Lie);if(n)throw(0,ho.handleHDBError)(n,n.message,Die.BAD_REQUEST,void 0,void 0,!0);if(e.operation==="remove_node"){if(!t&&!r)throw new ho.ClientError("url or hostname is required for remove_node operation");let _=r,m=nr(),S=await m.get(_);if(!S)throw new ho.ClientError(_+" does not exist");try{await B_({url:S.url},{operation:$t.REMOVE_NODE_BACK,name:S?.subscriptions?.length>0?Ze():_},void 0)}catch(g){Yn.warn(`Error removing node from target node ${_}, if it is offline and we be online in the future, you may need to clean up this node manually, or retry:`,g)}return await m.delete(_),`Successfully removed '${_}' from cluster`}if(!t)throw new ho.ClientError("url required for this operation");let s=da();if(s==null)throw new ho.ClientError("replication url is missing from harperdb-config.yaml");let i,o,c;if(t?.startsWith("wss:")){i=await(0,ms.getReplicationCert)();let _=await(0,ms.getReplicationCertAuth)();if(!i)throw new Error("Unable to find a certificate to use for replication");i.options.is_self_signed?(o=await(0,ms.createCsr)(),Yn.info("Sending CSR to target node:",t)):_&&(c=_.certificate,Yn.info("Sending CA named",_.name,"to target node",t))}let l={operation:$t.ADD_NODE_BACK,hostname:(0,ba.get)(x.REPLICATION_HOSTNAME),target_hostname:r,url:s,csr:o,cert_auth:c,authorization:e.retain_authorization?e.authorization:null};if((0,ba.get)(x.REPLICATION_SHARD)!==void 0&&(l.shard=(0,ba.get)(x.REPLICATION_SHARD)),e.subscriptions?l.subscriptions=e.subscriptions.map(wF):l.subscriptions=null,e.hasOwnProperty("subscribe")||e.hasOwnProperty("publish")){let _=wF(e);l.subscribe=_.subscribe,l.publish=_.publish}e?.authorization?.username&&e?.authorization?.password&&(e.authorization="Basic "+Buffer.from(e.authorization.username+":"+e.authorization.password).toString("base64"));let u,f;try{u=await B_({url:t},l,e)}catch(_){_.message=`Error returned from ${t}: `+_.message,Yn.warn("Error adding node:",t,"to cluster:",_),f=_}if(o&&(!u?.certificate||!u?.certificate?.includes?.("BEGIN CERTIFICATE")))throw f?(f.message+=" and connection was required to sign certificate",f):new Error(`Unexpected certificate signature response from node ${t} response: ${JSON.stringify(u)}`);o&&(Yn.info("CSR response received from node:",t,"saving certificate and CA in hdb_certificate"),await(0,ms.setCertTable)({name:Pie.certificateFromPem(u.signingCA).issuer.getField("CN").value,certificate:u.signingCA,is_authority:!0}),u.certificate&&await(0,ms.setCertTable)({name:Ze(),uses:["https","operations","wss"],certificate:u.certificate,private_key_name:i?.options?.key_file,is_authority:!1,is_self_signed:!1}),c=u.signingCA);let d={url:t,ca:u?.usingCA};if(e.hostname&&(d.name=e.hostname),e.subscriptions?d.subscriptions=e.subscriptions:d.replicates=!0,e.start_time&&(d.start_time=typeof e.start_time=="string"?new Date(e.start_time).getTime():e.start_time),e.retain_authorization&&(d.authorization=e.authorization),e.revoked_certificates&&(d.revoked_certificates=e.revoked_certificates),e.shard!==void 0&&(d.shard=e.shard),d.replicates){let _={url:s,ca:c,replicates:!0,subscriptions:null};(0,ba.get)(x.REPLICATION_SHARD)!==void 0&&(_.shard=(0,ba.get)(x.REPLICATION_SHARD)),e.retain_authorization&&(_.authorization=e.authorization),e.start_time&&(_.start_time=e.start_time),await co(Ze(),_)}await co(u?u.nodeName:d.name??Ks(t),d);let h;return e.operation==="update_node"?h=`Successfully updated '${t}'`:h=`Successfully added '${t}' to cluster`,f&&(h+=" but there was an error updating target node: "+f.message),h}async function vie(e){Yn.trace("addNodeBack received request:",e);let t=await(0,ms.signCertificate)(e),r;e.csr?(r=t.signingCA,Yn.info("addNodeBack received CSR from node:",e.url,"this node will use and respond with CA that was used to issue CSR")):(r=e?.cert_auth,Yn.info("addNodeBack received CA from node:",e.url));let n={url:e.url,ca:r};e.subscriptions?n.subscriptions=e.subscriptions:(n.replicates=!0,n.subscriptions=null),e.start_time&&(n.start_time=e.start_time),e.authorization&&(n.authorization=e.authorization),e.shard!==void 0&&(n.shard=e.shard);let s=await(0,ms.getReplicationCertAuth)();if(n.replicates){let i={url:da(),ca:s?.certificate,replicates:!0,subscriptions:null};(0,ba.get)(x.REPLICATION_SHARD)!==void 0&&(i.shard=(0,ba.get)(x.REPLICATION_SHARD)),e.start_time&&(i.start_time=e.start_time),e.authorization&&(i.authorization=e.authorization),await co(Ze(),i)}return await co(e.hostname,n),t.nodeName=Ze(),t.usingCA=s?.certificate,Yn.info("addNodeBack responding to:",e.url,"with CA named:",s?.name),t}async function Uie(e){Yn.trace("removeNodeBack received request:",e),await nr().delete(e.name)}function wF(e){let{subscribe:t,publish:r}=e;return{...e,subscribe:r,publish:t}}var ms,IF,ya,ba,Yn,ho,Pie,Die,Lie,tl=be(()=>{ms=M(zs()),IF=M(nt()),ya=M(require("joi")),ba=M(ce());H();P_();Kc();ds();Yn=M(J()),ho=M(he()),{pki:Pie}=require("node-forge"),{HTTP_STATUS_CODES:Die}=ho.hdb_errors,Lie=ya.default.object({hostname:ya.default.string(),verify_tls:ya.default.boolean(),replicates:ya.default.boolean(),subscriptions:ya.default.array(),revoked_certificates:ya.default.array(),shard:ya.default.number()});a(Mie,"setNode");a(vie,"addNodeBack");a(Uie,"removeNodeBack");a(wF,"reverseSubscription")});var _g=C((iCe,PF)=>{"use strict";var{handleHDBError:lg,hdb_errors:xie}=he(),{HTTP_STATUS_CODES:ug}=xie,{addUpdateNodeValidator:Bie}=ig(),dg=J(),fg=(H(),P($)),CF=Nt(),Hie=ae(),$_=pr(),V_=_o(),JO=ce(),kie=jO(),{Node:Fie,NodeSubscription:Gie}=$u(),{broadcast:qie}=rt(),{setNode:$ie}=(tl(),P(el)),nCe=ce(),sCe=(H(),P($)),Vie="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",Kie="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",Yie=JO.get(fg.CONFIG_PARAMS.CLUSTERING_NODENAME);PF.exports=Wie;async function Wie(e,t=!1){if(dg.trace("addNode called with:",e),JO.get(fg.CONFIG_PARAMS.REPLICATION_URL)||JO.get(fg.CONFIG_PARAMS.REPLICATION_HOSTNAME))return $ie(e);V_.checkClusteringEnabled();let r=Bie(e);if(r)throw lg(r,r.message,ug.BAD_REQUEST,void 0,void 0,!0);let n=e.node_name;if(!t){let d=await V_.getNodeRecord(n);if(!Hie.isEmptyOrZeroLength(d))throw lg(new Error,`Node '${n}' has already been added, perform update_node to proceed.`,ug.BAD_REQUEST,void 0,void 0,!0)}let{added:s,skipped:i}=await kie(e.subscriptions,n),o={message:void 0,added:s,skipped:i};if(s.length===0)return o.message=Vie,o;let c=V_.buildNodePayloads(s,Yie,fg.OPERATIONS_ENUM.ADD_NODE,await V_.getSystemInfo()),l=[];for(let d=0,h=s.length;d<h;d++){let _=s[d];s[d].start_time===void 0&&delete s[d].start_time,l.push(new Gie(_.schema,_.table,_.publish,_.subscribe))}dg.trace("addNode sending remote payload:",c);let u;try{u=await $_.request(`${n}.${CF.REQUEST_SUFFIX}`,c)}catch(d){dg.error(`addNode received error from request: ${d}`);for(let _=0,m=s.length;_<m;_++){let S=s[_];S.publish=!1,S.subscribe=!1,await $_.updateRemoteConsumer(S,n)}let h=$_.requestErrorHandler(d,"add_node",n);throw lg(new Error,h,ug.INTERNAL_SERVER_ERROR,"error",h)}if(u.status===CF.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let d=`Error returned from remote node ${n}: ${u.message}`;throw lg(new Error,d,ug.INTERNAL_SERVER_ERROR,"error",d)}dg.trace(u);for(let d=0,h=s.length;d<h;d++){let _=s[d];await $_.updateRemoteConsumer(_,n),_.subscribe===!0&&await $_.updateConsumerIterator(_.schema,_.table,n,"start")}let f=new Fie(n,l,u.system_info);return await V_.upsertNodeRecord(f),qie({type:"nats_update"}),i.length>0?o.message=Kie:o.message=`Successfully added '${n}' to manifest`,o}a(Wie,"addNode")});var tN=C((cCe,LF)=>{"use strict";var{handleHDBError:XO,hdb_errors:zie}=he(),{HTTP_STATUS_CODES:ZO}=zie,{addUpdateNodeValidator:Qie}=ig(),K_=J(),hg=(H(),P($)),DF=Nt(),aCe=ae(),Y_=pr(),W_=_o(),eN=ce(),{cloneDeep:jie}=require("lodash"),Jie=jO(),{Node:Xie,NodeSubscription:Zie}=$u(),{broadcast:eoe}=rt(),{setNode:toe}=(tl(),P(el)),roe="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",noe="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",soe=eN.get(hg.CONFIG_PARAMS.CLUSTERING_NODENAME);LF.exports=ioe;async function ioe(e){if(K_.trace("updateNode called with:",e),eN.get(hg.CONFIG_PARAMS.REPLICATION_URL)??eN.get(hg.CONFIG_PARAMS.REPLICATION_HOSTNAME))return toe(e);W_.checkClusteringEnabled();let t=Qie(e);if(t)throw XO(t,t.message,ZO.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await W_.getNodeRecord(r);s.length>0&&(n=jie(s));let{added:i,skipped:o}=await Jie(e.subscriptions,r),c={message:void 0,updated:i,skipped:o};if(i.length===0)return c.message=roe,c;let l=W_.buildNodePayloads(i,soe,hg.OPERATIONS_ENUM.UPDATE_NODE,await W_.getSystemInfo());for(let f=0,d=i.length;f<d;f++){let h=i[f];K_.trace(`updateNode updating work stream for node: ${r} subscription:`,h),i[f].start_time===void 0&&delete i[f].start_time}K_.trace("updateNode sending remote payload:",l);let u;try{u=await Y_.request(`${r}.${DF.REQUEST_SUFFIX}`,l)}catch(f){K_.error(`updateNode received error from request: ${f}`);let d=Y_.requestErrorHandler(f,"update_node",r);throw XO(new Error,d,ZO.INTERNAL_SERVER_ERROR,"error",d)}if(u.status===DF.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let f=`Error returned from remote node ${r}: ${u.message}`;throw XO(new Error,f,ZO.INTERNAL_SERVER_ERROR,"error",f)}K_.trace(u);for(let f=0,d=i.length;f<d;f++){let h=i[f];await Y_.updateRemoteConsumer(h,r),h.subscribe===!0?await Y_.updateConsumerIterator(h.schema,h.table,r,"start"):await Y_.updateConsumerIterator(h.schema,h.table,r,"stop")}return n||(n=[new Xie(r,[],u.system_info)]),await ooe(n[0],i,u.system_info),o.length>0?c.message=noe:c.message=`Successfully updated '${r}'`,c}a(ioe,"updateNode");async function ooe(e,t,r){let n=e;for(let s=0,i=t.length;s<i;s++){let o=t[s],c=!1;for(let l=0,u=e.subscriptions.length;l<u;l++){let f=n.subscriptions[l];if(f.schema===o.schema&&f.table===o.table){f.publish=o.publish,f.subscribe=o.subscribe,c=!0;break}}c||n.subscriptions.push(new Zie(o.schema,o.table,o.publish,o.subscribe))}n.system_info=r,await W_.upsertNodeRecord(n),eoe({type:"nats_update"})}a(ooe,"updateNodeTable")});var BF=C((uCe,xF)=>{"use strict";var UF=require("joi"),{string:MF}=UF.types(),aoe=nt(),vF=(H(),P($)),coe=ce(),loe=Nt();xF.exports=uoe;function uoe(e){let t=MF.invalid(coe.get(vF.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(loe.NATS_TERM_CONSTRAINTS_RX).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >","any.invalid":"'node_name' cannot be this nodes name"}).empty(null),r=UF.object({operation:MF.valid(vF.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return aoe.validateBySchema(e,r)}a(uoe,"removeNodeValidator")});var mg=C((fCe,qF)=>{"use strict";var{handleHDBError:HF,hdb_errors:doe}=he(),{HTTP_STATUS_CODES:kF}=doe,foe=BF(),z_=J(),FF=_o(),_oe=ae(),Yu=(H(),P($)),GF=Nt(),rN=pr(),nN=ce(),{RemotePayloadObject:hoe}=G_(),{NodeSubscription:moe}=$u(),poe=e_(),Eoe=Oc(),{broadcast:goe}=rt(),{setNode:Soe}=(tl(),P(el)),Toe=nN.get(Yu.CONFIG_PARAMS.CLUSTERING_NODENAME);qF.exports=Aoe;async function Aoe(e){if(z_.trace("removeNode called with:",e),nN.get(Yu.CONFIG_PARAMS.REPLICATION_URL)??nN.get(Yu.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Soe(e);FF.checkClusteringEnabled();let t=foe(e);if(t)throw HF(t,t.message,kF.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await FF.getNodeRecord(r);if(_oe.isEmptyOrZeroLength(n))throw HF(new Error,`Node '${r}' was not found.`,kF.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new hoe(Yu.OPERATIONS_ENUM.REMOVE_NODE,Toe,[]),i,o=!1;for(let l=0,u=n.subscriptions.length;l<u;l++){let f=n.subscriptions[l];f.subscribe===!0&&await rN.updateConsumerIterator(f.schema,f.table,r,"stop");try{await rN.updateRemoteConsumer(new moe(f.schema,f.table,!1,!1),r)}catch(d){z_.error(d)}}try{i=await rN.request(`${r}.${GF.REQUEST_SUFFIX}`,s),z_.trace("Remove node reply from remote node:",r,i)}catch(l){z_.error("removeNode received error from request:",l),o=!0}let c=new poe(Yu.SYSTEM_SCHEMA_NAME,Yu.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await Eoe.deleteRecord(c),goe({type:"nats_update"}),i?.status===GF.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||o?(z_.error("Error returned from remote node:",r,i?.message),`Successfully removed '${r}' from local manifest, however there was an error reaching remote node. Check the logs for more details.`):`Successfully removed '${r}' from manifest`}a(Aoe,"removeNode")});var KF=C((hCe,VF)=>{"use strict";var $F=require("joi"),{string:Roe,array:yoe}=$F.types(),boe=nt(),Ooe=ig();VF.exports=Noe;function Noe(e){let t=$F.object({operation:Roe.valid("configure_cluster").required(),connections:yoe.items(Ooe.validation_schema).required()});return boe.validateBySchema(e,t)}a(Noe,"configureClusterValidator")});var sN=C((pCe,jF)=>{"use strict";var YF=(H(),P($)),pg=J(),woe=ae(),Ioe=ce(),Coe=mg(),Poe=_g(),Doe=_o(),Loe=KF(),{handleHDBError:WF,hdb_errors:Moe}=he(),{HTTP_STATUS_CODES:zF}=Moe,voe="Configure cluster complete.",Uoe="Failed to configure the cluster. Check the logs for more details.",xoe="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";jF.exports=Boe;async function Boe(e){pg.trace("configure cluster called with:",e);let t=Loe(e);if(t)throw WF(t,t.message,zF.BAD_REQUEST,void 0,void 0,!0);let r=await Doe.getAllNodeRecords(),n=[];if(Ioe.get(YF.CONFIG_PARAMS.CLUSTERING_ENABLED)){for(let f=0,d=r.length;f<d;f++){let h=await QF(Coe,{operation:YF.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[f].name},r[f].name);n.push(h)}pg.trace("All results from configure_cluster remove node:",n)}let s=[],i=e.connections.length;for(let f=0;f<i;f++){let d=e.connections[f],h=await QF(Poe,d,d.node_name);s.push(h)}pg.trace("All results from configure_cluster add node:",s);let o=[],c=[],l=!1,u=n.concat(s);for(let f=0,d=u.length;f<d;f++){let h=u[f];h.status==="rejected"&&(pg.error(h.node_name,h?.error?.message,h?.error?.stack),o.includes(h.node_name)||o.push(h.node_name)),(h?.result?.message?.includes?.("Successfully")||h?.result?.includes?.("Successfully"))&&(l=!0),!(typeof h.result=="string"&&h.result.includes("Successfully removed")||h.status==="rejected")&&c.push({node_name:h?.node_name,response:h?.result})}if(woe.isEmptyOrZeroLength(o))return{message:voe,connections:c};if(l)return{message:xoe,failed_nodes:o,connections:c};throw WF(new Error,Uoe,zF.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(Boe,"configureCluster");async function QF(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){return{node_name:r,error:n,status:"rejected"}}}a(QF,"functionWrapper")});var eG=C((gCe,ZF)=>{"use strict";var Q_=require("joi"),Hoe=nt(),{validateSchemaExists:JF,validateTableExists:koe,validateSchemaName:XF}=gi(),Foe=Q_.object({operation:Q_.string().valid("purge_stream"),schema:Q_.string().custom(JF).custom(XF).optional(),database:Q_.string().custom(JF).custom(XF).optional(),table:Q_.string().custom(koe).required()});function Goe(e){return Hoe.validateBySchema(e,Foe)}a(Goe,"purgeStreamValidator");ZF.exports=Goe});var iN=C((TCe,tG)=>{"use strict";var{handleHDBError:qoe,hdb_errors:$oe}=he(),{HTTP_STATUS_CODES:Voe}=$oe,Koe=eG(),Yoe=pr(),Woe=_o();tG.exports=zoe;async function zoe(e){e.schema=e.schema??e.database;let t=Koe(e);if(t)throw qoe(t,t.message,Voe.BAD_REQUEST,void 0,void 0,!0);Woe.checkClusteringEnabled();let{schema:r,table:n,options:s}=e;return await Yoe.purgeTableStream(r,n,s),`Successfully purged table '${r}.${n}'`}a(zoe,"purgeStream")});var cN=C((RCe,cG)=>{"use strict";var aN=_o(),Qoe=pr(),gg=ce(),Wu=(H(),P($)),rl=Nt(),joe=ae(),oN=J(),{RemotePayloadObject:Joe}=G_(),{ErrorCode:rG}=require("nats"),{parentPort:nG}=require("worker_threads"),{onMessageByType:Xoe}=rt(),{getThisNodeName:Zoe}=(ds(),P(pa)),{requestClusterStatus:eae}=(P_(),P(wH)),{getReplicationSharedStatus:tae,getHDBNodeTable:rae}=(Kc(),P(zb)),{CONFIRMATION_STATUS_POSITION:nae,RECEIVED_VERSION_POSITION:sae,RECEIVED_TIME_POSITION:iae,SENDING_TIME_POSITION:oae}=(EO(),P(mk)),sG=gg.get(Wu.CONFIG_PARAMS.CLUSTERING_ENABLED),iG=gg.get(Wu.CONFIG_PARAMS.CLUSTERING_NODENAME);cG.exports={clusterStatus:aae,buildNodeStatus:aG};var oG;Xoe("cluster-status",async e=>{oG(e)});async function aae(){if(gg.get(Wu.CONFIG_PARAMS.REPLICATION_URL)||gg.get(Wu.CONFIG_PARAMS.REPLICATION_HOSTNAME)){let n;if(nG){nG.postMessage({type:"request-cluster-status"}),n=await new Promise(i=>{oG=i});for(let i of n.connections){let o=i.name;for(let c of i.database_sockets){let l=c.database,u;for(let d of Object.values(databases[l]||{}))if(u=d.auditStore,u)break;if(!u)continue;let f=tae(u,l,o);c.lastCommitConfirmed=Eg(f[nae]),c.lastReceivedRemoteTime=Eg(f[sae]),c.lastReceivedLocalTime=Eg(f[iae]),c.sendingMessage=Eg(f[oae])}}}else n=eae();n.node_name=Zoe();let s=rae().primaryStore.get(n.node_name);return s?.shard&&(n.shard=s.shard),s?.url&&(n.url=s.url),n.is_enabled=!0,n}let e={node_name:iG,is_enabled:sG,connections:[]};if(!sG)return e;let t=await aN.getAllNodeRecords();if(joe.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(aG(t[n],e.connections));return await Promise.allSettled(r),e}a(aae,"clusterStatus");function Eg(e){return e?e===1?"Copying":new Date(e).toUTCString():void 0}a(Eg,"asDate");async function aG(e,t){let r=e.name,n=new Joe(Wu.OPERATIONS_ENUM.CLUSTER_STATUS,iG,void 0,await aN.getSystemInfo()),s,i,o=rl.CLUSTER_STATUS_STATUSES.OPEN;try{let l=Date.now();s=await Qoe.request(rl.REQUEST_SUBJECT(r),n),i=Date.now()-l,s.status===rl.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=rl.CLUSTER_STATUS_STATUSES.CLOSED,oN.error(`Error getting node status from ${r} `,s))}catch(l){oN.warn(`Error getting node status from ${r}`,l),l.code===rG.NoResponders?o=rl.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:l.code===rG.Timeout?o=rl.CLUSTER_STATUS_STATUSES.TIMEOUT:o=rl.CLUSTER_STATUS_STATUSES.CLOSED}let c=new cae(r,o,s?.message?.ports?.clustering,s?.message?.ports?.operations_api,i,s?.message?.uptime,e.subscriptions,s?.message?.system_info);try{let l={name:r,system_info:s?.message?.system_info};e.system_info?.hdb_version!==Wu.PRE_4_0_0_VERSION&&await aN.upsertNodeRecord(l)}catch(l){oN.error("Cluster status encountered an error updating system info for node:",r,l)}t.push(c)}a(aG,"buildNodeStatus");function cae(e,t,r,n,s,i,o,c){this.node_name=e,this.status=t,this.ports={clustering:r,operations_api:n},this.latency_ms=s,this.uptime=i,this.subscriptions=o,this.system_info=c}a(cae,"NodeStatusObject")});var uN=C((bCe,lG)=>{"use strict";var{handleHDBError:lae,hdb_errors:uae}=he(),{HTTP_STATUS_CODES:dae}=uae,fae=pr(),_ae=_o(),lN=ae(),Sg=require("joi"),hae=nt(),mae=2e3,pae=Sg.object({timeout:Sg.number().min(1),connected_nodes:Sg.boolean(),routes:Sg.boolean()});lG.exports=Eae;async function Eae(e){_ae.checkClusteringEnabled();let t=hae.validateBySchema(e,pae);if(t)throw lae(t,t.message,dae.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||lN.autoCastBoolean(n),o=s===void 0||lN.autoCastBoolean(s),c={nodes:[]},l=await fae.getServerList(r??mae),u={};if(i)for(let f=0,d=l.length;f<d;f++){let h=l[f].statsz;h&&(u[l[f].server.name]=h.routes)}for(let f=0,d=l.length;f<d;f++){if(l[f].statsz)continue;let h=l[f].server,_=l[f].data;if(h.name.endsWith("-hub")){let m={name:h.name.slice(0,-4),response_time:l[f].response_time};i&&(m.connected_nodes=[],u[h.name]&&u[h.name].forEach(S=>{m.connected_nodes.includes(S.name.slice(0,-4))||m.connected_nodes.push(S.name.slice(0,-4))})),o&&(m.routes=_.cluster?.urls?_.cluster?.urls.map(S=>({host:S.split(":")[0],port:lN.autoCast(S.split(":")[1])})):[]),c.nodes.push(m)}}return c}a(Eae,"clusterNetwork")});var _G=C((NCe,fG)=>{"use strict";var dN=require("joi"),uG=nt(),{route_constraints:dG}=KR();fG.exports={setRoutesValidator:gae,deleteRoutesValidator:Sae};function gae(e){let t=dN.object({server:dN.valid("hub","leaf"),routes:dG.required()});return uG.validateBySchema(e,t)}a(gae,"setRoutesValidator");function Sae(e){let t=dN.object({routes:dG.required()});return uG.validateBySchema(e,t)}a(Sae,"deleteRoutesValidator")});var Tg=C((ICe,TG)=>{"use strict";var mo=It(),fN=ae(),ps=(H(),P($)),zu=ce(),hG=_G(),{handleHDBError:mG,hdb_errors:Tae}=he(),{HTTP_STATUS_CODES:pG}=Tae,EG="cluster routes successfully set",gG="cluster routes successfully deleted";TG.exports={setRoutes:Rae,getRoutes:yae,deleteRoutes:bae};function Aae(e){let t=mo.getClusteringRoutes(),r=e.server==="hub"?t.hub_routes:t.leaf_routes,n=e.server==="hub"?t.leaf_routes:t.hub_routes,s=[],i=[];for(let o=0,c=e.routes.length;o<c;o++){let l=e.routes[o];l.port=fN.autoCast(l.port);let u=r.some(d=>d.host===l.host&&d.port===l.port),f=n.some(d=>d.host===l.host&&d.port===l.port);u||f?s.push(l):(r.push(l),i.push(l))}return e.server==="hub"?mo.updateConfigValue(ps.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r):mo.updateConfigValue(ps.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,r),{message:EG,set:i,skipped:s}}a(Aae,"setRoutesNats");function Rae(e){let t=hG.setRoutesValidator(e);if(t)throw mG(t,t.message,pG.BAD_REQUEST,void 0,void 0,!0);if(zu.get(ps.CONFIG_PARAMS.CLUSTERING_ENABLED))return Aae(e);let r=[],n=[],s=zu.get(ps.CONFIG_PARAMS.REPLICATION_ROUTES)??[];return e.routes.forEach(i=>{SG(s,i)?n.push(i):(s.push(i),r.push(i))}),mo.updateConfigValue(ps.CONFIG_PARAMS.REPLICATION_ROUTES,s),{message:EG,set:r,skipped:n}}a(Rae,"setRoutes");function SG(e,t){return typeof t=="string"?e.includes(t):typeof t=="object"&&t!==null?e.some(r=>(r.host===t.host||r.hostname===t.hostname)&&r.port===t.port):!1}a(SG,"existsInArray");function yae(){if(zu.get(ps.CONFIG_PARAMS.CLUSTERING_ENABLED)){let e=mo.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}else return zu.get(ps.CONFIG_PARAMS.REPLICATION_ROUTES)??[]}a(yae,"getRoutes");function bae(e){let t=hG.deleteRoutesValidator(e);if(t)throw mG(t,t.message,pG.BAD_REQUEST,void 0,void 0,!0);if(zu.get(ps.CONFIG_PARAMS.CLUSTERING_ENABLED))return Oae(e);let r=[],n=[],s=zu.get(ps.CONFIG_PARAMS.REPLICATION_ROUTES)??[],i=[];return s.forEach(o=>{SG(e.routes,o)?r.push(o):(i.push(o),n.push(o))}),mo.updateConfigValue(ps.CONFIG_PARAMS.REPLICATION_ROUTES,i),{message:gG,deleted:r,skipped:n}}a(bae,"deleteRoutes");function Oae(e){let t=mo.getClusteringRoutes(),r=t.hub_routes,n=t.leaf_routes,s=[],i=[],o=!1,c=!1;for(let l=0,u=e.routes.length;l<u;l++){let f=e.routes[l],d=!1;for(let h=0,_=r.length;h<_;h++){let m=r[h];if(f.host===m.host&&f.port===m.port){r.splice(h,1),d=!0,o=!0,s.push(f);break}}if(!d){let h=!0;for(let _=0,m=n.length;_<m;_++){let S=n[_];if(f.host===S.host&&f.port===S.port){n.splice(_,1),c=!0,h=!1,s.push(f);break}}h&&i.push(f)}}return o&&(r=fN.isEmptyOrZeroLength(r)?null:r,mo.updateConfigValue(ps.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r)),c&&(n=fN.isEmptyOrZeroLength(n)?null:n,mo.updateConfigValue(ps.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n)),{message:gG,deleted:s,skipped:i}}a(Oae,"deleteRoutesNats")});var RG=C((PCe,AG)=>{"use strict";var j_=require("alasql"),nl=require("recursive-iterator"),Qs=J(),Nae=ae(),J_=(H(),P($)),_N=class{static{a(this,"sql_statement_bucket")}constructor(t){this.ast=t,this.affected_attributes=new Map,this.table_lookup=new Map,this.schema_lookup=new Map,this.table_to_schema_lookup=new Map,Iae(this.ast,this.affected_attributes,this.table_lookup,this.schema_lookup,this.table_to_schema_lookup)}getAttributesBySchemaTableName(t,r){if(!t||!r||!this.affected_attributes)return[];if(this.affected_attributes.has(t))return!this.affected_attributes.get(t).has(r)&&(r=this.table_lookup.get(r),!r)?[]:this.affected_attributes.get(t).get(r)}getAllTables(){let t=[];if(!this.affected_attributes)return t;for(let r of this.affected_attributes.keys())t.push(Array.from(this.affected_attributes.get(r).keys()));return t}getTablesBySchemaName(t){return!t||!this.affected_attributes?[]:Array.from(this.affected_attributes.get(t).keys())}getSchemas(){return this.affected_attributes?Array.from(this.affected_attributes.keys()):[]}getAst(){return this.ast}updateAttributeWildcardsForRolePerms(t){let r=this.ast.columns.filter(s=>J_.SEARCH_WILDCARDS.includes(s.columnid));if(r.length===0)return this.ast;let n=this.ast.from[0].databaseid;return this.ast.columns=this.ast.columns.filter(s=>!J_.SEARCH_WILDCARDS.includes(s.columnid)),r.forEach(s=>{let i=this.table_to_schema_lookup.has(s.tableid)?this.table_to_schema_lookup.get(s.tableid):n,o=this.table_lookup.has(s.tableid)?this.table_lookup.get(s.tableid):this.ast.from[0].tableid;if(t[i]&&t[i].tables[o]&&t[i].tables[o][J_.PERMS_CRUD_ENUM.READ]){let c;t[i].tables[o].attribute_permissions.length>0?c=wae(t[i].tables[o].attribute_permissions):c=global.hdb_schema[i][o].attributes.map(u=>({attribute_name:u.attribute}));let l=this.affected_attributes.get(i).get(o).filter(u=>!J_.SEARCH_WILDCARDS.includes(u));c.forEach(({attribute_name:u})=>{let f=new j_.yy.Column({columnid:u});s.tableid&&(f.tableid=s.tableid),this.ast.columns.push(f),l.includes(u)||l.push(u)}),this.affected_attributes.get(i).set(o,l)}}),this.ast}};function wae(e){return e.filter(t=>t[J_.PERMS_CRUD_ENUM.READ])}a(wae,"filterReadRestrictedAttrs");function Iae(e,t,r,n,s){Cae(e,t,r,n,s)}a(Iae,"interpretAST");function X_(e,t,r,n,s){if(!(!e||!e.databaseid)&&(t.has(e.databaseid)||t.set(e.databaseid,new Map),t.get(e.databaseid).has(e.tableid)||t.get(e.databaseid).set(e.tableid,[]),e.as&&(r.has(e.as)||r.set(e.as,e.tableid),n&&!n.has(e.as)&&n.set(e.as,e.databaseid)),s)){let i=e.databaseid,o=e.tableid;e.as&&(o=e.as),s.set(o,i)}}a(X_,"addSchemaTableToMap");function Cae(e,t,r,n,s){if(!e){Qs.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof j_.yy.Insert?Mae(e,t,r):e instanceof j_.yy.Select?Pae(e,t,r,n,s):e instanceof j_.yy.Update?Dae(e,t,r):e instanceof j_.yy.Delete?Lae(e,t,r):Qs.error("AST in getRecordAttributesAST() is not a valid SQL type.")}a(Cae,"getRecordAttributesAST");function Pae(e,t,r,n,s){if(!e){Qs.info("getSelectAttributes: invalid SQL syntax tree");return}if(!e.from||e.from[0]===void 0)return;let i=e.from[0].databaseid;if(Nae.isEmptyOrZeroLength(i)){Qs.error("No schema specified");return}e.from.forEach(c=>{X_(c,t,r,n,s)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),X_(c.table,t,r,n,s)});let o=new nl(e.columns);for(let{node:c}of o)if(c&&c.columnid){let l=c.tableid,u=n.has(l)?n.get(l):i;if(l||(l=e.from[0].tableid),!t.get(u).has(l))if(r.has(l))l=r.get(l);else{Qs.info(`table specified as ${l} not found.`);return}t.get(u).get(l).indexOf(c.columnid)<0&&t.get(u).get(l).push(c.columnid)}if(e.where){let c=new nl(e.where),l=e.from[0].tableid;for(let{node:u}of c)if(u&&u.columnid){let f=u.tableid?u.tableid:l;if(!t.get(i).has(f))if(r.has(f))f=r.get(f);else{Qs.info(`table specified as ${f} not found.`);continue}t.get(i).get(f).indexOf(u.columnid)<0&&t.get(i).get(f).push(u.columnid)}}if(e.joins&&e.joins.forEach(c=>{let l=new nl(c.on);for(let{node:u}of l)if(u&&u.columnid){let f=u.tableid,d=s.get(f);if(!t.get(d).has(f))if(r.has(f))f=r.get(f);else{Qs.info(`table specified as ${f} not found.`);continue}t.get(d).get(f).indexOf(u.columnid)<0&&t.get(d).get(f).push(u.columnid)}}),e.order){let c=new nl(e.order);for(let{node:l}of c)if(l&&l.columnid){let u=l.tableid,f=n.has(u)?n.get(u):i;if(u||(u=e.from[0].tableid),!t.get(f).has(u))if(r.has(u))u=r.get(u);else{Qs.info(`table specified as ${u} not found.`);return}t.get(f).get(u).indexOf(l.columnid)<0&&t.get(f).get(u).push(l.columnid)}}}a(Pae,"getSelectAttributes");function Dae(e,t,r){if(!e){Qs.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new nl(e.columns),s=e.table.databaseid;X_(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&hN(e.table.tableid,s,i.columnid,t,r)}a(Dae,"getUpdateAttributes");function Lae(e,t,r){if(!e){Qs.info("getDeleteAttributes: invalid SQL syntax tree");return}let n=new nl(e.where),s=e.table.databaseid;X_(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&hN(e.table.tableid,s,i.columnid,t,r)}a(Lae,"getDeleteAttributes");function Mae(e,t,r){if(!e){Qs.info("getInsertAttributes: invalid SQL syntax tree");return}let n=new nl(e.columns),s=e.into.databaseid;X_(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&hN(e.into.tableid,s,i.columnid,t,r)}a(Mae,"getInsertAttributes");function hN(e,t,r,n,s){if(!n.get(t))return;let i=e;n.get(t).has(i)||(i=s.get(i)),n.get(t).get(i).push(r)}a(hN,"pushAttribute");AG.exports=_N});var bG=C((LCe,yG)=>{"use strict";var Ag=(H(),P($)),Rg=class{static{a(this,"BaseLicense")}constructor(t=0,r=Ag.RAM_ALLOCATION_ENUM.DEFAULT,n=Ag.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},mN=class extends Rg{static{a(this,"ExtendedLicense")}constructor(t=0,r=Ag.RAM_ALLOCATION_ENUM.DEFAULT,n=Ag.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};yG.exports={BaseLicense:Rg,ExtendedLicense:mN}});var Ju=C((vCe,PG)=>{"use strict";var ju=require("fs-extra"),yg=(yp(),P(Rp)),NG=require("crypto"),vae=require("moment"),Uae=require("uuid").v4,Jr=J(),EN=require("path"),xae=ae(),sl=(H(),P($)),{totalmem:OG}=require("os"),Bae=bG().ExtendedLicense,Qu="invalid license key format",Hae="061183",kae="mofi25",Fae="aes-256-cbc",Gae=16,qae=32,wG=ce(),{resolvePath:IG}=It();wG.initSync();var pN;PG.exports={validateLicense:CG,generateFingerPrint:Vae,licenseSearch:TN,getLicense:Wae,checkMemoryLimit:zae};function gN(){return EN.join(wG.getHdbBasePath(),sl.LICENSE_KEY_DIR_NAME,sl.LICENSE_FILE_NAME)}a(gN,"getLicenseDirPath");function $ae(){let e=gN();return IG(EN.join(e,sl.LICENSE_FILE_NAME))}a($ae,"getLicenseFilePath");function SN(){let e=gN();return IG(EN.join(e,sl.REG_KEY_FILE_NAME))}a(SN,"getFingerPrintFilePath");async function Vae(){let e=SN();try{return await ju.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await Kae();throw Jr.error(`Error writing fingerprint file to ${e}`),Jr.error(t),new Error("There was an error generating the fingerprint")}}a(Vae,"generateFingerPrint");async function Kae(){let e=Uae(),t=yg.hash(e,yg.HASH_FUNCTION.MD5),r=SN();try{await ju.mkdirp(gN()),await ju.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw Jr.error(`Error writing fingerprint file to ${r}`),Jr.error(n),new Error("There was an error generating the fingerprint")}return t}a(Kae,"writeFingerprint");function CG(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:sl.RAM_ALLOCATION_ENUM.DEFAULT,version:sl.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return Jr.error("empty license key passed to validate."),r;let n=SN(),s=!1;try{s=ju.statSync(n)}catch(i){Jr.error(i)}if(s){let i;try{i=ju.readFileSync(n,"utf8")}catch{Jr.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(kae),c=o[1];c=Buffer.concat([Buffer.from(c)],Gae);let l=Buffer.concat([Buffer.from(i)],qae),u=NG.createDecipheriv(Fae,l,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let f=null;try{f=u.update(o[0],"hex","utf8"),f.trim(),f+=u.final("utf8")}catch{let _=Yae(o[0],i);if(_)f=_;else throw r.valid_license=!1,r.valid_machine=!1,console.error(Qu),Jr.error(Qu),new Error(Qu)}let d;if(isNaN(f))try{d=JSON.parse(f),r.version=d.version,r.exp_date=d.exp_date,isNaN(r.exp_date)&&(r.exp_date=new Date(r.exp_date).getTime()),d.ram_allocation&&(r.ram_allocation=d.ram_allocation)}catch{throw console.error(Qu),Jr.error(Qu),new Error(Qu)}else r.exp_date=f;r.exp_date<vae().valueOf()&&(r.valid_date=!1),yg.validate(o[1],`${Hae}${i}${t}`,yg.HASH_FUNCTION.MD5)||(r.valid_license=!1)}else r.valid_license=!1,r.valid_machine=!1;return r.valid_license&&r.valid_machine&&r.valid_date||Jr.error("Invalid licence"),r}a(CG,"validateLicense");function Yae(e,t){try{let r=NG.createDecipher("aes192",t),n=r.update(e,"hex","utf8");return n.trim(),n+=r.final("utf8"),n}catch{Jr.warn("Check old license failed")}}a(Yae,"checkOldLicense");function TN(){let e=new Bae,t=[];try{t=ju.readFileSync($ae(),"utf-8").split(`\r
|
|
24
24
|
`)}catch(r){r.code==="ENOENT"?Jr.debug("no license file found"):Jr.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if(xae.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=CG(s.license_key,s.company);i.valid_machine===!0&&i.valid_date===!0&&i.valid_machine===!0&&(e.exp_date=i.exp_date>e.exp_date?i.exp_date:e.exp_date,e.ram_allocation=i.ram_allocation,e.enterprise=!0)}catch(s){Jr.error("There was an error parsing the license string."),Jr.error(s),e.ram_allocation=sl.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return pN=e,e}a(TN,"licenseSearch");async function Wae(){return pN||await TN(),pN}a(Wae,"getLicense");function zae(){let e=TN().ram_allocation,t=process.constrainedMemory?.()||OG();if(t=Math.round(Math.min(t,OG())/2**20),t>e)return`This server has more memory (${t}MB) than HarperDB is licensed for (${e}MB), this should only be used for educational and development purposes.`}a(zae,"checkMemoryLimit")});var yN=C((xCe,vG)=>{var bg=Ju(),DG=require("chalk"),Wn=J(),LG=require("prompt"),{promisify:Qae}=require("util"),AN=(H(),P($)),jae=require("fs-extra"),Jae=require("path"),Xae=ae(),{packageJson:Zae}=pt(),MG=ce();MG.initSync();var ece=require("moment"),tce=Qae(LG.get),rce=Jae.join(MG.getHdbBasePath(),AN.LICENSE_KEY_DIR_NAME,AN.LICENSE_FILE_NAME,AN.LICENSE_FILE_NAME);vG.exports={getFingerprint:sce,setLicense:nce,parseLicense:RN,register:ice,getRegistrationInfo:ace};async function nce(e){if(e&&e.key&&e.company){try{Wn.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await RN(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw Wn.error(r),Wn.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}a(nce,"setLicense");async function sce(){let e={};try{e=await bg.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw Wn.error(r),Wn.error(t),new Error(r)}return e}a(sce,"getFingerprint");async function RN(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");Wn.info("Validating license input...");let r=bg.validateLicense(e,t);if(Wn.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(Wn.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(Wn.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{Wn.info("writing license to disk"),await jae.writeFile(rce,JSON.stringify({license_key:e,company:t}))}catch(n){throw Wn.error("Failed to write License"),n}return"Registration successful."}a(RN,"parseLicense");async function ice(){let e=await oce();return RN(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(ice,"register");async function oce(){let e=await bg.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:DG.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:DG.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{LG.start()}catch(n){Wn.error(n)}let r;try{r=await tce(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}a(oce,"promptForRegistration");async function ace(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await bg.getLicense()}catch(r){throw Wn.error(`There was an error when searching licenses due to: ${r.message}`),r}if(Xae.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=Zae.version,e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=ece.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(ace,"getRegistrationInfo")});var xG=C((HCe,UG)=>{"use strict";var cce=Nt(),bN=class{static{a(this,"HubConfigObject")}constructor(t,r,n,s,i,o,c,l,u,f,d,h,_,m){this.port=t,o===null&&(o=void 0),this.server_name=r+cce.SERVER_SUFFIX.HUB,this.pid_file=n,this.max_payload=67108864,this.reconnect_error_reports=100,this.jetstream={enabled:!1},this.tls={cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l},this.leafnodes={port:u,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c}},this.cluster={name:f,port:d,routes:h,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l}},this.accounts={SYS:{users:_},HDB:{users:m}},this.system_account="SYS"}};UG.exports=bN});var kG=C((FCe,HG)=>{"use strict";var BG=Nt(),ON=class{static{a(this,"LeafConfigObject")}constructor(t,r,n,s,i,o,c,l,u,f,d){this.port=t,d===null&&(d=void 0),this.server_name=r+BG.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+BG.SERVER_SUFFIX.LEAF},this.tls={cert_file:u,key_file:f,ca_file:d,insecure:!0},this.leafnodes={remotes:[{tls:{ca_file:d,insecure:!0},urls:i,account:"SYS"},{tls:{ca_file:d,insecure:!0},urls:o,account:"HDB"}]},this.accounts={SYS:{users:c},HDB:{users:l,jetstream:"enabled"}},this.system_account="SYS"}};HG.exports=ON});var GG=C((qCe,FG)=>{"use strict";var NN=class{static{a(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};FG.exports=NN});var $G=C((VCe,qG)=>{"use strict";var lce=Nt(),wN=class{static{a(this,"SysUserObject")}constructor(t,r){this.user=t+lce.SERVER_SUFFIX.ADMIN,this.password=r}};qG.exports=wN});var Ig=C((YCe,YG)=>{"use strict";var il=require("path"),ol=require("fs-extra"),uce=xG(),dce=kG(),fce=GG(),_ce=$G(),IN=Fn(),Zu=ae(),Tn=It(),Ng=(H(),P($)),Z_=Nt(),{CONFIG_PARAMS:Wt}=Ng,ed=J(),eh=ce(),VG=eo(),CN=pr(),hce=zs(),Xu="clustering",mce=1e4,KG=50;YG.exports={generateNatsConfig:Ece,removeNatsConfig:gce,getHubConfigPath:pce};function pce(){let e=eh.get(Wt.ROOTPATH);return il.join(e,Xu,Z_.NATS_CONFIG_FILES.HUB_SERVER)}a(pce,"getHubConfigPath");async function Ece(e=!1,t=void 0){let r=eh.get(Wt.ROOTPATH);ol.ensureDirSync(il.join(r,"clustering","leaf")),eh.initSync();let n=Tn.getConfigFromFile(Wt.CLUSTERING_TLS_CERT_AUTH),s=Tn.getConfigFromFile(Wt.CLUSTERING_TLS_PRIVATEKEY),i=Tn.getConfigFromFile(Wt.CLUSTERING_TLS_CERTIFICATE);!await ol.exists(i)&&!await ol.exists(!n)&&await hce.createNatsCerts();let o=il.join(r,Xu,Z_.PID_FILES.HUB),c=il.join(r,Xu,Z_.PID_FILES.LEAF),l=Tn.getConfigFromFile(Wt.CLUSTERING_LEAFSERVER_STREAMS_PATH),u=il.join(r,Xu,Z_.NATS_CONFIG_FILES.HUB_SERVER),f=il.join(r,Xu,Z_.NATS_CONFIG_FILES.LEAF_SERVER),d=Tn.getConfigFromFile(Wt.CLUSTERING_TLS_INSECURE),h=Tn.getConfigFromFile(Wt.CLUSTERING_TLS_VERIFY),_=Tn.getConfigFromFile(Wt.CLUSTERING_NODENAME),m=Tn.getConfigFromFile(Wt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await CN.checkNATSServerInstalled()||wg("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let S=await IN.listUsers(),g=Tn.getConfigFromFile(Wt.CLUSTERING_USER),R=await IN.getClusterUser();(Zu.isEmpty(R)||R.active!==!0)&&wg(`Invalid cluster user '${g}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await Og(Wt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await Og(Wt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await Og(Wt.CLUSTERING_HUBSERVER_NETWORK_PORT),await Og(Wt.CLUSTERING_LEAFSERVER_NETWORK_PORT));let E=[],A=[];for(let[oe,z]of S.entries())z.role?.role===Ng.ROLE_TYPES_ENUM.CLUSTER_USER&&z.active&&(E.push(new _ce(z.username,VG.decrypt(z.hash))),A.push(new fce(z.username,VG.decrypt(z.hash))));let N=[],{hub_routes:v}=Tn.getClusteringRoutes();if(!Zu.isEmptyOrZeroLength(v))for(let oe of v)N.push(`tls://${R.sys_name_encoded}:${R.uri_encoded_d_hash}@${oe.host}:${oe.port}`);let F=new uce(Tn.getConfigFromFile(Wt.CLUSTERING_HUBSERVER_NETWORK_PORT),_,o,i,s,n,d,h,m,Tn.getConfigFromFile(Wt.CLUSTERING_HUBSERVER_CLUSTER_NAME),Tn.getConfigFromFile(Wt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),N,E,A);n==null&&(delete F.tls.ca_file,delete F.leafnodes.tls.ca_file),t=Zu.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===Ng.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await ol.writeJson(u,F),ed.trace(`Hub server config written to ${u}`));let q=`tls://${R.sys_name_encoded}:${R.uri_encoded_d_hash}@0.0.0.0:${m}`,Y=`tls://${R.uri_encoded_name}:${R.uri_encoded_d_hash}@0.0.0.0:${m}`,ee=new dce(Tn.getConfigFromFile(Wt.CLUSTERING_LEAFSERVER_NETWORK_PORT),_,c,l,[q],[Y],E,A,i,s,n,d);n==null&&delete ee.tls.ca_file,(t===void 0||t===Ng.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await ol.writeJson(f,ee),ed.trace(`Leaf server config written to ${f}`))}a(Ece,"generateNatsConfig");async function Og(e){let t=eh.get(e);return Zu.isEmpty(t)&&wg(`port undefined for '${e}'`),await Zu.isPortTaken(t)&&wg(`'${e}' port '${t}' is is in use by another process, check to see if HarperDB is already running or another process is using this port.`),!0}a(Og,"isPortAvailable");function wg(e){let t=`Error generating clustering config: ${e}`;ed.error(t),console.error(t),process.exit(1)}a(wg,"generateNatsConfigError");async function gce(e){let{port:t,config_file:r}=CN.getServerConfig(e),{username:n,decrypt_hash:s}=await IN.getClusterUser(),i=0,o=2e3;for(;i<KG;){try{let f=await CN.createConnection(t,n,s,!1);if(f.protocol.connected===!0){f.close();break}}catch(f){ed.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${f}`)}if(i++,i>=KG)throw new Error(`Operations API timed out attempting to connect to ${e}. This is commonly caused by incorrect clustering config. Check hdb.log for further details.`);let u=o*(i*2);u>3e4&&ed.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await Zu.async_set_timeout(u)}let c="0".repeat(mce),l=il.join(eh.get(Wt.ROOTPATH),Xu,r);await ol.writeFile(l,c),await ol.remove(l),ed.notify(e,"started.")}a(gce,"removeNatsConfig")});var XG=C((zCe,JG)=>{"use strict";var zn=ce(),Sce=Ju(),Ge=(H(),P($)),th=Nt(),po=require("path"),{PACKAGE_ROOT:Pg}=pt(),WG=ce(),Cg=ae(),td="/dev/null",Tce=po.join(Pg,"launchServiceScripts"),zG=po.join(Pg,"utility/scripts"),Ace=po.join(zG,Ge.HDB_RESTART_SCRIPT),QG=po.resolve(Pg,"dependencies",`${process.platform}-${process.arch}`,th.NATS_BINARY_NAME);function jG(){let t=Sce.licenseSearch().ram_allocation||Ge.RAM_ALLOCATION_ENUM.DEFAULT,r=Ge.MEM_SETTING_KEY+t,n={[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.HDB,IS_SCRIPTED_SERVICE:!0};return Cg.noBootFile()&&(n[Ge.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Cg.getEnvCliRootPath()),{name:Ge.PROCESS_DESCRIPTORS.HDB,script:Ge.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:n,node_args:r,cwd:Pg}}a(jG,"generateMainServerConfig");var Rce=9930;function yce(){zn.initSync(!0);let e=zn.get(Ge.CONFIG_PARAMS.ROOTPATH),t=po.join(e,"clustering",th.NATS_CONFIG_FILES.HUB_SERVER),r=po.join(zn.get(Ge.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Ge.LOG_NAMES.HDB),n=WG.get(Ge.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=th.LOG_LEVEL_FLAGS[zn.get(Ge.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Ge.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==Rce?"-"+n:""),script:QG,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.CLUSTERING_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return zn.get(Ge.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=td,i.error_file=td),i}a(yce,"generateNatsHubServerConfig");var bce=9940;function Oce(){zn.initSync(!0);let e=zn.get(Ge.CONFIG_PARAMS.ROOTPATH),t=po.join(e,"clustering",th.NATS_CONFIG_FILES.LEAF_SERVER),r=po.join(zn.get(Ge.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Ge.LOG_NAMES.HDB),n=WG.get(Ge.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=th.LOG_LEVEL_FLAGS[zn.get(Ge.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Ge.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==bce?"-"+n:""),script:QG,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.CLUSTERING_LEAF},merge_logs:!0,out_file:r,error_file:r,instances:1};return zn.get(Ge.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=td,i.error_file=td),i}a(Oce,"generateNatsLeafServerConfig");function Nce(){zn.initSync();let e=po.join(zn.get(Ge.CONFIG_PARAMS.LOGGING_ROOT),Ge.LOG_NAMES.HDB),t={name:Ge.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,script:Ge.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:Tce,autorestart:!1};return zn.get(Ge.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=td,t.error_file=td),t}a(Nce,"generateClusteringUpgradeV4ServiceConfig");function wce(){let e={[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.RESTART_HDB};return Cg.noBootFile()&&(e[Ge.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Cg.getEnvCliRootPath()),{...{name:Ge.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:zG},script:Ace}}a(wce,"generateRestart");function Ice(){return{apps:[jG()]}}a(Ice,"generateAllServiceConfigs");JG.exports={generateAllServiceConfigs:Ice,generateMainServerConfig:jG,generateRestart:wce,generateNatsHubServerConfig:yce,generateNatsLeafServerConfig:Oce,generateClusteringUpgradeV4ServiceConfig:Nce}});var nh=C((JCe,fq)=>{"use strict";var et=(H(),P($)),Cce=ae(),go=Ig(),Dg=pr(),Eo=Nt(),Oa=XG(),Lg=ce(),al=J(),Pce=_o(),{startWorker:ZG,onMessageFromWorkers:Dce}=rt(),Lce=Ku(),jCe=require("util"),Mce=require("child_process"),vce=require("fs"),{execFile:Uce}=Mce,Ke;fq.exports={enterPM2Mode:xce,start:Na,stop:PN,reload:tq,restart:rq,list:DN,describe:iq,connect:So,kill:Gce,startAllServices:qce,startService:LN,getUniqueServicesList:oq,restartAllServices:$ce,isServiceRegistered:aq,reloadStopStart:cq,restartHdb:sq,deleteProcess:kce,startClusteringProcesses:uq,startClusteringThreads:dq,isHdbRestartRunning:Fce,isClusteringRunning:Kce,stopClustering:Vce,reloadClustering:Yce,expectedRestartOfChildren:nq};var rh=!1;Dce(e=>{e.type==="restart"&&Lg.initSync(!0)});function xce(){rh=!0}a(xce,"enterPM2Mode");function So(){return Ke||(Ke=require("pm2")),new Promise((e,t)=>{Ke.connect((r,n)=>{r&&t(r),e(n)})})}a(So,"connect");var Xr,Bce=10,eq;function Na(e,t=!1){if(rh)return Hce(e);let r=Uce(e.script,e.args.split(" "),e);r.name=e.name,r.config=e,r.on("exit",async i=>{let o=Xr.indexOf(r);o>-1&&Xr.splice(o,1),!eq&&i!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<Bce&&(vce.existsSync(go.getHubConfigPath())?Na(e):(await go.generateNatsConfig(!0),Na(e),await new Promise(c=>setTimeout(c,3e3)),await go.removeNatsConfig(et.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await go.removeNatsConfig(et.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let n={serviceName:e.name.replace(/ /g,"-")};function s(i){let o=Lg.get(et.CONFIG_PARAMS.CLUSTERING_LOGLEVEL),c=/\[\d+][^\[]+\[(\w+)]/g,l,u=0,f;for(;l=c.exec(i);){if(l.index&&Eo.LOG_LEVEL_HIERARCHY[o]>=Eo.LOG_LEVEL_HIERARCHY[f||"info"]){let _=f===Eo.LOG_LEVELS.ERR||f===Eo.LOG_LEVELS.WRN?al.OUTPUTS.STDERR:al.OUTPUTS.STDOUT;al.logCustomLevel(f||"info",_,n,i.slice(u,l.index).trim())}let[d,h]=l;u=l.index+d.length,f=Eo.LOG_LEVELS[h]}if(Eo.LOG_LEVEL_HIERARCHY[o]>=Eo.LOG_LEVEL_HIERARCHY[f||"info"]){let d=f===Eo.LOG_LEVELS.ERR||f===Eo.LOG_LEVELS.WRN?al.OUTPUTS.STDERR:al.OUTPUTS.STDOUT;al.logCustomLevel(f||"info",d,n,i.slice(u).trim())}}if(a(s,"extractMessages"),r.stdout.on("data",s),r.stderr.on("data",s),r.unref(),!Xr&&(Xr=[],!t)){let i=a(()=>{eq=!0,Xr&&(Xr.map(o=>o.kill()),process.exit(0))},"kill_children");process.on("exit",i),process.on("SIGINT",i),process.on("SIGQUIT",i),process.on("SIGTERM",i)}Xr.push(r)}a(Na,"start");function Hce(e){return new Promise(async(t,r)=>{try{await So()}catch(n){r(n)}Ke.start(e,(n,s)=>{n&&(Ke.disconnect(),r(n)),Ke.disconnect(),t(s)})})}a(Hce,"startWithPM2");function PN(e){if(!rh){for(let t of Xr||[])t.name===e&&(Xr.splice(Xr.indexOf(t),1),t.kill());return}return new Promise(async(t,r)=>{try{await So()}catch(n){r(n)}Ke.stop(e,async(n,s)=>{n&&(Ke.disconnect(),r(n)),Ke.delete(e,(i,o)=>{i&&(Ke.disconnect(),r(n)),Ke.disconnect(),t(o)})})})}a(PN,"stop");function tq(e){return new Promise(async(t,r)=>{try{await So()}catch(n){r(n)}Ke.reload(e,(n,s)=>{n&&(Ke.disconnect(),r(n)),Ke.disconnect(),t(s)})})}a(tq,"reload");function rq(e){if(!rh){nq();for(let t of Xr||[])t.name===e&&t.kill()}return new Promise(async(t,r)=>{try{await So()}catch(n){r(n)}Ke.restart(e,(n,s)=>{Ke.disconnect(),t(s)})})}a(rq,"restart");function nq(){for(let e of Xr||[])e.config&&(e.config.restarts=0)}a(nq,"expectedRestartOfChildren");function kce(e){return new Promise(async(t,r)=>{try{await So()}catch(n){r(n)}Ke.delete(e,(n,s)=>{n&&(Ke.disconnect(),r(n)),Ke.disconnect(),t(s)})})}a(kce,"deleteProcess");async function sq(){await Na(Oa.generateRestart())}a(sq,"restartHdb");async function Fce(){let e=await DN();for(let t in e)if(e[t].name===et.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}a(Fce,"isHdbRestartRunning");function DN(){return new Promise(async(e,t)=>{try{await So()}catch(r){t(r)}Ke.list((r,n)=>{r&&(Ke.disconnect(),t(r)),Ke.disconnect(),e(n)})})}a(DN,"list");function iq(e){return new Promise(async(t,r)=>{try{await So()}catch(n){r(n)}Ke.describe(e,(n,s)=>{n&&(Ke.disconnect(),r(n)),Ke.disconnect(),t(s)})})}a(iq,"describe");function Gce(){if(!rh){for(let e of Xr||[])e.kill();Xr=[];return}return new Promise(async(e,t)=>{try{await So()}catch(r){t(r)}Ke.killDaemon((r,n)=>{r&&(Ke.disconnect(),t(r)),Ke.disconnect(),e(n)})})}a(Gce,"kill");async function qce(){try{await uq(),await dq(),await Na(Oa.generateAllServiceConfigs())}catch(e){throw Ke?.disconnect(),e}}a(qce,"startAllServices");async function LN(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case et.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=Oa.generateMainServerConfig();break;case et.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=Oa.generateNatsIngestServiceConfig();break;case et.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=Oa.generateNatsReplyServiceConfig();break;case et.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=Oa.generateNatsHubServerConfig(),await Na(r,t),await go.removeNatsConfig(e);return;case et.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=Oa.generateNatsLeafServerConfig(),await Na(r,t),await go.removeNatsConfig(e);return;case et.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=Oa.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await Na(r)}catch(r){throw Ke?.disconnect(),r}}a(LN,"startService");async function oq(){try{let e=await DN(),t={};for(let r=0,n=e.length;r<n;r++){let s=e[r];t[s.name]===void 0&&(t[s.name]={name:s.name,exec_mode:s.pm2_env.exec_mode})}return t}catch(e){throw Ke?.disconnect(),e}}a(oq,"getUniqueServicesList");async function $ce(e=[]){try{let t=!1,r=await oq();for(let n=0,s=Object.values(r).length;n<s;n++){let o=Object.values(r)[n].name;e.includes(o)||(o===et.PROCESS_DESCRIPTORS.HDB?t=!0:await rq(o))}t&&await cq(et.PROCESS_DESCRIPTORS.HDB)}catch(t){throw Ke?.disconnect(),t}}a($ce,"restartAllServices");async function aq(e){if(Xr?.find(r=>r.name===e))return!0;let t=await Lce.getHDBProcessInfo();return t.core.length&&t.core[0]?.parent==="PM2"}a(aq,"isServiceRegistered");async function cq(e){let t=Lg.get(et.CONFIG_PARAMS.THREADS_COUNT)??Lg.get(et.CONFIG_PARAMS.THREADS),r=await iq(e),n=Cce.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await PN(e),await LN(e)):e===et.PROCESS_DESCRIPTORS.HDB?await sq():await tq(e)}a(cq,"reloadStopStart");var lq;async function uq(e=!1){for(let t in et.CLUSTERING_PROCESSES){let r=et.CLUSTERING_PROCESSES[t];await LN(r,e)}}a(uq,"startClusteringProcesses");async function dq(){lq=ZG(et.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,{name:et.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE});try{await Dg.deleteLocalStream("__HARPERDB_WORK_QUEUE__")}catch{}await Dg.updateLocalStreams();let e=await Pce.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===et.PRE_4_0_0_VERSION){al.info("Starting clustering upgrade 4.0.0 process"),ZG(et.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}a(dq,"startClusteringThreads");async function Vce(){for(let e in et.CLUSTERING_PROCESSES)if(e!==et.CLUSTERING_PROCESSES.CLUSTERING_INGEST_PROC_DESCRIPTOR)if(e===et.CLUSTERING_PROCESSES.CLUSTERING_REPLY_SERVICE_DESCRIPTOR)await lq.terminate();else{let t=et.CLUSTERING_PROCESSES[e];await PN(t)}}a(Vce,"stopClustering");async function Kce(){for(let e in et.CLUSTERING_PROCESSES){let t=et.CLUSTERING_PROCESSES[e];if(await aq(t)===!1)return!1}return!0}a(Kce,"isClusteringRunning");async function Yce(){await go.generateNatsConfig(!0),await Dg.reloadNATSHub(),await Dg.reloadNATSLeaf(),await go.removeNatsConfig(et.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await go.removeNatsConfig(et.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}a(Yce,"reloadClustering")});var UN={};Ue(UN,{compactOnStart:()=>Wce,copyDb:()=>gq});async function Wce(){wa.notify("Running compact on start"),console.log("Running compact on start");let e=(0,MN.get)(x.ROOTPATH),t=new Map,r=Xe();(0,vN.updateConfigValue)(x.STORAGE_COMPACTONSTART,!1);try{for(let n in r){if(n==="system"||n.endsWith("-copy"))continue;let s;for(let l in r[n]){s=r[n][l].primaryStore.path;break}if(!s){console.log("Couldn't find any tables in database",n);continue}let i=(0,Mg.join)(e,"backup",n+".mdb"),o=(0,Mg.join)(e,nc,n+"-copy.mdb"),c=0;try{c=await _q(n),console.log("Database",n,"before compact has a total record count of",c)}catch(l){wa.error("Error getting record count for database",n,l),console.error("Error getting record count for database",n,l)}t.set(n,{db_path:s,copy_dest:o,backup_dest:i,record_count:c}),await gq(n,o),console.log("Backing up",n,"to",i),await(0,cl.move)(s,i,{overwrite:!0})}try{rd()}catch(n){wa.error("Error resetting databases after backup",n),console.error("Error resetting databases after backup",n)}for(let[n,{db_path:s,copy_dest:i}]of t)console.log("Moving copy compacted",n,"to",s),await(0,cl.move)(i,s,{overwrite:!0}),await(0,cl.remove)((0,Mg.join)(e,nc,`${n}-copy.mdb-lock`));try{rd()}catch(n){wa.error("Error resetting databases after backup",n),console.error("Error resetting databases after backup",n),process.exit(0)}}catch(n){wa.error("Error compacting database, rolling back operation",n),console.error("Error compacting database, rolling back operation",n),(0,vN.updateConfigValue)(x.STORAGE_COMPACTONSTART,!1);for(let[s,{db_path:i,backup_dest:o}]of t){console.error("Moving backup database",o,"back to",i);try{await(0,cl.move)(o,i,{overwrite:!0})}catch(c){console.error(c)}}throw rd(),n}for(let[n,{backup_dest:s,record_count:i}]of t){let o=!0,c=await _q(n);if(console.log("Database",n,"after compact has a total record count of",c),i!==c){o=!1;let l=`There is a discrepancy between pre and post compact record count for database ${n}.
|
|
25
25
|
Total record count before compaction: ${i}, total after: ${c}.
|