harperdb 4.3.35 → 4.3.37

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.
@@ -6,7 +6,7 @@ Caused by:`));else if(typeof _=="object")try{n+=JSON.stringify(_)}catch{n+="Obje
6
6
  `).slice(1)){s=s.trim();let[i]=s.split(" ",1),o=s.slice(i.length+1).trim();t[i]===void 0&&(t[i]={}),t[i][r]=o}}))}catch(r){throw r}return Object.entries(t).filter(([,r])=>r.comm&&r.args&&r.ppid&&r.uid&&r["%cpu"]&&r["%mem"]&&r.args.includes(e)).map(([r,n])=>({pid:Number.parseInt(r,10),name:Ik.basename(n.comm),cmd:n.args,ppid:Number.parseInt(n.ppid,10),uid:Number.parseInt(n.uid,10),cpu:Number.parseFloat(n["%cpu"]),memory:Number.parseFloat(n["%mem"])}))}a(Lk,"findPs")});var dt=g((Hoe,CO)=>{"use strict";var Mk="__dbis__",Pk="__txns__",Uk="__environment_name__",vk="__dbi_defintion__",Bk={EQUALS:"equals",STARTS_WITH:"startsWith",_STARTS_WITH:"starts_with",ENDS_WITH:"endsWith",_ENDS_WITH:"ends_with",CONTAINS:"contains",SEARCH_ALL:"searchAll",SEARCH_ALL_TO_MAP:"searchAllToMap",BATCH_SEARCH_BY_HASH:"batchSearchByHash",BATCH_SEARCH_BY_HASH_TO_MAP:"batchSearchByHashToMap",GREATER_THAN:"greaterThan",_GREATER_THAN:"greater_than",GREATER_THAN_EQUAL:"greaterThanEqual",_GREATER_THAN_EQUAL:"greater_than_equal",LESS_THAN:"lessThan",_LESS_THAN:"less_than",LESS_THAN_EQUAL:"lessThanEqual",_LESS_THAN_EQUAL:"less_than_equal",BETWEEN:"between"},Hk=["__createdtime__","__updatedtime__"],xk="\uFFFF",wO={TIMESTAMP:"timestamp",HASH_VALUE:"hash_value",USER_NAME:"user_name"},Gk=Object.values(wO);CO.exports={AUDIT_STORE_NAME:Pk,INTERNAL_DBIS_NAME:Mk,DBI_DEFINITION_NAME:vk,SEARCH_TYPES:Bk,TIMESTAMP_NAMES:Hk,MAX_SEARCH_KEY_LENGTH:256,ENVIRONMENT_NAME_KEY:Uk,TRANSACTIONS_DBI_NAMES_ENUM:wO,TRANSACTIONS_DBIS:Gk,OVERFLOW_MARKER:xk}});var vr=g((xoe,xO)=>{"use strict";var DO=P(),LO=dt(),MO={CONTINUE:100,OK:200,CREATED:201,BAD_REQUEST:400,UNAUTHORIZED:401,FORBIDDEN:403,NOT_FOUND:404,METHOD_NOT_ALLOWED:405,REQUEST_TIMEOUT:408,CONFLICT:409,TOO_MANY_REQUESTS:429,INTERNAL_SERVER_ERROR:500,NOT_IMPLEMENTED:501,BAD_GATEWAY:502,SERVICE_UNAVAILABLE:503,GATEWAY_TIMEOUT:504,HTTP_VERSION_NOT_SUPPORTED:505,INSUFFICIENT_STORAGE:507,NETWORK_AUTHENTICATION_REQUIRED:511},PO=a(e=>`${e} Check logs and try again.`,"CHECK_LOGS_WRAPPER"),UO={500:PO("There was an error processing your request."),400:"Invalid request"},Fk=UO[MO.INTERNAL_SERVER_ERROR],qk={OP_NOT_SUPPORTED_FOR_FS:e=>`${e} is not available for this instance because it uses the File System data store.`,MISSING_VALUE:e=>`${e} is missing.`,INVALID_VALUE:e=>`${e} is invalid.`,NOT_FOUND:e=>`${e} not found.`},kk={CONFIG_VALIDATION:e=>`HarperDB config file validation error: ${e}`},Vk={DEFAULT_BULK_LOAD_ERR:"There was an error during your bulk load into HarperDB.",DOWNLOAD_FILE_ERR:e=>`There was an error downloading '${e}'.`,INSERT_JSON_ERR:"There was an error inserting the downloaded JSON data.",INSERT_CSV_ERR:"There was an error inserting the downloaded CSV data.",INVALID_ACTION_PARAM_ERR:e=>`Bulk load operation failed - ${e} is not a valid 'action' parameter`,INVALID_FILE_EXT_ERR:e=>`Error selecting correct parser - valid file type not found in json - ${e}`,MAX_FILE_SIZE_ERR:(e,t)=>`File size is ${e} bytes, which exceeded the maximum size allowed of: ${t} bytes`,PAPA_PARSE_ERR:"There was an error parsing the downloaded CSV data.",S3_DOWNLOAD_ERR:e=>`There was an error downloading '${e}' from AWS.`,WRITE_TEMP_FILE_ERR:"Error writing temporary file to storage"},$k={BASE_PATH_REQUIRED:"base_path is required",DESTINATION_PATH_REQUIRED:"destination_path is required",ENV_NAME_REQUIRED:"env_name is required",INVALID_BASE_PATH:"invalid base_path",INVALID_DESTINATION_PATH:"invalid destination_path",INVALID_ENVIRONMENT:"invalid environment",ENV_REQUIRED:"env is required",DBI_NAME_REQUIRED:"dbi_name is required",DBI_DOES_NOT_EXIST:"dbi does not exist",HASH_ATTRIBUTE_REQUIRED:"hash_attribute is required",ID_REQUIRED:"id is required",IDS_REQUIRED:"ids is required",IDS_MUST_BE_ITERABLE:"ids must be iterable",FETCH_ATTRIBUTES_REQUIRED:"fetch_attributes is required",FETCH_ATTRIBUTES_MUST_BE_ARRAY:"fetch_attributes must be an array",ATTRIBUTE_REQUIRED:"attribute is required",SEARCH_VALUE_REQUIRED:"search_value is required",SEARCH_VALUE_TOO_LARGE:"search_value is too long",WRITE_ATTRIBUTES_REQUIRED:"write_attributes is required",WRITE_ATTRIBUTES_MUST_BE_ARRAY:"write_attributes must be an array",RECORDS_REQUIRED:"records is required",RECORDS_MUST_BE_ARRAY:"records must be an array",CANNOT_CREATE_INTERNAL_DBIS_NAME:`cannot create a dbi named ${LO.INTERNAL_DBIS_NAME}`,CANNOT_DROP_INTERNAL_DBIS_NAME:`cannot drop a dbi named ${LO.INTERNAL_DBIS_NAME}`,START_VALUE_REQUIRED:"start_value is required",END_VALUE_REQUIRED:"end_value is required",CANNOT_COMPARE_STRING_TO_NUMERIC_KEYS:"cannot compare a string to numeric keys",END_VALUE_MUST_BE_GREATER_THAN_START_VALUE:"end_value must be greater than or equal to start_value",UNKNOWN_SEARCH_TYPE:"unknown search type",CANNOT_DROP_TABLE_HASH_ATTRIBUTE:"cannot drop a table's hash attribute"},Yk={ATTR_NAME_LENGTH_ERR:e=>`transaction aborted due to attribute name ${e} being too long. Attribute names cannot be longer than ${DO.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE} bytes.`,ATTR_NAME_NULLISH_ERR:"transaction aborted due to record(s) with an attribute name that is null, undefined or empty string",HASH_VAL_LENGTH_ERR:`transaction aborted due to record(s) with a hash value that exceeds ${DO.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE} bytes, check log for more info`,INVALID_FORWARD_SLASH_IN_HASH_ERR:"transaction aborted due to record(s) with a hash value that contains a forward slash, check log for more info",RECORD_MISSING_HASH_ERR:"transaction aborted due to record(s) with no hash value, check log for more info"},vO={GENERIC_AUTH_FAIL:"Login failed",USER_INACTIVE:"Cannot complete request: User is inactive",INVALID_TOKEN:"invalid token",NO_ENCRYPTION_KEYS:"unable to generate JWT as there are no encryption keys. please contact your administrator",INVALID_CREDENTIALS:"invalid credentials",PASSWORD_REQUIRED:"password is required",USERNAME_REQUIRED:"username is required",REFRESH_TOKEN_REQUIRED:"refresh_token is required",INVALID_AUTH_OBJECT:"invalid auth_object",INVALID_BODY:"invalid body",TOKEN_EXPIRED:"token expired",REFRESH_TOKEN_SAVE_FAILED:"unable to store refresh_token"},Kk={DEFAULT_INVALID_REQUEST:"Invalid request",OP_AUTH_PERMS_ERROR:"This operation is not authorized due to role restrictions and/or invalid database items",OP_IS_SU_ONLY:e=>`Operation '${e}' is restricted to 'super_user' roles`,OP_NOT_FOUND:e=>`Operation '${e}' not found`,SYSTEM_TIMESTAMP_PERMS_ERR:"Internal timestamp attributes - '__createdtime_' and '__updatedtime__' - cannot be inserted to or updated by HDB users.",UNKNOWN_OP_AUTH_ERROR:(e,t,r)=>`There was an error authorizing ${e} op on table '${t}.${r}'`,USER_HAS_NO_PERMS:e=>`User ${e} has no role or permissions. Please assign the user a valid role.`,DROP_SYSTEM:"The 'system' database, tables and records are used internally by HarperDB and cannot be updated or removed."},Wk={ATTR_PERM_MISSING:(e,t)=>`${e.toUpperCase()} attribute permission missing for '${t}'`,ATTR_PERM_MISSING_NAME:"Permission object in 'attribute_permission' missing an 'attribute_name'",ATTR_PERM_NOT_BOOLEAN:(e,t)=>`${e.toUpperCase()} attribute permission for '${t}' must be a boolean`,ATTR_PERMS_ARRAY_MISSING:"Missing 'attribute_permissions' array",ATTR_PERMS_NOT_ARRAY:"Value for 'attribute_permissions' must be an array",INVALID_ATTRIBUTE_IN_PERMS:e=>`Invalid attribute '${e}' in 'attribute_permissions'`,INVALID_PERM_KEY:e=>`Invalid table permission key value '${e}'`,INVALID_ATTR_PERM_KEY:e=>`Invalid attribute permission key value '${e}'`,INVALID_ROLE_JSON_KEYS:e=>`Invalid ${e.length>1?"keys":"key"} in JSON body - '${e.join("', '")}'`,MISMATCHED_TABLE_ATTR_PERMS:e=>`You have a conflict with TABLE permissions for '${e}' being false and ATTRIBUTE permissions being true`,OUTDATED_PERMS_TRANSLATION_ERROR:"This instance was recently upgraded and uses our new role permissions structure. Please login to this instance in HarperDB Studio, go to 'Roles', and click 'Update Role Permission' for all standard roles to migrate them to the new structure.",ROLE_ALREADY_EXISTS:e=>`A role with name '${e}' already exists`,ROLE_NOT_FOUND:"Role not found",ROLE_PERMS_ERROR:"Errors in the role permissions JSON provided",SCHEMA_PERM_ERROR:e=>`Your role does not have permission to view database metadata for '${e}'`,SCHEMA_TABLE_PERM_ERROR:(e,t)=>`Your role does not have permission to view database.table metadata for '${e}.${t}'`,SU_ROLE_MISSING_ERROR:"Missing 'super_user' key/value in permission set",SU_CU_ROLE_BOOLEAN_ERROR:e=>`Value for '${e}' permission must be a boolean`,STRUCTURE_USER_ROLE_TYPE_ERROR:e=>`Value for '${e}' permission must be a boolean or Array`,SU_CU_ROLE_NO_PERMS_ALLOWED:e=>`Roles with '${e}' set to true cannot have other permissions set.`,SU_CU_ROLE_COMBINED_ERROR:"Roles cannot have both 'super_user' and 'cluster_user' values included in their permissions set.",TABLE_PERM_MISSING:e=>`Missing table ${e.toUpperCase()} permission`,TABLE_PERM_NOT_BOOLEAN:e=>`Table ${e.toUpperCase()} permission must be a boolean`},Qk={ATTR_NOT_FOUND:(e,t,r)=>`Attribute '${r}' does not exist on '${e}.${t}'`,ATTR_EXISTS_ERR:(e,t,r)=>`Attribute '${r}' already exists in ${e}.${t}'`,DESCRIBE_ALL_ERR:"There was an error during describeAll. Please check the logs and try again.",INVALID_TABLE_ERR:e=>`Invalid table ${JSON.stringify(e)}`,SCHEMA_NOT_FOUND:e=>`database '${e}' does not exist`,SCHEMA_EXISTS_ERR:e=>`database '${e}' already exists`,TABLE_EXISTS_ERR:(e,t)=>`Table '${t}' already exists in '${e}'`,SCHEMA_REQUIRED_ERR:"database is required",TABLE_NOT_FOUND:(e,t)=>`Table '${e}.${t}' does not exist`,TABLE_REQUIRED_ERR:"table is required"},zk={OUTER_JOIN_TRANSLATION_ERROR:"There was an error translating the final SQL outer join data."},Jk={ALTER_USER_DUP_ROLES:e=>`Update failed. There are duplicates for the '${e}' role which is not allowed. Update your roles and try again.`,ALTER_USER_ROLE_NOT_FOUND:e=>`Update failed. Requested '${e}' role not found.`,DUP_ROLES_FOUND:e=>`Multiple ${e} roles found. Roles must have unique 'role' value. Please update and try again.`,ROLE_NAME_NOT_FOUND:e=>`${e} role not found`,USER_ALREADY_EXISTS:e=>`User ${e} already exists`,USER_NOT_EXIST:e=>`User ${e} does not exist`},BO={INVALID_DATE:"Invalid date, must be in ISO-8601 format (YYYY-MM-DD).",SEARCH_CONDITIONS_INVALID_SORT_ATTRIBUTE:e=>`invalid sort attribute '${e}', the attribute must either be the table's hash attribute or an attribute used in conditions.`},HO={INVALID_ITC_DATA_TYPE:"Invalid ITC event data type, must be an object",MISSING_TYPE:"ITC event missing 'type'",MISSING_MSG:"ITC event missing 'message'",MISSING_ORIGIN:"ITC event message missing 'originator' property",INVALID_EVENT:e=>`ITC server received invalid event type: ${e}`},Xk={FUNCTION_STATUS:"Error getting custom function status, check the log for more details",GET_FUNCTIONS:"Error getting custom functions, check the log for more details",GET_FUNCTION:"Error getting custom function, check the log for more details",SET_FUNCTION:"Error setting custom function, check the log for more details",NO_PROJECT:"Project does not exist. Create one using 'add_custom_function_project'",PROJECT_EXISTS:"Project already exists",VALIDATION_ERR:"Error validating request, check the log for more details",NO_FILE:"File does not exist",BAD_FILE_NAME:"File name can only contain alphanumeric, dash and underscore characters",BAD_PROJECT_NAME:"Project name can only contain alphanumeric, dash and underscores characters",BAD_PACKAGE:"Packaged project must be base64-encoded tar file of project directory",DROP_FUNCTION:"Error dropping custom function, check the log for more details",ADD_FUNCTION:"Error adding custom function project, check the log for more details",DROP_FUNCTION_PROJECT:"Error dropping custom function project, check the log for more details",BAD_FILE_PATH:"Filepath must be valid, and contain the name of the tarball you wish to write",NOT_ENABLED:"Custom functions is not enabled, to enable set fastifyRoutes enabled to true in hdb/harperdb-config.yaml file."},jk={CLUSTERING_NOT_ENABLED:"Clustering must be enabled to perform this operation."},Zk={...vO,...Vk,...qk,...Kk,...Wk,...Qk,...zk,...Jk,...Yk,...BO,...HO,...Xk,...jk,...kk};xO.exports={CHECK_LOGS_WRAPPER:PO,HDB_ERROR_MSGS:Zk,DEFAULT_ERROR_MSGS:UO,DEFAULT_ERROR_RESP:Fk,HTTP_STATUS_CODES:MO,LMDB_ERRORS_ENUM:$k,AUTHENTICATION_ERROR_MSGS:vO,VALIDATION_ERROR_MSGS:BO,ITC_ERRORS:HO}});var se=g((Foe,qO)=>{"use strict";var qo=vr(),eV=K(),tV=P(),c_=class extends Error{static{a(this,"HdbError")}constructor(t,r,n,s,i){super(),Error.captureStackTrace(this,GO),this.statusCode=n||qo.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR,this.http_resp_msg=r||(qo.DEFAULT_ERROR_MSGS[n]?qo.DEFAULT_ERROR_MSGS[n]:qo.DEFAULT_ERROR_MSGS[qo.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR]),this.message=t.message?t.message:this.http_resp_msg,this.type=t.name,s&&(this.logLevel=s),typeof this.message!="string"&&(this.stack=t.stack),i&&eV[s](i)}},Hh=class extends Error{static{a(this,"ClientError")}constructor(t,r){if(t instanceof Error)return t.statusCode=r||400,t;super(t),this.statusCode=r||400}},xh=class extends Error{static{a(this,"ServerError")}constructor(t,r){super(t),this.statusCode=r||500}};function GO(e,t,r,n=tV.LOG_LEVELS.ERROR,s=null,i=!1){if(FO(e))return e;let o=new c_(e,t,r,n,s);return i&&delete o.stack,o}a(GO,"handleHDBError");function FO(e){return e.__proto__.constructor.name===c_.name}a(FO,"isHDBError");qO.exports={isHDBError:FO,handleHDBError:GO,ClientError:Hh,ServerError:xh,hdb_errors:qo}});var ze=g((koe,QO)=>{"use strict";var Rc=P(),rV=J(),dr=ne(),Ac=require("path"),nV=require("minimist"),kO=require("fs-extra"),VO=require("lodash");dr.initSync();var{CONFIG_PARAMS:Zs,DATABASES_PARAM_CONFIG:pc,SYSTEM_SCHEMA_NAME:l_}=Rc,Sc,Tc,gc;function $O(){if(Sc!==void 0)return Sc;if(dr.getHdbBasePath()!==void 0)return Sc=dr.get(Zs.STORAGE_PATH)||Ac.join(dr.getHdbBasePath(),Rc.DATABASES_DIR_NAME),Sc}a($O,"getBaseSchemaPath");function YO(){if(Tc!==void 0)return Tc;if(dr.getHdbBasePath()!==void 0)return Tc=WO(l_),Tc}a(YO,"getSystemSchemaPath");function KO(){if(gc!==void 0)return gc;if(dr.getHdbBasePath()!==void 0)return gc=dr.get(Rc.CONFIG_PARAMS.STORAGE_AUDIT_PATH)||Ac.join(dr.getHdbBasePath(),Rc.TRANSACTIONS_DIR_NAME),gc}a(KO,"getTransactionAuditStoreBasePath");function sV(e,t){let r=dr.get(Zs.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||Ac.join(KO(),e.toString())}a(sV,"getTransactionAuditStorePath");function WO(e,t){e=e.toString(),t=t&&t.toString();let r=dr.get(Rc.CONFIG_PARAMS.DATABASES)?.[e];return t&&r?.tables?.[t]?.path||r?.path||Ac.join($O(),e)}a(WO,"getSchemaPath");function iV(e,t){e=e.toString(),t=t.toString();let r=process.env;Object.assign(r,nV(process.argv));let n=r[Zs.DATABASES.toUpperCase()];if(n){let i;try{i=JSON.parse(n)}catch(o){if(!rV.isObject(n))throw o;i=n}for(let o of i){let c=o[l_];if(!c)continue;let l=dr.get(Zs.DATABASES);l=l??{};let _=c?.tables?.[t]?.[pc.PATH];if(_)return VO.set(l,[l_,pc.TABLES,t,pc.PATH],_),dr.setProperty(Zs.DATABASES,l),_;let u=c?.[pc.PATH];if(u)return VO.set(l,[l_,pc.PATH],u),dr.setProperty(Zs.DATABASES,l),u}}let s=r[Zs.STORAGE_PATH.toUpperCase()];if(s){if(!kO.pathExistsSync(s))throw new Error(s+" does not exist");let i=Ac.join(s,e);return kO.mkdirsSync(i),dr.setProperty(Zs.STORAGE_PATH,s),i}return YO()}a(iV,"initSystemSchemaPaths");function oV(){Sc=void 0,Tc=void 0,gc=void 0}a(oV,"resetPaths");QO.exports={getBaseSchemaPath:$O,getSystemSchemaPath:YO,getTransactionAuditStorePath:sV,getTransactionAuditStoreBasePath:KO,getSchemaPath:WO,initSystemSchemaPaths:iV,resetPaths:oV}});var Br=g((Koe,ZO)=>{"use strict";var aV=vr().LMDB_ERRORS_ENUM,$oe=require("lmdb"),cV=dt(),Yoe=require("buffer").Buffer,{OVERFLOW_MARKER:zO,MAX_SEARCH_KEY_LENGTH:u_}=cV,JO=["number","string","symbol","boolean","bigint"];function lV(e){if(e=e?.primaryStore||e,!e)throw new Error(aV.ENV_REQUIRED)}a(lV,"validateEnv");function uV(e){if(e==null)return null;let t;try{t=typeof e=="object"?JSON.stringify(e):e.toString()}catch{t=e.toString()}return t}a(uV,"stringifyData");function _V(e){return e instanceof Date?e.valueOf():e}a(_V,"convertKeyValueToWrite");function dV(e,t){if(e===null)return t?[null]:void 0;if(e===void 0)return;if(JO.includes(typeof e))return e.length>u_?[e.slice(0,u_)+zO]:[e];let r;if(Array.isArray(e)){r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n];if(JO.includes(typeof i))i.length>u_?r.push(i.slice(0,u_)+zO):r.push(i);else{if(i===null&&t)return r.push(null);if(i instanceof Date)return r.push(i.getTime())}}}else if(e instanceof Date)return[e.getTime()];return r}a(dV,"getIndexedValues");var __=0,XO=0;function jO(){XO=Date.now()-performance.now()}a(jO,"adjustStartTime");jO();var fV=6e4;setInterval(jO,fV).unref();function EV(){let e=performance.now()+XO;return e>__?(__=e,e):(__+=488e-6,__)}a(EV,"getNextMonotonicTime");ZO.exports={validateEnv:lV,stringifyData:uV,convertKeyValueToWrite:_V,getNextMonotonicTime:EV,getIndexedValues:dV}});var Oc=g((Qoe,eb)=>{"use strict";var hV=P().OPERATIONS_ENUM,Gh=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i=void 0){this.operation=hV.INSERT,this.schema=t,this.table=r,this.hash_attribute=n,this.records=s,this.__origin=i}};eb.exports=Gh});var bc=g((Xoe,sb)=>{"use strict";var Joe=Oc(),d_=P(),Fh=J(),tb=K(),mV=require("uuid"),{handleHDBError:f_,hdb_errors:pV}=se(),{HDB_ERROR_MSGS:E_,HTTP_STATUS_CODES:h_}=pV;sb.exports=rb;function rb(e,t,r){for(let s=0;s<t.length;s++)nb(t[s]);let{records:n}=e;for(let s=0;s<n.length;s++){let i=n[s];SV(i,r,e.operation)}}a(rb,"processRows");rb.validateAttribute=nb;function nb(e){if(Buffer.byteLength(String(e))>d_.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw f_(new Error,E_.ATTR_NAME_LENGTH_ERR(e),h_.BAD_REQUEST,void 0,void 0,!0);if(Fh.isEmptyOrZeroLength(e)||Fh.isEmpty(e.trim()))throw f_(new Error,E_.ATTR_NAME_NULLISH_ERR,h_.BAD_REQUEST,void 0,void 0,!0)}a(nb,"validateAttribute");function SV(e,t,r){if(!e.hasOwnProperty(t)||Fh.isEmptyOrZeroLength(e[t])){if(r===d_.OPERATIONS_ENUM.INSERT||r===d_.OPERATIONS_ENUM.UPSERT){e[t]=mV.v4();return}throw tb.error("Update transaction aborted due to record with no hash value:",e),f_(new Error,E_.RECORD_MISSING_HASH_ERR,h_.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>d_.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw tb.error(e),f_(new Error,E_.HASH_VAL_LENGTH_ERR,h_.BAD_REQUEST,void 0,void 0,!0)}a(SV,"validateHash")});var ib,Nn,qh,yc=Re(()=>{ib=require("events"),Nn=class extends ib.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;drainCloseListener;currentDrainResolver;[Symbol.asyncIterator](){let t=new qh;return t.queue=this,t}push(t){this.send(t)}send(t){this.resolveNext?(this.resolveNext({value:t}),this.resolveNext=null):this.hasDataListeners?this.emit("data",t):(this.queue||(this.queue=[]),this.queue.push(t))}getNextMessage(){let t=this.queue?.shift();return t||this.emit("drained"),t}waitForDrain(){return new Promise(t=>{!this.queue||this.queue.length===0?t(!0):(this.once("drained",()=>t(!0)),this.currentDrainResolver=t,this.drainCloseListener||(this.drainCloseListener=!0,this.on("close",()=>{this.currentDrainResolver?.(!1)})))})}on(t,r){if(t==="data"&&!this.hasDataListeners)for(this.hasDataListeners=!0;this.queue?.length>0;)r(this.queue.shift());return super.on(t,r)}},qh=class{static{a(this,"EventQueueIterator")}queue;push(t){this.queue.send(t)}next(){let t=this.queue.getNextMessage();return t?{value:t}:new Promise(r=>this.queue.resolveNext=r)}return(t){return this.queue.emit("close"),{value:t,done:!0}}throw(t){return this.queue.emit("close",t),{done:!0}}}});var Bi={};qe(Bi,{server:()=>st});var ob,st,fr=Re(()=>{ob=require("../index"),st={};(0,ob._assignPackageExport)("server",st)});var $h={};qe($h,{loadGQLSchema:()=>RV,start:()=>Vh,startOnMainThread:()=>gV});function Vh({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r,n,s,i){let{parse:o,Source:c,Kind:l,NamedTypeNode:_,StringValueNode:u}=await import("graphql"),d=o(new c(r.toString(),s)),E=new Map,f=[],h;for(let S of d.definitions)switch(S.kind){case l.OBJECT_TYPE_DEFINITION:let B=function(U){if(U.kind==="NonNullType"){let Q=B(U.type);return Q.nullable=!1,Q}if(U.kind==="ListType")return{type:"array",elements:B(U.type)};let M={type:U.name?.value};return Object.defineProperty(M,"location",{value:U.loc.startToken}),M};a(B,"getProperty");let T=S.name.value,A=[],b={table:null,database:null,properties:A};E.set(T,b);for(let U of S.directives){if(U.name.value==="table"){for(let q of U.arguments)b[q.name.value]=q.value.value;b.schema&&(b.database=b.schema),b.table||(b.table=T),b.audit&&(b.audit=b.audit!=="false"),b.attributes=b.properties,f.push(b)}if(U.name.value==="sealed"&&(b.sealed=!0),U.name.value==="export"){b.export=!0;for(let q of U.arguments)q.name.value==="name"&&(b.export={name:q.value.value})}}let I=!1;for(let U of S.fields){let q=B(U.type);q.name=U.name.value,A.push(q);for(let M of U.directives)if(M.name.value==="primaryKey")I?console.warn("Can not define two attributes as a primary key"):(q.isPrimaryKey=!0,I=!0);else if(M.name.value==="indexed")q.indexed=!0;else if(M.name.value==="relationship"){let Q={};for(let z of M.arguments)Q[z.name.value]=z.value.value;q.relationship=Q}else if(M.name.value==="createdTime")q.assignCreatedTime=!0;else if(M.name.value==="updatedTime")q.assignUpdatedTime=!0;else if(M.name.value==="expiresAt")q.expiresAt=!0;else if(M.name.value==="allow"){let Q=q.authorizedRoles=[];for(let z of M.arguments)z.name.value==="role"&&Q.push(z.value.value)}}b.type=T,T==="Query"&&(h=b)}function p(S){let T=E.get(S.type);T?(Object.defineProperty(S,"properties",{value:T.properties}),Object.defineProperty(S,"definition",{value:T})):S.type==="array"?p(S.elements):TV.includes(S.type)||(0,ab.getWorkerIndex)()===0&&console.error(`The type ${S.type} is unknown at line ${S.location.line}, column ${S.location.column}, in ${s}`)}a(p,"connectPropertyType");for(let S of E.values())for(let T of S.properties)p(T);for(let S of f)S.tableClass=e(S),S.export&&(S.export.name===""?i.set((0,kh.dirname)(n),S.tableClass):i.set((0,kh.dirname)(n)+"/"+(S.export.name||S.type),S.tableClass))}}var kh,ab,TV,gV,RV,cb=Re(()=>{kh=require("path");Ae();ab=x(it()),TV=["ID","Int","Float","Long","String","Boolean","Date","Bytes","Any","BigInt"];a(Vh,"start");gV=Vh,RV=Vh({ensureTable:ft}).handleFile});async function m_(e){let t=(0,_b.pathToFileURL)(e).toString();return AV?(Nc||(Nc=OV(yV)),(await(await Nc).import(t)).namespace):import(t)}async function OV(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),Nc=new Compartment({console,Math,Date,fetch:bV,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,ub.extname)(r)||(r+=".js"),r)},importHook:async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){Object.assign(s,{Resource:Yt,tables:Hr,databases:ot})}};let n=await(0,lb.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)}}),Nc}function bV(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 yV(){return{Resource:Yt,tables:Hr}}var lb,ub,_b,AV,Nc,Yh=Re(()=>{an();Ae();lb=require("fs/promises"),ub=require("path"),_b=require("url"),AV=!1;a(m_,"secureImport");a(OV,"getCompartment");a(bV,"secureOnlyFetch");a(yV,"getGlobalVars")});var Wh={};qe(Wh,{handleFile:()=>NV});async function NV(e,t,r,n){let s=new Map,i=await m_(r);c(i.default)&&n.set((0,Kh.dirname)(t),i.default),o(i,(0,Kh.dirname)(t));function o(l,_){for(let u in l){let d=l[u];c(d)?n.set(_+"/"+u,d):typeof d=="object"&&o(d,_+"/"+u)}}a(o,"recurseForResources");function c(l){return typeof l=="function"&&(l.get||l.put||l.post||l.delete)}return a(c,"isResource"),s}var Kh,db=Re(()=>{Yh();Kh=require("path");a(NV,"handleFile")});var zh={};qe(zh,{start:()=>IV});function IV({resources:e}){e.set("login",Qh),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var Qh,fb=Re(()=>{an();a(IV,"start");Qh=class extends Yt{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 gb={};qe(gb,{parse:()=>Xh,streamAsJSON:()=>Ic,stringify:()=>Hi});function Ic(e){return new Jh({value:e})}function Eb(e){return console.error(e),JSON.stringify(e.toString())}function hb(e,t,r){return e?.then?r?e.then(t,r):e.then(t):t(e)}function Hi(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===Sb)return Tb(e);if(t.resolution)return t.resolution.then(()=>Hi(e));throw t}}function Tb(e){let t=typeof e;if(t==="object"){if(e===null)return"null";e.toJSON&&(e=e.toJSON());let r;if(Array.isArray(e)){r="[";for(let n=0;n<e.length;n++)n>0&&(r+=","),r+=Tb(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+Hi(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function Xh(e){return DV.test(e)?wV.parse(e):JSON.parse(e)}var mb,pb,wV,CV,Sb,Jh,DV,jh=Re(()=>{mb=require("stream"),pb=x(require("json-bigint-fixes")),wV=(0,pb.default)({useNativeBigInt:!0}),CV=1e4,Sb={};BigInt.prototype.toJSON=function(){throw Sb};a(Ic,"streamAsJSON");Jh=class extends mb.Readable{static{a(this,"JSONStream")}constructor(t){super(t),this.buffer=[],this.bufferSize=0,this.iterator=this.serialize(t.value,!0),this.activeIterators=[]}*serialize(t){if(t&&typeof t=="object"){let r=t[Symbol.asyncIterator],n=t[Symbol.iterator];if((n||r)&&!t.then){yield"[";let s=!0;if((r||n)&&!(t instanceof Array)){let i=r?t[Symbol.asyncIterator]():t[Symbol.iterator]();this.activeIterators.push(i);let o;for(;;)if(o=i.next(),o.then&&(yield o.then(c=>(o=c,""))),o.done){this.activeIterators.splice(this.activeIterators.indexOf(i),1),yield"]";return}else s?s=!1:yield",",yield*this.serialize(o.value)}for(let i of t)s?s=!1:yield",",yield*this.serialize(i);yield"]";return}if(t.then)try{yield t.then(s=>this.serialize(s),Eb)}catch(s){yield Eb(s)}else yield Hi(t)}else yield Hi(t)}_read(){if(!this._amReading){if(this._amReading=!0,this.done)return this.push(null);hb(this.readIterator(this.iterator),t=>{t?(this.done=!0,this.push(null)):this._amReading=!1},t=>{console.error(t),this.done=!0,this.push(t.toString()),this.push(null)})}}push(t){return t===null||t instanceof Buffer?(this.bufferSize>0&&this.flush(),super.push(t)):(this.bufferSize+=t.length||t.toString().length,this.buffer.push(t),this.bufferSize>CV?this.flush():!0)}flush(){let t=super.push(this.buffer.join(""));return this.buffer=[],this.bufferSize=0,t}readIterator(t){try{let r;if(t.childIterator)return hb(this.readIterator(t.childIterator),n=>{if(n)return t.childIterator=null,this.readIterator(t)});do{let n=t.next();if(n.done)return!0;if(r=n.value,r==null)r="null";else{if(r.then)return this.flush(),Promise.resolve(r).then(s=>{if(s&&typeof s.return=="function")return t.childIterator=s,this.readIterator(t);if(this.push(s+""))return this.readIterator(t)});if(typeof r.return=="function")return t.childIterator=r,this.readIterator(t)}}while(this.push(r))}catch(r){return console.error(r),this.push(r.toString()),this.push(null),!0}}_destroy(t,r){for(let n of this.activeIterators)t?n.throw(t):n.return();r()}};a(Eb,"handleError");a(hb,"when");a(Hi,"stringify");a(Tb,"jsStringify");DV=/[[,:]\s*-?\d{16,}/;a(Xh,"parse")});var Pb=g((fae,Mb)=>{"use strict";var Zh=require("recursive-iterator"),LV=require("alasql"),em=require("clone"),Rb=J(),{handleHDBError:Ab,hdb_errors:MV}=se(),{HDB_ERROR_MSGS:Ob,HTTP_STATUS_CODES:bb}=MV,{getDatabases:PV}=(Ae(),ie(ke)),UV=["DISTINCT_ARRAY"],yb=Symbol("validateTables"),tm=Symbol("validateTable"),dae=Symbol("getAllColumns"),Nb=Symbol("validateAllColumns"),p_=Symbol("findColumn"),Ib=Symbol("validateOrderBy"),wc=Symbol("validateSegment"),rm=Symbol("validateColumn"),wb=Symbol("setColumnsForTable"),Cb=Symbol("checkColumnsForAsterisk"),Db=Symbol("validateGroupBy"),Lb=Symbol("hasColumns"),nm=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[yb](),this[Cb](),this[Nb]()}[yb](){if(this[Lb]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[tm](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[tm](t.table)})}}[Lb](){let t=!1,r=new Zh(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[tm](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=PV();if(!r[t.databaseid])throw Ab(new Error,Ob.SCHEMA_NOT_FOUND(t.databaseid),bb.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw Ab(new Error,Ob.TABLE_NOT_FOUND(t.databaseid,t.tableid),bb.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=em(s);i.table=em(t),this.attributes.push(i)})}[p_](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)}[Cb](){let t=new Zh(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[wb](r.tableid)}[wb](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new LV.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[Nb](){this[wc](this.statement.columns,!1),this[wc](this.statement.joins,!1),this[wc](this.statement.where,!1),this[Db](this.statement.group,!1),this[wc](this.statement.order,!0)}[wc](t,r){if(!t)return;let n=new Zh(t),s=[];for(let{node:i,path:o}of n)!Rb.isEmpty(i)&&!Rb.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[Ib](i):s.push(this[rm](i)));return s}[Db](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&UV.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=em(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[p_](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[p_](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`}[Ib](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[rm](t)}[rm](t){let r=this[p_](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]}};Mb.exports=nm});var vb=g((hae,Ub)=>{"use strict";var sm=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")}};Ub.exports=sm});var Hb=g((pae,Bb)=>{"use strict";var im=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};Bb.exports=im});var qb={};qe(qb,{HAS_EXPIRATION:()=>dm,LAST_TIMESTAMP_PLACEHOLDER:()=>Lc,LOCAL_TIMESTAMP:()=>vV,METADATA:()=>Cc,NO_TIMESTAMP:()=>am,PENDING_LOCAL_TIME:()=>fm,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>_m,RecordEncoder:()=>um,TIMESTAMP_ASSIGN_LAST:()=>HV,TIMESTAMP_ASSIGN_NEW:()=>Gb,TIMESTAMP_ASSIGN_PREVIOUS:()=>Fb,TIMESTAMP_PLACEHOLDER:()=>S_,TIMESTAMP_RECORD_PREVIOUS:()=>cm,getUpdateRecord:()=>Em,handleLocalTimeForGets:()=>A_});function GV(){return Dc[0]=Dc[0]^64,BV.getFloat64(0)}function A_(e){let t=e.getEntry;e.readCount=0,e.cachePuts=!1,e.getEntry=function(i,o){e.readCount++;let c=t.call(this,i,o),l=c?.value,_=l?.[Cc];return _>=0&&(c.metadataFlags=_,c.localTime=l.localTime,c.value=l.value,l.expiresAt>0&&(c.expiresAt=l.expiresAt)),c&&(c.key=i),c};let r=e.get;e.get=function(i,o){let c=r.call(this,i,o);return c?.[Cc]>=0?c.value:c};let n=e.getRange;e.getRange=function(i){let o=n.call(this,i);return i.valuesForKey?o.map(c=>c?.value):i.values===!1||i.onlyCount?o:o.map(c=>{let l=c.value,_=l[Cc];return _>=0&&(c.metadataFlags=_,c.localTime=l.localTime,c.value=l.value,l.expiresAt>0&&(c.expiresAt=l.expiresAt)),c})};let s=e.useReadTransaction();if(s.done(),!s.done.isTracked){let i=s.constructor,o=s.use,c=s.done;i.prototype.use=function(){this.timerTracked||(this.timerTracked=!0,xi.push(new WeakRef(this))),o.call(this)},i.prototype.done=function(){if(c.call(this),this.isDone)for(let l=0;l<xi.length;l++){let _=xi[l].deref();(!_||_.isDone||_.isCommitted)&&xi.splice(l--,1)}},i.prototype.done.isTracked=!0}return e}function Em(e,t,r){return function(n,s,i,o,c=-1,l,_,u,d="put",E,f){if(E||l==null?ko=i?.localTime?cm|Fb:am:ko=l?i?.localTime?cm|16384:Gb|16384:am,u>0&&(c|=dm),g_=c,lm=u,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let h={version:o,instructedWrite:ko>0},p;try{E&&(h.ifVersion=p=i?.version??null);let S=e.put(n,s,h);if(l){let T=_?.user?.username;if(f&&(T_=e.encoder.encode(f)),E&&i?.localTime){let A=i?.localTime,b=r.get(A);if(b){let I=Bt(b).previousLocalTime;return r.put(A,R_(o,t,n,I,T,d,T_),{ifVersion:p}),S}}r.put(Lc,R_(o,t,n,i?.localTime?1:0,T,d,T_),{append:d!=="invalidate",instructedWrite:!0,ifVersion:p})}return S}catch(S){throw S.message+=" id: "+n+" options: "+h,S}}}var xb,om,S_,Lc,_m,vV,Cc,Dc,BV,am,Gb,HV,Fb,cm,dm,fm,xV,T_,ko,g_,lm,um,xi,Mc=Re(()=>{xb=require("msgpackr");ei();om=x(K()),S_=new Uint8Array([1,1,1,1,4,64,0,0]),Lc=new Uint8Array([1,1,1,1,1,0,0,0]),_m=new Uint8Array([1,1,1,1,3,64,0,0]),vV=Symbol("local-timestamp"),Cc=Symbol("metadata"),Dc=new Uint8Array(8),BV=new DataView(Dc.buffer,0,8),am=0,Gb=0,HV=1,Fb=3,cm=4,dm=16,fm=1,ko=0,g_=-1,lm=0,um=class extends xb.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(n,s){if(ko||g_>=0){let i=0,o=ko;o&&(i+=8,ko=0);let c=g_,l=lm;c>=0&&(i+=2,g_=-1,l&&(i+=8,lm=0));let _=xV=r.call(this,n,s|2048|i);T_=_.subarray((_.start||0)+i,_.end);let u=_.start||0;return o&&(S_[4]=o,S_[5]=o>>8,_.set(S_,u),u+=8),c>=0&&(_[u++]=c,_[u++]=0,l&&(_.dataView||(_.dataView=new DataView(_.buffer,_.byteOffset,_.byteLength))).setFloat64(u,l)),_}else return r.call(this,n,s)}}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(Dc,0,c),c+=8;else for(let d=0;d<8;d++)Dc[d]=t[c++];l=GV(),i=t[c]}let _;i<32&&(o=i,c+=2,o&dm&&(_=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8));let u=super.decode(t.subarray(c,s),s-c);return{localTime:l,value:u,[Cc]:o,expiresAt:_}}return super.decode(t,r)}catch(c){throw c.message+=", data: "+t.slice(0,40).toString("hex"),c}}};a(GV,"getTimestamp");a(A_,"handleLocalTimeForGets");xi=[];setInterval(()=>{for(let e=0;e<xi.length;e++){let t=xi[e].deref();!t||t.isDone||t.isCommitted?xi.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(om.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):om.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(Em,"getUpdateRecord")});var Pc=g((Aae,Vb)=>{"use strict";var kb=ne(),FV=P(),{RecordEncoder:qV}=(Mc(),ie(qb)),Rae=require("fs");kb.initSync();var kV=kb.get(FV.CONFIG_PARAMS.STORAGE_CACHING)!==!1,hm=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=kV&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:qV})}};Vb.exports=hm});var Uc=g((bae,$b)=>{"use strict";var xr=ne(),cn=P();xr.initSync();var O_=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=xr.get(cn.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||xr.get(cn.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||xr.get(cn.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",xr.get(cn.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=xr.get(cn.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),xr.get(cn.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=xr.get(cn.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),xr.get(cn.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=xr.get(cn.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),xr.get(cn.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=xr.get(cn.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=xr.get(cn.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};$b.exports=O_;O_.MAX_DBS=1e4});var We=g((Nae,ey)=>{"use strict";var pm=require("lmdb"),In=require("fs-extra"),Gr=require("path"),b_=Br(),Wb=K(),Er=vr().LMDB_ERRORS_ENUM,y_=Hb(),Sm=Pc(),Qb=Uc(),ti=dt(),Yb=P(),{table:VV,resetDatabases:$V}=(Ae(),ie(ke)),Kb=ne(),wn=ti.INTERNAL_DBIS_NAME,zb=ti.DBI_DEFINITION_NAME,YV="data.mdb",KV="lock.mdb",vc=".mdb",WV="-lock",mm=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=ln(t,r),this.key_type=this.dbi[ti.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[ti.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new pm.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function N_(e,t){if(e===void 0)throw new Error(Er.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(Er.ENV_NAME_REQUIRED)}a(N_,"pathEnvNameValidation");async function Tm(e,t,r=!0){try{await In.access(e)}catch(n){throw n.code==="ENOENT"?new Error(Er.INVALID_BASE_PATH):n}try{let n=Gr.join(e,t+vc);return await In.access(n,In.constants.R_OK|In.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await In.access(Gr.join(e,t,YV),In.constants.R_OK|In.constants.F_OK),Gr.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(Er.INVALID_ENVIRONMENT)}else throw new Error(Er.INVALID_ENVIRONMENT);throw n}}a(Tm,"validateEnvironmentPath");function I_(e,t){if(b_.validateEnv(e),t===void 0)throw new Error(Er.DBI_NAME_REQUIRED)}a(I_,"validateEnvDBIName");async function QV(e,t,r=!1,n=!1){N_(e,t);let s=Gr.basename(e);t=t.toString();let i=Kb.get(Yb.CONFIG_PARAMS.DATABASES);i||Kb.setProperty(Yb.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await Tm(e,t,n),Jb(e,t,r)}catch(o){if(o.message===Er.INVALID_ENVIRONMENT){let c=Gr.join(e,t);await In.mkdirp(n?c:e);let l=new Qb(n?c:c+vc,!1),_=pm.open(l);_.dbis=Object.create(null);let u=new Sm(!1);_.openDB(wn,u),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let d=gm(e,t,r);return _[ti.ENVIRONMENT_NAME_KEY]=d,global.lmdb_map[d]=_,_}throw o}}a(QV,"createEnvironment");async function zV(e,t,r,n=!0){N_(e,t),t=t.toString();let s=Gr.join(e,t);return VV({table:t,database:Gr.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(zV,"copyEnvironment");async function Jb(e,t,r=!1){N_(e,t),t=t.toString();let n=gm(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 Tm(e,t),i=Gr.join(e,t+vc),o=s!=i,c=new Qb(s,o),l=pm.open(c);l.dbis=Object.create(null);let _=jb(l);for(let u=0;u<_.length;u++)ln(l,_[u]);return l[ti.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(Jb,"openEnvironment");async function JV(e,t,r=!1){N_(e,t),t=t.toString();let n=Gr.join(e,t+vc),s=await Tm(e,t);if(global.lmdb_map!==void 0){let i=gm(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await Xb(o),delete global.lmdb_map[i]}}await In.remove(s),await In.remove(s===n?s+WV:Gr.join(Gr.dirname(s),KV))}a(JV,"deleteEnvironment");async function Xb(e){b_.validateEnv(e);let t=e[ti.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(Xb,"closeEnvironment");function gm(e,t,r=!1){let s=`${Gr.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(gm,"getCachedEnvironmentName");function XV(e){b_.validateEnv(e);let t=Object.create(null),r=ln(e,wn);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==wn)try{t[n]=Object.assign(new y_,s)}catch{Wb.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(XV,"listDBIDefinitions");function jb(e){b_.validateEnv(e);let t=[],r=ln(e,wn);for(let{key:n}of r.getRange({start:!1}))n!==wn&&t.push(n);return t}a(jb,"listDBIs");function jV(e,t){let n=ln(e,wn).getEntry(t),s=new y_;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{Wb.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(jV,"getDBIDefinition");function Zb(e,t,r,n=!r){if(I_(e,t),t=t.toString(),t===wn)throw new Error(Er.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return ln(e,t)}catch(s){if(s.message===Er.DBI_DOES_NOT_EXIST){let i=new Sm(r,n===!0),o=e.openDB(t,i),c=new y_(r===!0,n);return o[zb]=c,ln(e,wn).putSync(t,c),e.dbis[t]=o,o}throw s}}a(Zb,"createDBI");function ln(e,t){if(I_(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==wn?r=jV(e,t):r=new y_,r===void 0)throw new Error(Er.DBI_DOES_NOT_EXIST);let n;try{let s=new Sm(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(Er.DBI_DOES_NOT_EXIST):s}return n[zb]=r,e.dbis[t]=n,n}a(ln,"openDBI");function ZV(e,t){I_(e,t),t=t.toString();let r=ln(e,t),n=r.getStats();return r[ti.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(ZV,"statDBI");async function e$(e,t){try{let r=Gr.join(e,t+vc);return(await In.stat(r)).size}catch{throw new Error(Er.INVALID_ENVIRONMENT)}}a(e$,"environmentDataSize");function t$(e,t){if(I_(e,t),t=t.toString(),t===wn)throw new Error(Er.CANNOT_DROP_INTERNAL_DBIS_NAME);ln(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],ln(e,wn).removeSync(t)}a(t$,"dropDBI");function r$(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{ln(e,i)}catch(o){if(o.message===Er.DBI_DOES_NOT_EXIST)Zb(e,i,i!==t,i===t),n=!0;else throw o}}n&&$V()}a(r$,"initializeDBIs");ey.exports={openDBI:ln,openEnvironment:Jb,createEnvironment:QV,listDBIs:jb,listDBIDefinitions:XV,createDBI:Zb,dropDBI:t$,statDBI:ZV,deleteEnvironment:JV,initializeDBIs:r$,TransactionCursor:mm,environmentDataSize:e$,copyEnvironment:zV,closeEnvironment:Xb}});var ry=g((wae,ty)=>{"use strict";var Rm=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};ty.exports=Rm});var sy=g((Dae,ny)=>{"use strict";var Am=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}};ny.exports=Am});var oy=g((Mae,iy)=>{"use strict";var Om=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};iy.exports=Om});var Vo=g((Hae,ly)=>{"use strict";var n$=We(),s$=ry(),i$=sy(),o$=oy(),zn=Br(),Bc=vr().LMDB_ERRORS_ENUM,a$=dt(),gs=P(),c$=J(),l$=require("uuid"),Uae=require("lmdb"),{handleHDBError:u$,hdb_errors:_$}=se(),{OVERFLOW_MARKER:vae,MAX_SEARCH_KEY_LENGTH:Bae}=a$,ay=ne();ay.initSync();var w_=ay.get(gs.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),bm=gs.TIME_STAMP_NAMES_ENUM.CREATED_TIME,Gi=gs.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function d$(e,t,r,n,s=zn.getNextMonotonicTime()){wm(e,t,r,n),ym(e,t,r);let i=new s$,o=[],c=[];for(let l=0;l<n.length;l++){let _=n[l];cy(_,!0,s);let u=f$(e,t,r,_),d=_[t];o.push(u),c.push(d)}return Nm(o,c,n,i,s)}a(d$,"insertRecords");function f$(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 u=c([[{}]]);Array.isArray(u)&&(c=u[0][gs.FUNC_VAL],n[o]=c)}let l=zn.getIndexedValues(c),_=e.dbis[o];if(l){w_&&_.prefetch(l.map(u=>({key:u,value:s})),C_);for(let u=0,d=l.length;u<d;u++)_.put(l[u],s)}}w_&&e.dbis[t].prefetch([s],C_),e.dbis[t].put(s,n,n[Gi])})}a(f$,"insertRecord");function E$(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(E$,"removeSkippedRecords");function cy(e,t,r){let n=r>0;(n||!Number.isInteger(e[Gi]))&&(e[Gi]=r||(r=zn.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[bm]))&&(e[bm]=r||zn.getNextMonotonicTime()):delete e[bm]}a(cy,"setTimestamps");function ym(e,t,r){r.indexOf(gs.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(gs.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(gs.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(gs.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),n$.initializeDBIs(e,t,r)}a(ym,"initializeTransaction");async function h$(e,t,r,n,s=zn.getNextMonotonicTime()){wm(e,t,r,n),ym(e,t,r);let i=new i$,o=[],c=[],l=[];for(let _=0;_<n.length;_++){let u=n[_],d=u[t],E;try{E=Im(e,t,u,d,i,!0,s)}catch{i.skipped_hashes.push(d),o.push(_);continue}c.push(E),l.push(d)}return Nm(c,l,n,i,s,o)}a(h$,"updateRecords");async function m$(e,t,r,n,s=zn.getNextMonotonicTime()){try{wm(e,t,r,n)}catch(l){throw u$(l,l.message,_$.HTTP_STATUS_CODES.BAD_REQUEST)}ym(e,t,r);let i=new o$,o=[],c=[];for(let l=0;l<n.length;l++){let _=n[l],u;c$.isEmpty(_[t])?(u=l$.v4(),_[t]=u):u=_[t];let d=Im(e,t,_,u,i,!1,s);o.push(d),c.push(u)}return Nm(o,c,n,i,s)}a(m$,"upsertRecords");async function Nm(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||zn.getNextMonotonicTime(),E$(r,i),n}a(Nm,"finalizeWrite");function Im(e,t,r,n,s,i=!1,o){let c=e.dbis[t],l=c.getEntry(n),_=l?.value,u=_;if(!_){if(i)return!1;_={}}if(cy(r,!u,o),Number.isInteger(r[Gi])&&_[Gi]>r[Gi])return!1;u&&s.original_records.push(_);let d,E=a(()=>{for(let h in r){if(!r.hasOwnProperty(h)||h===t)continue;let p=r[h],S=e.dbis[h];if(S===void 0)continue;let T=_[h];if(typeof p=="function"){let b=p([[_]]);Array.isArray(b)&&(p=b[0][gs.FUNC_VAL],r[h]=p)}if(p===T)continue;let A=zn.getIndexedValues(T);if(A){w_&&S.prefetch(A.map(b=>({key:b,value:n})),C_);for(let b=0,I=A.length;b<I;b++)S.remove(A[b],n)}if(A=zn.getIndexedValues(p),A){w_&&S.prefetch(A.map(b=>({key:b,value:n})),C_);for(let b=0,I=A.length;b<I;b++)S.put(A[b],n)}}let f=Object.assign({},_,r);c.put(n,f,f[Gi])},"do_put");return l?d=c.ifVersion(n,l.version,E):d=c.ifNoExists(n,E),d.then(f=>f?!0:Im(e,t,r,n,s,i,o))}a(Im,"updateUpsertRecord");function p$(e,t,r){if(zn.validateEnv(e),t===void 0)throw new Error(Bc.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(Bc.WRITE_ATTRIBUTES_REQUIRED):new Error(Bc.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(p$,"validateBasic");function wm(e,t,r,n){if(p$(e,t,r),!Array.isArray(n))throw n===void 0?new Error(Bc.RECORDS_REQUIRED):new Error(Bc.RECORDS_MUST_BE_ARRAY)}a(wm,"validateWrite");function C_(){}a(C_,"noop");ly.exports={insertRecords:d$,updateRecords:h$,upsertRecords:m$}});var Fi=g((Gae,S$)=>{S$.exports={hdb_table:{hash_attribute:"id",name:"hdb_table",schema:"system",residence:["*"],attributes:[{attribute:"id"},{attribute:"name"},{attribute:"hash_attribute"},{attribute:"schema"},{attribute:"residence"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_attribute:{hash_attribute:"id",name:"hdb_attribute",schema:"system",residence:["*"],attributes:[{attribute:"id"},{attribute:"schema"},{attribute:"table"},{attribute:"attribute"},{attribute:"schema_table"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_schema:{hash_attribute:"name",name:"hdb_schema",schema:"system",residence:["*"],attributes:[{attribute:"name"},{attribute:"createddate"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},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:"__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:"__createdtime__"},{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 Xn=g((Fae,dy)=>{"use strict";var _y=J(),uy=P(),$o=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Jn=require("joi"),ri={schema_format:{pattern:$o,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},T$=Jn.alternatives(Jn.string().min(1).max(ri.schema_length.maximum).pattern($o).messages({"string.pattern.base":"{:#label} "+ri.schema_format.message}),Jn.number(),Jn.array()).required(),g$=Jn.alternatives(Jn.string().min(1).max(ri.schema_length.maximum).pattern($o).messages({"string.pattern.base":"{:#label} "+ri.schema_format.message}),Jn.number()),R$=Jn.alternatives(Jn.string().min(1).max(ri.schema_length.maximum).pattern($o).messages({"string.pattern.base":"{:#label} "+ri.schema_format.message}),Jn.number()).required();function A$(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>ri.schema_length.maximum?`'${e}' maximum of 250 characters`:$o.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(A$,"checkValidTable");function O$(e,t){return _y.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(O$,"validateSchemaExists");function b$(e,t){let r=t.state.ancestors[0].schema;return _y.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(b$,"validateTableExists");function y$(e,t){return e.toLowerCase()===uy.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${uy.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(y$,"validateSchemaName");dy.exports={common_validators:ri,schema_regex:$o,hdb_schema_table:T$,validateSchemaExists:O$,validateTableExists:b$,validateSchemaName:y$,checkValidTable:A$,hdb_database:g$,hdb_table:R$}});var at=g((kae,fy)=>{"use strict";var hr=require("validate.js");hr.validators.type=function(e,t,r,n){return e===null||typeof e>"u"||hr.validators.type.checks[t](e)?null:` must be a '${t}' value`};hr.validators.type.checks={Object:function(e){return hr.isObject(e)&&!hr.isArray(e)},Array:hr.isArray,Integer:hr.isInteger,Number:hr.isNumber,String:hr.isString,Date:hr.isDate,Boolean:function(e){return typeof e=="boolean"}};hr.validators.hasValidFileExt=function(e,t){return hr.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};fy.exports={validateObject:N$,validateObjectAsync:I$,validateBySchema:w$};function N$(e,t){if(!e||!t)return new Error("validateObject parameters were null");let r=hr(e,t,{format:"flat"});return r?new Error(r):null}a(N$,"validateObject");async function I$(e,t){if(!e||!t)return new Error("validateObject parameters were null");try{await hr.async(e,t,{format:"flat"})}catch(r){let n=r.join(",");return new Error(n)}return null}a(I$,"validateObjectAsync");function w$(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(w$,"validateBySchema")});var D_=g(($ae,Ey)=>{var{common_validators:jn}=Xn(),xc=at(),Hc="is required",Tt={database:{presence:!1,format:jn.schema_format,length:jn.schema_length},schema:{presence:!1,format:jn.schema_format,length:jn.schema_length},table:{presence:!0,format:jn.schema_format,length:jn.schema_length},attribute:{presence:!0,format:jn.schema_format,length:jn.schema_length},hash_attribute:{presence:!0,format:jn.schema_format,length:jn.schema_length}};function Gc(e){for(let t in e)e[t]=e[t]===null||e[t]===void 0||typeof e[t]=="object"?e[t]:e[t].toString();return e}a(Gc,"makeAttributesStrings");function C$(e){return e=Gc(e),Tt.table.presence=!1,Tt.attribute.presence=!1,Tt.hash_attribute.presence=!1,xc.validateObject(e,Tt)}a(C$,"schema_object");function D$(e){return e=Gc(e),Tt.table.presence={message:Hc},Tt.attribute.presence=!1,Tt.hash_attribute.presence=!1,xc.validateObject(e,Tt)}a(D$,"table_object");function L$(e){return e=Gc(e),Tt.table.presence={message:Hc},Tt.attribute.presence=!1,xc.validateObject(e,Tt)}a(L$,"create_table_object");function M$(e){return e=Gc(e),Tt.table.presence={message:Hc},Tt.attribute.presence={message:Hc},Tt.hash_attribute.presence=!1,xc.validateObject(e,Tt)}a(M$,"attribute_object");function P$(e){return e=Gc(e),Tt.table.presence={message:Hc},Tt.attribute.presence=!1,Tt.hash_attribute.presence=!1,xc.validateObject(e,Tt)}a(P$,"describe_table");function U$(e){if(e){if(!Array.isArray(e))throw new Error("residence must be a string array");if(e.length===0)throw new Error("residence cannot be an empty array");for(let t=0;t<e.length;t++)if(typeof e[t]!="string")throw new Error(`residence must be a string array, item '${e[t]}' is not a string`)}}a(U$,"validateTableResidence");Ey.exports={schema_object:C$,create_table_object:L$,table_object:D$,attribute_object:M$,describe_table:P$,validateTableResidence:U$}});var my=g((Kae,hy)=>{"use strict";var v$=require("uuid"),Cm=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||v$.v4(),this.schema_table=`${this.schema}.${this.table}`}};hy.exports=Cm});var L_=g((Qae,py)=>{"use strict";var B$=my(),Dm=class extends B${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}};py.exports=Dm});var Ty=g((Jae,Sy)=>{"use strict";Sy.exports=x$;var H$="inserted";function x$(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===H$?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(x$,"returnObject")});var M_=g((jae,by)=>{"use strict";var G$=P(),Lm=We(),F$=Vo(),{getSystemSchemaPath:q$,getSchemaPath:k$}=ze(),V$=Fi(),$$=D_(),Y$=L_(),K$=Ty(),{handleHDBError:gy,hdb_errors:Ay}=se(),Ry=J(),{HTTP_STATUS_CODES:W$}=Ay,Mm=V$.hdb_attribute,Oy=[];for(let e=0;e<Mm.attributes.length;e++)Oy.push(Mm.attributes[e].attribute);var Q$="inserted";by.exports=z$;async function z$(e){let t=$$.attribute_object(e);if(t)throw gy(new Error,t.message,Ay.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=!e.skip_table_check&&Ry.checkGlobalSchemaTable(e.schema,e.table);if(r)throw gy(new Error,r,W$.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=Ry.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 Y$(e.schema,e.table,e.attribute,e.id);try{let i=await Lm.openEnvironment(k$(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}`);Lm.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await Lm.openEnvironment(q$(),G$.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await F$.insertRecords(o,Mm.hash_attribute,Oy,[s]);return K$(Q$,c,{records:[s]},l)}catch(i){throw i}}a(z$,"lmdbCreateAttribute")});var Um=g((ece,Ny)=>{var{hdb_table:J$,hdb_database:yy}=Xn(),X$=at(),Pm=require("joi"),j$={undefined:"undefined",null:"null"},Z$=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||j$[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"),e1=Pm.object({database:yy,schema:yy,table:J$,records:Pm.array().items(Pm.object().custom(Z$)).required()});Ny.exports=function(e){return X$.validateBySchema(e,e1)}});var Fc=g((nce,wy)=>{"use strict";var Rs=J(),Iy=K(),rce=Um(),{getDatabases:t1}=(Ae(),ie(ke)),{ClientError:qi}=se();wy.exports=r1;function r1(e){if(Rs.isEmpty(e))throw new qi("invalid update parameters defined.");if(Rs.isEmptyOrZeroLength(e.schema))throw new qi("invalid schema specified.");if(Rs.isEmptyOrZeroLength(e.table))throw new qi("invalid table specified.");if(!Array.isArray(e.records))throw new qi("records must be an array");let t=t1()[e.schema]?.[e.table];if(Rs.isEmpty(t))throw new qi(`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&&Rs.isEmptyOrZeroLength(o[r]))throw Iy.error("a valid hash attribute must be provided with update record:",o),new qi("a valid hash attribute must be provided with update record, check log for more info");if(!Rs.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw Iy.error(`a valid hash value must be provided with ${e.operation} record:`,o),new qi(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!Rs.isEmpty(o[r])&&o[r]!==""&&n.has(Rs.autoCast(o[r]))&&(o.skip=!0),n.add(Rs.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(r1,"insertUpdateValidate")});var Dy=g((ice,Cy)=>{"use strict";var vm=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};Cy.exports=vm});var Py=g((ace,My)=>{"use strict";var Bm=We(),n1=K(),Ly=vr().LMDB_ERRORS_ENUM;My.exports=s1;async function s1(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 Bm.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==Ly.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await Bm.closeEnvironment(global.lmdb_map[n]),await Bm.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==Ly.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){n1.error(t)}}a(s1,"cleanLMDBMap")});var As=g((lce,Hy)=>{"use strict";var qc=require("crypto"),i1=ne(),{CONFIG_PARAMS:o1}=P(),vy="aes-256-cbc",a1=32,c1=16,Hm=64,By=32,l1=Hm+By,Uy=new Map;Hy.exports={encrypt:u1,decrypt:_1,createNatsTableStreamName:d1};function u1(e){let t=qc.randomBytes(a1),r=qc.randomBytes(c1),n=qc.createCipheriv(vy,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(u1,"encrypt");function _1(e){let t=e.substr(0,Hm),r=e.substr(Hm,By),n=e.substr(l1,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=qc.createDecipheriv(vy,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(_1,"decrypt");function d1(e,t){let r=i1.get(o1.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=Uy.get(r);return n||(n=qc.createHash("md5").update(r).digest("hex"),Uy.set(r,n)),n}a(d1,"createNatsTableStreamName")});var ni=g((dce,Gy)=>{"use strict";var _ce=Fr(),kc=K(),xy=D_(),f1=As(),P_=J(),{handleHDBError:U_,hdb_errors:E1}=se(),{HDB_ERROR_MSGS:v_,HTTP_STATUS_CODES:xm}=E1,h1=ne();h1.initSync();var{getDatabases:Gm}=(Ae(),ie(ke)),m1=require("fs-extra");Gy.exports={describeAll:p1,describeTable:B_,describeSchema:S1};async function p1(e={}){try{let t=P_.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=Gm(),o={},c={},l=[],_=e?.exact_count;for(let d in i){o[d]=!0,!t&&!s&&!r&&(c[d]=e.hdb_user?.role?.permission[d]?.describe);let E=i[d];for(let f in E)try{let h;if(t||s||r)h=await B_({schema:d,table:f,exact_count:_});else if(n&&n[d].describe&&n[d].tables[f].describe){let p=n[d].tables[f].attribute_permissions;h=await B_({schema:d,table:f,exact_count:_},p)}h&&l.push(h)}catch(h){kc.error(h)}}let u={};for(let d in l)t||s||r?(u[l[d].schema]==null&&(u[l[d].schema]={}),u[l[d].schema][l[d].name]=l[d],o[l[d].schema]&&delete o[l[d].schema]):c[l[d].schema]&&(u[l[d].schema]==null&&(u[l[d].schema]={}),u[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?u[d]={}:c[d]&&(u[d]={});return u}catch(t){return kc.error("Got an error in describeAll"),kc.error(t),U_(new Error,v_.DESCRIBE_ALL_ERR)}}a(p1,"describeAll");async function B_(e,t){P_.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=xy.describe_table(e);if(i)throw i;let c=Gm()[r];if(!c)throw U_(new Error,v_.SCHEMA_NOT_FOUND(e.schema),xm.NOT_FOUND);let l=c[n];if(!l)throw U_(new Error,v_.TABLE_NOT_FOUND(e.schema,e.table),xm.NOT_FOUND);function _(f){u.push(Object.assign({},{attribute:f.attribute,type:f.type,elements:f.elements?.type,indexed:f.indexed,is_primary_key:f.isPrimaryKey,assigned_created_time:f.assignCreatedTime,assigned_updated_time:f.assignUpdatedTime,nullable:f.nullable,properties:f.properties?f.properties.map(h=>({type:h.type,name:h.name})):void 0}))}a(_,"pushAtt");let u=[];if(s){let f={};s.forEach(h=>{h.describe&&(f[h.attribute_name]=!0)}),l.attributes.forEach(h=>{f[h.name]&&_(h)})}else l.attributes?.forEach(f=>_(f));let d;try{d=(await m1.stat(l.primaryStore.env.path)).size}catch(f){kc.warn("unable to get database size",f)}let E={schema:r,name:l.tableName,hash_attribute:l.attributes.find(f=>f.isPrimaryKey||f.is_hash_attribute)?.name,audit:l.audit,schema_defined:l.schemaDefined,attributes:u,db_size:d};E.clustering_stream_name=f1.createNatsTableStreamName(E.schema,E.name);try{let f=l.getRecordCount({exactCount:e.exact_count==="true"});E.record_count=f.recordCount,E.estimated_record_range=f.estimatedRange;let h=l.auditStore;if(h)for(let p of h.getKeys({reverse:!0,limit:1}))E.last_updated_record=p[0];if(!E.last_updated_record&&l.indices.__updatedtime__)for(let p of l.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))E.last_updated_record=p}catch(f){kc.warn(`unable to stat table dbi due to ${f}`)}return E}a(B_,"descTable");async function S1(e){P_.transformReq(e);let t=xy.schema_object(e);if(t)throw t;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=Gm()[n];if(!i)throw U_(new Error,v_.SCHEMA_NOT_FOUND(e.schema),xm.NOT_FOUND);let o={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),P_.isEmpty(l)||l.describe){let _=await B_({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);_&&(o[_.name]=_)}}return o}a(S1,"describeSchema")});var si=g((mce,$y)=>{var T1=Fi(),{callbackify:qy,promisify:g1}=require("util"),{getDatabases:ky}=(Ae(),ie(ke));$y.exports={setSchemaDataToGlobal:Fy,getTableSchema:R1,getSystemSchema:A1,setSchemaDataToGlobalAsync:g1(Fy)};var Vy=ni(),Ece=qy(Vy.describeAll),hce=qy(Vy.describeTable);function Fy(e){global.hdb_schema=ky(),e&&e()}a(Fy,"setSchemaDataToGlobal");function R1(e,t,r){let n=ky()[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(R1,"getTableSchema");function A1(){return T1}a(A1,"getSystemSchema")});var un=g((Sce,Qy)=>{"use strict";var x_=Um(),Kt=J(),O1=require("util"),G_=Cn(),b1=si(),Yy=K(),{handleHDBError:ki,hdb_errors:y1}=se(),{HTTP_STATUS_CODES:Vi}=y1,N1=O1.promisify(b1.getTableSchema),I1="updated",Ky="inserted",Wy="upserted";Qy.exports={insert:C1,update:D1,upsert:L1,validation:w1,flush:M1};async function w1(e){if(Kt.isEmpty(e))throw new Error("invalid update parameters defined.");if(Kt.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if(Kt.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await N1(e.schema,e.table),r=x_(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&&Kt.isEmptyOrZeroLength(c[n]))throw Yy.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(!Kt.isEmptyOrZeroLength(c[n])&&(c[n]==="null"||c[n]==="undefined"))throw Yy.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[n]}" is not a valid hash attribute value`);!Kt.isEmpty(c[n])&&c[n]!==""&&s.has(Kt.autoCast(c[n]))&&(c.skip=!0),s.add(Kt.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(w1,"validation");async function C1(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=x_(e);if(t)throw ki(new Error,t.message,Vi.BAD_REQUEST);Kt.transformReq(e);let r=Kt.checkSchemaTableExist(e.schema,e.table);if(r)throw ki(new Error,r,Vi.BAD_REQUEST);let n=await G_.createRecords(e);return H_(Ky,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(C1,"insertData");async function D1(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=x_(e);if(t)throw ki(new Error,t.message,Vi.BAD_REQUEST);Kt.transformReq(e);let r=Kt.checkSchemaTableExist(e.schema,e.table);if(r)throw ki(new Error,r,Vi.BAD_REQUEST);let n=await G_.updateRecords(e);return Kt.isEmpty(n.existing_rows)?H_(I1,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):H_(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(D1,"updateData");async function L1(e){if(e.operation!=="upsert")throw ki(new Error,"invalid operation, must be upsert",Vi.INTERNAL_SERVER_ERROR);let t=x_(e);if(t)throw ki(new Error,t.message,Vi.BAD_REQUEST);Kt.transformReq(e);let r=Kt.checkSchemaTableExist(e.schema,e.table);if(r)throw ki(new Error,r,Vi.BAD_REQUEST);let n=await G_.upsertRecords(e);return H_(Wy,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(L1,"upsertData");function H_(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===Ky?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===Wy?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(H_,"returnObject");function M1(e){return Kt.transformReq(e),G_.flush(e.schema,e.table)}a(M1,"flush")});var qm=g((gce,Xy)=>{var P1=at(),Fm=require("joi"),{hdb_table:U1,hdb_database:zy}=Xn(),Jy={schema:zy,database:zy,table:U1},v1={date:Fm.date().iso().required()},B1={timestamp:Fm.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};Xy.exports=function(e,t){let r=t==="timestamp"?{...Jy,...B1}:{...Jy,...v1},n=Fm.object(r);return P1.validateBySchema(e,n)}});var eN=g((Rce,Zy)=>{var H1=at(),km=require("joi"),{hdb_table:x1,hdb_database:jy}=Xn(),G1=km.object({schema:jy,database:jy,table:x1,hash_values:km.array().required(),ids:km.array()});Zy.exports=function(e){return H1.validateBySchema(e,G1)}});var rN=g((Ace,tN)=>{"use strict";var Vm=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}},$m=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}},Ym=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};tN.exports={InsertObject:Vm,NoSQLSeachObject:$m,DeleteResponseObject:Ym}});var Ki=g((bce,aN)=>{"use strict";var sN=qm(),F1=eN(),$i=J(),nN=require("moment"),iN=K(),{promisify:q1,callbackify:k1}=require("util"),Yi=P(),V1=si(),Km=q1(V1.getTableSchema),Wm=Cn(),{DeleteResponseObject:$1}=rN(),{handleHDBError:ii,hdb_errors:Y1}=se(),{HDB_ERROR_MSGS:F_,HTTP_STATUS_CODES:oi}=Y1,K1="records successfully deleted",W1=k1(oN);aN.exports={delete:W1,deleteRecord:oN,deleteFilesBefore:Q1,deleteAuditLogsBefore:z1};async function Q1(e){let t=sN(e,"date");if(t)throw ii(t,t.message,oi.BAD_REQUEST,void 0,void 0,!0);if($i.transformReq(e),!nN(e.date,nN.ISO_8601).isValid())throw ii(new Error,F_.INVALID_DATE,oi.BAD_REQUEST,Yi.LOG_LEVELS.ERROR,F_.INVALID_DATE,!0);let n=$i.checkSchemaTableExist(e.schema,e.table);if(n)throw ii(new Error,n,oi.NOT_FOUND,Yi.LOG_LEVELS.ERROR,n,!0);let s=await Wm.deleteRecordsBefore(e);if(await Km(e.schema,e.table),iN.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(Q1,"deleteFilesBefore");async function z1(e){let t=sN(e,"timestamp");if(t)throw ii(t,t.message,oi.BAD_REQUEST,void 0,void 0,!0);if($i.transformReq(e),isNaN(e.timestamp))throw ii(new Error,F_.INVALID_VALUE("Timestamp"),oi.BAD_REQUEST,Yi.LOG_LEVELS.ERROR,F_.INVALID_VALUE("Timestamp"),!0);let r=$i.checkSchemaTableExist(e.schema,e.table);if(r)throw ii(new Error,r,oi.NOT_FOUND,Yi.LOG_LEVELS.ERROR,r,!0);let n=await Wm.deleteAuditLogsBefore(e);return await Km(e.schema,e.table),iN.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(z1,"deleteAuditLogsBefore");async function oN(e){e.ids&&(e.hash_values=e.ids);let t=F1(e);if(t)throw ii(t,t.message,oi.BAD_REQUEST,void 0,void 0,!0);$i.transformReq(e);let r=$i.checkSchemaTableExist(e.schema,e.table);if(r)throw ii(new Error,r,oi.NOT_FOUND,Yi.LOG_LEVELS.ERROR,r,!0);try{await Km(e.schema,e.table);let n=await Wm.deleteRecords(e);return $i.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${K1}`),n}catch(n){if(n.message===Yi.SEARCH_NOT_FOUND_MESSAGE){let s=new $1;return s.message=Yi.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(oN,"deleteRecord")});var q_=g((Nce,uN)=>{var J1=require("crypto"),cN=9;function X1(e){let t=Z1(cN),r=lN(e+t);return t+r}a(X1,"createHash");function j1(e,t){let r=e?.substr(0,cN),n=r+lN(t+r);return e===n}a(j1,"validateHash");function Z1(e){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ",r=t.length,n="";for(let s=0;s<e;s++){let i=Math.floor(Math.random()*r);n+=t[i]}return n}a(Z1,"generateSalt");function lN(e){return J1.createHash("md5").update(e).digest("hex")}a(lN,"md5");uN.exports={hash:X1,validate:j1}});var dN=g((wce,_N)=>{var Qm=at(),Zt={username:{presence:!0,format:"[\\w\\-\\_]+",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 eY(e){return Zt.password.presence=!0,Zt.username.presence=!0,Zt.role.presence=!0,Zt.active.presence=!0,Qm.validateObject(e,Zt)}a(eY,"addUserValidation");function tY(e){return Zt.password.presence=!1,Zt.username.presence=!0,Zt.role.presence=!1,Zt.active.presence=!1,Qm.validateObject(e,Zt)}a(tY,"alterUserValidation");function rY(e){return Zt.password.presence=!1,Zt.username.presence=!0,Zt.role.presence=!1,Zt.active.presence=!1,Qm.validateObject(e,Zt)}a(rY,"dropUserValidation");_N.exports={addUserValidation:eY,alterUserValidation:tY,dropUserValidation:rY}});var ct=g((Lce,EN)=>{"use strict";var{platform:Dce}=require("os"),nY="nats-server.zip",zm="nats-server",sY=process.platform==="win32"?`${zm}.exe`:zm,iY=/^[^\s.,*>]+$/,fN="__request__",oY=a(e=>`${e}.${fN}`,"REQUEST_SUBJECT"),aY={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},cY={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},lY={HUB:"hub.pid",LEAF:"leaf.pid"},uY={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},_Y={SUCCESS:"success",ERROR:"error"},dY={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},fY={TXN:"txn",MSGID:"msgid"},Yo={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},EY={[Yo.ERR]:1,[Yo.WRN]:2,[Yo.INF]:3,[Yo.DBG]:4,[Yo.TRC]:5},hY={debug:"-D",trace:"-DVV"};EN.exports={NATS_SERVER_ZIP:nY,NATS_SERVER_NAME:zm,NATS_BINARY_NAME:sY,PID_FILES:lY,NATS_CONFIG_FILES:cY,SERVER_SUFFIX:uY,NATS_TERM_CONSTRAINTS_RX:iY,REQUEST_SUFFIX:fN,UPDATE_REMOTE_RESPONSE_STATUSES:_Y,CLUSTER_STATUS_STATUSES:dY,REQUEST_SUBJECT:oY,SUBJECT_PREFIXES:fY,MSG_HEADERS:aY,LOG_LEVELS:Yo,LOG_LEVEL_FLAGS:hY,LOG_LEVEL_HIERARCHY:EY}});var mN=g((Pce,hN)=>{"use strict";var mY={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
7
7
  `),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
8
8
  `)},pY="certificate.pem",SY="privateKey.pem",TY="ca.pem";hN.exports={CERTIFICATE_VALUES:mY,CERTIFICATE_PEM_NAME:pY,PRIVATEKEY_PEM_NAME:SY,CA_PEM_NAME:TY}});var Jm=g((vce,AN)=>{"use strict";var gN=require("fs-extra"),ae=require("joi"),gY=require("os"),{boolean:be,string:er,number:je,array:k_}=ae.types(),{totalmem:pN}=require("os"),Wi=require("path"),RY=K(),V_=J(),Uce=mN(),SN=P(),AY=at(),TN="log",OY="components",bY="Invalid logging.rotation.maxSize unit. Available units are G, M or K",yY="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",NY="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",IY="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",wY="rootPath config parameter is undefined",CY="clustering.enabled config parameter is undefined",Qi=je.min(0).required(),$_=k_.items({host:er.required(),port:Qi}).empty(null),Zn,RN=!1;AN.exports={configValidator:DY,routesValidator:BY,route_constraints:$_};function DY(e,t=!1){if(RN=t,Zn=e.rootPath,V_.isEmpty(Zn))throw wY;let r=be.required(),n=je.min(0).max(1e3).empty(null).default(vY),s=er.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(Vc),i=er.optional().empty(null),o=er.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null).required(),c=ae.string().empty(null).default(Vc),l=ae.custom(MY).empty(null).default(Vc),_=e.clustering?.enabled;if(V_.isEmpty(_))throw CY;let u=ae.object({certificate:i,certificateAuthority:i,privateKey:i}),d;return _===!0?d=ae.object({enabled:r,hubServer:ae.object({cluster:ae.object({name:ae.required().empty(null),network:ae.object({port:Qi,routes:$_}).required()}).required(),leafNodes:ae.object({network:ae.object({port:Qi}).required()}).required(),network:ae.object({port:Qi}).required()}).required(),leafServer:ae.object({network:ae.object({port:Qi,routes:$_}).required(),streams:ae.object({maxAge:je.min(120).allow(null).optional(),maxBytes:je.min(1).allow(null).optional(),maxMsgs:je.min(1).allow(null).optional(),path:c}).required()}).required(),logLevel:ae.valid("error","warn","info","debug","trace"),nodeName:o,republishMessages:be.optional(),databaseLevel:be.optional(),tls:ae.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:be.required(),verify:be.optional()}),user:er.optional().empty(null)}).required():d=ae.object({enabled:r,tls:ae.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:be.required()})}).required(),ae.object({authentication:ae.object({authorizeLocal:be,cacheTTL:je.required(),enableSessions:be}),analytics:ae.object({aggregatePeriod:je}),componentsRoot:s.optional(),clustering:d,localStudio:ae.object({enabled:r}).required(),logging:ae.object({auditAuthEvents:ae.object({logFailed:be,logSuccessful:be}),file:be.required(),level:ae.valid("notify","fatal","error","warn","info","debug","trace"),rotation:ae.object({enabled:be.optional(),compress:be.optional(),interval:er.custom(UY).optional().empty(null),maxSize:er.custom(PY).optional().empty(null),path:er.optional().empty(null).default(Vc)}).required(),root:s,stdStreams:be.required(),auditLog:be.required()}).required(),operationsApi:ae.object({network:ae.object({cors:be.optional(),corsAccessList:k_.optional(),headersTimeout:je.min(1).optional(),keepAliveTimeout:je.min(1).optional(),port:je.optional().empty(null),domainSocket:ae.optional().empty("hdb/operations-server").default(Vc),securePort:je.optional().empty(null),timeout:je.min(1).optional()}).optional(),tls:ae.alternatives([ae.array().items(u),u])}).required(),rootPath:er.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path").required(),mqtt:ae.object({network:ae.object({port:Qi,securePort:Qi,mtls:ae.alternatives([be.optional(),ae.object({user:er.optional(),certificateAuthority:i,required:be.optional()})])}).required(),webSocket:be.optional(),requireAuthentication:be.optional()}),http:ae.object({compressionThreshold:je.optional(),cors:be.optional(),corsAccessList:k_.optional(),headersTimeout:je.min(1).optional(),port:je.min(0).optional().empty(null),securePort:je.min(0).optional().empty(null),maxHeaderSize:je.optional(),mtls:ae.alternatives([be.optional(),ae.object({user:er.optional(),certificateAuthority:i,required:be.optional()})]),threadRange:ae.alternatives([k_.optional(),er.optional()])}).required(),threads:ae.alternatives(n.optional(),ae.object({count:n.optional(),debug:ae.alternatives(be.optional(),ae.object({startingPort:je.min(1).optional(),host:er.optional(),waitForDebugger:be.optional()})),maxHeapMemory:je.min(0).optional()})),storage:ae.object({writeAsync:be.required(),overlappingSync:be.optional(),caching:be.optional(),compression:ae.alternatives([be.optional(),ae.object({dictionary:er.optional(),threshold:je.optional()})]),compactOnStart:be.optional(),compactOnStartKeepBackup:be.optional(),noReadAhead:be.optional(),path:l,prefetchWrites:be.optional(),maxFreeSpaceToLoad:je.optional(),maxFreeSpaceToRetain:je.optional()}).required(),ignoreScripts:be.optional(),tls:ae.alternatives([ae.array().items(u),u])}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(DY,"configValidator");function LY(e){return RN||gN.existsSync(e)?null:`Specified path ${e} does not exist.`}a(LY,"doesPathExist");function MY(e,t){ae.assert(e,er.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=LY(e);if(r)return t.message(r)}a(MY,"validatePath");function PY(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(bY);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(NY):e}a(PY,"validateRotationMaxSize");function UY(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message(yY);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(IY):e}a(UY,"validateRotationInterval");function vY(e,t){let r=t.state.path.join("."),n=gY.cpus().length,s=n-1;s<=2&&(s=2);let i=process.constrainedMemory?.()||pN();return i=Math.round(Math.min(i,pN())/1e6),s=Math.max(Math.min(s,Math.round((i-750)/300)),1),RY.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}a(vY,"setDefaultThreads");function Vc(e,t){let r=t.state.path.join(".");if(!V_.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if(V_.isEmpty(Zn))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return Wi.join(Zn,OY);case"logging.root":return Wi.join(Zn,TN);case"clustering.leafServer.streams.path":return Wi.join(Zn,"clustering","leaf");case"storage.path":let n=Wi.join(Zn,SN.LEGACY_DATABASES_DIR_NAME);return gN.existsSync(n)?n:Wi.join(Zn,SN.DATABASES_DIR_NAME);case"logging.rotation.path":return Wi.join(Zn,TN);case"operationsApi.network.domainSocket":return r==null?null:Wi.join(Zn,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(Vc,"setDefaultRoot");function BY(e){let t=ae.object({routes:$_});return AY.validateBySchema({routes:e},t)}a(BY,"routesValidator")});var pr=g((xce,LN)=>{"use strict";var kr=P(),Ht=J(),Nt=K(),{configValidator:HY,routesValidator:ON}=Jm(),mr=require("fs-extra"),xY=require("yaml"),Dn=require("path"),GY=require("is-number"),yN=require("properties-reader"),FY=require("lodash"),{handleHDBError:qY}=se(),{HTTP_STATUS_CODES:kY,HDB_ERROR_MSGS:Y_}=vr(),Hce=require("minimist"),{server:VY}=(fr(),ie(Bi)),{DATABASES_PARAM_CONFIG:$c,CONFIG_PARAMS:qr,CONFIG_PARAM_MAP:Ln}=kr,$Y="Unable to get config value because config is uninitialized",YY="Config successfully initialized",KY="Error backing up config file",WY="Empty parameter sent to getConfigValue",NN=Dn.join(kr.PACKAGE_ROOT,"config","yaml",kr.HDB_DEFAULT_CONFIG_FILE),QY="Configuration successfully set. You must restart HarperDB for new config settings to take effect.",bN={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"},K_,It,W_;LN.exports={createConfigFile:zY,getDefaultConfig:JY,getConfigValue:wN,initConfig:jm,flattenConfig:Ko,updateConfigValue:CN,updateConfigObject:jY,getConfiguration:tK,setConfiguration:rK,readConfigFile:ep,getClusteringRoutes:nK,initOldConfig:DN,getConfigFromFile:sK,getConfigFilePath:zi,addConfig:iK,deleteConfigFromFile:oK,getConfigObj:aK};function zY(e,t=!1){let r=ai(NN);K_=Ko(r.toJSON());let n;for(let c in e){let l=Ln[c.toLowerCase()];if(l===qr.DATABASES){Array.isArray(e[c])?n=e[c]:n=Object.keys(e[c]).map(_=>({[_]:e[c][_]}));continue}if(!l&&(c.endsWith("_package")||c.endsWith("_port"))&&(l=c),l!==void 0){let _=l.split("_"),u=Xm(l,e[c]);l==="rootPath"&&u?.endsWith("/")&&(u=u.slice(0,-1));try{r.setIn([..._],u)}catch(d){Nt.error(d)}}}n&&IN(r,n),Zm(r,t);let s=r.toJSON();It=Ko(s);let i=r.getIn(["rootPath"]),o=Dn.join(i,kr.HDB_CONFIG_FILE);mr.createFileSync(o),mr.writeFileSync(o,String(r)),Nt.trace(`Config file written to ${o}`)}a(zY,"createConfigFile");function IN(e,t){let r;try{try{r=JSON.parse(t)}catch(n){if(!Ht.isObject(t))throw n;r=t}for(let n of r){let s=Object.keys(n)[0];if(n[s].hasOwnProperty($c.TABLES))for(let i in n[s][$c.TABLES])for(let o in n[s][$c.TABLES][i]){let c=n[s][$c.TABLES][i][o],l=[qr.DATABASES,s,$c.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=[qr.DATABASES,s,i];e.hasIn(c)?e.setIn(c,o):e.addIn(c,o)}}}catch(n){Nt.error("Error parsing schemas CLI/env config arguments",n)}}a(IN,"setSchemasConfig");function JY(e){if(K_===void 0){let r=ai(NN);K_=Ko(r.toJSON())}let t=Ln[e.toLowerCase()];if(t!==void 0)return K_[t.toLowerCase()]}a(JY,"getDefaultConfig");function wN(e){if(e==null){Nt.error(WY);return}if(It===void 0){Nt.trace($Y);return}let t=Ln[e.toLowerCase()];if(t!==void 0)return It[t.toLowerCase()]}a(wN,"getConfigValue");function zi(e=Ht.getPropsFilePath()){let t=Ht.getEnvCliRootPath();return t?Dn.join(t,kr.HDB_CONFIG_FILE):yN(e).get(kr.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY)}a(zi,"getConfigFilePath");function jm(e=!1){if(It===void 0||e){let t;if(!Ht.noBootFile()){t=Ht.getPropsFilePath();try{mr.accessSync(t,mr.constants.F_OK|mr.constants.R_OK)}catch(i){throw Nt.error(i),new Error(`HarperDB properties file at path ${t} does not exist`)}}let r=zi(t),n;if(r.includes("config/settings.js"))try{DN(r);return}catch(i){if(i.code!==kr.NODE_ERROR_CODES.ENOENT)throw i}try{n=ai(r)}catch(i){if(i.code===kr.NODE_ERROR_CODES.ENOENT){Nt.trace(`HarperDB config file not found at ${r}.
9
- This can occur during early stages of install where the config file has not yet been created`);return}else throw Nt.error(i),new Error(`Error reading HarperDB config file at ${r}`)}XY(n,r),Zm(n);let s=n.toJSON();if(VY.config=s,It=Ko(s),It.logging_rotation_rotate)for(let i in bN)It[i]&&Nt.error(`Config ${bN[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);Nt.trace(YY)}}a(jm,"initConfig");function XY(e,t){let r=e.getIn(["rootPath"]),n=!1;e.hasIn(["storage","path"])||(e.setIn(["storage","path"],Dn.join(r,"database")),n=!0),e.hasIn(["clustering","leafServer","streams","path"])||(e.setIn(["clustering","leafServer","streams","path"],Dn.join(r,"clustering","leaf")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],Dn.join(r,"log")),n=!0),e.hasIn(["clustering","tls","verify"])||(e.setIn(["clustering","tls","verify"],!0),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&&(Nt.trace("Updating config file with missing config params"),mr.writeFileSync(t,String(e)))}a(XY,"checkForUpdatedConfig");function Zm(e,t=!1){let r=e.toJSON();r.componentsRoot=r.componentsRoot??r?.customFunctions?.root,r?.http?.threads&&(r.threads=r?.http?.threads);let n=HY(r,t);if(n.error)throw Y_.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(["clustering","leafServer","streams","path"],n.value.clustering.leafServer.streams?.path),e.setIn(["operationsApi","network","domainSocket"],n.value?.operationsApi?.network?.domainSocket)}a(Zm,"validateConfig");function jY(e,t){It===void 0&&(It={});let r=Ln[e.toLowerCase()];if(r===void 0){Nt.trace(`Unable to update config object because config param '${e}' does not exist`);return}It[r.toLowerCase()]=t}a(jY,"updateConfigObject");function CN(e,t,r=void 0,n=!1,s=!1,i=!1){It===void 0&&jm();let o=wN(Ln.hdb_root),c=Dn.join(o,kr.HDB_CONFIG_FILE),l=ai(c),_;if(r===void 0&&e.toLowerCase()===qr.DATABASES)_=t;else if(r===void 0){let E;if(i)E=e;else if(E=Ln[e.toLowerCase()],E===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let f=E.split("_"),h=Xm(E,t);l.setIn([...f],h)}else for(let E in r){let f=Ln[E.toLowerCase()];if(f===qr.HTTP_SECUREPORT&&r[E]===It[qr.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),f===qr.OPERATIONSAPI_NETWORK_SECUREPORT&&r[E]===It[qr.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&l.setIn(["operationsApi","network","port"],null),f===qr.DATABASES){_=r[E];continue}if(f?.startsWith("threads_")){let h=l.getIn(["threads"]);h>=0&&(l.deleteIn(["threads"]),l.setIn(["threads","count"],h))}if(!f&&(E.endsWith("_package")||E.endsWith("_port"))&&(f=E),f!==void 0){let h=f.split("_"),p=kr.LEGACY_CONFIG_PARAMS[E.toUpperCase()];p&&p.startsWith("customFunctions")&&l.hasIn(p.split("_"))&&(f=p,h=p.split("_"));let S=Xm(f,r[E]);f==="rootPath"&&S?.endsWith("/")&&(S=S.slice(0,-1));try{h.length>1&&typeof l.getIn(h.slice(0,-1))=="boolean"&&l.deleteIn(h.slice(0,-1)),l.setIn([...h],S)}catch(T){Nt.error(T)}}}_&&IN(l,_),Zm(l);let u=l.getIn(["rootPath"]),d=Dn.join(u,kr.HDB_CONFIG_FILE);n===!0&&ZY(c,u),mr.writeFileSync(d,String(l)),s&&(It=Ko(l.toJSON())),Nt.trace(`Config parameter: ${e} updated with value: ${t}`)}a(CN,"updateConfigValue");function ZY(e,t){try{let r=Dn.join(t,"backup",`${kr.HDB_CONFIG_FILE}.bak`);mr.copySync(e,r),Nt.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){Nt.error(KY),Nt.error(r)}}a(ZY,"backupConfigFile");var eK=["databases"];function Ko(e){return e.http&&Object.assign(e.http,e?.customFunctions?.network),e?.operationsApi?.network&&(e.operationsApi.network=Object.assign({},e.http,e.operationsApi.network)),e?.operationsApi&&(e.operationsApi.tls=Object.assign({},e.tls,e.operationsApi.tls)),W_=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])&&!eK.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;!qr[l.toUpperCase()]&&Ln[l]&&(s[Ln[l].toLowerCase()]=o[c]),s[l]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(Ko,"flattenConfig");function Xm(e,t){if(e===qr.CLUSTERING_NODENAME||e===qr.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(GY(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||Ht.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 Ht.autoCast(t)}a(Xm,"castConfigValue");function tK(){let e=Ht.getPropsFilePath(),t=zi(e);return ai(t).toJSON()}a(tK,"getConfiguration");async function rK(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return CN(void 0,void 0,s,!0),QY}catch(i){throw typeof i=="string"||i instanceof String?qY(i,i,kY.BAD_REQUEST,void 0,void 0,!0):i}}a(rK,"setConfiguration");function ep(){let e=Ht.getPropsFilePath();try{mr.accessSync(e,mr.constants.F_OK|mr.constants.R_OK)}catch(n){if(!Ht.noBootFile())throw Nt.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=zi(e);return ai(t).toJSON()}a(ep,"readConfigFile");function ai(e){return xY.parseDocument(mr.readFileSync(e,"utf8"),{simpleKeys:!0})}a(ai,"parseYamlDoc");function nK(){let e=ep(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=Ht.isEmptyOrZeroLength(t)?[]:t;let r=ON(t);if(r)throw Y_.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=Ht.isEmptyOrZeroLength(n)?[]:n;let s=ON(n);if(s)throw Y_.CONFIG_VALIDATION(s.message);if(!Ht.isEmptyOrZeroLength(n)&&!Ht.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!Ht.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw Y_.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(nK,"getClusteringRoutes");function DN(e){let t=yN(e);It={};for(let r in Ln){let n=t.get(r.toUpperCase());if(Ht.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=Ln[r].toLowerCase();s===qr.LOGGING_ROOT?It[s]=Dn.dirname(n):It[s]=n}return It}a(DN,"initOldConfig");function sK(e){let t=ep();return FY.get(t,e.replaceAll("_","."))}a(sK,"getConfigFromFile");async function iK(e,t){let r=ai(zi());r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),await mr.writeFile(zi(),String(r))}a(iK,"addConfig");function oK(e){let t=zi(Ht.getPropsFilePath()),r=ai(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=Dn.join(n,kr.HDB_CONFIG_FILE);mr.writeFileSync(s,String(r))}a(oK,"deleteConfigFromFile");function aK(){return W_||(jm(),W_)}a(aK,"getConfigObj")});var PN=g((Fce,MN)=>{"use strict";var Q_=P(),z_=class{static{a(this,"BaseLicense")}constructor(t=0,r=Q_.RAM_ALLOCATION_ENUM.DEFAULT,n=Q_.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},tp=class extends z_{static{a(this,"ExtendedLicense")}constructor(t=0,r=Q_.RAM_ALLOCATION_ENUM.DEFAULT,n=Q_.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};MN.exports={BaseLicense:z_,ExtendedLicense:tp}});var Ji=g((kce,GN)=>{"use strict";var Qo=require("fs-extra"),vN=q_(),BN=require("crypto"),cK=require("moment"),lK=require("uuid").v4,tr=K(),np=require("path"),uK=J(),ci=P(),{totalmem:UN}=require("os"),_K=PN().ExtendedLicense,Wo="invalid license key format",dK="061183",fK="mofi25",EK="aes-256-cbc",hK=16,mK=32,HN=ne();HN.initSync();var rp;GN.exports={validateLicense:xN,generateFingerPrint:SK,licenseSearch:op,getLicense:RK,checkMemoryLimit:AK};function sp(){return np.join(HN.getHdbBasePath(),ci.LICENSE_KEY_DIR_NAME,ci.LICENSE_FILE_NAME)}a(sp,"getLicenseDirPath");function pK(){let e=sp();return np.join(e,ci.LICENSE_FILE_NAME)}a(pK,"getLicenseFilePath");function ip(){let e=sp();return np.join(e,ci.REG_KEY_FILE_NAME)}a(ip,"getFingerPrintFilePath");async function SK(){let e=ip();try{return await Qo.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await TK();throw tr.error(`Error writing fingerprint file to ${e}`),tr.error(t),new Error("There was an error generating the fingerprint")}}a(SK,"generateFingerPrint");async function TK(){let e=lK(),t=vN.hash(e),r=ip();try{await Qo.mkdirp(sp()),await Qo.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw tr.error(`Error writing fingerprint file to ${r}`),tr.error(n),new Error("There was an error generating the fingerprint")}return t}a(TK,"writeFingerprint");function xN(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:ci.RAM_ALLOCATION_ENUM.DEFAULT,version:ci.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return tr.error("empty license key passed to validate."),r;let n=ip(),s=!1;try{s=Qo.statSync(n)}catch(i){tr.error(i)}if(s){let i;try{i=Qo.readFileSync(n,"utf8")}catch{tr.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(fK),c=o[1];c=Buffer.concat([Buffer.from(c)],hK);let l=Buffer.concat([Buffer.from(i)],mK),_=BN.createDecipheriv(EK,l,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let u=null;try{u=_.update(o[0],"hex","utf8"),u.trim(),u+=_.final("utf8")}catch{let f=gK(o[0],i);if(f)u=f;else throw r.valid_license=!1,r.valid_machine=!1,console.error(Wo),tr.error(Wo),new Error(Wo)}let d;if(isNaN(u))try{d=JSON.parse(u),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(Wo),tr.error(Wo),new Error(Wo)}else r.exp_date=u;r.exp_date<cK().valueOf()&&(r.valid_date=!1),vN.validate(o[1],`${dK}${i}${t}`)||(r.valid_license=!1)}else r.valid_license=!1,r.valid_machine=!1;return r.valid_license&&r.valid_machine&&r.valid_date||tr.error("Invalid licence"),r}a(xN,"validateLicense");function gK(e,t){try{let r=BN.createDecipher("aes192",t),n=r.update(e,"hex","utf8");return n.trim(),n+=r.final("utf8"),n}catch{tr.warn("Check old license failed")}}a(gK,"checkOldLicense");function op(){let e=new _K,t=[];try{t=Qo.readFileSync(pK(),"utf-8").split(ci.NEW_LINE)}catch(r){r.code==="ENOENT"?tr.info("no license file found"):tr.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if(uK.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=xN(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){tr.error("There was an error parsing the license string."),tr.error(s),e.ram_allocation=ci.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return rp=e,e}a(op,"licenseSearch");async function RK(){return rp||await op(),rp}a(RK,"getLicense");function AK(){let e=op().ram_allocation,t=process.constrainedMemory?.()||UN();if(t=Math.round(Math.min(t,UN())/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(AK,"checkMemoryLimit")});var _n=g((Wce,tI)=>{"use strict";var VN="username is required",$N="nothing to update, must supply active, role or password to update",YN="password cannot be an empty string",KN="If role is specified, it cannot be empty.",WN="active must be true or false";tI.exports={addUser:LK,alterUser:MK,dropUser:UK,getSuperUser:xK,userInfo:vK,listUsers:X_,listUsersExternal:BK,setUsersToGlobal:Jo,findAndValidateUser:ZN,getClusterUser:GK,USERNAME_REQUIRED:VN,ALTERUSER_NOTHING_TO_UPDATE:$N,EMPTY_PASSWORD:YN,EMPTY_ROLE:KN,ACTIVE_BOOLEAN:WN};var QN=un(),OK=Ki(),lp=q_(),zN=dN(),JN=Fr(),up=Os(),Vr=J(),XN=require("validate.js"),Oe=K(),{promisify:bK}=require("util"),_p=As(),FN=P(),qN=ct(),yK=pr(),$ce=ne(),Yce=Ji(),NK=Fi(),{table:Kce}=(Ae(),ie(ke)),{handleHDBError:es,hdb_errors:IK}=se(),{HTTP_STATUS_CODES:ts,AUTHENTICATION_ERROR_MSGS:ap,HDB_ERROR_MSGS:zo}=IK,{UserEventMsg:dp}=Mn(),cp=require("lodash"),{server:fp}=(fr(),ie(Bi)),wK=K();fp.getUser=(e,t)=>ZN(e,t,t!=null);var jN={username:!0,active:!0,role:!0,password:!0},kN=new Map,J_=JN.searchByValue,CK=JN.searchByHash,DK=bK(OK.delete);async function LK(e){let t=XN.cleanAttributes(e,jN),r=zN.addUserValidation(t);if(r)throw es(new Error,r.message,ts.BAD_REQUEST,void 0,void 0,!0);let n={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["id","permission","role"]},s;try{s=await J_(n),s=s&&Array.from(s)}catch(l){throw Oe.error("There was an error searching for a role in add user"),Oe.error(l),l}if(!s||s.length<1)throw es(new Error,zo.ROLE_NAME_NOT_FOUND(t.role),ts.NOT_FOUND,void 0,void 0,!0);if(s.length>1)throw es(new Error,zo.DUP_ROLES_FOUND(t.role),ts.CONFLICT,void 0,void 0,!0);s[0].permission.cluster_user===!0&&(t.hash=_p.encrypt(t.password)),t.password=lp.hash(t.password),t.role=s[0].id;let i={operation:"insert",schema:"system",table:"hdb_user",records:[t]},o;try{o=await QN.insert(i)}catch(l){throw Oe.error("There was an error searching for a user."),Oe.error(l),l}Oe.debug(o);try{await Jo()}catch(l){throw Oe.error("Got an error setting users to global"),Oe.error(l),l}if(o.skipped_hashes.length===1)throw es(new Error,zo.USER_ALREADY_EXISTS(t.username),ts.CONFLICT,void 0,void 0,!0);let c=Object.assign({},t);return c.role=s[0],up.signalUserChange(new dp(process.pid)),`${c.username} successfully added`}a(LK,"addUser");async function MK(e){let t=XN.cleanAttributes(e,jN);if(Vr.isEmptyOrZeroLength(t.username))throw new Error(VN);if(Vr.isEmptyOrZeroLength(t.password)&&Vr.isEmptyOrZeroLength(t.role)&&Vr.isEmptyOrZeroLength(t.active))throw new Error($N);if(!Vr.isEmpty(t.password)&&Vr.isEmptyOrZeroLength(t.password.trim()))throw new Error(YN);if(!Vr.isEmpty(t.active)&&!Vr.isBoolean(t.active))throw new Error(WN);let r=PK(t.username);if(!Vr.isEmpty(t.password)&&!Vr.isEmptyOrZeroLength(t.password.trim())&&(r&&(t.hash=_p.encrypt(t.password)),t.password=lp.hash(t.password)),t.role==="")throw new Error(KN);if(t.role){let i={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]},o;try{o=Array.from(await J_(i)||[])}catch(c){throw Oe.error("Got an error searching for a role."),Oe.error(c),c}if(!o||o.length===0){let c=zo.ALTER_USER_ROLE_NOT_FOUND(t.role);throw Oe.error(c),es(new Error,c,ts.NOT_FOUND,void 0,void 0,!0)}if(o.length>1){let c=zo.ALTER_USER_DUP_ROLES(t.role);throw Oe.error(c),es(new Error,c,ts.CONFLICT,void 0,void 0,!0)}t.role=o[0].id}let n={operation:"update",schema:"system",table:"hdb_user",records:[t]},s;try{s=await QN.update(n)}catch(i){throw Oe.error("Error during update."),Oe.error(i),i}try{await Jo()}catch(i){throw Oe.error("Got an error setting users to global"),Oe.error(i),i}return up.signalUserChange(new dp(process.pid)),s}a(MK,"alterUser");function PK(e){let t=!1,r=global.hdb_users.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(PK,"isClusterUser");async function UK(e){try{let t=zN.dropUserValidation(e);if(t)throw new Error(t);let r={table:"hdb_user",schema:"system",hash_values:[e.username]};if(Vr.isEmpty(global.hdb_users.get(e.username)))throw es(new Error,zo.USER_NOT_EXIST(e.username),ts.NOT_FOUND,void 0,void 0,!0);let n;try{n=await DK(r)}catch(s){throw Oe.error("Got an error deleting a user."),Oe.error(s),s}Oe.debug(n);try{await Jo()}catch(s){throw Oe.error("Got an error setting users to global."),Oe.error(s),s}return up.signalUserChange(new dp(process.pid)),`${e.username} successfully deleted`}catch(t){throw t}}a(UK,"dropUser");async function vK(e){let t={};try{if(!e||!e.hdb_user)return"There was no user info in the body";t=cp.cloneDeep(e.hdb_user);let r={schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]},n;try{n=await CK(r)}catch(s){throw Oe.error("Got an error searching for a role."),Oe.error(s),s}t.role=n[0],delete t.password,delete t.refresh_token,delete t.hash}catch(r){throw Oe.error(r),r}return t}a(vK,"userInfo");async function BK(){let e;try{e=await X_()}catch(t){throw Oe.error("Got an error listing users."),Oe.error(t),t}try{e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token})}catch{throw new Error("there was an error massaging the user data")}return[...e.values()]}a(BK,"listUsersExternal");async function X_(){try{let e={schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]},t;try{t=await J_(e)}catch(o){throw Oe.error("Got an error searching for roles."),Oe.error(o),o}let r={};for(let o of t)r[o.id]=cp.cloneDeep(o);if(Object.keys(r).length===0)return null;let n={schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]},s;try{s=await J_(n)}catch(o){throw Oe.error("Got an error searching for users."),Oe.error(o),o}let i=new Map;for(let o of s)o=cp.cloneDeep(o),o.role=r[o.role],HK(o.role),i.set(o.username,o);return i}catch(e){throw Oe.error("got an error listing users"),Oe.error(e),Vr.errorizeMessage(e)}return null}a(X_,"listUsers");function HK(e){try{if(!e){Oe.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(NK)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}catch(t){Oe.error("Got an error trying to set system permissions."),Oe.error(t)}}a(HK,"appendSystemTablesToRole");async function Jo(){try{let e=await X_();global.hdb_users=e}catch(e){throw Oe.error(e),e}}a(Jo,"setUsersToGlobal");async function ZN(e,t,r=!0){global.hdb_users||await Jo();let n=global.hdb_users.get(e);if(!n){if(!r)return{username:e};throw es(new Error,ap.GENERIC_AUTH_FAIL,ts.UNAUTHORIZED,void 0,void 0,!0)}if(n&&!n.active)throw es(new Error,ap.USER_INACTIVE,ts.UNAUTHORIZED,void 0,void 0,!0);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(kN.get(t)===n.password)return s;if(lp.validate(n.password,t))kN.set(t,n.password);else throw es(new Error,ap.GENERIC_AUTH_FAIL,ts.UNAUTHORIZED,void 0,void 0,!0)}return s}a(ZN,"findAndValidateUser");async function xK(){global.hdb_users||await Jo();for(let[,e]of global.hdb_users)if(e.role.role==="super_user")return e}a(xK,"getSuperUser");async function GK(){let e=await X_(),t=yK.getConfigFromFile(FN.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!Vr.isEmpty(r)&&r?.role?.role===FN.ROLE_TYPES_ENUM.CLUSTER_USER)return r.decrypt_hash=_p.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+qN.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+qN.SERVER_SUFFIX.ADMIN,r}a(GK,"getClusterUser");var eI=[];fp.invalidateUser=function(e){for(let t of eI)try{t(e)}catch(r){wK.error("Error invalidating user",r)}};fp.onInvalidatedUser=function(e){eI.push(e)}});var Kc=g((Xce,iI)=>{"use strict";var Xi=K(),$r=P(),FK=Py(),zce=si(),Jce=ni(),qK=_n(),{validateEvent:rI}=Mn(),Yc=Cn(),kK=require("process"),{resetDatabases:VK}=(Ae(),ie(ke)),$K={[$r.ITC_EVENT_TYPES.SCHEMA]:YK,[$r.ITC_EVENT_TYPES.USER]:sI};async function YK(e){let t=rI(e);if(t){Xi.error(t);return}Xi.trace("ITC schemaHandler received schema event:",e),await FK(e.message),await KK(e.message)}a(YK,"schemaHandler");async function KK(e){try{Yc.resetReadTxn($r.SYSTEM_SCHEMA_NAME,$r.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),Yc.resetReadTxn($r.SYSTEM_SCHEMA_NAME,$r.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),Yc.resetReadTxn($r.SYSTEM_SCHEMA_NAME,$r.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=VK();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){Xi.error(t)}}a(KK,"syncSchemaMetadata");var nI=[];async function sI(e){try{try{Yc.resetReadTxn($r.SYSTEM_SCHEMA_NAME,$r.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),Yc.resetReadTxn($r.SYSTEM_SCHEMA_NAME,$r.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){Xi.warn(r)}let t=rI(e);if(t){Xi.error(t);return}Xi.trace(`ITC userHandler ${$r.HDB_ITC_CLIENT_PREFIX}${kK.pid} received user event:`,e),await qK.setUsersToGlobal();for(let r of nI)r()}catch(t){Xi.error(t)}}a(sI,"userHandler");sI.addListener=function(e){nI.push(e)};iI.exports=$K});var Mn=g((nle,aI)=>{"use strict";var Zce=K(),Ep=J(),WK=P(),{ITC_ERRORS:Wc}=vr(),{parentPort:ele,threadId:QK,isMainThread:zK,workerData:tle}=require("worker_threads"),{onMessageFromWorkers:JK,broadcast:rle,broadcastWithAcknowledgement:XK}=it();aI.exports={sendItcEvent:jK,validateEvent:oI,SchemaEventMsg:ZK,UserEventMsg:eW};var j_;JK(async(e,t)=>{j_=j_||Kc(),oI(e),j_[e.type]&&await j_[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function jK(e){return!zK&&e.message&&(e.message.originator=QK),XK(e)}a(jK,"sendItcEvent");function oI(e){if(typeof e!="object")return Wc.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||Ep.isEmpty(e.type))return Wc.MISSING_TYPE;if(!e.hasOwnProperty("message")||Ep.isEmpty(e.message))return Wc.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||Ep.isEmpty(e.message.originator))return Wc.MISSING_ORIGIN;if(WK.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return Wc.INVALID_EVENT(e.type)}a(oI,"validateEvent");function ZK(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(ZK,"SchemaEventMsg");function eW(e){this.originator=e}a(eW,"UserEventMsg")});var Os=g((ole,_I)=>{"use strict";var cI=P(),ile=J(),Z_=K(),lI=Dy(),Xo,{sendItcEvent:uI}=Mn();function tW(e){try{Z_.trace("signalSchemaChange called with message:",e),Xo=Xo||Kc();let t=new lI(cI.ITC_EVENT_TYPES.SCHEMA,e);return Xo.schema(t),uI(t)}catch(t){Z_.error(t)}}a(tW,"signalSchemaChange");function rW(e){try{Z_.trace("signalUserChange called with message:",e),Xo=Xo||Kc();let t=new lI(cI.ITC_EVENT_TYPES.USER,e);return Xo.user(t),uI(t)}catch(t){Z_.error(t)}}a(rW,"signalUserChange");_I.exports={signalSchemaChange:tW,signalUserChange:rW}});var ed=g((cle,fI)=>{"use strict";var dI=J(),nW=P(),sW=K(),iW=M_(),oW=L_(),aW=Os(),{SchemaEventMsg:cW}=Mn(),lW="already exists in";fI.exports=uW;async function uW(e,t,r){if(dI.isEmptyOrZeroLength(r))return r;let n=[];dI.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 _W(e,t.schema,t.name,i)})),s}a(uW,"lmdbCheckForNewAttributes");async function _W(e,t,r,n){let s=new oW(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await dW(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(lW))sW.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(_W,"createNewAttribute");async function dW(e){let t;return t=await iW(e),aW.signalSchemaChange(new cW(process.pid,nW.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(dW,"createAttribute")});var jo=g((ule,EI)=>{"use strict";var hp=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}};EI.exports=hp});var mI=g((dle,hI)=>{"use strict";var fW=jo(),EW=P().OPERATIONS_ENUM,mp=class extends fW{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(EW.INSERT,r,n,s,i),this.records=t}};hI.exports=mp});var SI=g((Ele,pI)=>{"use strict";var hW=jo(),mW=P().OPERATIONS_ENUM,pp=class extends hW{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(mW.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};pI.exports=pp});var gI=g((mle,TI)=>{"use strict";var pW=jo(),SW=P().OPERATIONS_ENUM,Sp=class extends pW{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(SW.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};TI.exports=Sp});var AI=g((Sle,RI)=>{"use strict";var TW=jo(),gW=P().OPERATIONS_ENUM,Tp=class extends TW{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(gW.DELETE,n,s,t,i),this.original_records=r}};RI.exports=Tp});var Qc=g((Rle,NI)=>{"use strict";var gle=require("path"),OI=We(),RW=mI(),AW=SI(),OW=gI(),bW=AI(),Zo=dt(),bI=J(),{CONFIG_PARAMS:yW}=P(),yI=ne();yI.initSync();var td=P().OPERATIONS_ENUM,{getTransactionAuditStorePath:NW}=ze();NI.exports=IW;async function IW(e,t){if(yI.get(yW.LOGGING_AUDITLOG)===!1)return;let r=NW(e.schema,e.table),n=await OI.openEnvironment(r,e.table,!0),s=wW(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){OI.initializeDBIs(n,Zo.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Zo.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[Zo.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[Zo.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),bI.isEmpty(s.user_name)||n.dbis[Zo.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[Zo.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(IW,"writeTransaction");function wW(e,t){let r=bI.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===td.INSERT)return new RW(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===td.UPDATE)return new AW(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===td.UPSERT)return new OW(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===td.DELETE)return new bW(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(wW,"createTransactionObject")});var gp=g((ble,II)=>{"use strict";var CW=Fc(),Ole=Oc(),zc=P(),DW=bc(),LW=Vo().insertRecords,MW=We(),PW=K(),UW=ed(),{getSchemaPath:vW}=ze(),BW=Qc();II.exports=HW;async function HW(e){try{let{schema_table:t,attributes:r}=CW(e);DW(e,r,t.hash_attribute),e.schema!==zc.SYSTEM_SCHEMA_NAME&&(r.includes(zc.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(zc.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(zc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(zc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await UW(e.hdb_auth_header,t,r),s=vW(e.schema,e.table),i=await MW.openEnvironment(s,e.table),o=await LW(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await BW(e,o)}catch(c){PW.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(HW,"lmdbCreateRecords")});var DI=g((Nle,CI)=>{"use strict";var wI=P(),xW=gp(),GW=Oc(),FW=require("fs-extra"),{getSchemaPath:qW}=ze();CI.exports=kW;async function kW(e){let t=[{name:e.schema,createddate:Date.now()}],r=new GW(wI.SYSTEM_SCHEMA_NAME,wI.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await xW(r),await FW.mkdirp(qW(e.schema))}a(kW,"lmdbCreateSchema")});var MI=g((wle,LI)=>{"use strict";var Rp=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}};LI.exports=Rp});var BI=g((Ple,vI)=>{"use strict";var PI=We(),Ap=Br(),Op=vr().LMDB_ERRORS_ENUM,VW=dt(),UI=K(),Dle=J(),$W=require("lmdb"),YW=MI(),KW=P(),{OVERFLOW_MARKER:Lle,MAX_SEARCH_KEY_LENGTH:Mle}=VW,WW=KW.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function QW(e,t,r,n){if(Ap.validateEnv(e),t===void 0)throw new Error(Op.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(Op.IDS_REQUIRED):new Error(Op.IDS_MUST_BE_ITERABLE);try{let s=PI.listDBIs(e);PI.initializeDBIs(e,t,s);let i=new YW,o,c=[],l=[];for(let E=0,f=r.length;E<f;E++)try{o=r[E];let h=e.dbis[t].get(o);if(!h||n&&h[WW]>n){i.skipped.push(o);continue}let p=e.dbis[t].ifVersion(o,$W.IF_EXISTS,()=>{e.dbis[t].remove(o);for(let S=0;S<s.length;S++){let T=s[S];if(!h.hasOwnProperty(T)||T===t)continue;let A=e.dbis[T],b=h[T];if(b!=null)try{let I=Ap.getIndexedValues(b);if(I)for(let B=0,U=I.length;B<U;B++)A.remove(I[B],o)}catch{UI.warn(`cannot delete from attribute: ${T}, ${b}:${o}`)}}});c.push(p),l.push(o),i.original_records.push(h)}catch(h){UI.warn(h),i.skipped.push(o)}let _=[],u=await Promise.all(c);for(let E=0,f=u.length;E<f;E++)u[E]===!0?i.deleted.push(l[E]):(i.skipped.push(l[E]),_.push(E));let d=0;for(let E=0;E<_.length;E++){let f=_[E];i.original_records.splice(f-d,1),d++}return i.txn_time=Ap.getNextMonotonicTime(),i}catch(s){throw s}}a(QW,"deleteRecords");vI.exports={deleteRecords:QW}});var Jc=g((vle,xI)=>{"use strict";var ea=J(),zW=BI(),JW=We(),{getSchemaPath:XW}=ze(),jW=Qc(),ZW=K();xI.exports=eQ;async function eQ(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(ea.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(ea.isEmptyOrZeroLength(e.hash_values)&&!ea.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];ea.isEmpty(l)||e.hash_values.push(l)}}if(ea.isEmptyOrZeroLength(e.hash_values))return HI([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(ea.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=XW(e.schema,e.table),i=await JW.openEnvironment(s,e.table),o=await zW.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await jW(e,o)}catch(c){ZW.error(`unable to write transaction due to ${c.message}`)}return HI(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(eQ,"lmdbDeleteRecords");function HI(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(HI,"createDeleteResponse")});var yp=g((xle,GI)=>{"use strict";var tQ=P(),Hle=Br();function bp(e,t){let r=Object.create(null);if(t.length===1&&tQ.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(bp,"parseRow");function rQ(e,t,r,n){let s=bp(r,e);n.push(s)}a(rQ,"searchAll");function nQ(e,t,r,n){let s=bp(r,e);n[t]=s}a(nQ,"searchAllToMap");function sQ(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(sQ,"iterateDBI");function ji(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(ji,"pushResults");function iQ(e,t,r,n,s,i){t.toString().endsWith(e)&&ji(t,r,n,s,i)}a(iQ,"endsWith");function oQ(e,t,r,n,s,i){t.toString().includes(e)&&ji(t,r,n,s,i)}a(oQ,"contains");function aQ(e,t,r,n,s,i){t>e&&ji(t,r,n,s,i)}a(aQ,"greaterThanCompare");function cQ(e,t,r,n,s,i){t>=e&&ji(t,r,n,s,i)}a(cQ,"greaterThanEqualCompare");function lQ(e,t,r,n,s,i){t<e&&ji(t,r,n,s,i)}a(lQ,"lessThanCompare");function uQ(e,t,r,n,s,i){t<=e&&ji(t,r,n,s,i)}a(uQ,"lessThanEqualCompare");GI.exports={parseRow:bp,searchAll:rQ,searchAllToMap:nQ,iterateDBI:sQ,endsWith:iQ,contains:oQ,greaterThanCompare:aQ,greaterThanEqualCompare:cQ,lessThanCompare:lQ,lessThanEqualCompare:uQ,pushResults:ji}});var ta=g((Vle,KI)=>{"use strict";var li=We(),Fle=K(),Yr=Br(),rd=dt(),Et=vr().LMDB_ERRORS_ENUM,qle=J(),_Q=P(),nd=yp(),{parseRow:dQ}=nd,kle=require("lmdb"),{OVERFLOW_MARKER:FI,MAX_SEARCH_KEY_LENGTH:fQ}=rd;function qI(e,t,r,n=!1,s=void 0,i=void 0){return Zi(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(qI,"iterateFullIndex");function Xc(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,_=!1){return Zi(e,t,r,(u,d,E,f)=>{let A={transaction:u,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!l:!_,exclusiveStart:i===!0?_:l};return f===r?(A.values=!1,d.getRange(A).map(b=>({value:b}))):d.getRange(A)})}a(Xc,"iterateRangeBetween");function Zi(e,t,r,n){let s=e.database||e,i=li.openDBI(s,r);i[rd.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&li.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(Zi,"setupTransaction");function kI(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(FI)){if(!s)if(r)s=li.openDBI(e,r);else{let l=li.listDBIs(e);for(let _=0,u=l.length;_<u&&(s=li.openDBI(e,l[_]),!s[rd.DBI_DEFINITION_NAME].is_hash_attribute);_++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(kI,"getOverflowCheck");function EQ(e,t,r,n=!1,s=void 0,i=void 0){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);return Zi(e,t,t,(o,c,l)=>(sd(r),r=jc(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(_=>dQ(_.value,r))))}a(EQ,"searchAll");function hQ(e,t,r,n=!1,s=void 0,i=void 0){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);sd(r),r=jc(e.database||e,r);let o=new Map;for(let{key:c,value:l}of qI(e,t,t,n,s,i))o.set(c,nd.parseRow(l,r));return o}a(hQ,"searchAllToMap");function mQ(e,t,r=!1,n=void 0,s=void 0){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=qI(e,void 0,t,r,n,s),c=o.transaction,l=kI(c.database,c,void 0,t);for(let{key:_,value:u}of o){let d=l(_,u);i[d]===void 0&&(i[d]=[]),i[d].push(u)}return i}a(mQ,"iterateDBI");function pQ(e,t){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);return li.statDBI(e,t).entryCount}a(pQ,"countAll");function SQ(e,t,r,n,s=!1,i=void 0,o=void 0){return ui(e,r,n),Zi(e,t,r,(c,l,_,u)=>(n=Yr.convertKeyValueToWrite(n),u===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(SQ,"equals");function TQ(e,t,r){return ui(e,t,r),li.openDBI(e,t).getValuesCount(r)}a(TQ,"count");function gQ(e,t,r,n,s=!1,i=void 0,o=void 0){return ui(e,r,n),Zi(e,null,r,(c,l)=>{n=Yr.convertKeyValueToWrite(n);let _=!0;typeof n=="number"&&(_=!1);let u;if(s===!0){let d;for(let E of l.getKeys({transaction:c,start:n}))if(!E.startsWith(n)){d=E;break}return d!==void 0&&(Number.isInteger(o)?o++:i++),u=l.getRange({transaction:c,start:d,end:void 0,reverse:s,limit:i,offset:o}).map(E=>{let{key:f}=E;if(f!==d){if(f.toString().startsWith(n))return E;if(_===!0)return u.DONE}}),u.filter(E=>E)}else return u=l.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(d=>{if(d.key.toString().startsWith(n))return d;if(_===!0)return u.DONE}),_?u:u.filter(d=>d)})}a(gQ,"startsWith");function RQ(e,t,r,n,s=!1,i=void 0,o=void 0){return VI(e,t,r,n,s,i,o,!0)}a(RQ,"endsWith");function VI(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return ui(e,r,n),Zi(e,null,r,(l,_,u,d)=>{let E=kI(u,l,d,r);return o=Number.isInteger(o)?o:0,_.getKeys({transaction:l,end:s?!1:void 0,reverse:s}).flatMap(f=>{let h=f.toString();return h.endsWith(FI)?_.getValues(f,{transaction:l}).map(p=>{let S=E(f,p);if(c?S.endsWith(n):S.includes(n))return{key:S,value:p}}).filter(p=>p):(c?h.endsWith(n):h.includes(n))?_[rd.DBI_DEFINITION_NAME].is_hash_attribute?{key:f,value:f}:_.getValues(f,{transaction:l}).map(p=>({key:f,value:p})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a(VI,"contains");function AQ(e,t,r,n,s=!1,i=void 0,o=void 0){ui(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),Xc(e,t,r,n,l,s,i,o,!0,!1)}a(AQ,"greaterThan");function OQ(e,t,r,n,s=!1,i=void 0,o=void 0){ui(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),Xc(e,t,r,n,l,s,i,o,!1,!1)}a(OQ,"greaterThanEqual");function bQ(e,t,r,n,s=!1,i=void 0,o=void 0){ui(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),Xc(e,t,r,l,n,s,i,o,!1,!0)}a(bQ,"lessThan");function yQ(e,t,r,n,s=!1,i=void 0,o=void 0){ui(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),Xc(e,t,r,l,n,s,i,o,!1,!1)}a(yQ,"lessThanEqual");function NQ(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(Yr.validateEnv(e),r===void 0)throw new Error(Et.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(Et.START_VALUE_REQUIRED);if(s===void 0)throw new Error(Et.END_VALUE_REQUIRED);if(n=Yr.convertKeyValueToWrite(n),s=Yr.convertKeyValueToWrite(s),n>s)throw new Error(Et.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return Xc(e,t,r,n,s,i,o,c)}a(NQ,"between");function IQ(e,t,r,n){Yr.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);if(sd(r),r=jc(s,r),n===void 0)throw new Error(Et.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=nd.parseRow(c,r)),o}a(IQ,"searchByHash");function wQ(e,t,r){Yr.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Et.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(wQ,"checkHashExists");function CQ(e,t,r,n,s=[]){return YI(e,t,r,n,s),$I(e,t,r,n,s).map(i=>i[1])}a(CQ,"batchSearchByHash");function DQ(e,t,r,n,s=[]){YI(e,t,r,n,s);let i=new Map;for(let[o,c]of $I(e,t,r,n,s))i.set(o,c);return i}a(DQ,"batchSearchByHashToMap");function $I(e,t,r,n,s=[]){return Zi(e,t,t,(i,o,c)=>{r=jc(c,r);let l=r.length<3;return n.map(_=>{let u=c.dbis[t].get(_,{transaction:i,lazy:l});if(u)return[_,nd.parseRow(u,r)];s.push(_)}).filter(_=>_)})}a($I,"batchHashSearch");function YI(e,t,r,n,s){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);if(sd(r),n==null)throw new Error(Et.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(Et.IDS_MUST_BE_ITERABLE)}a(YI,"initializeBatchSearchByHash");function sd(e){if(!Array.isArray(e))throw e===void 0?new Error(Et.FETCH_ATTRIBUTES_REQUIRED):new Error(Et.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(sd,"validateFetchAttributes");function ui(e,t,r){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Et.SEARCH_VALUE_REQUIRED);if(r?.length>fQ)throw new Error(Et.SEARCH_VALUE_TOO_LARGE)}a(ui,"validateComparisonFunctions");function jc(e,t){return t.length===1&&_Q.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=li.listDBIs(e)),t}a(jc,"setGetWholeRowAttributes");KI.exports={searchAll:EQ,searchAllToMap:hQ,count:TQ,countAll:pQ,equals:SQ,startsWith:gQ,endsWith:RQ,contains:VI,searchByHash:IQ,setGetWholeRowAttributes:jc,batchSearchByHash:CQ,batchSearchByHashToMap:DQ,checkHashExists:wQ,iterateDBI:mQ,greaterThan:AQ,greaterThanEqual:OQ,lessThan:bQ,lessThanEqual:yQ,between:NQ}});var ra=g((Yle,XI)=>{var WI=require("lodash"),QI=at(),he=require("joi"),LQ=J(),{hdb_schema_table:Zc,checkValidTable:zI,hdb_table:JI,hdb_database:id}=Xn(),{handleHDBError:MQ,hdb_errors:PQ}=se(),{getDatabases:UQ}=(Ae(),ie(ke)),{HTTP_STATUS_CODES:vQ}=PQ,BQ=he.object({database:id,schema:id,table:JI,search_attribute:Zc,search_value:he.any().required(),get_attributes:he.array().min(1).items(he.alternatives(Zc,he.object())).optional(),desc:he.bool(),limit:he.number().integer().min(1),offset:he.number().integer().min(0)}),HQ=he.object({database:id,schema:id,table:JI,operator:he.string().valid("and","or").default("and").lowercase(),offset:he.number().integer().min(0),limit:he.number().integer().min(1),get_attributes:he.array().min(1).items(he.alternatives(Zc,he.object())).optional(),sort:he.object({attribute:he.alternatives(Zc,he.array().min(1)),descending:he.bool().optional()}).optional(),conditions:he.array().min(1).items(he.alternatives(he.object({operator:he.string().valid("and","or").default("and").lowercase(),conditions:he.array()}),he.object({search_attribute:he.alternatives(Zc,he.array().min(1)),search_type:he.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:he.when("search_type",{switch:[{is:"equals",then:he.any()},{is:"between",then:he.array().items(he.alternatives([he.string(),he.number()])).length(2)}],otherwise:he.alternatives(he.string(),he.number())}).required()}))).required()});XI.exports=function(e,t){let r=null;switch(t){case"value":r=QI.validateBySchema(e,BQ);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(zI("database",e.schema)),i(zI("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=QI.validateBySchema(e,HQ);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=LQ.checkGlobalSchemaTable(e.schema,e.table);if(s)return MQ(new Error,s,vQ.NOT_FOUND);let o=UQ()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let l=a(u=>{for(let d=0,E=u.conditions.length;d<E;d++){let f=u.conditions[d];f.conditions?l(f):c.push(f.search_attribute)}},"addConditions");t==="conditions"&&l(e);let _=WI.filter(c,u=>u!=="*"&&!u.startsWith?.("$")&&u.attribute!=="*"&&!Array.isArray(u)&&!u.name&&!WI.some(o,d=>d===u||d.attribute===u||d.attribute===u.attribute));if(_&&_.length>0){let u=_.join(", ");return u=u.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${u}'`)}}return r}});var Np=g((Wle,jI)=>{"use strict";var xQ=We(),GQ=ra(),{getSchemaPath:FQ}=ze();jI.exports=qQ;function qQ(e){let t=GQ(e,"hashes");if(t)throw t;let r=FQ(e.schema,e.table);return xQ.openEnvironment(r,e.table)}a(qQ,"initialize")});var Ip=g((zle,ZI)=>{"use strict";var kQ=ta(),VQ=Np();ZI.exports=$Q;async function $Q(e){let t=await VQ(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return kQ.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a($Q,"lmdbGetDataByHash")});var na=g((Xle,ew)=>{"use strict";var wp=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};ew.exports=wp});var rw=g((eue,tw)=>{"use strict";var Zle=na(),YQ=ta(),KQ=Np();tw.exports=WQ;async function WQ(e){let t=await KQ(e),r=global.hdb_schema[e.schema][e.table];return YQ.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(WQ,"lmdbSearchByHash")});var rs=g((rue,nw)=>{"use strict";var Cp=class{static{a(this,"SearchObject")}constructor(t,r,n,s,i,o,c,l=!1,_=void 0,u=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=_,this.offset=u}};nw.exports=Cp});var od=g((sue,lw)=>{"use strict";var rr=ta(),QQ=We(),zQ=J(),me=dt(),eo=P(),JQ=Fi(),sw=vr().LMDB_ERRORS_ENUM,{getSchemaPath:XQ}=ze(),bs=eo.SEARCH_WILDCARDS;async function jQ(e,t,r){let n;e.schema===eo.SYSTEM_SCHEMA_NAME?n=JQ[e.table]:n=global.hdb_schema[e.schema][e.table];let s=cw(e,n.hash_attribute,r,t);return ow(e,s,n.hash_attribute,r)}a(jQ,"prepSearch");async function ow(e,t,r,n){let s=XQ(e.schema,e.table),i=await QQ.openEnvironment(s,e.table),o=aw(i,e,t,r),c=o.transaction||i;if([me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,me.SEARCH_TYPES.SEARCH_ALL,me.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(ZQ(e,r)===!1){let u=e.search_attribute;if(u===r)return n?iw(o,()=>!0):o.map(E=>({[r]:E.key}));let d=a(E=>({[r]:E.value,[u]:E.key}),"toObject");return n?iw(o,d):o.map(d)}let _=e.search_attribute===r?o.map(u=>u.key):o.map(u=>u.value);return n===!0?rr.batchSearchByHashToMap(c,r,e.get_attributes,_):rr.batchSearchByHash(c,r,e.get_attributes,_)}a(ow,"executeSearch");function aw(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 me.SEARCH_TYPES.EQUALS:s=rr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.CONTAINS:s=rr.contains(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.ENDS_WITH:case me.SEARCH_TYPES._ENDS_WITH:s=rr.endsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.STARTS_WITH:case me.SEARCH_TYPES._STARTS_WITH:s=rr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return rr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return rr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case me.SEARCH_TYPES.SEARCH_ALL:return rr.searchAll(e,n,t.get_attributes,o,c,l);case me.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return rr.searchAllToMap(e,n,t.get_attributes,o,c,l);case me.SEARCH_TYPES.BETWEEN:s=rr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,l);break;case me.SEARCH_TYPES.GREATER_THAN:case me.SEARCH_TYPES._GREATER_THAN:s=rr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.GREATER_THAN_EQUAL:case me.SEARCH_TYPES._GREATER_THAN_EQUAL:s=rr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.LESS_THAN:case me.SEARCH_TYPES._LESS_THAN:s=rr.lessThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.LESS_THAN_EQUAL:case me.SEARCH_TYPES._LESS_THAN_EQUAL:s=rr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;default:return Object.create(null)}return s}a(aw,"searchByType");function iw(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(iw,"createMapFromIterable");function ZQ(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(ZQ,"checkToFetchMore");function cw(e,t,r,n){if(zQ.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),bs.indexOf(s)>-1)return r===!0?me.SEARCH_TYPES.SEARCH_ALL_TO_MAP:me.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(bs[0])<0&&s.indexOf(bs[1])<0)return c===!0?r===!0?me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:me.SEARCH_TYPES.EQUALS;if(bs.indexOf(i)>=0&&bs.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),me.SEARCH_TYPES.CONTAINS;if(bs.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),me.SEARCH_TYPES.ENDS_WITH;if(bs.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),me.SEARCH_TYPES.STARTS_WITH;if(s.includes(bs[0])||s.includes(bs[1]))return me.SEARCH_TYPES.EQUALS;throw new Error(sw.UNKNOWN_SEARCH_TYPE)}else switch(n){case eo.VALUE_SEARCH_COMPARATORS.BETWEEN:return me.SEARCH_TYPES.BETWEEN;case eo.VALUE_SEARCH_COMPARATORS.GREATER:return me.SEARCH_TYPES.GREATER_THAN;case eo.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return me.SEARCH_TYPES.GREATER_THAN_EQUAL;case eo.VALUE_SEARCH_COMPARATORS.LESS:return me.SEARCH_TYPES.LESS_THAN;case eo.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return me.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(sw.UNKNOWN_SEARCH_TYPE)}}a(cw,"createSearchTypeFromSearchObject");lw.exports={executeSearch:ow,createSearchTypeFromSearchObject:cw,prepSearch:jQ,searchByType:aw}});var _w=g((aue,uw)=>{"use strict";var oue=rs(),ez=ra(),tz=J(),rz=P(),nz=od();uw.exports=sz;function sz(e,t){if(!tz.isEmpty(t)&&rz.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=ez(e,"value");if(n)throw n;return nz.prepSearch(e,t,!0)}a(sz,"lmdbGetDataByValue")});var el=g((uue,dw)=>{"use strict";var lue=rs(),iz=ra(),oz=J(),az=P(),cz=od();dw.exports=lz;async function lz(e,t){if(!oz.isEmpty(t)&&az.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=iz(e,"value");if(n)throw n;return cz.prepSearch(e,t,!1)}a(lz,"lmdbSearchByValue")});var Ew=g((fue,fw)=>{"use strict";var due=dt(),Dp=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}},Lp=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},Mp=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};fw.exports={SearchByConditionsObject:Dp,SearchCondition:Lp,SortAttribute:Mp}});var Tw=g((pue,Sw)=>{"use strict";var hue=Ew().SearchByConditionsObject,uz=rs(),_z=ra(),Pp=ta(),ad=dt(),{Resource:mue}=(an(),ie(Up)),pw=od(),dz=yp(),fz=require("lodash"),{getSchemaPath:Ez}=ze(),hw=We(),{handleHDBError:hz,hdb_errors:mz}=se(),{HTTP_STATUS_CODES:pz}=mz,Sz=1e8;Sw.exports=Tz;async function Tz(e){let t=_z(e,"conditions");if(t)throw hz(t,t.message,pz.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=Ez(e.schema,e.table),n=await hw.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let _ of e.conditions)hw.openDBI(n,_.search_attribute);let i=fz.sortBy(e.conditions,_=>{if(_.estimated_count===void 0){let u=_.search_type;u===ad.SEARCH_TYPES.EQUALS?_.estimated_count=Pp.count(n,_.search_attribute,_.search_value):u===ad.SEARCH_TYPES.CONTAINS||u===ad.SEARCH_TYPES.ENDS_WITH?_.estimated_count=1/0:_.estimated_count=Sz}return _.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await mw(o,e,i[0],s.hash_attribute),l;if(!e.operator||e.operator.toLowerCase()==="and"){let _=n.dbis[s.hash_attribute],u=i.slice(1).map(pw.filterByType),d=u.length,E=Pp.setGetWholeRowAttributes(n,e.get_attributes);l=c.map(f=>_.get(f,{transaction:o,lazy:!0})),d>0&&(l=l.filter(f=>{for(let h=0;h<d;h++)if(!u[h](f))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(f=>dz.parseRow(f,E))}else{for(let d=1;d<i.length;d++){let E=i[d],f=await mw(o,e,E,s.hash_attribute);c=c.concat(f)}let _=new Set,u=e.offset||0;c=c.filter(d=>_.has(d)?!1:(_.add(d),!0)).slice(u,e.limit&&e.limit+u),l=Pp.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(Tz,"lmdbSearchByConditions");async function mw(e,t,r,n){let s=new uz(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===ad.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,pw.searchByType(e,s,i,n).map(o=>o.value)}a(mw,"executeConditionSearch")});var tl=g((Tue,gw)=>{"use strict";var gz=P().OPERATIONS_ENUM,vp=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=gz.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};gw.exports=vp});var Bp=g((Rue,ww)=>{"use strict";var bw=rs(),yw=tl(),Nw=el(),Iw=Jc(),Sr=P(),Rw=J(),Aw=We(),{getTransactionAuditStorePath:Rz,getSchemaPath:Az}=ze(),Ow=K();ww.exports=Oz;async function Oz(e){try{if(Rw.isEmpty(global.hdb_schema[e.schema])||Rw.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await bz(e),await yz(e);let t=Az(e.schema,e.table);try{await Aw.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")Ow.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=Rz(e.schema,e.table);await Aw.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")Ow.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(Oz,"lmdbDropTable");async function bz(e){let t=new bw(Sr.SYSTEM_SCHEMA_NAME,Sr.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await Nw(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 yw(Sr.SYSTEM_SCHEMA_NAME,Sr.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await Iw(s)}a(bz,"deleteAttributesFromSystem");async function yz(e){let t=new bw(Sr.SYSTEM_SCHEMA_NAME,Sr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await Nw(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 yw(Sr.SYSTEM_SCHEMA_NAME,Sr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await Iw(s)}catch(i){throw i}}a(yz,"dropTableFromSystem")});var Dw=g((Oue,Cw)=>{"use strict";var Nz=require("fs-extra"),Iz=rs(),wz=na(),Cz=tl(),Dz=Bp(),Lz=Jc(),Mz=Ip(),Pz=el(),ys=P(),{getSchemaPath:Uz}=ze(),{handleHDBError:vz,hdb_errors:Bz}=se(),{HDB_ERROR_MSGS:Hz,HTTP_STATUS_CODES:xz}=Bz;Cw.exports=Gz;async function Gz(e){let t;try{t=await Fz(e.schema);let r=new Iz(ys.SYSTEM_SCHEMA_NAME,ys.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,ys.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[ys.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await Pz(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await Dz(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new Cz(ys.SYSTEM_SCHEMA_NAME,ys.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await Lz(s);let i=Uz(t);await Nz.remove(i)}catch(r){throw r}}a(Gz,"lmdbDropSchema");async function Fz(e){let t=new wz(ys.SYSTEM_SCHEMA_NAME,ys.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[ys.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await Mz(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw vz(new Error,Hz.SCHEMA_NOT_FOUND(e),xz.NOT_FOUND,void 0,void 0,!0);return n}a(Fz,"validateDropSchema")});var xp=g((yue,Lw)=>{"use strict";var Hp=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};Lw.exports=Hp});var Pw=g((wue,Mw)=>{"use strict";var qz=require("fs-extra"),cd=We(),{getTransactionAuditStorePath:kz}=ze(),Gp=dt(),Iue=xp();Mw.exports=Vz;async function Vz(e){let t;try{let r=kz(e.schema,e.table);await qz.mkdirp(r),t=await cd.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{cd.createDBI(t,Gp.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),cd.createDBI(t,Gp.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),cd.createDBI(t,Gp.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(Vz,"createTransactionsAuditEnvironment")});var Hw=g((Due,Bw)=>{"use strict";var Fp=P(),Uw=We(),$z=Vo(),{getSystemSchemaPath:Yz,getSchemaPath:Kz}=ze(),Wz=Fi(),Qz=M_(),qp=L_(),zz=K(),Jz=Pw(),Vp=Wz.hdb_table,vw=[];for(let e=0;e<Vp.attributes.length;e++)vw.push(Vp.attributes[e].attribute);Bw.exports=Xz;async function Xz(e,t){let r=Kz(t.schema,t.table),n=new qp(t.schema,t.table,Fp.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new qp(t.schema,t.table,Fp.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new qp(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await Uw.createEnvironment(r,t.table),e!==void 0){let o=await Uw.openEnvironment(Yz(),Fp.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await $z.insertRecords(o,Vp.hash_attribute,vw,[e]),n.skip_table_check=!0,s.skip_table_check=!0,i.skip_table_check=!0,await kp(n),await kp(s),await kp(i)}await Jz(t)}catch(o){throw o}}a(Xz,"lmdbCreateTable");async function kp(e){try{await Qz(e)}catch(t){zz.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(kp,"createAttribute")});var Gw=g((Mue,xw)=>{"use strict";var jz=Fc(),Zz=bc(),e2=ed(),rl=P(),t2=Vo().updateRecords,r2=We(),{getSchemaPath:n2}=ze(),s2=Qc(),i2=K();xw.exports=o2;async function o2(e){try{let{schema_table:t,attributes:r}=jz(e);Zz(e,r,t.hash_attribute),e.schema!==rl.SYSTEM_SCHEMA_NAME&&(r.includes(rl.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(rl.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(rl.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(rl.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await e2(e.hdb_auth_header,t,r),s=n2(e.schema,e.table),i=await r2.openEnvironment(s,e.table),o=await t2(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await s2(e,o)}catch(c){i2.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(o2,"lmdbUpdateRecords")});var qw=g((Uue,Fw)=>{"use strict";var a2=P().OPERATIONS_ENUM,$p=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=a2.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};Fw.exports=$p});var Vw=g((Hue,kw)=>{"use strict";var Bue=qw(),c2=Fc(),l2=bc(),u2=ed(),nl=P(),_2=Vo().upsertRecords,d2=We(),{getSchemaPath:f2}=ze(),E2=Qc(),h2=K(),{handleHDBError:m2,hdb_errors:p2}=se();kw.exports=S2;async function S2(e){let t;try{t=c2(e)}catch(l){throw m2(l,l.message,p2.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;l2(e,n,r.hash_attribute),e.schema!==nl.SYSTEM_SCHEMA_NAME&&(n.includes(nl.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(nl.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(nl.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(nl.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await u2(e.hdb_auth_header,r,n),i=f2(e.schema,e.table),o=await d2.openEnvironment(i,e.table),c=await _2(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await E2(e,c)}catch(l){h2.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(S2,"lmdbUpsertRecords")});var Yw=g((Gue,$w)=>{"use strict";var Yp=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};$w.exports=Yp});var Ww=g((que,Kw)=>{"use strict";var Kp=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}};Kw.exports=Kp});var Jw=g(($ue,zw)=>{"use strict";var Wp=We(),{getTransactionAuditStorePath:T2}=ze(),Vue=Yw(),sl=dt(),g2=J(),Qw=Ww(),R2=require("util").promisify,A2=R2(setTimeout),O2=1e4,b2=100;zw.exports=y2;async function y2(e){let t=T2(e.schema,e.table),r=await Wp.openEnvironment(t,e.table,!0),n=Wp.listDBIs(r);Wp.initializeDBIs(r,sl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new Qw;do s=await N2(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 A2(b2);while(s.transactions_deleted>0);return i}a(y2,"deleteAuditLogsBefore");async function N2(e,t){let r=new Qw;try{let n=e.dbis[sl.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[sl.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];g2.isEmpty(c)||(s=e.dbis[sl.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[sl.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>O2)break}return await s,r}catch(n){throw n}}a(N2,"deleteTransactions")});var jw=g((Kue,Xw)=>{"use strict";var Qp=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};Xw.exports=Qp});var eC=g((zue,Zw)=>{"use strict";var I2=rs(),w2=tl(),Que=jw(),ns=P(),C2=J(),zp=We(),D2=Fi(),L2=el(),M2=Jc(),{getSchemaPath:P2}=ze();Zw.exports=U2;async function U2(e,t=!0){let r;e.schema===ns.SYSTEM_SCHEMA_NAME?r=D2[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await B2(e),s=P2(e.schema,e.table),i=await zp.openEnvironment(s,e.table);return t===!0&&await v2(e,i,r.hash_attribute),zp.dropDBI(i,e.attribute),n}a(U2,"lmdbDropAttribute");async function v2(e,t,r){let n=zp.openDBI(t,r),s,i=e.attribute;for(let{key:o,value:c,version:l}of n.getRange({start:!1,versions:!0})){let _={};for(let u in c)u!==i&&(_[u]=c[u]);s=t.dbis[r].put(o,_,l)}await s}a(v2,"removeAttributeFromAllObjects");async function B2(e){let t=new I2(ns.SYSTEM_SCHEMA_NAME,ns.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,ns.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[ns.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,ns.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await L2(t)).filter(o=>o[ns.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(C2.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[ns.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new w2(ns.SYSTEM_SCHEMA_NAME,ns.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return M2(i)}a(B2,"dropAttributeFromSystem")});var oC=g((jue,iC)=>{"use strict";var Jp=We(),sa=dt(),Xue=Br(),Xp=P(),tC=J(),{getTransactionAuditStorePath:H2}=ze(),x2=ta(),ld=jo(),G2=K();iC.exports=F2;async function F2(e){let t=H2(e.schema,e.table),r=await Jp.openEnvironment(t,e.table,!0),n=Jp.listDBIs(r);Jp.initializeDBIs(r,sa.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case Xp.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return rC(r,e.search_values);case Xp.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,k2(r,e.search_values,s);case Xp.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return q2(r,e.search_values);default:return rC(r)}}a(F2,"readAuditLog");function rC(e,t=[0,Date.now()]){tC.isEmpty(t[0])&&(t[0]=0),tC.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[sa.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 ld,s))}a(rC,"searchTransactionsByTimestamp");function q2(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[sa.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,sC(e,i))}return Object.fromEntries(r)}a(q2,"searchTransactionsByUsername");function k2(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let _=t[c],u=x2.equals(e,sa.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,sa.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,_);for(let{value:d}of u){let E=Number(d);n.has(E)?n.get(E).push(_.toString()):n.set(E,[_.toString()])}}let s=Array.from(n.keys()),i=sC(e,s),o=new Map;for(let c=0;c<i.length;c++){let l=i[c],_=l.timestamp,u=n.get(_);nC(l,"records",r,u,o),nC(l,"original_records",r,u,o)}return Object.fromEntries(o)}a(k2,"searchTransactionsByHashValues");function nC(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 _=s.get(l),u=_[_.length-1];if(u.timestamp===i)u[t]=[c];else{let d=new ld(e.operation,e.user_name,i,void 0);d[t]=[c],_.push(d)}}else{let _=new ld(e.operation,e.user_name,i,void 0);_[t]=[c],s.set(l,[_])}}}a(nC,"loopRecords");function sC(e,t){let r=[];try{let n=e.dbis[sa.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 ld,i);r.push(o)}}catch(i){G2.warn(i)}return r}catch(n){throw n}}a(sC,"batchSearchTransactions")});var cC=g((r_e,aC)=>{"use strict";var{getSchemaPath:e_e}=ze(),t_e=We(),{database:V2}=(Ae(),ie(ke));aC.exports={writeTransaction:$2};async function $2(e,t,r){return V2({database:e,table:t}).transaction(r)}a($2,"writeTransaction")});var dC=g((s_e,_C)=>{"use strict";var{getSchemaPath:lC}=ze(),uC=We();_C.exports={flush:Y2,resetReadTxn:K2};async function Y2(e,t){return(await uC.openEnvironment(lC(e,t),t.toString())).flushed}a(Y2,"flush");async function K2(e,t){try{(await uC.openEnvironment(lC(e,t),t.toString())).resetReadTxn()}catch{}}a(K2,"resetReadTxn")});var mC=g((o_e,hC)=>{"use strict";var{Readable:W2}=require("stream"),{getDatabases:Q2}=(Ae(),ie(ke)),{readSync:z2,openSync:J2,createReadStream:fC}=require("fs"),{open:X2}=require("lmdb"),EC=Pc(),j2=Uc(),{AUDIT_STORE_OPTIONS:Z2}=(ei(),ie(pC)),{INTERNAL_DBIS_NAME:eJ,AUDIT_STORE_NAME:tJ}=dt();hC.exports=nJ;var jp=32768,rJ=100;async function nJ(e){let t=e.database||e.schema||"data",r=Q2()[t],n=new Date().toISOString(),s=e.tables||e.table&&[e.table];if(s){let _=r[s[0]];if(!_)throw new Error(`Can not find table ${s[0]}`);let u=_.dbisDB,d=X2({noSync:!0,maxDbs:j2.MAX_DBS}),E,f=d.openDB(eJ,new EC(!1)),h=u.useReadTransaction(),p=0,S=a(async function(A,b){b.encoding="binary",b.encoder=void 0;let I=d.openDB(A,b),B=u.openDB(A,b);for(let{key:U,version:q,value:M}of B.getRange({start:null,transaction:h,versions:B.useVersions}))E=I.put(U,M,q),p++%rJ===0&&(await new Promise(Q=>setTimeout(Q,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:A,value:b}of u.getRange({transaction:h,start:!1}))if(s.some(I=>A.startsWith?.(I+"/"))){f.put(A,b);let[,I]=A.split("/"),B=!I,U=new EC(!B,B);await S(A,U)}e.include_audit&&await S(tJ,Object.assign({},Z2)),await E;let T=fC(d.path);return T.headers=l(),T.on("close",()=>{h.done(),d.close()}),T}let o=r[Object.keys(r)[0]].primaryStore,c=J2(o.path);return o.transaction(()=>{let _=Buffer.alloc(jp);z2(c,_,0,jp),o.resetReadTxn();let u=o.useReadTransaction();u.renew();let d=fC(null,{fd:c,start:jp}),E=new W2.from(async function*(){yield _;for await(let f of d)u.openTimer&&(u.openTimer=0),yield f;u.done()}());return E.headers=l(),E});function l(){let _=new Map;return _.set("content-type","application/octet-stream"),_.set("content-disposition",`attachment; filename="${t}"`),_.set("date",n),_}}a(nJ,"getBackup")});var gC=g((c_e,TC)=>{"use strict";var sJ=K(),{handleHDBError:iJ}=se(),oJ=vb(),aJ=M_(),cJ=gp(),lJ=DI(),uJ=Jc(),_J=Ip(),dJ=rw(),fJ=_w(),EJ=el(),hJ=Tw(),mJ=Dw(),pJ=Hw(),SJ=Gw(),TJ=Vw(),gJ=Jw(),RJ=Bp(),AJ=eC(),OJ=oC(),bJ=cC(),SC=dC(),yJ=mC(),Zp=class extends oJ{static{a(this,"LMDBBridge")}async searchByConditions(t){return hJ(t)}async getDataByHash(t){return await _J(t)}async searchByHash(t){return await dJ(t)}async getDataByValue(t,r){return await fJ(t,r)}async searchByValue(t){return await EJ(t)}async createSchema(t){return await lJ(t)}async dropSchema(t){return await mJ(t)}async createTable(t,r){return await pJ(t,r)}async dropTable(t){return await RJ(t)}async createAttribute(t){return await aJ(t)}async createRecords(t){return await cJ(t)}async updateRecords(t){return await SJ(t)}async upsertRecords(t){try{return await TJ(t)}catch(r){throw iJ(r,null,null,sJ.ERR,r)}}async deleteRecords(t){return await uJ(t)}async dropAttribute(t){return await AJ(t)}async deleteAuditLogsBefore(t){return await gJ(t)}async readAuditLog(t){return await OJ(t)}writeTransaction(t,r,n){return bJ.writeTransaction(t,r,n)}flush(t,r){return SC.flush(t,r)}resetReadTxn(t,r){return SC.resetReadTxn(t,r)}getBackup(t){return yJ(t)}};TC.exports=Zp});function CJ(){wJ=setInterval(function(){for(let e of eS)if(e.stale){let t=e[ye]?.url;bC.error(`Transaction was open too long and has been aborted, from table: ${e.lmdbDb?.name+(t?" path: "+t:"")}`),e.abort()}else e.stale=!0},IJ).unref()}var tS,OC,bC,yC,NC,IC,RC,eS,NJ,il,AC,to,ud,IJ,wJ,rS=Re(()=>{tS=x(Br()),OC=x(se()),bC=x(K());an();yC=x(ne()),NC=x(P()),IC=x(J()),RC=100,eS=new Set,NJ=(0,IC.convertToMS)(yC.get(NC.CONFIG_PARAMS.STORAGE_MAXTRANSACTIONQUEUETIME))||45e3,to=class e{static{a(this,"DatabaseTransaction")}writes=[];lmdbDb;readTxn;readTxnRefCount;readTxnsUsed;validated=0;timestamp=0;overloadChecked;open=1;getReadTxn(){if(this.readTxnRefCount=(this.readTxnRefCount||0)+1,this.stale&&(this.stale=!1),this.readTxn)return this.readTxn.openTimer&&(this.readTxn.openTimer=0),this.readTxn;if(this.open===1)return this.readTxn=this.lmdbDb.useReadTransaction(),this.readTxnsUsed=1,this.readTxn.openTimer&&(this.readTxn.openTimer=0),eS.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(eS.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(il&&!this.overloadChecked&&performance.now()-AC>NJ)throw new OC.ServerError("Outstanding write transactions have too long of queue, please try again later",503);this.overloadChecked=!0}addWrite(t){if(this.open===0)throw new Error("Can not use a transaction that is no longer open");if(this.open===2){let r=new e;return r.addWrite(t),r.commit({})}else this.writes.push(t)}removeWrite(t){let r=this.writes.indexOf(t);r>-1&&(this.writes[r]=null)}commit(t={}){let r=this.timestamp;r||(r=this.timestamp=t.timestamp||(0,tS.getNextMonotonicTime)()),t.timestamp||(t.timestamp=r);let n=t.retries||0;if(this.validated<this.writes.length)try{let d=this.validated;this.validated=this.writes.length;for(let f=d;f<this.validated;f++)this.writes[f]?.validate?.(this.timestamp);let E;for(let f=d;f<this.validated;f++){let h=this.writes[f];h&&(h.before||h.beforeIntermediate)&&(E=!0)}if(E)return(async()=>{try{for(let f=0;f<2;f++){let h;for(let p=d;p<this.validated;p++){let S=this.writes[p];if(!S)continue;let T=S[f===0?"before":"beforeIntermediate"];if(T){let A=T();h?h.push?h.push(A):h=[h,A]:h=A}}h&&await(h.push?Promise.all(h):h)}}catch(f){throw this.abort(),f}return this.commit(t)})()}catch(d){throw this.abort(),d}n||this.doneReadTxn(),this.open=t?.letItLinger?2:0;let s,i=[],o=0;this.writes=this.writes.filter(d=>d);let c=a(d=>{d.commit(r,d.entry,n)},"doWrite"),l=a(()=>{let d=this.writes[o++];if(d)if(d.key){n>0&&(d.entry=d.store.getEntry(d.key));let E=d.store.ifVersion(d.key,d.entry?.version??null,l);s=s||E}else l();else for(let E of this.writes)c(E)},"nextCondition"),_=this.lmdbDb;if(this.writes.length>0&&(_?.retryRisk&&(_.retryRisk*=.99),this.writes.length+(_?.retryRisk||0)<RC>>n?l():s=this.writes[0].store.transaction(()=>{for(let d of this.writes)d.entry=d.store.getEntry(d.key),c(d);return!0})),s)return il||(il=s,AC=performance.now(),il.then(()=>{il=null})),s.then(d=>d?(this.next&&i.push(this.next.commit(t)),t?.flush&&i.push(this.writes[0].store.flushed),this.writes=[],this.next=null,Promise.all(i).then(()=>({txnTime:r}))):(_&&(_.retryRisk=(_.retryRisk||0)+RC/2),t?t.retries=n+1:t={retries:1},this.commit(t)));let u={txnTime:r};if(this.next){let d=this.next?.commit(t);if(d?.then)return d?.then(E=>({txnTime:r,next:E}));u.next=d}return u}abort(){for(;this.readTxnsUsed>0;)this.doneReadTxn();this.open=0,this.writes=[]}},ud=class extends to{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,tS.getNextMonotonicTime)())}getReadTxn(){}},IJ=3e4;a(CJ,"startMonitoringTxns");CJ()});function Ze(e,t,r){if(!t)t=e,e={};else if(!e)e={};else if(e?.transaction?.open===1&&typeof t=="function")return t(e.transaction);if(typeof t!="function")throw new Error("Callback function must be provided to transaction");let n=e.transaction=new to;e.timestamp&&(n.timestamp=e.timestamp),n[ye]=e,e.resourceCache||(e.resourceCache=[]);let s;try{if(s=t(n),s?.then)return s.then(i,o)}catch(c){o(c)}return i(s);function i(c){let l=n.commit({letItLinger:r?.letItLinger});return l.then?l.then(()=>c):c}function o(c){throw n.abort({}),c}}var wC,ro=Re(()=>{wC=require("../index");an();rS();a(Ze,"transaction");(0,wC._assignPackageExport)("transaction",Ze);Ze.commit=function(e){let t=(e[ye]||e)?.transaction;if(!t)throw new Error("No active transaction is available to commit");return t.commit()};Ze.abort=function(e){let t=(e[ye]||e)?.transaction;if(!t)throw new Error("No active transaction is available to abort");return t.abort()}});var BC={};qe(BC,{ResourceBridge:()=>iS});function oS({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 DC(e,t){let r=ss(e),n=oS(e,r);if(!r)throw new Pn.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},o;Ze(i,()=>new Promise(_=>o=_));let c=e.ids||e.hash_values,l=0;return{[Symbol.asyncIterator](){return{async next(){if(l<c.length){let _=c[l++],u;try{u=await r.get({id:_,lazy:s,select:n},i),u=u&&dd(u)}catch(d){u={message:d.toString()}}return t?{value:{key:_,value:u}}:{value:u}}else return o(),{done:!0}},return(_){return o(),{value:_,done:!0}},throw(_){return o(),{done:!0}}}}}}function ss(e){let t=e.database||e.schema||LJ,r=Tr()[t];if(!r)throw(0,Pn.handleHDBError)(new Error,DJ.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function LC(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*MC(e,t,r){let n;for await(let s of e.getHistory(t,r)){let i=s.type;i==="put"&&(i="upsert");let{id:o,version:c,value:l}=s;n?.timestamp===c?(n.hash_values.push(o),n.records.push(l)):(n&&(yield n),n={operation:i,user_name:s.user,timestamp:c,hash_values:[o],records:[l]})}n&&(yield n)}var PC,_d,Pn,UC,Un,nS,sS,vC,DJ,LJ,MJ,PJ,CC,iS,HC=Re(()=>{"use strict";PC=x(gC()),_d=x(ra()),Pn=x(se());Ae();UC=x(Fc()),Un=x(P()),nS=x(Os()),sS=x(Mn()),vC=x(J());ro();fd();({HDB_ERROR_MSGS:DJ}=Pn.hdb_errors),LJ="data",MJ=1e4,PJ=10,iS=class extends PC.default{static{a(this,"ResourceBridge")}constructor(t){super(t),CC=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,_d.default)(t,"conditions");if(r)throw(0,Pn.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=ss(t);if(!n)throw new Pn.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:oS(t,n),sort:t.sort,allowFullScan:!0},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache})}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 Pn.ClientError("A primary key must be specified with a `primary_key` property or with `attributes`");n=[{name:i,isPrimaryKey:!0},{name:"__createdtime__",indexed:!0},{name:"__updatedtime__",indexed:!0}]}ft({database:r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration})}async createAttribute(t){return await ss(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=ss(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=a((o,c,l)=>(c=Object.assign({},c),delete c[n],r.primaryStore.ifVersion(o,l,()=>r.primaryStore.put(o,c,l)).then(_=>{if(!_){let{value:u,version:d}=r.primaryStore.getEntry(o);return i(o,u,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(_=>setImmediate(_));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){ss(t).dropTable()}createSchema(t){return ia({database:t.schema,table:null}),nS.signalSchemaChange(new sS.SchemaEventMsg(process.pid,Un.OPERATIONS_ENUM.CREATE_SCHEMA,t.schema))}async dropSchema(t){await aS(t.schema),nS.signalSchemaChange(new sS.SchemaEventMsg(process.pid,Un.OPERATIONS_ENUM.DROP_SCHEMA,t.schema))}async updateRecords(t){return t.requires_existing=!0,this.upsertRecords(t)}async createRecords(t){return t.requires_no_existing=!0,CC.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,UC.default)(t),s,i=Tr()[t.schema][t.table],o={user:t.hdb_user,expiresAt:t.expiresAt};return Ze(o,async c=>{if(!i.schemaDefined){s=[];for(let u of n)i.attributes.find(E=>E.name==u)||s.push(u);s.length>0&&await i.addAttributes(s.map(u=>({name:u,indexed:!0})))}let l=[],_=[];for(let u of t.records){let d=u[i.primaryKey],E=d!=null&&await i.get(d,o);if(t.requires_existing&&!E||t.requires_no_existing&&E){_.push(u[i.primaryKey]);continue}E&&(E=dd(E));for(let f in u)if(Object.prototype.hasOwnProperty.call(u,f)){let h=u[f];if(typeof h=="function")try{let p=h([[E]]);Array.isArray(p)&&(h=p[0].func_val,u[f]=h)}catch(p){throw p.message+="Trying to set key "+f+" on object"+JSON.stringify(u),p}}if(E)for(let f in E)Object.prototype.hasOwnProperty.call(u,f)||(u[f]=E[f]);await(d==null?i.create(u,o):i.put(u,o)),l.push(u[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:l,new_attributes:s,skipped_hashes:_}})}async deleteRecords(t){let r=Tr()[t.schema][t.table],n={user:t.hdb_user};return Ze(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 LC(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=Tr()[t.schema][t.table];if(!r.createdTimeProperty)throw new Pn.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:Un.VALUE_SEARCH_COMPARATORS.LESS}]}),s=!1,i=[],o=[],c=0,l=[],_=a(async()=>{let u=await this.deleteRecords({schema:t.schema,table:t.table,hash_values:l});i.push(...u.deleted_hashes),o.push(...u.skipped_hashes),await(0,vC.async_set_timeout)(PJ),l=[],s=!0},"chunkDelete");for await(let u of n)l.push(u[r.primaryKey]),c++,c%MJ===0&&await _();return l.length>0&&await _(),s?LC(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,_d.default)(t,"hashes");if(r)throw r;return DC(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of DC(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&Un.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[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,_d.default)(t,"value");if(n)throw n;let s=ss(t);if(!s)throw new Pn.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===Un.VALUE_SEARCH_COMPARATORS.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:oS(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache})}async getDataByValue(t,r){let n=new Map,s=ss(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){ss({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return ss(t).deleteHistory(t.timestamp)}async readAuditLog(t){let r=ss(t),n={};switch(t.search_type){case Un.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:for(let i of t.search_values)n[i]=(await r.getHistoryOfRecord(i)).map(o=>{let c=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 Un.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:let s=t.search_values;for await(let i of MC(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return MC(r,t.search_values?.[0],t.search_values?.[1])}}};a(oS,"getSelect");a(DC,"getRecords");a(ss,"getTable");a(LC,"createDeleteResponse");a(MC,"groupRecordsInHistory")});var Cn=g((O_e,xC)=>{"use strict";var{ResourceBridge:UJ}=(HC(),ie(BC)),vJ=ne();vJ.initSync();var Ed;function BJ(){return Ed||(Ed=new UJ,Ed)}a(BJ,"getBridge");xC.exports=BJ()});var kC=g((y_e,qC)=>{"use strict";var GC=require("lodash"),ol=require("mathjs"),HJ=require("jsonata"),FC=J();qC.exports={distinct_array:e=>Array.isArray(e)&&e.length>1?GC.uniqWith(e,GC.isEqual):e,searchJSON:xJ,mad:al.bind(null,ol.mad),mean:al.bind(null,ol.mean),mode:al.bind(null,ol.mode),prod:al.bind(null,ol.prod),median:al.bind(null,ol.median)};function al(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(al,"aggregateFunction");function xJ(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(FC.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),FC.isEmpty(this.__ala__.res[r])){let n=HJ(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(xJ,"searchJSON")});var $C=g((I_e,VC)=>{"use strict";var gt=require("moment"),cS="YYYY-MM-DDTHH:mm:ss.SSSZZ";gt.suppressDeprecationWarnings=!0;VC.exports={current_date:()=>gt().utc().format("YYYY-MM-DD"),current_time:()=>gt().utc().format("HH:mm:ss.SSS"),extract:(e,t)=>{switch(t.toLowerCase()){case"year":return gt(e).utc().format("YYYY");case"month":return gt(e).utc().format("MM");case"day":return gt(e).utc().format("DD");case"hour":return gt(e).utc().format("HH");case"minute":return gt(e).utc().format("mm");case"second":return gt(e).utc().format("ss");case"millisecond":return gt(e).utc().format("SSS");default:break}},date:e=>gt(e).utc().format(cS),date_format:(e,t)=>gt(e).utc().format(t),date_add:(e,t,r)=>gt(e).utc().add(t,r).valueOf(),date_sub:(e,t,r)=>gt(e).utc().subtract(t,r).valueOf(),date_diff:(e,t,r)=>{let n=gt(e).utc(),s=gt(t).utc();return r?n.diff(s,r,!0):n.diff(s)},now:()=>gt().utc().valueOf(),get_server_time:()=>gt().format(cS),offset_utc:(e,t)=>gt(e).utc().utcOffset(t).format(cS)}});var QC=g((w_e,WC)=>{"use strict";var GJ=require("@turf/area"),FJ=require("@turf/length"),qJ=require("@turf/circle"),kJ=require("@turf/difference"),VJ=require("@turf/distance"),$J=require("@turf/boolean-contains"),YJ=require("@turf/boolean-equal"),KJ=require("@turf/boolean-disjoint"),WJ=require("@turf/helpers"),YC=P(),Te=J(),Ns=K();WC.exports={geoArea:QJ,geoLength:zJ,geoCircle:JJ,geoDifference:XJ,geoDistance:KC,geoNear:jJ,geoContains:ZJ,geoEqual:e4,geoCrosses:t4,geoConvert:r4};function QJ(e){if(Te.isEmpty(e))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e));try{return GJ.default(e)}catch(t){return Ns.trace(t,e),NaN}}a(QJ,"geoArea");function zJ(e,t){if(Te.isEmpty(e))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e));try{return FJ.default(e,{units:t||"kilometers"})}catch(r){return Ns.trace(r,e),NaN}}a(zJ,"geoLength");function JJ(e,t,r){if(Te.isEmpty(e))return NaN;if(Te.isEmpty(t))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e));try{return qJ.default(e,t,{units:r||"kilometers"})}catch(n){return Ns.trace(n,e,t),NaN}}a(JJ,"geoCircle");function XJ(e,t){if(Te.isEmpty(e))return NaN;if(Te.isEmpty(t))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return kJ(e,t)}catch(r){return Ns.trace(r,e,t),NaN}}a(XJ,"geoDifference");function KC(e,t,r){if(Te.isEmpty(e))return NaN;if(Te.isEmpty(t))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return VJ.default(e,t,{units:r||"kilometers"})}catch(n){return Ns.trace(n,e,t),NaN}}a(KC,"geoDistance");function jJ(e,t,r,n){if(Te.isEmpty(e)||Te.isEmpty(t))return!1;if(Te.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t)),isNaN(r))throw new Error("distance must be a number");try{return KC(e,t,n)<=r}catch(s){return Ns.trace(s,e,t),!1}}a(jJ,"geoNear");function ZJ(e,t){if(Te.isEmpty(e)||Te.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return $J.default(e,t)}catch(r){return Ns.trace(r,e,t),!1}}a(ZJ,"geoContains");function e4(e,t){if(Te.isEmpty(e)||Te.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return YJ.default(e,t)}catch(r){return Ns.trace(r,e,t),!1}}a(e4,"geoEqual");function t4(e,t){if(Te.isEmpty(e)||Te.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return!KJ.default(e,t)}catch(r){return Ns.trace(r,e,t),!1}}a(t4,"geoCrosses");function r4(e,t,r){if(Te.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if(Te.isEmpty(t))throw new Error("geo_type is required");if(Te.isEmpty(YC.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(YC.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Te.autoCastJSON(e)),WJ[t](e,r)}a(r4,"geoConvert")});var hd=g((D_e,zC)=>{var no=kC(),Kr=$C(),is=QC();zC.exports=e=>{e.aggr.mad=e.aggr.MAD=no.mad,e.aggr.mean=e.aggr.MEAN=no.mean,e.aggr.mode=e.aggr.MODE=no.mode,e.aggr.prod=e.aggr.PROD=no.prod,e.aggr.median=e.aggr.MEDIAN=no.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=no.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=no.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=Kr.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Kr.current_time,e.fn.extract=e.fn.EXTRACT=Kr.extract,e.fn.date=e.fn.DATE=Kr.date,e.fn.date_format=e.fn.DATE_FORMAT=Kr.date_format,e.fn.date_add=e.fn.DATE_ADD=Kr.date_add,e.fn.date_sub=e.fn.DATE_SUB=Kr.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Kr.date_diff,e.fn.now=e.fn.NOW=Kr.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Kr.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Kr.get_server_time,e.fn.getdate=e.fn.GETDATE=Kr.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Kr.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=is.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=is.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=is.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=is.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=is.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=is.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=is.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=is.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=is.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=is.geoNear}});var ZC=g((L_e,jC)=>{"use strict";var cl=require("lodash"),gr=require("alasql");gr.options.cache=!1;var n4=hd(),JC=require("clone"),md=require("recursive-iterator"),fe=K(),Le=J(),oa=Cn(),s4=P(),{hdb_errors:i4}=se(),{getDatabases:XC}=(Ae(),ie(ke)),o4="IS NULL",vn="There was a problem performing this search. Please check the logs and try again.";n4(gr);var lS=class{static{a(this,"SQLSearch")}constructor(t,r){if(Le.isEmpty(t))throw fe.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(),Le.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!Le.isEmptyOrZeroLength(n))return fe.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw fe.error("Error thrown from checkEmptySQL in SQLSearch class method search."),fe.error(n),new Error(vn)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw fe.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),fe.error(n),new Error(vn)}if(Object.keys(this.data).length===0)return fe.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw fe.error("Error thrown from processJoins in SQLSearch class method search."),fe.error(n),new Error(vn)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw fe.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),fe.error(n),new Error(vn)}try{return t=await this._finalSQL(),t}catch(n){throw fe.error("Error thrown from finalSQL in SQLSearch class method search."),fe.error(n),new Error(vn)}}_getColumns(){let t=new md(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(JC(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=cl.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=XC()[r.databaseid][r.tableid].primaryKey,this.data[n].__merged_data={},this.data[n].__merged_attributes=[],this.data[n].__merged_attr_map={}})}_conditionsToFetchAttributeValues(){if(Le.isEmpty(this.statement.where)){fe.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new md(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!Le.isEmpty(r)&&r.right)if(Le.isNotEmptyAndHasValue(r.right.value)){let n=Le.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new gr.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=Le.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new gr.yy.LogicValue({value:i}):n instanceof gr.yy.StringValue&&Le.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new gr.yy.NumValue({value:i}))});if(t){fe.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new md(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(!Le.isEmpty(s4.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(Le.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(Le.isEmptyOrZeroLength(r.left.columnid)||Le.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(Le.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"=":!Le.isEmpty(r.right.value)||!Le.isEmpty(r.left.value)?n.add(Le.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 _=0;_<l.length;_++)if(l[_].value)n.add(l[_].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(Le.isEmptyOrZeroLength(this.all_table_attributes)&&Le.isEmptyOrZeroLength(this.statement.from)&&Le.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&&cl.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(Le.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);Le.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(Le.isEmptyOrZeroLength(this.all_table_attributes)&&!Le.isEmptyOrZeroLength(this.columns.columns))return t;if(Le.isEmptyOrZeroLength(this.all_table_attributes)&&Le.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await gr.promise(r)}catch(r){throw fe.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),fe.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(JC(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(Le.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(o4)>-1&&this.tables.forEach(s=>{let i={columnid:XC()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=cl.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,_=[s.table.databaseid,s.table.tableid,s.attribute].join("/");if(s.attribute===o&&(l=!0),!Le.isEmpty(this.exact_search_values[_])&&!this.exact_search_values[_].ignore&&!Le.isEmptyOrZeroLength(this.exact_search_values[_].values))if(l)try{c.hash_values=Array.from(this.exact_search_values[_].values);let u=await oa.getDataByHash(c);for(let d of c.hash_values)u.get(d)&&!this.data[i].__merged_data[d]&&(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d))}catch(u){throw fe.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),fe.error(u),new Error(vn)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[_].values).map(async u=>{let d=Object.assign({},c);d.search_value=u;let E=await oa.getDataByValue(d);for(let[f,h]of E)this.data[i].__merged_data[f]?this._updateMergedAttribute(i,f,s.attribute,h[s.attribute]):(this.data[i].__merged_data[f]=[...n[i]],this._updateMergedAttribute(i,f,s.attribute,h[s.attribute]),this._setMergedHashAttribute(i,f))}))}catch(u){throw fe.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),fe.error(u),new Error(vn)}else if(!Le.isEmpty(this.comparator_search_values[_])&&!this.comparator_search_values[_].ignore&&!Le.isEmptyOrZeroLength(this.comparator_search_values[_].comparators))try{let u=this.comparator_search_values[_].comparators;for(let d=0,E=u.length;d<E;d++){let f=u[d];c.search_attribute=f.attribute,c.search_value=f.search_value;let h=await oa.getDataByValue(c,f.operation);if(l)for(let[p]of h)this.data[i].__merged_data[p]||(this.data[i].__merged_data[p]=[...n[i]],this._setMergedHashAttribute(i,p));else for(let[p,S]of h)this.data[i].__merged_data[p]?this._updateMergedAttribute(i,p,s.attribute,S[s.attribute]):(this.data[i].__merged_data[p]=[...n[i]],this._updateMergedAttribute(i,p,s.attribute,S[s.attribute]),this._setMergedHashAttribute(i,p))}}catch(u){throw fe.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),fe.error(u),new Error(vn)}else try{c.search_attribute=s.attribute,c.search_value="*";let u=await oa.getDataByValue(c);if(l)for(let[d]of u)this.data[i].__merged_data[d]||(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d));else for(let[d,E]of u)this.data[i].__merged_data[d]?this._updateMergedAttribute(i,d,s.attribute,E[s.attribute]):(this.data[i].__merged_data[d]=[...n[i]],this._updateMergedAttribute(i,d,s.attribute,E[s.attribute]),this._setMergedHashAttribute(i,d))}catch(u){throw fe.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),fe.error(u),new Error(vn)}}}_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 gr.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 gr.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new gr.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 gr.yy.FuncValue:new gr.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(f=>{f.joinmode&&f.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(f.table);let h=f.joinmode+" JOIN ? AS "+(f.as?f.as:f.table.tableid);f.on&&(h+=" ON "+f.on.toString()),i.push(h),t.push(Object.values(this.data[`${f.table.databaseid_orig}_${f.table.as?f.table.as_orig:f.table.tableid_orig}`].__merged_data))});let o=[],c={};s.forEach(f=>{let h=this.data[`${f.databaseid_orig}_${f.as?f.as_orig:f.tableid_orig}`].__hash_name,p=f.as?f.as_orig:f.tableid_orig;o.push({key:`'${p}.${h}'`,schema:f.databaseid_orig,table:f.as?f.as_orig:f.tableid_orig,keys:new Set}),r.push(`${f.as?f.as:f.tableid}.\`${h}\` AS "${p}.${h}"`),c[f.as?f.as_orig:f.tableid_orig]=this.data[`${f.databaseid_orig}_${f.as?f.as_orig:f.tableid_orig}`].__merged_attributes});let l=this.statement.where?"WHERE "+this.statement.where:"";l=l.replace(/NOT\(NULL\)/g,"NOT NULL");let _="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(_="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(f=>{f.is_func?r.push(f.initial_select_column.toString()):f.initial_select_column.tableid?r.push(`${f.initial_select_column.tableid}.${f.initial_select_column.columnid} AS ${f.expression.columnid}`):r.push(`${f.initial_select_column.columnid} AS ${f.expression.columnid}`)}));let u="",d="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(u=this.statement.limit?"LIMIT "+this.statement.limit:"",d=this.statement.offset?"OFFSET "+this.statement.offset:"");let E=[];try{let f=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${l} ${_} ${u} ${d}`,h=this._convertColumnsToIndexes(f,s);E=await gr.promise(h,t),t=null}catch(f){throw fe.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),fe.error(f),new Error("There was a problem processing the data.")}if(E&&E.length>0){for(let f=0,h=E.length;f<h;f++){let p=E[f];o.forEach(S=>{p[S.key]!==null&&p[S.key]!==void 0&&S.keys.add(p[S.key])})}o.forEach(f=>{let h=Object.keys(this.data[`${f.schema}_${f.table}`].__merged_data),p=cl.difference(h,[...f.keys].map(S=>S.toString()));for(let S=0,T=p.length;S<T;S++){let A=p[S];delete this.data[`${f.schema}_${f.table}`].__merged_data[A]}})}return{existing_attributes:c,joined_length:E?E.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new md(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=cl.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 fe.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),fe.error(i),new Error(vn)}}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 u in i)o.push(i[u][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 oa.getDataByHash(c),_=s.columns.length;for(let u=0,d=o.length;u<d;u++){let E=o[u],f=l.get(E);for(let h=0;h<_;h++){let p=s.columns[h],S=f[p]===void 0?null:f[p];this.data[n].__merged_data[E].push(S)}}}}catch(r){throw fe.error("Error thrown from getDataByHash function in SQLSearch class method getData."),fe.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();fe.trace(`Final SQL: ${s}`),n=await gr.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),fe.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw fe.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),fe.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 fe.error(i4.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),fe.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],_=new RegExp(`${l}.\`${o}\``,"g"),u=`${l}.[${c}]`;n=n.replace(_,u)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=new RegExp(`\`${o}\``,"g"),_=`[${c}]`;n=n.replace(l,_)});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 oa.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]=Object.assign({},r[s])),this.data[s].__merged_data[c][t[n.attribute]]=l[n.attribute]??null}catch(o){throw fe.error("There was an error when processing this SQL operation. Check your logs"),fe.error(o),new Error(vn)}}return Object.values(Object.values(this.data)[0].__merged_data)}};jC.exports=lS});var Fr=g((P_e,eD)=>{"use strict";var a4=Pb();eD.exports={searchByConditions:l4,searchByHash:u4,searchByValue:_4,search:d4};var uS=Cn(),{transformReq:_S}=J(),c4=ZC();async function l4(e){return _S(e),uS.searchByConditions(e)}a(l4,"searchByConditions");async function u4(e){_S(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of uS.searchByHash(e))r&&t.push(r);return t}a(u4,"searchByHash");async function _4(e){_S(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of uS.searchByValue(e))t.push(r);return t}a(_4,"searchByValue");function d4(e,t){try{let r=new a4(e);r.validate(),new c4(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(d4,"search")});var pd=g((v_e,tD)=>{"use strict";var f4=Cn();tD.exports={writeTransaction:E4};function E4(e,t,r){return f4.writeTransaction(e,t,r)}a(E4,"writeTransaction")});var iD=g((x_e,sD)=>{"use strict";var h4=Fr(),m4=si(),rD=K(),p4=un(),H_e=pd(),S4=require("clone"),fS=require("alasql"),T4=hd(),nD=require("util"),g4=nD.promisify(m4.getTableSchema),R4=nD.promisify(h4.search),A4=P(),dS=J();T4(fS);sD.exports={update:b4};var O4="There was a problem performing this update. Please check the logs and try again.";async function b4({statement:e,hdb_user:t}){let r=await g4(e.table.databaseid,e.table.tableid),n=y4(e.columns);dS.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=S4(s),c=dS.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,_=fS.parse(l).statements[0],u=await R4(_),d=N4(n,u);return I4(o,d,t)}a(b4,"update");function y4(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=fS.compile(`SELECT ${r.expression.toString()} AS [${A4.FUNC_VAL}] FROM ?`)}),t}catch(t){throw rD.error(t),new Error(O4)}}a(y4,"createUpdateRecord");function N4(e,t){return dS.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(N4,"buildUpdateRecords");async function I4(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await p4.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){rD.error(`Error delete new_attributes from update response: ${i}`)}return s}a(I4,"updateRecords")});var aD=g((k_e,oD)=>{var w4=require("alasql"),C4=Fr(),D4=K(),L4=Cn(),hS=require("util"),ES=J(),M4=P(),P4=si(),F_e=pd(),q_e=un(),U4="record",v4="successfully deleted",B4=hS.callbackify(F4),H4=hS.promisify(C4.search),x4=hS.promisify(P4.getTableSchema);oD.exports={convertDelete:B4};function G4(e){return`${e.deleted_hashes.length} ${U4}${e.deleted_hashes.length===1?"":"s"} ${v4}`}a(G4,"generateReturnMessage");async function F4({statement:e,hdb_user:t}){let r=await x4(e.table.databaseid,e.table.tableid);ES.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=ES.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=w4.parse(o).statements[0],l={operation:M4.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await H4(c);let _=await L4.deleteRecords(l);return ES.isEmptyOrZeroLength(_.message)&&(_.message=G4(_)),delete _.txn_time,_}catch(_){throw D4.error(_),_.hdb_code?_.message:_}}a(F4,"convertDelete")});var dD=g(($_e,_D)=>{"use strict";var q4=ni(),{hdb_errors:cD}=se(),{getDatabases:lD}=(Ae(),ie(ke));_D.exports={checkSchemaExists:uD,checkSchemaTableExists:k4,schema_describe:q4};async function uD(e){if(!lD()[e])return cD.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(uD,"checkSchemaExists");async function k4(e,t){let r=await uD(e);if(r)return r;if(!lD()[e][t])return cD.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(k4,"checkSchemaTableExists")});var Rd=g((W_e,mD)=>{"use strict";var aa=D_(),ca=dD(),V4=K(),$4=require("uuid").v4,K_e=require("clone"),Td=Os(),la=P(),Y4=require("util"),_i=Cn(),{handleHDBError:Rr,hdb_errors:K4}=se(),{HDB_ERROR_MSGS:Sd,HTTP_STATUS_CODES:Ar}=K4,{SchemaEventMsg:gd}=Mn(),fD=wt(),{getDatabases:W4}=(Ae(),ie(ke)),{transformReq:ua}=J();mD.exports={createSchema:Q4,createSchemaStructure:ED,createTable:z4,createTableStructure:hD,createAttribute:e3,dropSchema:J4,dropTable:X4,dropAttribute:j4,getBackup:t3};async function Q4(e){let t=await ED(e);return Td.signalSchemaChange(new gd(process.pid,e.operation,e.schema)),t}a(Q4,"createSchema");async function ED(e){let t=aa.schema_object(e);if(t)throw Rr(t,t.message,Ar.BAD_REQUEST,void 0,void 0,!0);if(ua(e),!await ca.checkSchemaExists(e.schema))throw Rr(new Error,Sd.SCHEMA_EXISTS_ERR(e.schema),Ar.BAD_REQUEST,la.LOG_LEVELS.ERROR,Sd.SCHEMA_EXISTS_ERR(e.schema),!0);return await _i.createSchema(e),`database '${e.schema}' successfully created`}a(ED,"createSchemaStructure");async function z4(e){return ua(e),e.hash_attribute=e.primary_key??e.hash_attribute,await hD(e)}a(z4,"createTable");async function hD(e){let t=aa.create_table_object(e);if(t)throw Rr(t,t.message,Ar.BAD_REQUEST,void 0,void 0,!0);if(aa.validateTableResidence(e.residence),!await ca.checkSchemaTableExists(e.schema,e.table))throw Rr(new Error,Sd.TABLE_EXISTS_ERR(e.schema,e.table),Ar.BAD_REQUEST,la.LOG_LEVELS.ERROR,Sd.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:$4(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await _i.createTable(n,e);else throw Rr(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",Ar.BAD_REQUEST);else await _i.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}a(hD,"createTableStructure");async function J4(e){let t=!e.schema&&!e.database?new Error("database is required"):void 0,r=aa.schema_object(e),n=t??r;if(n)throw Rr(n,n.message,Ar.BAD_REQUEST,void 0,void 0,!0);ua(e);let s=await ca.checkSchemaExists(e.schema);if(s)throw Rr(new Error,s,Ar.NOT_FOUND,la.LOG_LEVELS.ERROR,s,!0);let i=await ca.schema_describe.describeSchema({schema:e.schema}),o=Object.keys(global.hdb_schema[e.schema]);return await _i.dropSchema(e),Td.signalSchemaChange(new gd(process.pid,e.operation,e.schema)),await fD.purgeSchemaTableStreams(e.schema,o),`successfully deleted '${e.schema}'`}a(J4,"dropSchema");async function X4(e){let t=aa.table_object(e);if(t)throw Rr(t,t.message,Ar.BAD_REQUEST,void 0,void 0,!0);ua(e);let r=await ca.checkSchemaTableExists(e.schema,e.table);if(r)throw Rr(new Error,r,Ar.NOT_FOUND,la.LOG_LEVELS.ERROR,r,!0);return await _i.dropTable(e),await fD.purgeTableStream(e.schema,e.table),`successfully deleted table '${e.schema}.${e.table}'`}a(X4,"dropTable");async function j4(e){let t=aa.attribute_object(e);if(t)throw Rr(t,t.message,Ar.BAD_REQUEST,void 0,void 0,!0);ua(e);let r=await ca.checkSchemaTableExists(e.schema,e.table);if(r)throw Rr(new Error,r,Ar.NOT_FOUND,la.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw Rr(new Error,"You cannot drop a hash attribute",Ar.BAD_REQUEST,void 0,void 0,!0);if(la.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw Rr(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,Ar.BAD_REQUEST,void 0,void 0,!0);try{return await _i.dropAttribute(e),Z4(e),Td.signalSchemaChange(new gd(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw V4.error(`Got an error deleting attribute ${Y4.inspect(e)}.`),n}}a(j4,"dropAttribute");function Z4(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(Z4,"dropAttributeFromGlobal");async function e3(e){ua(e);let t=W4()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw Rr(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,Ar.BAD_REQUEST,void 0,void 0,!0);return await _i.createAttribute(e),Td.signalSchemaChange(new gd(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}a(e3,"createAttribute");function t3(e){return _i.getBackup(e)}a(t3,"getBackup")});var SD=g((z_e,pD)=>{"use strict";var{OPERATIONS_ENUM:r3}=P(),mS=class{static{a(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=r3.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};pD.exports=mS});var pS=g((j_e,OD)=>{"use strict";var n3=Cn(),X_e=SD(),Ad=J(),Od=P(),s3=ne(),{handleHDBError:TD,hdb_errors:i3}=se(),{HDB_ERROR_MSGS:gD,HTTP_STATUS_CODES:RD}=i3,o3=Object.values(Od.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),AD="To use this operation audit log must be enabled in harperdb-config.yaml";OD.exports=a3;async function a3(e){if(Ad.isEmpty(e.schema))throw new Error(gD.SCHEMA_REQUIRED_ERR);if(Ad.isEmpty(e.table))throw new Error(gD.TABLE_REQUIRED_ERR);if(!s3.get(Od.CONFIG_PARAMS.LOGGING_AUDITLOG))throw TD(new Error,AD,RD.BAD_REQUEST,Od.LOG_LEVELS.ERROR,AD,!0);let t=Ad.checkSchemaTableExist(e.schema,e.table);if(t)throw TD(new Error,t,RD.NOT_FOUND,Od.LOG_LEVELS.ERROR,t,!0);if(!Ad.isEmpty(e.search_type)&&o3.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await n3.readAuditLog(e)}a(a3,"readAuditLog")});var yD=g((ede,bD)=>{"use strict";var{OPERATIONS_ENUM:c3}=P(),SS=class{static{a(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=c3.GET_BACKUP,this.schema=t,this.table=r}};bD.exports=SS});var wD=g((sde,ID)=>{"use strict";var l3=Cn(),rde=yD(),TS=J(),u3=P(),nde=ne(),{handleHDBError:_3,hdb_errors:d3}=se(),{HDB_ERROR_MSGS:ND,HTTP_STATUS_CODES:f3}=d3;ID.exports=E3;async function E3(e){if(TS.isEmpty(e.schema))throw new Error(ND.SCHEMA_REQUIRED_ERR);if(TS.isEmpty(e.table))throw new Error(ND.TABLE_REQUIRED_ERR);let t=TS.checkSchemaTableExist(e.schema,e.table);if(t)throw _3(new Error,t,f3.NOT_FOUND,u3.LOG_LEVELS.ERROR,t,!0);return await l3.getBackup(read_audit_log_object)}a(E3,"getBackup")});var UD=g((ode,PD)=>{var di=require("validate.js"),DD=at(),_a=P(),{handleHDBError:h3,hdb_errors:m3}=se(),{HDB_ERROR_MSGS:ht,HTTP_STATUS_CODES:p3}=m3,gS=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),S3={STRUCTURE_USER:"structure_user"},CD=Object.values(_a.ROLE_TYPES_ENUM),T3="attribute_permissions",g3="attribute_name",{PERMS_CRUD_ENUM:da}=_a,R3=[T3,...Object.values(da)],LD=[da.READ,da.INSERT,da.UPDATE],A3=[g3,...LD];function O3(e){let t=gS();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,MD(e,t)}a(O3,"addRoleValidation");function b3(e){let t=gS();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,MD(e,t)}a(b3,"alterRoleValidation");function y3(e){let t=gS();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,DD.validateObject(e,t)}a(y3,"dropRoleValidation");var N3=["operation","role","id","permission","hdb_user","hdb_auth_header"];function MD(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)N3.includes(n[o])||s.push(n[o]);s.length>0&&Rt(ht.INVALID_ROLE_JSON_KEYS(s),r);let i=DD.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{Rt(o,r)}),e.permission){let o=I3(e);o&&Rt(o,r),CD.forEach(c=>{e.permission[c]&&!di.isBoolean(e.permission[c])&&Rt(ht.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(CD.indexOf(o)<0){if(o===S3.STRUCTURE_USER){let l=e.permission[o];if(typeof l=="boolean")continue;if(Array.isArray(l)){for(let _=0,u=l.length;_<u;_++){let d=l[_];global.hdb_schema[d]||Rt(ht.SCHEMA_NOT_FOUND(d),r)}continue}Rt(ht.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){Rt(ht.SCHEMA_NOT_FOUND(o),r);continue}if(c.tables)for(let l in c.tables){let _=c.tables[l];if(!l||!global.hdb_schema[o][l]){Rt(ht.TABLE_NOT_FOUND(o,l),r);continue}if(Object.keys(_).forEach(u=>{R3.includes(u)||Rt(ht.INVALID_PERM_KEY(u),r,o,l)}),Object.values(da).forEach(u=>{di.isDefined(_[u])?di.isBoolean(_[u])||Rt(ht.TABLE_PERM_NOT_BOOLEAN(u),r,o,l):Rt(ht.TABLE_PERM_MISSING(u),r,o,l)}),di.isDefined(_.attribute_permissions)){if(!di.isArray(_.attribute_permissions)){Rt(ht.ATTR_PERMS_NOT_ARRAY,r,o,l);continue}}else{Rt(ht.ATTR_PERMS_ARRAY_MISSING,r,o,l);continue}if(_.attribute_permissions){let u=global.hdb_schema[o][l].attributes.map(({attribute:E})=>E),d={read:!1,insert:!1,update:!1};for(let E in _.attribute_permissions){let f=_.attribute_permissions[E];if(Object.keys(f).forEach(p=>{!A3.includes(p)&&p!==da.DELETE&&Rt(ht.INVALID_ATTR_PERM_KEY(p),r,o,l)}),!di.isDefined(f.attribute_name)){Rt(ht.ATTR_PERM_MISSING_NAME,r,o,l);continue}let h=f.attribute_name;if(!u.includes(h)){Rt(ht.INVALID_ATTRIBUTE_IN_PERMS(h),r,o,l);continue}LD.forEach(p=>{di.isDefined(f[p])?di.isBoolean(f[p])||Rt(ht.ATTR_PERM_NOT_BOOLEAN(p,h),r,o,l):Rt(ht.ATTR_PERM_MISSING(p,h),r,o,l)}),!d.read&&f.read===!0&&(d.read=!0),!d.insert&&f.insert===!0&&(d.insert=!0),!d.update&&f.update===!0&&(d.update=!0)}if(_.read===!1&&d.read===!0||_.insert===!1&&d.insert===!0||_.update===!1&&d.update===!0){let E=`${o}.${l}`;Rt(ht.MISMATCHED_TABLE_ATTR_PERMS(E),r,o,l)}}}}return w3(r)}a(MD,"customValidate");PD.exports={addRoleValidation:O3,alterRoleValidation:b3,dropRoleValidation:y3};function I3(e){let{operation:t,permission:r}=e;if(t===_a.OPERATIONS_ENUM.ADD_ROLE||t===_a.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 ht.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?_a.ROLE_TYPES_ENUM.SUPER_USER:_a.ROLE_TYPES_ENUM.CLUSTER_USER;return ht.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(I3,"validateNoSUPerms");function w3(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:ht.ROLE_PERMS_ERROR,...e};return h3(new Error,n,p3.BAD_REQUEST)}else return null}a(w3,"generateRolePermResponse");function Rt(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(Rt,"addPermError")});var NS=g((cde,xD)=>{"use strict";var vD=un(),BD=Fr(),C3=Ki(),AS=UD(),OS=Os(),D3=require("uuid").v4,L3=require("util"),bd=P(),M3=J(),bS=BD.searchByValue,P3=BD.searchByHash,U3=L3.promisify(C3.delete),v3=rs(),B3=na(),{hdb_errors:H3,handleHDBError:so}=se(),{HDB_ERROR_MSGS:HD,HTTP_STATUS_CODES:ll}=H3,{UserEventMsg:yS}=Mn();xD.exports={addRole:x3,alterRole:G3,dropRole:F3,listRoles:q3};function RS(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(RS,"scrubRoleDetails");async function x3(e){let t=AS.addRoleValidation(e);if(t)throw t;e=RS(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 bS(r)||[])}catch(i){throw so(i)}if(n&&n.length>0)throw so(new Error,HD.ROLE_ALREADY_EXISTS(e.role),ll.CONFLICT,void 0,void 0,!0);e.id||(e.id=D3());let s={operation:"insert",schema:"system",table:"hdb_role",hash_attribute:"id",records:[e]};return await vD.insert(s),OS.signalUserChange(new yS(process.pid)),e=RS(e),e}a(x3,"addRole");async function G3(e){let t=AS.alterRoleValidation(e);if(t)throw t;e=RS(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await vD.update(r)}catch(s){throw so(s)}if(n&&n?.message==="updated 0 of 1 records")throw so(new Error,"Invalid role id",ll.BAD_REQUEST,void 0,void 0,!0);return await OS.signalUserChange(new yS(process.pid)),e}a(G3,"alterRole");async function F3(e){let t=AS.dropRoleValidation(e);if(t)throw so(new Error,t,ll.BAD_REQUEST,void 0,void 0,!0);let r=new B3(bd.SYSTEM_SCHEMA_NAME,bd.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await P3(r));if(n.length===0)throw so(new Error,HD.ROLE_NOT_FOUND,ll.NOT_FOUND,void 0,void 0,!0);let s=new v3(bd.SYSTEM_SCHEMA_NAME,bd.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await bS(s)),o=!1;if(M3.isEmptyOrZeroLength(i)===!1){for(let l=0;l<i.length;l++)if(i[l].active===!0){o=!0;break}}if(o===!0)throw so(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,ll.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await U3(c),OS.signalUserChange(new yS(process.pid)),`${n[0].role} successfully deleted`}a(F3,"dropRole");async function q3(){return bS({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(q3,"listRoles")});var kD=g((ude,qD)=>{"use strict";var k3=ne(),fi=require("joi"),V3=at(),GD=require("moment"),$3=require("fs-extra"),IS=require("path"),Y3=require("lodash"),ul=P(),{LOG_LEVELS:io}=P(),K3="YYYY-MM-DD hh:mm:ss",W3=IS.resolve(__dirname,"../logs");qD.exports=function(e){return V3.validateBySchema(e,Q3)};var Q3=fi.object({from:fi.custom(FD),until:fi.custom(FD),level:fi.valid(io.NOTIFY,io.FATAL,io.ERROR,io.WARN,io.INFO,io.DEBUG,io.TRACE),order:fi.valid("asc","desc"),limit:fi.number().min(1),start:fi.number().min(0),log_name:fi.custom(z3)});function FD(e,t){if(GD(e,GD.ISO_8601).format(K3)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(FD,"validateDatetime");function z3(e,t){if(Y3.invert(ul.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=k3.get(ul.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?ul.LOG_NAMES.HDB:e,i=s===ul.LOG_NAMES.INSTALL?IS.join(W3,ul.LOG_NAMES.INSTALL):IS.join(n,s);return $3.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(z3,"validateReadLogPath")});var CS=g((dde,$D)=>{"use strict";var yd=P(),J3=K(),X3=ne(),j3=kD(),wS=require("path"),VD=require("fs-extra"),{once:Z3}=require("events"),{handleHDBError:eX,hdb_errors:tX}=se(),{PACKAGE_ROOT:rX}=P(),nX=wS.join(rX,"logs"),sX=1e3,iX=200;$D.exports=oX;async function oX(e){let t=j3(e);if(t)throw eX(t,t.message,tX.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=X3.get(yd.HDB_SETTINGS_NAMES.LOG_PATH_KEY),n=e.log_name===void 0?yd.LOG_NAMES.HDB:e.log_name,s=n===yd.LOG_NAMES.INSTALL?wS.join(nX,yd.LOG_NAMES.INSTALL):wS.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,_=e.until!==void 0,u=_?new Date(e.until):void 0,d=e.limit===void 0?sX:e.limit,E=e.order===void 0?void 0:e.order,f=e.start===void 0?0:e.start,h=f+d,p=0;E==="desc"&&!l&&!u&&(p=Math.max(VD.statSync(s).size-(h+5)*iX,0));let S=VD.createReadStream(s,{start:p});S.on("error",U=>{J3.error(U)});let T=0,A=[],b="",I;S.on("data",U=>{let q=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;U=b+U;let M=0,Q;for(;(Q=q.exec(U))&&!S.destroyed;){I&&(I.message=U.slice(M,Q.index),B(I));let[z,j,oe]=Q,le=oe.split("] ["),ue=le[0],Be=le[1];le.splice(0,2),I={timestamp:j,thread:ue,level:Be,tags:le,message:""},M=Q.index+z.length}b=U.slice(M)}),S.on("end",U=>{S.destroyed||I&&(I.message=b.trim(),B(I))}),S.resume();function B(U){let q,M,Q;switch(!0){case(i&&c&&_):q=new Date(U.timestamp),M=new Date(l),Q=new Date(u),U.level===o&&q>=M&&q<=Q&&T<f?T++:U.level===o&&q>=M&&q<=Q&&(Ei(U,E,A),T++,T===h&&S.destroy());break;case(i&&c):q=new Date(U.timestamp),M=new Date(l),U.level===o&&q>=M&&T<f?T++:U.level===o&&q>=M&&(Ei(U,E,A),T++,T===h&&S.destroy());break;case(i&&_):q=new Date(U.timestamp),Q=new Date(u),U.level===o&&q<=Q&&T<f?T++:U.level===o&&q<=Q&&(Ei(U,E,A),T++,T===h&&S.destroy());break;case(c&&_):q=new Date(U.timestamp),M=new Date(l),Q=new Date(u),q>=M&&q<=Q&&T<f?T++:q>=M&&q<=Q&&(Ei(U,E,A),T++,T===h&&S.destroy());break;case i:U.level===o&&T<f?T++:U.level===o&&(Ei(U,E,A),T++,T===h&&S.destroy());break;case c:q=new Date(U.timestamp),M=new Date(l),q>=M&&T<f?T++:q>=M&&T>=f&&(Ei(U,E,A),T++,T===h&&S.destroy());break;case _:q=new Date(U.timestamp),Q=new Date(u),q<=Q&&T<f?T++:q<=Q&&T>=f&&(Ei(U,E,A),T++,T===h&&S.destroy());break;default:T<f?T++:(Ei(U,E,A),T++,T===h&&S.destroy())}}return a(B,"onLogMessage"),await Z3(S,"close"),A}a(oX,"readLog");function Ei(e,t,r){t==="desc"?aX(e,r):t==="asc"?cX(e,r):r.push(e)}a(Ei,"pushLineToResult");function aX(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(aX,"insertDescending");function cX(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(cX,"insertAscending")});var Nd=g((pde,QD)=>{"use strict";var DS=require("joi"),{string:_l,boolean:YD,date:lX}=DS.types(),uX=at(),{validateSchemaExists:Ede,validateTableExists:hde,validateSchemaName:mde}=Xn(),_X=P(),dX=ct(),KD=ne();KD.initSync();var fX=_l.invalid(KD.get(_X.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(dX.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).required(),WD={operation:_l.valid("add_node","update_node","set_node_replication"),node_name:fX,subscriptions:DS.array().items({table:_l.optional(),schema:_l.optional(),database:_l.optional(),subscribe:YD.required(),publish:YD.required().custom(hX),start_time:lX.iso()}).min(1).required()};function EX(e){return uX.validateBySchema(e,DS.object(WD))}a(EX,"addUpdateNodeValidator");function hX(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(hX,"checkForFalsy");QD.exports={addUpdateNodeValidator:EX,validation_schema:WD}});var JD=g((Tde,zD)=>{var mX=at(),pX={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};zD.exports=function(e){return mX.validateObject(e,pX)}});var MS=g((gde,XD)=>{"use strict";var SX=P().OPERATIONS_ENUM,LS=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=SX.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};XD.exports=LS});var ZD=g((Ade,jD)=>{"use strict";var TX={OPERATION:"operation",REFRESH:"refresh"},PS=class{static{a(this,"JWTTokens")}constructor(t,r){this.operation_token=t,this.refresh_token=r}},US=class{static{a(this,"JWTRSAKeys")}constructor(t,r,n){this.public_key=t,this.private_key=r,this.passphrase=n}};jD.exports={JWTTokens:PS,TOKEN_TYPE_ENUM:TX,JWTRSAKeys:US}});var El=g((bde,nL)=>{"use strict";var fl=require("jsonwebtoken"),vS=require("fs-extra"),BS=J(),dn=P(),{handleHDBError:Or,hdb_errors:gX}=se(),{HTTP_STATUS_CODES:br,AUTHENTICATION_ERROR_MSGS:yr}=gX,dl=K(),eL=q_(),GS=_n(),RX=un().update,AX=MS(),OX=Os(),{UserEventMsg:bX}=Mn(),hi=ne();hi.initSync();var HS=require("path"),{JWTTokens:yX,JWTRSAKeys:NX,TOKEN_TYPE_ENUM:Id}=ZD(),IX=hi.get(dn.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY)?hi.get(dn.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY):"1d",wX=hi.get(dn.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY)?hi.get(dn.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY):"30d",wd="RS256",xS;nL.exports={createTokens:CX,validateOperationToken:LX,refreshOperationToken:DX,validateRefreshToken:rL};async function CX(e){if(BS.isEmpty(e)||typeof e!="object")throw Or(new Error,yr.INVALID_AUTH_OBJECT,br.BAD_REQUEST,void 0,void 0,!0);if(BS.isEmpty(e.username))throw Or(new Error,yr.USERNAME_REQUIRED,br.BAD_REQUEST,void 0,void 0,!0);if(BS.isEmpty(e.password))throw Or(new Error,yr.PASSWORD_REQUIRED,br.BAD_REQUEST,void 0,void 0,!0);let t;try{if(t=await GS.findAndValidateUser(e.username,e.password),!t)throw Or(new Error,yr.INVALID_CREDENTIALS,br.UNAUTHORIZED,void 0,void 0,!0)}catch(E){throw dl.error(E),Or(new Error,yr.INVALID_CREDENTIALS,br.UNAUTHORIZED,void 0,void 0,!0)}let r=await Cd(),n=!1,s=!1;t.role&&t.role.permission&&(n=t.role.permission.super_user===!0,s=t.role.permission.cluster_user===!0);let i={username:e.username,super_user:n,cluster_user:s},o=await tL(i,r.private_key,r.passphrase),c=await fl.sign(i,{key:r.private_key,passphrase:r.passphrase},{expiresIn:wX,algorithm:wd,subject:Id.REFRESH}),l=eL.hash(c),_=new AX(dn.SYSTEM_SCHEMA_NAME,dn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,[{username:e.username,refresh_token:l}]),u,d;try{u=await RX(_)}catch(E){dl.error(E),d=E}if(d!==void 0||u.skipped_hashes.length>0)throw Or(new Error,yr.REFRESH_TOKEN_SAVE_FAILED,br.INTERNAL_SERVER_ERROR);return OX.signalUserChange(new bX(process.pid)),new yX(o,c)}a(CX,"createTokens");async function tL(e,t,r){return await fl.sign(e,{key:t,passphrase:r},{expiresIn:IX,algorithm:wd,subject:Id.OPERATION})}a(tL,"signOperationToken");async function Cd(){if(xS===void 0)try{let e=HS.join(hi.getHdbBasePath(),dn.LICENSE_KEY_DIR_NAME,dn.JWT_ENUM.JWT_PASSPHRASE_NAME),t=HS.join(hi.getHdbBasePath(),dn.LICENSE_KEY_DIR_NAME,dn.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r=HS.join(hi.getHdbBasePath(),dn.LICENSE_KEY_DIR_NAME,dn.JWT_ENUM.JWT_PUBLIC_KEY_NAME),n=(await vS.readFile(e)).toString(),s=(await vS.readFile(t)).toString(),i=(await vS.readFile(r)).toString();xS=new NX(i,s,n)}catch(e){throw dl.error(e),Or(new Error,yr.NO_ENCRYPTION_KEYS,br.INTERNAL_SERVER_ERROR)}return xS}a(Cd,"getJWTRSAKeys");async function DX(e){if(!e)throw Or(new Error,yr.INVALID_BODY,br.BAD_REQUEST,void 0,void 0,!0);if(!e.refresh_token)throw Or(new Error,yr.REFRESH_TOKEN_REQUIRED,br.BAD_REQUEST,void 0,void 0,!0);await rL(e.refresh_token);let t=await Cd(),r=await fl.decode(e.refresh_token);return{operation_token:await tL({username:r.username,super_user:r.super_user,cluster_user:r.cluster_user},t.private_key,t.passphrase)}}a(DX,"refreshOperationToken");async function LX(e){try{let t=await Cd(),r=await fl.verify(e,t.public_key,{algorithms:wd,subject:Id.OPERATION});return await GS.findAndValidateUser(r.username,void 0,!1)}catch(t){throw dl.warn(t),t.name&&t.name==="TokenExpiredError"?Or(new Error,yr.TOKEN_EXPIRED,br.FORBIDDEN):Or(new Error,yr.INVALID_TOKEN,br.UNAUTHORIZED)}}a(LX,"validateOperationToken");async function rL(e){let t;try{let r=await Cd(),n=await fl.verify(e,r.public_key,{algorithms:wd,subject:Id.REFRESH});t=await GS.findAndValidateUser(n.username,void 0,!1)}catch(r){throw dl.warn(r),r.name&&r.name==="TokenExpiredError"?Or(new Error,yr.TOKEN_EXPIRED,br.FORBIDDEN):Or(new Error,yr.INVALID_TOKEN,br.UNAUTHORIZED)}if(!eL.validate(t.refresh_token,e))throw Or(new Error,yr.INVALID_TOKEN,br.UNAUTHORIZED);return t}a(rL,"validateRefreshToken")});var FS=g((Ide,oL)=>{"use strict";var MX=JD(),fa=require("passport"),PX=require("passport-local").Strategy,UX=require("passport-http").BasicStrategy,vX=require("util"),BX=_n(),iL=vX.callbackify(BX.findAndValidateUser),Nde=vr(),HX=P(),sL=El();fa.use(new PX(function(e,t,r){iL(e,t,r)}));fa.use(new UX(function(e,t,r){iL(e,t,r)}));fa.serializeUser(function(e,t){t(null,e)});fa.deserializeUser(function(e,t){t(null,e)});function xX(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":fa.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===HX.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?sL.validateRefreshToken(s).then(o=>{e.body.refresh_token=s,r(null,o)}).catch(o=>{r(o)}):sL.validateOperationToken(s).then(o=>{r(null,o)}).catch(o=>{r(o)});break;default:fa.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(xX,"authorize");function GX(e,t){let r=MX(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(GX,"checkPermissions");oL.exports={authorize:xX,checkPermissions:GX}});var Ea=g((Cde,aL)=>{"use strict";var qS=class{static{a(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},kS=class{static{a(this,"NodeSubscription")}constructor(t,r,n,s){this.schema=t,this.table=r,this.publish=n,this.subscribe=s}};aL.exports={Node:qS,NodeSubscription:kS}});var lL=g((Lde,cL)=>{"use strict";var FX=P().OPERATIONS_ENUM,VS=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=FX.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};cL.exports=VS});var hl=g((Pde,uL)=>{"use strict";var $S=class{static{a(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},YS=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)}};uL.exports={RemotePayloadObject:$S,RemotePayloadSubscription:YS}});var dL=g((vde,_L)=>{"use strict";var KS=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}};_L.exports=KS});var hL=g((Fde,EL)=>{"use strict";var qX=dL(),Hde=dt(),fL=We(),kX=K(),{getSchemaPath:xde,getTransactionAuditStorePath:Gde}=ze(),{getDatabases:VX}=(Ae(),ie(ke));EL.exports=$X;async function $X(e){let t=new qX;try{let r=VX()[e.schema]?.[e.name],n=r.primaryStore.getStats(),s=r.auditStore?.getStats(),i=await fL.environmentDataSize(schema_path,e.name),o=await fL.environmentDataSize(txn_path,e.name);t.schema=e.schema,t.table=e.name,t.table_size=i,t.record_count=n.entryCount,t.transaction_log_size=o,t.transaction_log_record_count=s.entryCount}catch(r){kX.warn(`unable to stat table dbi due to ${r}`)}return t}a($X,"lmdbGetTableSize")});var pL=g((kde,mL)=>{"use strict";var WS=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}};mL.exports=WS});var ha=g((Qde,RL)=>{"use strict";var YX=require("fs-extra"),KX=require("path"),nr=require("systeminformation"),mi=K(),SL=wt(),$de=ct(),Ld=P(),WX=hL(),QX=ni(),{getThreadInfo:TL}=it(),sT=ne();sT.initSync();var zX=pL(),{openEnvironment:Yde}=We(),{getSchemaPath:Kde}=ze(),{database:Wde,databases:QS}=(Ae(),ie(ke)),Dd;RL.exports={getHDBProcessInfo:jS,getNetworkInfo:eT,getDiskInfo:ZS,getMemoryInfo:XS,getCPUInfo:JS,getTimeInfo:zS,getSystemInformation:tT,systemInformation:JX,getTableSize:rT,getMetrics:nT};function zS(){return nr.time()}a(zS,"getTimeInfo");async function JS(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:o,governor:c,socket:l,cache:_,...u}=await nr.cpu();u.cpu_speed=await nr.cpuCurrentSpeed();let{raw_currentload:d,raw_currentload_idle:E,raw_currentload_irq:f,raw_currentload_nice:h,raw_currentload_system:p,raw_currentload_user:S,cpus:T,...A}=await nr.currentLoad();return A.cpus=[],T.forEach(b=>{let{raw_load:I,raw_load_idle:B,raw_load_irq:U,raw_load_nice:q,raw_load_system:M,raw_load_user:Q,...z}=b;A.cpus.push(z)}),u.current_load=A,u}catch(e){return mi.error(`error in getCPUInfo: ${e}`),{}}}a(JS,"getCPUInfo");async function XS(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await nr.mem();return Object.assign(s,process.memoryUsage())}catch(e){return mi.error(`error in getMemoryInfo: ${e}`),{}}}a(XS,"getMemoryInfo");async function jS(){let e={core:[],clustering:[]};try{let t=await nr.processes(),r;try{r=Number.parseInt(await YX.readFile(KX.join(sT.get(Ld.CONFIG_PARAMS.ROOTPATH),Ld.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===Ld.NODE_ERROR_CODES.ENOENT)mi.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 mi.error(`error in getHDBProcessInfo: ${t}`),e}}a(jS,"getHDBProcessInfo");async function ZS(){let e={};try{let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await nr.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:l,..._}=await nr.fsStats();return e.read_write=_,e.size=await nr.fsSize(),e}catch(t){return mi.error(`error in getDiskInfo: ${t}`),e}}a(ZS,"getDiskInfo");async function eT(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return e.default_interface=await nr.networkInterfaceDefault(),e.latency=await nr.inetChecksite("google.com"),(await nr.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:o,dhcp:c,dnsSuffix:l,ieee8021xAuth:_,ieee8021xState:u,carrier_changes:d,...E}=n;e.interfaces.push(E)}),(await nr.networkStats()).forEach(n=>{let{rx_sec:s,tx_sec:i,ms:o,...c}=n;e.stats.push(c)}),e}catch(t){return mi.error(`error in getNetworkInfo: ${t}`),e}}a(eT,"getNetworkInfo");async function tT(){if(Dd!==void 0)return Dd;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:o,...c}=await nr.osInfo();e=c;let l=await nr.versions("node, npm");return e.node_version=l.node,e.npm_version=l.npm,Dd=e,Dd}catch(t){return mi.error(`error in getSystemInformation: ${t}`),e}}a(tT,"getSystemInformation");async function rT(){let e=[],t=await QX.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await WX(n));return e}a(rT,"getTableSize");async function nT(){let e={};for(let t in QS){let r=e[t]={},n=r.tables={};for(let s in QS[t])try{let i=QS[t][s];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,d]=l.trim().split(" ");return{pid:_,thread:u,txnid:d}}),i.primaryStore.auditStore&&(r.audit=i.auditStore.getStats()));let o=i.primaryStore.getStats(),c={};for(let l of["treeDepth","treeBranchPageCount","treeLeafPageCount","entryCount","overflowPages"])c[l]=o[l];n[s]=c}catch(i){mi.notify(`Error getting stats for table ${s}: ${i}`)}}return e}a(nT,"getMetrics");async function gL(){if(sT.get(Ld.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{jsm:e}=await SL.getNATSReferences(),t=await SL.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(gL,"getNatsStreamInfo");async function JX(e){let t=new zX;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await tT(),t.time=zS(),t.cpu=await JS(),t.memory=await XS(),t.disk=await ZS(),t.network=await eT(),t.harperdb_processes=await jS(),t.table_size=await rT(),t.metrics=await nT(),t.threads=await TL(),t.replication=await gL(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await tT();break;case"time":t.time=zS();break;case"cpu":t.cpu=await JS();break;case"memory":t.memory=await XS();break;case"disk":t.disk=await ZS();break;case"network":t.network=await eT();break;case"harperdb_processes":t.harperdb_processes=await jS();break;case"table_size":t.table_size=await rT();break;case"database_metrics":case"metrics":t.metrics=await nT();break;case"threads":t.threads=await TL();break;case"replication":t.replication=await gL();break;default:break}return t}a(JX,"systemInformation")});var ml=g((Jde,XX)=>{XX.exports={name:"harperdb",version:"4.3.35",description:"HarperDB is a distributed database, caching service, streaming broker, and application development platform focused on performance and ease of use.",keywords:["database","nosql","api","distributed","broker","mqtt","real-time","enterprise","Fastify","NATS","HarperDB","Harper","clustering","replication","REST","WebSockets","decentralized","server-sent events","document store"],main:"harperdb.js",bin:{harperdb:"./bin/harperdb.js"},engines:{"minimum-node":"16.0.0","go-lang":"1.21.7","nats-server":"2.10.11"},exports:{".":"./index.js"},homepage:"https://www.harperdb.io/",bugs:"support@harperdb.io",author:{name:"HarperDB",email:"support@harperdb.io"},license:"SEE LICENSE IN LICENSE",scripts:{submodules:"git submodule update --init --recursive",build:"eslint -c ./.eslintbuild bin/ dataLayer/ security/ server/ sqlTranslator/ upgrade/ utility/ validation/",pretty:"eslint --fix bin/ dataLayer/ security/ server/ sqlTranslator/ upgrade/ utility/ validation/","cover:test":"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && nyc --no-clean --reporter=lcovonly npm run test:apitests && nyc --no-clean --reporter=lcovonly npm run test:resources && nyc --no-clean --reporter=lcovonly npm run test:logging && nyc --no-clean --reporter=lcovonly npm run test:upgrade && nyc --no-clean --reporter=lcovonly npm run test:nats && nyc --no-clean --reporter=lcovonly npm run test:cfserver && nyc --no-clean --reporter=lcovonly npm run test:hdbserver && nyc --no-clean --reporter=lcovonly npm run test:bin && nyc --no-clean --reporter=lcovonly npm run test:main && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license",test:"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && npm run test:apitests && npm run test:resources && npm run test:logging && npm run test:upgrade && npm run test:nats && npm run test:cfserver && npm run test:hdbserver && npm run test:bin && npm run test:main && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license","test:resources":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/resources/**/*.js' --config '../unitTests/.mocharc.json'","test:bin":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/bin/**/*.js' --config '../unitTests/.mocharc.json'","test:main":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --config '../unitTests/.mocharc-main.json'","test:lmdbbridge":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --config '../unitTests/.mocharc.json'","test:lmdbutility":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --config '../unitTests/.mocharc.json'","test:hdbserver":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --config '../unitTests/.mocharc.json'","test:cfserver":"npm run submodules && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/fastifyRoutes/customFunctionsServer-test.js' --config '../unitTests/.mocharc.json'","test:nats":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json'","test:upgrade":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --config '../unitTests/.mocharc.json'","test:apitests":"pm2 kill && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/apiTests/**/*-test.mjs' --config '../unitTests/.mocharc.json'","test:logging":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/logging/*.js' --config '../unitTests/.mocharc.json'","test:ci":" cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --retries 3 --config '../unitTests/.mocharc-main.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/customFunctions/customFunctionsServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter","hdb-check":"./utility/devops/hdb-check.sh","download-prebuilds":"node ./utility/devops/build/download-prebuilds.js",prebuild:"date",postinstall:"node ./launchServiceScripts/launchInstallNATSServer.js",build_nats_dependency:"node ./utility/devops/nats/builder.js",coverage:"nyc --reporter=lcov npm test"},dependencies:{"@aws-sdk/client-s3":"3.635.0","@aws-sdk/lib-storage":"3.635.0","@endo/static-module-record":"^1.0.4","@fastify/autoload":"5.7.1","@fastify/compress":"~6.5.0","@fastify/cors":"~8.5.0","@fastify/static":"~6.12.0","@turf/area":"6.5.0","@turf/boolean-contains":"6.5.0","@turf/boolean-disjoint":"6.5.0","@turf/boolean-equal":"6.5.0","@turf/circle":"6.5.0","@turf/difference":"6.5.0","@turf/distance":"6.5.0","@turf/helpers":"6.5.0","@turf/length":"6.5.0",alasql:"4.1.10","cbor-x":"1.5.8",chalk:"4.1.2","cli-progress":"3.12.0",clone:"2.1.2","fast-glob":"3.3.2",fastify:"~4.26.2","fastify-plugin":"~4.5.1","fs-extra":"11.2.0",graphql:"^16.8.1","human-readable-ids":"1.0.4",inquirer:"8.2.6","is-number":"7.0.0",joi:"17.12.2","json-bigint-fixes":"1.1.0",json2csv:"5.0.7",jsonata:"1.8.7",jsonwebtoken:"9.0.2",lmdb:"3.1.5",lodash:"4.17.21",mathjs:"11.12.0",minimist:"1.2.8",mkcert:"1.5.1",moment:"2.30.1","mqtt-packet":"~8.2.1",msgpackr:"1.11.2",nats:"2.19.0",needle:"3.3.1","node-stream-zip":"1.15.0","node-unix-socket":"0.2.5","normalize-path":"^3.0.0",ora:"5.4.1","ordered-binary":"1.5.3",papaparse:"5.4.1",passport:"0.6.0","passport-http":"0.3.0","passport-local":"1.0.0",pino:"8.16.0",pm2:"5.4.1",prompt:"1.3.0","properties-reader":"2.3.0","recursive-iterator":"3.3.0",semver:"7.5.4",send:"^0.18.0","serve-static":"1.15.0",ses:"1.1.0","stream-chain":"2.2.5","stream-json":"1.8.0",systeminformation:"5.22.9","tar-fs":"2.1.1",ulidx:"0.5.0",uuid:"9.0.1","validate.js":"0.13.1",ws:"8.17.1",yaml:"2.4.1"},devDependencies:{"@tsconfig/node16":"^1.0.3","@types/node":"latest","@typescript-eslint/eslint-plugin":"^5.55.0","@typescript-eslint/parser":"^5.55.0",axios:"1.6.8",chai:"4.4.1","chai-integer":"0.1.0",esbuild:"^0.20.2",eslint:"8.22.0","eslint-config-prettier":"8.3.0","eslint-plugin-prettier":"3.4.1","eslint-plugin-radar":"0.2.1",eventsource:"^2.0.2","hook-std":"3.0.0","intercept-stdout":"0.1.2",mocha:"^10.3.0","mocha-teamcity-reporter":"3.0.0","mock-require":"3.0.3","mock-stdin":"1.0.0",mqtt:"~4.3.8",newman:"5.3.2","newman-reporter-html":"1.0.5","newman-reporter-htmlextra":"1.22.11","newman-reporter-teamcity":"0.1.12","node-fetch":"2.6.7",nyc:"15.1.0",prettier:"2.8.4",rewire:"5.0.0",rimraf:"3.0.2",sinon:"10.0.0","sinon-chai":"3.7.0","source-map-support":"^0.5.21",typescript:"^5.4.2","why-is-node-still-running":"^1.0.0"},overrides:{"eslint-plugin-radar":{eslint:"8.22.0"},alasql:{xlsx:"0.18.5"}},optionalDependencies:{bufferutil:"^4.0.7","utf-8-validate":"^5.0.10"}}});var Pd=g((Xde,AL)=>{"use strict";AL.exports={version:jX,printVersion:ZX};var Md=ml();function jX(){if(Md)return Md.version}a(jX,"version");function ZX(){Md&&console.log(`HarperDB Version ${Md.version}`)}a(ZX,"printVersion")});var Is=g((tfe,NL)=>{"use strict";var ej=un(),iT=J(),tj=require("util"),oo=P(),OL=ne();OL.initSync();var rj=FS(),bL=Fr(),{Node:Zde,NodeSubscription:efe}=Ea(),nj=na(),sj=lL(),{RemotePayloadObject:ij,RemotePayloadSubscription:oj}=hl(),{handleHDBError:aj,hdb_errors:cj}=se(),{HTTP_STATUS_CODES:lj,HDB_ERROR_MSGS:uj}=cj,_j=rs(),dj=ha(),fj=Pd(),{getDatabases:Ej}=(Ae(),ie(ke)),hj=tj.promisify(rj.authorize),mj=bL.searchByHash,pj=bL.searchByValue;NL.exports={authHeaderToUser:Sj,isEmpty:Tj,getNodeRecord:gj,upsertNodeRecord:Rj,buildNodePayloads:Aj,checkClusteringEnabled:Oj,getAllNodeRecords:bj,getSystemInfo:yj,reverseSubscription:yL};async function Sj(e){let t={headers:{authorization:e.hdb_auth_header}};return e.hdb_user=await hj(t,null),e}a(Sj,"authHeaderToUser");function Tj(e){return e==null}a(Tj,"isEmpty");async function gj(e){let t=new nj(oo.SYSTEM_SCHEMA_NAME,oo.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return mj(t)}a(gj,"getNodeRecord");async function Rj(e){let t=new sj(oo.SYSTEM_SCHEMA_NAME,oo.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return ej.upsert(t)}a(Rj,"upsertNodeRecord");function yL(e){if(iT.isEmpty(e.subscribe)||iT.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(yL,"reverseSubscription");function Aj(e,t,r,n){let s=[];for(let i=0,o=e.length;i<o;i++){let c=e[i],{schema:l,table:_}=c,u=iT.getTableHashAttribute(l,_),{subscribe:d,publish:E}=yL(c),f=Ej()[l]?.[_],h=new oj(l,_,u,E,d,c.start_time,f.schemaDefined?f.attributes:void 0);s.push(h)}return new ij(r,t,s,n)}a(Aj,"buildNodePayloads");function Oj(){if(!OL.get(oo.CONFIG_PARAMS.CLUSTERING_ENABLED))throw aj(new Error,uj.CLUSTERING_NOT_ENABLED,lj.BAD_REQUEST,void 0,void 0,!0)}a(Oj,"checkClusteringEnabled");async function bj(){let e=new _j(oo.SYSTEM_SCHEMA_NAME,oo.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await pj(e))}a(bj,"getAllNodeRecords");async function yj(){let e=await dj.getSystemInformation();return{hdb_version:fj.version(),node_version:e.node_version,platform:e.platform}}a(yj,"getSystemInfo")});var oT=g((nfe,UL)=>{"use strict";var Ud=wt(),IL=J(),wL=ct(),CL=P(),vd=K(),DL=Rd(),Nj=xp(),{RemotePayloadObject:Ij}=hl(),{handleHDBError:LL,hdb_errors:wj}=se(),{HTTP_STATUS_CODES:ML}=wj,{NodeSubscription:PL}=Ea();UL.exports=Cj;async function Cj(e,t){let r;try{r=await Ud.request(`${t}.${wL.REQUEST_SUFFIX}`,new Ij(CL.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),vd.trace("Response from remote describe all request:",r)}catch(o){vd.error(`addNode received error from describe all request to remote node: ${o}`);let c=Ud.requestErrorHandler(o,"add_node",t);throw LL(new Error,c,ML.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===wL.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let o=`Error returned from remote node ${t}: ${r.message}`;throw LL(new Error,o,ML.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===CL.SYSTEM_SCHEMA_NAME){await Ud.createLocalTableStream(l,c);let h=new PL(l,c,o.publish,o.subscribe);h.start_time=o.start_time,i.push(h);continue}let _=IL.doesSchemaExist(l),u=n[l]!==void 0,d=c?IL.doesTableExist(l,c):!0,E=c?n?.[l]?.[c]!==void 0:!0;if(!_&&!u||!d&&!E){s.push(o);continue}if(!_&&u&&(vd.trace(`addNode creating schema: ${l}`),await DL.createSchema({operation:"create_schema",schema:l})),!d&&E){vd.trace(`addNode creating table: ${c} in schema: ${l} with attributes ${JSON.stringify(n[l][c].attributes)}`);let h=new Nj(l,c,n[l][c].hash_attribute);n[l][c].attributes&&(h.attributes=n[l][c].attributes),await DL.createTable(h)}await Ud.createLocalTableStream(l,c);let f=new PL(l,c,o.publish,o.subscribe);f.start_time=o.start_time,i.push(f)}return{added:i,skipped:s}}a(Cj,"reviewSubscriptions")});var Gd=g((ife,HL)=>{"use strict";var{handleHDBError:Bd,hdb_errors:Dj}=se(),{HTTP_STATUS_CODES:Hd}=Dj,{addUpdateNodeValidator:Lj}=Nd(),xd=K(),BL=P(),vL=ct(),Mj=J(),pl=wt(),Sl=Is(),Pj=ne(),Uj=oT(),{Node:vj,NodeSubscription:Bj}=Ea(),{broadcast:Hj}=it(),xj="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",Gj="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",Fj=Pj.get(BL.CONFIG_PARAMS.CLUSTERING_NODENAME);HL.exports=qj;async function qj(e,t=!1){xd.trace("addNode called with:",e),Sl.checkClusteringEnabled();let r=Lj(e);if(r)throw Bd(r,r.message,Hd.BAD_REQUEST,void 0,void 0,!0);let n=e.node_name;if(!t){let d=await Sl.getNodeRecord(n);if(!Mj.isEmptyOrZeroLength(d))throw Bd(new Error,`Node '${n}' has already been added, perform update_node to proceed.`,Hd.BAD_REQUEST,void 0,void 0,!0)}let{added:s,skipped:i}=await Uj(e.subscriptions,n),o={message:void 0,added:s,skipped:i};if(s.length===0)return o.message=xj,o;let c=Sl.buildNodePayloads(s,Fj,BL.OPERATIONS_ENUM.ADD_NODE,await Sl.getSystemInfo()),l=[];for(let d=0,E=s.length;d<E;d++){let f=s[d];s[d].start_time===void 0&&delete s[d].start_time,l.push(new Bj(f.schema,f.table,f.publish,f.subscribe))}xd.trace("addNode sending remote payload:",c);let _;try{_=await pl.request(`${n}.${vL.REQUEST_SUFFIX}`,c)}catch(d){xd.error(`addNode received error from request: ${d}`);for(let f=0,h=s.length;f<h;f++){let p=s[f];p.publish=!1,p.subscribe=!1,await pl.updateRemoteConsumer(p,n)}let E=pl.requestErrorHandler(d,"add_node",n);throw Bd(new Error,E,Hd.INTERNAL_SERVER_ERROR,"error",E)}if(_.status===vL.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let d=`Error returned from remote node ${n}: ${_.message}`;throw Bd(new Error,d,Hd.INTERNAL_SERVER_ERROR,"error",d)}xd.trace(_);for(let d=0,E=s.length;d<E;d++){let f=s[d];await pl.updateRemoteConsumer(f,n),f.subscribe===!0&&await pl.updateConsumerIterator(f.schema,f.table,n,"start")}let u=new vj(n,l,_.system_info);return await Sl.upsertNodeRecord(u),Hj({type:"nats_update"}),i.length>0?o.message=Gj:o.message=`Successfully added '${n}' to manifest`,o}a(qj,"addNode")});var lT=g((cfe,FL)=>{"use strict";var{handleHDBError:aT,hdb_errors:kj}=se(),{HTTP_STATUS_CODES:cT}=kj,{addUpdateNodeValidator:Vj}=Nd(),Tl=K(),GL=P(),xL=ct(),afe=J(),gl=wt(),Rl=Is(),$j=ne(),{cloneDeep:Yj}=require("lodash"),Kj=oT(),{Node:Wj,NodeSubscription:Qj}=Ea(),{broadcast:zj}=it(),Jj="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",Xj="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",jj=$j.get(GL.CONFIG_PARAMS.CLUSTERING_NODENAME);FL.exports=Zj;async function Zj(e){Tl.trace("updateNode called with:",e),Rl.checkClusteringEnabled();let t=Vj(e);if(t)throw aT(t,t.message,cT.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await Rl.getNodeRecord(r);s.length>0&&(n=Yj(s));let{added:i,skipped:o}=await Kj(e.subscriptions,r),c={message:void 0,updated:i,skipped:o};if(i.length===0)return c.message=Jj,c;let l=Rl.buildNodePayloads(i,jj,GL.OPERATIONS_ENUM.UPDATE_NODE,await Rl.getSystemInfo());for(let u=0,d=i.length;u<d;u++){let E=i[u];Tl.trace(`updateNode updating work stream for node: ${r} subscription:`,E),i[u].start_time===void 0&&delete i[u].start_time}Tl.trace("updateNode sending remote payload:",l);let _;try{_=await gl.request(`${r}.${xL.REQUEST_SUFFIX}`,l)}catch(u){Tl.error(`updateNode received error from request: ${u}`);let d=gl.requestErrorHandler(u,"update_node",r);throw aT(new Error,d,cT.INTERNAL_SERVER_ERROR,"error",d)}if(_.status===xL.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let u=`Error returned from remote node ${r}: ${_.message}`;throw aT(new Error,u,cT.INTERNAL_SERVER_ERROR,"error",u)}Tl.trace(_);for(let u=0,d=i.length;u<d;u++){let E=i[u];await gl.updateRemoteConsumer(E,r),E.subscribe===!0?await gl.updateConsumerIterator(E.schema,E.table,r,"start"):await gl.updateConsumerIterator(E.schema,E.table,r,"stop")}return n||(n=[new Wj(r,[],_.system_info)]),await eZ(n[0],i,_.system_info),o.length>0?c.message=Xj:c.message=`Successfully updated '${r}'`,c}a(Zj,"updateNode");async function eZ(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,_=e.subscriptions.length;l<_;l++){let u=n.subscriptions[l];if(u.schema===o.schema&&u.table===o.table){u.publish=o.publish,u.subscribe=o.subscribe,c=!0;break}}c||n.subscriptions.push(new Qj(o.schema,o.table,o.publish,o.subscribe))}n.system_info=r,await Rl.upsertNodeRecord(n),zj({type:"nats_update"})}a(eZ,"updateNodeTable")});var YL=g((ufe,$L)=>{"use strict";var VL=require("joi"),{string:qL}=VL.types(),tZ=at(),kL=P(),rZ=ne(),nZ=ct();$L.exports=sZ;function sZ(e){let t=qL.invalid(rZ.get(kL.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(nZ.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=VL.object({operation:qL.valid(kL.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return tZ.validateBySchema(e,r)}a(sZ,"removeNodeValidator")});var qd=g((dfe,JL)=>{"use strict";var{handleHDBError:KL,hdb_errors:iZ}=se(),{HTTP_STATUS_CODES:WL}=iZ,oZ=YL(),Al=K(),QL=Is(),aZ=J(),Fd=P(),zL=ct(),uT=wt(),cZ=ne(),{RemotePayloadObject:lZ}=hl(),{NodeSubscription:uZ}=Ea(),_Z=tl(),dZ=Ki(),{broadcast:fZ}=it(),EZ=cZ.get(Fd.CONFIG_PARAMS.CLUSTERING_NODENAME);JL.exports=hZ;async function hZ(e){Al.trace("removeNode called with:",e),QL.checkClusteringEnabled();let t=oZ(e);if(t)throw KL(t,t.message,WL.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await QL.getNodeRecord(r);if(aZ.isEmptyOrZeroLength(n))throw KL(new Error,`Node '${r}' was not found.`,WL.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new lZ(Fd.OPERATIONS_ENUM.REMOVE_NODE,EZ,[]),i,o=!1;for(let l=0,_=n.subscriptions.length;l<_;l++){let u=n.subscriptions[l];u.subscribe===!0&&await uT.updateConsumerIterator(u.schema,u.table,r,"stop");try{await uT.updateRemoteConsumer(new uZ(u.schema,u.table,!1,!1),r)}catch(d){Al.error(d)}}try{i=await uT.request(`${r}.${zL.REQUEST_SUFFIX}`,s),Al.trace("Remove node reply from remote node:",r,i)}catch(l){Al.error("removeNode received error from request:",l),o=!0}let c=new _Z(Fd.SYSTEM_SCHEMA_NAME,Fd.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await dZ.deleteRecord(c),fZ({type:"nats_update"}),i?.status===zL.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||o?(Al.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(hZ,"removeNode")});var ZL=g((Efe,jL)=>{"use strict";var XL=require("joi"),{string:mZ,array:pZ}=XL.types(),SZ=at(),TZ=Nd();jL.exports=gZ;function gZ(e){let t=XL.object({operation:mZ.valid("configure_cluster").required(),connections:pZ.items(TZ.validation_schema).required()});return SZ.validateBySchema(e,t)}a(gZ,"configureClusterValidator")});var _T=g((mfe,sM)=>{"use strict";var RZ=P(),kd=K(),AZ=J(),OZ=qd(),bZ=Gd(),eM=Is(),yZ=ZL(),{handleHDBError:tM,hdb_errors:NZ}=se(),{HTTP_STATUS_CODES:rM}=NZ,IZ="Configure cluster complete.",wZ="Failed to configure the cluster. Check the logs for more details.",CZ="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";sM.exports=DZ;async function DZ(e){kd.trace("configure cluster called with:",e),eM.checkClusteringEnabled();let t=yZ(e);if(t)throw tM(t,t.message,rM.BAD_REQUEST,void 0,void 0,!0);let r=await eM.getAllNodeRecords(),n=[];for(let u=0,d=r.length;u<d;u++){let E=await nM(OZ,{operation:RZ.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[u].name},r[u].name);n.push(E)}kd.trace("All results from configure_cluster remove node:",n);let s=[],i=e.connections.length;for(let u=0;u<i;u++){let d=e.connections[u],E=await nM(bZ,d,d.node_name);s.push(E)}kd.trace("All results from configure_cluster add node:",s);let o=[],c=[],l=!1,_=n.concat(s);for(let u=0,d=_.length;u<d;u++){let E=_[u];E.status==="rejected"&&(kd.error(E),o.includes(E.node_name)||o.push(E.node_name)),(E?.result?.message?.includes?.("Successfully")||E?.result?.includes?.("Successfully"))&&(l=!0),!(typeof E.result=="string"&&E.result.includes("Successfully removed")||E.status==="rejected")&&c.push({node_name:E?.node_name,subscriptions:E?.result})}if(AZ.isEmptyOrZeroLength(o))return{message:IZ,connections:c};if(l)return{message:CZ,failed_nodes:o,connections:c};throw tM(new Error,wZ,rM.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(DZ,"configureCluster");async function nM(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){return{node_name:r,error:n,status:"rejected"}}}a(nM,"functionWrapper")});var cM=g((Sfe,aM)=>{"use strict";var Ol=require("joi"),LZ=at(),{validateSchemaExists:iM,validateTableExists:MZ,validateSchemaName:oM}=Xn(),PZ=Ol.object({operation:Ol.string().valid("purge_stream"),schema:Ol.string().custom(iM).custom(oM).optional(),database:Ol.string().custom(iM).custom(oM).optional(),table:Ol.string().custom(MZ).required()});function UZ(e){return LZ.validateBySchema(e,PZ)}a(UZ,"purgeStreamValidator");aM.exports=UZ});var dT=g((gfe,lM)=>{"use strict";var{handleHDBError:vZ,hdb_errors:BZ}=se(),{HTTP_STATUS_CODES:HZ}=BZ,xZ=cM(),GZ=wt(),FZ=Is();lM.exports=qZ;async function qZ(e){e.schema=e.schema??e.database;let t=xZ(e);if(t)throw vZ(t,t.message,HZ.BAD_REQUEST,void 0,void 0,!0);FZ.checkClusteringEnabled();let{schema:r,table:n,options:s}=e;return await GZ.purgeTableStream(r,n,s),`Successfully purged table '${r}.${n}'`}a(qZ,"purgeStream")});var hT=g((Afe,hM)=>{"use strict";var ET=Is(),kZ=wt(),dM=ne(),Vd=P(),ao=ct(),VZ=J(),fT=K(),{RemotePayloadObject:$Z}=hl(),{ErrorCode:uM}=require("nats"),_M=dM.get(Vd.CONFIG_PARAMS.CLUSTERING_ENABLED),fM=dM.get(Vd.CONFIG_PARAMS.CLUSTERING_NODENAME);hM.exports={clusterStatus:YZ,buildNodeStatus:EM};async function YZ(){let e={node_name:fM,is_enabled:_M,connections:[]};if(!_M)return e;let t=await ET.getAllNodeRecords();if(VZ.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(EM(t[n],e.connections));return await Promise.allSettled(r),e}a(YZ,"clusterStatus");async function EM(e,t){let r=e.name,n=new $Z(Vd.OPERATIONS_ENUM.CLUSTER_STATUS,fM,void 0,await ET.getSystemInfo()),s,i,o=ao.CLUSTER_STATUS_STATUSES.OPEN;try{let l=Date.now();s=await kZ.request(ao.REQUEST_SUBJECT(r),n),i=Date.now()-l,s.status===ao.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=ao.CLUSTER_STATUS_STATUSES.CLOSED,fT.error(`Error getting node status from ${r} `,s))}catch(l){fT.warn(`Error getting node status from ${r}`,l),l.code===uM.NoResponders?o=ao.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:l.code===uM.Timeout?o=ao.CLUSTER_STATUS_STATUSES.TIMEOUT:o=ao.CLUSTER_STATUS_STATUSES.CLOSED}let c=new KZ(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!==Vd.PRE_4_0_0_VERSION&&await ET.upsertNodeRecord(l)}catch(l){fT.error("Cluster status encountered an error updating system info for node:",r,l)}t.push(c)}a(EM,"buildNodeStatus");function KZ(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(KZ,"NodeStatusObject")});var pT=g((bfe,mM)=>{"use strict";var{handleHDBError:WZ,hdb_errors:QZ}=se(),{HTTP_STATUS_CODES:zZ}=QZ,JZ=wt(),XZ=Is(),mT=J(),$d=require("joi"),jZ=at(),ZZ=2e3,e5=$d.object({timeout:$d.number().min(1),connected_nodes:$d.boolean(),routes:$d.boolean()});mM.exports=t5;async function t5(e){XZ.checkClusteringEnabled();let t=jZ.validateBySchema(e,e5);if(t)throw WZ(t,t.message,zZ.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||mT.autoCastBoolean(n),o=s===void 0||mT.autoCastBoolean(s),c={nodes:[]},l=await JZ.getServerList(r??ZZ),_={};if(i)for(let u=0,d=l.length;u<d;u++){let E=l[u].statsz;E&&(_[l[u].server.name]=E.routes)}for(let u=0,d=l.length;u<d;u++){if(l[u].statsz)continue;let E=l[u].server,f=l[u].data;if(E.name.endsWith("-hub")){let h={name:E.name.slice(0,-4),response_time:l[u].response_time};i&&(h.connected_nodes=[],_[E.name]&&_[E.name].forEach(p=>{h.connected_nodes.includes(p.name.slice(0,-4))||h.connected_nodes.push(p.name.slice(0,-4))})),o&&(h.routes=f.cluster?.urls?f.cluster?.urls.map(p=>({host:p.split(":")[0],port:mT.autoCast(p.split(":")[1])})):[]),c.nodes.push(h)}}return c}a(t5,"clusterNetwork")});var gM=g((Nfe,TM)=>{"use strict";var ST=require("joi"),pM=at(),{route_constraints:SM}=Jm();TM.exports={setRoutesValidator:r5,deleteRoutesValidator:n5};function r5(e){let t=ST.object({server:ST.valid("hub","leaf").required(),routes:SM.required()});return pM.validateBySchema(e,t)}a(r5,"setRoutesValidator");function n5(e){let t=ST.object({routes:SM.required()});return pM.validateBySchema(e,t)}a(n5,"deleteRoutesValidator")});var gT=g((wfe,bM)=>{"use strict";var co=pr(),TT=J(),Yd=P(),RM=gM(),{handleHDBError:AM,hdb_errors:s5}=se(),{HTTP_STATUS_CODES:OM}=s5,i5="cluster routes successfully set",o5="cluster routes successfully deleted";bM.exports={setRoutes:a5,getRoutes:c5,deleteRoutes:l5};function a5(e){let t=RM.setRoutesValidator(e);if(t)throw AM(t,t.message,OM.BAD_REQUEST,void 0,void 0,!0);let r=co.getClusteringRoutes(),n=e.server==="hub"?r.hub_routes:r.leaf_routes,s=e.server==="hub"?r.leaf_routes:r.hub_routes,i=[],o=[];for(let c=0,l=e.routes.length;c<l;c++){let _=e.routes[c];_.port=TT.autoCast(_.port);let u=n.some(E=>E.host===_.host&&E.port===_.port),d=s.some(E=>E.host===_.host&&E.port===_.port);u||d?i.push(_):(n.push(_),o.push(_))}return e.server==="hub"?co.updateConfigValue(Yd.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,n):co.updateConfigValue(Yd.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n),{message:i5,set:o,skipped:i}}a(a5,"setRoutes");function c5(){let e=co.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}a(c5,"getRoutes");function l5(e){let t=RM.deleteRoutesValidator(e);if(t)throw AM(t,t.message,OM.BAD_REQUEST,void 0,void 0,!0);let r=co.getClusteringRoutes(),n=r.hub_routes,s=r.leaf_routes,i=[],o=[],c=!1,l=!1;for(let _=0,u=e.routes.length;_<u;_++){let d=e.routes[_],E=!1;for(let f=0,h=n.length;f<h;f++){let p=n[f];if(d.host===p.host&&d.port===p.port){n.splice(f,1),E=!0,c=!0,i.push(d);break}}if(!E){let f=!0;for(let h=0,p=s.length;h<p;h++){let S=s[h];if(d.host===S.host&&d.port===S.port){s.splice(h,1),l=!0,f=!1,i.push(d);break}}f&&o.push(d)}}return c&&(n=TT.isEmptyOrZeroLength(n)?null:n,co.updateConfigValue(Yd.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,n)),l&&(s=TT.isEmptyOrZeroLength(s)?null:s,co.updateConfigValue(Yd.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,s)),{message:o5,deleted:i,skipped:o}}a(l5,"deleteRoutes")});var NM=g((Dfe,yM)=>{"use strict";var bl=require("alasql"),lo=require("recursive-iterator"),Bn=K(),u5=J(),yl=P(),RT=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,d5(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=>yl.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=>!yl.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][yl.PERMS_CRUD_ENUM.READ]){let c;t[i].tables[o].attribute_permissions.length>0?c=_5(t[i].tables[o].attribute_permissions):c=global.hdb_schema[i][o].attributes.map(_=>({attribute_name:_.attribute}));let l=this.affected_attributes.get(i).get(o).filter(_=>!yl.SEARCH_WILDCARDS.includes(_));c.forEach(({attribute_name:_})=>{let u=new bl.yy.Column({columnid:_});s.tableid&&(u.tableid=s.tableid),this.ast.columns.push(u),l.includes(_)||l.push(_)}),this.affected_attributes.get(i).set(o,l)}}),this.ast}};function _5(e){return e.filter(t=>t[yl.PERMS_CRUD_ENUM.READ])}a(_5,"filterReadRestrictedAttrs");function d5(e,t,r,n,s){f5(e,t,r,n,s)}a(d5,"interpretAST");function Nl(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(Nl,"addSchemaTableToMap");function f5(e,t,r,n,s){if(!e){Bn.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof bl.yy.Insert?p5(e,t,r):e instanceof bl.yy.Select?E5(e,t,r,n,s):e instanceof bl.yy.Update?h5(e,t,r):e instanceof bl.yy.Delete?m5(e,t,r):Bn.error("AST in getRecordAttributesAST() is not a valid SQL type.")}a(f5,"getRecordAttributesAST");function E5(e,t,r,n,s){if(!e){Bn.info("getSelectAttributes: invalid SQL syntax tree");return}if(!e.from||e.from[0]===void 0)return;let i=e.from[0].databaseid;if(u5.isEmptyOrZeroLength(i)){Bn.error("No schema specified");return}e.from.forEach(c=>{Nl(c,t,r,n,s)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),Nl(c.table,t,r,n,s)});let o=new lo(e.columns);for(let{node:c}of o)if(c&&c.columnid){let l=c.tableid,_=n.has(l)?n.get(l):i;if(l||(l=e.from[0].tableid),!t.get(_).has(l))if(r.has(l))l=r.get(l);else{Bn.info(`table specified as ${l} not found.`);return}t.get(_).get(l).indexOf(c.columnid)<0&&t.get(_).get(l).push(c.columnid)}if(e.where){let c=new lo(e.where),l=e.from[0].tableid;for(let{node:_}of c)if(_&&_.columnid){let u=_.tableid?_.tableid:l;if(!t.get(i).has(u))if(r.has(u))u=r.get(u);else{Bn.info(`table specified as ${u} not found.`);continue}t.get(i).get(u).indexOf(_.columnid)<0&&t.get(i).get(u).push(_.columnid)}}if(e.joins&&e.joins.forEach(c=>{let l=new lo(c.on);for(let{node:_}of l)if(_&&_.columnid){let u=_.tableid,d=s.get(u);if(!t.get(d).has(u))if(r.has(u))u=r.get(u);else{Bn.info(`table specified as ${u} not found.`);continue}t.get(d).get(u).indexOf(_.columnid)<0&&t.get(d).get(u).push(_.columnid)}}),e.order){let c=new lo(e.order);for(let{node:l}of c)if(l&&l.columnid){let _=l.tableid,u=n.has(_)?n.get(_):i;if(_||(_=e.from[0].tableid),!t.get(u).has(_))if(r.has(_))_=r.get(_);else{Bn.info(`table specified as ${_} not found.`);return}t.get(u).get(_).indexOf(l.columnid)<0&&t.get(u).get(_).push(l.columnid)}}}a(E5,"getSelectAttributes");function h5(e,t,r){if(!e){Bn.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new lo(e.columns),s=e.table.databaseid;Nl(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&AT(e.table.tableid,s,i.columnid,t,r)}a(h5,"getUpdateAttributes");function m5(e,t,r){if(!e){Bn.info("getDeleteAttributes: invalid SQL syntax tree");return}let n=new lo(e.where),s=e.table.databaseid;Nl(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&AT(e.table.tableid,s,i.columnid,t,r)}a(m5,"getDeleteAttributes");function p5(e,t,r){if(!e){Bn.info("getInsertAttributes: invalid SQL syntax tree");return}let n=new lo(e.columns),s=e.into.databaseid;Nl(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&AT(e.into.tableid,s,i.columnid,t,r)}a(p5,"getInsertAttributes");function AT(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(AT,"pushAttribute");yM.exports=RT});var yT=g((Mfe,DM)=>{var Kd=Ji(),IM=require("chalk"),Wr=K(),wM=require("prompt"),{promisify:S5}=require("util"),OT=P(),T5=require("fs-extra"),g5=require("path"),R5=J(),A5=Pd(),CM=ne();CM.initSync();var O5=require("moment"),b5=S5(wM.get),y5=g5.join(CM.getHdbBasePath(),OT.LICENSE_KEY_DIR_NAME,OT.LICENSE_FILE_NAME,OT.LICENSE_FILE_NAME);DM.exports={getFingerprint:I5,setLicense:N5,parseLicense:bT,register:w5,getRegistrationInfo:D5};async function N5(e){if(e&&e.key&&e.company){try{Wr.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await bT(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw Wr.error(r),Wr.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}a(N5,"setLicense");async function I5(){let e={};try{e=await Kd.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw Wr.error(r),Wr.error(t),new Error(r)}return e}a(I5,"getFingerprint");async function bT(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");Wr.info("Validating license input...");let r=Kd.validateLicense(e,t);if(Wr.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(Wr.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(Wr.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{Wr.info("writing license to disk"),await T5.writeFile(y5,JSON.stringify({license_key:e,company:t}))}catch(n){throw Wr.error("Failed to write License"),n}return"Registration successful."}a(bT,"parseLicense");async function w5(){let e=await C5();return bT(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(w5,"register");async function C5(){let e=await Kd.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:IM.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:IM.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{wM.start()}catch(n){Wr.error(n)}let r;try{r=await b5(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}a(C5,"promptForRegistration");async function D5(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await Kd.getLicense()}catch(r){throw Wr.error(`There was an error when searching licenses due to: ${r.message}`),r}if(R5.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=A5.version(),e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=O5.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(D5,"getRegistrationInfo")});var MM=g((Ufe,LM)=>{"use strict";var L5=ct(),NT=class{static{a(this,"HubConfigObject")}constructor(t,r,n,s,i,o,c,l,_,u,d,E,f,h){this.port=t,o===null&&(o=void 0),this.server_name=r+L5.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:_,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c}},this.cluster={name:u,port:d,routes:E,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l}},this.accounts={SYS:{users:f},HDB:{users:h}},this.system_account="SYS"}};LM.exports=NT});var vM=g((Bfe,UM)=>{"use strict";var PM=ct(),IT=class{static{a(this,"LeafConfigObject")}constructor(t,r,n,s,i,o,c,l,_,u,d){this.port=t,d===null&&(d=void 0),this.server_name=r+PM.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+PM.SERVER_SUFFIX.LEAF},this.tls={cert_file:_,key_file:u,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"}};UM.exports=IT});var HM=g((xfe,BM)=>{"use strict";var wT=class{static{a(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};BM.exports=wT});var GM=g((Ffe,xM)=>{"use strict";var M5=ct(),CT=class{static{a(this,"SysUserObject")}constructor(t,r){this.user=t+M5.SERVER_SUFFIX.ADMIN,this.password=r}};xM.exports=CT});var MT=g((kfe,kM)=>{"use strict";var ma=require("path"),zd=require("fs-extra"),P5=MM(),U5=vM(),v5=HM(),B5=GM(),DT=_n(),Sa=J(),Nr=pr(),Qd=P(),Il=ct(),{CONFIG_PARAMS:mt}=Qd,Ta=K(),wl=ne(),FM=As(),LT=wt(),pa="clustering",H5=1e4,qM=50;kM.exports={generateNatsConfig:G5,removeNatsConfig:F5,getHubConfigPath:x5};function x5(){let e=wl.get(mt.ROOTPATH);return ma.join(e,pa,Il.NATS_CONFIG_FILES.HUB_SERVER)}a(x5,"getHubConfigPath");async function G5(e=!1,t=void 0){wl.initSync();let r=wl.get(mt.ROOTPATH),n=ma.join(r,pa,Il.PID_FILES.HUB),s=ma.join(r,pa,Il.PID_FILES.LEAF),i=Nr.getConfigFromFile(mt.CLUSTERING_LEAFSERVER_STREAMS_PATH),o=ma.join(r,pa,Il.NATS_CONFIG_FILES.HUB_SERVER),c=ma.join(r,pa,Il.NATS_CONFIG_FILES.LEAF_SERVER),l=Nr.getConfigFromFile(mt.CLUSTERING_TLS_CERTIFICATE),_=Nr.getConfigFromFile(mt.CLUSTERING_TLS_PRIVATEKEY),u=Nr.getConfigFromFile(mt.CLUSTERING_TLS_CERT_AUTH),d=Nr.getConfigFromFile(mt.CLUSTERING_TLS_INSECURE),E=Nr.getConfigFromFile(mt.CLUSTERING_TLS_VERIFY),f=Nr.getConfigFromFile(mt.CLUSTERING_NODENAME),h=Nr.getConfigFromFile(mt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await LT.checkNATSServerInstalled()||Jd("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let p=await DT.listUsers(),S=Nr.getConfigFromFile(mt.CLUSTERING_USER),T=await DT.getClusterUser();(Sa.isEmpty(T)||T.active!==!0)&&Jd(`Invalid cluster user '${S}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await Wd(mt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await Wd(mt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await Wd(mt.CLUSTERING_HUBSERVER_NETWORK_PORT),await Wd(mt.CLUSTERING_LEAFSERVER_NETWORK_PORT));let A=[],b=[];for(let[z,j]of p.entries())j.role?.role===Qd.ROLE_TYPES_ENUM.CLUSTER_USER&&j.active&&(A.push(new B5(j.username,FM.decrypt(j.hash))),b.push(new v5(j.username,FM.decrypt(j.hash))));let I=[],{hub_routes:B}=Nr.getClusteringRoutes();if(!Sa.isEmptyOrZeroLength(B))for(let z of B)I.push(`tls://${T.sys_name_encoded}:${T.uri_encoded_d_hash}@${z.host}:${z.port}`);let U=new P5(Nr.getConfigFromFile(mt.CLUSTERING_HUBSERVER_NETWORK_PORT),f,n,l,_,u,d,E,h,Nr.getConfigFromFile(mt.CLUSTERING_HUBSERVER_CLUSTER_NAME),Nr.getConfigFromFile(mt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),I,A,b);u==null&&(delete U.tls.ca_file,delete U.leafnodes.tls.ca_file),t=Sa.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===Qd.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await zd.writeJson(o,U),Ta.trace(`Hub server config written to ${o}`));let q=`tls://${T.sys_name_encoded}:${T.uri_encoded_d_hash}@0.0.0.0:${h}`,M=`tls://${T.uri_encoded_name}:${T.uri_encoded_d_hash}@0.0.0.0:${h}`,Q=new U5(Nr.getConfigFromFile(mt.CLUSTERING_LEAFSERVER_NETWORK_PORT),f,s,i,[q],[M],A,b,l,_,u,d);u==null&&delete Q.tls.ca_file,(t===void 0||t===Qd.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await zd.writeJson(c,Q),Ta.trace(`Leaf server config written to ${c}`))}a(G5,"generateNatsConfig");async function Wd(e){let t=wl.get(e);return Sa.isEmpty(t)&&Jd(`port undefined for '${e}'`),await Sa.isPortTaken(t)&&Jd(`'${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(Wd,"isPortAvailable");function Jd(e){let t=`Error generating clustering config: ${e}`;Ta.error(t),console.error(t),process.exit(1)}a(Jd,"generateNatsConfigError");async function F5(e){let{port:t,config_file:r}=LT.getServerConfig(e),{username:n,decrypt_hash:s}=await DT.getClusterUser(),i=0,o=2e3;for(;i<qM;){try{let u=await LT.createConnection(t,n,s,!1);if(u.protocol.connected===!0){u.close();break}}catch(u){Ta.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${u}`)}if(i++,i>=qM)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 _=o*(i*2);_>3e4&&Ta.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await Sa.async_set_timeout(_)}let c="0".repeat(H5),l=ma.join(wl.get(mt.ROOTPATH),pa,r);await zd.writeFile(l,c),await zd.remove(l),Ta.notify(e,"started.")}a(F5,"removeNatsConfig")});var QM=g(($fe,WM)=>{"use strict";var Qr=ne(),q5=Ji(),pe=P(),Cl=ct(),ws=require("path"),{PACKAGE_ROOT:jd}=P(),VM=ne(),Xd=J(),ga="/dev/null",k5=ws.join(jd,"launchServiceScripts"),$M=ws.join(jd,"utility/scripts"),V5=ws.join($M,pe.HDB_RESTART_SCRIPT),YM=ws.resolve(jd,"dependencies",`${process.platform}-${process.arch}`,Cl.NATS_BINARY_NAME);function KM(){let t=q5.licenseSearch().ram_allocation||pe.RAM_ALLOCATION_ENUM.DEFAULT,r=pe.MEM_SETTING_KEY+t,n={[pe.PROCESS_NAME_ENV_PROP]:pe.PROCESS_DESCRIPTORS.HDB,IS_SCRIPTED_SERVICE:!0};return Xd.noBootFile()&&(n[pe.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Xd.getEnvCliRootPath()),{name:pe.PROCESS_DESCRIPTORS.HDB,script:pe.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:n,node_args:r,cwd:jd}}a(KM,"generateMainServerConfig");var $5=9930;function Y5(){Qr.initSync(!0);let e=Qr.get(pe.CONFIG_PARAMS.ROOTPATH),t=ws.join(e,"clustering",Cl.NATS_CONFIG_FILES.HUB_SERVER),r=ws.join(Qr.get(pe.HDB_SETTINGS_NAMES.LOG_PATH_KEY),pe.LOG_NAMES.HDB),n=VM.get(pe.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=Cl.LOG_LEVEL_FLAGS[Qr.get(pe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:pe.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==$5?"-"+n:""),script:YM,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[pe.PROCESS_NAME_ENV_PROP]:pe.PROCESS_DESCRIPTORS.CLUSTERING_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return Qr.get(pe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=ga,i.error_file=ga),i}a(Y5,"generateNatsHubServerConfig");var K5=9940;function W5(){Qr.initSync(!0);let e=Qr.get(pe.CONFIG_PARAMS.ROOTPATH),t=ws.join(e,"clustering",Cl.NATS_CONFIG_FILES.LEAF_SERVER),r=ws.join(Qr.get(pe.HDB_SETTINGS_NAMES.LOG_PATH_KEY),pe.LOG_NAMES.HDB),n=VM.get(pe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=Cl.LOG_LEVEL_FLAGS[Qr.get(pe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:pe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==K5?"-"+n:""),script:YM,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[pe.PROCESS_NAME_ENV_PROP]:pe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF},merge_logs:!0,out_file:r,error_file:r,instances:1};return Qr.get(pe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=ga,i.error_file=ga),i}a(W5,"generateNatsLeafServerConfig");function Q5(){Qr.initSync();let e=ws.join(Qr.get(pe.CONFIG_PARAMS.LOGGING_ROOT),pe.LOG_NAMES.HDB),t={name:pe.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,script:pe.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[pe.PROCESS_NAME_ENV_PROP]:pe.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:k5,autorestart:!1};return Qr.get(pe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=ga,t.error_file=ga),t}a(Q5,"generateClusteringUpgradeV4ServiceConfig");function z5(){let e={[pe.PROCESS_NAME_ENV_PROP]:pe.PROCESS_DESCRIPTORS.RESTART_HDB};return Xd.noBootFile()&&(e[pe.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Xd.getEnvCliRootPath()),{...{name:pe.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:$M},script:V5}}a(z5,"generateRestart");function J5(){return{apps:[KM()]}}a(J5,"generateAllServiceConfigs");WM.exports={generateAllServiceConfigs:J5,generateMainServerConfig:KM,generateRestart:z5,generateNatsHubServerConfig:Y5,generateNatsLeafServerConfig:W5,generateClusteringUpgradeV4ServiceConfig:Q5}});var lP=g((Wfe,cP)=>{"use strict";var ve=P(),X5=J(),Ds=MT(),Zd=wt(),Cs=ct(),pi=QM(),ef=ne(),Si=K(),j5=Is(),{startWorker:zM,onMessageFromWorkers:Z5}=it(),e8=ha(),Kfe=require("util"),t8=require("child_process"),r8=require("fs"),{execFile:n8}=t8,Ie;cP.exports={enterPM2Mode:s8,start:Ti,stop:PT,reload:XM,restart:jM,list:UT,describe:tP,connect:Ls,kill:l8,startAllServices:u8,startService:vT,getUniqueServicesList:rP,restartAllServices:_8,isServiceRegistered:nP,reloadStopStart:sP,restartHdb:eP,deleteProcess:a8,startClusteringProcesses:oP,startClusteringThreads:aP,isHdbRestartRunning:c8,isClusteringRunning:f8,stopClustering:d8,reloadClustering:E8,expectedRestartOfChildren:ZM};var Dl=!1;Z5(e=>{e.type==="restart"&&ef.initSync(!0)});function s8(){Dl=!0}a(s8,"enterPM2Mode");function Ls(){return Ie||(Ie=require("pm2")),new Promise((e,t)=>{Ie.connect((r,n)=>{Si.setupConsoleLogging(),r&&t(r),e(n)})})}a(Ls,"connect");var sr,i8=10,JM;function Ti(e,t=!1){if(Dl)return o8(e);let r=n8(e.script,e.args.split(" "),e);r.name=e.name,r.config=e,r.on("exit",async i=>{let o=sr.indexOf(r);o>-1&&sr.splice(o,1),!JM&&i!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<i8&&(r8.existsSync(Ds.getHubConfigPath())?Ti(e):(await Ds.generateNatsConfig(!0),Ti(e),await new Promise(c=>setTimeout(c,3e3)),await Ds.removeNatsConfig(ve.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await Ds.removeNatsConfig(ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let n={serviceName:e.name.replace(/ /g,"-")};function s(i){let o=ef.get(ve.CONFIG_PARAMS.CLUSTERING_LOGLEVEL),c=/\[\d+][^\[]+\[(\w+)]/g,l,_=0,u;for(;l=c.exec(i);){if(l.index&&Cs.LOG_LEVEL_HIERARCHY[o]>=Cs.LOG_LEVEL_HIERARCHY[u||"info"]){let f=u===Cs.LOG_LEVELS.ERR||u===Cs.LOG_LEVELS.WRN?Si.OUTPUTS.STDERR:Si.OUTPUTS.STDOUT;Si.logCustomLevel(u||"info",f,n,i.slice(_,l.index).trim())}let[d,E]=l;_=l.index+d.length,u=Cs.LOG_LEVELS[E]}if(Cs.LOG_LEVEL_HIERARCHY[o]>=Cs.LOG_LEVEL_HIERARCHY[u||"info"]){let d=u===Cs.LOG_LEVELS.ERR||u===Cs.LOG_LEVELS.WRN?Si.OUTPUTS.STDERR:Si.OUTPUTS.STDOUT;Si.logCustomLevel(u||"info",d,n,i.slice(_).trim())}}if(a(s,"extractMessages"),r.stdout.on("data",s),r.stderr.on("data",s),r.unref(),!sr&&(sr=[],!t)){let i=a(()=>{JM=!0,sr&&(sr.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)}sr.push(r)}a(Ti,"start");function o8(e){return new Promise(async(t,r)=>{try{await Ls()}catch(n){r(n)}Ie.start(e,(n,s)=>{n&&(Ie.disconnect(),r(n)),Ie.disconnect(),t(s)})})}a(o8,"startWithPM2");function PT(e){if(!Dl){for(let t of sr||[])t.name===e&&(sr.splice(sr.indexOf(t),1),t.kill());return}return new Promise(async(t,r)=>{try{await Ls()}catch(n){r(n)}Ie.stop(e,async(n,s)=>{n&&(Ie.disconnect(),r(n)),Ie.delete(e,(i,o)=>{i&&(Ie.disconnect(),r(n)),Ie.disconnect(),t(o)})})})}a(PT,"stop");function XM(e){return new Promise(async(t,r)=>{try{await Ls()}catch(n){r(n)}Ie.reload(e,(n,s)=>{n&&(Ie.disconnect(),r(n)),Ie.disconnect(),t(s)})})}a(XM,"reload");function jM(e){if(!Dl){ZM();for(let t of sr||[])t.name===e&&t.kill()}return new Promise(async(t,r)=>{try{await Ls()}catch(n){r(n)}Ie.restart(e,(n,s)=>{Ie.disconnect(),t(s)})})}a(jM,"restart");function ZM(){for(let e of sr||[])e.config&&(e.config.restarts=0)}a(ZM,"expectedRestartOfChildren");function a8(e){return new Promise(async(t,r)=>{try{await Ls()}catch(n){r(n)}Ie.delete(e,(n,s)=>{n&&(Ie.disconnect(),r(n)),Ie.disconnect(),t(s)})})}a(a8,"deleteProcess");async function eP(){await Ti(pi.generateRestart())}a(eP,"restartHdb");async function c8(){let e=await UT();for(let t in e)if(e[t].name===ve.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}a(c8,"isHdbRestartRunning");function UT(){return new Promise(async(e,t)=>{try{await Ls()}catch(r){t(r)}Ie.list((r,n)=>{r&&(Ie.disconnect(),t(r)),Ie.disconnect(),e(n)})})}a(UT,"list");function tP(e){return new Promise(async(t,r)=>{try{await Ls()}catch(n){r(n)}Ie.describe(e,(n,s)=>{n&&(Ie.disconnect(),r(n)),Ie.disconnect(),t(s)})})}a(tP,"describe");function l8(){if(!Dl){for(let e of sr||[])e.kill();sr=[];return}return new Promise(async(e,t)=>{try{await Ls()}catch(r){t(r)}Ie.killDaemon((r,n)=>{r&&(Ie.disconnect(),t(r)),Ie.disconnect(),e(n)})})}a(l8,"kill");async function u8(){try{await oP(),await aP(),await Ti(pi.generateAllServiceConfigs())}catch(e){throw Ie?.disconnect(),e}}a(u8,"startAllServices");async function vT(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case ve.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=pi.generateMainServerConfig();break;case ve.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=pi.generateNatsIngestServiceConfig();break;case ve.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=pi.generateNatsReplyServiceConfig();break;case ve.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=pi.generateNatsHubServerConfig(),await Ti(r,t),await Ds.removeNatsConfig(e);return;case ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=pi.generateNatsLeafServerConfig(),await Ti(r,t),await Ds.removeNatsConfig(e);return;case ve.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=pi.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await Ti(r)}catch(r){throw Ie?.disconnect(),r}}a(vT,"startService");async function rP(){try{let e=await UT(),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 Ie?.disconnect(),e}}a(rP,"getUniqueServicesList");async function _8(e=[]){try{let t=!1,r=await rP();for(let n=0,s=Object.values(r).length;n<s;n++){let o=Object.values(r)[n].name;e.includes(o)||(o===ve.PROCESS_DESCRIPTORS.HDB?t=!0:await jM(o))}t&&await sP(ve.PROCESS_DESCRIPTORS.HDB)}catch(t){throw Ie?.disconnect(),t}}a(_8,"restartAllServices");async function nP(e){if(sr?.find(r=>r.name===e))return!0;let t=await e8.getHDBProcessInfo();return t.core.length&&t.core[0]?.parent==="PM2"}a(nP,"isServiceRegistered");async function sP(e){let t=ef.get(ve.CONFIG_PARAMS.THREADS_COUNT)??ef.get(ve.CONFIG_PARAMS.THREADS),r=await tP(e),n=X5.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await PT(e),await vT(e)):e===ve.PROCESS_DESCRIPTORS.HDB?await eP():await XM(e)}a(sP,"reloadStopStart");var iP;async function oP(e=!1){for(let t in ve.CLUSTERING_PROCESSES){let r=ve.CLUSTERING_PROCESSES[t];await vT(r,e)}}a(oP,"startClusteringProcesses");async function aP(){iP=zM(ve.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,{name:ve.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE});try{await Zd.deleteLocalStream("__HARPERDB_WORK_QUEUE__")}catch{}await Zd.updateLocalStreams();let e=await j5.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===ve.PRE_4_0_0_VERSION){Si.info("Starting clustering upgrade 4.0.0 process"),zM(ve.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}a(aP,"startClusteringThreads");async function d8(){for(let e in ve.CLUSTERING_PROCESSES)if(e!==ve.CLUSTERING_PROCESSES.CLUSTERING_INGEST_PROC_DESCRIPTOR)if(e===ve.CLUSTERING_PROCESSES.CLUSTERING_REPLY_SERVICE_DESCRIPTOR)await iP.terminate();else{let t=ve.CLUSTERING_PROCESSES[e];await PT(t)}}a(d8,"stopClustering");async function f8(){for(let e in ve.CLUSTERING_PROCESSES){let t=ve.CLUSTERING_PROCESSES[e];if(await nP(t)===!1)return!1}return!0}a(f8,"isClusteringRunning");async function E8(){await Ds.generateNatsConfig(!0),await Zd.reloadNATSHub(),await Zd.reloadNATSLeaf(),await Ds.removeNatsConfig(ve.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await Ds.removeNatsConfig(ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}a(E8,"reloadClustering")});var mP={};qe(mP,{compactOnStart:()=>h8,copyDb:()=>hP});async function h8(){Ml.notify("Running compact on start"),console.log("Running compact on start");let e=(0,BT.get)(gi.CONFIG_PARAMS.ROOTPATH),t=new Map,r=Tr();try{for(let n in r){if(n==="system")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,tf.join)(e,"backup",n+".mdb"),o=(0,tf.join)(e,gi.DATABASES_DIR_NAME,n+"-copy.mdb"),c=await uP(n);console.log("Database",n,"before compact has a total record count of",c),t.set(n,{db_path:s,copy_dest:o,backup_dest:i,record_count:c}),await hP(n,o),console.log("Backing up",n,"to",i),await(0,uo.move)(s,i,{overwrite:!0})}Ll();for(let[n,{db_path:s,copy_dest:i}]of t)console.log("Moving copy compacted",n,"to",s),await(0,uo.move)(i,s,{overwrite:!0}),await(0,uo.remove)((0,tf.join)(e,gi.DATABASES_DIR_NAME,`${n}-copy.mdb-lock`));Ll()}catch(n){Ml.error("Error compacting database, rolling back operation",n),console.error("Error compacting database, rolling back operation",n),(0,HT.updateConfigValue)(gi.CONFIG_PARAMS.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,uo.move)(o,i,{overwrite:!0})}catch(c){console.error(c)}}throw Ll(),n}for(let[n,{backup_dest:s,record_count:i}]of t){let o=!0,c=await uP(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}.
9
+ This can occur during early stages of install where the config file has not yet been created`);return}else throw Nt.error(i),new Error(`Error reading HarperDB config file at ${r}`)}XY(n,r),Zm(n);let s=n.toJSON();if(VY.config=s,It=Ko(s),It.logging_rotation_rotate)for(let i in bN)It[i]&&Nt.error(`Config ${bN[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);Nt.trace(YY)}}a(jm,"initConfig");function XY(e,t){let r=e.getIn(["rootPath"]),n=!1;e.hasIn(["storage","path"])||(e.setIn(["storage","path"],Dn.join(r,"database")),n=!0),e.hasIn(["clustering","leafServer","streams","path"])||(e.setIn(["clustering","leafServer","streams","path"],Dn.join(r,"clustering","leaf")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],Dn.join(r,"log")),n=!0),e.hasIn(["clustering","tls","verify"])||(e.setIn(["clustering","tls","verify"],!0),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&&(Nt.trace("Updating config file with missing config params"),mr.writeFileSync(t,String(e)))}a(XY,"checkForUpdatedConfig");function Zm(e,t=!1){let r=e.toJSON();r.componentsRoot=r.componentsRoot??r?.customFunctions?.root,r?.http?.threads&&(r.threads=r?.http?.threads);let n=HY(r,t);if(n.error)throw Y_.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(["clustering","leafServer","streams","path"],n.value.clustering.leafServer.streams?.path),e.setIn(["operationsApi","network","domainSocket"],n.value?.operationsApi?.network?.domainSocket)}a(Zm,"validateConfig");function jY(e,t){It===void 0&&(It={});let r=Ln[e.toLowerCase()];if(r===void 0){Nt.trace(`Unable to update config object because config param '${e}' does not exist`);return}It[r.toLowerCase()]=t}a(jY,"updateConfigObject");function CN(e,t,r=void 0,n=!1,s=!1,i=!1){It===void 0&&jm();let o=wN(Ln.hdb_root),c=Dn.join(o,kr.HDB_CONFIG_FILE),l=ai(c),_;if(r===void 0&&e.toLowerCase()===qr.DATABASES)_=t;else if(r===void 0){let E;if(i)E=e;else if(E=Ln[e.toLowerCase()],E===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let f=E.split("_"),h=Xm(E,t);l.setIn([...f],h)}else for(let E in r){let f=Ln[E.toLowerCase()];if(f===qr.HTTP_SECUREPORT&&r[E]===It[qr.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),f===qr.OPERATIONSAPI_NETWORK_SECUREPORT&&r[E]===It[qr.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&l.setIn(["operationsApi","network","port"],null),f===qr.DATABASES){_=r[E];continue}if(f?.startsWith("threads_")){let h=l.getIn(["threads"]);h>=0&&(l.deleteIn(["threads"]),l.setIn(["threads","count"],h))}if(!f&&(E.endsWith("_package")||E.endsWith("_port"))&&(f=E),f!==void 0){let h=f.split("_"),p=kr.LEGACY_CONFIG_PARAMS[E.toUpperCase()];p&&p.startsWith("customFunctions")&&l.hasIn(p.split("_"))&&(f=p,h=p.split("_"));let S=Xm(f,r[E]);f==="rootPath"&&S?.endsWith("/")&&(S=S.slice(0,-1));try{h.length>1&&typeof l.getIn(h.slice(0,-1))=="boolean"&&l.deleteIn(h.slice(0,-1)),l.setIn([...h],S)}catch(T){Nt.error(T)}}}_&&IN(l,_),Zm(l);let u=l.getIn(["rootPath"]),d=Dn.join(u,kr.HDB_CONFIG_FILE);n===!0&&ZY(c,u),mr.writeFileSync(d,String(l)),s&&(It=Ko(l.toJSON())),Nt.trace(`Config parameter: ${e} updated with value: ${t}`)}a(CN,"updateConfigValue");function ZY(e,t){try{let r=Dn.join(t,"backup",`${kr.HDB_CONFIG_FILE}.bak`);mr.copySync(e,r),Nt.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){Nt.error(KY),Nt.error(r)}}a(ZY,"backupConfigFile");var eK=["databases"];function Ko(e){return e.http&&Object.assign(e.http,e?.customFunctions?.network),e?.operationsApi?.network&&(e.operationsApi.network=Object.assign({},e.http,e.operationsApi.network)),e?.operationsApi&&(e.operationsApi.tls=Object.assign({},e.tls,e.operationsApi.tls)),W_=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])&&!eK.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;!qr[l.toUpperCase()]&&Ln[l]&&(s[Ln[l].toLowerCase()]=o[c]),s[l]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(Ko,"flattenConfig");function Xm(e,t){if(e===qr.CLUSTERING_NODENAME||e===qr.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(GY(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||Ht.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 Ht.autoCast(t)}a(Xm,"castConfigValue");function tK(){let e=Ht.getPropsFilePath(),t=zi(e);return ai(t).toJSON()}a(tK,"getConfiguration");async function rK(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return CN(void 0,void 0,s,!0),QY}catch(i){throw typeof i=="string"||i instanceof String?qY(i,i,kY.BAD_REQUEST,void 0,void 0,!0):i}}a(rK,"setConfiguration");function ep(){let e=Ht.getPropsFilePath();try{mr.accessSync(e,mr.constants.F_OK|mr.constants.R_OK)}catch(n){if(!Ht.noBootFile())throw Nt.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=zi(e);return ai(t).toJSON()}a(ep,"readConfigFile");function ai(e){return xY.parseDocument(mr.readFileSync(e,"utf8"),{simpleKeys:!0})}a(ai,"parseYamlDoc");function nK(){let e=ep(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=Ht.isEmptyOrZeroLength(t)?[]:t;let r=ON(t);if(r)throw Y_.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=Ht.isEmptyOrZeroLength(n)?[]:n;let s=ON(n);if(s)throw Y_.CONFIG_VALIDATION(s.message);if(!Ht.isEmptyOrZeroLength(n)&&!Ht.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!Ht.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw Y_.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(nK,"getClusteringRoutes");function DN(e){let t=yN(e);It={};for(let r in Ln){let n=t.get(r.toUpperCase());if(Ht.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=Ln[r].toLowerCase();s===qr.LOGGING_ROOT?It[s]=Dn.dirname(n):It[s]=n}return It}a(DN,"initOldConfig");function sK(e){let t=ep();return FY.get(t,e.replaceAll("_","."))}a(sK,"getConfigFromFile");async function iK(e,t){let r=ai(zi());r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),await mr.writeFile(zi(),String(r))}a(iK,"addConfig");function oK(e){let t=zi(Ht.getPropsFilePath()),r=ai(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=Dn.join(n,kr.HDB_CONFIG_FILE);mr.writeFileSync(s,String(r))}a(oK,"deleteConfigFromFile");function aK(){return W_||(jm(),W_)}a(aK,"getConfigObj")});var PN=g((Fce,MN)=>{"use strict";var Q_=P(),z_=class{static{a(this,"BaseLicense")}constructor(t=0,r=Q_.RAM_ALLOCATION_ENUM.DEFAULT,n=Q_.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},tp=class extends z_{static{a(this,"ExtendedLicense")}constructor(t=0,r=Q_.RAM_ALLOCATION_ENUM.DEFAULT,n=Q_.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};MN.exports={BaseLicense:z_,ExtendedLicense:tp}});var Ji=g((kce,GN)=>{"use strict";var Qo=require("fs-extra"),vN=q_(),BN=require("crypto"),cK=require("moment"),lK=require("uuid").v4,tr=K(),np=require("path"),uK=J(),ci=P(),{totalmem:UN}=require("os"),_K=PN().ExtendedLicense,Wo="invalid license key format",dK="061183",fK="mofi25",EK="aes-256-cbc",hK=16,mK=32,HN=ne();HN.initSync();var rp;GN.exports={validateLicense:xN,generateFingerPrint:SK,licenseSearch:op,getLicense:RK,checkMemoryLimit:AK};function sp(){return np.join(HN.getHdbBasePath(),ci.LICENSE_KEY_DIR_NAME,ci.LICENSE_FILE_NAME)}a(sp,"getLicenseDirPath");function pK(){let e=sp();return np.join(e,ci.LICENSE_FILE_NAME)}a(pK,"getLicenseFilePath");function ip(){let e=sp();return np.join(e,ci.REG_KEY_FILE_NAME)}a(ip,"getFingerPrintFilePath");async function SK(){let e=ip();try{return await Qo.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await TK();throw tr.error(`Error writing fingerprint file to ${e}`),tr.error(t),new Error("There was an error generating the fingerprint")}}a(SK,"generateFingerPrint");async function TK(){let e=lK(),t=vN.hash(e),r=ip();try{await Qo.mkdirp(sp()),await Qo.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw tr.error(`Error writing fingerprint file to ${r}`),tr.error(n),new Error("There was an error generating the fingerprint")}return t}a(TK,"writeFingerprint");function xN(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:ci.RAM_ALLOCATION_ENUM.DEFAULT,version:ci.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return tr.error("empty license key passed to validate."),r;let n=ip(),s=!1;try{s=Qo.statSync(n)}catch(i){tr.error(i)}if(s){let i;try{i=Qo.readFileSync(n,"utf8")}catch{tr.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(fK),c=o[1];c=Buffer.concat([Buffer.from(c)],hK);let l=Buffer.concat([Buffer.from(i)],mK),_=BN.createDecipheriv(EK,l,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let u=null;try{u=_.update(o[0],"hex","utf8"),u.trim(),u+=_.final("utf8")}catch{let f=gK(o[0],i);if(f)u=f;else throw r.valid_license=!1,r.valid_machine=!1,console.error(Wo),tr.error(Wo),new Error(Wo)}let d;if(isNaN(u))try{d=JSON.parse(u),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(Wo),tr.error(Wo),new Error(Wo)}else r.exp_date=u;r.exp_date<cK().valueOf()&&(r.valid_date=!1),vN.validate(o[1],`${dK}${i}${t}`)||(r.valid_license=!1)}else r.valid_license=!1,r.valid_machine=!1;return r.valid_license&&r.valid_machine&&r.valid_date||tr.error("Invalid licence"),r}a(xN,"validateLicense");function gK(e,t){try{let r=BN.createDecipher("aes192",t),n=r.update(e,"hex","utf8");return n.trim(),n+=r.final("utf8"),n}catch{tr.warn("Check old license failed")}}a(gK,"checkOldLicense");function op(){let e=new _K,t=[];try{t=Qo.readFileSync(pK(),"utf-8").split(ci.NEW_LINE)}catch(r){r.code==="ENOENT"?tr.info("no license file found"):tr.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if(uK.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=xN(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){tr.error("There was an error parsing the license string."),tr.error(s),e.ram_allocation=ci.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return rp=e,e}a(op,"licenseSearch");async function RK(){return rp||await op(),rp}a(RK,"getLicense");function AK(){let e=op().ram_allocation,t=process.constrainedMemory?.()||UN();if(t=Math.round(Math.min(t,UN())/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(AK,"checkMemoryLimit")});var _n=g((Wce,tI)=>{"use strict";var VN="username is required",$N="nothing to update, must supply active, role or password to update",YN="password cannot be an empty string",KN="If role is specified, it cannot be empty.",WN="active must be true or false";tI.exports={addUser:LK,alterUser:MK,dropUser:UK,getSuperUser:xK,userInfo:vK,listUsers:X_,listUsersExternal:BK,setUsersToGlobal:Jo,findAndValidateUser:ZN,getClusterUser:GK,USERNAME_REQUIRED:VN,ALTERUSER_NOTHING_TO_UPDATE:$N,EMPTY_PASSWORD:YN,EMPTY_ROLE:KN,ACTIVE_BOOLEAN:WN};var QN=un(),OK=Ki(),lp=q_(),zN=dN(),JN=Fr(),up=Os(),Vr=J(),XN=require("validate.js"),Oe=K(),{promisify:bK}=require("util"),_p=As(),FN=P(),qN=ct(),yK=pr(),$ce=ne(),Yce=Ji(),NK=Fi(),{table:Kce}=(Ae(),ie(ke)),{handleHDBError:es,hdb_errors:IK}=se(),{HTTP_STATUS_CODES:ts,AUTHENTICATION_ERROR_MSGS:ap,HDB_ERROR_MSGS:zo}=IK,{UserEventMsg:dp}=Mn(),cp=require("lodash"),{server:fp}=(fr(),ie(Bi)),wK=K();fp.getUser=(e,t)=>ZN(e,t,t!=null);var jN={username:!0,active:!0,role:!0,password:!0},kN=new Map,J_=JN.searchByValue,CK=JN.searchByHash,DK=bK(OK.delete);async function LK(e){let t=XN.cleanAttributes(e,jN),r=zN.addUserValidation(t);if(r)throw es(new Error,r.message,ts.BAD_REQUEST,void 0,void 0,!0);let n={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["id","permission","role"]},s;try{s=await J_(n),s=s&&Array.from(s)}catch(l){throw Oe.error("There was an error searching for a role in add user"),Oe.error(l),l}if(!s||s.length<1)throw es(new Error,zo.ROLE_NAME_NOT_FOUND(t.role),ts.NOT_FOUND,void 0,void 0,!0);if(s.length>1)throw es(new Error,zo.DUP_ROLES_FOUND(t.role),ts.CONFLICT,void 0,void 0,!0);s[0].permission.cluster_user===!0&&(t.hash=_p.encrypt(t.password)),t.password=lp.hash(t.password),t.role=s[0].id;let i={operation:"insert",schema:"system",table:"hdb_user",records:[t]},o;try{o=await QN.insert(i)}catch(l){throw Oe.error("There was an error searching for a user."),Oe.error(l),l}Oe.debug(o);try{await Jo()}catch(l){throw Oe.error("Got an error setting users to global"),Oe.error(l),l}if(o.skipped_hashes.length===1)throw es(new Error,zo.USER_ALREADY_EXISTS(t.username),ts.CONFLICT,void 0,void 0,!0);let c=Object.assign({},t);return c.role=s[0],up.signalUserChange(new dp(process.pid)),`${c.username} successfully added`}a(LK,"addUser");async function MK(e){let t=XN.cleanAttributes(e,jN);if(Vr.isEmptyOrZeroLength(t.username))throw new Error(VN);if(Vr.isEmptyOrZeroLength(t.password)&&Vr.isEmptyOrZeroLength(t.role)&&Vr.isEmptyOrZeroLength(t.active))throw new Error($N);if(!Vr.isEmpty(t.password)&&Vr.isEmptyOrZeroLength(t.password.trim()))throw new Error(YN);if(!Vr.isEmpty(t.active)&&!Vr.isBoolean(t.active))throw new Error(WN);let r=PK(t.username);if(!Vr.isEmpty(t.password)&&!Vr.isEmptyOrZeroLength(t.password.trim())&&(r&&(t.hash=_p.encrypt(t.password)),t.password=lp.hash(t.password)),t.role==="")throw new Error(KN);if(t.role){let i={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]},o;try{o=Array.from(await J_(i)||[])}catch(c){throw Oe.error("Got an error searching for a role."),Oe.error(c),c}if(!o||o.length===0){let c=zo.ALTER_USER_ROLE_NOT_FOUND(t.role);throw Oe.error(c),es(new Error,c,ts.NOT_FOUND,void 0,void 0,!0)}if(o.length>1){let c=zo.ALTER_USER_DUP_ROLES(t.role);throw Oe.error(c),es(new Error,c,ts.CONFLICT,void 0,void 0,!0)}t.role=o[0].id}let n={operation:"update",schema:"system",table:"hdb_user",records:[t]},s;try{s=await QN.update(n)}catch(i){throw Oe.error("Error during update."),Oe.error(i),i}try{await Jo()}catch(i){throw Oe.error("Got an error setting users to global"),Oe.error(i),i}return up.signalUserChange(new dp(process.pid)),s}a(MK,"alterUser");function PK(e){let t=!1,r=global.hdb_users.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(PK,"isClusterUser");async function UK(e){try{let t=zN.dropUserValidation(e);if(t)throw new Error(t);let r={table:"hdb_user",schema:"system",hash_values:[e.username]};if(Vr.isEmpty(global.hdb_users.get(e.username)))throw es(new Error,zo.USER_NOT_EXIST(e.username),ts.NOT_FOUND,void 0,void 0,!0);let n;try{n=await DK(r)}catch(s){throw Oe.error("Got an error deleting a user."),Oe.error(s),s}Oe.debug(n);try{await Jo()}catch(s){throw Oe.error("Got an error setting users to global."),Oe.error(s),s}return up.signalUserChange(new dp(process.pid)),`${e.username} successfully deleted`}catch(t){throw t}}a(UK,"dropUser");async function vK(e){let t={};try{if(!e||!e.hdb_user)return"There was no user info in the body";t=cp.cloneDeep(e.hdb_user);let r={schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]},n;try{n=await CK(r)}catch(s){throw Oe.error("Got an error searching for a role."),Oe.error(s),s}t.role=n[0],delete t.password,delete t.refresh_token,delete t.hash}catch(r){throw Oe.error(r),r}return t}a(vK,"userInfo");async function BK(){let e;try{e=await X_()}catch(t){throw Oe.error("Got an error listing users."),Oe.error(t),t}try{e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token})}catch{throw new Error("there was an error massaging the user data")}return[...e.values()]}a(BK,"listUsersExternal");async function X_(){try{let e={schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]},t;try{t=await J_(e)}catch(o){throw Oe.error("Got an error searching for roles."),Oe.error(o),o}let r={};for(let o of t)r[o.id]=cp.cloneDeep(o);if(Object.keys(r).length===0)return null;let n={schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]},s;try{s=await J_(n)}catch(o){throw Oe.error("Got an error searching for users."),Oe.error(o),o}let i=new Map;for(let o of s)o=cp.cloneDeep(o),o.role=r[o.role],HK(o.role),i.set(o.username,o);return i}catch(e){throw Oe.error("got an error listing users"),Oe.error(e),Vr.errorizeMessage(e)}return null}a(X_,"listUsers");function HK(e){try{if(!e){Oe.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(NK)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}catch(t){Oe.error("Got an error trying to set system permissions."),Oe.error(t)}}a(HK,"appendSystemTablesToRole");async function Jo(){try{let e=await X_();global.hdb_users=e}catch(e){throw Oe.error(e),e}}a(Jo,"setUsersToGlobal");async function ZN(e,t,r=!0){global.hdb_users||await Jo();let n=global.hdb_users.get(e);if(!n){if(!r)return{username:e};throw es(new Error,ap.GENERIC_AUTH_FAIL,ts.UNAUTHORIZED,void 0,void 0,!0)}if(n&&!n.active)throw es(new Error,ap.USER_INACTIVE,ts.UNAUTHORIZED,void 0,void 0,!0);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(kN.get(t)===n.password)return s;if(lp.validate(n.password,t))kN.set(t,n.password);else throw es(new Error,ap.GENERIC_AUTH_FAIL,ts.UNAUTHORIZED,void 0,void 0,!0)}return s}a(ZN,"findAndValidateUser");async function xK(){global.hdb_users||await Jo();for(let[,e]of global.hdb_users)if(e.role.role==="super_user")return e}a(xK,"getSuperUser");async function GK(){let e=await X_(),t=yK.getConfigFromFile(FN.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!Vr.isEmpty(r)&&r?.role?.role===FN.ROLE_TYPES_ENUM.CLUSTER_USER)return r.decrypt_hash=_p.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+qN.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+qN.SERVER_SUFFIX.ADMIN,r}a(GK,"getClusterUser");var eI=[];fp.invalidateUser=function(e){for(let t of eI)try{t(e)}catch(r){wK.error("Error invalidating user",r)}};fp.onInvalidatedUser=function(e){eI.push(e)}});var Kc=g((Xce,iI)=>{"use strict";var Xi=K(),$r=P(),FK=Py(),zce=si(),Jce=ni(),qK=_n(),{validateEvent:rI}=Mn(),Yc=Cn(),kK=require("process"),{resetDatabases:VK}=(Ae(),ie(ke)),$K={[$r.ITC_EVENT_TYPES.SCHEMA]:YK,[$r.ITC_EVENT_TYPES.USER]:sI};async function YK(e){let t=rI(e);if(t){Xi.error(t);return}Xi.trace("ITC schemaHandler received schema event:",e),await FK(e.message),await KK(e.message)}a(YK,"schemaHandler");async function KK(e){try{Yc.resetReadTxn($r.SYSTEM_SCHEMA_NAME,$r.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),Yc.resetReadTxn($r.SYSTEM_SCHEMA_NAME,$r.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),Yc.resetReadTxn($r.SYSTEM_SCHEMA_NAME,$r.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=VK();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){Xi.error(t)}}a(KK,"syncSchemaMetadata");var nI=[];async function sI(e){try{try{Yc.resetReadTxn($r.SYSTEM_SCHEMA_NAME,$r.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),Yc.resetReadTxn($r.SYSTEM_SCHEMA_NAME,$r.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){Xi.warn(r)}let t=rI(e);if(t){Xi.error(t);return}Xi.trace(`ITC userHandler ${$r.HDB_ITC_CLIENT_PREFIX}${kK.pid} received user event:`,e),await qK.setUsersToGlobal();for(let r of nI)r()}catch(t){Xi.error(t)}}a(sI,"userHandler");sI.addListener=function(e){nI.push(e)};iI.exports=$K});var Mn=g((nle,aI)=>{"use strict";var Zce=K(),Ep=J(),WK=P(),{ITC_ERRORS:Wc}=vr(),{parentPort:ele,threadId:QK,isMainThread:zK,workerData:tle}=require("worker_threads"),{onMessageFromWorkers:JK,broadcast:rle,broadcastWithAcknowledgement:XK}=it();aI.exports={sendItcEvent:jK,validateEvent:oI,SchemaEventMsg:ZK,UserEventMsg:eW};var j_;JK(async(e,t)=>{j_=j_||Kc(),oI(e),j_[e.type]&&await j_[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function jK(e){return!zK&&e.message&&(e.message.originator=QK),XK(e)}a(jK,"sendItcEvent");function oI(e){if(typeof e!="object")return Wc.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||Ep.isEmpty(e.type))return Wc.MISSING_TYPE;if(!e.hasOwnProperty("message")||Ep.isEmpty(e.message))return Wc.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||Ep.isEmpty(e.message.originator))return Wc.MISSING_ORIGIN;if(WK.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return Wc.INVALID_EVENT(e.type)}a(oI,"validateEvent");function ZK(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(ZK,"SchemaEventMsg");function eW(e){this.originator=e}a(eW,"UserEventMsg")});var Os=g((ole,_I)=>{"use strict";var cI=P(),ile=J(),Z_=K(),lI=Dy(),Xo,{sendItcEvent:uI}=Mn();function tW(e){try{Z_.trace("signalSchemaChange called with message:",e),Xo=Xo||Kc();let t=new lI(cI.ITC_EVENT_TYPES.SCHEMA,e);return Xo.schema(t),uI(t)}catch(t){Z_.error(t)}}a(tW,"signalSchemaChange");function rW(e){try{Z_.trace("signalUserChange called with message:",e),Xo=Xo||Kc();let t=new lI(cI.ITC_EVENT_TYPES.USER,e);return Xo.user(t),uI(t)}catch(t){Z_.error(t)}}a(rW,"signalUserChange");_I.exports={signalSchemaChange:tW,signalUserChange:rW}});var ed=g((cle,fI)=>{"use strict";var dI=J(),nW=P(),sW=K(),iW=M_(),oW=L_(),aW=Os(),{SchemaEventMsg:cW}=Mn(),lW="already exists in";fI.exports=uW;async function uW(e,t,r){if(dI.isEmptyOrZeroLength(r))return r;let n=[];dI.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 _W(e,t.schema,t.name,i)})),s}a(uW,"lmdbCheckForNewAttributes");async function _W(e,t,r,n){let s=new oW(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await dW(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(lW))sW.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(_W,"createNewAttribute");async function dW(e){let t;return t=await iW(e),aW.signalSchemaChange(new cW(process.pid,nW.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(dW,"createAttribute")});var jo=g((ule,EI)=>{"use strict";var hp=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}};EI.exports=hp});var mI=g((dle,hI)=>{"use strict";var fW=jo(),EW=P().OPERATIONS_ENUM,mp=class extends fW{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(EW.INSERT,r,n,s,i),this.records=t}};hI.exports=mp});var SI=g((Ele,pI)=>{"use strict";var hW=jo(),mW=P().OPERATIONS_ENUM,pp=class extends hW{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(mW.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};pI.exports=pp});var gI=g((mle,TI)=>{"use strict";var pW=jo(),SW=P().OPERATIONS_ENUM,Sp=class extends pW{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(SW.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};TI.exports=Sp});var AI=g((Sle,RI)=>{"use strict";var TW=jo(),gW=P().OPERATIONS_ENUM,Tp=class extends TW{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(gW.DELETE,n,s,t,i),this.original_records=r}};RI.exports=Tp});var Qc=g((Rle,NI)=>{"use strict";var gle=require("path"),OI=We(),RW=mI(),AW=SI(),OW=gI(),bW=AI(),Zo=dt(),bI=J(),{CONFIG_PARAMS:yW}=P(),yI=ne();yI.initSync();var td=P().OPERATIONS_ENUM,{getTransactionAuditStorePath:NW}=ze();NI.exports=IW;async function IW(e,t){if(yI.get(yW.LOGGING_AUDITLOG)===!1)return;let r=NW(e.schema,e.table),n=await OI.openEnvironment(r,e.table,!0),s=wW(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){OI.initializeDBIs(n,Zo.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Zo.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[Zo.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[Zo.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),bI.isEmpty(s.user_name)||n.dbis[Zo.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[Zo.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(IW,"writeTransaction");function wW(e,t){let r=bI.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===td.INSERT)return new RW(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===td.UPDATE)return new AW(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===td.UPSERT)return new OW(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===td.DELETE)return new bW(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(wW,"createTransactionObject")});var gp=g((ble,II)=>{"use strict";var CW=Fc(),Ole=Oc(),zc=P(),DW=bc(),LW=Vo().insertRecords,MW=We(),PW=K(),UW=ed(),{getSchemaPath:vW}=ze(),BW=Qc();II.exports=HW;async function HW(e){try{let{schema_table:t,attributes:r}=CW(e);DW(e,r,t.hash_attribute),e.schema!==zc.SYSTEM_SCHEMA_NAME&&(r.includes(zc.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(zc.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(zc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(zc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await UW(e.hdb_auth_header,t,r),s=vW(e.schema,e.table),i=await MW.openEnvironment(s,e.table),o=await LW(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await BW(e,o)}catch(c){PW.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(HW,"lmdbCreateRecords")});var DI=g((Nle,CI)=>{"use strict";var wI=P(),xW=gp(),GW=Oc(),FW=require("fs-extra"),{getSchemaPath:qW}=ze();CI.exports=kW;async function kW(e){let t=[{name:e.schema,createddate:Date.now()}],r=new GW(wI.SYSTEM_SCHEMA_NAME,wI.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await xW(r),await FW.mkdirp(qW(e.schema))}a(kW,"lmdbCreateSchema")});var MI=g((wle,LI)=>{"use strict";var Rp=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}};LI.exports=Rp});var BI=g((Ple,vI)=>{"use strict";var PI=We(),Ap=Br(),Op=vr().LMDB_ERRORS_ENUM,VW=dt(),UI=K(),Dle=J(),$W=require("lmdb"),YW=MI(),KW=P(),{OVERFLOW_MARKER:Lle,MAX_SEARCH_KEY_LENGTH:Mle}=VW,WW=KW.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function QW(e,t,r,n){if(Ap.validateEnv(e),t===void 0)throw new Error(Op.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(Op.IDS_REQUIRED):new Error(Op.IDS_MUST_BE_ITERABLE);try{let s=PI.listDBIs(e);PI.initializeDBIs(e,t,s);let i=new YW,o,c=[],l=[];for(let E=0,f=r.length;E<f;E++)try{o=r[E];let h=e.dbis[t].get(o);if(!h||n&&h[WW]>n){i.skipped.push(o);continue}let p=e.dbis[t].ifVersion(o,$W.IF_EXISTS,()=>{e.dbis[t].remove(o);for(let S=0;S<s.length;S++){let T=s[S];if(!h.hasOwnProperty(T)||T===t)continue;let A=e.dbis[T],b=h[T];if(b!=null)try{let I=Ap.getIndexedValues(b);if(I)for(let B=0,U=I.length;B<U;B++)A.remove(I[B],o)}catch{UI.warn(`cannot delete from attribute: ${T}, ${b}:${o}`)}}});c.push(p),l.push(o),i.original_records.push(h)}catch(h){UI.warn(h),i.skipped.push(o)}let _=[],u=await Promise.all(c);for(let E=0,f=u.length;E<f;E++)u[E]===!0?i.deleted.push(l[E]):(i.skipped.push(l[E]),_.push(E));let d=0;for(let E=0;E<_.length;E++){let f=_[E];i.original_records.splice(f-d,1),d++}return i.txn_time=Ap.getNextMonotonicTime(),i}catch(s){throw s}}a(QW,"deleteRecords");vI.exports={deleteRecords:QW}});var Jc=g((vle,xI)=>{"use strict";var ea=J(),zW=BI(),JW=We(),{getSchemaPath:XW}=ze(),jW=Qc(),ZW=K();xI.exports=eQ;async function eQ(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(ea.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(ea.isEmptyOrZeroLength(e.hash_values)&&!ea.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];ea.isEmpty(l)||e.hash_values.push(l)}}if(ea.isEmptyOrZeroLength(e.hash_values))return HI([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(ea.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=XW(e.schema,e.table),i=await JW.openEnvironment(s,e.table),o=await zW.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await jW(e,o)}catch(c){ZW.error(`unable to write transaction due to ${c.message}`)}return HI(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(eQ,"lmdbDeleteRecords");function HI(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(HI,"createDeleteResponse")});var yp=g((xle,GI)=>{"use strict";var tQ=P(),Hle=Br();function bp(e,t){let r=Object.create(null);if(t.length===1&&tQ.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(bp,"parseRow");function rQ(e,t,r,n){let s=bp(r,e);n.push(s)}a(rQ,"searchAll");function nQ(e,t,r,n){let s=bp(r,e);n[t]=s}a(nQ,"searchAllToMap");function sQ(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(sQ,"iterateDBI");function ji(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(ji,"pushResults");function iQ(e,t,r,n,s,i){t.toString().endsWith(e)&&ji(t,r,n,s,i)}a(iQ,"endsWith");function oQ(e,t,r,n,s,i){t.toString().includes(e)&&ji(t,r,n,s,i)}a(oQ,"contains");function aQ(e,t,r,n,s,i){t>e&&ji(t,r,n,s,i)}a(aQ,"greaterThanCompare");function cQ(e,t,r,n,s,i){t>=e&&ji(t,r,n,s,i)}a(cQ,"greaterThanEqualCompare");function lQ(e,t,r,n,s,i){t<e&&ji(t,r,n,s,i)}a(lQ,"lessThanCompare");function uQ(e,t,r,n,s,i){t<=e&&ji(t,r,n,s,i)}a(uQ,"lessThanEqualCompare");GI.exports={parseRow:bp,searchAll:rQ,searchAllToMap:nQ,iterateDBI:sQ,endsWith:iQ,contains:oQ,greaterThanCompare:aQ,greaterThanEqualCompare:cQ,lessThanCompare:lQ,lessThanEqualCompare:uQ,pushResults:ji}});var ta=g((Vle,KI)=>{"use strict";var li=We(),Fle=K(),Yr=Br(),rd=dt(),Et=vr().LMDB_ERRORS_ENUM,qle=J(),_Q=P(),nd=yp(),{parseRow:dQ}=nd,kle=require("lmdb"),{OVERFLOW_MARKER:FI,MAX_SEARCH_KEY_LENGTH:fQ}=rd;function qI(e,t,r,n=!1,s=void 0,i=void 0){return Zi(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(qI,"iterateFullIndex");function Xc(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,_=!1){return Zi(e,t,r,(u,d,E,f)=>{let A={transaction:u,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!l:!_,exclusiveStart:i===!0?_:l};return f===r?(A.values=!1,d.getRange(A).map(b=>({value:b}))):d.getRange(A)})}a(Xc,"iterateRangeBetween");function Zi(e,t,r,n){let s=e.database||e,i=li.openDBI(s,r);i[rd.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&li.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(Zi,"setupTransaction");function kI(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(FI)){if(!s)if(r)s=li.openDBI(e,r);else{let l=li.listDBIs(e);for(let _=0,u=l.length;_<u&&(s=li.openDBI(e,l[_]),!s[rd.DBI_DEFINITION_NAME].is_hash_attribute);_++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(kI,"getOverflowCheck");function EQ(e,t,r,n=!1,s=void 0,i=void 0){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);return Zi(e,t,t,(o,c,l)=>(sd(r),r=jc(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(_=>dQ(_.value,r))))}a(EQ,"searchAll");function hQ(e,t,r,n=!1,s=void 0,i=void 0){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);sd(r),r=jc(e.database||e,r);let o=new Map;for(let{key:c,value:l}of qI(e,t,t,n,s,i))o.set(c,nd.parseRow(l,r));return o}a(hQ,"searchAllToMap");function mQ(e,t,r=!1,n=void 0,s=void 0){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=qI(e,void 0,t,r,n,s),c=o.transaction,l=kI(c.database,c,void 0,t);for(let{key:_,value:u}of o){let d=l(_,u);i[d]===void 0&&(i[d]=[]),i[d].push(u)}return i}a(mQ,"iterateDBI");function pQ(e,t){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);return li.statDBI(e,t).entryCount}a(pQ,"countAll");function SQ(e,t,r,n,s=!1,i=void 0,o=void 0){return ui(e,r,n),Zi(e,t,r,(c,l,_,u)=>(n=Yr.convertKeyValueToWrite(n),u===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(SQ,"equals");function TQ(e,t,r){return ui(e,t,r),li.openDBI(e,t).getValuesCount(r)}a(TQ,"count");function gQ(e,t,r,n,s=!1,i=void 0,o=void 0){return ui(e,r,n),Zi(e,null,r,(c,l)=>{n=Yr.convertKeyValueToWrite(n);let _=!0;typeof n=="number"&&(_=!1);let u;if(s===!0){let d;for(let E of l.getKeys({transaction:c,start:n}))if(!E.startsWith(n)){d=E;break}return d!==void 0&&(Number.isInteger(o)?o++:i++),u=l.getRange({transaction:c,start:d,end:void 0,reverse:s,limit:i,offset:o}).map(E=>{let{key:f}=E;if(f!==d){if(f.toString().startsWith(n))return E;if(_===!0)return u.DONE}}),u.filter(E=>E)}else return u=l.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(d=>{if(d.key.toString().startsWith(n))return d;if(_===!0)return u.DONE}),_?u:u.filter(d=>d)})}a(gQ,"startsWith");function RQ(e,t,r,n,s=!1,i=void 0,o=void 0){return VI(e,t,r,n,s,i,o,!0)}a(RQ,"endsWith");function VI(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return ui(e,r,n),Zi(e,null,r,(l,_,u,d)=>{let E=kI(u,l,d,r);return o=Number.isInteger(o)?o:0,_.getKeys({transaction:l,end:s?!1:void 0,reverse:s}).flatMap(f=>{let h=f.toString();return h.endsWith(FI)?_.getValues(f,{transaction:l}).map(p=>{let S=E(f,p);if(c?S.endsWith(n):S.includes(n))return{key:S,value:p}}).filter(p=>p):(c?h.endsWith(n):h.includes(n))?_[rd.DBI_DEFINITION_NAME].is_hash_attribute?{key:f,value:f}:_.getValues(f,{transaction:l}).map(p=>({key:f,value:p})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a(VI,"contains");function AQ(e,t,r,n,s=!1,i=void 0,o=void 0){ui(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),Xc(e,t,r,n,l,s,i,o,!0,!1)}a(AQ,"greaterThan");function OQ(e,t,r,n,s=!1,i=void 0,o=void 0){ui(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),Xc(e,t,r,n,l,s,i,o,!1,!1)}a(OQ,"greaterThanEqual");function bQ(e,t,r,n,s=!1,i=void 0,o=void 0){ui(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),Xc(e,t,r,l,n,s,i,o,!1,!0)}a(bQ,"lessThan");function yQ(e,t,r,n,s=!1,i=void 0,o=void 0){ui(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),Xc(e,t,r,l,n,s,i,o,!1,!1)}a(yQ,"lessThanEqual");function NQ(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(Yr.validateEnv(e),r===void 0)throw new Error(Et.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(Et.START_VALUE_REQUIRED);if(s===void 0)throw new Error(Et.END_VALUE_REQUIRED);if(n=Yr.convertKeyValueToWrite(n),s=Yr.convertKeyValueToWrite(s),n>s)throw new Error(Et.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return Xc(e,t,r,n,s,i,o,c)}a(NQ,"between");function IQ(e,t,r,n){Yr.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);if(sd(r),r=jc(s,r),n===void 0)throw new Error(Et.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=nd.parseRow(c,r)),o}a(IQ,"searchByHash");function wQ(e,t,r){Yr.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Et.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(wQ,"checkHashExists");function CQ(e,t,r,n,s=[]){return YI(e,t,r,n,s),$I(e,t,r,n,s).map(i=>i[1])}a(CQ,"batchSearchByHash");function DQ(e,t,r,n,s=[]){YI(e,t,r,n,s);let i=new Map;for(let[o,c]of $I(e,t,r,n,s))i.set(o,c);return i}a(DQ,"batchSearchByHashToMap");function $I(e,t,r,n,s=[]){return Zi(e,t,t,(i,o,c)=>{r=jc(c,r);let l=r.length<3;return n.map(_=>{let u=c.dbis[t].get(_,{transaction:i,lazy:l});if(u)return[_,nd.parseRow(u,r)];s.push(_)}).filter(_=>_)})}a($I,"batchHashSearch");function YI(e,t,r,n,s){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);if(sd(r),n==null)throw new Error(Et.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(Et.IDS_MUST_BE_ITERABLE)}a(YI,"initializeBatchSearchByHash");function sd(e){if(!Array.isArray(e))throw e===void 0?new Error(Et.FETCH_ATTRIBUTES_REQUIRED):new Error(Et.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(sd,"validateFetchAttributes");function ui(e,t,r){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Et.SEARCH_VALUE_REQUIRED);if(r?.length>fQ)throw new Error(Et.SEARCH_VALUE_TOO_LARGE)}a(ui,"validateComparisonFunctions");function jc(e,t){return t.length===1&&_Q.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=li.listDBIs(e)),t}a(jc,"setGetWholeRowAttributes");KI.exports={searchAll:EQ,searchAllToMap:hQ,count:TQ,countAll:pQ,equals:SQ,startsWith:gQ,endsWith:RQ,contains:VI,searchByHash:IQ,setGetWholeRowAttributes:jc,batchSearchByHash:CQ,batchSearchByHashToMap:DQ,checkHashExists:wQ,iterateDBI:mQ,greaterThan:AQ,greaterThanEqual:OQ,lessThan:bQ,lessThanEqual:yQ,between:NQ}});var ra=g((Yle,XI)=>{var WI=require("lodash"),QI=at(),he=require("joi"),LQ=J(),{hdb_schema_table:Zc,checkValidTable:zI,hdb_table:JI,hdb_database:id}=Xn(),{handleHDBError:MQ,hdb_errors:PQ}=se(),{getDatabases:UQ}=(Ae(),ie(ke)),{HTTP_STATUS_CODES:vQ}=PQ,BQ=he.object({database:id,schema:id,table:JI,search_attribute:Zc,search_value:he.any().required(),get_attributes:he.array().min(1).items(he.alternatives(Zc,he.object())).optional(),desc:he.bool(),limit:he.number().integer().min(1),offset:he.number().integer().min(0)}),HQ=he.object({database:id,schema:id,table:JI,operator:he.string().valid("and","or").default("and").lowercase(),offset:he.number().integer().min(0),limit:he.number().integer().min(1),get_attributes:he.array().min(1).items(he.alternatives(Zc,he.object())).optional(),sort:he.object({attribute:he.alternatives(Zc,he.array().min(1)),descending:he.bool().optional()}).optional(),conditions:he.array().min(1).items(he.alternatives(he.object({operator:he.string().valid("and","or").default("and").lowercase(),conditions:he.array()}),he.object({search_attribute:he.alternatives(Zc,he.array().min(1)),search_type:he.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:he.when("search_type",{switch:[{is:"equals",then:he.any()},{is:"between",then:he.array().items(he.alternatives([he.string(),he.number()])).length(2)}],otherwise:he.alternatives(he.string(),he.number())}).required()}))).required()});XI.exports=function(e,t){let r=null;switch(t){case"value":r=QI.validateBySchema(e,BQ);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(zI("database",e.schema)),i(zI("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=QI.validateBySchema(e,HQ);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=LQ.checkGlobalSchemaTable(e.schema,e.table);if(s)return MQ(new Error,s,vQ.NOT_FOUND);let o=UQ()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let l=a(u=>{for(let d=0,E=u.conditions.length;d<E;d++){let f=u.conditions[d];f.conditions?l(f):c.push(f.search_attribute)}},"addConditions");t==="conditions"&&l(e);let _=WI.filter(c,u=>u!=="*"&&!u.startsWith?.("$")&&u.attribute!=="*"&&!Array.isArray(u)&&!u.name&&!WI.some(o,d=>d===u||d.attribute===u||d.attribute===u.attribute));if(_&&_.length>0){let u=_.join(", ");return u=u.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${u}'`)}}return r}});var Np=g((Wle,jI)=>{"use strict";var xQ=We(),GQ=ra(),{getSchemaPath:FQ}=ze();jI.exports=qQ;function qQ(e){let t=GQ(e,"hashes");if(t)throw t;let r=FQ(e.schema,e.table);return xQ.openEnvironment(r,e.table)}a(qQ,"initialize")});var Ip=g((zle,ZI)=>{"use strict";var kQ=ta(),VQ=Np();ZI.exports=$Q;async function $Q(e){let t=await VQ(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return kQ.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a($Q,"lmdbGetDataByHash")});var na=g((Xle,ew)=>{"use strict";var wp=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};ew.exports=wp});var rw=g((eue,tw)=>{"use strict";var Zle=na(),YQ=ta(),KQ=Np();tw.exports=WQ;async function WQ(e){let t=await KQ(e),r=global.hdb_schema[e.schema][e.table];return YQ.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(WQ,"lmdbSearchByHash")});var rs=g((rue,nw)=>{"use strict";var Cp=class{static{a(this,"SearchObject")}constructor(t,r,n,s,i,o,c,l=!1,_=void 0,u=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=_,this.offset=u}};nw.exports=Cp});var od=g((sue,lw)=>{"use strict";var rr=ta(),QQ=We(),zQ=J(),me=dt(),eo=P(),JQ=Fi(),sw=vr().LMDB_ERRORS_ENUM,{getSchemaPath:XQ}=ze(),bs=eo.SEARCH_WILDCARDS;async function jQ(e,t,r){let n;e.schema===eo.SYSTEM_SCHEMA_NAME?n=JQ[e.table]:n=global.hdb_schema[e.schema][e.table];let s=cw(e,n.hash_attribute,r,t);return ow(e,s,n.hash_attribute,r)}a(jQ,"prepSearch");async function ow(e,t,r,n){let s=XQ(e.schema,e.table),i=await QQ.openEnvironment(s,e.table),o=aw(i,e,t,r),c=o.transaction||i;if([me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,me.SEARCH_TYPES.SEARCH_ALL,me.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(ZQ(e,r)===!1){let u=e.search_attribute;if(u===r)return n?iw(o,()=>!0):o.map(E=>({[r]:E.key}));let d=a(E=>({[r]:E.value,[u]:E.key}),"toObject");return n?iw(o,d):o.map(d)}let _=e.search_attribute===r?o.map(u=>u.key):o.map(u=>u.value);return n===!0?rr.batchSearchByHashToMap(c,r,e.get_attributes,_):rr.batchSearchByHash(c,r,e.get_attributes,_)}a(ow,"executeSearch");function aw(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 me.SEARCH_TYPES.EQUALS:s=rr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.CONTAINS:s=rr.contains(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.ENDS_WITH:case me.SEARCH_TYPES._ENDS_WITH:s=rr.endsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.STARTS_WITH:case me.SEARCH_TYPES._STARTS_WITH:s=rr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return rr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return rr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case me.SEARCH_TYPES.SEARCH_ALL:return rr.searchAll(e,n,t.get_attributes,o,c,l);case me.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return rr.searchAllToMap(e,n,t.get_attributes,o,c,l);case me.SEARCH_TYPES.BETWEEN:s=rr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,l);break;case me.SEARCH_TYPES.GREATER_THAN:case me.SEARCH_TYPES._GREATER_THAN:s=rr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.GREATER_THAN_EQUAL:case me.SEARCH_TYPES._GREATER_THAN_EQUAL:s=rr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.LESS_THAN:case me.SEARCH_TYPES._LESS_THAN:s=rr.lessThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.LESS_THAN_EQUAL:case me.SEARCH_TYPES._LESS_THAN_EQUAL:s=rr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;default:return Object.create(null)}return s}a(aw,"searchByType");function iw(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(iw,"createMapFromIterable");function ZQ(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(ZQ,"checkToFetchMore");function cw(e,t,r,n){if(zQ.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),bs.indexOf(s)>-1)return r===!0?me.SEARCH_TYPES.SEARCH_ALL_TO_MAP:me.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(bs[0])<0&&s.indexOf(bs[1])<0)return c===!0?r===!0?me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:me.SEARCH_TYPES.EQUALS;if(bs.indexOf(i)>=0&&bs.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),me.SEARCH_TYPES.CONTAINS;if(bs.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),me.SEARCH_TYPES.ENDS_WITH;if(bs.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),me.SEARCH_TYPES.STARTS_WITH;if(s.includes(bs[0])||s.includes(bs[1]))return me.SEARCH_TYPES.EQUALS;throw new Error(sw.UNKNOWN_SEARCH_TYPE)}else switch(n){case eo.VALUE_SEARCH_COMPARATORS.BETWEEN:return me.SEARCH_TYPES.BETWEEN;case eo.VALUE_SEARCH_COMPARATORS.GREATER:return me.SEARCH_TYPES.GREATER_THAN;case eo.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return me.SEARCH_TYPES.GREATER_THAN_EQUAL;case eo.VALUE_SEARCH_COMPARATORS.LESS:return me.SEARCH_TYPES.LESS_THAN;case eo.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return me.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(sw.UNKNOWN_SEARCH_TYPE)}}a(cw,"createSearchTypeFromSearchObject");lw.exports={executeSearch:ow,createSearchTypeFromSearchObject:cw,prepSearch:jQ,searchByType:aw}});var _w=g((aue,uw)=>{"use strict";var oue=rs(),ez=ra(),tz=J(),rz=P(),nz=od();uw.exports=sz;function sz(e,t){if(!tz.isEmpty(t)&&rz.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=ez(e,"value");if(n)throw n;return nz.prepSearch(e,t,!0)}a(sz,"lmdbGetDataByValue")});var el=g((uue,dw)=>{"use strict";var lue=rs(),iz=ra(),oz=J(),az=P(),cz=od();dw.exports=lz;async function lz(e,t){if(!oz.isEmpty(t)&&az.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=iz(e,"value");if(n)throw n;return cz.prepSearch(e,t,!1)}a(lz,"lmdbSearchByValue")});var Ew=g((fue,fw)=>{"use strict";var due=dt(),Dp=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}},Lp=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},Mp=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};fw.exports={SearchByConditionsObject:Dp,SearchCondition:Lp,SortAttribute:Mp}});var Tw=g((pue,Sw)=>{"use strict";var hue=Ew().SearchByConditionsObject,uz=rs(),_z=ra(),Pp=ta(),ad=dt(),{Resource:mue}=(an(),ie(Up)),pw=od(),dz=yp(),fz=require("lodash"),{getSchemaPath:Ez}=ze(),hw=We(),{handleHDBError:hz,hdb_errors:mz}=se(),{HTTP_STATUS_CODES:pz}=mz,Sz=1e8;Sw.exports=Tz;async function Tz(e){let t=_z(e,"conditions");if(t)throw hz(t,t.message,pz.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=Ez(e.schema,e.table),n=await hw.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let _ of e.conditions)hw.openDBI(n,_.search_attribute);let i=fz.sortBy(e.conditions,_=>{if(_.estimated_count===void 0){let u=_.search_type;u===ad.SEARCH_TYPES.EQUALS?_.estimated_count=Pp.count(n,_.search_attribute,_.search_value):u===ad.SEARCH_TYPES.CONTAINS||u===ad.SEARCH_TYPES.ENDS_WITH?_.estimated_count=1/0:_.estimated_count=Sz}return _.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await mw(o,e,i[0],s.hash_attribute),l;if(!e.operator||e.operator.toLowerCase()==="and"){let _=n.dbis[s.hash_attribute],u=i.slice(1).map(pw.filterByType),d=u.length,E=Pp.setGetWholeRowAttributes(n,e.get_attributes);l=c.map(f=>_.get(f,{transaction:o,lazy:!0})),d>0&&(l=l.filter(f=>{for(let h=0;h<d;h++)if(!u[h](f))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(f=>dz.parseRow(f,E))}else{for(let d=1;d<i.length;d++){let E=i[d],f=await mw(o,e,E,s.hash_attribute);c=c.concat(f)}let _=new Set,u=e.offset||0;c=c.filter(d=>_.has(d)?!1:(_.add(d),!0)).slice(u,e.limit&&e.limit+u),l=Pp.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(Tz,"lmdbSearchByConditions");async function mw(e,t,r,n){let s=new uz(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===ad.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,pw.searchByType(e,s,i,n).map(o=>o.value)}a(mw,"executeConditionSearch")});var tl=g((Tue,gw)=>{"use strict";var gz=P().OPERATIONS_ENUM,vp=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=gz.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};gw.exports=vp});var Bp=g((Rue,ww)=>{"use strict";var bw=rs(),yw=tl(),Nw=el(),Iw=Jc(),Sr=P(),Rw=J(),Aw=We(),{getTransactionAuditStorePath:Rz,getSchemaPath:Az}=ze(),Ow=K();ww.exports=Oz;async function Oz(e){try{if(Rw.isEmpty(global.hdb_schema[e.schema])||Rw.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await bz(e),await yz(e);let t=Az(e.schema,e.table);try{await Aw.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")Ow.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=Rz(e.schema,e.table);await Aw.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")Ow.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(Oz,"lmdbDropTable");async function bz(e){let t=new bw(Sr.SYSTEM_SCHEMA_NAME,Sr.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await Nw(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 yw(Sr.SYSTEM_SCHEMA_NAME,Sr.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await Iw(s)}a(bz,"deleteAttributesFromSystem");async function yz(e){let t=new bw(Sr.SYSTEM_SCHEMA_NAME,Sr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await Nw(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 yw(Sr.SYSTEM_SCHEMA_NAME,Sr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await Iw(s)}catch(i){throw i}}a(yz,"dropTableFromSystem")});var Dw=g((Oue,Cw)=>{"use strict";var Nz=require("fs-extra"),Iz=rs(),wz=na(),Cz=tl(),Dz=Bp(),Lz=Jc(),Mz=Ip(),Pz=el(),ys=P(),{getSchemaPath:Uz}=ze(),{handleHDBError:vz,hdb_errors:Bz}=se(),{HDB_ERROR_MSGS:Hz,HTTP_STATUS_CODES:xz}=Bz;Cw.exports=Gz;async function Gz(e){let t;try{t=await Fz(e.schema);let r=new Iz(ys.SYSTEM_SCHEMA_NAME,ys.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,ys.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[ys.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await Pz(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await Dz(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new Cz(ys.SYSTEM_SCHEMA_NAME,ys.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await Lz(s);let i=Uz(t);await Nz.remove(i)}catch(r){throw r}}a(Gz,"lmdbDropSchema");async function Fz(e){let t=new wz(ys.SYSTEM_SCHEMA_NAME,ys.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[ys.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await Mz(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw vz(new Error,Hz.SCHEMA_NOT_FOUND(e),xz.NOT_FOUND,void 0,void 0,!0);return n}a(Fz,"validateDropSchema")});var xp=g((yue,Lw)=>{"use strict";var Hp=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};Lw.exports=Hp});var Pw=g((wue,Mw)=>{"use strict";var qz=require("fs-extra"),cd=We(),{getTransactionAuditStorePath:kz}=ze(),Gp=dt(),Iue=xp();Mw.exports=Vz;async function Vz(e){let t;try{let r=kz(e.schema,e.table);await qz.mkdirp(r),t=await cd.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{cd.createDBI(t,Gp.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),cd.createDBI(t,Gp.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),cd.createDBI(t,Gp.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(Vz,"createTransactionsAuditEnvironment")});var Hw=g((Due,Bw)=>{"use strict";var Fp=P(),Uw=We(),$z=Vo(),{getSystemSchemaPath:Yz,getSchemaPath:Kz}=ze(),Wz=Fi(),Qz=M_(),qp=L_(),zz=K(),Jz=Pw(),Vp=Wz.hdb_table,vw=[];for(let e=0;e<Vp.attributes.length;e++)vw.push(Vp.attributes[e].attribute);Bw.exports=Xz;async function Xz(e,t){let r=Kz(t.schema,t.table),n=new qp(t.schema,t.table,Fp.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new qp(t.schema,t.table,Fp.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new qp(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await Uw.createEnvironment(r,t.table),e!==void 0){let o=await Uw.openEnvironment(Yz(),Fp.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await $z.insertRecords(o,Vp.hash_attribute,vw,[e]),n.skip_table_check=!0,s.skip_table_check=!0,i.skip_table_check=!0,await kp(n),await kp(s),await kp(i)}await Jz(t)}catch(o){throw o}}a(Xz,"lmdbCreateTable");async function kp(e){try{await Qz(e)}catch(t){zz.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(kp,"createAttribute")});var Gw=g((Mue,xw)=>{"use strict";var jz=Fc(),Zz=bc(),e2=ed(),rl=P(),t2=Vo().updateRecords,r2=We(),{getSchemaPath:n2}=ze(),s2=Qc(),i2=K();xw.exports=o2;async function o2(e){try{let{schema_table:t,attributes:r}=jz(e);Zz(e,r,t.hash_attribute),e.schema!==rl.SYSTEM_SCHEMA_NAME&&(r.includes(rl.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(rl.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(rl.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(rl.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await e2(e.hdb_auth_header,t,r),s=n2(e.schema,e.table),i=await r2.openEnvironment(s,e.table),o=await t2(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await s2(e,o)}catch(c){i2.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(o2,"lmdbUpdateRecords")});var qw=g((Uue,Fw)=>{"use strict";var a2=P().OPERATIONS_ENUM,$p=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=a2.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};Fw.exports=$p});var Vw=g((Hue,kw)=>{"use strict";var Bue=qw(),c2=Fc(),l2=bc(),u2=ed(),nl=P(),_2=Vo().upsertRecords,d2=We(),{getSchemaPath:f2}=ze(),E2=Qc(),h2=K(),{handleHDBError:m2,hdb_errors:p2}=se();kw.exports=S2;async function S2(e){let t;try{t=c2(e)}catch(l){throw m2(l,l.message,p2.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;l2(e,n,r.hash_attribute),e.schema!==nl.SYSTEM_SCHEMA_NAME&&(n.includes(nl.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(nl.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(nl.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(nl.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await u2(e.hdb_auth_header,r,n),i=f2(e.schema,e.table),o=await d2.openEnvironment(i,e.table),c=await _2(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await E2(e,c)}catch(l){h2.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(S2,"lmdbUpsertRecords")});var Yw=g((Gue,$w)=>{"use strict";var Yp=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};$w.exports=Yp});var Ww=g((que,Kw)=>{"use strict";var Kp=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}};Kw.exports=Kp});var Jw=g(($ue,zw)=>{"use strict";var Wp=We(),{getTransactionAuditStorePath:T2}=ze(),Vue=Yw(),sl=dt(),g2=J(),Qw=Ww(),R2=require("util").promisify,A2=R2(setTimeout),O2=1e4,b2=100;zw.exports=y2;async function y2(e){let t=T2(e.schema,e.table),r=await Wp.openEnvironment(t,e.table,!0),n=Wp.listDBIs(r);Wp.initializeDBIs(r,sl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new Qw;do s=await N2(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 A2(b2);while(s.transactions_deleted>0);return i}a(y2,"deleteAuditLogsBefore");async function N2(e,t){let r=new Qw;try{let n=e.dbis[sl.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[sl.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];g2.isEmpty(c)||(s=e.dbis[sl.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[sl.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>O2)break}return await s,r}catch(n){throw n}}a(N2,"deleteTransactions")});var jw=g((Kue,Xw)=>{"use strict";var Qp=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};Xw.exports=Qp});var eC=g((zue,Zw)=>{"use strict";var I2=rs(),w2=tl(),Que=jw(),ns=P(),C2=J(),zp=We(),D2=Fi(),L2=el(),M2=Jc(),{getSchemaPath:P2}=ze();Zw.exports=U2;async function U2(e,t=!0){let r;e.schema===ns.SYSTEM_SCHEMA_NAME?r=D2[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await B2(e),s=P2(e.schema,e.table),i=await zp.openEnvironment(s,e.table);return t===!0&&await v2(e,i,r.hash_attribute),zp.dropDBI(i,e.attribute),n}a(U2,"lmdbDropAttribute");async function v2(e,t,r){let n=zp.openDBI(t,r),s,i=e.attribute;for(let{key:o,value:c,version:l}of n.getRange({start:!1,versions:!0})){let _={};for(let u in c)u!==i&&(_[u]=c[u]);s=t.dbis[r].put(o,_,l)}await s}a(v2,"removeAttributeFromAllObjects");async function B2(e){let t=new I2(ns.SYSTEM_SCHEMA_NAME,ns.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,ns.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[ns.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,ns.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await L2(t)).filter(o=>o[ns.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(C2.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[ns.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new w2(ns.SYSTEM_SCHEMA_NAME,ns.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return M2(i)}a(B2,"dropAttributeFromSystem")});var oC=g((jue,iC)=>{"use strict";var Jp=We(),sa=dt(),Xue=Br(),Xp=P(),tC=J(),{getTransactionAuditStorePath:H2}=ze(),x2=ta(),ld=jo(),G2=K();iC.exports=F2;async function F2(e){let t=H2(e.schema,e.table),r=await Jp.openEnvironment(t,e.table,!0),n=Jp.listDBIs(r);Jp.initializeDBIs(r,sa.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case Xp.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return rC(r,e.search_values);case Xp.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,k2(r,e.search_values,s);case Xp.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return q2(r,e.search_values);default:return rC(r)}}a(F2,"readAuditLog");function rC(e,t=[0,Date.now()]){tC.isEmpty(t[0])&&(t[0]=0),tC.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[sa.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 ld,s))}a(rC,"searchTransactionsByTimestamp");function q2(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[sa.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,sC(e,i))}return Object.fromEntries(r)}a(q2,"searchTransactionsByUsername");function k2(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let _=t[c],u=x2.equals(e,sa.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,sa.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,_);for(let{value:d}of u){let E=Number(d);n.has(E)?n.get(E).push(_.toString()):n.set(E,[_.toString()])}}let s=Array.from(n.keys()),i=sC(e,s),o=new Map;for(let c=0;c<i.length;c++){let l=i[c],_=l.timestamp,u=n.get(_);nC(l,"records",r,u,o),nC(l,"original_records",r,u,o)}return Object.fromEntries(o)}a(k2,"searchTransactionsByHashValues");function nC(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 _=s.get(l),u=_[_.length-1];if(u.timestamp===i)u[t]=[c];else{let d=new ld(e.operation,e.user_name,i,void 0);d[t]=[c],_.push(d)}}else{let _=new ld(e.operation,e.user_name,i,void 0);_[t]=[c],s.set(l,[_])}}}a(nC,"loopRecords");function sC(e,t){let r=[];try{let n=e.dbis[sa.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 ld,i);r.push(o)}}catch(i){G2.warn(i)}return r}catch(n){throw n}}a(sC,"batchSearchTransactions")});var cC=g((r_e,aC)=>{"use strict";var{getSchemaPath:e_e}=ze(),t_e=We(),{database:V2}=(Ae(),ie(ke));aC.exports={writeTransaction:$2};async function $2(e,t,r){return V2({database:e,table:t}).transaction(r)}a($2,"writeTransaction")});var dC=g((s_e,_C)=>{"use strict";var{getSchemaPath:lC}=ze(),uC=We();_C.exports={flush:Y2,resetReadTxn:K2};async function Y2(e,t){return(await uC.openEnvironment(lC(e,t),t.toString())).flushed}a(Y2,"flush");async function K2(e,t){try{(await uC.openEnvironment(lC(e,t),t.toString())).resetReadTxn()}catch{}}a(K2,"resetReadTxn")});var mC=g((o_e,hC)=>{"use strict";var{Readable:W2}=require("stream"),{getDatabases:Q2}=(Ae(),ie(ke)),{readSync:z2,openSync:J2,createReadStream:fC}=require("fs"),{open:X2}=require("lmdb"),EC=Pc(),j2=Uc(),{AUDIT_STORE_OPTIONS:Z2}=(ei(),ie(pC)),{INTERNAL_DBIS_NAME:eJ,AUDIT_STORE_NAME:tJ}=dt();hC.exports=nJ;var jp=32768,rJ=100;async function nJ(e){let t=e.database||e.schema||"data",r=Q2()[t],n=new Date().toISOString(),s=e.tables||e.table&&[e.table];if(s){let _=r[s[0]];if(!_)throw new Error(`Can not find table ${s[0]}`);let u=_.dbisDB,d=X2({noSync:!0,maxDbs:j2.MAX_DBS}),E,f=d.openDB(eJ,new EC(!1)),h=u.useReadTransaction(),p=0,S=a(async function(A,b){b.encoding="binary",b.encoder=void 0;let I=d.openDB(A,b),B=u.openDB(A,b);for(let{key:U,version:q,value:M}of B.getRange({start:null,transaction:h,versions:B.useVersions}))E=I.put(U,M,q),p++%rJ===0&&(await new Promise(Q=>setTimeout(Q,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:A,value:b}of u.getRange({transaction:h,start:!1}))if(s.some(I=>A.startsWith?.(I+"/"))){f.put(A,b);let[,I]=A.split("/"),B=!I,U=new EC(!B,B);await S(A,U)}e.include_audit&&await S(tJ,Object.assign({},Z2)),await E;let T=fC(d.path);return T.headers=l(),T.on("close",()=>{h.done(),d.close()}),T}let o=r[Object.keys(r)[0]].primaryStore,c=J2(o.path);return o.transaction(()=>{let _=Buffer.alloc(jp);z2(c,_,0,jp),o.resetReadTxn();let u=o.useReadTransaction();u.renew();let d=fC(null,{fd:c,start:jp}),E=new W2.from(async function*(){yield _;for await(let f of d)u.openTimer&&(u.openTimer=0),yield f;u.done()}());return E.headers=l(),E});function l(){let _=new Map;return _.set("content-type","application/octet-stream"),_.set("content-disposition",`attachment; filename="${t}"`),_.set("date",n),_}}a(nJ,"getBackup")});var gC=g((c_e,TC)=>{"use strict";var sJ=K(),{handleHDBError:iJ}=se(),oJ=vb(),aJ=M_(),cJ=gp(),lJ=DI(),uJ=Jc(),_J=Ip(),dJ=rw(),fJ=_w(),EJ=el(),hJ=Tw(),mJ=Dw(),pJ=Hw(),SJ=Gw(),TJ=Vw(),gJ=Jw(),RJ=Bp(),AJ=eC(),OJ=oC(),bJ=cC(),SC=dC(),yJ=mC(),Zp=class extends oJ{static{a(this,"LMDBBridge")}async searchByConditions(t){return hJ(t)}async getDataByHash(t){return await _J(t)}async searchByHash(t){return await dJ(t)}async getDataByValue(t,r){return await fJ(t,r)}async searchByValue(t){return await EJ(t)}async createSchema(t){return await lJ(t)}async dropSchema(t){return await mJ(t)}async createTable(t,r){return await pJ(t,r)}async dropTable(t){return await RJ(t)}async createAttribute(t){return await aJ(t)}async createRecords(t){return await cJ(t)}async updateRecords(t){return await SJ(t)}async upsertRecords(t){try{return await TJ(t)}catch(r){throw iJ(r,null,null,sJ.ERR,r)}}async deleteRecords(t){return await uJ(t)}async dropAttribute(t){return await AJ(t)}async deleteAuditLogsBefore(t){return await gJ(t)}async readAuditLog(t){return await OJ(t)}writeTransaction(t,r,n){return bJ.writeTransaction(t,r,n)}flush(t,r){return SC.flush(t,r)}resetReadTxn(t,r){return SC.resetReadTxn(t,r)}getBackup(t){return yJ(t)}};TC.exports=Zp});function CJ(){wJ=setInterval(function(){for(let e of eS)if(e.stale){let t=e[ye]?.url;bC.error(`Transaction was open too long and has been aborted, from table: ${e.lmdbDb?.name+(t?" path: "+t:"")}`),e.abort()}else e.stale=!0},IJ).unref()}var tS,OC,bC,yC,NC,IC,RC,eS,NJ,il,AC,to,ud,IJ,wJ,rS=Re(()=>{tS=x(Br()),OC=x(se()),bC=x(K());an();yC=x(ne()),NC=x(P()),IC=x(J()),RC=100,eS=new Set,NJ=(0,IC.convertToMS)(yC.get(NC.CONFIG_PARAMS.STORAGE_MAXTRANSACTIONQUEUETIME))||45e3,to=class e{static{a(this,"DatabaseTransaction")}writes=[];lmdbDb;readTxn;readTxnRefCount;readTxnsUsed;validated=0;timestamp=0;overloadChecked;open=1;getReadTxn(){if(this.readTxnRefCount=(this.readTxnRefCount||0)+1,this.stale&&(this.stale=!1),this.readTxn)return this.readTxn.openTimer&&(this.readTxn.openTimer=0),this.readTxn;if(this.open===1)return this.readTxn=this.lmdbDb.useReadTransaction(),this.readTxnsUsed=1,this.readTxn.openTimer&&(this.readTxn.openTimer=0),eS.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(eS.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(il&&!this.overloadChecked&&performance.now()-AC>NJ)throw new OC.ServerError("Outstanding write transactions have too long of queue, please try again later",503);this.overloadChecked=!0}addWrite(t){if(this.open===0)throw new Error("Can not use a transaction that is no longer open");if(this.open===2){let r=new e;return r.addWrite(t),r.commit({})}else this.writes.push(t)}removeWrite(t){let r=this.writes.indexOf(t);r>-1&&(this.writes[r]=null)}commit(t={}){let r=this.timestamp;r||(r=this.timestamp=t.timestamp||(0,tS.getNextMonotonicTime)()),t.timestamp||(t.timestamp=r);let n=t.retries||0;if(this.validated<this.writes.length)try{let d=this.validated;this.validated=this.writes.length;for(let f=d;f<this.validated;f++)this.writes[f]?.validate?.(this.timestamp);let E;for(let f=d;f<this.validated;f++){let h=this.writes[f];h&&(h.before||h.beforeIntermediate)&&(E=!0)}if(E)return(async()=>{try{for(let f=0;f<2;f++){let h;for(let p=d;p<this.validated;p++){let S=this.writes[p];if(!S)continue;let T=S[f===0?"before":"beforeIntermediate"];if(T){let A=T();h?h.push?h.push(A):h=[h,A]:h=A}}h&&await(h.push?Promise.all(h):h)}}catch(f){throw this.abort(),f}return this.commit(t)})()}catch(d){throw this.abort(),d}n||this.doneReadTxn(),this.open=t?.letItLinger?2:0;let s,i=[],o=0;this.writes=this.writes.filter(d=>d);let c=a(d=>{d.commit(r,d.entry,n)},"doWrite"),l=a(()=>{let d=this.writes[o++];if(d)if(d.key){n>0&&(d.entry=d.store.getEntry(d.key));let E=d.store.ifVersion(d.key,d.entry?.version??null,l);s=s||E}else l();else for(let E of this.writes)c(E)},"nextCondition"),_=this.lmdbDb;if(this.writes.length>0&&(_?.retryRisk&&(_.retryRisk*=.99),this.writes.length+(_?.retryRisk||0)<RC>>n?l():s=this.writes[0].store.transaction(()=>{for(let d of this.writes)d.entry=d.store.getEntry(d.key),c(d);return!0})),s)return il||(il=s,AC=performance.now(),il.then(()=>{il=null})),s.then(d=>d?(this.next&&i.push(this.next.commit(t)),t?.flush&&i.push(this.writes[0].store.flushed),this.writes=[],this.next=null,Promise.all(i).then(()=>({txnTime:r}))):(_&&(_.retryRisk=(_.retryRisk||0)+RC/2),t?t.retries=n+1:t={retries:1},this.commit(t)));let u={txnTime:r};if(this.next){let d=this.next?.commit(t);if(d?.then)return d?.then(E=>({txnTime:r,next:E}));u.next=d}return u}abort(){for(;this.readTxnsUsed>0;)this.doneReadTxn();this.open=0,this.writes=[]}},ud=class extends to{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,tS.getNextMonotonicTime)())}getReadTxn(){}},IJ=3e4;a(CJ,"startMonitoringTxns");CJ()});function Ze(e,t,r){if(!t)t=e,e={};else if(!e)e={};else if(e?.transaction?.open===1&&typeof t=="function")return t(e.transaction);if(typeof t!="function")throw new Error("Callback function must be provided to transaction");let n=e.transaction=new to;e.timestamp&&(n.timestamp=e.timestamp),n[ye]=e,e.resourceCache||(e.resourceCache=[]);let s;try{if(s=t(n),s?.then)return s.then(i,o)}catch(c){o(c)}return i(s);function i(c){let l=n.commit({letItLinger:r?.letItLinger});return l.then?l.then(()=>c):c}function o(c){throw n.abort({}),c}}var wC,ro=Re(()=>{wC=require("../index");an();rS();a(Ze,"transaction");(0,wC._assignPackageExport)("transaction",Ze);Ze.commit=function(e){let t=(e[ye]||e)?.transaction;if(!t)throw new Error("No active transaction is available to commit");return t.commit()};Ze.abort=function(e){let t=(e[ye]||e)?.transaction;if(!t)throw new Error("No active transaction is available to abort");return t.abort()}});var BC={};qe(BC,{ResourceBridge:()=>iS});function oS({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 DC(e,t){let r=ss(e),n=oS(e,r);if(!r)throw new Pn.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},o;Ze(i,()=>new Promise(_=>o=_));let c=e.ids||e.hash_values,l=0;return{[Symbol.asyncIterator](){return{async next(){if(l<c.length){let _=c[l++],u;try{u=await r.get({id:_,lazy:s,select:n},i),u=u&&dd(u)}catch(d){u={message:d.toString()}}return t?{value:{key:_,value:u}}:{value:u}}else return o(),{done:!0}},return(_){return o(),{value:_,done:!0}},throw(_){return o(),{done:!0}}}}}}function ss(e){let t=e.database||e.schema||LJ,r=Tr()[t];if(!r)throw(0,Pn.handleHDBError)(new Error,DJ.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function LC(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*MC(e,t,r){let n;for await(let s of e.getHistory(t,r)){let i=s.type;i==="put"&&(i="upsert");let{id:o,version:c,value:l}=s;n?.timestamp===c?(n.hash_values.push(o),n.records.push(l)):(n&&(yield n),n={operation:i,user_name:s.user,timestamp:c,hash_values:[o],records:[l]})}n&&(yield n)}var PC,_d,Pn,UC,Un,nS,sS,vC,DJ,LJ,MJ,PJ,CC,iS,HC=Re(()=>{"use strict";PC=x(gC()),_d=x(ra()),Pn=x(se());Ae();UC=x(Fc()),Un=x(P()),nS=x(Os()),sS=x(Mn()),vC=x(J());ro();fd();({HDB_ERROR_MSGS:DJ}=Pn.hdb_errors),LJ="data",MJ=1e4,PJ=10,iS=class extends PC.default{static{a(this,"ResourceBridge")}constructor(t){super(t),CC=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,_d.default)(t,"conditions");if(r)throw(0,Pn.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=ss(t);if(!n)throw new Pn.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:oS(t,n),sort:t.sort,allowFullScan:!0},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache})}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 Pn.ClientError("A primary key must be specified with a `primary_key` property or with `attributes`");n=[{name:i,isPrimaryKey:!0},{name:"__createdtime__",indexed:!0},{name:"__updatedtime__",indexed:!0}]}ft({database:r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration})}async createAttribute(t){return await ss(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=ss(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=a((o,c,l)=>(c=Object.assign({},c),delete c[n],r.primaryStore.ifVersion(o,l,()=>r.primaryStore.put(o,c,l)).then(_=>{if(!_){let{value:u,version:d}=r.primaryStore.getEntry(o);return i(o,u,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(_=>setImmediate(_));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){ss(t).dropTable()}createSchema(t){return ia({database:t.schema,table:null}),nS.signalSchemaChange(new sS.SchemaEventMsg(process.pid,Un.OPERATIONS_ENUM.CREATE_SCHEMA,t.schema))}async dropSchema(t){await aS(t.schema),nS.signalSchemaChange(new sS.SchemaEventMsg(process.pid,Un.OPERATIONS_ENUM.DROP_SCHEMA,t.schema))}async updateRecords(t){return t.requires_existing=!0,this.upsertRecords(t)}async createRecords(t){return t.requires_no_existing=!0,CC.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,UC.default)(t),s,i=Tr()[t.schema][t.table],o={user:t.hdb_user,expiresAt:t.expiresAt};return Ze(o,async c=>{if(!i.schemaDefined){s=[];for(let u of n)i.attributes.find(E=>E.name==u)||s.push(u);s.length>0&&await i.addAttributes(s.map(u=>({name:u,indexed:!0})))}let l=[],_=[];for(let u of t.records){let d=u[i.primaryKey],E=d!=null&&await i.get(d,o);if(t.requires_existing&&!E||t.requires_no_existing&&E){_.push(u[i.primaryKey]);continue}E&&(E=dd(E));for(let f in u)if(Object.prototype.hasOwnProperty.call(u,f)){let h=u[f];if(typeof h=="function")try{let p=h([[E]]);Array.isArray(p)&&(h=p[0].func_val,u[f]=h)}catch(p){throw p.message+="Trying to set key "+f+" on object"+JSON.stringify(u),p}}if(E)for(let f in E)Object.prototype.hasOwnProperty.call(u,f)||(u[f]=E[f]);await(d==null?i.create(u,o):i.put(u,o)),l.push(u[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:l,new_attributes:s,skipped_hashes:_}})}async deleteRecords(t){let r=Tr()[t.schema][t.table],n={user:t.hdb_user};return Ze(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 LC(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=Tr()[t.schema][t.table];if(!r.createdTimeProperty)throw new Pn.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:Un.VALUE_SEARCH_COMPARATORS.LESS}]}),s=!1,i=[],o=[],c=0,l=[],_=a(async()=>{let u=await this.deleteRecords({schema:t.schema,table:t.table,hash_values:l});i.push(...u.deleted_hashes),o.push(...u.skipped_hashes),await(0,vC.async_set_timeout)(PJ),l=[],s=!0},"chunkDelete");for await(let u of n)l.push(u[r.primaryKey]),c++,c%MJ===0&&await _();return l.length>0&&await _(),s?LC(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,_d.default)(t,"hashes");if(r)throw r;return DC(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of DC(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&Un.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[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,_d.default)(t,"value");if(n)throw n;let s=ss(t);if(!s)throw new Pn.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===Un.VALUE_SEARCH_COMPARATORS.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:oS(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache})}async getDataByValue(t,r){let n=new Map,s=ss(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){ss({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return ss(t).deleteHistory(t.timestamp)}async readAuditLog(t){let r=ss(t),n={};switch(t.search_type){case Un.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:for(let i of t.search_values)n[i]=(await r.getHistoryOfRecord(i)).map(o=>{let c=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 Un.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:let s=t.search_values;for await(let i of MC(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return MC(r,t.search_values?.[0],t.search_values?.[1])}}};a(oS,"getSelect");a(DC,"getRecords");a(ss,"getTable");a(LC,"createDeleteResponse");a(MC,"groupRecordsInHistory")});var Cn=g((O_e,xC)=>{"use strict";var{ResourceBridge:UJ}=(HC(),ie(BC)),vJ=ne();vJ.initSync();var Ed;function BJ(){return Ed||(Ed=new UJ,Ed)}a(BJ,"getBridge");xC.exports=BJ()});var kC=g((y_e,qC)=>{"use strict";var GC=require("lodash"),ol=require("mathjs"),HJ=require("jsonata"),FC=J();qC.exports={distinct_array:e=>Array.isArray(e)&&e.length>1?GC.uniqWith(e,GC.isEqual):e,searchJSON:xJ,mad:al.bind(null,ol.mad),mean:al.bind(null,ol.mean),mode:al.bind(null,ol.mode),prod:al.bind(null,ol.prod),median:al.bind(null,ol.median)};function al(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(al,"aggregateFunction");function xJ(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(FC.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),FC.isEmpty(this.__ala__.res[r])){let n=HJ(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(xJ,"searchJSON")});var $C=g((I_e,VC)=>{"use strict";var gt=require("moment"),cS="YYYY-MM-DDTHH:mm:ss.SSSZZ";gt.suppressDeprecationWarnings=!0;VC.exports={current_date:()=>gt().utc().format("YYYY-MM-DD"),current_time:()=>gt().utc().format("HH:mm:ss.SSS"),extract:(e,t)=>{switch(t.toLowerCase()){case"year":return gt(e).utc().format("YYYY");case"month":return gt(e).utc().format("MM");case"day":return gt(e).utc().format("DD");case"hour":return gt(e).utc().format("HH");case"minute":return gt(e).utc().format("mm");case"second":return gt(e).utc().format("ss");case"millisecond":return gt(e).utc().format("SSS");default:break}},date:e=>gt(e).utc().format(cS),date_format:(e,t)=>gt(e).utc().format(t),date_add:(e,t,r)=>gt(e).utc().add(t,r).valueOf(),date_sub:(e,t,r)=>gt(e).utc().subtract(t,r).valueOf(),date_diff:(e,t,r)=>{let n=gt(e).utc(),s=gt(t).utc();return r?n.diff(s,r,!0):n.diff(s)},now:()=>gt().utc().valueOf(),get_server_time:()=>gt().format(cS),offset_utc:(e,t)=>gt(e).utc().utcOffset(t).format(cS)}});var QC=g((w_e,WC)=>{"use strict";var GJ=require("@turf/area"),FJ=require("@turf/length"),qJ=require("@turf/circle"),kJ=require("@turf/difference"),VJ=require("@turf/distance"),$J=require("@turf/boolean-contains"),YJ=require("@turf/boolean-equal"),KJ=require("@turf/boolean-disjoint"),WJ=require("@turf/helpers"),YC=P(),Te=J(),Ns=K();WC.exports={geoArea:QJ,geoLength:zJ,geoCircle:JJ,geoDifference:XJ,geoDistance:KC,geoNear:jJ,geoContains:ZJ,geoEqual:e4,geoCrosses:t4,geoConvert:r4};function QJ(e){if(Te.isEmpty(e))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e));try{return GJ.default(e)}catch(t){return Ns.trace(t,e),NaN}}a(QJ,"geoArea");function zJ(e,t){if(Te.isEmpty(e))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e));try{return FJ.default(e,{units:t||"kilometers"})}catch(r){return Ns.trace(r,e),NaN}}a(zJ,"geoLength");function JJ(e,t,r){if(Te.isEmpty(e))return NaN;if(Te.isEmpty(t))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e));try{return qJ.default(e,t,{units:r||"kilometers"})}catch(n){return Ns.trace(n,e,t),NaN}}a(JJ,"geoCircle");function XJ(e,t){if(Te.isEmpty(e))return NaN;if(Te.isEmpty(t))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return kJ(e,t)}catch(r){return Ns.trace(r,e,t),NaN}}a(XJ,"geoDifference");function KC(e,t,r){if(Te.isEmpty(e))return NaN;if(Te.isEmpty(t))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return VJ.default(e,t,{units:r||"kilometers"})}catch(n){return Ns.trace(n,e,t),NaN}}a(KC,"geoDistance");function jJ(e,t,r,n){if(Te.isEmpty(e)||Te.isEmpty(t))return!1;if(Te.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t)),isNaN(r))throw new Error("distance must be a number");try{return KC(e,t,n)<=r}catch(s){return Ns.trace(s,e,t),!1}}a(jJ,"geoNear");function ZJ(e,t){if(Te.isEmpty(e)||Te.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return $J.default(e,t)}catch(r){return Ns.trace(r,e,t),!1}}a(ZJ,"geoContains");function e4(e,t){if(Te.isEmpty(e)||Te.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return YJ.default(e,t)}catch(r){return Ns.trace(r,e,t),!1}}a(e4,"geoEqual");function t4(e,t){if(Te.isEmpty(e)||Te.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return!KJ.default(e,t)}catch(r){return Ns.trace(r,e,t),!1}}a(t4,"geoCrosses");function r4(e,t,r){if(Te.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if(Te.isEmpty(t))throw new Error("geo_type is required");if(Te.isEmpty(YC.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(YC.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Te.autoCastJSON(e)),WJ[t](e,r)}a(r4,"geoConvert")});var hd=g((D_e,zC)=>{var no=kC(),Kr=$C(),is=QC();zC.exports=e=>{e.aggr.mad=e.aggr.MAD=no.mad,e.aggr.mean=e.aggr.MEAN=no.mean,e.aggr.mode=e.aggr.MODE=no.mode,e.aggr.prod=e.aggr.PROD=no.prod,e.aggr.median=e.aggr.MEDIAN=no.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=no.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=no.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=Kr.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Kr.current_time,e.fn.extract=e.fn.EXTRACT=Kr.extract,e.fn.date=e.fn.DATE=Kr.date,e.fn.date_format=e.fn.DATE_FORMAT=Kr.date_format,e.fn.date_add=e.fn.DATE_ADD=Kr.date_add,e.fn.date_sub=e.fn.DATE_SUB=Kr.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Kr.date_diff,e.fn.now=e.fn.NOW=Kr.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Kr.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Kr.get_server_time,e.fn.getdate=e.fn.GETDATE=Kr.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Kr.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=is.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=is.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=is.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=is.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=is.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=is.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=is.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=is.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=is.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=is.geoNear}});var ZC=g((L_e,jC)=>{"use strict";var cl=require("lodash"),gr=require("alasql");gr.options.cache=!1;var n4=hd(),JC=require("clone"),md=require("recursive-iterator"),fe=K(),Le=J(),oa=Cn(),s4=P(),{hdb_errors:i4}=se(),{getDatabases:XC}=(Ae(),ie(ke)),o4="IS NULL",vn="There was a problem performing this search. Please check the logs and try again.";n4(gr);var lS=class{static{a(this,"SQLSearch")}constructor(t,r){if(Le.isEmpty(t))throw fe.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(),Le.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!Le.isEmptyOrZeroLength(n))return fe.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw fe.error("Error thrown from checkEmptySQL in SQLSearch class method search."),fe.error(n),new Error(vn)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw fe.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),fe.error(n),new Error(vn)}if(Object.keys(this.data).length===0)return fe.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw fe.error("Error thrown from processJoins in SQLSearch class method search."),fe.error(n),new Error(vn)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw fe.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),fe.error(n),new Error(vn)}try{return t=await this._finalSQL(),t}catch(n){throw fe.error("Error thrown from finalSQL in SQLSearch class method search."),fe.error(n),new Error(vn)}}_getColumns(){let t=new md(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(JC(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=cl.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=XC()[r.databaseid][r.tableid].primaryKey,this.data[n].__merged_data={},this.data[n].__merged_attributes=[],this.data[n].__merged_attr_map={}})}_conditionsToFetchAttributeValues(){if(Le.isEmpty(this.statement.where)){fe.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new md(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!Le.isEmpty(r)&&r.right)if(Le.isNotEmptyAndHasValue(r.right.value)){let n=Le.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new gr.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=Le.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new gr.yy.LogicValue({value:i}):n instanceof gr.yy.StringValue&&Le.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new gr.yy.NumValue({value:i}))});if(t){fe.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new md(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(!Le.isEmpty(s4.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(Le.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(Le.isEmptyOrZeroLength(r.left.columnid)||Le.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(Le.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"=":!Le.isEmpty(r.right.value)||!Le.isEmpty(r.left.value)?n.add(Le.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 _=0;_<l.length;_++)if(l[_].value)n.add(l[_].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(Le.isEmptyOrZeroLength(this.all_table_attributes)&&Le.isEmptyOrZeroLength(this.statement.from)&&Le.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&&cl.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(Le.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);Le.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(Le.isEmptyOrZeroLength(this.all_table_attributes)&&!Le.isEmptyOrZeroLength(this.columns.columns))return t;if(Le.isEmptyOrZeroLength(this.all_table_attributes)&&Le.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await gr.promise(r)}catch(r){throw fe.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),fe.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(JC(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(Le.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(o4)>-1&&this.tables.forEach(s=>{let i={columnid:XC()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=cl.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,_=[s.table.databaseid,s.table.tableid,s.attribute].join("/");if(s.attribute===o&&(l=!0),!Le.isEmpty(this.exact_search_values[_])&&!this.exact_search_values[_].ignore&&!Le.isEmptyOrZeroLength(this.exact_search_values[_].values))if(l)try{c.hash_values=Array.from(this.exact_search_values[_].values);let u=await oa.getDataByHash(c);for(let d of c.hash_values)u.get(d)&&!this.data[i].__merged_data[d]&&(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d))}catch(u){throw fe.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),fe.error(u),new Error(vn)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[_].values).map(async u=>{let d=Object.assign({},c);d.search_value=u;let E=await oa.getDataByValue(d);for(let[f,h]of E)this.data[i].__merged_data[f]?this._updateMergedAttribute(i,f,s.attribute,h[s.attribute]):(this.data[i].__merged_data[f]=[...n[i]],this._updateMergedAttribute(i,f,s.attribute,h[s.attribute]),this._setMergedHashAttribute(i,f))}))}catch(u){throw fe.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),fe.error(u),new Error(vn)}else if(!Le.isEmpty(this.comparator_search_values[_])&&!this.comparator_search_values[_].ignore&&!Le.isEmptyOrZeroLength(this.comparator_search_values[_].comparators))try{let u=this.comparator_search_values[_].comparators;for(let d=0,E=u.length;d<E;d++){let f=u[d];c.search_attribute=f.attribute,c.search_value=f.search_value;let h=await oa.getDataByValue(c,f.operation);if(l)for(let[p]of h)this.data[i].__merged_data[p]||(this.data[i].__merged_data[p]=[...n[i]],this._setMergedHashAttribute(i,p));else for(let[p,S]of h)this.data[i].__merged_data[p]?this._updateMergedAttribute(i,p,s.attribute,S[s.attribute]):(this.data[i].__merged_data[p]=[...n[i]],this._updateMergedAttribute(i,p,s.attribute,S[s.attribute]),this._setMergedHashAttribute(i,p))}}catch(u){throw fe.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),fe.error(u),new Error(vn)}else try{c.search_attribute=s.attribute,c.search_value="*";let u=await oa.getDataByValue(c);if(l)for(let[d]of u)this.data[i].__merged_data[d]||(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d));else for(let[d,E]of u)this.data[i].__merged_data[d]?this._updateMergedAttribute(i,d,s.attribute,E[s.attribute]):(this.data[i].__merged_data[d]=[...n[i]],this._updateMergedAttribute(i,d,s.attribute,E[s.attribute]),this._setMergedHashAttribute(i,d))}catch(u){throw fe.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),fe.error(u),new Error(vn)}}}_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 gr.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 gr.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new gr.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 gr.yy.FuncValue:new gr.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(f=>{f.joinmode&&f.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(f.table);let h=f.joinmode+" JOIN ? AS "+(f.as?f.as:f.table.tableid);f.on&&(h+=" ON "+f.on.toString()),i.push(h),t.push(Object.values(this.data[`${f.table.databaseid_orig}_${f.table.as?f.table.as_orig:f.table.tableid_orig}`].__merged_data))});let o=[],c={};s.forEach(f=>{let h=this.data[`${f.databaseid_orig}_${f.as?f.as_orig:f.tableid_orig}`].__hash_name,p=f.as?f.as_orig:f.tableid_orig;o.push({key:`'${p}.${h}'`,schema:f.databaseid_orig,table:f.as?f.as_orig:f.tableid_orig,keys:new Set}),r.push(`${f.as?f.as:f.tableid}.\`${h}\` AS "${p}.${h}"`),c[f.as?f.as_orig:f.tableid_orig]=this.data[`${f.databaseid_orig}_${f.as?f.as_orig:f.tableid_orig}`].__merged_attributes});let l=this.statement.where?"WHERE "+this.statement.where:"";l=l.replace(/NOT\(NULL\)/g,"NOT NULL");let _="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(_="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(f=>{f.is_func?r.push(f.initial_select_column.toString()):f.initial_select_column.tableid?r.push(`${f.initial_select_column.tableid}.${f.initial_select_column.columnid} AS ${f.expression.columnid}`):r.push(`${f.initial_select_column.columnid} AS ${f.expression.columnid}`)}));let u="",d="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(u=this.statement.limit?"LIMIT "+this.statement.limit:"",d=this.statement.offset?"OFFSET "+this.statement.offset:"");let E=[];try{let f=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${l} ${_} ${u} ${d}`,h=this._convertColumnsToIndexes(f,s);E=await gr.promise(h,t),t=null}catch(f){throw fe.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),fe.error(f),new Error("There was a problem processing the data.")}if(E&&E.length>0){for(let f=0,h=E.length;f<h;f++){let p=E[f];o.forEach(S=>{p[S.key]!==null&&p[S.key]!==void 0&&S.keys.add(p[S.key])})}o.forEach(f=>{let h=Object.keys(this.data[`${f.schema}_${f.table}`].__merged_data),p=cl.difference(h,[...f.keys].map(S=>S.toString()));for(let S=0,T=p.length;S<T;S++){let A=p[S];delete this.data[`${f.schema}_${f.table}`].__merged_data[A]}})}return{existing_attributes:c,joined_length:E?E.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new md(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=cl.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 fe.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),fe.error(i),new Error(vn)}}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 u in i)o.push(i[u][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 oa.getDataByHash(c),_=s.columns.length;for(let u=0,d=o.length;u<d;u++){let E=o[u],f=l.get(E);for(let h=0;h<_;h++){let p=s.columns[h],S=f[p]===void 0?null:f[p];this.data[n].__merged_data[E].push(S)}}}}catch(r){throw fe.error("Error thrown from getDataByHash function in SQLSearch class method getData."),fe.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();fe.trace(`Final SQL: ${s}`),n=await gr.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),fe.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw fe.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),fe.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 fe.error(i4.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),fe.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],_=new RegExp(`${l}.\`${o}\``,"g"),u=`${l}.[${c}]`;n=n.replace(_,u)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=new RegExp(`\`${o}\``,"g"),_=`[${c}]`;n=n.replace(l,_)});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 oa.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]=Object.assign({},r[s])),this.data[s].__merged_data[c][t[n.attribute]]=l[n.attribute]??null}catch(o){throw fe.error("There was an error when processing this SQL operation. Check your logs"),fe.error(o),new Error(vn)}}return Object.values(Object.values(this.data)[0].__merged_data)}};jC.exports=lS});var Fr=g((P_e,eD)=>{"use strict";var a4=Pb();eD.exports={searchByConditions:l4,searchByHash:u4,searchByValue:_4,search:d4};var uS=Cn(),{transformReq:_S}=J(),c4=ZC();async function l4(e){return _S(e),uS.searchByConditions(e)}a(l4,"searchByConditions");async function u4(e){_S(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of uS.searchByHash(e))r&&t.push(r);return t}a(u4,"searchByHash");async function _4(e){_S(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of uS.searchByValue(e))t.push(r);return t}a(_4,"searchByValue");function d4(e,t){try{let r=new a4(e);r.validate(),new c4(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(d4,"search")});var pd=g((v_e,tD)=>{"use strict";var f4=Cn();tD.exports={writeTransaction:E4};function E4(e,t,r){return f4.writeTransaction(e,t,r)}a(E4,"writeTransaction")});var iD=g((x_e,sD)=>{"use strict";var h4=Fr(),m4=si(),rD=K(),p4=un(),H_e=pd(),S4=require("clone"),fS=require("alasql"),T4=hd(),nD=require("util"),g4=nD.promisify(m4.getTableSchema),R4=nD.promisify(h4.search),A4=P(),dS=J();T4(fS);sD.exports={update:b4};var O4="There was a problem performing this update. Please check the logs and try again.";async function b4({statement:e,hdb_user:t}){let r=await g4(e.table.databaseid,e.table.tableid),n=y4(e.columns);dS.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=S4(s),c=dS.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,_=fS.parse(l).statements[0],u=await R4(_),d=N4(n,u);return I4(o,d,t)}a(b4,"update");function y4(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=fS.compile(`SELECT ${r.expression.toString()} AS [${A4.FUNC_VAL}] FROM ?`)}),t}catch(t){throw rD.error(t),new Error(O4)}}a(y4,"createUpdateRecord");function N4(e,t){return dS.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(N4,"buildUpdateRecords");async function I4(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await p4.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){rD.error(`Error delete new_attributes from update response: ${i}`)}return s}a(I4,"updateRecords")});var aD=g((k_e,oD)=>{var w4=require("alasql"),C4=Fr(),D4=K(),L4=Cn(),hS=require("util"),ES=J(),M4=P(),P4=si(),F_e=pd(),q_e=un(),U4="record",v4="successfully deleted",B4=hS.callbackify(F4),H4=hS.promisify(C4.search),x4=hS.promisify(P4.getTableSchema);oD.exports={convertDelete:B4};function G4(e){return`${e.deleted_hashes.length} ${U4}${e.deleted_hashes.length===1?"":"s"} ${v4}`}a(G4,"generateReturnMessage");async function F4({statement:e,hdb_user:t}){let r=await x4(e.table.databaseid,e.table.tableid);ES.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=ES.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=w4.parse(o).statements[0],l={operation:M4.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await H4(c);let _=await L4.deleteRecords(l);return ES.isEmptyOrZeroLength(_.message)&&(_.message=G4(_)),delete _.txn_time,_}catch(_){throw D4.error(_),_.hdb_code?_.message:_}}a(F4,"convertDelete")});var dD=g(($_e,_D)=>{"use strict";var q4=ni(),{hdb_errors:cD}=se(),{getDatabases:lD}=(Ae(),ie(ke));_D.exports={checkSchemaExists:uD,checkSchemaTableExists:k4,schema_describe:q4};async function uD(e){if(!lD()[e])return cD.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(uD,"checkSchemaExists");async function k4(e,t){let r=await uD(e);if(r)return r;if(!lD()[e][t])return cD.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(k4,"checkSchemaTableExists")});var Rd=g((W_e,mD)=>{"use strict";var aa=D_(),ca=dD(),V4=K(),$4=require("uuid").v4,K_e=require("clone"),Td=Os(),la=P(),Y4=require("util"),_i=Cn(),{handleHDBError:Rr,hdb_errors:K4}=se(),{HDB_ERROR_MSGS:Sd,HTTP_STATUS_CODES:Ar}=K4,{SchemaEventMsg:gd}=Mn(),fD=wt(),{getDatabases:W4}=(Ae(),ie(ke)),{transformReq:ua}=J();mD.exports={createSchema:Q4,createSchemaStructure:ED,createTable:z4,createTableStructure:hD,createAttribute:e3,dropSchema:J4,dropTable:X4,dropAttribute:j4,getBackup:t3};async function Q4(e){let t=await ED(e);return Td.signalSchemaChange(new gd(process.pid,e.operation,e.schema)),t}a(Q4,"createSchema");async function ED(e){let t=aa.schema_object(e);if(t)throw Rr(t,t.message,Ar.BAD_REQUEST,void 0,void 0,!0);if(ua(e),!await ca.checkSchemaExists(e.schema))throw Rr(new Error,Sd.SCHEMA_EXISTS_ERR(e.schema),Ar.BAD_REQUEST,la.LOG_LEVELS.ERROR,Sd.SCHEMA_EXISTS_ERR(e.schema),!0);return await _i.createSchema(e),`database '${e.schema}' successfully created`}a(ED,"createSchemaStructure");async function z4(e){return ua(e),e.hash_attribute=e.primary_key??e.hash_attribute,await hD(e)}a(z4,"createTable");async function hD(e){let t=aa.create_table_object(e);if(t)throw Rr(t,t.message,Ar.BAD_REQUEST,void 0,void 0,!0);if(aa.validateTableResidence(e.residence),!await ca.checkSchemaTableExists(e.schema,e.table))throw Rr(new Error,Sd.TABLE_EXISTS_ERR(e.schema,e.table),Ar.BAD_REQUEST,la.LOG_LEVELS.ERROR,Sd.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:$4(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await _i.createTable(n,e);else throw Rr(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",Ar.BAD_REQUEST);else await _i.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}a(hD,"createTableStructure");async function J4(e){let t=!e.schema&&!e.database?new Error("database is required"):void 0,r=aa.schema_object(e),n=t??r;if(n)throw Rr(n,n.message,Ar.BAD_REQUEST,void 0,void 0,!0);ua(e);let s=await ca.checkSchemaExists(e.schema);if(s)throw Rr(new Error,s,Ar.NOT_FOUND,la.LOG_LEVELS.ERROR,s,!0);let i=await ca.schema_describe.describeSchema({schema:e.schema}),o=Object.keys(global.hdb_schema[e.schema]);return await _i.dropSchema(e),Td.signalSchemaChange(new gd(process.pid,e.operation,e.schema)),await fD.purgeSchemaTableStreams(e.schema,o),`successfully deleted '${e.schema}'`}a(J4,"dropSchema");async function X4(e){let t=aa.table_object(e);if(t)throw Rr(t,t.message,Ar.BAD_REQUEST,void 0,void 0,!0);ua(e);let r=await ca.checkSchemaTableExists(e.schema,e.table);if(r)throw Rr(new Error,r,Ar.NOT_FOUND,la.LOG_LEVELS.ERROR,r,!0);return await _i.dropTable(e),await fD.purgeTableStream(e.schema,e.table),`successfully deleted table '${e.schema}.${e.table}'`}a(X4,"dropTable");async function j4(e){let t=aa.attribute_object(e);if(t)throw Rr(t,t.message,Ar.BAD_REQUEST,void 0,void 0,!0);ua(e);let r=await ca.checkSchemaTableExists(e.schema,e.table);if(r)throw Rr(new Error,r,Ar.NOT_FOUND,la.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw Rr(new Error,"You cannot drop a hash attribute",Ar.BAD_REQUEST,void 0,void 0,!0);if(la.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw Rr(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,Ar.BAD_REQUEST,void 0,void 0,!0);try{return await _i.dropAttribute(e),Z4(e),Td.signalSchemaChange(new gd(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw V4.error(`Got an error deleting attribute ${Y4.inspect(e)}.`),n}}a(j4,"dropAttribute");function Z4(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(Z4,"dropAttributeFromGlobal");async function e3(e){ua(e);let t=W4()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw Rr(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,Ar.BAD_REQUEST,void 0,void 0,!0);return await _i.createAttribute(e),Td.signalSchemaChange(new gd(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}a(e3,"createAttribute");function t3(e){return _i.getBackup(e)}a(t3,"getBackup")});var SD=g((z_e,pD)=>{"use strict";var{OPERATIONS_ENUM:r3}=P(),mS=class{static{a(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=r3.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};pD.exports=mS});var pS=g((j_e,OD)=>{"use strict";var n3=Cn(),X_e=SD(),Ad=J(),Od=P(),s3=ne(),{handleHDBError:TD,hdb_errors:i3}=se(),{HDB_ERROR_MSGS:gD,HTTP_STATUS_CODES:RD}=i3,o3=Object.values(Od.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),AD="To use this operation audit log must be enabled in harperdb-config.yaml";OD.exports=a3;async function a3(e){if(Ad.isEmpty(e.schema))throw new Error(gD.SCHEMA_REQUIRED_ERR);if(Ad.isEmpty(e.table))throw new Error(gD.TABLE_REQUIRED_ERR);if(!s3.get(Od.CONFIG_PARAMS.LOGGING_AUDITLOG))throw TD(new Error,AD,RD.BAD_REQUEST,Od.LOG_LEVELS.ERROR,AD,!0);let t=Ad.checkSchemaTableExist(e.schema,e.table);if(t)throw TD(new Error,t,RD.NOT_FOUND,Od.LOG_LEVELS.ERROR,t,!0);if(!Ad.isEmpty(e.search_type)&&o3.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await n3.readAuditLog(e)}a(a3,"readAuditLog")});var yD=g((ede,bD)=>{"use strict";var{OPERATIONS_ENUM:c3}=P(),SS=class{static{a(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=c3.GET_BACKUP,this.schema=t,this.table=r}};bD.exports=SS});var wD=g((sde,ID)=>{"use strict";var l3=Cn(),rde=yD(),TS=J(),u3=P(),nde=ne(),{handleHDBError:_3,hdb_errors:d3}=se(),{HDB_ERROR_MSGS:ND,HTTP_STATUS_CODES:f3}=d3;ID.exports=E3;async function E3(e){if(TS.isEmpty(e.schema))throw new Error(ND.SCHEMA_REQUIRED_ERR);if(TS.isEmpty(e.table))throw new Error(ND.TABLE_REQUIRED_ERR);let t=TS.checkSchemaTableExist(e.schema,e.table);if(t)throw _3(new Error,t,f3.NOT_FOUND,u3.LOG_LEVELS.ERROR,t,!0);return await l3.getBackup(read_audit_log_object)}a(E3,"getBackup")});var UD=g((ode,PD)=>{var di=require("validate.js"),DD=at(),_a=P(),{handleHDBError:h3,hdb_errors:m3}=se(),{HDB_ERROR_MSGS:ht,HTTP_STATUS_CODES:p3}=m3,gS=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),S3={STRUCTURE_USER:"structure_user"},CD=Object.values(_a.ROLE_TYPES_ENUM),T3="attribute_permissions",g3="attribute_name",{PERMS_CRUD_ENUM:da}=_a,R3=[T3,...Object.values(da)],LD=[da.READ,da.INSERT,da.UPDATE],A3=[g3,...LD];function O3(e){let t=gS();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,MD(e,t)}a(O3,"addRoleValidation");function b3(e){let t=gS();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,MD(e,t)}a(b3,"alterRoleValidation");function y3(e){let t=gS();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,DD.validateObject(e,t)}a(y3,"dropRoleValidation");var N3=["operation","role","id","permission","hdb_user","hdb_auth_header"];function MD(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)N3.includes(n[o])||s.push(n[o]);s.length>0&&Rt(ht.INVALID_ROLE_JSON_KEYS(s),r);let i=DD.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{Rt(o,r)}),e.permission){let o=I3(e);o&&Rt(o,r),CD.forEach(c=>{e.permission[c]&&!di.isBoolean(e.permission[c])&&Rt(ht.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(CD.indexOf(o)<0){if(o===S3.STRUCTURE_USER){let l=e.permission[o];if(typeof l=="boolean")continue;if(Array.isArray(l)){for(let _=0,u=l.length;_<u;_++){let d=l[_];global.hdb_schema[d]||Rt(ht.SCHEMA_NOT_FOUND(d),r)}continue}Rt(ht.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){Rt(ht.SCHEMA_NOT_FOUND(o),r);continue}if(c.tables)for(let l in c.tables){let _=c.tables[l];if(!l||!global.hdb_schema[o][l]){Rt(ht.TABLE_NOT_FOUND(o,l),r);continue}if(Object.keys(_).forEach(u=>{R3.includes(u)||Rt(ht.INVALID_PERM_KEY(u),r,o,l)}),Object.values(da).forEach(u=>{di.isDefined(_[u])?di.isBoolean(_[u])||Rt(ht.TABLE_PERM_NOT_BOOLEAN(u),r,o,l):Rt(ht.TABLE_PERM_MISSING(u),r,o,l)}),di.isDefined(_.attribute_permissions)){if(!di.isArray(_.attribute_permissions)){Rt(ht.ATTR_PERMS_NOT_ARRAY,r,o,l);continue}}else{Rt(ht.ATTR_PERMS_ARRAY_MISSING,r,o,l);continue}if(_.attribute_permissions){let u=global.hdb_schema[o][l].attributes.map(({attribute:E})=>E),d={read:!1,insert:!1,update:!1};for(let E in _.attribute_permissions){let f=_.attribute_permissions[E];if(Object.keys(f).forEach(p=>{!A3.includes(p)&&p!==da.DELETE&&Rt(ht.INVALID_ATTR_PERM_KEY(p),r,o,l)}),!di.isDefined(f.attribute_name)){Rt(ht.ATTR_PERM_MISSING_NAME,r,o,l);continue}let h=f.attribute_name;if(!u.includes(h)){Rt(ht.INVALID_ATTRIBUTE_IN_PERMS(h),r,o,l);continue}LD.forEach(p=>{di.isDefined(f[p])?di.isBoolean(f[p])||Rt(ht.ATTR_PERM_NOT_BOOLEAN(p,h),r,o,l):Rt(ht.ATTR_PERM_MISSING(p,h),r,o,l)}),!d.read&&f.read===!0&&(d.read=!0),!d.insert&&f.insert===!0&&(d.insert=!0),!d.update&&f.update===!0&&(d.update=!0)}if(_.read===!1&&d.read===!0||_.insert===!1&&d.insert===!0||_.update===!1&&d.update===!0){let E=`${o}.${l}`;Rt(ht.MISMATCHED_TABLE_ATTR_PERMS(E),r,o,l)}}}}return w3(r)}a(MD,"customValidate");PD.exports={addRoleValidation:O3,alterRoleValidation:b3,dropRoleValidation:y3};function I3(e){let{operation:t,permission:r}=e;if(t===_a.OPERATIONS_ENUM.ADD_ROLE||t===_a.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 ht.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?_a.ROLE_TYPES_ENUM.SUPER_USER:_a.ROLE_TYPES_ENUM.CLUSTER_USER;return ht.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(I3,"validateNoSUPerms");function w3(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:ht.ROLE_PERMS_ERROR,...e};return h3(new Error,n,p3.BAD_REQUEST)}else return null}a(w3,"generateRolePermResponse");function Rt(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(Rt,"addPermError")});var NS=g((cde,xD)=>{"use strict";var vD=un(),BD=Fr(),C3=Ki(),AS=UD(),OS=Os(),D3=require("uuid").v4,L3=require("util"),bd=P(),M3=J(),bS=BD.searchByValue,P3=BD.searchByHash,U3=L3.promisify(C3.delete),v3=rs(),B3=na(),{hdb_errors:H3,handleHDBError:so}=se(),{HDB_ERROR_MSGS:HD,HTTP_STATUS_CODES:ll}=H3,{UserEventMsg:yS}=Mn();xD.exports={addRole:x3,alterRole:G3,dropRole:F3,listRoles:q3};function RS(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(RS,"scrubRoleDetails");async function x3(e){let t=AS.addRoleValidation(e);if(t)throw t;e=RS(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 bS(r)||[])}catch(i){throw so(i)}if(n&&n.length>0)throw so(new Error,HD.ROLE_ALREADY_EXISTS(e.role),ll.CONFLICT,void 0,void 0,!0);e.id||(e.id=D3());let s={operation:"insert",schema:"system",table:"hdb_role",hash_attribute:"id",records:[e]};return await vD.insert(s),OS.signalUserChange(new yS(process.pid)),e=RS(e),e}a(x3,"addRole");async function G3(e){let t=AS.alterRoleValidation(e);if(t)throw t;e=RS(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await vD.update(r)}catch(s){throw so(s)}if(n&&n?.message==="updated 0 of 1 records")throw so(new Error,"Invalid role id",ll.BAD_REQUEST,void 0,void 0,!0);return await OS.signalUserChange(new yS(process.pid)),e}a(G3,"alterRole");async function F3(e){let t=AS.dropRoleValidation(e);if(t)throw so(new Error,t,ll.BAD_REQUEST,void 0,void 0,!0);let r=new B3(bd.SYSTEM_SCHEMA_NAME,bd.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await P3(r));if(n.length===0)throw so(new Error,HD.ROLE_NOT_FOUND,ll.NOT_FOUND,void 0,void 0,!0);let s=new v3(bd.SYSTEM_SCHEMA_NAME,bd.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await bS(s)),o=!1;if(M3.isEmptyOrZeroLength(i)===!1){for(let l=0;l<i.length;l++)if(i[l].active===!0){o=!0;break}}if(o===!0)throw so(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,ll.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await U3(c),OS.signalUserChange(new yS(process.pid)),`${n[0].role} successfully deleted`}a(F3,"dropRole");async function q3(){return bS({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(q3,"listRoles")});var kD=g((ude,qD)=>{"use strict";var k3=ne(),fi=require("joi"),V3=at(),GD=require("moment"),$3=require("fs-extra"),IS=require("path"),Y3=require("lodash"),ul=P(),{LOG_LEVELS:io}=P(),K3="YYYY-MM-DD hh:mm:ss",W3=IS.resolve(__dirname,"../logs");qD.exports=function(e){return V3.validateBySchema(e,Q3)};var Q3=fi.object({from:fi.custom(FD),until:fi.custom(FD),level:fi.valid(io.NOTIFY,io.FATAL,io.ERROR,io.WARN,io.INFO,io.DEBUG,io.TRACE),order:fi.valid("asc","desc"),limit:fi.number().min(1),start:fi.number().min(0),log_name:fi.custom(z3)});function FD(e,t){if(GD(e,GD.ISO_8601).format(K3)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(FD,"validateDatetime");function z3(e,t){if(Y3.invert(ul.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=k3.get(ul.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?ul.LOG_NAMES.HDB:e,i=s===ul.LOG_NAMES.INSTALL?IS.join(W3,ul.LOG_NAMES.INSTALL):IS.join(n,s);return $3.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(z3,"validateReadLogPath")});var CS=g((dde,$D)=>{"use strict";var yd=P(),J3=K(),X3=ne(),j3=kD(),wS=require("path"),VD=require("fs-extra"),{once:Z3}=require("events"),{handleHDBError:eX,hdb_errors:tX}=se(),{PACKAGE_ROOT:rX}=P(),nX=wS.join(rX,"logs"),sX=1e3,iX=200;$D.exports=oX;async function oX(e){let t=j3(e);if(t)throw eX(t,t.message,tX.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=X3.get(yd.HDB_SETTINGS_NAMES.LOG_PATH_KEY),n=e.log_name===void 0?yd.LOG_NAMES.HDB:e.log_name,s=n===yd.LOG_NAMES.INSTALL?wS.join(nX,yd.LOG_NAMES.INSTALL):wS.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,_=e.until!==void 0,u=_?new Date(e.until):void 0,d=e.limit===void 0?sX:e.limit,E=e.order===void 0?void 0:e.order,f=e.start===void 0?0:e.start,h=f+d,p=0;E==="desc"&&!l&&!u&&(p=Math.max(VD.statSync(s).size-(h+5)*iX,0));let S=VD.createReadStream(s,{start:p});S.on("error",U=>{J3.error(U)});let T=0,A=[],b="",I;S.on("data",U=>{let q=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;U=b+U;let M=0,Q;for(;(Q=q.exec(U))&&!S.destroyed;){I&&(I.message=U.slice(M,Q.index),B(I));let[z,j,oe]=Q,le=oe.split("] ["),ue=le[0],Be=le[1];le.splice(0,2),I={timestamp:j,thread:ue,level:Be,tags:le,message:""},M=Q.index+z.length}b=U.slice(M)}),S.on("end",U=>{S.destroyed||I&&(I.message=b.trim(),B(I))}),S.resume();function B(U){let q,M,Q;switch(!0){case(i&&c&&_):q=new Date(U.timestamp),M=new Date(l),Q=new Date(u),U.level===o&&q>=M&&q<=Q&&T<f?T++:U.level===o&&q>=M&&q<=Q&&(Ei(U,E,A),T++,T===h&&S.destroy());break;case(i&&c):q=new Date(U.timestamp),M=new Date(l),U.level===o&&q>=M&&T<f?T++:U.level===o&&q>=M&&(Ei(U,E,A),T++,T===h&&S.destroy());break;case(i&&_):q=new Date(U.timestamp),Q=new Date(u),U.level===o&&q<=Q&&T<f?T++:U.level===o&&q<=Q&&(Ei(U,E,A),T++,T===h&&S.destroy());break;case(c&&_):q=new Date(U.timestamp),M=new Date(l),Q=new Date(u),q>=M&&q<=Q&&T<f?T++:q>=M&&q<=Q&&(Ei(U,E,A),T++,T===h&&S.destroy());break;case i:U.level===o&&T<f?T++:U.level===o&&(Ei(U,E,A),T++,T===h&&S.destroy());break;case c:q=new Date(U.timestamp),M=new Date(l),q>=M&&T<f?T++:q>=M&&T>=f&&(Ei(U,E,A),T++,T===h&&S.destroy());break;case _:q=new Date(U.timestamp),Q=new Date(u),q<=Q&&T<f?T++:q<=Q&&T>=f&&(Ei(U,E,A),T++,T===h&&S.destroy());break;default:T<f?T++:(Ei(U,E,A),T++,T===h&&S.destroy())}}return a(B,"onLogMessage"),await Z3(S,"close"),A}a(oX,"readLog");function Ei(e,t,r){t==="desc"?aX(e,r):t==="asc"?cX(e,r):r.push(e)}a(Ei,"pushLineToResult");function aX(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(aX,"insertDescending");function cX(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(cX,"insertAscending")});var Nd=g((pde,QD)=>{"use strict";var DS=require("joi"),{string:_l,boolean:YD,date:lX}=DS.types(),uX=at(),{validateSchemaExists:Ede,validateTableExists:hde,validateSchemaName:mde}=Xn(),_X=P(),dX=ct(),KD=ne();KD.initSync();var fX=_l.invalid(KD.get(_X.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(dX.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).required(),WD={operation:_l.valid("add_node","update_node","set_node_replication"),node_name:fX,subscriptions:DS.array().items({table:_l.optional(),schema:_l.optional(),database:_l.optional(),subscribe:YD.required(),publish:YD.required().custom(hX),start_time:lX.iso()}).min(1).required()};function EX(e){return uX.validateBySchema(e,DS.object(WD))}a(EX,"addUpdateNodeValidator");function hX(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(hX,"checkForFalsy");QD.exports={addUpdateNodeValidator:EX,validation_schema:WD}});var JD=g((Tde,zD)=>{var mX=at(),pX={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};zD.exports=function(e){return mX.validateObject(e,pX)}});var MS=g((gde,XD)=>{"use strict";var SX=P().OPERATIONS_ENUM,LS=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=SX.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};XD.exports=LS});var ZD=g((Ade,jD)=>{"use strict";var TX={OPERATION:"operation",REFRESH:"refresh"},PS=class{static{a(this,"JWTTokens")}constructor(t,r){this.operation_token=t,this.refresh_token=r}},US=class{static{a(this,"JWTRSAKeys")}constructor(t,r,n){this.public_key=t,this.private_key=r,this.passphrase=n}};jD.exports={JWTTokens:PS,TOKEN_TYPE_ENUM:TX,JWTRSAKeys:US}});var El=g((bde,nL)=>{"use strict";var fl=require("jsonwebtoken"),vS=require("fs-extra"),BS=J(),dn=P(),{handleHDBError:Or,hdb_errors:gX}=se(),{HTTP_STATUS_CODES:br,AUTHENTICATION_ERROR_MSGS:yr}=gX,dl=K(),eL=q_(),GS=_n(),RX=un().update,AX=MS(),OX=Os(),{UserEventMsg:bX}=Mn(),hi=ne();hi.initSync();var HS=require("path"),{JWTTokens:yX,JWTRSAKeys:NX,TOKEN_TYPE_ENUM:Id}=ZD(),IX=hi.get(dn.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY)?hi.get(dn.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY):"1d",wX=hi.get(dn.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY)?hi.get(dn.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY):"30d",wd="RS256",xS;nL.exports={createTokens:CX,validateOperationToken:LX,refreshOperationToken:DX,validateRefreshToken:rL};async function CX(e){if(BS.isEmpty(e)||typeof e!="object")throw Or(new Error,yr.INVALID_AUTH_OBJECT,br.BAD_REQUEST,void 0,void 0,!0);if(BS.isEmpty(e.username))throw Or(new Error,yr.USERNAME_REQUIRED,br.BAD_REQUEST,void 0,void 0,!0);if(BS.isEmpty(e.password))throw Or(new Error,yr.PASSWORD_REQUIRED,br.BAD_REQUEST,void 0,void 0,!0);let t;try{if(t=await GS.findAndValidateUser(e.username,e.password),!t)throw Or(new Error,yr.INVALID_CREDENTIALS,br.UNAUTHORIZED,void 0,void 0,!0)}catch(E){throw dl.error(E),Or(new Error,yr.INVALID_CREDENTIALS,br.UNAUTHORIZED,void 0,void 0,!0)}let r=await Cd(),n=!1,s=!1;t.role&&t.role.permission&&(n=t.role.permission.super_user===!0,s=t.role.permission.cluster_user===!0);let i={username:e.username,super_user:n,cluster_user:s},o=await tL(i,r.private_key,r.passphrase),c=await fl.sign(i,{key:r.private_key,passphrase:r.passphrase},{expiresIn:wX,algorithm:wd,subject:Id.REFRESH}),l=eL.hash(c),_=new AX(dn.SYSTEM_SCHEMA_NAME,dn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,[{username:e.username,refresh_token:l}]),u,d;try{u=await RX(_)}catch(E){dl.error(E),d=E}if(d!==void 0||u.skipped_hashes.length>0)throw Or(new Error,yr.REFRESH_TOKEN_SAVE_FAILED,br.INTERNAL_SERVER_ERROR);return OX.signalUserChange(new bX(process.pid)),new yX(o,c)}a(CX,"createTokens");async function tL(e,t,r){return await fl.sign(e,{key:t,passphrase:r},{expiresIn:IX,algorithm:wd,subject:Id.OPERATION})}a(tL,"signOperationToken");async function Cd(){if(xS===void 0)try{let e=HS.join(hi.getHdbBasePath(),dn.LICENSE_KEY_DIR_NAME,dn.JWT_ENUM.JWT_PASSPHRASE_NAME),t=HS.join(hi.getHdbBasePath(),dn.LICENSE_KEY_DIR_NAME,dn.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r=HS.join(hi.getHdbBasePath(),dn.LICENSE_KEY_DIR_NAME,dn.JWT_ENUM.JWT_PUBLIC_KEY_NAME),n=(await vS.readFile(e)).toString(),s=(await vS.readFile(t)).toString(),i=(await vS.readFile(r)).toString();xS=new NX(i,s,n)}catch(e){throw dl.error(e),Or(new Error,yr.NO_ENCRYPTION_KEYS,br.INTERNAL_SERVER_ERROR)}return xS}a(Cd,"getJWTRSAKeys");async function DX(e){if(!e)throw Or(new Error,yr.INVALID_BODY,br.BAD_REQUEST,void 0,void 0,!0);if(!e.refresh_token)throw Or(new Error,yr.REFRESH_TOKEN_REQUIRED,br.BAD_REQUEST,void 0,void 0,!0);await rL(e.refresh_token);let t=await Cd(),r=await fl.decode(e.refresh_token);return{operation_token:await tL({username:r.username,super_user:r.super_user,cluster_user:r.cluster_user},t.private_key,t.passphrase)}}a(DX,"refreshOperationToken");async function LX(e){try{let t=await Cd(),r=await fl.verify(e,t.public_key,{algorithms:wd,subject:Id.OPERATION});return await GS.findAndValidateUser(r.username,void 0,!1)}catch(t){throw dl.warn(t),t.name&&t.name==="TokenExpiredError"?Or(new Error,yr.TOKEN_EXPIRED,br.FORBIDDEN):Or(new Error,yr.INVALID_TOKEN,br.UNAUTHORIZED)}}a(LX,"validateOperationToken");async function rL(e){let t;try{let r=await Cd(),n=await fl.verify(e,r.public_key,{algorithms:wd,subject:Id.REFRESH});t=await GS.findAndValidateUser(n.username,void 0,!1)}catch(r){throw dl.warn(r),r.name&&r.name==="TokenExpiredError"?Or(new Error,yr.TOKEN_EXPIRED,br.FORBIDDEN):Or(new Error,yr.INVALID_TOKEN,br.UNAUTHORIZED)}if(!eL.validate(t.refresh_token,e))throw Or(new Error,yr.INVALID_TOKEN,br.UNAUTHORIZED);return t}a(rL,"validateRefreshToken")});var FS=g((Ide,oL)=>{"use strict";var MX=JD(),fa=require("passport"),PX=require("passport-local").Strategy,UX=require("passport-http").BasicStrategy,vX=require("util"),BX=_n(),iL=vX.callbackify(BX.findAndValidateUser),Nde=vr(),HX=P(),sL=El();fa.use(new PX(function(e,t,r){iL(e,t,r)}));fa.use(new UX(function(e,t,r){iL(e,t,r)}));fa.serializeUser(function(e,t){t(null,e)});fa.deserializeUser(function(e,t){t(null,e)});function xX(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":fa.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===HX.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?sL.validateRefreshToken(s).then(o=>{e.body.refresh_token=s,r(null,o)}).catch(o=>{r(o)}):sL.validateOperationToken(s).then(o=>{r(null,o)}).catch(o=>{r(o)});break;default:fa.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(xX,"authorize");function GX(e,t){let r=MX(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(GX,"checkPermissions");oL.exports={authorize:xX,checkPermissions:GX}});var Ea=g((Cde,aL)=>{"use strict";var qS=class{static{a(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},kS=class{static{a(this,"NodeSubscription")}constructor(t,r,n,s){this.schema=t,this.table=r,this.publish=n,this.subscribe=s}};aL.exports={Node:qS,NodeSubscription:kS}});var lL=g((Lde,cL)=>{"use strict";var FX=P().OPERATIONS_ENUM,VS=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=FX.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};cL.exports=VS});var hl=g((Pde,uL)=>{"use strict";var $S=class{static{a(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},YS=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)}};uL.exports={RemotePayloadObject:$S,RemotePayloadSubscription:YS}});var dL=g((vde,_L)=>{"use strict";var KS=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}};_L.exports=KS});var hL=g((Fde,EL)=>{"use strict";var qX=dL(),Hde=dt(),fL=We(),kX=K(),{getSchemaPath:xde,getTransactionAuditStorePath:Gde}=ze(),{getDatabases:VX}=(Ae(),ie(ke));EL.exports=$X;async function $X(e){let t=new qX;try{let r=VX()[e.schema]?.[e.name],n=r.primaryStore.getStats(),s=r.auditStore?.getStats(),i=await fL.environmentDataSize(schema_path,e.name),o=await fL.environmentDataSize(txn_path,e.name);t.schema=e.schema,t.table=e.name,t.table_size=i,t.record_count=n.entryCount,t.transaction_log_size=o,t.transaction_log_record_count=s.entryCount}catch(r){kX.warn(`unable to stat table dbi due to ${r}`)}return t}a($X,"lmdbGetTableSize")});var pL=g((kde,mL)=>{"use strict";var WS=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}};mL.exports=WS});var ha=g((Qde,RL)=>{"use strict";var YX=require("fs-extra"),KX=require("path"),nr=require("systeminformation"),mi=K(),SL=wt(),$de=ct(),Ld=P(),WX=hL(),QX=ni(),{getThreadInfo:TL}=it(),sT=ne();sT.initSync();var zX=pL(),{openEnvironment:Yde}=We(),{getSchemaPath:Kde}=ze(),{database:Wde,databases:QS}=(Ae(),ie(ke)),Dd;RL.exports={getHDBProcessInfo:jS,getNetworkInfo:eT,getDiskInfo:ZS,getMemoryInfo:XS,getCPUInfo:JS,getTimeInfo:zS,getSystemInformation:tT,systemInformation:JX,getTableSize:rT,getMetrics:nT};function zS(){return nr.time()}a(zS,"getTimeInfo");async function JS(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:o,governor:c,socket:l,cache:_,...u}=await nr.cpu();u.cpu_speed=await nr.cpuCurrentSpeed();let{raw_currentload:d,raw_currentload_idle:E,raw_currentload_irq:f,raw_currentload_nice:h,raw_currentload_system:p,raw_currentload_user:S,cpus:T,...A}=await nr.currentLoad();return A.cpus=[],T.forEach(b=>{let{raw_load:I,raw_load_idle:B,raw_load_irq:U,raw_load_nice:q,raw_load_system:M,raw_load_user:Q,...z}=b;A.cpus.push(z)}),u.current_load=A,u}catch(e){return mi.error(`error in getCPUInfo: ${e}`),{}}}a(JS,"getCPUInfo");async function XS(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await nr.mem();return Object.assign(s,process.memoryUsage())}catch(e){return mi.error(`error in getMemoryInfo: ${e}`),{}}}a(XS,"getMemoryInfo");async function jS(){let e={core:[],clustering:[]};try{let t=await nr.processes(),r;try{r=Number.parseInt(await YX.readFile(KX.join(sT.get(Ld.CONFIG_PARAMS.ROOTPATH),Ld.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===Ld.NODE_ERROR_CODES.ENOENT)mi.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 mi.error(`error in getHDBProcessInfo: ${t}`),e}}a(jS,"getHDBProcessInfo");async function ZS(){let e={};try{let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await nr.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:l,..._}=await nr.fsStats();return e.read_write=_,e.size=await nr.fsSize(),e}catch(t){return mi.error(`error in getDiskInfo: ${t}`),e}}a(ZS,"getDiskInfo");async function eT(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return e.default_interface=await nr.networkInterfaceDefault(),e.latency=await nr.inetChecksite("google.com"),(await nr.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:o,dhcp:c,dnsSuffix:l,ieee8021xAuth:_,ieee8021xState:u,carrier_changes:d,...E}=n;e.interfaces.push(E)}),(await nr.networkStats()).forEach(n=>{let{rx_sec:s,tx_sec:i,ms:o,...c}=n;e.stats.push(c)}),e}catch(t){return mi.error(`error in getNetworkInfo: ${t}`),e}}a(eT,"getNetworkInfo");async function tT(){if(Dd!==void 0)return Dd;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:o,...c}=await nr.osInfo();e=c;let l=await nr.versions("node, npm");return e.node_version=l.node,e.npm_version=l.npm,Dd=e,Dd}catch(t){return mi.error(`error in getSystemInformation: ${t}`),e}}a(tT,"getSystemInformation");async function rT(){let e=[],t=await QX.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await WX(n));return e}a(rT,"getTableSize");async function nT(){let e={};for(let t in QS){let r=e[t]={},n=r.tables={};for(let s in QS[t])try{let i=QS[t][s];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,d]=l.trim().split(" ");return{pid:_,thread:u,txnid:d}}),i.primaryStore.auditStore&&(r.audit=i.auditStore.getStats()));let o=i.primaryStore.getStats(),c={};for(let l of["treeDepth","treeBranchPageCount","treeLeafPageCount","entryCount","overflowPages"])c[l]=o[l];n[s]=c}catch(i){mi.notify(`Error getting stats for table ${s}: ${i}`)}}return e}a(nT,"getMetrics");async function gL(){if(sT.get(Ld.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{jsm:e}=await SL.getNATSReferences(),t=await SL.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(gL,"getNatsStreamInfo");async function JX(e){let t=new zX;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await tT(),t.time=zS(),t.cpu=await JS(),t.memory=await XS(),t.disk=await ZS(),t.network=await eT(),t.harperdb_processes=await jS(),t.table_size=await rT(),t.metrics=await nT(),t.threads=await TL(),t.replication=await gL(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await tT();break;case"time":t.time=zS();break;case"cpu":t.cpu=await JS();break;case"memory":t.memory=await XS();break;case"disk":t.disk=await ZS();break;case"network":t.network=await eT();break;case"harperdb_processes":t.harperdb_processes=await jS();break;case"table_size":t.table_size=await rT();break;case"database_metrics":case"metrics":t.metrics=await nT();break;case"threads":t.threads=await TL();break;case"replication":t.replication=await gL();break;default:break}return t}a(JX,"systemInformation")});var ml=g((Jde,XX)=>{XX.exports={name:"harperdb",version:"4.3.37",description:"HarperDB is a distributed database, caching service, streaming broker, and application development platform focused on performance and ease of use.",keywords:["database","nosql","api","distributed","broker","mqtt","real-time","enterprise","Fastify","NATS","HarperDB","Harper","clustering","replication","REST","WebSockets","decentralized","server-sent events","document store"],main:"harperdb.js",bin:{harperdb:"./bin/harperdb.js"},engines:{"minimum-node":"16.0.0","go-lang":"1.21.7","nats-server":"2.10.11"},exports:{".":"./index.js"},homepage:"https://www.harperdb.io/",bugs:"support@harperdb.io",author:{name:"HarperDB",email:"support@harperdb.io"},license:"SEE LICENSE IN LICENSE",scripts:{submodules:"git submodule update --init --recursive",build:"eslint -c ./.eslintbuild bin/ dataLayer/ security/ server/ sqlTranslator/ upgrade/ utility/ validation/",pretty:"eslint --fix bin/ dataLayer/ security/ server/ sqlTranslator/ upgrade/ utility/ validation/","cover:test":"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && nyc --no-clean --reporter=lcovonly npm run test:apitests && nyc --no-clean --reporter=lcovonly npm run test:resources && nyc --no-clean --reporter=lcovonly npm run test:logging && nyc --no-clean --reporter=lcovonly npm run test:upgrade && nyc --no-clean --reporter=lcovonly npm run test:nats && nyc --no-clean --reporter=lcovonly npm run test:cfserver && nyc --no-clean --reporter=lcovonly npm run test:hdbserver && nyc --no-clean --reporter=lcovonly npm run test:bin && nyc --no-clean --reporter=lcovonly npm run test:main && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license",test:"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && npm run test:apitests && npm run test:resources && npm run test:logging && npm run test:upgrade && npm run test:nats && npm run test:cfserver && npm run test:hdbserver && npm run test:bin && npm run test:main && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license","test:resources":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/resources/**/*.js' --config '../unitTests/.mocharc.json'","test:bin":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/bin/**/*.js' --config '../unitTests/.mocharc.json'","test:main":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --config '../unitTests/.mocharc-main.json'","test:lmdbbridge":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --config '../unitTests/.mocharc.json'","test:lmdbutility":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --config '../unitTests/.mocharc.json'","test:hdbserver":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --config '../unitTests/.mocharc.json'","test:cfserver":"npm run submodules && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/fastifyRoutes/customFunctionsServer-test.js' --config '../unitTests/.mocharc.json'","test:nats":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json'","test:upgrade":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --config '../unitTests/.mocharc.json'","test:apitests":"pm2 kill && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/apiTests/**/*-test.mjs' --config '../unitTests/.mocharc.json'","test:logging":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/logging/*.js' --config '../unitTests/.mocharc.json'","test:ci":" cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --retries 3 --config '../unitTests/.mocharc-main.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/customFunctions/customFunctionsServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter","hdb-check":"./utility/devops/hdb-check.sh","download-prebuilds":"node ./utility/devops/build/download-prebuilds.js",prebuild:"date",postinstall:"node ./launchServiceScripts/launchInstallNATSServer.js",build_nats_dependency:"node ./utility/devops/nats/builder.js",coverage:"nyc --reporter=lcov npm test"},dependencies:{"@aws-sdk/client-s3":"3.635.0","@aws-sdk/lib-storage":"3.635.0","@endo/static-module-record":"^1.0.4","@fastify/autoload":"5.7.1","@fastify/compress":"~6.5.0","@fastify/cors":"~8.5.0","@fastify/static":"~6.12.0","@turf/area":"6.5.0","@turf/boolean-contains":"6.5.0","@turf/boolean-disjoint":"6.5.0","@turf/boolean-equal":"6.5.0","@turf/circle":"6.5.0","@turf/difference":"6.5.0","@turf/distance":"6.5.0","@turf/helpers":"6.5.0","@turf/length":"6.5.0",alasql:"4.1.10","cbor-x":"1.5.8",chalk:"4.1.2","cli-progress":"3.12.0",clone:"2.1.2","fast-glob":"3.3.2",fastify:"~4.26.2","fastify-plugin":"~4.5.1","fs-extra":"11.2.0",graphql:"^16.8.1","human-readable-ids":"1.0.4",inquirer:"8.2.6","is-number":"7.0.0",joi:"17.12.2","json-bigint-fixes":"1.1.0",json2csv:"5.0.7",jsonata:"1.8.7",jsonwebtoken:"9.0.2",lmdb:"3.2.0",lodash:"4.17.21",mathjs:"11.12.0",minimist:"1.2.8",mkcert:"1.5.1",moment:"2.30.1","mqtt-packet":"~8.2.1",msgpackr:"1.11.2",nats:"2.19.0",needle:"3.3.1","node-stream-zip":"1.15.0","node-unix-socket":"0.2.5","normalize-path":"^3.0.0",ora:"5.4.1","ordered-binary":"1.5.3",papaparse:"5.4.1",passport:"0.6.0","passport-http":"0.3.0","passport-local":"1.0.0",pino:"8.16.0",pm2:"5.4.1",prompt:"1.3.0","properties-reader":"2.3.0","recursive-iterator":"3.3.0",semver:"7.5.4",send:"^0.18.0","serve-static":"1.15.0",ses:"1.1.0","stream-chain":"2.2.5","stream-json":"1.8.0",systeminformation:"5.22.9","tar-fs":"2.1.1",ulidx:"0.5.0",uuid:"9.0.1","validate.js":"0.13.1",ws:"8.17.1",yaml:"2.4.1"},devDependencies:{"@tsconfig/node16":"^1.0.3","@types/node":"latest","@typescript-eslint/eslint-plugin":"^5.55.0","@typescript-eslint/parser":"^5.55.0",axios:"1.6.8",chai:"4.4.1","chai-integer":"0.1.0",esbuild:"^0.20.2",eslint:"8.22.0","eslint-config-prettier":"8.3.0","eslint-plugin-prettier":"3.4.1","eslint-plugin-radar":"0.2.1",eventsource:"^2.0.2","hook-std":"3.0.0","intercept-stdout":"0.1.2",mocha:"^10.3.0","mocha-teamcity-reporter":"3.0.0","mock-require":"3.0.3","mock-stdin":"1.0.0",mqtt:"~4.3.8",newman:"5.3.2","newman-reporter-html":"1.0.5","newman-reporter-htmlextra":"1.22.11","newman-reporter-teamcity":"0.1.12","node-fetch":"2.6.7",nyc:"15.1.0",prettier:"2.8.4",rewire:"5.0.0",rimraf:"3.0.2",sinon:"10.0.0","sinon-chai":"3.7.0","source-map-support":"^0.5.21",typescript:"^5.4.2","why-is-node-still-running":"^1.0.0"},overrides:{"eslint-plugin-radar":{eslint:"8.22.0"},alasql:{xlsx:"0.18.5"}},optionalDependencies:{bufferutil:"^4.0.7","utf-8-validate":"^5.0.10"}}});var Pd=g((Xde,AL)=>{"use strict";AL.exports={version:jX,printVersion:ZX};var Md=ml();function jX(){if(Md)return Md.version}a(jX,"version");function ZX(){Md&&console.log(`HarperDB Version ${Md.version}`)}a(ZX,"printVersion")});var Is=g((tfe,NL)=>{"use strict";var ej=un(),iT=J(),tj=require("util"),oo=P(),OL=ne();OL.initSync();var rj=FS(),bL=Fr(),{Node:Zde,NodeSubscription:efe}=Ea(),nj=na(),sj=lL(),{RemotePayloadObject:ij,RemotePayloadSubscription:oj}=hl(),{handleHDBError:aj,hdb_errors:cj}=se(),{HTTP_STATUS_CODES:lj,HDB_ERROR_MSGS:uj}=cj,_j=rs(),dj=ha(),fj=Pd(),{getDatabases:Ej}=(Ae(),ie(ke)),hj=tj.promisify(rj.authorize),mj=bL.searchByHash,pj=bL.searchByValue;NL.exports={authHeaderToUser:Sj,isEmpty:Tj,getNodeRecord:gj,upsertNodeRecord:Rj,buildNodePayloads:Aj,checkClusteringEnabled:Oj,getAllNodeRecords:bj,getSystemInfo:yj,reverseSubscription:yL};async function Sj(e){let t={headers:{authorization:e.hdb_auth_header}};return e.hdb_user=await hj(t,null),e}a(Sj,"authHeaderToUser");function Tj(e){return e==null}a(Tj,"isEmpty");async function gj(e){let t=new nj(oo.SYSTEM_SCHEMA_NAME,oo.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return mj(t)}a(gj,"getNodeRecord");async function Rj(e){let t=new sj(oo.SYSTEM_SCHEMA_NAME,oo.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return ej.upsert(t)}a(Rj,"upsertNodeRecord");function yL(e){if(iT.isEmpty(e.subscribe)||iT.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(yL,"reverseSubscription");function Aj(e,t,r,n){let s=[];for(let i=0,o=e.length;i<o;i++){let c=e[i],{schema:l,table:_}=c,u=iT.getTableHashAttribute(l,_),{subscribe:d,publish:E}=yL(c),f=Ej()[l]?.[_],h=new oj(l,_,u,E,d,c.start_time,f.schemaDefined?f.attributes:void 0);s.push(h)}return new ij(r,t,s,n)}a(Aj,"buildNodePayloads");function Oj(){if(!OL.get(oo.CONFIG_PARAMS.CLUSTERING_ENABLED))throw aj(new Error,uj.CLUSTERING_NOT_ENABLED,lj.BAD_REQUEST,void 0,void 0,!0)}a(Oj,"checkClusteringEnabled");async function bj(){let e=new _j(oo.SYSTEM_SCHEMA_NAME,oo.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await pj(e))}a(bj,"getAllNodeRecords");async function yj(){let e=await dj.getSystemInformation();return{hdb_version:fj.version(),node_version:e.node_version,platform:e.platform}}a(yj,"getSystemInfo")});var oT=g((nfe,UL)=>{"use strict";var Ud=wt(),IL=J(),wL=ct(),CL=P(),vd=K(),DL=Rd(),Nj=xp(),{RemotePayloadObject:Ij}=hl(),{handleHDBError:LL,hdb_errors:wj}=se(),{HTTP_STATUS_CODES:ML}=wj,{NodeSubscription:PL}=Ea();UL.exports=Cj;async function Cj(e,t){let r;try{r=await Ud.request(`${t}.${wL.REQUEST_SUFFIX}`,new Ij(CL.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),vd.trace("Response from remote describe all request:",r)}catch(o){vd.error(`addNode received error from describe all request to remote node: ${o}`);let c=Ud.requestErrorHandler(o,"add_node",t);throw LL(new Error,c,ML.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===wL.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let o=`Error returned from remote node ${t}: ${r.message}`;throw LL(new Error,o,ML.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===CL.SYSTEM_SCHEMA_NAME){await Ud.createLocalTableStream(l,c);let h=new PL(l,c,o.publish,o.subscribe);h.start_time=o.start_time,i.push(h);continue}let _=IL.doesSchemaExist(l),u=n[l]!==void 0,d=c?IL.doesTableExist(l,c):!0,E=c?n?.[l]?.[c]!==void 0:!0;if(!_&&!u||!d&&!E){s.push(o);continue}if(!_&&u&&(vd.trace(`addNode creating schema: ${l}`),await DL.createSchema({operation:"create_schema",schema:l})),!d&&E){vd.trace(`addNode creating table: ${c} in schema: ${l} with attributes ${JSON.stringify(n[l][c].attributes)}`);let h=new Nj(l,c,n[l][c].hash_attribute);n[l][c].attributes&&(h.attributes=n[l][c].attributes),await DL.createTable(h)}await Ud.createLocalTableStream(l,c);let f=new PL(l,c,o.publish,o.subscribe);f.start_time=o.start_time,i.push(f)}return{added:i,skipped:s}}a(Cj,"reviewSubscriptions")});var Gd=g((ife,HL)=>{"use strict";var{handleHDBError:Bd,hdb_errors:Dj}=se(),{HTTP_STATUS_CODES:Hd}=Dj,{addUpdateNodeValidator:Lj}=Nd(),xd=K(),BL=P(),vL=ct(),Mj=J(),pl=wt(),Sl=Is(),Pj=ne(),Uj=oT(),{Node:vj,NodeSubscription:Bj}=Ea(),{broadcast:Hj}=it(),xj="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",Gj="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",Fj=Pj.get(BL.CONFIG_PARAMS.CLUSTERING_NODENAME);HL.exports=qj;async function qj(e,t=!1){xd.trace("addNode called with:",e),Sl.checkClusteringEnabled();let r=Lj(e);if(r)throw Bd(r,r.message,Hd.BAD_REQUEST,void 0,void 0,!0);let n=e.node_name;if(!t){let d=await Sl.getNodeRecord(n);if(!Mj.isEmptyOrZeroLength(d))throw Bd(new Error,`Node '${n}' has already been added, perform update_node to proceed.`,Hd.BAD_REQUEST,void 0,void 0,!0)}let{added:s,skipped:i}=await Uj(e.subscriptions,n),o={message:void 0,added:s,skipped:i};if(s.length===0)return o.message=xj,o;let c=Sl.buildNodePayloads(s,Fj,BL.OPERATIONS_ENUM.ADD_NODE,await Sl.getSystemInfo()),l=[];for(let d=0,E=s.length;d<E;d++){let f=s[d];s[d].start_time===void 0&&delete s[d].start_time,l.push(new Bj(f.schema,f.table,f.publish,f.subscribe))}xd.trace("addNode sending remote payload:",c);let _;try{_=await pl.request(`${n}.${vL.REQUEST_SUFFIX}`,c)}catch(d){xd.error(`addNode received error from request: ${d}`);for(let f=0,h=s.length;f<h;f++){let p=s[f];p.publish=!1,p.subscribe=!1,await pl.updateRemoteConsumer(p,n)}let E=pl.requestErrorHandler(d,"add_node",n);throw Bd(new Error,E,Hd.INTERNAL_SERVER_ERROR,"error",E)}if(_.status===vL.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let d=`Error returned from remote node ${n}: ${_.message}`;throw Bd(new Error,d,Hd.INTERNAL_SERVER_ERROR,"error",d)}xd.trace(_);for(let d=0,E=s.length;d<E;d++){let f=s[d];await pl.updateRemoteConsumer(f,n),f.subscribe===!0&&await pl.updateConsumerIterator(f.schema,f.table,n,"start")}let u=new vj(n,l,_.system_info);return await Sl.upsertNodeRecord(u),Hj({type:"nats_update"}),i.length>0?o.message=Gj:o.message=`Successfully added '${n}' to manifest`,o}a(qj,"addNode")});var lT=g((cfe,FL)=>{"use strict";var{handleHDBError:aT,hdb_errors:kj}=se(),{HTTP_STATUS_CODES:cT}=kj,{addUpdateNodeValidator:Vj}=Nd(),Tl=K(),GL=P(),xL=ct(),afe=J(),gl=wt(),Rl=Is(),$j=ne(),{cloneDeep:Yj}=require("lodash"),Kj=oT(),{Node:Wj,NodeSubscription:Qj}=Ea(),{broadcast:zj}=it(),Jj="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",Xj="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",jj=$j.get(GL.CONFIG_PARAMS.CLUSTERING_NODENAME);FL.exports=Zj;async function Zj(e){Tl.trace("updateNode called with:",e),Rl.checkClusteringEnabled();let t=Vj(e);if(t)throw aT(t,t.message,cT.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await Rl.getNodeRecord(r);s.length>0&&(n=Yj(s));let{added:i,skipped:o}=await Kj(e.subscriptions,r),c={message:void 0,updated:i,skipped:o};if(i.length===0)return c.message=Jj,c;let l=Rl.buildNodePayloads(i,jj,GL.OPERATIONS_ENUM.UPDATE_NODE,await Rl.getSystemInfo());for(let u=0,d=i.length;u<d;u++){let E=i[u];Tl.trace(`updateNode updating work stream for node: ${r} subscription:`,E),i[u].start_time===void 0&&delete i[u].start_time}Tl.trace("updateNode sending remote payload:",l);let _;try{_=await gl.request(`${r}.${xL.REQUEST_SUFFIX}`,l)}catch(u){Tl.error(`updateNode received error from request: ${u}`);let d=gl.requestErrorHandler(u,"update_node",r);throw aT(new Error,d,cT.INTERNAL_SERVER_ERROR,"error",d)}if(_.status===xL.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let u=`Error returned from remote node ${r}: ${_.message}`;throw aT(new Error,u,cT.INTERNAL_SERVER_ERROR,"error",u)}Tl.trace(_);for(let u=0,d=i.length;u<d;u++){let E=i[u];await gl.updateRemoteConsumer(E,r),E.subscribe===!0?await gl.updateConsumerIterator(E.schema,E.table,r,"start"):await gl.updateConsumerIterator(E.schema,E.table,r,"stop")}return n||(n=[new Wj(r,[],_.system_info)]),await eZ(n[0],i,_.system_info),o.length>0?c.message=Xj:c.message=`Successfully updated '${r}'`,c}a(Zj,"updateNode");async function eZ(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,_=e.subscriptions.length;l<_;l++){let u=n.subscriptions[l];if(u.schema===o.schema&&u.table===o.table){u.publish=o.publish,u.subscribe=o.subscribe,c=!0;break}}c||n.subscriptions.push(new Qj(o.schema,o.table,o.publish,o.subscribe))}n.system_info=r,await Rl.upsertNodeRecord(n),zj({type:"nats_update"})}a(eZ,"updateNodeTable")});var YL=g((ufe,$L)=>{"use strict";var VL=require("joi"),{string:qL}=VL.types(),tZ=at(),kL=P(),rZ=ne(),nZ=ct();$L.exports=sZ;function sZ(e){let t=qL.invalid(rZ.get(kL.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(nZ.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=VL.object({operation:qL.valid(kL.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return tZ.validateBySchema(e,r)}a(sZ,"removeNodeValidator")});var qd=g((dfe,JL)=>{"use strict";var{handleHDBError:KL,hdb_errors:iZ}=se(),{HTTP_STATUS_CODES:WL}=iZ,oZ=YL(),Al=K(),QL=Is(),aZ=J(),Fd=P(),zL=ct(),uT=wt(),cZ=ne(),{RemotePayloadObject:lZ}=hl(),{NodeSubscription:uZ}=Ea(),_Z=tl(),dZ=Ki(),{broadcast:fZ}=it(),EZ=cZ.get(Fd.CONFIG_PARAMS.CLUSTERING_NODENAME);JL.exports=hZ;async function hZ(e){Al.trace("removeNode called with:",e),QL.checkClusteringEnabled();let t=oZ(e);if(t)throw KL(t,t.message,WL.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await QL.getNodeRecord(r);if(aZ.isEmptyOrZeroLength(n))throw KL(new Error,`Node '${r}' was not found.`,WL.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new lZ(Fd.OPERATIONS_ENUM.REMOVE_NODE,EZ,[]),i,o=!1;for(let l=0,_=n.subscriptions.length;l<_;l++){let u=n.subscriptions[l];u.subscribe===!0&&await uT.updateConsumerIterator(u.schema,u.table,r,"stop");try{await uT.updateRemoteConsumer(new uZ(u.schema,u.table,!1,!1),r)}catch(d){Al.error(d)}}try{i=await uT.request(`${r}.${zL.REQUEST_SUFFIX}`,s),Al.trace("Remove node reply from remote node:",r,i)}catch(l){Al.error("removeNode received error from request:",l),o=!0}let c=new _Z(Fd.SYSTEM_SCHEMA_NAME,Fd.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await dZ.deleteRecord(c),fZ({type:"nats_update"}),i?.status===zL.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||o?(Al.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(hZ,"removeNode")});var ZL=g((Efe,jL)=>{"use strict";var XL=require("joi"),{string:mZ,array:pZ}=XL.types(),SZ=at(),TZ=Nd();jL.exports=gZ;function gZ(e){let t=XL.object({operation:mZ.valid("configure_cluster").required(),connections:pZ.items(TZ.validation_schema).required()});return SZ.validateBySchema(e,t)}a(gZ,"configureClusterValidator")});var _T=g((mfe,sM)=>{"use strict";var RZ=P(),kd=K(),AZ=J(),OZ=qd(),bZ=Gd(),eM=Is(),yZ=ZL(),{handleHDBError:tM,hdb_errors:NZ}=se(),{HTTP_STATUS_CODES:rM}=NZ,IZ="Configure cluster complete.",wZ="Failed to configure the cluster. Check the logs for more details.",CZ="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";sM.exports=DZ;async function DZ(e){kd.trace("configure cluster called with:",e),eM.checkClusteringEnabled();let t=yZ(e);if(t)throw tM(t,t.message,rM.BAD_REQUEST,void 0,void 0,!0);let r=await eM.getAllNodeRecords(),n=[];for(let u=0,d=r.length;u<d;u++){let E=await nM(OZ,{operation:RZ.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[u].name},r[u].name);n.push(E)}kd.trace("All results from configure_cluster remove node:",n);let s=[],i=e.connections.length;for(let u=0;u<i;u++){let d=e.connections[u],E=await nM(bZ,d,d.node_name);s.push(E)}kd.trace("All results from configure_cluster add node:",s);let o=[],c=[],l=!1,_=n.concat(s);for(let u=0,d=_.length;u<d;u++){let E=_[u];E.status==="rejected"&&(kd.error(E),o.includes(E.node_name)||o.push(E.node_name)),(E?.result?.message?.includes?.("Successfully")||E?.result?.includes?.("Successfully"))&&(l=!0),!(typeof E.result=="string"&&E.result.includes("Successfully removed")||E.status==="rejected")&&c.push({node_name:E?.node_name,subscriptions:E?.result})}if(AZ.isEmptyOrZeroLength(o))return{message:IZ,connections:c};if(l)return{message:CZ,failed_nodes:o,connections:c};throw tM(new Error,wZ,rM.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(DZ,"configureCluster");async function nM(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){return{node_name:r,error:n,status:"rejected"}}}a(nM,"functionWrapper")});var cM=g((Sfe,aM)=>{"use strict";var Ol=require("joi"),LZ=at(),{validateSchemaExists:iM,validateTableExists:MZ,validateSchemaName:oM}=Xn(),PZ=Ol.object({operation:Ol.string().valid("purge_stream"),schema:Ol.string().custom(iM).custom(oM).optional(),database:Ol.string().custom(iM).custom(oM).optional(),table:Ol.string().custom(MZ).required()});function UZ(e){return LZ.validateBySchema(e,PZ)}a(UZ,"purgeStreamValidator");aM.exports=UZ});var dT=g((gfe,lM)=>{"use strict";var{handleHDBError:vZ,hdb_errors:BZ}=se(),{HTTP_STATUS_CODES:HZ}=BZ,xZ=cM(),GZ=wt(),FZ=Is();lM.exports=qZ;async function qZ(e){e.schema=e.schema??e.database;let t=xZ(e);if(t)throw vZ(t,t.message,HZ.BAD_REQUEST,void 0,void 0,!0);FZ.checkClusteringEnabled();let{schema:r,table:n,options:s}=e;return await GZ.purgeTableStream(r,n,s),`Successfully purged table '${r}.${n}'`}a(qZ,"purgeStream")});var hT=g((Afe,hM)=>{"use strict";var ET=Is(),kZ=wt(),dM=ne(),Vd=P(),ao=ct(),VZ=J(),fT=K(),{RemotePayloadObject:$Z}=hl(),{ErrorCode:uM}=require("nats"),_M=dM.get(Vd.CONFIG_PARAMS.CLUSTERING_ENABLED),fM=dM.get(Vd.CONFIG_PARAMS.CLUSTERING_NODENAME);hM.exports={clusterStatus:YZ,buildNodeStatus:EM};async function YZ(){let e={node_name:fM,is_enabled:_M,connections:[]};if(!_M)return e;let t=await ET.getAllNodeRecords();if(VZ.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(EM(t[n],e.connections));return await Promise.allSettled(r),e}a(YZ,"clusterStatus");async function EM(e,t){let r=e.name,n=new $Z(Vd.OPERATIONS_ENUM.CLUSTER_STATUS,fM,void 0,await ET.getSystemInfo()),s,i,o=ao.CLUSTER_STATUS_STATUSES.OPEN;try{let l=Date.now();s=await kZ.request(ao.REQUEST_SUBJECT(r),n),i=Date.now()-l,s.status===ao.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=ao.CLUSTER_STATUS_STATUSES.CLOSED,fT.error(`Error getting node status from ${r} `,s))}catch(l){fT.warn(`Error getting node status from ${r}`,l),l.code===uM.NoResponders?o=ao.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:l.code===uM.Timeout?o=ao.CLUSTER_STATUS_STATUSES.TIMEOUT:o=ao.CLUSTER_STATUS_STATUSES.CLOSED}let c=new KZ(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!==Vd.PRE_4_0_0_VERSION&&await ET.upsertNodeRecord(l)}catch(l){fT.error("Cluster status encountered an error updating system info for node:",r,l)}t.push(c)}a(EM,"buildNodeStatus");function KZ(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(KZ,"NodeStatusObject")});var pT=g((bfe,mM)=>{"use strict";var{handleHDBError:WZ,hdb_errors:QZ}=se(),{HTTP_STATUS_CODES:zZ}=QZ,JZ=wt(),XZ=Is(),mT=J(),$d=require("joi"),jZ=at(),ZZ=2e3,e5=$d.object({timeout:$d.number().min(1),connected_nodes:$d.boolean(),routes:$d.boolean()});mM.exports=t5;async function t5(e){XZ.checkClusteringEnabled();let t=jZ.validateBySchema(e,e5);if(t)throw WZ(t,t.message,zZ.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||mT.autoCastBoolean(n),o=s===void 0||mT.autoCastBoolean(s),c={nodes:[]},l=await JZ.getServerList(r??ZZ),_={};if(i)for(let u=0,d=l.length;u<d;u++){let E=l[u].statsz;E&&(_[l[u].server.name]=E.routes)}for(let u=0,d=l.length;u<d;u++){if(l[u].statsz)continue;let E=l[u].server,f=l[u].data;if(E.name.endsWith("-hub")){let h={name:E.name.slice(0,-4),response_time:l[u].response_time};i&&(h.connected_nodes=[],_[E.name]&&_[E.name].forEach(p=>{h.connected_nodes.includes(p.name.slice(0,-4))||h.connected_nodes.push(p.name.slice(0,-4))})),o&&(h.routes=f.cluster?.urls?f.cluster?.urls.map(p=>({host:p.split(":")[0],port:mT.autoCast(p.split(":")[1])})):[]),c.nodes.push(h)}}return c}a(t5,"clusterNetwork")});var gM=g((Nfe,TM)=>{"use strict";var ST=require("joi"),pM=at(),{route_constraints:SM}=Jm();TM.exports={setRoutesValidator:r5,deleteRoutesValidator:n5};function r5(e){let t=ST.object({server:ST.valid("hub","leaf").required(),routes:SM.required()});return pM.validateBySchema(e,t)}a(r5,"setRoutesValidator");function n5(e){let t=ST.object({routes:SM.required()});return pM.validateBySchema(e,t)}a(n5,"deleteRoutesValidator")});var gT=g((wfe,bM)=>{"use strict";var co=pr(),TT=J(),Yd=P(),RM=gM(),{handleHDBError:AM,hdb_errors:s5}=se(),{HTTP_STATUS_CODES:OM}=s5,i5="cluster routes successfully set",o5="cluster routes successfully deleted";bM.exports={setRoutes:a5,getRoutes:c5,deleteRoutes:l5};function a5(e){let t=RM.setRoutesValidator(e);if(t)throw AM(t,t.message,OM.BAD_REQUEST,void 0,void 0,!0);let r=co.getClusteringRoutes(),n=e.server==="hub"?r.hub_routes:r.leaf_routes,s=e.server==="hub"?r.leaf_routes:r.hub_routes,i=[],o=[];for(let c=0,l=e.routes.length;c<l;c++){let _=e.routes[c];_.port=TT.autoCast(_.port);let u=n.some(E=>E.host===_.host&&E.port===_.port),d=s.some(E=>E.host===_.host&&E.port===_.port);u||d?i.push(_):(n.push(_),o.push(_))}return e.server==="hub"?co.updateConfigValue(Yd.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,n):co.updateConfigValue(Yd.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n),{message:i5,set:o,skipped:i}}a(a5,"setRoutes");function c5(){let e=co.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}a(c5,"getRoutes");function l5(e){let t=RM.deleteRoutesValidator(e);if(t)throw AM(t,t.message,OM.BAD_REQUEST,void 0,void 0,!0);let r=co.getClusteringRoutes(),n=r.hub_routes,s=r.leaf_routes,i=[],o=[],c=!1,l=!1;for(let _=0,u=e.routes.length;_<u;_++){let d=e.routes[_],E=!1;for(let f=0,h=n.length;f<h;f++){let p=n[f];if(d.host===p.host&&d.port===p.port){n.splice(f,1),E=!0,c=!0,i.push(d);break}}if(!E){let f=!0;for(let h=0,p=s.length;h<p;h++){let S=s[h];if(d.host===S.host&&d.port===S.port){s.splice(h,1),l=!0,f=!1,i.push(d);break}}f&&o.push(d)}}return c&&(n=TT.isEmptyOrZeroLength(n)?null:n,co.updateConfigValue(Yd.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,n)),l&&(s=TT.isEmptyOrZeroLength(s)?null:s,co.updateConfigValue(Yd.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,s)),{message:o5,deleted:i,skipped:o}}a(l5,"deleteRoutes")});var NM=g((Dfe,yM)=>{"use strict";var bl=require("alasql"),lo=require("recursive-iterator"),Bn=K(),u5=J(),yl=P(),RT=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,d5(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=>yl.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=>!yl.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][yl.PERMS_CRUD_ENUM.READ]){let c;t[i].tables[o].attribute_permissions.length>0?c=_5(t[i].tables[o].attribute_permissions):c=global.hdb_schema[i][o].attributes.map(_=>({attribute_name:_.attribute}));let l=this.affected_attributes.get(i).get(o).filter(_=>!yl.SEARCH_WILDCARDS.includes(_));c.forEach(({attribute_name:_})=>{let u=new bl.yy.Column({columnid:_});s.tableid&&(u.tableid=s.tableid),this.ast.columns.push(u),l.includes(_)||l.push(_)}),this.affected_attributes.get(i).set(o,l)}}),this.ast}};function _5(e){return e.filter(t=>t[yl.PERMS_CRUD_ENUM.READ])}a(_5,"filterReadRestrictedAttrs");function d5(e,t,r,n,s){f5(e,t,r,n,s)}a(d5,"interpretAST");function Nl(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(Nl,"addSchemaTableToMap");function f5(e,t,r,n,s){if(!e){Bn.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof bl.yy.Insert?p5(e,t,r):e instanceof bl.yy.Select?E5(e,t,r,n,s):e instanceof bl.yy.Update?h5(e,t,r):e instanceof bl.yy.Delete?m5(e,t,r):Bn.error("AST in getRecordAttributesAST() is not a valid SQL type.")}a(f5,"getRecordAttributesAST");function E5(e,t,r,n,s){if(!e){Bn.info("getSelectAttributes: invalid SQL syntax tree");return}if(!e.from||e.from[0]===void 0)return;let i=e.from[0].databaseid;if(u5.isEmptyOrZeroLength(i)){Bn.error("No schema specified");return}e.from.forEach(c=>{Nl(c,t,r,n,s)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),Nl(c.table,t,r,n,s)});let o=new lo(e.columns);for(let{node:c}of o)if(c&&c.columnid){let l=c.tableid,_=n.has(l)?n.get(l):i;if(l||(l=e.from[0].tableid),!t.get(_).has(l))if(r.has(l))l=r.get(l);else{Bn.info(`table specified as ${l} not found.`);return}t.get(_).get(l).indexOf(c.columnid)<0&&t.get(_).get(l).push(c.columnid)}if(e.where){let c=new lo(e.where),l=e.from[0].tableid;for(let{node:_}of c)if(_&&_.columnid){let u=_.tableid?_.tableid:l;if(!t.get(i).has(u))if(r.has(u))u=r.get(u);else{Bn.info(`table specified as ${u} not found.`);continue}t.get(i).get(u).indexOf(_.columnid)<0&&t.get(i).get(u).push(_.columnid)}}if(e.joins&&e.joins.forEach(c=>{let l=new lo(c.on);for(let{node:_}of l)if(_&&_.columnid){let u=_.tableid,d=s.get(u);if(!t.get(d).has(u))if(r.has(u))u=r.get(u);else{Bn.info(`table specified as ${u} not found.`);continue}t.get(d).get(u).indexOf(_.columnid)<0&&t.get(d).get(u).push(_.columnid)}}),e.order){let c=new lo(e.order);for(let{node:l}of c)if(l&&l.columnid){let _=l.tableid,u=n.has(_)?n.get(_):i;if(_||(_=e.from[0].tableid),!t.get(u).has(_))if(r.has(_))_=r.get(_);else{Bn.info(`table specified as ${_} not found.`);return}t.get(u).get(_).indexOf(l.columnid)<0&&t.get(u).get(_).push(l.columnid)}}}a(E5,"getSelectAttributes");function h5(e,t,r){if(!e){Bn.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new lo(e.columns),s=e.table.databaseid;Nl(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&AT(e.table.tableid,s,i.columnid,t,r)}a(h5,"getUpdateAttributes");function m5(e,t,r){if(!e){Bn.info("getDeleteAttributes: invalid SQL syntax tree");return}let n=new lo(e.where),s=e.table.databaseid;Nl(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&AT(e.table.tableid,s,i.columnid,t,r)}a(m5,"getDeleteAttributes");function p5(e,t,r){if(!e){Bn.info("getInsertAttributes: invalid SQL syntax tree");return}let n=new lo(e.columns),s=e.into.databaseid;Nl(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&AT(e.into.tableid,s,i.columnid,t,r)}a(p5,"getInsertAttributes");function AT(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(AT,"pushAttribute");yM.exports=RT});var yT=g((Mfe,DM)=>{var Kd=Ji(),IM=require("chalk"),Wr=K(),wM=require("prompt"),{promisify:S5}=require("util"),OT=P(),T5=require("fs-extra"),g5=require("path"),R5=J(),A5=Pd(),CM=ne();CM.initSync();var O5=require("moment"),b5=S5(wM.get),y5=g5.join(CM.getHdbBasePath(),OT.LICENSE_KEY_DIR_NAME,OT.LICENSE_FILE_NAME,OT.LICENSE_FILE_NAME);DM.exports={getFingerprint:I5,setLicense:N5,parseLicense:bT,register:w5,getRegistrationInfo:D5};async function N5(e){if(e&&e.key&&e.company){try{Wr.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await bT(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw Wr.error(r),Wr.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}a(N5,"setLicense");async function I5(){let e={};try{e=await Kd.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw Wr.error(r),Wr.error(t),new Error(r)}return e}a(I5,"getFingerprint");async function bT(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");Wr.info("Validating license input...");let r=Kd.validateLicense(e,t);if(Wr.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(Wr.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(Wr.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{Wr.info("writing license to disk"),await T5.writeFile(y5,JSON.stringify({license_key:e,company:t}))}catch(n){throw Wr.error("Failed to write License"),n}return"Registration successful."}a(bT,"parseLicense");async function w5(){let e=await C5();return bT(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(w5,"register");async function C5(){let e=await Kd.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:IM.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:IM.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{wM.start()}catch(n){Wr.error(n)}let r;try{r=await b5(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}a(C5,"promptForRegistration");async function D5(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await Kd.getLicense()}catch(r){throw Wr.error(`There was an error when searching licenses due to: ${r.message}`),r}if(R5.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=A5.version(),e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=O5.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(D5,"getRegistrationInfo")});var MM=g((Ufe,LM)=>{"use strict";var L5=ct(),NT=class{static{a(this,"HubConfigObject")}constructor(t,r,n,s,i,o,c,l,_,u,d,E,f,h){this.port=t,o===null&&(o=void 0),this.server_name=r+L5.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:_,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c}},this.cluster={name:u,port:d,routes:E,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l}},this.accounts={SYS:{users:f},HDB:{users:h}},this.system_account="SYS"}};LM.exports=NT});var vM=g((Bfe,UM)=>{"use strict";var PM=ct(),IT=class{static{a(this,"LeafConfigObject")}constructor(t,r,n,s,i,o,c,l,_,u,d){this.port=t,d===null&&(d=void 0),this.server_name=r+PM.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+PM.SERVER_SUFFIX.LEAF},this.tls={cert_file:_,key_file:u,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"}};UM.exports=IT});var HM=g((xfe,BM)=>{"use strict";var wT=class{static{a(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};BM.exports=wT});var GM=g((Ffe,xM)=>{"use strict";var M5=ct(),CT=class{static{a(this,"SysUserObject")}constructor(t,r){this.user=t+M5.SERVER_SUFFIX.ADMIN,this.password=r}};xM.exports=CT});var MT=g((kfe,kM)=>{"use strict";var ma=require("path"),zd=require("fs-extra"),P5=MM(),U5=vM(),v5=HM(),B5=GM(),DT=_n(),Sa=J(),Nr=pr(),Qd=P(),Il=ct(),{CONFIG_PARAMS:mt}=Qd,Ta=K(),wl=ne(),FM=As(),LT=wt(),pa="clustering",H5=1e4,qM=50;kM.exports={generateNatsConfig:G5,removeNatsConfig:F5,getHubConfigPath:x5};function x5(){let e=wl.get(mt.ROOTPATH);return ma.join(e,pa,Il.NATS_CONFIG_FILES.HUB_SERVER)}a(x5,"getHubConfigPath");async function G5(e=!1,t=void 0){wl.initSync();let r=wl.get(mt.ROOTPATH),n=ma.join(r,pa,Il.PID_FILES.HUB),s=ma.join(r,pa,Il.PID_FILES.LEAF),i=Nr.getConfigFromFile(mt.CLUSTERING_LEAFSERVER_STREAMS_PATH),o=ma.join(r,pa,Il.NATS_CONFIG_FILES.HUB_SERVER),c=ma.join(r,pa,Il.NATS_CONFIG_FILES.LEAF_SERVER),l=Nr.getConfigFromFile(mt.CLUSTERING_TLS_CERTIFICATE),_=Nr.getConfigFromFile(mt.CLUSTERING_TLS_PRIVATEKEY),u=Nr.getConfigFromFile(mt.CLUSTERING_TLS_CERT_AUTH),d=Nr.getConfigFromFile(mt.CLUSTERING_TLS_INSECURE),E=Nr.getConfigFromFile(mt.CLUSTERING_TLS_VERIFY),f=Nr.getConfigFromFile(mt.CLUSTERING_NODENAME),h=Nr.getConfigFromFile(mt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await LT.checkNATSServerInstalled()||Jd("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let p=await DT.listUsers(),S=Nr.getConfigFromFile(mt.CLUSTERING_USER),T=await DT.getClusterUser();(Sa.isEmpty(T)||T.active!==!0)&&Jd(`Invalid cluster user '${S}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await Wd(mt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await Wd(mt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await Wd(mt.CLUSTERING_HUBSERVER_NETWORK_PORT),await Wd(mt.CLUSTERING_LEAFSERVER_NETWORK_PORT));let A=[],b=[];for(let[z,j]of p.entries())j.role?.role===Qd.ROLE_TYPES_ENUM.CLUSTER_USER&&j.active&&(A.push(new B5(j.username,FM.decrypt(j.hash))),b.push(new v5(j.username,FM.decrypt(j.hash))));let I=[],{hub_routes:B}=Nr.getClusteringRoutes();if(!Sa.isEmptyOrZeroLength(B))for(let z of B)I.push(`tls://${T.sys_name_encoded}:${T.uri_encoded_d_hash}@${z.host}:${z.port}`);let U=new P5(Nr.getConfigFromFile(mt.CLUSTERING_HUBSERVER_NETWORK_PORT),f,n,l,_,u,d,E,h,Nr.getConfigFromFile(mt.CLUSTERING_HUBSERVER_CLUSTER_NAME),Nr.getConfigFromFile(mt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),I,A,b);u==null&&(delete U.tls.ca_file,delete U.leafnodes.tls.ca_file),t=Sa.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===Qd.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await zd.writeJson(o,U),Ta.trace(`Hub server config written to ${o}`));let q=`tls://${T.sys_name_encoded}:${T.uri_encoded_d_hash}@0.0.0.0:${h}`,M=`tls://${T.uri_encoded_name}:${T.uri_encoded_d_hash}@0.0.0.0:${h}`,Q=new U5(Nr.getConfigFromFile(mt.CLUSTERING_LEAFSERVER_NETWORK_PORT),f,s,i,[q],[M],A,b,l,_,u,d);u==null&&delete Q.tls.ca_file,(t===void 0||t===Qd.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await zd.writeJson(c,Q),Ta.trace(`Leaf server config written to ${c}`))}a(G5,"generateNatsConfig");async function Wd(e){let t=wl.get(e);return Sa.isEmpty(t)&&Jd(`port undefined for '${e}'`),await Sa.isPortTaken(t)&&Jd(`'${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(Wd,"isPortAvailable");function Jd(e){let t=`Error generating clustering config: ${e}`;Ta.error(t),console.error(t),process.exit(1)}a(Jd,"generateNatsConfigError");async function F5(e){let{port:t,config_file:r}=LT.getServerConfig(e),{username:n,decrypt_hash:s}=await DT.getClusterUser(),i=0,o=2e3;for(;i<qM;){try{let u=await LT.createConnection(t,n,s,!1);if(u.protocol.connected===!0){u.close();break}}catch(u){Ta.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${u}`)}if(i++,i>=qM)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 _=o*(i*2);_>3e4&&Ta.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await Sa.async_set_timeout(_)}let c="0".repeat(H5),l=ma.join(wl.get(mt.ROOTPATH),pa,r);await zd.writeFile(l,c),await zd.remove(l),Ta.notify(e,"started.")}a(F5,"removeNatsConfig")});var QM=g(($fe,WM)=>{"use strict";var Qr=ne(),q5=Ji(),pe=P(),Cl=ct(),ws=require("path"),{PACKAGE_ROOT:jd}=P(),VM=ne(),Xd=J(),ga="/dev/null",k5=ws.join(jd,"launchServiceScripts"),$M=ws.join(jd,"utility/scripts"),V5=ws.join($M,pe.HDB_RESTART_SCRIPT),YM=ws.resolve(jd,"dependencies",`${process.platform}-${process.arch}`,Cl.NATS_BINARY_NAME);function KM(){let t=q5.licenseSearch().ram_allocation||pe.RAM_ALLOCATION_ENUM.DEFAULT,r=pe.MEM_SETTING_KEY+t,n={[pe.PROCESS_NAME_ENV_PROP]:pe.PROCESS_DESCRIPTORS.HDB,IS_SCRIPTED_SERVICE:!0};return Xd.noBootFile()&&(n[pe.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Xd.getEnvCliRootPath()),{name:pe.PROCESS_DESCRIPTORS.HDB,script:pe.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:n,node_args:r,cwd:jd}}a(KM,"generateMainServerConfig");var $5=9930;function Y5(){Qr.initSync(!0);let e=Qr.get(pe.CONFIG_PARAMS.ROOTPATH),t=ws.join(e,"clustering",Cl.NATS_CONFIG_FILES.HUB_SERVER),r=ws.join(Qr.get(pe.HDB_SETTINGS_NAMES.LOG_PATH_KEY),pe.LOG_NAMES.HDB),n=VM.get(pe.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=Cl.LOG_LEVEL_FLAGS[Qr.get(pe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:pe.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==$5?"-"+n:""),script:YM,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[pe.PROCESS_NAME_ENV_PROP]:pe.PROCESS_DESCRIPTORS.CLUSTERING_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return Qr.get(pe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=ga,i.error_file=ga),i}a(Y5,"generateNatsHubServerConfig");var K5=9940;function W5(){Qr.initSync(!0);let e=Qr.get(pe.CONFIG_PARAMS.ROOTPATH),t=ws.join(e,"clustering",Cl.NATS_CONFIG_FILES.LEAF_SERVER),r=ws.join(Qr.get(pe.HDB_SETTINGS_NAMES.LOG_PATH_KEY),pe.LOG_NAMES.HDB),n=VM.get(pe.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=Cl.LOG_LEVEL_FLAGS[Qr.get(pe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:pe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==K5?"-"+n:""),script:YM,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[pe.PROCESS_NAME_ENV_PROP]:pe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF},merge_logs:!0,out_file:r,error_file:r,instances:1};return Qr.get(pe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=ga,i.error_file=ga),i}a(W5,"generateNatsLeafServerConfig");function Q5(){Qr.initSync();let e=ws.join(Qr.get(pe.CONFIG_PARAMS.LOGGING_ROOT),pe.LOG_NAMES.HDB),t={name:pe.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,script:pe.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[pe.PROCESS_NAME_ENV_PROP]:pe.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:k5,autorestart:!1};return Qr.get(pe.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=ga,t.error_file=ga),t}a(Q5,"generateClusteringUpgradeV4ServiceConfig");function z5(){let e={[pe.PROCESS_NAME_ENV_PROP]:pe.PROCESS_DESCRIPTORS.RESTART_HDB};return Xd.noBootFile()&&(e[pe.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Xd.getEnvCliRootPath()),{...{name:pe.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:$M},script:V5}}a(z5,"generateRestart");function J5(){return{apps:[KM()]}}a(J5,"generateAllServiceConfigs");WM.exports={generateAllServiceConfigs:J5,generateMainServerConfig:KM,generateRestart:z5,generateNatsHubServerConfig:Y5,generateNatsLeafServerConfig:W5,generateClusteringUpgradeV4ServiceConfig:Q5}});var lP=g((Wfe,cP)=>{"use strict";var ve=P(),X5=J(),Ds=MT(),Zd=wt(),Cs=ct(),pi=QM(),ef=ne(),Si=K(),j5=Is(),{startWorker:zM,onMessageFromWorkers:Z5}=it(),e8=ha(),Kfe=require("util"),t8=require("child_process"),r8=require("fs"),{execFile:n8}=t8,Ie;cP.exports={enterPM2Mode:s8,start:Ti,stop:PT,reload:XM,restart:jM,list:UT,describe:tP,connect:Ls,kill:l8,startAllServices:u8,startService:vT,getUniqueServicesList:rP,restartAllServices:_8,isServiceRegistered:nP,reloadStopStart:sP,restartHdb:eP,deleteProcess:a8,startClusteringProcesses:oP,startClusteringThreads:aP,isHdbRestartRunning:c8,isClusteringRunning:f8,stopClustering:d8,reloadClustering:E8,expectedRestartOfChildren:ZM};var Dl=!1;Z5(e=>{e.type==="restart"&&ef.initSync(!0)});function s8(){Dl=!0}a(s8,"enterPM2Mode");function Ls(){return Ie||(Ie=require("pm2")),new Promise((e,t)=>{Ie.connect((r,n)=>{Si.setupConsoleLogging(),r&&t(r),e(n)})})}a(Ls,"connect");var sr,i8=10,JM;function Ti(e,t=!1){if(Dl)return o8(e);let r=n8(e.script,e.args.split(" "),e);r.name=e.name,r.config=e,r.on("exit",async i=>{let o=sr.indexOf(r);o>-1&&sr.splice(o,1),!JM&&i!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<i8&&(r8.existsSync(Ds.getHubConfigPath())?Ti(e):(await Ds.generateNatsConfig(!0),Ti(e),await new Promise(c=>setTimeout(c,3e3)),await Ds.removeNatsConfig(ve.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await Ds.removeNatsConfig(ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let n={serviceName:e.name.replace(/ /g,"-")};function s(i){let o=ef.get(ve.CONFIG_PARAMS.CLUSTERING_LOGLEVEL),c=/\[\d+][^\[]+\[(\w+)]/g,l,_=0,u;for(;l=c.exec(i);){if(l.index&&Cs.LOG_LEVEL_HIERARCHY[o]>=Cs.LOG_LEVEL_HIERARCHY[u||"info"]){let f=u===Cs.LOG_LEVELS.ERR||u===Cs.LOG_LEVELS.WRN?Si.OUTPUTS.STDERR:Si.OUTPUTS.STDOUT;Si.logCustomLevel(u||"info",f,n,i.slice(_,l.index).trim())}let[d,E]=l;_=l.index+d.length,u=Cs.LOG_LEVELS[E]}if(Cs.LOG_LEVEL_HIERARCHY[o]>=Cs.LOG_LEVEL_HIERARCHY[u||"info"]){let d=u===Cs.LOG_LEVELS.ERR||u===Cs.LOG_LEVELS.WRN?Si.OUTPUTS.STDERR:Si.OUTPUTS.STDOUT;Si.logCustomLevel(u||"info",d,n,i.slice(_).trim())}}if(a(s,"extractMessages"),r.stdout.on("data",s),r.stderr.on("data",s),r.unref(),!sr&&(sr=[],!t)){let i=a(()=>{JM=!0,sr&&(sr.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)}sr.push(r)}a(Ti,"start");function o8(e){return new Promise(async(t,r)=>{try{await Ls()}catch(n){r(n)}Ie.start(e,(n,s)=>{n&&(Ie.disconnect(),r(n)),Ie.disconnect(),t(s)})})}a(o8,"startWithPM2");function PT(e){if(!Dl){for(let t of sr||[])t.name===e&&(sr.splice(sr.indexOf(t),1),t.kill());return}return new Promise(async(t,r)=>{try{await Ls()}catch(n){r(n)}Ie.stop(e,async(n,s)=>{n&&(Ie.disconnect(),r(n)),Ie.delete(e,(i,o)=>{i&&(Ie.disconnect(),r(n)),Ie.disconnect(),t(o)})})})}a(PT,"stop");function XM(e){return new Promise(async(t,r)=>{try{await Ls()}catch(n){r(n)}Ie.reload(e,(n,s)=>{n&&(Ie.disconnect(),r(n)),Ie.disconnect(),t(s)})})}a(XM,"reload");function jM(e){if(!Dl){ZM();for(let t of sr||[])t.name===e&&t.kill()}return new Promise(async(t,r)=>{try{await Ls()}catch(n){r(n)}Ie.restart(e,(n,s)=>{Ie.disconnect(),t(s)})})}a(jM,"restart");function ZM(){for(let e of sr||[])e.config&&(e.config.restarts=0)}a(ZM,"expectedRestartOfChildren");function a8(e){return new Promise(async(t,r)=>{try{await Ls()}catch(n){r(n)}Ie.delete(e,(n,s)=>{n&&(Ie.disconnect(),r(n)),Ie.disconnect(),t(s)})})}a(a8,"deleteProcess");async function eP(){await Ti(pi.generateRestart())}a(eP,"restartHdb");async function c8(){let e=await UT();for(let t in e)if(e[t].name===ve.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}a(c8,"isHdbRestartRunning");function UT(){return new Promise(async(e,t)=>{try{await Ls()}catch(r){t(r)}Ie.list((r,n)=>{r&&(Ie.disconnect(),t(r)),Ie.disconnect(),e(n)})})}a(UT,"list");function tP(e){return new Promise(async(t,r)=>{try{await Ls()}catch(n){r(n)}Ie.describe(e,(n,s)=>{n&&(Ie.disconnect(),r(n)),Ie.disconnect(),t(s)})})}a(tP,"describe");function l8(){if(!Dl){for(let e of sr||[])e.kill();sr=[];return}return new Promise(async(e,t)=>{try{await Ls()}catch(r){t(r)}Ie.killDaemon((r,n)=>{r&&(Ie.disconnect(),t(r)),Ie.disconnect(),e(n)})})}a(l8,"kill");async function u8(){try{await oP(),await aP(),await Ti(pi.generateAllServiceConfigs())}catch(e){throw Ie?.disconnect(),e}}a(u8,"startAllServices");async function vT(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case ve.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=pi.generateMainServerConfig();break;case ve.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=pi.generateNatsIngestServiceConfig();break;case ve.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=pi.generateNatsReplyServiceConfig();break;case ve.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=pi.generateNatsHubServerConfig(),await Ti(r,t),await Ds.removeNatsConfig(e);return;case ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=pi.generateNatsLeafServerConfig(),await Ti(r,t),await Ds.removeNatsConfig(e);return;case ve.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=pi.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await Ti(r)}catch(r){throw Ie?.disconnect(),r}}a(vT,"startService");async function rP(){try{let e=await UT(),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 Ie?.disconnect(),e}}a(rP,"getUniqueServicesList");async function _8(e=[]){try{let t=!1,r=await rP();for(let n=0,s=Object.values(r).length;n<s;n++){let o=Object.values(r)[n].name;e.includes(o)||(o===ve.PROCESS_DESCRIPTORS.HDB?t=!0:await jM(o))}t&&await sP(ve.PROCESS_DESCRIPTORS.HDB)}catch(t){throw Ie?.disconnect(),t}}a(_8,"restartAllServices");async function nP(e){if(sr?.find(r=>r.name===e))return!0;let t=await e8.getHDBProcessInfo();return t.core.length&&t.core[0]?.parent==="PM2"}a(nP,"isServiceRegistered");async function sP(e){let t=ef.get(ve.CONFIG_PARAMS.THREADS_COUNT)??ef.get(ve.CONFIG_PARAMS.THREADS),r=await tP(e),n=X5.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await PT(e),await vT(e)):e===ve.PROCESS_DESCRIPTORS.HDB?await eP():await XM(e)}a(sP,"reloadStopStart");var iP;async function oP(e=!1){for(let t in ve.CLUSTERING_PROCESSES){let r=ve.CLUSTERING_PROCESSES[t];await vT(r,e)}}a(oP,"startClusteringProcesses");async function aP(){iP=zM(ve.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,{name:ve.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE});try{await Zd.deleteLocalStream("__HARPERDB_WORK_QUEUE__")}catch{}await Zd.updateLocalStreams();let e=await j5.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===ve.PRE_4_0_0_VERSION){Si.info("Starting clustering upgrade 4.0.0 process"),zM(ve.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}a(aP,"startClusteringThreads");async function d8(){for(let e in ve.CLUSTERING_PROCESSES)if(e!==ve.CLUSTERING_PROCESSES.CLUSTERING_INGEST_PROC_DESCRIPTOR)if(e===ve.CLUSTERING_PROCESSES.CLUSTERING_REPLY_SERVICE_DESCRIPTOR)await iP.terminate();else{let t=ve.CLUSTERING_PROCESSES[e];await PT(t)}}a(d8,"stopClustering");async function f8(){for(let e in ve.CLUSTERING_PROCESSES){let t=ve.CLUSTERING_PROCESSES[e];if(await nP(t)===!1)return!1}return!0}a(f8,"isClusteringRunning");async function E8(){await Ds.generateNatsConfig(!0),await Zd.reloadNATSHub(),await Zd.reloadNATSLeaf(),await Ds.removeNatsConfig(ve.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await Ds.removeNatsConfig(ve.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}a(E8,"reloadClustering")});var mP={};qe(mP,{compactOnStart:()=>h8,copyDb:()=>hP});async function h8(){Ml.notify("Running compact on start"),console.log("Running compact on start");let e=(0,BT.get)(gi.CONFIG_PARAMS.ROOTPATH),t=new Map,r=Tr();try{for(let n in r){if(n==="system")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,tf.join)(e,"backup",n+".mdb"),o=(0,tf.join)(e,gi.DATABASES_DIR_NAME,n+"-copy.mdb"),c=await uP(n);console.log("Database",n,"before compact has a total record count of",c),t.set(n,{db_path:s,copy_dest:o,backup_dest:i,record_count:c}),await hP(n,o),console.log("Backing up",n,"to",i),await(0,uo.move)(s,i,{overwrite:!0})}Ll();for(let[n,{db_path:s,copy_dest:i}]of t)console.log("Moving copy compacted",n,"to",s),await(0,uo.move)(i,s,{overwrite:!0}),await(0,uo.remove)((0,tf.join)(e,gi.DATABASES_DIR_NAME,`${n}-copy.mdb-lock`));Ll()}catch(n){Ml.error("Error compacting database, rolling back operation",n),console.error("Error compacting database, rolling back operation",n),(0,HT.updateConfigValue)(gi.CONFIG_PARAMS.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,uo.move)(o,i,{overwrite:!0})}catch(c){console.error(c)}}throw Ll(),n}for(let[n,{backup_dest:s,record_count:i}]of t){let o=!0,c=await uP(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}.
10
10
  Total record count before compaction: ${i}, total after: ${c}.
11
11
  Database backup has not been removed and can be found here: ${s}`;Ml.error(l),console.error(l)}(0,BT.get)(gi.CONFIG_PARAMS.STORAGE_COMPACTONSTARTKEEPBACKUP)===!0||o===!1||(console.log("Removing backup",s),await(0,uo.remove)(s))}(0,HT.updateConfigValue)(gi.CONFIG_PARAMS.STORAGE_COMPACTONSTART,!1)}async function uP(e){let t=await(0,EP.describeSchema)({database:e}),r=0;for(let n in t)r+=t[n].record_count;return r}async function hP(e,t){console.log("copyDb start");let r=Tr()[e],n;for(let d in r){n=r[d].primaryStore.rootStore;break}let s=n.dbisDb,i=n.auditStore,o=(0,_P.open)(new dP.default(t)),c=o.openDB(rf.INTERNAL_DBIS_NAME),l,_=0,u=s.useReadTransaction();try{for(let{key:f,value:h}of s.getRange({transaction:u})){let p=h.is_hash_attribute||h.isPrimaryKey,S,T;if(p&&(S=h.compression,T=sf(),T?h.compression=T:delete h.compression,S?.dictionary?.toString()===T?.dictionary?.toString()&&(S=null,T=null)),c.put(f,h),!(p||h.indexed))continue;let A=new fP.default(!p,p);A.encoding="binary",A.compression=S;let b=n.openDB(f,A);b.decoder=null,A.compression=T;let I=o.openDB(f,A);I.encoder=null,console.log("copying",f,"from",e,"to",t),await E(b,I,p,u)}let d=n.openDB(rf.AUDIT_STORE_NAME,nf);console.log("copying audit log"),E(i,d,!1,u);async function E(f,h,p,S){let T=0,A=0;for(let{key:b,value:I,version:B}of f.getRange({start:null,versions:p,transaction:S}))l=h.put(b,I,B),T++,S.openTimer&&(S.openTimer=0),A+=(b?.length||10)+I.length,_++>5e3&&(await l,console.log("copied",T,"entries",A,"bytes"),_=0);console.log("finish copying, copied",T,"entries",A,"bytes")}a(E,"copyDbi"),await l,console.log("copied database "+e+" to "+t)}finally{u.done(),o.close()}}var _P,tf,uo,BT,dP,fP,rf,gi,EP,HT,Ml,pP=Re(()=>{Ae();_P=require("lmdb"),tf=require("path"),uo=require("fs-extra"),BT=x(ne()),dP=x(Uc()),fP=x(Pc()),rf=x(dt()),gi=x(P());ei();EP=x(ni()),HT=x(pr()),Ml=x(K());a(h8,"compactOnStart");a(uP,"getTotalDBRecordCount");a(hP,"copyDb")});var Bl=g((eEe,OP)=>{"use strict";var m8=require("minimist"),{isMainThread:FT,parentPort:xT,threadId:jfe}=require("worker_threads"),et=P(),{PROCESS_DESCRIPTORS_VALIDATE:Pl}=et,os=K(),qT=J(),af=MT(),of=wt(),Zfe=ct(),gP=pr(),Hn=lP(),SP=ha(),{compactOnStart:p8}=(pP(),ie(mP)),S8=Ch(),{restartWorkers:cf,onMessageByType:T8}=it(),{handleHDBError:g8,hdb_errors:R8}=se(),{HTTP_STATUS_CODES:A8}=R8,vl=ne();vl.initSync();var Ul=`Restarting HarperDB. This may take up to ${et.RESTART_TIMEOUT_MS/1e3} seconds.`,O8="Restart is not available from the CLI when running in non-pm2 mode. Either call restart from the API or stop and start HarperDB.",TP="Clustering is not enabled so cannot be restarted",b8="Invalid service",Ra,fn;OP.exports={restart:RP,restartService:kT};FT&&T8(et.ITC_EVENT_TYPES.RESTART,async(e,t)=>{e.workerType?await kT({service:e.workerType}):RP({operation:"restart"}),t.postMessage({type:"restart-complete"})});async function RP(e){fn=Object.keys(e).length===0,Ra=await Hn.isServiceRegistered(et.HDB_PROC_DESCRIPTOR);let t=m8(process.argv);if(t.service){await kT(t);return}if(fn&&!Ra){console.error(O8);return}if(fn&&console.log(Ul),Ra){Hn.enterPM2Mode(),os.notify(Ul);let r=S8(Object.keys(et.CONFIG_PARAM_MAP),!0);return qT.isEmptyOrZeroLength(Object.keys(r))||gP.updateConfigValue(void 0,void 0,r,!0,!0),y8(),Ul}return FT?(os.notify(Ul),vl.get(et.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await p8(),setTimeout(()=>{cf()},50)):xT.postMessage({type:et.ITC_EVENT_TYPES.RESTART}),Ul}a(RP,"restart");async function kT(e){let{service:t}=e;if(et.PROCESS_DESCRIPTORS_VALIDATE[t]===void 0)throw g8(new Error,b8,A8.BAD_REQUEST,void 0,void 0,!0);if(Hn.expectedRestartOfChildren(),Ra=await Hn.isServiceRegistered(et.HDB_PROC_DESCRIPTOR),!FT)return xT.postMessage({type:et.ITC_EVENT_TYPES.RESTART,workerType:t}),new Promise(n=>{xT.on("message",s=>{s.type==="restart-complete"&&n()})});let r;switch(t){case Pl.clustering:if(!vl.get(et.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=TP;break}fn&&console.log("Restarting clustering"),os.notify("Restarting clustering"),await AP();break;case Pl.clustering_config:case Pl["clustering config"]:if(!vl.get(et.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=TP;break}fn&&console.log("Restarting clustering_config"),os.notify("Restarting clustering_config"),await Hn.reloadClustering();break;case"custom_functions":case"custom functions":case Pl.harperdb:case Pl.http_workers:if(fn&&!Ra){r=`Restart ${t} is not available from the CLI when running in non-pm2 mode. Either call restart ${t} from the API or stop and start HarperDB.`;break}fn&&console.log("Restarting http_workers"),os.notify("Restarting http_workers"),fn?await Hn.restart(et.HDB_PROC_DESCRIPTOR):await cf("http");break;default:r=`Unrecognized service: ${t}`;break}return r?(os.error(r),fn&&console.error(r),r):(t==="custom_functions"&&(t="Custom Functions"),`Restarting ${t}`)}a(kT,"restartService");async function y8(){await AP(),await Hn.restart(et.HDB_PROC_DESCRIPTOR),await qT.async_set_timeout(2e3),vl.get(et.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await GT(),fn&&(await of.closeConnection(),process.exit(0))}a(y8,"restartPM2Mode");async function AP(){if(!gP.getConfigFromFile(et.CONFIG_PARAMS.CLUSTERING_ENABLED))return;if((await SP.getHDBProcessInfo()).clustering.length===0)os.trace("Clustering not running, restart will start clustering services"),await af.generateNatsConfig(!0),await Hn.startClusteringProcesses(),await Hn.startClusteringThreads(),await GT(),fn&&await of.closeConnection();else{await af.generateNatsConfig(!0),Ra?(os.trace("Restart clustering restarting PM2 managed Hub and Leaf servers"),await Hn.restart(et.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await Hn.restart(et.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)):(await SP.getHDBProcessInfo()).clustering.forEach(s=>{os.trace("Restart clustering killing process pid",s.pid),process.kill(s.pid)}),await qT.async_set_timeout(3e3),await GT(),await of.updateLocalStreams(),fn&&await of.closeConnection(),os.trace("Restart clustering restarting ingest and reply service threads");let t=cf(et.LAUNCH_SERVICE_SCRIPTS.NATS_INGEST_SERVICE),r=cf(et.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE);await t,await r}}a(AP,"restartClustering");async function GT(){await af.removeNatsConfig(et.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await af.removeNatsConfig(et.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)}a(GT,"removeNatsConfig")});var UP=g((nEe,PP)=>{"use strict";var rEe=require("lodash"),Ir=P(),{handleHDBError:bP,hdb_errors:N8}=se(),{HDB_ERROR_MSGS:I8,HTTP_STATUS_CODES:w8}=N8,VT=K();PP.exports={getRolePermissions:D8};var _o=Object.create(null),C8=a(e=>({key:e,perms:{}}),"perms_template_obj"),wP=a((e=!1)=>({describe:e,tables:{}}),"schema_perms_template"),CP=a((e=!1,t=!1,r=!1,n=!1)=>({[Ir.PERMS_CRUD_ENUM.READ]:e,[Ir.PERMS_CRUD_ENUM.INSERT]:t,[Ir.PERMS_CRUD_ENUM.UPDATE]:r,[Ir.PERMS_CRUD_ENUM.DELETE]:n}),"permissions_template"),$T=a((e=!1,t=!1,r=!1,n=!1,s=!1)=>({attribute_permissions:[],describe:e,...CP(t,r,n,s)}),"table_perms_template"),yP=a((e,t=CP())=>({attribute_name:e,describe:MP(t),[Hl]:t[Hl],[YT]:t[YT],[KT]:t[KT]}),"attr_perms_template"),NP=a((e,t=!1)=>({attribute_name:e,describe:t,[Hl]:t}),"timestamp_attr_perms_template"),{READ:Hl,INSERT:YT,UPDATE:KT}=Ir.PERMS_CRUD_ENUM,DP=Object.values(Ir.PERMS_CRUD_ENUM),LP=[Hl,YT,KT];function D8(e){let t;try{if(e.permission.super_user||e.permission.cluster_user)return e.permission;let r=Object.assign({},global.hdb_schema);delete r[Ir.SYSTEM_SCHEMA_NAME],t=e.role;let n=JSON.stringify([e.__updatedtime__,r]);if(_o[t]&&_o[t].key===n)return _o[t].perms;let s=L8(e,r);return _o[t]?_o[t].key=n:_o[t]=C8(n),_o[t].perms=s,s}catch(r){if(!e[Ir.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]||e[Ir.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]<Ir.PERMS_UPDATE_RELEASE_TIMESTAMP){let n=`Role permissions for role '${t}' must be updated to align with new structure from the 2.2.0 release.`;throw VT.error(n),VT.debug(r),bP(new Error,I8.OUTDATED_PERMS_TRANSLATION_ERROR,w8.BAD_REQUEST)}else{let n=`There was an error while translating role permissions for role: ${t}.
12
12
  ${r.stack}`;throw VT.error(n),bP(new Error)}}}a(D8,"getRolePermissions");function L8(e,t){let r=Object.create(null);r.super_user=!1;let n=e.permission;r[Ir.SYSTEM_SCHEMA_NAME]=n[Ir.SYSTEM_SCHEMA_NAME],r.structure_user=n.structure_user;let s=Array.isArray(e.permission.structure_user)||e.permission.structure_user===!0?e.permission.structure_user:[];return Object.keys(t).forEach(i=>{if(s===!0||s.indexOf(i)>-1){r[i]=M8(t[i]);return}r[i]=wP(),n[i]?(n[i].describe&&(r[i].describe=!0),Object.keys(t[i]).forEach(o=>{if(n[i].tables[o]){let c=n[i].tables[o],l=t[i][o],_=P8(c,l);r[i].describe||DP.forEach(u=>{_[u]&&(r[i].describe=!0)}),r[i].tables[o]=_}else r[i].tables[o]=$T()})):Object.keys(t[i]).forEach(o=>{r[i].tables[o]=$T()})}),r}a(L8,"translateRolePermissions");function M8(e){let t=wP(!0);return Object.keys(e).forEach(r=>{t.tables[r]=$T(!0,!0,!0,!0,!0)}),t}a(M8,"createStructureUserPermissions");function P8(e,t){let{attribute_permissions:r}=e;if(r.length>0){let s=Object.assign({},e);s.attribute_permissions=[];let i=r.reduce((_,u)=>{let{attribute_name:d}=u,E=u;return Ir.TIME_STAMP_NAMES.includes(d)&&(E=NP(d,u[Hl])),_[d]=E,_},{}),o=t.primaryKey||t.hash_attribute,c=!!i[o],l=yP(o);return t.attributes.forEach(({attribute:_})=>{if(i[_]){let u=i[_];u.describe=MP(u),s.attribute_permissions.push(u),c||U8(u,l)}else if(_!==o){let u;Ir.TIME_STAMP_NAMES.includes(_)?u=NP(_):u=yP(_),s.attribute_permissions.push(u)}}),c||s.attribute_permissions.push(l),s.describe=IP(s),s}else return e.describe=IP(e),e}a(P8,"getTableAttrPerms");function IP(e){return DP.filter(t=>e[t]).length>0}a(IP,"getSchemaTableDescribePerm");function MP(e){return LP.filter(t=>e[t]).length>0}a(MP,"getAttributeDescribePerm");function U8(e,t){LP.forEach(r=>{e[r]&&!t[r]&&(t[r]=!0,t.describe=!0)})}a(U8,"checkForHashPerms")});var vP={};qe(vP,{Resources:()=>lf,keyArrayToString:()=>Aa,resetResources:()=>v8,resources:()=>Ri});function v8(){return Ri=new lf}function Aa(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var lf,Ri,xl=Re(()=>{ro();lf=class extends Map{static{a(this,"Resources")}isWorker=!0;loginPath;set(t,r,n,s){if(!r)throw new Error("Must provide a resource");t.startsWith("/")&&(t=t.replace(/^\/+/,""));let i={Resource:r,path:t,type:n,hasSubPaths:!1,relativeURL:""},o=super.get(t);if(o&&(o.Resource.databaseName!==r.databaseName||o.Resource.tableName!==r.tableName)&&!s)throw new Error(`Conflicting paths for ${t}`);super.set(t,i);for(let[c,l]of this){let _=2;for(;(_=c.indexOf("/",_))>-1;){let u=this.get(c.slice(0,_));u&&(u.hasSubPaths=!0),_+=2}}}getMatch(t,r){let n=2,s;for(;(n=t.indexOf("/",n))>-1;){let c=t.slice(0,n),l=this.get(c);if(!l&&c.indexOf(".")>-1){let _=c.split(".");l=this.get(_[0])}if(l){if(l.relativeURL=t.slice(n),!l.hasSubPaths)return l;s=l}n+=2}if(s)return s;let i=t.indexOf("?"),o=i>-1?t.slice(0,i):t;return s=this.get(o),!s&&o.indexOf(".")>-1&&(s=this.get(o.split(".")[0])),s?s.relativeURL=i>-1?t.slice(i):"":s||(s=this.get(""),s&&(t[0]!=="/"&&(t="/"+t),s.relativeURL=t)),s}getResource(t,r){let n=this.getMatch(t);if(n)return t=n.relativeURL,n.Resource.getResource(this.pathToId(t,n.Resource),r)}call(t,r,n){return Ze(r,async()=>{let s=this.getMatch(t);if(s)return t=s.relativeURL,n(s.Resource,s.path,t)})}setRepresentation(t,r,n){}};a(v8,"resetResources");a(Aa,"keyArrayToString")});var BP={};qe(BP,{Headers:()=>Ai,appendHeader:()=>uf});function uf(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}var Ai,Gl=Re(()=>{Ai=class extends Map{static{a(this,"Headers")}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(uf,"appendHeader")});var Fl={};qe(Fl,{authentication:()=>$P,bypassAuth:()=>k8,login:()=>$8,logout:()=>Y8,start:()=>V8});function k8(){VP=!0}async function $P(e,t){let r=e.headers.asObject,n=r.authorization,s=r.cookie,i=r.origin,o=[];try{if(i){let f=e.isOperationsServer?G8?x8:[]:H8?B8:[];if(f.includes(i)||f.includes("*")){if(e.method==="OPTIONS"){let h=new Ai([["Access-Control-Allow-Methods","POST, GET, PUT, DELETE, PATCH, OPTIONS"],["Access-Control-Allow-Headers","Accept, Content-Type, Authorization"],["Access-Control-Allow-Origin",i]]);return _f&&h.set("Access-Control-Allow-Credentials","true"),{status:200,headers:h}}o.push("Access-Control-Allow-Origin",i),_f&&o.push("Access-Control-Allow-Credentials","true")}}let l,_;if(_f){i||(i=r.host);let f=(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session=",h=s?.split(/;\s+/)||[];for(let p of h)if(p.startsWith(f)){let S=p.indexOf(";");l=p.slice(f.length,S===-1?p.length:S),_=await xP.get(l);break}e.session=_||(_={})}let u=a((f,h,p)=>{let S=new Oa.AuthAuditLog(f,h,xt.AUTH_AUDIT_TYPES.AUTHENTICATION,r["x-forwarded-for"]??e.ip,e.method,e.pathname);S.auth_strategy=p,l&&(S.session_id=l),r.referer&&(S.referer=r.referer),r.origin&&(S.origin=r.origin),h===xt.AUTH_AUDIT_STATUS.SUCCESS?HP.notify(S):HP.error(S)},"authAuditLog");if(e.mtlsConfig&&e.authorized){let f=e.mtlsConfig.user;f!==null?((f===void 0||f==="Common Name"||f==="CN")&&(f=e.peerCertificate.subject.CN),e.user=await st.getUser(f,null,null),u(f,xt.AUTH_AUDIT_STATUS.SUCCESS,"mTLS")):(0,Oa.debug)("HTTPS/WSS mTLS authorized connection (mTLS did not authorize a user)","from",e.ip)}let d;if(!e.user)if(n){if(d=fo.get(n),!d){let f=n.indexOf(" "),h=n.slice(0,f),p=n.slice(f+1),S,T;try{switch(h){case"Basic":let A=atob(p),b=A.indexOf(":");S=A.slice(0,b),T=A.slice(b+1),d=S||T?await st.getUser(S,T,e):null;break;case"Bearer":try{d=await(0,df.validateOperationToken)(p)}catch(I){if(I.message==="invalid token")try{return await(0,df.validateRefreshToken)(p),c({status:-1})}catch{throw I}}break}}catch(A){return q8&&(fo.get(p)||(fo.set(p,p),u(S,xt.AUTH_AUDIT_STATUS.FAILURE,h))),c({status:401,body:Eo({error:A.message},e)})}fo.set(n,d),F8&&u(d.username,xt.AUTH_AUDIT_STATUS.SUCCESS,h)}e.user=d}else _?.user?e.user=await st.getUser(_.user,null,e):(VP&&(e.ip?.includes("127.0.0.1")||e.ip=="::1")||e?._nodeRequest?.socket?.server?._pipeName&&e.ip===void 0)&&(e.user=await(0,FP.getSuperUser)());_f&&(e.session.update=function(f){if(!l){l=(0,qP.v4)();let p=`${(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session="}${l}; Path=/; Expires=Tue, 01 Oct 8307 19:33:20 GMT; HttpOnly${e.protocol==="https"?"; SameSite=None; Secure":""}`;o?o.push("Set-Cookie",p):E?.headers?.set&&E.headers.set("Set-Cookie",p)}return e.protocol==="https"&&(o?(i&&o.push("Access-Control-Expose-Headers","X-Hdb-Session"),o.push("X-Hdb-Session","Secure")):E?.headers?.set&&(i&&E.headers.set("Access-Control-Expose-Headers","X-Hdb-Session"),E.headers.set("X-Hdb-Session","Secure"))),f.id=l,xP.put(f)},e.login=async function(f,h){e.user=await st.getUser(f,h,e),e.session.update({user:e.user.username})});let E=await t(e);return E&&(E.status===401&&(r["user-agent"]?.startsWith("Mozilla")&&r.accept?.startsWith("text/html")&&Ri.loginPath?(E.status=302,E.headers.set("Location",Ri.loginPath(e))):E.headers.set("WWW-Authenticate","Basic")),c(E))}catch(l){throw c(l)}function c(l){let _=o.length;if(_>0){let u=l.headers;u||(l.headers=u=new Ai);for(let d=0;d<_;){let E=o[d++];u.set(E,o[d++])}}return o=null,l}a(c,"applyResponseHeaders")}function V8({server:e,port:t}){e.http($P,{port:t||"all"}),GP||(GP=!0,setInterval(()=>{fo=new Map},En.get(xt.CONFIG_PARAMS.AUTHENTICATION_CACHETTL)).unref(),kP.user.addListener(()=>{fo=new Map}))}async function $8(e){if(!e.baseRequest?.login)throw new Error("No session for login");return e.baseResponse.headers.set=(t,r)=>{e.fastifyResponse.header(t,r)},await e.baseRequest.login(e.username,e.password),"Login successful"}async function Y8(e){if(!e.baseRequest.session)throw new Error("No session for logout");return await e.baseRequest.session.update({user:null}),"Logout successful"}var FP,df,qP,En,xt,Oa,kP,HP,B8,H8,x8,G8,xP,_f,VP,F8,q8,fo,GP,ff=Re(()=>{FP=x(_n());fr();xl();df=x(El());Ae();qP=require("uuid"),En=x(ne()),xt=x(P()),Oa=x(K()),kP=x(Kc());Gl();ba();HP=(0,Oa.loggerWithTag)("auth-event");En.initSync();B8=En.get(xt.CONFIG_PARAMS.HTTP_CORSACCESSLIST),H8=En.get(xt.CONFIG_PARAMS.HTTP_CORS),x8=En.get(xt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORSACCESSLIST),G8=En.get(xt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORS),xP=ft({table:"hdb_session",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"user"}]}),_f=En.get(xt.CONFIG_PARAMS.AUTHENTICATION_ENABLESESSIONS)??!0,VP=En.get(xt.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE,F8=En.get(xt.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)??!1,q8=En.get(xt.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)??!1,fo=new Map;st.onInvalidatedUser(()=>{fo=new Map});a(k8,"bypassAuth");a($P,"authentication");a(V8,"start");a($8,"login");a(Y8,"logout")});var XP=g((EEe,JP)=>{"use strict";var we=require("joi"),YP=require("fs-extra"),KP=require("path"),Ps=at(),WP=ne(),QP=P(),zP=K(),{hdb_errors:K8}=se(),{HDB_ERROR_MSGS:ir}=K8,Ms=/^[a-zA-Z0-9-_]+$/;JP.exports={getDropCustomFunctionValidator:Q8,setCustomFunctionValidator:z8,addComponentValidator:Z8,dropCustomFunctionProjectValidator:e6,packageComponentValidator:t6,deployComponentValidator:r6,setComponentFileValidator:J8,getComponentFileValidator:j8,dropComponentFileValidator:X8};function Ef(e,t,r){try{let n=WP.get(QP.CONFIG_PARAMS.COMPONENTSROOT),s=KP.join(n,t);return YP.existsSync(s)?e?t:r.message(ir.PROJECT_EXISTS):e?r.message(ir.NO_PROJECT):t}catch(n){return zP.error(n),r.message(ir.VALIDATION_ERR)}}a(Ef,"checkProjectExists");function ql(e,t){return e.includes("..")?t.message("Invalid file path"):e}a(ql,"checkFilePath");function W8(e,t,r,n){try{let s=WP.get(QP.CONFIG_PARAMS.COMPONENTSROOT),i=KP.join(s,e,t,r+".js");return YP.existsSync(i)?r:n.message(ir.NO_FILE)}catch(s){return zP.error(s),n.message(ir.VALIDATION_ERR)}}a(W8,"checkFileExists");function Q8(e){let t=we.object({project:we.string().pattern(Ms).custom(Ef.bind(null,!0)).required().messages({"string.pattern.base":ir.BAD_PROJECT_NAME}),type:we.string().valid("helpers","routes").required(),file:we.string().pattern(Ms).custom(W8.bind(null,e.project,e.type)).custom(ql).required().messages({"string.pattern.base":ir.BAD_FILE_NAME})});return Ps.validateBySchema(e,t)}a(Q8,"getDropCustomFunctionValidator");function z8(e){let t=we.object({project:we.string().pattern(Ms).custom(Ef.bind(null,!0)).required().messages({"string.pattern.base":ir.BAD_PROJECT_NAME}),type:we.string().valid("helpers","routes").required(),file:we.string().custom(ql).required(),function_content:we.string().required()});return Ps.validateBySchema(e,t)}a(z8,"setCustomFunctionValidator");function J8(e){let t=we.object({project:we.string().pattern(Ms).required().messages({"string.pattern.base":ir.BAD_PROJECT_NAME}),file:we.string().custom(ql).required(),payload:we.string().allow("").optional(),encoding:we.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return Ps.validateBySchema(e,t)}a(J8,"setComponentFileValidator");function X8(e){let t=we.object({project:we.string().pattern(Ms).required().messages({"string.pattern.base":ir.BAD_PROJECT_NAME}),file:we.string().custom(ql).optional()});return Ps.validateBySchema(e,t)}a(X8,"dropComponentFileValidator");function j8(e){let t=we.object({project:we.string().required(),file:we.string().custom(ql).required(),encoding:we.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return Ps.validateBySchema(e,t)}a(j8,"getComponentFileValidator");function Z8(e){let t=we.object({project:we.string().pattern(Ms).custom(Ef.bind(null,!1)).required().messages({"string.pattern.base":ir.BAD_PROJECT_NAME})});return Ps.validateBySchema(e,t)}a(Z8,"addComponentValidator");function e6(e){let t=we.object({project:we.string().pattern(Ms).custom(Ef.bind(null,!0)).required().messages({"string.pattern.base":ir.BAD_PROJECT_NAME})});return Ps.validateBySchema(e,t)}a(e6,"dropCustomFunctionProjectValidator");function t6(e){let t=we.object({project:we.string().pattern(Ms).required().messages({"string.pattern.base":ir.BAD_PROJECT_NAME}),skip_node_modules:we.boolean()});return Ps.validateBySchema(e,t)}a(t6,"packageComponentValidator");function r6(e){let t=we.object({project:we.string().pattern(Ms).required().messages({"string.pattern.base":ir.BAD_PROJECT_NAME}),payload:we.string().optional().messages({"string.pattern.base":ir.BAD_PACKAGE}),package:we.string().optional()});return Ps.validateBySchema(e,t)}a(r6,"deployComponentValidator")});var Sf=g((mEe,sU)=>{"use strict";var hf=require("joi"),mf=require("path"),jP=require("fs-extra"),{exec:n6}=require("child_process"),s6=require("util"),ZP=s6.promisify(n6),kl=P(),{handleHDBError:ya,hdb_errors:i6}=se(),{HTTP_STATUS_CODES:Na}=i6,Vl=ne(),o6=at(),Ia=K();Vl.initSync();var WT=Vl.get(kl.CONFIG_PARAMS.COMPONENTSROOT),eU="npm install --omit=dev --json",a6=`${eU} --dry-run`;sU.exports={installModules:_6,auditModules:d6,installAllRootModules:c6,uninstallRootModule:l6,linkHarperdb:u6};async function c6(e=!1){await pf(),await $l(e?"npm install --ignore-scripts":"npm install",Vl.get(kl.CONFIG_PARAMS.ROOTPATH))}a(c6,"installAllRootModules");async function l6(e){await $l(`npm uninstall ${e}`,Vl.get(kl.CONFIG_PARAMS.ROOTPATH))}a(l6,"uninstallRootModule");async function u6(){await pf(),await $l(`npm link ${kl.PACKAGE_ROOT}`,Vl.get(kl.CONFIG_PARAMS.ROOTPATH))}a(u6,"linkHarperdb");async function $l(e,t=void 0){let r,n;try{({stdout:r,stderr:n}=await ZP(e,{cwd:t}))}catch(s){throw new Error(s.stderr.replace(`