harperdb 4.3.13 → 4.3.14

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.
@@ -4,7 +4,7 @@
4
4
  `).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:dk.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(mk,"findPs")});var at=R((Noe,AO)=>{"use strict";var pk="__dbis__",Sk="__txns__",Tk="__environment_name__",gk="__dbi_defintion__",Rk={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"},Ak=["__createdtime__","__updatedtime__"],Ok="\uFFFF",RO={TIMESTAMP:"timestamp",HASH_VALUE:"hash_value",USER_NAME:"user_name"},bk=Object.values(RO);AO.exports={AUDIT_STORE_NAME:Sk,INTERNAL_DBIS_NAME:pk,DBI_DEFINITION_NAME:gk,SEARCH_TYPES:Rk,TIMESTAMP_NAMES:Ak,MAX_SEARCH_KEY_LENGTH:256,ENVIRONMENT_NAME_KEY:Tk,TRANSACTIONS_DBI_NAMES_ENUM:RO,TRANSACTIONS_DBIS:bk,OVERFLOW_MARKER:Ok}});var Lr=R((Ioe,LO)=>{"use strict";var OO=U(),bO=at(),yO={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},NO=a(e=>`${e} Check logs and try again.`,"CHECK_LOGS_WRAPPER"),IO={500:NO("There was an error processing your request."),400:"Invalid request"},yk=IO[yO.INTERNAL_SERVER_ERROR],Nk={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.`},Ik={CONFIG_VALIDATION:e=>`HarperDB config file validation error: ${e}`},wk={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"},Ck={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 ${bO.INTERNAL_DBIS_NAME}`,CANNOT_DROP_INTERNAL_DBIS_NAME:`cannot drop a dbi named ${bO.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"},Dk={ATTR_NAME_LENGTH_ERR:e=>`transaction aborted due to attribute name ${e} being too long. Attribute names cannot be longer than ${OO.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 ${OO.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"},wO={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"},Lk={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."},Mk={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`},Uk={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"},Pk={OUTER_JOIN_TRANSLATION_ERROR:"There was an error translating the final SQL outer join data."},vk={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`},CO={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.`},DO={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}`},Bk={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."},Hk={CLUSTERING_NOT_ENABLED:"Clustering must be enabled to perform this operation."},xk={...wO,...wk,...Nk,...Lk,...Mk,...Uk,...Pk,...vk,...Dk,...CO,...DO,...Bk,...Hk,...Ik};LO.exports={CHECK_LOGS_WRAPPER:NO,HDB_ERROR_MSGS:xk,DEFAULT_ERROR_MSGS:IO,DEFAULT_ERROR_RESP:yk,HTTP_STATUS_CODES:yO,LMDB_ERRORS_ENUM:Ck,AUTHENTICATION_ERROR_MSGS:wO,VALIDATION_ERROR_MSGS:CO,ITC_ERRORS:DO}});var ne=R((Coe,PO)=>{"use strict";var Go=Lr(),Gk=K(),Fk=U(),Xl=class extends Error{static{a(this,"HdbError")}constructor(t,r,n,s,i){super(),Error.captureStackTrace(this,MO),this.statusCode=n||Go.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR,this.http_resp_msg=r||(Go.DEFAULT_ERROR_MSGS[n]?Go.DEFAULT_ERROR_MSGS[n]:Go.DEFAULT_ERROR_MSGS[Go.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&&Gk[s](i)}},Ch=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}},Dh=class extends Error{static{a(this,"ServerError")}constructor(t,r){super(t),this.statusCode=r||500}};function MO(e,t,r,n=Fk.LOG_LEVELS.ERROR,s=null,i=!1){if(UO(e))return e;let o=new Xl(e,t,r,n,s);return i&&delete o.stack,o}a(MO,"handleHDBError");function UO(e){return e.__proto__.constructor.name===Xl.name}a(UO,"isHDBError");PO.exports={isHDBError:UO,handleHDBError:MO,ClientError:Ch,ServerError:Dh,hdb_errors:Go}});var Qe=R((Loe,qO)=>{"use strict";var hc=U(),qk=Q(),or=te(),mc=require("path"),kk=require("minimist"),vO=require("fs-extra"),BO=require("lodash");or.initSync();var{CONFIG_PARAMS:Xs,DATABASES_PARAM_CONFIG:_c,SYSTEM_SCHEMA_NAME:jl}=hc,dc,fc,Ec;function HO(){if(dc!==void 0)return dc;if(or.getHdbBasePath()!==void 0)return dc=or.get(Xs.STORAGE_PATH)||mc.join(or.getHdbBasePath(),hc.DATABASES_DIR_NAME),dc}a(HO,"getBaseSchemaPath");function xO(){if(fc!==void 0)return fc;if(or.getHdbBasePath()!==void 0)return fc=FO(jl),fc}a(xO,"getSystemSchemaPath");function GO(){if(Ec!==void 0)return Ec;if(or.getHdbBasePath()!==void 0)return Ec=or.get(hc.CONFIG_PARAMS.STORAGE_AUDIT_PATH)||mc.join(or.getHdbBasePath(),hc.TRANSACTIONS_DIR_NAME),Ec}a(GO,"getTransactionAuditStoreBasePath");function Vk(e,t){let r=or.get(Xs.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||mc.join(GO(),e.toString())}a(Vk,"getTransactionAuditStorePath");function FO(e,t){e=e.toString(),t=t&&t.toString();let r=or.get(hc.CONFIG_PARAMS.DATABASES)?.[e];return t&&r?.tables?.[t]?.path||r?.path||mc.join(HO(),e)}a(FO,"getSchemaPath");function $k(e,t){e=e.toString(),t=t.toString();let r=process.env;Object.assign(r,kk(process.argv));let n=r[Xs.DATABASES.toUpperCase()];if(n){let i;try{i=JSON.parse(n)}catch(o){if(!qk.isObject(n))throw o;i=n}for(let o of i){let c=o[jl];if(!c)continue;let u=or.get(Xs.DATABASES);u=u??{};let _=c?.tables?.[t]?.[_c.PATH];if(_)return BO.set(u,[jl,_c.TABLES,t,_c.PATH],_),or.setProperty(Xs.DATABASES,u),_;let l=c?.[_c.PATH];if(l)return BO.set(u,[jl,_c.PATH],l),or.setProperty(Xs.DATABASES,u),l}}let s=r[Xs.STORAGE_PATH.toUpperCase()];if(s){if(!vO.pathExistsSync(s))throw new Error(s+" does not exist");let i=mc.join(s,e);return vO.mkdirsSync(i),or.setProperty(Xs.STORAGE_PATH,s),i}return xO()}a($k,"initSystemSchemaPaths");function Yk(){dc=void 0,fc=void 0,Ec=void 0}a(Yk,"resetPaths");qO.exports={getBaseSchemaPath:HO,getSystemSchemaPath:xO,getTransactionAuditStorePath:Vk,getTransactionAuditStoreBasePath:GO,getSchemaPath:FO,initSystemSchemaPaths:$k,resetPaths:Yk}});var Mr=R((voe,KO)=>{"use strict";var Kk=Lr().LMDB_ERRORS_ENUM,Uoe=require("lmdb"),Wk=at(),Poe=require("buffer").Buffer,{OVERFLOW_MARKER:kO,MAX_SEARCH_KEY_LENGTH:Zl}=Wk,VO=["number","string","symbol","boolean","bigint"];function Qk(e){if(e=e?.primaryStore||e,!e)throw new Error(Kk.ENV_REQUIRED)}a(Qk,"validateEnv");function zk(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(zk,"stringifyData");function Jk(e){return e instanceof Date?e.valueOf():e}a(Jk,"convertKeyValueToWrite");function Xk(e,t){if(e===null)return t?[null]:void 0;if(e===void 0)return;if(VO.includes(typeof e))return e.length>Zl?[e.slice(0,Zl)+kO]:[e];let r;if(Array.isArray(e)){r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n];if(VO.includes(typeof i))i.length>Zl?r.push(i.slice(0,Zl)+kO):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(Xk,"getIndexedValues");var e_=0,$O=0;function YO(){$O=Date.now()-performance.now()}a(YO,"adjustStartTime");YO();var jk=6e4;setInterval(YO,jk).unref();function Zk(){let e=performance.now()+$O;return e>e_?(e_=e,e):(e_+=488e-6,e_)}a(Zk,"getNextMonotonicTime");KO.exports={validateEnv:Qk,stringifyData:zk,convertKeyValueToWrite:Jk,getNextMonotonicTime:Zk,getIndexedValues:Xk}});var WO,On,Lh,pc=Re(()=>{WO=require("events"),On=class extends WO.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;[Symbol.asyncIterator](){let t=new Lh;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(){return this.queue?.shift()}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)}},Lh=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 Ui={};Fe(Ui,{server:()=>et});var QO,et,ar=Re(()=>{QO=require("../index"),et={};(0,QO._assignPackageExport)("server",et)});var Ph={};Fe(Ph,{loadGQLSchema:()=>rV,start:()=>Uh,startOnMainThread:()=>tV});function Uh({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r,n,s,i){let{parse:o,Source:c,Kind:u,NamedTypeNode:_,StringValueNode:l}=await import("graphql"),d=o(new c(r.toString(),s)),f=new Map,E=[],h;for(let p of d.definitions)switch(p.kind){case u.OBJECT_TYPE_DEFINITION:let v=function(P){if(P.kind==="NonNullType"){let X=v(P.type);return X.nullable=!1,X}if(P.kind==="ListType")return{type:"array",elements:v(P.type)};let H={type:P.name?.value};return Object.defineProperty(H,"location",{value:P.loc.startToken}),H};a(v,"getProperty");let T=p.name.value,A=[],g={table:null,database:null,properties:A};f.set(T,g);for(let P of p.directives){if(P.name.value==="table"){for(let k of P.arguments)g[k.name.value]=k.value.value;g.schema&&(g.database=g.schema),g.table||(g.table=T),g.audit&&(g.audit=g.audit!=="false"),g.attributes=g.properties,E.push(g)}if(P.name.value==="sealed"&&(g.sealed=!0),P.name.value==="export"){g.export=!0;for(let k of P.arguments)k.name.value==="name"&&(g.export={name:k.value.value})}}let L=!1;for(let P of p.fields){let k=v(P.type);k.name=P.name.value,A.push(k);for(let H of P.directives)if(H.name.value==="primaryKey")L?console.warn("Can not define two attributes as a primary key"):(k.isPrimaryKey=!0,L=!0);else if(H.name.value==="indexed")k.indexed=!0;else if(H.name.value==="relationship"){let X={};for(let z of H.arguments)X[z.name.value]=z.value.value;k.relationship=X}else if(H.name.value==="createdTime")k.assignCreatedTime=!0;else if(H.name.value==="updatedTime")k.assignUpdatedTime=!0;else if(H.name.value==="expiresAt")k.expiresAt=!0;else if(H.name.value==="allow"){let X=k.authorizedRoles=[];for(let z of H.arguments)z.name.value==="role"&&X.push(z.value.value)}}g.type=T,T==="Query"&&(h=g)}function S(p){let T=f.get(p.type);T?(Object.defineProperty(p,"properties",{value:T.properties}),Object.defineProperty(p,"definition",{value:T})):p.type==="array"?S(p.elements):eV.includes(p.type)||(0,zO.getWorkerIndex)()===0&&console.error(`The type ${p.type} is unknown at line ${p.location.line}, column ${p.location.column}, in ${s}`)}a(S,"connectPropertyType");for(let p of f.values())for(let T of p.properties)S(T);for(let p of E)p.tableClass=e(p),p.export&&(p.export.name===""?i.set((0,Mh.dirname)(n),p.tableClass):i.set((0,Mh.dirname)(n)+"/"+(p.export.name||p.type),p.tableClass))}}var Mh,zO,eV,tV,rV,JO=Re(()=>{Mh=require("path");Ae();zO=B(ct()),eV=["ID","Int","Float","Long","String","Boolean","Date","Bytes","Any","BigInt"];a(Uh,"start");tV=Uh,rV=Uh({ensureTable:ut}).handleFile});async function t_(e){return nV?(Sc||(Sc=sV(oV)),(await(await Sc).import(e)).namespace):import(e)}async function sV(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),Sc=new Compartment({console,Math,Date,fetch:iV,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,jO.extname)(r)||(r+=".js"),r)},importHook:async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){Object.assign(s,{Resource:kt,tables:Ur,databases:tt})}};let n=await(0,XO.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)}}),Sc}function iV(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 oV(){return{Resource:kt,tables:Ur}}var XO,jO,nV,Sc,vh=Re(()=>{bn();Ae();XO=require("fs/promises"),jO=require("path"),nV=!1;a(t_,"secureImport");a(sV,"getCompartment");a(iV,"secureOnlyFetch");a(oV,"getGlobalVars")});var Hh={};Fe(Hh,{handleFile:()=>aV});async function aV(e,t,r,n){let s=new Map,i=(0,ZO.pathToFileURL)(r).toString(),o=await t_(i);u(o.default)&&n.set((0,Bh.dirname)(t),o.default),c(o,(0,Bh.dirname)(t));function c(_,l){for(let d in _){let f=_[d];u(f)?n.set(l+"/"+d,f):typeof f=="object"&&c(f,l+"/"+d)}}a(c,"recurseForResources");function u(_){return typeof _=="function"&&(_.get||_.put||_.post||_.delete)}return a(u,"isResource"),s}var ZO,Bh,eb=Re(()=>{ZO=require("url");vh();Bh=require("path");a(aV,"handleFile")});var Gh={};Fe(Gh,{start:()=>cV});function cV({resources:e}){e.set("login",xh),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var xh,tb=Re(()=>{bn();a(cV,"start");xh=class extends kt{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 cb={};Fe(cb,{parse:()=>qh,streamAsJSON:()=>Tc,stringify:()=>Pi});function Tc(e){return new Fh({value:e})}function rb(e){return console.error(e),JSON.stringify(e.toString())}function nb(e,t,r){return e?.then?r?e.then(t,r):e.then(t):t(e)}function Pi(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===ob)return ab(e);if(t.resolution)return t.resolution.then(()=>Pi(e));throw t}}function ab(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+=ab(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+Pi(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function qh(e){return _V.test(e)?uV.parse(e):JSON.parse(e)}var sb,ib,uV,lV,ob,Fh,_V,kh=Re(()=>{sb=require("stream"),ib=B(require("json-bigint-fixes")),uV=(0,ib.default)({useNativeBigInt:!0}),lV=1e4,ob={};BigInt.prototype.toJSON=function(){throw ob};a(Tc,"streamAsJSON");Fh=class extends sb.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),rb)}catch(s){yield rb(s)}else yield Pi(t)}else yield Pi(t)}_read(){if(!this._amReading){if(this._amReading=!0,this.done)return this.push(null);nb(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>lV?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 nb(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(rb,"handleError");a(nb,"when");a(Pi,"stringify");a(ab,"jsStringify");_V=/[[,:]\s*-?\d{16,}/;a(qh,"parse")});var Rb=R((Xoe,gb)=>{"use strict";var Vh=require("recursive-iterator"),dV=require("alasql"),$h=require("clone"),ub=Q(),{handleHDBError:lb,hdb_errors:fV}=ne(),{HDB_ERROR_MSGS:_b,HTTP_STATUS_CODES:db}=fV,{getDatabases:EV}=(Ae(),ie(qe)),hV=["DISTINCT_ARRAY"],fb=Symbol("validateTables"),Yh=Symbol("validateTable"),Joe=Symbol("getAllColumns"),Eb=Symbol("validateAllColumns"),r_=Symbol("findColumn"),hb=Symbol("validateOrderBy"),gc=Symbol("validateSegment"),Kh=Symbol("validateColumn"),mb=Symbol("setColumnsForTable"),pb=Symbol("checkColumnsForAsterisk"),Sb=Symbol("validateGroupBy"),Tb=Symbol("hasColumns"),Wh=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[fb](),this[pb](),this[Eb]()}[fb](){if(this[Tb]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[Yh](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[Yh](t.table)})}}[Tb](){let t=!1,r=new Vh(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[Yh](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=EV();if(!r[t.databaseid])throw lb(new Error,_b.SCHEMA_NOT_FOUND(t.databaseid),db.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw lb(new Error,_b.TABLE_NOT_FOUND(t.databaseid,t.tableid),db.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=$h(s);i.table=$h(t),this.attributes.push(i)})}[r_](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)}[pb](){let t=new Vh(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[mb](r.tableid)}[mb](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new dV.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[Eb](){this[gc](this.statement.columns,!1),this[gc](this.statement.joins,!1),this[gc](this.statement.where,!1),this[Sb](this.statement.group,!1),this[gc](this.statement.order,!0)}[gc](t,r){if(!t)return;let n=new Vh(t),s=[];for(let{node:i,path:o}of n)!ub.isEmpty(i)&&!ub.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[hb](i):s.push(this[Kh](i)));return s}[Sb](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&hV.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=$h(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[r_](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[r_](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`}[hb](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[Kh](t)}[Kh](t){let r=this[r_](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]}};gb.exports=Wh});var Ob=R((Zoe,Ab)=>{"use strict";var Qh=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")}};Ab.exports=Qh});var yb=R((tae,bb)=>{"use strict";var zh=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};bb.exports=zh});var Cb={};Fe(Cb,{HAS_EXPIRATION:()=>rm,LAST_TIMESTAMP_PLACEHOLDER:()=>Oc,LOCAL_TIMESTAMP:()=>mV,METADATA:()=>Rc,NO_TIMESTAMP:()=>Xh,PENDING_LOCAL_TIME:()=>nm,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>tm,RecordEncoder:()=>em,TIMESTAMP_ASSIGN_LAST:()=>SV,TIMESTAMP_ASSIGN_NEW:()=>Ib,TIMESTAMP_ASSIGN_PREVIOUS:()=>wb,TIMESTAMP_PLACEHOLDER:()=>n_,TIMESTAMP_RECORD_PREVIOUS:()=>jh,getUpdateRecord:()=>sm,handleLocalTimeForGets:()=>a_});function gV(){return Ac[0]=Ac[0]^64,pV.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),u=c?.value,_=u?.[Rc];return _>=0&&(c.metadataFlags=_,c.localTime=u.localTime,c.value=u.value,u.expiresAt>0&&(c.expiresAt=u.expiresAt)),c&&(c.key=i),c};let r=e.get;e.get=function(i,o){let c=r.call(this,i,o);return c?.[Rc]>=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 u=c.value,_=u[Rc];return _>=0&&(c.metadataFlags=_,c.localTime=u.localTime,c.value=u.value,u.expiresAt>0&&(c.expiresAt=u.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,vi.push(new WeakRef(this))),o.call(this)},i.prototype.done=function(){if(c.call(this),this.isDone)for(let u=0;u<vi.length;u++){let _=vi[u].deref();(!_||_.isDone||_.isCommitted)&&vi.splice(u--,1)}},i.prototype.done.isTracked=!0}return e}function sm(e,t,r){return function(n,s,i,o,c=-1,u,_,l,d="put",f,E){if(f||u==null?Fo=i?.localTime?jh|wb:Xh:Fo=u?i?.localTime?jh|16384:Ib|16384:Xh,l>0&&(c|=rm),i_=c,Zh=l,i?.version===o&&u===!1)throw new Error("Must retain local time if version is not changed");let h={version:o,instructedWrite:Fo>0},S;try{f&&(h.ifVersion=S=i?.version??null);let p=e.put(n,s,h);if(u){let T=_?.user?.username;if(E&&(s_=e.encoder.encode(E)),f&&i?.localTime){let A=i?.localTime,g=r.get(A);if(g){let L=Ut(g).previousLocalTime;return r.put(A,o_(o,t,n,L,T,d,s_),{ifVersion:S}),p}}r.put(Oc,o_(o,t,n,i?.localTime?1:0,T,d,s_),{append:d!=="invalidate",instructedWrite:!0,ifVersion:S})}return p}catch(p){throw p.message+=" id: "+n+" options: "+h,p}}}var Nb,Jh,n_,Oc,tm,mV,Rc,Ac,pV,Xh,Ib,SV,wb,jh,rm,nm,TV,s_,Fo,i_,Zh,em,vi,bc=Re(()=>{Nb=require("msgpackr");js();Jh=B(K()),n_=new Uint8Array([1,1,1,1,4,64,0,0]),Oc=new Uint8Array([1,1,1,1,1,0,0,0]),tm=new Uint8Array([1,1,1,1,3,64,0,0]),mV=Symbol("local-timestamp"),Rc=Symbol("metadata"),Ac=new Uint8Array(8),pV=new DataView(Ac.buffer,0,8),Xh=0,Ib=0,SV=1,wb=3,jh=4,rm=16,nm=1,Fo=0,i_=-1,Zh=0,em=class extends Nb.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(n,s){if(Fo||i_>=0){let i=0,o=Fo;o&&(i+=8,Fo=0);let c=i_,u=Zh;c>=0&&(i+=2,i_=-1,u&&(i+=8,Zh=0));let _=TV=r.call(this,n,s|2048|i);s_=_.subarray((_.start||0)+i,_.end);let l=_.start||0;return o&&(n_[4]=o,n_[5]=o>>8,_.set(n_,l),l+=8),c>=0&&(_[l++]=c,_[l++]=0,u&&(_.dataView||(_.dataView=new DataView(_.buffer,_.byteOffset,_.byteLength))).setFloat64(l,u)),_}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,u;if(i===2){if(t.copy)t.copy(Ac,0,c),c+=8;else for(let d=0;d<8;d++)Ac[d]=t[c++];u=gV(),i=t[c]}let _;i<32&&(o=i,c+=2,o&rm&&(_=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8));let l=super.decode(t.subarray(c,s),s-c);return{localTime:u,value:l,[Rc]: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");vi=[];setInterval(()=>{for(let e=0;e<vi.length;e++){let t=vi[e].deref();!t||t.isDone||t.isCommitted?vi.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(Jh.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):Jh.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(sm,"getUpdateRecord")});var yc=R((oae,Lb)=>{"use strict";var Db=te(),RV=U(),{RecordEncoder:AV}=(bc(),ie(Cb)),iae=require("fs");Db.initSync();var OV=Db.get(RV.CONFIG_PARAMS.STORAGE_CACHING)!==!1,im=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=OV&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:AV})}};Lb.exports=im});var Nc=R((cae,Mb)=>{"use strict";var Pr=te(),on=U();Pr.initSync();var c_=class{static{a(this,"OpenEnvironmentObject")}constructor(t,r=!1){this.path=t,this.mapSize=1073741824,this.maxDbs=1e4,this.maxReaders=1e3,this.sharedStructuresKey=Symbol.for("structures"),this.readOnly=r,this.trackMetrics=!0,this.eventTurnBatching=!1,this.noSync=Pr.get(on.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Pr.get(on.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Pr.get(on.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Pr.get(on.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Pr.get(on.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Pr.get(on.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Pr.get(on.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Pr.get(on.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Pr.get(on.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Pr.get(on.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Pr.get(on.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Pr.get(on.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};Mb.exports=c_;c_.MAX_DBS=1e4});var Ye=R((lae,kb)=>{"use strict";var am=require("lmdb"),yn=require("fs-extra"),vr=require("path"),u_=Mr(),vb=K(),cr=Lr().LMDB_ERRORS_ENUM,l_=yb(),cm=yc(),Bb=Nc(),Zs=at(),Ub=U(),{table:bV,resetDatabases:yV}=(Ae(),ie(qe)),Pb=te(),Nn=Zs.INTERNAL_DBIS_NAME,Hb=Zs.DBI_DEFINITION_NAME,NV="data.mdb",IV="lock.mdb",Ic=".mdb",wV="-lock",om=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=an(t,r),this.key_type=this.dbi[Zs.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[Zs.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new am.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function __(e,t){if(e===void 0)throw new Error(cr.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(cr.ENV_NAME_REQUIRED)}a(__,"pathEnvNameValidation");async function um(e,t,r=!0){try{await yn.access(e)}catch(n){throw n.code==="ENOENT"?new Error(cr.INVALID_BASE_PATH):n}try{let n=vr.join(e,t+Ic);return await yn.access(n,yn.constants.R_OK|yn.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await yn.access(vr.join(e,t,NV),yn.constants.R_OK|yn.constants.F_OK),vr.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(cr.INVALID_ENVIRONMENT)}else throw new Error(cr.INVALID_ENVIRONMENT);throw n}}a(um,"validateEnvironmentPath");function d_(e,t){if(u_.validateEnv(e),t===void 0)throw new Error(cr.DBI_NAME_REQUIRED)}a(d_,"validateEnvDBIName");async function CV(e,t,r=!1,n=!1){__(e,t);let s=vr.basename(e);t=t.toString();let i=Pb.get(Ub.CONFIG_PARAMS.DATABASES);i||Pb.setProperty(Ub.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await um(e,t,n),xb(e,t,r)}catch(o){if(o.message===cr.INVALID_ENVIRONMENT){let c=vr.join(e,t);await yn.mkdirp(n?c:e);let u=new Bb(n?c:c+Ic,!1),_=am.open(u);_.dbis=Object.create(null);let l=new cm(!1);_.openDB(Nn,l),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let d=lm(e,t,r);return _[Zs.ENVIRONMENT_NAME_KEY]=d,global.lmdb_map[d]=_,_}throw o}}a(CV,"createEnvironment");async function DV(e,t,r,n=!0){__(e,t),t=t.toString();let s=vr.join(e,t);return bV({table:t,database:vr.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(DV,"copyEnvironment");async function xb(e,t,r=!1){__(e,t),t=t.toString();let n=lm(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 um(e,t),i=vr.join(e,t+Ic),o=s!=i,c=new Bb(s,o),u=am.open(c);u.dbis=Object.create(null);let _=Fb(u);for(let l=0;l<_.length;l++)an(u,_[l]);return u[Zs.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=u,u}a(xb,"openEnvironment");async function LV(e,t,r=!1){__(e,t),t=t.toString();let n=vr.join(e,t+Ic),s=await um(e,t);if(global.lmdb_map!==void 0){let i=lm(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await Gb(o),delete global.lmdb_map[i]}}await yn.remove(s),await yn.remove(s===n?s+wV:vr.join(vr.dirname(s),IV))}a(LV,"deleteEnvironment");async function Gb(e){u_.validateEnv(e);let t=e[Zs.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(Gb,"closeEnvironment");function lm(e,t,r=!1){let s=`${vr.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(lm,"getCachedEnvironmentName");function MV(e){u_.validateEnv(e);let t=Object.create(null),r=an(e,Nn);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==Nn)try{t[n]=Object.assign(new l_,s)}catch{vb.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(MV,"listDBIDefinitions");function Fb(e){u_.validateEnv(e);let t=[],r=an(e,Nn);for(let{key:n}of r.getRange({start:!1}))n!==Nn&&t.push(n);return t}a(Fb,"listDBIs");function UV(e,t){let n=an(e,Nn).getEntry(t),s=new l_;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{vb.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(UV,"getDBIDefinition");function qb(e,t,r,n=!r){if(d_(e,t),t=t.toString(),t===Nn)throw new Error(cr.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return an(e,t)}catch(s){if(s.message===cr.DBI_DOES_NOT_EXIST){let i=new cm(r,n===!0),o=e.openDB(t,i),c=new l_(r===!0,n);return o[Hb]=c,an(e,Nn).putSync(t,c),e.dbis[t]=o,o}throw s}}a(qb,"createDBI");function an(e,t){if(d_(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==Nn?r=UV(e,t):r=new l_,r===void 0)throw new Error(cr.DBI_DOES_NOT_EXIST);let n;try{let s=new cm(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(cr.DBI_DOES_NOT_EXIST):s}return n[Hb]=r,e.dbis[t]=n,n}a(an,"openDBI");function PV(e,t){d_(e,t),t=t.toString();let r=an(e,t),n=r.getStats();return r[Zs.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(PV,"statDBI");async function vV(e,t){try{let r=vr.join(e,t+Ic);return(await yn.stat(r)).size}catch{throw new Error(cr.INVALID_ENVIRONMENT)}}a(vV,"environmentDataSize");function BV(e,t){if(d_(e,t),t=t.toString(),t===Nn)throw new Error(cr.CANNOT_DROP_INTERNAL_DBIS_NAME);an(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],an(e,Nn).removeSync(t)}a(BV,"dropDBI");function HV(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{an(e,i)}catch(o){if(o.message===cr.DBI_DOES_NOT_EXIST)qb(e,i,i!==t,i===t),n=!0;else throw o}}n&&yV()}a(HV,"initializeDBIs");kb.exports={openDBI:an,openEnvironment:xb,createEnvironment:CV,listDBIs:Fb,listDBIDefinitions:MV,createDBI:qb,dropDBI:BV,statDBI:PV,deleteEnvironment:LV,initializeDBIs:HV,TransactionCursor:om,environmentDataSize:vV,copyEnvironment:DV,closeEnvironment:Gb}});var $b=R((dae,Vb)=>{"use strict";var _m=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};Vb.exports=_m});var Kb=R((Eae,Yb)=>{"use strict";var dm=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}};Yb.exports=dm});var Qb=R((mae,Wb)=>{"use strict";var fm=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};Wb.exports=fm});var qo=R((Rae,Xb)=>{"use strict";var xV=Ye(),GV=$b(),FV=Kb(),qV=Qb(),Kn=Mr(),wc=Lr().LMDB_ERRORS_ENUM,kV=at(),Ss=U(),VV=Q(),$V=require("uuid"),Sae=require("lmdb"),{handleHDBError:YV,hdb_errors:KV}=ne(),{OVERFLOW_MARKER:Tae,MAX_SEARCH_KEY_LENGTH:gae}=kV,zb=te();zb.initSync();var f_=zb.get(Ss.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),Em=Ss.TIME_STAMP_NAMES_ENUM.CREATED_TIME,Bi=Ss.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function WV(e,t,r,n,s=Kn.getNextMonotonicTime()){Sm(e,t,r,n),hm(e,t,r);let i=new GV,o=[],c=[];for(let u=0;u<n.length;u++){let _=n[u];Jb(_,!0,s);let l=QV(e,t,r,_),d=_[t];o.push(l),c.push(d)}return mm(o,c,n,i,s)}a(WV,"insertRecords");function QV(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 l=c([[{}]]);Array.isArray(l)&&(c=l[0][Ss.FUNC_VAL],n[o]=c)}let u=Kn.getIndexedValues(c),_=e.dbis[o];if(u){f_&&_.prefetch(u.map(l=>({key:l,value:s})),E_);for(let l=0,d=u.length;l<d;l++)_.put(u[l],s)}}f_&&e.dbis[t].prefetch([s],E_),e.dbis[t].put(s,n,n[Bi])})}a(QV,"insertRecord");function zV(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(zV,"removeSkippedRecords");function Jb(e,t,r){let n=r>0;(n||!Number.isInteger(e[Bi]))&&(e[Bi]=r||(r=Kn.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[Em]))&&(e[Em]=r||Kn.getNextMonotonicTime()):delete e[Em]}a(Jb,"setTimestamps");function hm(e,t,r){r.indexOf(Ss.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(Ss.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(Ss.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(Ss.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),xV.initializeDBIs(e,t,r)}a(hm,"initializeTransaction");async function JV(e,t,r,n,s=Kn.getNextMonotonicTime()){Sm(e,t,r,n),hm(e,t,r);let i=new FV,o=[],c=[],u=[];for(let _=0;_<n.length;_++){let l=n[_],d=l[t],f;try{f=pm(e,t,l,d,i,!0,s)}catch{i.skipped_hashes.push(d),o.push(_);continue}c.push(f),u.push(d)}return mm(c,u,n,i,s,o)}a(JV,"updateRecords");async function XV(e,t,r,n,s=Kn.getNextMonotonicTime()){try{Sm(e,t,r,n)}catch(u){throw YV(u,u.message,KV.HTTP_STATUS_CODES.BAD_REQUEST)}hm(e,t,r);let i=new qV,o=[],c=[];for(let u=0;u<n.length;u++){let _=n[u],l;VV.isEmpty(_[t])?(l=$V.v4(),_[t]=l):l=_[t];let d=pm(e,t,_,l,i,!1,s);o.push(d),c.push(l)}return mm(o,c,n,i,s)}a(XV,"upsertRecords");async function mm(e,t,r,n,s,i=[]){let o=await Promise.all(e);for(let c=0,u=o.length;c<u;c++)o[c]===!0?n.written_hashes.push(t[c]):(n.skipped_hashes.push(t[c]),i.push(c));return n.txn_time=s||Kn.getNextMonotonicTime(),zV(r,i),n}a(mm,"finalizeWrite");function pm(e,t,r,n,s,i=!1,o){let c=e.dbis[t],u=c.getEntry(n),_=u?.value,l=_;if(!_){if(i)return!1;_={}}if(Jb(r,!l,o),Number.isInteger(r[Bi])&&_[Bi]>r[Bi])return!1;l&&s.original_records.push(_);let d,f=a(()=>{for(let h in r){if(!r.hasOwnProperty(h)||h===t)continue;let S=r[h],p=e.dbis[h];if(p===void 0)continue;let T=_[h];if(typeof S=="function"){let g=S([[_]]);Array.isArray(g)&&(S=g[0][Ss.FUNC_VAL],r[h]=S)}if(S===T)continue;let A=Kn.getIndexedValues(T);if(A){f_&&p.prefetch(A.map(g=>({key:g,value:n})),E_);for(let g=0,L=A.length;g<L;g++)p.remove(A[g],n)}if(A=Kn.getIndexedValues(S),A){f_&&p.prefetch(A.map(g=>({key:g,value:n})),E_);for(let g=0,L=A.length;g<L;g++)p.put(A[g],n)}}let E=Object.assign({},_,r);c.put(n,E,E[Bi])},"do_put");return u?d=c.ifVersion(n,u.version,f):d=c.ifNoExists(n,f),d.then(E=>E?!0:pm(e,t,r,n,s,i,o))}a(pm,"updateUpsertRecord");function jV(e,t,r){if(Kn.validateEnv(e),t===void 0)throw new Error(wc.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(wc.WRITE_ATTRIBUTES_REQUIRED):new Error(wc.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(jV,"validateBasic");function Sm(e,t,r,n){if(jV(e,t,r),!Array.isArray(n))throw n===void 0?new Error(wc.RECORDS_REQUIRED):new Error(wc.RECORDS_MUST_BE_ARRAY)}a(Sm,"validateWrite");function E_(){}a(E_,"noop");Xb.exports={insertRecords:WV,updateRecords:JV,upsertRecords:XV}});var Hi=R((Oae,ZV)=>{ZV.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 Qn=R((bae,ey)=>{"use strict";var Zb=Q(),jb=U(),ko=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Wn=require("joi"),ei={schema_format:{pattern:ko,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},e$=Wn.alternatives(Wn.string().min(1).max(ei.schema_length.maximum).pattern(ko).messages({"string.pattern.base":"{:#label} "+ei.schema_format.message}),Wn.number(),Wn.array()).required(),t$=Wn.alternatives(Wn.string().min(1).max(ei.schema_length.maximum).pattern(ko).messages({"string.pattern.base":"{:#label} "+ei.schema_format.message}),Wn.number()),r$=Wn.alternatives(Wn.string().min(1).max(ei.schema_length.maximum).pattern(ko).messages({"string.pattern.base":"{:#label} "+ei.schema_format.message}),Wn.number()).required();function n$(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>ei.schema_length.maximum?`'${e}' maximum of 250 characters`:ko.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(n$,"checkValidTable");function s$(e,t){return Zb.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(s$,"validateSchemaExists");function i$(e,t){let r=t.state.ancestors[0].schema;return Zb.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(i$,"validateTableExists");function o$(e,t){return e.toLowerCase()===jb.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${jb.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(o$,"validateSchemaName");ey.exports={common_validators:ei,schema_regex:ko,hdb_schema_table:e$,validateSchemaExists:s$,validateTableExists:i$,validateSchemaName:o$,checkValidTable:n$,hdb_database:t$,hdb_table:r$}});var rt=R((Nae,ty)=>{"use strict";var ur=require("validate.js");ur.validators.type=function(e,t,r,n){return e===null||typeof e>"u"||ur.validators.type.checks[t](e)?null:` must be a '${t}' value`};ur.validators.type.checks={Object:function(e){return ur.isObject(e)&&!ur.isArray(e)},Array:ur.isArray,Integer:ur.isInteger,Number:ur.isNumber,String:ur.isString,Date:ur.isDate,Boolean:function(e){return typeof e=="boolean"}};ur.validators.hasValidFileExt=function(e,t){return ur.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};ty.exports={validateObject:a$,validateObjectAsync:c$,validateBySchema:u$};function a$(e,t){if(!e||!t)return new Error("validateObject parameters were null");let r=ur(e,t,{format:"flat"});return r?new Error(r):null}a(a$,"validateObject");async function c$(e,t){if(!e||!t)return new Error("validateObject parameters were null");try{await ur.async(e,t,{format:"flat"})}catch(r){let n=r.join(",");return new Error(n)}return null}a(c$,"validateObjectAsync");function u$(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(u$,"validateBySchema")});var h_=R((wae,ry)=>{var{common_validators:zn}=Qn(),Dc=rt(),Cc="is required",mt={database:{presence:!1,format:zn.schema_format,length:zn.schema_length},schema:{presence:!1,format:zn.schema_format,length:zn.schema_length},table:{presence:!0,format:zn.schema_format,length:zn.schema_length},attribute:{presence:!0,format:zn.schema_format,length:zn.schema_length},hash_attribute:{presence:!0,format:zn.schema_format,length:zn.schema_length}};function Lc(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(Lc,"makeAttributesStrings");function l$(e){return e=Lc(e),mt.table.presence=!1,mt.attribute.presence=!1,mt.hash_attribute.presence=!1,Dc.validateObject(e,mt)}a(l$,"schema_object");function _$(e){return e=Lc(e),mt.table.presence={message:Cc},mt.attribute.presence=!1,mt.hash_attribute.presence=!1,Dc.validateObject(e,mt)}a(_$,"table_object");function d$(e){return e=Lc(e),mt.table.presence={message:Cc},mt.attribute.presence=!1,Dc.validateObject(e,mt)}a(d$,"create_table_object");function f$(e){return e=Lc(e),mt.table.presence={message:Cc},mt.attribute.presence={message:Cc},mt.hash_attribute.presence=!1,Dc.validateObject(e,mt)}a(f$,"attribute_object");function E$(e){return e=Lc(e),mt.table.presence={message:Cc},mt.attribute.presence=!1,mt.hash_attribute.presence=!1,Dc.validateObject(e,mt)}a(E$,"describe_table");function h$(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(h$,"validateTableResidence");ry.exports={schema_object:l$,create_table_object:d$,table_object:_$,attribute_object:f$,describe_table:E$,validateTableResidence:h$}});var sy=R((Dae,ny)=>{"use strict";var m$=require("uuid"),Tm=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||m$.v4(),this.schema_table=`${this.schema}.${this.table}`}};ny.exports=Tm});var m_=R((Mae,iy)=>{"use strict";var p$=sy(),gm=class extends p${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}};iy.exports=gm});var ay=R((Pae,oy)=>{"use strict";oy.exports=T$;var S$="inserted";function T$(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===S$?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(T$,"returnObject")});var p_=R((Bae,dy)=>{"use strict";var g$=U(),Rm=Ye(),R$=qo(),{getSystemSchemaPath:A$,getSchemaPath:O$}=Qe(),b$=Hi(),y$=h_(),N$=m_(),I$=ay(),{handleHDBError:cy,hdb_errors:ly}=ne(),uy=Q(),{HTTP_STATUS_CODES:w$}=ly,Am=b$.hdb_attribute,_y=[];for(let e=0;e<Am.attributes.length;e++)_y.push(Am.attributes[e].attribute);var C$="inserted";dy.exports=D$;async function D$(e){let t=y$.attribute_object(e);if(t)throw cy(new Error,t.message,ly.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=!e.skip_table_check&&uy.checkGlobalSchemaTable(e.schema,e.table);if(r)throw cy(new Error,r,w$.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=uy.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 N$(e.schema,e.table,e.attribute,e.id);try{let i=await Rm.openEnvironment(O$(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}`);Rm.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await Rm.openEnvironment(A$(),g$.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:u}=await R$.insertRecords(o,Am.hash_attribute,_y,[s]);return I$(C$,c,{records:[s]},u)}catch(i){throw i}}a(D$,"lmdbCreateAttribute")});var bm=R((xae,Ey)=>{var{hdb_table:L$,hdb_database:fy}=Qn(),M$=rt(),Om=require("joi"),U$={undefined:"undefined",null:"null"},P$=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||U$[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"),v$=Om.object({database:fy,schema:fy,table:L$,records:Om.array().items(Om.object().custom(P$)).required()});Ey.exports=function(e){return M$.validateBySchema(e,v$)}});var Mc=R((qae,my)=>{"use strict";var Ts=Q(),hy=K(),Fae=bm(),{getDatabases:B$}=(Ae(),ie(qe)),{ClientError:xi}=ne();my.exports=H$;function H$(e){if(Ts.isEmpty(e))throw new xi("invalid update parameters defined.");if(Ts.isEmptyOrZeroLength(e.schema))throw new xi("invalid schema specified.");if(Ts.isEmptyOrZeroLength(e.table))throw new xi("invalid table specified.");if(!Array.isArray(e.records))throw new xi("records must be an array");let t=B$()[e.schema]?.[e.table];if(Ts.isEmpty(t))throw new xi(`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&&Ts.isEmptyOrZeroLength(o[r]))throw hy.error("a valid hash attribute must be provided with update record:",o),new xi("a valid hash attribute must be provided with update record, check log for more info");if(!Ts.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw hy.error(`a valid hash value must be provided with ${e.operation} record:`,o),new xi(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!Ts.isEmpty(o[r])&&o[r]!==""&&n.has(Ts.autoCast(o[r]))&&(o.skip=!0),n.add(Ts.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(H$,"insertUpdateValidate")});var Uc=R((Vae,py)=>{"use strict";var x$=U().OPERATIONS_ENUM,ym=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i=void 0){this.operation=x$.INSERT,this.schema=t,this.table=r,this.hash_attribute=n,this.records=s,this.__origin=i}};py.exports=ym});var Pc=R((Kae,Ty)=>{"use strict";var Yae=Uc(),S_=U(),Nm=Q(),Sy=K(),G$=require("uuid"),{handleHDBError:T_,hdb_errors:F$}=ne(),{HDB_ERROR_MSGS:g_,HTTP_STATUS_CODES:R_}=F$;Ty.exports=q$;function q$(e,t,r){for(let s=0;s<t.length;s++)k$(t[s]);let{records:n}=e;for(let s=0;s<n.length;s++){let i=n[s];V$(i,r,e.operation)}}a(q$,"processRows");function k$(e){if(Buffer.byteLength(String(e))>S_.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw T_(new Error,g_.ATTR_NAME_LENGTH_ERR(e),R_.BAD_REQUEST,void 0,void 0,!0);if(Nm.isEmptyOrZeroLength(e)||Nm.isEmpty(e.trim()))throw T_(new Error,g_.ATTR_NAME_NULLISH_ERR,R_.BAD_REQUEST,void 0,void 0,!0)}a(k$,"validateAttribute");function V$(e,t,r){if(!e.hasOwnProperty(t)||Nm.isEmptyOrZeroLength(e[t])){if(r===S_.OPERATIONS_ENUM.INSERT||r===S_.OPERATIONS_ENUM.UPSERT){e[t]=G$.v4();return}throw Sy.error("Update transaction aborted due to record with no hash value:",e),T_(new Error,g_.RECORD_MISSING_HASH_ERR,R_.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>S_.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw Sy.error(e),T_(new Error,g_.HASH_VAL_LENGTH_ERR,R_.BAD_REQUEST,void 0,void 0,!0)}a(V$,"validateHash")});var Ry=R((Qae,gy)=>{"use strict";var Im=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};gy.exports=Im});var by=R((Jae,Oy)=>{"use strict";var wm=Ye(),$$=K(),Ay=Lr().LMDB_ERRORS_ENUM;Oy.exports=Y$;async function Y$(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 wm.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==Ay.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await wm.closeEnvironment(global.lmdb_map[n]),await wm.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==Ay.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){$$.error(t)}}a(Y$,"cleanLMDBMap")});var gs=R((jae,wy)=>{"use strict";var vc=require("crypto"),K$=te(),{CONFIG_PARAMS:W$}=U(),Ny="aes-256-cbc",Q$=32,z$=16,Cm=64,Iy=32,J$=Cm+Iy,yy=new Map;wy.exports={encrypt:X$,decrypt:j$,createNatsTableStreamName:Z$};function X$(e){let t=vc.randomBytes(Q$),r=vc.randomBytes(z$),n=vc.createCipheriv(Ny,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(X$,"encrypt");function j$(e){let t=e.substr(0,Cm),r=e.substr(Cm,Iy),n=e.substr(J$,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=vc.createDecipheriv(Ny,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(j$,"decrypt");function Z$(e,t){let r=K$.get(W$.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=yy.get(r);return n||(n=vc.createHash("md5").update(r).digest("hex"),yy.set(r,n)),n}a(Z$,"createNatsTableStreamName")});var ti=R((tce,Dy)=>{"use strict";var ece=Br(),A_=K(),Cy=h_(),e1=gs(),O_=Q(),{handleHDBError:b_,hdb_errors:t1}=ne(),{HDB_ERROR_MSGS:y_,HTTP_STATUS_CODES:Dm}=t1,r1=te();r1.initSync();var{getDatabases:Lm}=(Ae(),ie(qe));Dy.exports={describeAll:n1,describeTable:N_,describeSchema:s1};async function n1(e){try{let t=O_.isEmptyOrZeroLength(e),r,n;t||(r=e.hdb_user.role.permission,n=r.super_user||r.cluster_user);let s=Lm(),i={},o={},c=[],u=e?.exact_count;for(let l in s){i[l]=!0,!t&&!n&&(o[l]=e.hdb_user.role.permission[l].describe);let d=s[l];for(let f in d)try{let E;if(t||n)E=await N_({schema:l,table:f,exact_count:u});else if(r&&r[l].describe&&r[l].tables[f].describe){let h=r[l].tables[f].attribute_permissions;E=await N_({schema:l,table:f,exact_count:u},h)}E&&c.push(E)}catch(E){A_.error(E)}}let _={};for(let l in c)t||n?(_[c[l].schema]==null&&(_[c[l].schema]={}),_[c[l].schema][c[l].name]=c[l],i[c[l].schema]&&delete i[c[l].schema]):o[c[l].schema]&&(_[c[l].schema]==null&&(_[c[l].schema]={}),_[c[l].schema][c[l].name]=c[l],i[c[l].schema]&&delete i[c[l].schema]);for(let l in i)t||n?_[l]={}:o[l]&&(_[l]={});return _}catch(t){return A_.error("Got an error in describeAll"),A_.error(t),b_(new Error,y_.DESCRIBE_ALL_ERR)}}a(n1,"describeAll");async function N_(e,t){O_.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=Cy.describe_table(e);if(i)throw i;let c=Lm()[r];if(!c)throw b_(new Error,y_.SCHEMA_NOT_FOUND(e.schema),Dm.NOT_FOUND);let u=c[n];if(!u)throw b_(new Error,y_.TABLE_NOT_FOUND(e.schema,e.table),Dm.NOT_FOUND);function _(f){l.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(E=>({type:E.type,name:E.name})):void 0}))}a(_,"pushAtt");let l=[];if(s){let f={};s.forEach(E=>{E.describe&&(f[E.attribute_name]=!0)}),u.attributes.forEach(E=>{f[E.name]&&_(E)})}else u.attributes?.forEach(f=>_(f));let d={schema:r,name:u.tableName,hash_attribute:u.attributes.find(f=>f.isPrimaryKey||f.is_hash_attribute)?.name,audit:u.audit,schema_defined:u.schemaDefined,attributes:l};d.clustering_stream_name=e1.createNatsTableStreamName(d.schema,d.name);try{let f=u.getRecordCount({exactCount:e.exact_count==="true"});d.record_count=f.recordCount,d.estimated_record_range=f.estimatedRange;let E=u.auditStore;if(E)for(let h of E.getKeys({reverse:!0,limit:1}))d.last_updated_record=h[0];if(!d.last_updated_record&&u.indices.__updatedtime__)for(let h of u.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))d.last_updated_record=h}catch(f){A_.warn(`unable to stat table dbi due to ${f}`)}return d}a(N_,"descTable");async function s1(e){O_.transformReq(e);let t=Cy.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=Lm()[n];if(!i)throw b_(new Error,y_.SCHEMA_NOT_FOUND(e.schema),Dm.NOT_FOUND);let o={};for(let c in i){let u;if(r&&r.tables[c]&&(u=r.tables[c]),O_.isEmpty(u)||u.describe){let _=await N_({schema:e.schema,table:c,exact_count:e.exact_count},u?u.attribute_permissions:null);_&&(o[_.name]=_)}}return o}a(s1,"describeSchema")});var ri=R((ice,vy)=>{var i1=Hi(),{callbackify:My,promisify:o1}=require("util"),{getDatabases:Uy}=(Ae(),ie(qe));vy.exports={setSchemaDataToGlobal:Ly,getTableSchema:a1,getSystemSchema:c1,setSchemaDataToGlobalAsync:o1(Ly)};var Py=ti(),nce=My(Py.describeAll),sce=My(Py.describeTable);function Ly(e){global.hdb_schema=Uy(),e&&e()}a(Ly,"setSchemaDataToGlobal");function a1(e,t,r){let n=Uy()[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(a1,"getTableSchema");function c1(){return i1}a(c1,"getSystemSchema")});var cn=R((ace,Gy)=>{"use strict";var w_=bm(),Vt=Q(),u1=require("util"),C_=In(),l1=ri(),By=K(),{handleHDBError:Gi,hdb_errors:_1}=ne(),{HTTP_STATUS_CODES:Fi}=_1,d1=u1.promisify(l1.getTableSchema),f1="updated",Hy="inserted",xy="upserted";Gy.exports={insert:h1,update:m1,upsert:p1,validation:E1,flush:S1};async function E1(e){if(Vt.isEmpty(e))throw new Error("invalid update parameters defined.");if(Vt.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if(Vt.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await d1(e.schema,e.table),r=w_(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&&Vt.isEmptyOrZeroLength(c[n]))throw By.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(!Vt.isEmptyOrZeroLength(c[n])&&(c[n]==="null"||c[n]==="undefined"))throw By.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[n]}" is not a valid hash attribute value`);!Vt.isEmpty(c[n])&&c[n]!==""&&s.has(Vt.autoCast(c[n]))&&(c.skip=!0),s.add(Vt.autoCast(c[n]));for(let u in c)i[u]=1}),i[n]=1,{schema_table:t,hashes:Array.from(s),attributes:Object.keys(i)}}a(E1,"validation");async function h1(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=w_(e);if(t)throw Gi(new Error,t.message,Fi.BAD_REQUEST);Vt.transformReq(e);let r=Vt.checkSchemaTableExist(e.schema,e.table);if(r)throw Gi(new Error,r,Fi.BAD_REQUEST);let n=await C_.createRecords(e);return I_(Hy,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(h1,"insertData");async function m1(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=w_(e);if(t)throw Gi(new Error,t.message,Fi.BAD_REQUEST);Vt.transformReq(e);let r=Vt.checkSchemaTableExist(e.schema,e.table);if(r)throw Gi(new Error,r,Fi.BAD_REQUEST);let n=await C_.updateRecords(e);return Vt.isEmpty(n.existing_rows)?I_(f1,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):I_(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(m1,"updateData");async function p1(e){if(e.operation!=="upsert")throw Gi(new Error,"invalid operation, must be upsert",Fi.INTERNAL_SERVER_ERROR);let t=w_(e);if(t)throw Gi(new Error,t.message,Fi.BAD_REQUEST);Vt.transformReq(e);let r=Vt.checkSchemaTableExist(e.schema,e.table);if(r)throw Gi(new Error,r,Fi.BAD_REQUEST);let n=await C_.upsertRecords(e);return I_(xy,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(p1,"upsertData");function I_(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===Hy?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===xy?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(I_,"returnObject");function S1(e){return Vt.transformReq(e),C_.flush(e.schema,e.table)}a(S1,"flush")});var Um=R((uce,ky)=>{var T1=rt(),Mm=require("joi"),{hdb_table:g1,hdb_database:Fy}=Qn(),qy={schema:Fy,database:Fy,table:g1},R1={date:Mm.date().iso().required()},A1={timestamp:Mm.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};ky.exports=function(e,t){let r=t==="timestamp"?{...qy,...A1}:{...qy,...R1},n=Mm.object(r);return T1.validateBySchema(e,n)}});var Yy=R((lce,$y)=>{var O1=rt(),Pm=require("joi"),{hdb_table:b1,hdb_database:Vy}=Qn(),y1=Pm.object({schema:Vy,database:Vy,table:b1,hash_values:Pm.array().required(),ids:Pm.array()});$y.exports=function(e){return O1.validateBySchema(e,y1)}});var Wy=R((_ce,Ky)=>{"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}},Bm=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}},Hm=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};Ky.exports={InsertObject:vm,NoSQLSeachObject:Bm,DeleteResponseObject:Hm}});var Vi=R((fce,jy)=>{"use strict";var zy=Um(),N1=Yy(),qi=Q(),Qy=require("moment"),Jy=K(),{promisify:I1,callbackify:w1}=require("util"),ki=U(),C1=ri(),xm=I1(C1.getTableSchema),Gm=In(),{DeleteResponseObject:D1}=Wy(),{handleHDBError:ni,hdb_errors:L1}=ne(),{HDB_ERROR_MSGS:D_,HTTP_STATUS_CODES:si}=L1,M1="records successfully deleted",U1=w1(Xy);jy.exports={delete:U1,deleteRecord:Xy,deleteFilesBefore:P1,deleteAuditLogsBefore:v1};async function P1(e){let t=zy(e,"date");if(t)throw ni(t,t.message,si.BAD_REQUEST,void 0,void 0,!0);if(qi.transformReq(e),!Qy(e.date,Qy.ISO_8601).isValid())throw ni(new Error,D_.INVALID_DATE,si.BAD_REQUEST,ki.LOG_LEVELS.ERROR,D_.INVALID_DATE,!0);let n=qi.checkSchemaTableExist(e.schema,e.table);if(n)throw ni(new Error,n,si.NOT_FOUND,ki.LOG_LEVELS.ERROR,n,!0);let s=await Gm.deleteRecordsBefore(e);if(await xm(e.schema,e.table),Jy.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(P1,"deleteFilesBefore");async function v1(e){let t=zy(e,"timestamp");if(t)throw ni(t,t.message,si.BAD_REQUEST,void 0,void 0,!0);if(qi.transformReq(e),isNaN(e.timestamp))throw ni(new Error,D_.INVALID_VALUE("Timestamp"),si.BAD_REQUEST,ki.LOG_LEVELS.ERROR,D_.INVALID_VALUE("Timestamp"),!0);let r=qi.checkSchemaTableExist(e.schema,e.table);if(r)throw ni(new Error,r,si.NOT_FOUND,ki.LOG_LEVELS.ERROR,r,!0);let n=await Gm.deleteAuditLogsBefore(e);return await xm(e.schema,e.table),Jy.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(v1,"deleteAuditLogsBefore");async function Xy(e){e.ids&&(e.hash_values=e.ids);let t=N1(e);if(t)throw ni(t,t.message,si.BAD_REQUEST,void 0,void 0,!0);qi.transformReq(e);let r=qi.checkSchemaTableExist(e.schema,e.table);if(r)throw ni(new Error,r,si.NOT_FOUND,ki.LOG_LEVELS.ERROR,r,!0);try{await xm(e.schema,e.table);let n=await Gm.deleteRecords(e);return qi.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${M1}`),n}catch(n){if(n.message===ki.SEARCH_NOT_FOUND_MESSAGE){let s=new D1;return s.message=ki.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(Xy,"deleteRecord")});var L_=R((hce,tN)=>{var B1=require("crypto"),Zy=9;function H1(e){let t=G1(Zy),r=eN(e+t);return t+r}a(H1,"createHash");function x1(e,t){let r=e?.substr(0,Zy),n=r+eN(t+r);return e===n}a(x1,"validateHash");function G1(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(G1,"generateSalt");function eN(e){return B1.createHash("md5").update(e).digest("hex")}a(eN,"md5");tN.exports={hash:H1,validate:x1}});var nN=R((pce,rN)=>{var Fm=rt(),Jt={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 F1(e){return Jt.password.presence=!0,Jt.username.presence=!0,Jt.role.presence=!0,Jt.active.presence=!0,Fm.validateObject(e,Jt)}a(F1,"addUserValidation");function q1(e){return Jt.password.presence=!1,Jt.username.presence=!0,Jt.role.presence=!1,Jt.active.presence=!1,Fm.validateObject(e,Jt)}a(q1,"alterUserValidation");function k1(e){return Jt.password.presence=!1,Jt.username.presence=!0,Jt.role.presence=!1,Jt.active.presence=!1,Fm.validateObject(e,Jt)}a(k1,"dropUserValidation");rN.exports={addUserValidation:F1,alterUserValidation:q1,dropUserValidation:k1}});var nt=R((gce,iN)=>{"use strict";var{platform:Tce}=require("os"),V1="nats-server.zip",qm="nats-server",$1=process.platform==="win32"?`${qm}.exe`:qm,Y1=/^[^\s.,*>]+$/,sN="__request__",K1=a(e=>`${e}.${sN}`,"REQUEST_SUBJECT"),W1={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},Q1={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},z1={HUB:"hub.pid",LEAF:"leaf.pid"},J1={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},X1={SUCCESS:"success",ERROR:"error"},j1={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},Z1={TXN:"txn",MSGID:"msgid"},Vo={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},eY={[Vo.ERR]:1,[Vo.WRN]:2,[Vo.INF]:3,[Vo.DBG]:4,[Vo.TRC]:5},tY={debug:"-D",trace:"-DVV"};iN.exports={NATS_SERVER_ZIP:V1,NATS_SERVER_NAME:qm,NATS_BINARY_NAME:$1,PID_FILES:z1,NATS_CONFIG_FILES:Q1,SERVER_SUFFIX:J1,NATS_TERM_CONSTRAINTS_RX:Y1,REQUEST_SUFFIX:sN,UPDATE_REMOTE_RESPONSE_STATUSES:X1,CLUSTER_STATUS_STATUSES:j1,REQUEST_SUBJECT:K1,SUBJECT_PREFIXES:Z1,MSG_HEADERS:W1,LOG_LEVELS:Vo,LOG_LEVEL_FLAGS:tY,LOG_LEVEL_HIERARCHY:eY}});var aN=R((Ace,oN)=>{"use strict";var rY={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
5
5
  `),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
6
6
  `)},nY="certificate.pem",sY="privateKey.pem",iY="ca.pem";oN.exports={CERTIFICATE_VALUES:rY,CERTIFICATE_PEM_NAME:nY,PRIVATEKEY_PEM_NAME:sY,CA_PEM_NAME:iY}});var Vm=R((bce,fN)=>{"use strict";var _N=require("fs-extra"),oe=require("joi"),oY=require("os"),{boolean:be,string:lr,number:Je,array:km}=oe.types(),{totalmem:cN}=require("os"),$i=require("path"),aY=K(),M_=Q(),Oce=aN(),uN=U(),cY=rt(),lN="log",uY="components",lY="Invalid logging.rotation.maxSize unit. Available units are G, M or K",_Y="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",dY="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",fY="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",EY="rootPath config parameter is undefined",hY="clustering.enabled config parameter is undefined",Yi=Je.min(0).required(),U_=km.items({host:lr.required(),port:Yi}).empty(null),Jn,dN=!1;fN.exports={configValidator:mY,routesValidator:AY,route_constraints:U_};function mY(e,t=!1){if(dN=t,Jn=e.rootPath,M_.isEmpty(Jn))throw EY;let r=be.required(),n=Je.min(0).max(1e3).empty(null).default(RY),s=lr.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(Bc),i=lr.optional().empty(null),o=lr.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null).required(),c=oe.string().empty(null).default(Bc),u=oe.custom(SY).empty(null).default(Bc),_=e.clustering?.enabled;if(M_.isEmpty(_))throw hY;let l=oe.object({certificate:i,certificateAuthority:i,privateKey:i}),d;return _===!0?d=oe.object({enabled:r,hubServer:oe.object({cluster:oe.object({name:oe.required().empty(null),network:oe.object({port:Yi,routes:U_}).required()}).required(),leafNodes:oe.object({network:oe.object({port:Yi}).required()}).required(),network:oe.object({port:Yi}).required()}).required(),leafServer:oe.object({network:oe.object({port:Yi,routes:U_}).required(),streams:oe.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:oe.valid("error","warn","info","debug","trace"),nodeName:o,republishMessages:be.optional(),databaseLevel:be.optional(),tls:oe.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:be.required(),verify:be.optional()}),user:lr.optional().empty(null)}).required():d=oe.object({enabled:r,tls:oe.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:be.required()})}).required(),oe.object({authentication:oe.object({authorizeLocal:be,cacheTTL:Je.required(),enableSessions:be}),analytics:oe.object({aggregatePeriod:Je}),componentsRoot:s.optional(),clustering:d,localStudio:oe.object({enabled:r}).required(),logging:oe.object({auditAuthEvents:oe.object({logFailed:be,logSuccessful:be}),file:be.required(),level:oe.valid("notify","fatal","error","warn","info","debug","trace"),rotation:oe.object({enabled:be.optional(),compress:be.optional(),interval:lr.custom(gY).optional().empty(null),maxSize:lr.custom(TY).optional().empty(null),path:lr.optional().empty(null).default(Bc)}).required(),root:s,stdStreams:be.required(),auditLog:be.required()}).required(),operationsApi:oe.object({network:oe.object({cors:be.optional(),corsAccessList:km.optional(),headersTimeout:Je.min(1).optional(),keepAliveTimeout:Je.min(1).optional(),port:Je.optional().empty(null),domainSocket:oe.optional().empty("hdb/operations-server").default(Bc),securePort:Je.optional().empty(null),timeout:Je.min(1).optional()}).optional(),tls:oe.alternatives([oe.array().items(l),l])}).required(),rootPath:lr.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path").required(),mqtt:oe.object({network:oe.object({port:Yi,securePort:Yi,mtls:oe.alternatives([be.optional(),oe.object({user:lr.optional(),certificateAuthority:i,required:be.optional()})])}).required(),webSocket:be.optional(),requireAuthentication:be.optional()}),http:oe.object({compressionThreshold:Je.optional(),cors:be.optional(),corsAccessList:km.optional(),headersTimeout:Je.min(1).optional(),port:Je.min(0).optional().empty(null),securePort:Je.min(0).optional().empty(null),maxHeaderSize:Je.optional(),mtls:oe.alternatives([be.optional(),oe.object({user:lr.optional(),certificateAuthority:i,required:be.optional()})])}).required(),threads:oe.alternatives(n.optional(),oe.object({count:n.optional(),debug:oe.alternatives(be.optional(),oe.object({startingPort:Je.min(1).optional(),host:lr.optional(),waitForDebugger:be.optional()})),maxHeapMemory:Je.min(0).optional()})),storage:oe.object({writeAsync:be.required(),overlappingSync:be.optional(),caching:be.optional(),compression:oe.alternatives([be.optional(),oe.object({dictionary:lr.optional(),threshold:Je.optional()})]),compactOnStart:be.optional(),compactOnStartKeepBackup:be.optional(),noReadAhead:be.optional(),path:u,prefetchWrites:be.optional(),maxFreeSpaceToLoad:Je.optional(),maxFreeSpaceToRetain:Je.optional()}).required(),ignoreScripts:be.optional(),tls:oe.alternatives([oe.array().items(l),l])}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(mY,"configValidator");function pY(e){return dN||_N.existsSync(e)?null:`Specified path ${e} does not exist.`}a(pY,"doesPathExist");function SY(e,t){oe.assert(e,lr.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=pY(e);if(r)return t.message(r)}a(SY,"validatePath");function TY(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(lY);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(dY):e}a(TY,"validateRotationMaxSize");function gY(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message(_Y);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(fY):e}a(gY,"validateRotationInterval");function RY(e,t){let r=t.state.path.join("."),n=oY.cpus().length,s=n-1;s<=2&&(s=2);let i=process.constrainedMemory?.()||cN();return i=Math.round(Math.min(i,cN())/1e6),s=Math.max(Math.min(s,Math.round((i-750)/300)),1),aY.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}a(RY,"setDefaultThreads");function Bc(e,t){let r=t.state.path.join(".");if(!M_.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if(M_.isEmpty(Jn))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return $i.join(Jn,uY);case"logging.root":return $i.join(Jn,lN);case"clustering.leafServer.streams.path":return $i.join(Jn,"clustering","leaf");case"storage.path":let n=$i.join(Jn,uN.LEGACY_DATABASES_DIR_NAME);return _N.existsSync(n)?n:$i.join(Jn,uN.DATABASES_DIR_NAME);case"logging.rotation.path":return $i.join(Jn,lN);case"operationsApi.network.domainSocket":return r==null?null:$i.join(Jn,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(Bc,"setDefaultRoot");function AY(e){let t=oe.object({routes:U_});return cY.validateBySchema({routes:e},t)}a(AY,"routesValidator")});var dr=R((Ice,AN)=>{"use strict";var xr=U(),Pt=Q(),bt=K(),{configValidator:OY,routesValidator:EN}=Vm(),_r=require("fs-extra"),bY=require("yaml"),wn=require("path"),yY=require("is-number"),mN=require("properties-reader"),NY=require("lodash"),{handleHDBError:IY}=ne(),{HTTP_STATUS_CODES:wY,HDB_ERROR_MSGS:P_}=Lr(),Nce=require("minimist"),{server:CY}=(ar(),ie(Ui)),{DATABASES_PARAM_CONFIG:Hc,CONFIG_PARAMS:Hr,CONFIG_PARAM_MAP:Cn}=xr,DY="Unable to get config value because config is uninitialized",LY="Config successfully initialized",MY="Error backing up config file",UY="Empty parameter sent to getConfigValue",pN=wn.join(xr.PACKAGE_ROOT,"config","yaml",xr.HDB_DEFAULT_CONFIG_FILE),PY="Configuration successfully set. You must restart HarperDB for new config settings to take effect.",hN={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"},v_,yt,B_;AN.exports={createConfigFile:vY,getDefaultConfig:BY,getConfigValue:TN,initConfig:Ym,flattenConfig:$o,updateConfigValue:gN,updateConfigObject:xY,getConfiguration:qY,setConfiguration:kY,readConfigFile:Wm,getClusteringRoutes:VY,initOldConfig:RN,getConfigFromFile:$Y,getConfigFilePath:Ki,addConfig:YY,deleteConfigFromFile:KY,getConfigObj:WY};function vY(e,t=!1){let r=ii(pN);v_=$o(r.toJSON());let n;for(let c in e){let u=Cn[c.toLowerCase()];if(u===Hr.DATABASES){Array.isArray(e[c])?n=e[c]:n=Object.keys(e[c]).map(_=>({[_]:e[c][_]}));continue}if(!u&&(c.endsWith("_package")||c.endsWith("_port"))&&(u=c),u!==void 0){let _=u.split("_"),l=$m(u,e[c]);u==="rootPath"&&l?.endsWith("/")&&(l=l.slice(0,-1));try{r.setIn([..._],l)}catch(d){bt.error(d)}}}n&&SN(r,n),Km(r,t);let s=r.toJSON();yt=$o(s);let i=r.getIn(["rootPath"]),o=wn.join(i,xr.HDB_CONFIG_FILE);_r.createFileSync(o),_r.writeFileSync(o,String(r)),bt.trace(`Config file written to ${o}`)}a(vY,"createConfigFile");function SN(e,t){let r;try{try{r=JSON.parse(t)}catch(n){if(!Pt.isObject(t))throw n;r=t}for(let n of r){let s=Object.keys(n)[0];if(n[s].hasOwnProperty(Hc.TABLES))for(let i in n[s][Hc.TABLES])for(let o in n[s][Hc.TABLES][i]){let c=n[s][Hc.TABLES][i][o],u=[Hr.DATABASES,s,Hc.TABLES,i,o];e.hasIn(u)?e.setIn(u,c):e.addIn(u,c)}else for(let i in n[s]){let o=n[s][i],c=[Hr.DATABASES,s,i];e.hasIn(c)?e.setIn(c,o):e.addIn(c,o)}}}catch(n){bt.error("Error parsing schemas CLI/env config arguments",n)}}a(SN,"setSchemasConfig");function BY(e){if(v_===void 0){let r=ii(pN);v_=$o(r.toJSON())}let t=Cn[e.toLowerCase()];if(t!==void 0)return v_[t.toLowerCase()]}a(BY,"getDefaultConfig");function TN(e){if(e==null){bt.error(UY);return}if(yt===void 0){bt.trace(DY);return}let t=Cn[e.toLowerCase()];if(t!==void 0)return yt[t.toLowerCase()]}a(TN,"getConfigValue");function Ki(e=Pt.getPropsFilePath()){let t=Pt.getEnvCliRootPath();return t?wn.join(t,xr.HDB_CONFIG_FILE):mN(e).get(xr.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY)}a(Ki,"getConfigFilePath");function Ym(e=!1){if(yt===void 0||e){let t;if(!Pt.noBootFile()){t=Pt.getPropsFilePath();try{_r.accessSync(t,_r.constants.F_OK|_r.constants.R_OK)}catch(i){throw bt.error(i),new Error(`HarperDB properties file at path ${t} does not exist`)}}let r=Ki(t),n;if(r.includes("config/settings.js"))try{RN(r);return}catch(i){if(i.code!==xr.NODE_ERROR_CODES.ENOENT)throw i}try{n=ii(r)}catch(i){if(i.code===xr.NODE_ERROR_CODES.ENOENT){bt.trace(`HarperDB config file not found at ${r}.
7
- This can occur during early stages of install where the config file has not yet been created`);return}else throw bt.error(i),new Error(`Error reading HarperDB config file at ${r}`)}HY(n,r),Km(n);let s=n.toJSON();if(CY.config=s,yt=$o(s),yt.logging_rotation_rotate)for(let i in hN)yt[i]&&bt.error(`Config ${hN[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);bt.trace(LY)}}a(Ym,"initConfig");function HY(e,t){let r=e.getIn(["rootPath"]),n=!1;e.hasIn(["storage","path"])||(e.setIn(["storage","path"],wn.join(r,"database")),n=!0),e.hasIn(["clustering","leafServer","streams","path"])||(e.setIn(["clustering","leafServer","streams","path"],wn.join(r,"clustering","leaf")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],wn.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&&(bt.trace("Updating config file with missing config params"),_r.writeFileSync(t,String(e)))}a(HY,"checkForUpdatedConfig");function Km(e,t=!1){let r=e.toJSON();r.componentsRoot=r.componentsRoot??r?.customFunctions?.root,r?.http?.threads&&(r.threads=r?.http?.threads);let n=OY(r,t);if(n.error)throw P_.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(Km,"validateConfig");function xY(e,t){yt===void 0&&(yt={});let r=Cn[e.toLowerCase()];if(r===void 0){bt.trace(`Unable to update config object because config param '${e}' does not exist`);return}yt[r.toLowerCase()]=t}a(xY,"updateConfigObject");function gN(e,t,r=void 0,n=!1,s=!1,i=!1){yt===void 0&&Ym();let o=TN(Cn.hdb_root),c=wn.join(o,xr.HDB_CONFIG_FILE),u=ii(c),_;if(r===void 0&&e.toLowerCase()===Hr.DATABASES)_=t;else if(r===void 0){let f;if(i)f=e;else if(f=Cn[e.toLowerCase()],f===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let E=f.split("_"),h=$m(f,t);u.setIn([...E],h)}else for(let f in r){let E=Cn[f.toLowerCase()];if(E===Hr.HTTP_SECUREPORT&&r[f]===yt[Hr.HTTP_PORT]?.toString()&&u.setIn(["http","port"],null),E===Hr.OPERATIONSAPI_NETWORK_SECUREPORT&&r[f]===yt[Hr.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&u.setIn(["operationsApi","network","port"],null),E===Hr.DATABASES){_=r[f];continue}if(E?.startsWith("threads_")){let h=u.getIn(["threads"]);h>=0&&(u.deleteIn(["threads"]),u.setIn(["threads","count"],h))}if(!E&&(f.endsWith("_package")||f.endsWith("_port"))&&(E=f),E!==void 0){let h=E.split("_"),S=xr.LEGACY_CONFIG_PARAMS[f.toUpperCase()];S&&S.startsWith("customFunctions")&&u.hasIn(S.split("_"))&&(E=S,h=S.split("_"));let p=$m(E,r[f]);E==="rootPath"&&p?.endsWith("/")&&(p=p.slice(0,-1));try{h.length>1&&typeof u.getIn(h.slice(0,-1))=="boolean"&&u.deleteIn(h.slice(0,-1)),u.setIn([...h],p)}catch(T){bt.error(T)}}}_&&SN(u,_),Km(u);let l=u.getIn(["rootPath"]),d=wn.join(l,xr.HDB_CONFIG_FILE);n===!0&&GY(c,l),_r.writeFileSync(d,String(u)),s&&(yt=$o(u.toJSON())),bt.trace(`Config parameter: ${e} updated with value: ${t}`)}a(gN,"updateConfigValue");function GY(e,t){try{let r=wn.join(t,"backup",`${xr.HDB_CONFIG_FILE}.bak`);_r.copySync(e,r),bt.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){bt.error(MY),bt.error(r)}}a(GY,"backupConfigFile");var FY=["databases"];function $o(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)),B_=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])&&!FY.includes(i)){let o=r(n[i]);for(let c in o){if(!o.hasOwnProperty(c))continue;c!=="package"&&(i=i.toLowerCase());let u=i+"_"+c;!Hr[u.toUpperCase()]&&Cn[u]&&(s[Cn[u].toLowerCase()]=o[c]),s[u]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a($o,"flattenConfig");function $m(e,t){if(e===Hr.CLUSTERING_NODENAME||e===Hr.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(yY(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||Pt.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 Pt.autoCast(t)}a($m,"castConfigValue");function qY(){let e=Pt.getPropsFilePath(),t=Ki(e);return ii(t).toJSON()}a(qY,"getConfiguration");async function kY(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return gN(void 0,void 0,s,!0),PY}catch(i){throw typeof i=="string"||i instanceof String?IY(i,i,wY.BAD_REQUEST,void 0,void 0,!0):i}}a(kY,"setConfiguration");function Wm(){let e=Pt.getPropsFilePath();try{_r.accessSync(e,_r.constants.F_OK|_r.constants.R_OK)}catch(n){if(!Pt.noBootFile())throw bt.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=Ki(e);return ii(t).toJSON()}a(Wm,"readConfigFile");function ii(e){return bY.parseDocument(_r.readFileSync(e,"utf8"),{simpleKeys:!0})}a(ii,"parseYamlDoc");function VY(){let e=Wm(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=Pt.isEmptyOrZeroLength(t)?[]:t;let r=EN(t);if(r)throw P_.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=Pt.isEmptyOrZeroLength(n)?[]:n;let s=EN(n);if(s)throw P_.CONFIG_VALIDATION(s.message);if(!Pt.isEmptyOrZeroLength(n)&&!Pt.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!Pt.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw P_.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(VY,"getClusteringRoutes");function RN(e){let t=mN(e);yt={};for(let r in Cn){let n=t.get(r.toUpperCase());if(Pt.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=Cn[r].toLowerCase();s===Hr.LOGGING_ROOT?yt[s]=wn.dirname(n):yt[s]=n}return yt}a(RN,"initOldConfig");function $Y(e){let t=Wm();return NY.get(t,e.replaceAll("_","."))}a($Y,"getConfigFromFile");async function YY(e,t){let r=ii(Ki());r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),await _r.writeFile(Ki(),String(r))}a(YY,"addConfig");function KY(e){let t=Ki(Pt.getPropsFilePath()),r=ii(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=wn.join(n,xr.HDB_CONFIG_FILE);_r.writeFileSync(s,String(r))}a(KY,"deleteConfigFromFile");function WY(){return B_||(Ym(),B_)}a(WY,"getConfigObj")});var bN=R((Cce,ON)=>{"use strict";var H_=U(),x_=class{static{a(this,"BaseLicense")}constructor(t=0,r=H_.RAM_ALLOCATION_ENUM.DEFAULT,n=H_.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},Qm=class extends x_{static{a(this,"ExtendedLicense")}constructor(t=0,r=H_.RAM_ALLOCATION_ENUM.DEFAULT,n=H_.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};ON.exports={BaseLicense:x_,ExtendedLicense:Qm}});var Wi=R((Lce,DN)=>{"use strict";var Ko=require("fs-extra"),NN=L_(),IN=require("crypto"),QY=require("moment"),zY=require("uuid").v4,Xt=K(),Jm=require("path"),JY=Q(),oi=U(),{totalmem:yN}=require("os"),XY=bN().ExtendedLicense,Yo="invalid license key format",jY="061183",ZY="mofi25",eK="aes-256-cbc",tK=16,rK=32,wN=te();wN.initSync();var zm;DN.exports={validateLicense:CN,generateFingerPrint:sK,licenseSearch:Zm,getLicense:aK,checkMemoryLimit:cK};function Xm(){return Jm.join(wN.getHdbBasePath(),oi.LICENSE_KEY_DIR_NAME,oi.LICENSE_FILE_NAME)}a(Xm,"getLicenseDirPath");function nK(){let e=Xm();return Jm.join(e,oi.LICENSE_FILE_NAME)}a(nK,"getLicenseFilePath");function jm(){let e=Xm();return Jm.join(e,oi.REG_KEY_FILE_NAME)}a(jm,"getFingerPrintFilePath");async function sK(){let e=jm();try{return await Ko.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await iK();throw Xt.error(`Error writing fingerprint file to ${e}`),Xt.error(t),new Error("There was an error generating the fingerprint")}}a(sK,"generateFingerPrint");async function iK(){let e=zY(),t=NN.hash(e),r=jm();try{await Ko.mkdirp(Xm()),await Ko.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw Xt.error(`Error writing fingerprint file to ${r}`),Xt.error(n),new Error("There was an error generating the fingerprint")}return t}a(iK,"writeFingerprint");function CN(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:oi.RAM_ALLOCATION_ENUM.DEFAULT,version:oi.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return Xt.error("empty license key passed to validate."),r;let n=jm(),s=!1;try{s=Ko.statSync(n)}catch(i){Xt.error(i)}if(s){let i;try{i=Ko.readFileSync(n,"utf8")}catch{Xt.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(ZY),c=o[1];c=Buffer.concat([Buffer.from(c)],tK);let u=Buffer.concat([Buffer.from(i)],rK),_=IN.createDecipheriv(eK,u,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let l=null;try{l=_.update(o[0],"hex","utf8"),l.trim(),l+=_.final("utf8")}catch{let E=oK(o[0],i);if(E)l=E;else throw r.valid_license=!1,r.valid_machine=!1,console.error(Yo),Xt.error(Yo),new Error(Yo)}let d;if(isNaN(l))try{d=JSON.parse(l),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(Yo),Xt.error(Yo),new Error(Yo)}else r.exp_date=l;r.exp_date<QY().valueOf()&&(r.valid_date=!1),NN.validate(o[1],`${jY}${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||Xt.error("Invalid licence"),r}a(CN,"validateLicense");function oK(e,t){try{let r=IN.createDecipher("aes192",t),n=r.update(e,"hex","utf8");return n.trim(),n+=r.final("utf8"),n}catch{Xt.warn("Check old license failed")}}a(oK,"checkOldLicense");function Zm(){let e=new XY,t=[];try{t=Ko.readFileSync(nK(),"utf-8").split(oi.NEW_LINE)}catch(r){r.code==="ENOENT"?Xt.info("no license file found"):Xt.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if(JY.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=CN(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){Xt.error("There was an error parsing the license string."),Xt.error(s),e.ram_allocation=oi.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return zm=e,e}a(Zm,"licenseSearch");async function aK(){return zm||await Zm(),zm}a(aK,"getLicense");function cK(){let e=Zm().ram_allocation,t=process.constrainedMemory?.()||yN();if(t=Math.round(Math.min(t,yN())/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(cK,"checkMemoryLimit")});var un=R((Bce,KN)=>{"use strict";var PN="username is required",vN="nothing to update, must supply active, role or password to update",BN="password cannot be an empty string",HN="If role is specified, it cannot be empty.",xN="active must be true or false";KN.exports={addUser:pK,alterUser:SK,dropUser:gK,getSuperUser:bK,userInfo:RK,listUsers:F_,listUsersExternal:AK,setUsersToGlobal:Qo,findAndValidateUser:$N,getClusterUser:yK,USERNAME_REQUIRED:PN,ALTERUSER_NOTHING_TO_UPDATE:vN,EMPTY_PASSWORD:BN,EMPTY_ROLE:HN,ACTIVE_BOOLEAN:xN};var GN=cn(),uK=Vi(),rp=L_(),FN=nN(),qN=Br(),np=Rs(),Gr=Q(),kN=require("validate.js"),Oe=K(),{promisify:lK}=require("util"),sp=gs(),LN=U(),MN=nt(),_K=dr(),Uce=te(),Pce=Wi(),dK=Hi(),{table:vce}=(Ae(),ie(qe)),{handleHDBError:Xn,hdb_errors:fK}=ne(),{HTTP_STATUS_CODES:jn,AUTHENTICATION_ERROR_MSGS:ep,HDB_ERROR_MSGS:Wo}=fK,{UserEventMsg:ip}=Dn(),tp=require("lodash"),{server:op}=(ar(),ie(Ui)),EK=K();op.getUser=(e,t)=>$N(e,t,t!=null);var VN={username:!0,active:!0,role:!0,password:!0},UN=new Map,G_=qN.searchByValue,hK=qN.searchByHash,mK=lK(uK.delete);async function pK(e){let t=kN.cleanAttributes(e,VN),r=FN.addUserValidation(t);if(r)throw Xn(new Error,r.message,jn.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 G_(n),s=s&&Array.from(s)}catch(u){throw Oe.error("There was an error searching for a role in add user"),Oe.error(u),u}if(!s||s.length<1)throw Xn(new Error,Wo.ROLE_NAME_NOT_FOUND(t.role),jn.NOT_FOUND,void 0,void 0,!0);if(s.length>1)throw Xn(new Error,Wo.DUP_ROLES_FOUND(t.role),jn.CONFLICT,void 0,void 0,!0);s[0].permission.cluster_user===!0&&(t.hash=sp.encrypt(t.password)),t.password=rp.hash(t.password),t.role=s[0].id;let i={operation:"insert",schema:"system",table:"hdb_user",records:[t]},o;try{o=await GN.insert(i)}catch(u){throw Oe.error("There was an error searching for a user."),Oe.error(u),u}Oe.debug(o);try{await Qo()}catch(u){throw Oe.error("Got an error setting users to global"),Oe.error(u),u}if(o.skipped_hashes.length===1)throw Xn(new Error,Wo.USER_ALREADY_EXISTS(t.username),jn.CONFLICT,void 0,void 0,!0);let c=Object.assign({},t);return c.role=s[0],np.signalUserChange(new ip(process.pid)),`${c.username} successfully added`}a(pK,"addUser");async function SK(e){let t=kN.cleanAttributes(e,VN);if(Gr.isEmptyOrZeroLength(t.username))throw new Error(PN);if(Gr.isEmptyOrZeroLength(t.password)&&Gr.isEmptyOrZeroLength(t.role)&&Gr.isEmptyOrZeroLength(t.active))throw new Error(vN);if(!Gr.isEmpty(t.password)&&Gr.isEmptyOrZeroLength(t.password.trim()))throw new Error(BN);if(!Gr.isEmpty(t.active)&&!Gr.isBoolean(t.active))throw new Error(xN);let r=TK(t.username);if(!Gr.isEmpty(t.password)&&!Gr.isEmptyOrZeroLength(t.password.trim())&&(r&&(t.hash=sp.encrypt(t.password)),t.password=rp.hash(t.password)),t.role==="")throw new Error(HN);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 G_(i)||[])}catch(c){throw Oe.error("Got an error searching for a role."),Oe.error(c),c}if(!o||o.length===0){let c=Wo.ALTER_USER_ROLE_NOT_FOUND(t.role);throw Oe.error(c),Xn(new Error,c,jn.NOT_FOUND,void 0,void 0,!0)}if(o.length>1){let c=Wo.ALTER_USER_DUP_ROLES(t.role);throw Oe.error(c),Xn(new Error,c,jn.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 GN.update(n)}catch(i){throw Oe.error("Error during update."),Oe.error(i),i}try{await Qo()}catch(i){throw Oe.error("Got an error setting users to global"),Oe.error(i),i}return np.signalUserChange(new ip(process.pid)),s}a(SK,"alterUser");function TK(e){let t=!1,r=global.hdb_users.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(TK,"isClusterUser");async function gK(e){try{let t=FN.dropUserValidation(e);if(t)throw new Error(t);let r={table:"hdb_user",schema:"system",hash_values:[e.username]};if(Gr.isEmpty(global.hdb_users.get(e.username)))throw Xn(new Error,Wo.USER_NOT_EXIST(e.username),jn.NOT_FOUND,void 0,void 0,!0);let n;try{n=await mK(r)}catch(s){throw Oe.error("Got an error deleting a user."),Oe.error(s),s}Oe.debug(n);try{await Qo()}catch(s){throw Oe.error("Got an error setting users to global."),Oe.error(s),s}return np.signalUserChange(new ip(process.pid)),`${e.username} successfully deleted`}catch(t){throw t}}a(gK,"dropUser");async function RK(e){let t={};try{if(!e||!e.hdb_user)return"There was no user info in the body";t=tp.cloneDeep(e.hdb_user);let r={schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]},n;try{n=await hK(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(RK,"userInfo");async function AK(){let e;try{e=await F_()}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(AK,"listUsersExternal");async function F_(){try{let e={schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]},t;try{t=await G_(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]=tp.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 G_(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=tp.cloneDeep(o),o.role=r[o.role],OK(o.role),i.set(o.username,o);return i}catch(e){throw Oe.error("got an error listing users"),Oe.error(e),Gr.errorizeMessage(e)}return null}a(F_,"listUsers");function OK(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(dK)){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(OK,"appendSystemTablesToRole");async function Qo(){try{let e=await F_();global.hdb_users=e}catch(e){throw Oe.error(e),e}}a(Qo,"setUsersToGlobal");async function $N(e,t,r=!0){global.hdb_users||await Qo();let n=global.hdb_users.get(e);if(!n){if(!r)return{username:e};throw Xn(new Error,ep.GENERIC_AUTH_FAIL,jn.UNAUTHORIZED,void 0,void 0,!0)}if(n&&!n.active)throw Xn(new Error,ep.USER_INACTIVE,jn.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(UN.get(t)===n.password)return s;if(rp.validate(n.password,t))UN.set(t,n.password);else throw Xn(new Error,ep.GENERIC_AUTH_FAIL,jn.UNAUTHORIZED,void 0,void 0,!0)}return s}a($N,"findAndValidateUser");async function bK(){global.hdb_users||await Qo();for(let[,e]of global.hdb_users)if(e.role.role==="super_user")return e}a(bK,"getSuperUser");async function yK(){let e=await F_(),t=_K.getConfigFromFile(LN.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!Gr.isEmpty(r)&&r?.role?.role===LN.ROLE_TYPES_ENUM.CLUSTER_USER)return r.decrypt_hash=sp.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+MN.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+MN.SERVER_SUFFIX.ADMIN,r}a(yK,"getClusterUser");var YN=[];op.invalidateUser=function(e){for(let t of YN)try{t(e)}catch(r){EK.error("Error invalidating user",r)}};op.onInvalidatedUser=function(e){YN.push(e)}});var Gc=R((Fce,JN)=>{"use strict";var Qi=K(),Fr=U(),NK=by(),xce=ri(),Gce=ti(),IK=un(),{validateEvent:WN}=Dn(),xc=In(),wK=require("process"),{resetDatabases:CK}=(Ae(),ie(qe)),DK={[Fr.ITC_EVENT_TYPES.SCHEMA]:LK,[Fr.ITC_EVENT_TYPES.USER]:zN};async function LK(e){let t=WN(e);if(t){Qi.error(t);return}Qi.trace("ITC schemaHandler received schema event:",e),await NK(e.message),await MK(e.message)}a(LK,"schemaHandler");async function MK(e){try{xc.resetReadTxn(Fr.SYSTEM_SCHEMA_NAME,Fr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),xc.resetReadTxn(Fr.SYSTEM_SCHEMA_NAME,Fr.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),xc.resetReadTxn(Fr.SYSTEM_SCHEMA_NAME,Fr.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=CK();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){Qi.error(t)}}a(MK,"syncSchemaMetadata");var QN=[];async function zN(e){try{try{xc.resetReadTxn(Fr.SYSTEM_SCHEMA_NAME,Fr.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),xc.resetReadTxn(Fr.SYSTEM_SCHEMA_NAME,Fr.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){Qi.warn(r)}let t=WN(e);if(t){Qi.error(t);return}Qi.trace(`ITC userHandler ${Fr.HDB_ITC_CLIENT_PREFIX}${wK.pid} received user event:`,e),await IK.setUsersToGlobal();for(let r of QN)r()}catch(t){Qi.error(t)}}a(zN,"userHandler");zN.addListener=function(e){QN.push(e)};JN.exports=DK});var Dn=R((Kce,jN)=>{"use strict";var kce=K(),ap=Q(),UK=U(),{ITC_ERRORS:Fc}=Lr(),{parentPort:Vce,threadId:PK,isMainThread:vK,workerData:$ce}=require("worker_threads"),{onMessageFromWorkers:BK,broadcast:Yce,broadcastWithAcknowledgement:HK}=ct();jN.exports={sendItcEvent:xK,validateEvent:XN,SchemaEventMsg:GK,UserEventMsg:FK};var q_;BK(async(e,t)=>{q_=q_||Gc(),XN(e),q_[e.type]&&await q_[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function xK(e){return!vK&&e.message&&(e.message.originator=PK),HK(e)}a(xK,"sendItcEvent");function XN(e){if(typeof e!="object")return Fc.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||ap.isEmpty(e.type))return Fc.MISSING_TYPE;if(!e.hasOwnProperty("message")||ap.isEmpty(e.message))return Fc.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||ap.isEmpty(e.message.originator))return Fc.MISSING_ORIGIN;if(UK.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return Fc.INVALID_EVENT(e.type)}a(XN,"validateEvent");function GK(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(GK,"SchemaEventMsg");function FK(e){this.originator=e}a(FK,"UserEventMsg")});var Rs=R((zce,rI)=>{"use strict";var ZN=U(),Qce=Q(),k_=K(),eI=Ry(),zo,{sendItcEvent:tI}=Dn();function qK(e){try{k_.trace("signalSchemaChange called with message:",e),zo=zo||Gc();let t=new eI(ZN.ITC_EVENT_TYPES.SCHEMA,e);return zo.schema(t),tI(t)}catch(t){k_.error(t)}}a(qK,"signalSchemaChange");function kK(e){try{k_.trace("signalUserChange called with message:",e),zo=zo||Gc();let t=new eI(ZN.ITC_EVENT_TYPES.USER,e);return zo.user(t),tI(t)}catch(t){k_.error(t)}}a(kK,"signalUserChange");rI.exports={signalSchemaChange:qK,signalUserChange:kK}});var V_=R((Xce,sI)=>{"use strict";var nI=Q(),VK=U(),$K=K(),YK=p_(),KK=m_(),WK=Rs(),{SchemaEventMsg:QK}=Dn(),zK="already exists in";sI.exports=JK;async function JK(e,t,r){if(nI.isEmptyOrZeroLength(r))return r;let n=[];nI.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 XK(e,t.schema,t.name,i)})),s}a(JK,"lmdbCheckForNewAttributes");async function XK(e,t,r,n){let s=new KK(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await jK(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(zK))$K.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(XK,"createNewAttribute");async function jK(e){let t;return t=await YK(e),WK.signalSchemaChange(new QK(process.pid,VK.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(jK,"createAttribute")});var Jo=R((Zce,iI)=>{"use strict";var cp=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}};iI.exports=cp});var aI=R((tue,oI)=>{"use strict";var ZK=Jo(),eW=U().OPERATIONS_ENUM,up=class extends ZK{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(eW.INSERT,r,n,s,i),this.records=t}};oI.exports=up});var uI=R((nue,cI)=>{"use strict";var tW=Jo(),rW=U().OPERATIONS_ENUM,lp=class extends tW{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(rW.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};cI.exports=lp});var _I=R((iue,lI)=>{"use strict";var nW=Jo(),sW=U().OPERATIONS_ENUM,_p=class extends nW{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}};lI.exports=_p});var fI=R((aue,dI)=>{"use strict";var iW=Jo(),oW=U().OPERATIONS_ENUM,dp=class extends iW{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(oW.DELETE,n,s,t,i),this.original_records=r}};dI.exports=dp});var qc=R((lue,pI)=>{"use strict";var uue=require("path"),EI=Ye(),aW=aI(),cW=uI(),uW=_I(),lW=fI(),Xo=at(),hI=Q(),{CONFIG_PARAMS:_W}=U(),mI=te();mI.initSync();var $_=U().OPERATIONS_ENUM,{getTransactionAuditStorePath:dW}=Qe();pI.exports=fW;async function fW(e,t){if(mI.get(_W.LOGGING_AUDITLOG)===!1)return;let r=dW(e.schema,e.table),n=await EI.openEnvironment(r,e.table,!0),s=EW(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){EI.initializeDBIs(n,Xo.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Xo.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[Xo.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[Xo.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),hI.isEmpty(s.user_name)||n.dbis[Xo.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[Xo.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(fW,"writeTransaction");function EW(e,t){let r=hI.isEmpty(e.hdb_user)?void 0:e.hdb_user.username;if(e.operation===$_.INSERT)return new aW(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===$_.UPDATE)return new cW(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===$_.UPSERT)return new uW(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===$_.DELETE)return new lW(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(EW,"createTransactionObject")});var fp=R((fue,SI)=>{"use strict";var hW=Mc(),due=Uc(),kc=U(),mW=Pc(),pW=qo().insertRecords,SW=Ye(),TW=K(),gW=V_(),{getSchemaPath:RW}=Qe(),AW=qc();SI.exports=OW;async function OW(e){try{let{schema_table:t,attributes:r}=hW(e);mW(e,r,t.hash_attribute),e.schema!==kc.SYSTEM_SCHEMA_NAME&&(r.includes(kc.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(kc.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(kc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(kc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await gW(e.hdb_auth_header,t,r),s=RW(e.schema,e.table),i=await SW.openEnvironment(s,e.table),o=await pW(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await AW(e,o)}catch(c){TW.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(OW,"lmdbCreateRecords")});var RI=R((hue,gI)=>{"use strict";var TI=U(),bW=fp(),yW=Uc(),NW=require("fs-extra"),{getSchemaPath:IW}=Qe();gI.exports=wW;async function wW(e){let t=[{name:e.schema,createddate:Date.now()}],r=new yW(TI.SYSTEM_SCHEMA_NAME,TI.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await bW(r),await NW.mkdirp(IW(e.schema))}a(wW,"lmdbCreateSchema")});var OI=R((pue,AI)=>{"use strict";var Ep=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}};AI.exports=Ep});var II=R((Aue,NI)=>{"use strict";var bI=Ye(),hp=Mr(),mp=Lr().LMDB_ERRORS_ENUM,CW=at(),yI=K(),Tue=Q(),DW=require("lmdb"),LW=OI(),MW=U(),{OVERFLOW_MARKER:gue,MAX_SEARCH_KEY_LENGTH:Rue}=CW,UW=MW.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function PW(e,t,r,n){if(hp.validateEnv(e),t===void 0)throw new Error(mp.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(mp.IDS_REQUIRED):new Error(mp.IDS_MUST_BE_ITERABLE);try{let s=bI.listDBIs(e);bI.initializeDBIs(e,t,s);let i=new LW,o,c=[],u=[];for(let f=0,E=r.length;f<E;f++)try{o=r[f];let h=e.dbis[t].get(o);if(!h||n&&h[UW]>n){i.skipped.push(o);continue}let S=e.dbis[t].ifVersion(o,DW.IF_EXISTS,()=>{e.dbis[t].remove(o);for(let p=0;p<s.length;p++){let T=s[p];if(!h.hasOwnProperty(T)||T===t)continue;let A=e.dbis[T],g=h[T];if(g!=null)try{let L=hp.getIndexedValues(g);if(L)for(let v=0,P=L.length;v<P;v++)A.remove(L[v],o)}catch{yI.warn(`cannot delete from attribute: ${T}, ${g}:${o}`)}}});c.push(S),u.push(o),i.original_records.push(h)}catch(h){yI.warn(h),i.skipped.push(o)}let _=[],l=await Promise.all(c);for(let f=0,E=l.length;f<E;f++)l[f]===!0?i.deleted.push(u[f]):(i.skipped.push(u[f]),_.push(f));let d=0;for(let f=0;f<_.length;f++){let E=_[f];i.original_records.splice(E-d,1),d++}return i.txn_time=hp.getNextMonotonicTime(),i}catch(s){throw s}}a(PW,"deleteRecords");NI.exports={deleteRecords:PW}});var Vc=R((bue,CI)=>{"use strict";var jo=Q(),vW=II(),BW=Ye(),{getSchemaPath:HW}=Qe(),xW=qc(),GW=K();CI.exports=FW;async function FW(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(jo.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(jo.isEmptyOrZeroLength(e.hash_values)&&!jo.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let u=e.records[c][n];jo.isEmpty(u)||e.hash_values.push(u)}}if(jo.isEmptyOrZeroLength(e.hash_values))return wI([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(jo.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=HW(e.schema,e.table),i=await BW.openEnvironment(s,e.table),o=await vW.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await xW(e,o)}catch(c){GW.error(`unable to write transaction due to ${c.message}`)}return wI(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(FW,"lmdbDeleteRecords");function wI(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(wI,"createDeleteResponse")});var Sp=R((Iue,DI)=>{"use strict";var qW=U(),Nue=Mr();function pp(e,t){let r=Object.create(null);if(t.length===1&&qW.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(pp,"parseRow");function kW(e,t,r,n){let s=pp(r,e);n.push(s)}a(kW,"searchAll");function VW(e,t,r,n){let s=pp(r,e);n[t]=s}a(VW,"searchAllToMap");function $W(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a($W,"iterateDBI");function zi(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(zi,"pushResults");function YW(e,t,r,n,s,i){t.toString().endsWith(e)&&zi(t,r,n,s,i)}a(YW,"endsWith");function KW(e,t,r,n,s,i){t.toString().includes(e)&&zi(t,r,n,s,i)}a(KW,"contains");function WW(e,t,r,n,s,i){t>e&&zi(t,r,n,s,i)}a(WW,"greaterThanCompare");function QW(e,t,r,n,s,i){t>=e&&zi(t,r,n,s,i)}a(QW,"greaterThanEqualCompare");function zW(e,t,r,n,s,i){t<e&&zi(t,r,n,s,i)}a(zW,"lessThanCompare");function JW(e,t,r,n,s,i){t<=e&&zi(t,r,n,s,i)}a(JW,"lessThanEqualCompare");DI.exports={parseRow:pp,searchAll:kW,searchAllToMap:VW,iterateDBI:$W,endsWith:YW,contains:KW,greaterThanCompare:WW,greaterThanEqualCompare:QW,lessThanCompare:zW,lessThanEqualCompare:JW,pushResults:zi}});var Zo=R((Mue,HI)=>{"use strict";var ai=Ye(),Cue=K(),qr=Mr(),Y_=at(),lt=Lr().LMDB_ERRORS_ENUM,Due=Q(),XW=U(),K_=Sp(),{parseRow:jW}=K_,Lue=require("lmdb"),{OVERFLOW_MARKER:LI,MAX_SEARCH_KEY_LENGTH:ZW}=Y_;function MI(e,t,r,n=!1,s=void 0,i=void 0){return Ji(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(MI,"iterateFullIndex");function $c(e,t,r,n,s,i=!1,o=void 0,c=void 0,u=!1,_=!1){return Ji(e,t,r,(l,d,f,E)=>{let A={transaction:l,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!u:!_,exclusiveStart:i===!0?_:u};return E===r?(A.values=!1,d.getRange(A).map(g=>({value:g}))):d.getRange(A)})}a($c,"iterateRangeBetween");function Ji(e,t,r,n){let s=e.database||e,i=ai.openDBI(s,r);i[Y_.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&ai.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(Ji,"setupTransaction");function UI(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(LI)){if(!s)if(r)s=ai.openDBI(e,r);else{let u=ai.listDBIs(e);for(let _=0,l=u.length;_<l&&(s=ai.openDBI(e,u[_]),!s[Y_.DBI_DEFINITION_NAME].is_hash_attribute);_++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(UI,"getOverflowCheck");function eQ(e,t,r,n=!1,s=void 0,i=void 0){if(qr.validateEnv(e),t===void 0)throw new Error(lt.HASH_ATTRIBUTE_REQUIRED);return Ji(e,t,t,(o,c,u)=>(W_(r),r=Yc(u,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(_=>jW(_.value,r))))}a(eQ,"searchAll");function tQ(e,t,r,n=!1,s=void 0,i=void 0){if(qr.validateEnv(e),t===void 0)throw new Error(lt.HASH_ATTRIBUTE_REQUIRED);W_(r),r=Yc(e.database||e,r);let o=new Map;for(let{key:c,value:u}of MI(e,t,t,n,s,i))o.set(c,K_.parseRow(u,r));return o}a(tQ,"searchAllToMap");function rQ(e,t,r=!1,n=void 0,s=void 0){if(qr.validateEnv(e),t===void 0)throw new Error(lt.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=MI(e,void 0,t,r,n,s),c=o.transaction,u=UI(c.database,c,void 0,t);for(let{key:_,value:l}of o){let d=u(_,l);i[d]===void 0&&(i[d]=[]),i[d].push(l)}return i}a(rQ,"iterateDBI");function nQ(e,t){if(qr.validateEnv(e),t===void 0)throw new Error(lt.HASH_ATTRIBUTE_REQUIRED);return ai.statDBI(e,t).entryCount}a(nQ,"countAll");function sQ(e,t,r,n,s=!1,i=void 0,o=void 0){return ci(e,r,n),Ji(e,t,r,(c,u,_,l)=>(n=qr.convertKeyValueToWrite(n),l===r?u.get(n,{transaction:c,lazy:!0})===void 0?[]:[{key:n,value:n}]:u.getValues(n,{transaction:c,reverse:s,limit:i,offset:o}).map(d=>({key:n,value:d}))))}a(sQ,"equals");function iQ(e,t,r){return ci(e,t,r),ai.openDBI(e,t).getValuesCount(r)}a(iQ,"count");function oQ(e,t,r,n,s=!1,i=void 0,o=void 0){return ci(e,r,n),Ji(e,null,r,(c,u)=>{n=qr.convertKeyValueToWrite(n);let _=!0;typeof n=="number"&&(_=!1);let l;if(s===!0){let d;for(let f of u.getKeys({transaction:c,start:n}))if(!f.startsWith(n)){d=f;break}return d!==void 0&&(Number.isInteger(o)?o++:i++),l=u.getRange({transaction:c,start:d,end:void 0,reverse:s,limit:i,offset:o}).map(f=>{let{key:E}=f;if(E!==d){if(E.toString().startsWith(n))return f;if(_===!0)return l.DONE}}),l.filter(f=>f)}else return l=u.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(d=>{if(d.key.toString().startsWith(n))return d;if(_===!0)return l.DONE}),_?l:l.filter(d=>d)})}a(oQ,"startsWith");function aQ(e,t,r,n,s=!1,i=void 0,o=void 0){return PI(e,t,r,n,s,i,o,!0)}a(aQ,"endsWith");function PI(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return ci(e,r,n),Ji(e,null,r,(u,_,l,d)=>{let f=UI(l,u,d,r);return o=Number.isInteger(o)?o:0,_.getKeys({transaction:u,end:s?!1:void 0,reverse:s}).flatMap(E=>{let h=E.toString();return h.endsWith(LI)?_.getValues(E,{transaction:u}).map(S=>{let p=f(E,S);if(c?p.endsWith(n):p.includes(n))return{key:p,value:S}}).filter(S=>S):(c?h.endsWith(n):h.includes(n))?_[Y_.DBI_DEFINITION_NAME].is_hash_attribute?{key:E,value:E}:_.getValues(E,{transaction:u}).map(S=>({key:E,value:S})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a(PI,"contains");function cQ(e,t,r,n,s=!1,i=void 0,o=void 0){ci(e,r,n);let c=typeof n,u;return c==="string"?u="\uFFFF":c==="number"?u=1/0:c==="boolean"&&(u=!0),$c(e,t,r,n,u,s,i,o,!0,!1)}a(cQ,"greaterThan");function uQ(e,t,r,n,s=!1,i=void 0,o=void 0){ci(e,r,n);let c=typeof n,u;return c==="string"?u="\uFFFF":c==="number"?u=1/0:c==="boolean"&&(u=!0),$c(e,t,r,n,u,s,i,o,!1,!1)}a(uQ,"greaterThanEqual");function lQ(e,t,r,n,s=!1,i=void 0,o=void 0){ci(e,r,n);let c=typeof n,u;return c==="string"?u="\0":c==="number"?u=-1/0:c==="boolean"&&(u=!1),$c(e,t,r,u,n,s,i,o,!1,!0)}a(lQ,"lessThan");function _Q(e,t,r,n,s=!1,i=void 0,o=void 0){ci(e,r,n);let c=typeof n,u;return c==="string"?u="\0":c==="number"?u=-1/0:c==="boolean"&&(u=!1),$c(e,t,r,u,n,s,i,o,!1,!1)}a(_Q,"lessThanEqual");function dQ(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(qr.validateEnv(e),r===void 0)throw new Error(lt.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(lt.START_VALUE_REQUIRED);if(s===void 0)throw new Error(lt.END_VALUE_REQUIRED);if(n=qr.convertKeyValueToWrite(n),s=qr.convertKeyValueToWrite(s),n>s)throw new Error(lt.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return $c(e,t,r,n,s,i,o,c)}a(dQ,"between");function fQ(e,t,r,n){qr.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(lt.HASH_ATTRIBUTE_REQUIRED);if(W_(r),r=Yc(s,r),n===void 0)throw new Error(lt.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=K_.parseRow(c,r)),o}a(fQ,"searchByHash");function EQ(e,t,r){qr.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(lt.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(lt.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(EQ,"checkHashExists");function hQ(e,t,r,n,s=[]){return BI(e,t,r,n,s),vI(e,t,r,n,s).map(i=>i[1])}a(hQ,"batchSearchByHash");function mQ(e,t,r,n,s=[]){BI(e,t,r,n,s);let i=new Map;for(let[o,c]of vI(e,t,r,n,s))i.set(o,c);return i}a(mQ,"batchSearchByHashToMap");function vI(e,t,r,n,s=[]){return Ji(e,t,t,(i,o,c)=>{r=Yc(c,r);let u=r.length<3;return n.map(_=>{let l=c.dbis[t].get(_,{transaction:i,lazy:u});if(l)return[_,K_.parseRow(l,r)];s.push(_)}).filter(_=>_)})}a(vI,"batchHashSearch");function BI(e,t,r,n,s){if(qr.validateEnv(e),t===void 0)throw new Error(lt.HASH_ATTRIBUTE_REQUIRED);if(W_(r),n==null)throw new Error(lt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(lt.IDS_MUST_BE_ITERABLE)}a(BI,"initializeBatchSearchByHash");function W_(e){if(!Array.isArray(e))throw e===void 0?new Error(lt.FETCH_ATTRIBUTES_REQUIRED):new Error(lt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(W_,"validateFetchAttributes");function ci(e,t,r){if(qr.validateEnv(e),t===void 0)throw new Error(lt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(lt.SEARCH_VALUE_REQUIRED);if(r?.length>ZW)throw new Error(lt.SEARCH_VALUE_TOO_LARGE)}a(ci,"validateComparisonFunctions");function Yc(e,t){return t.length===1&&XW.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=ai.listDBIs(e)),t}a(Yc,"setGetWholeRowAttributes");HI.exports={searchAll:eQ,searchAllToMap:tQ,count:iQ,countAll:nQ,equals:sQ,startsWith:oQ,endsWith:aQ,contains:PI,searchByHash:fQ,setGetWholeRowAttributes:Yc,batchSearchByHash:hQ,batchSearchByHashToMap:mQ,checkHashExists:EQ,iterateDBI:rQ,greaterThan:cQ,greaterThanEqual:uQ,lessThan:lQ,lessThanEqual:_Q,between:dQ}});var ea=R((Pue,kI)=>{var xI=require("lodash"),GI=rt(),fe=require("joi"),pQ=Q(),{hdb_schema_table:Kc,checkValidTable:FI,hdb_table:qI,hdb_database:Q_}=Qn(),{handleHDBError:SQ,hdb_errors:TQ}=ne(),{getDatabases:gQ}=(Ae(),ie(qe)),{HTTP_STATUS_CODES:RQ}=TQ,AQ=fe.object({database:Q_,schema:Q_,table:qI,search_attribute:Kc,search_value:fe.any().required(),get_attributes:fe.array().min(1).items(fe.alternatives(Kc,fe.object())).optional(),desc:fe.bool(),limit:fe.number().integer().min(1),offset:fe.number().integer().min(0)}),OQ=fe.object({database:Q_,schema:Q_,table:qI,operator:fe.string().valid("and","or").default("and").lowercase(),offset:fe.number().integer().min(0),limit:fe.number().integer().min(1),get_attributes:fe.array().min(1).items(fe.alternatives(Kc,fe.object())).optional(),sort:fe.object({attribute:fe.alternatives(Kc,fe.array().min(1)),descending:fe.bool().optional()}).optional(),conditions:fe.array().min(1).items(fe.alternatives(fe.object({operator:fe.string().valid("and","or").default("and").lowercase(),conditions:fe.array()}),fe.object({search_attribute:fe.alternatives(Kc,fe.array().min(1)),search_type:fe.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:fe.when("search_type",{switch:[{is:"equals",then:fe.any()},{is:"between",then:fe.array().items(fe.alternatives([fe.string(),fe.number()])).length(2)}],otherwise:fe.alternatives(fe.string(),fe.number())}).required()}))).required()});kI.exports=function(e,t){let r=null;switch(t){case"value":r=GI.validateBySchema(e,AQ);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(FI("database",e.schema)),i(FI("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=GI.validateBySchema(e,OQ);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=pQ.checkGlobalSchemaTable(e.schema,e.table);if(s)return SQ(new Error,s,RQ.NOT_FOUND);let o=gQ()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let u=a(l=>{for(let d=0,f=l.conditions.length;d<f;d++){let E=l.conditions[d];E.conditions?u(E):c.push(E.search_attribute)}},"addConditions");t==="conditions"&&u(e);let _=xI.filter(c,l=>l!=="*"&&l.attribute!=="*"&&!Array.isArray(l)&&!l.name&&!xI.some(o,d=>d===l||d.attribute===l||d.attribute===l.attribute));if(_&&_.length>0){let l=_.join(", ");return l=l.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${l}'`)}}return r}});var Tp=R((Bue,VI)=>{"use strict";var bQ=Ye(),yQ=ea(),{getSchemaPath:NQ}=Qe();VI.exports=IQ;function IQ(e){let t=yQ(e,"hashes");if(t)throw t;let r=NQ(e.schema,e.table);return bQ.openEnvironment(r,e.table)}a(IQ,"initialize")});var gp=R((xue,$I)=>{"use strict";var wQ=Zo(),CQ=Tp();$I.exports=DQ;async function DQ(e){let t=await CQ(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return wQ.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(DQ,"lmdbGetDataByHash")});var ta=R((Fue,YI)=>{"use strict";var Rp=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};YI.exports=Rp});var WI=R((Vue,KI)=>{"use strict";var kue=ta(),LQ=Zo(),MQ=Tp();KI.exports=UQ;async function UQ(e){let t=await MQ(e),r=global.hdb_schema[e.schema][e.table];return LQ.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(UQ,"lmdbSearchByHash")});var Zn=R((Yue,QI)=>{"use strict";var Ap=class{static{a(this,"SearchObject")}constructor(t,r,n,s,i,o,c,u=!1,_=void 0,l=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=u,this.limit=_,this.offset=l}};QI.exports=Ap});var z_=R((Wue,ew)=>{"use strict";var jt=Zo(),PQ=Ye(),vQ=Q(),Ee=at(),Xi=U(),BQ=Hi(),zI=Lr().LMDB_ERRORS_ENUM,{getSchemaPath:HQ}=Qe(),As=Xi.SEARCH_WILDCARDS;async function xQ(e,t,r){let n;e.schema===Xi.SYSTEM_SCHEMA_NAME?n=BQ[e.table]:n=global.hdb_schema[e.schema][e.table];let s=ZI(e,n.hash_attribute,r,t);return XI(e,s,n.hash_attribute,r)}a(xQ,"prepSearch");async function XI(e,t,r,n){let s=HQ(e.schema,e.table),i=await PQ.openEnvironment(s,e.table),o=jI(i,e,t,r),c=o.transaction||i;if([Ee.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,Ee.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,Ee.SEARCH_TYPES.SEARCH_ALL,Ee.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(GQ(e,r)===!1){let l=e.search_attribute;if(l===r)return n?JI(o,()=>!0):o.map(f=>({[r]:f.key}));let d=a(f=>({[r]:f.value,[l]:f.key}),"toObject");return n?JI(o,d):o.map(d)}let _=e.search_attribute===r?o.map(l=>l.key):o.map(l=>l.value);return n===!0?jt.batchSearchByHashToMap(c,r,e.get_attributes,_):jt.batchSearchByHash(c,r,e.get_attributes,_)}a(XI,"executeSearch");function jI(e,t,r,n){let s,i=n;t.get_attributes.indexOf(n)<0&&(i=void 0);let{reverse:o,limit:c,offset:u}=t;switch(o=typeof o=="boolean"?o:!1,c=Number.isInteger(c)?c:void 0,u=Number.isInteger(u)?u:void 0,r){case Ee.SEARCH_TYPES.EQUALS:s=jt.equals(e,i,t.search_attribute,t.search_value,o,c,u);break;case Ee.SEARCH_TYPES.CONTAINS:s=jt.contains(e,i,t.search_attribute,t.search_value,o,c,u);break;case Ee.SEARCH_TYPES.ENDS_WITH:case Ee.SEARCH_TYPES._ENDS_WITH:s=jt.endsWith(e,i,t.search_attribute,t.search_value,o,c,u);break;case Ee.SEARCH_TYPES.STARTS_WITH:case Ee.SEARCH_TYPES._STARTS_WITH:s=jt.startsWith(e,i,t.search_attribute,t.search_value,o,c,u);break;case Ee.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return jt.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case Ee.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return jt.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case Ee.SEARCH_TYPES.SEARCH_ALL:return jt.searchAll(e,n,t.get_attributes,o,c,u);case Ee.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return jt.searchAllToMap(e,n,t.get_attributes,o,c,u);case Ee.SEARCH_TYPES.BETWEEN:s=jt.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,u);break;case Ee.SEARCH_TYPES.GREATER_THAN:case Ee.SEARCH_TYPES._GREATER_THAN:s=jt.greaterThan(e,i,t.search_attribute,t.search_value,o,c,u);break;case Ee.SEARCH_TYPES.GREATER_THAN_EQUAL:case Ee.SEARCH_TYPES._GREATER_THAN_EQUAL:s=jt.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,u);break;case Ee.SEARCH_TYPES.LESS_THAN:case Ee.SEARCH_TYPES._LESS_THAN:s=jt.lessThan(e,i,t.search_attribute,t.search_value,o,c,u);break;case Ee.SEARCH_TYPES.LESS_THAN_EQUAL:case Ee.SEARCH_TYPES._LESS_THAN_EQUAL:s=jt.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,u);break;default:return Object.create(null)}return s}a(jI,"searchByType");function JI(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(JI,"createMapFromIterable");function GQ(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(GQ,"checkToFetchMore");function ZI(e,t,r,n){if(vQ.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),As.indexOf(s)>-1)return r===!0?Ee.SEARCH_TYPES.SEARCH_ALL_TO_MAP:Ee.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(As[0])<0&&s.indexOf(As[1])<0)return c===!0?r===!0?Ee.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:Ee.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:Ee.SEARCH_TYPES.EQUALS;if(As.indexOf(i)>=0&&As.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),Ee.SEARCH_TYPES.CONTAINS;if(As.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),Ee.SEARCH_TYPES.ENDS_WITH;if(As.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),Ee.SEARCH_TYPES.STARTS_WITH;if(s.includes(As[0])||s.includes(As[1]))return Ee.SEARCH_TYPES.EQUALS;throw new Error(zI.UNKNOWN_SEARCH_TYPE)}else switch(n){case Xi.VALUE_SEARCH_COMPARATORS.BETWEEN:return Ee.SEARCH_TYPES.BETWEEN;case Xi.VALUE_SEARCH_COMPARATORS.GREATER:return Ee.SEARCH_TYPES.GREATER_THAN;case Xi.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return Ee.SEARCH_TYPES.GREATER_THAN_EQUAL;case Xi.VALUE_SEARCH_COMPARATORS.LESS:return Ee.SEARCH_TYPES.LESS_THAN;case Xi.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return Ee.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(zI.UNKNOWN_SEARCH_TYPE)}}a(ZI,"createSearchTypeFromSearchObject");ew.exports={executeSearch:XI,createSearchTypeFromSearchObject:ZI,prepSearch:xQ,searchByType:jI}});var rw=R((Jue,tw)=>{"use strict";var zue=Zn(),FQ=ea(),qQ=Q(),kQ=U(),VQ=z_();tw.exports=$Q;function $Q(e,t){if(!qQ.isEmpty(t)&&kQ.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=FQ(e,"value");if(n)throw n;return VQ.prepSearch(e,t,!0)}a($Q,"lmdbGetDataByValue")});var Wc=R((Zue,nw)=>{"use strict";var jue=Zn(),YQ=ea(),KQ=Q(),WQ=U(),QQ=z_();nw.exports=zQ;async function zQ(e,t){if(!KQ.isEmpty(t)&&WQ.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=YQ(e,"value");if(n)throw n;return QQ.prepSearch(e,t,!1)}a(zQ,"lmdbSearchByValue")});var iw=R((rle,sw)=>{"use strict";var tle=at(),Op=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}},bp=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},yp=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};sw.exports={SearchByConditionsObject:Op,SearchCondition:bp,SortAttribute:yp}});var lw=R((ole,uw)=>{"use strict";var sle=iw().SearchByConditionsObject,JQ=Zn(),XQ=ea(),Np=Zo(),J_=at(),{Resource:ile}=(bn(),ie(Ip)),cw=z_(),jQ=Sp(),ZQ=require("lodash"),{getSchemaPath:ez}=Qe(),ow=Ye(),{handleHDBError:tz,hdb_errors:rz}=ne(),{HTTP_STATUS_CODES:nz}=rz,sz=1e8;uw.exports=iz;async function iz(e){let t=XQ(e,"conditions");if(t)throw tz(t,t.message,nz.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 ow.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let _ of e.conditions)ow.openDBI(n,_.search_attribute);let i=ZQ.sortBy(e.conditions,_=>{if(_.estimated_count===void 0){let l=_.search_type;l===J_.SEARCH_TYPES.EQUALS?_.estimated_count=Np.count(n,_.search_attribute,_.search_value):l===J_.SEARCH_TYPES.CONTAINS||l===J_.SEARCH_TYPES.ENDS_WITH?_.estimated_count=1/0:_.estimated_count=sz}return _.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await aw(o,e,i[0],s.hash_attribute),u;if(!e.operator||e.operator.toLowerCase()==="and"){let _=n.dbis[s.hash_attribute],l=i.slice(1).map(cw.filterByType),d=l.length,f=Np.setGetWholeRowAttributes(n,e.get_attributes);u=c.map(E=>_.get(E,{transaction:o,lazy:!0})),d>0&&(u=u.filter(E=>{for(let h=0;h<d;h++)if(!l[h](E))return!1;return!0})),(e.offset||e.limit!==void 0)&&(u=u.slice(e.offset,e.limit!==void 0?(e.offset||0)+e.limit:void 0)),u=u.map(E=>jQ.parseRow(E,f))}else{for(let d=1;d<i.length;d++){let f=i[d],E=await aw(o,e,f,s.hash_attribute);c=c.concat(E)}let _=new Set,l=e.offset||0;c=c.filter(d=>_.has(d)?!1:(_.add(d),!0)).slice(l,e.limit&&e.limit+l),u=Np.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return u.onDone=()=>{o.done()},u}a(iz,"lmdbSearchByConditions");async function aw(e,t,r,n){let s=new JQ(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===J_.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,cw.searchByType(e,s,i,n).map(o=>o.value)}a(aw,"executeConditionSearch")});var Qc=R((cle,_w)=>{"use strict";var oz=U().OPERATIONS_ENUM,wp=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=oz.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};_w.exports=wp});var Cp=R((lle,Tw)=>{"use strict";var hw=Zn(),mw=Qc(),pw=Wc(),Sw=Vc(),fr=U(),dw=Q(),fw=Ye(),{getTransactionAuditStorePath:az,getSchemaPath:cz}=Qe(),Ew=K();Tw.exports=uz;async function uz(e){try{if(dw.isEmpty(global.hdb_schema[e.schema])||dw.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await lz(e),await _z(e);let t=cz(e.schema,e.table);try{await fw.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")Ew.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=az(e.schema,e.table);await fw.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")Ew.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(uz,"lmdbDropTable");async function lz(e){let t=new hw(fr.SYSTEM_SCHEMA_NAME,fr.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,fr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[fr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await pw(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 mw(fr.SYSTEM_SCHEMA_NAME,fr.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await Sw(s)}a(lz,"deleteAttributesFromSystem");async function _z(e){let t=new hw(fr.SYSTEM_SCHEMA_NAME,fr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,fr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[fr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,fr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,fr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await pw(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 mw(fr.SYSTEM_SCHEMA_NAME,fr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await Sw(s)}catch(i){throw i}}a(_z,"dropTableFromSystem")});var Rw=R((dle,gw)=>{"use strict";var dz=require("fs-extra"),fz=Zn(),Ez=ta(),hz=Qc(),mz=Cp(),pz=Vc(),Sz=gp(),Tz=Wc(),Os=U(),{getSchemaPath:gz}=Qe(),{handleHDBError:Rz,hdb_errors:Az}=ne(),{HDB_ERROR_MSGS:Oz,HTTP_STATUS_CODES:bz}=Az;gw.exports=yz;async function yz(e){let t;try{t=await Nz(e.schema);let r=new fz(Os.SYSTEM_SCHEMA_NAME,Os.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Os.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[Os.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await Tz(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await mz(c)}catch(u){if(u.message!=="invalid environment")throw u}}let s=new hz(Os.SYSTEM_SCHEMA_NAME,Os.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await pz(s);let i=gz(t);await dz.remove(i)}catch(r){throw r}}a(yz,"lmdbDropSchema");async function Nz(e){let t=new Ez(Os.SYSTEM_SCHEMA_NAME,Os.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[Os.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await Sz(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw Rz(new Error,Oz.SCHEMA_NOT_FOUND(e),bz.NOT_FOUND,void 0,void 0,!0);return n}a(Nz,"validateDropSchema")});var Lp=R((Ele,Aw)=>{"use strict";var Dp=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};Aw.exports=Dp});var bw=R((ple,Ow)=>{"use strict";var Iz=require("fs-extra"),X_=Ye(),{getTransactionAuditStorePath:wz}=Qe(),Mp=at(),mle=Lp();Ow.exports=Cz;async function Cz(e){let t;try{let r=wz(e.schema,e.table);await Iz.mkdirp(r),t=await X_.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{X_.createDBI(t,Mp.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),X_.createDBI(t,Mp.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),X_.createDBI(t,Mp.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(Cz,"createTransactionsAuditEnvironment")});var ww=R((Tle,Iw)=>{"use strict";var Up=U(),yw=Ye(),Dz=qo(),{getSystemSchemaPath:Lz,getSchemaPath:Mz}=Qe(),Uz=Hi(),Pz=p_(),Pp=m_(),vz=K(),Bz=bw(),Bp=Uz.hdb_table,Nw=[];for(let e=0;e<Bp.attributes.length;e++)Nw.push(Bp.attributes[e].attribute);Iw.exports=Hz;async function Hz(e,t){let r=Mz(t.schema,t.table),n=new Pp(t.schema,t.table,Up.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new Pp(t.schema,t.table,Up.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new Pp(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await yw.createEnvironment(r,t.table),e!==void 0){let o=await yw.openEnvironment(Lz(),Up.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await Dz.insertRecords(o,Bp.hash_attribute,Nw,[e]),n.skip_table_check=!0,s.skip_table_check=!0,i.skip_table_check=!0,await vp(n),await vp(s),await vp(i)}await Bz(t)}catch(o){throw o}}a(Hz,"lmdbCreateTable");async function vp(e){try{await Pz(e)}catch(t){vz.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(vp,"createAttribute")});var Dw=R((Rle,Cw)=>{"use strict";var xz=Mc(),Gz=Pc(),Fz=V_(),zc=U(),qz=qo().updateRecords,kz=Ye(),{getSchemaPath:Vz}=Qe(),$z=qc(),Yz=K();Cw.exports=Kz;async function Kz(e){try{let{schema_table:t,attributes:r}=xz(e);Gz(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 Fz(e.hdb_auth_header,t,r),s=Vz(e.schema,e.table),i=await kz.openEnvironment(s,e.table),o=await qz(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await $z(e,o)}catch(c){Yz.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(Kz,"lmdbUpdateRecords")});var Mw=R((Ole,Lw)=>{"use strict";var Wz=U().OPERATIONS_ENUM,Hp=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=Wz.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};Lw.exports=Hp});var Pw=R((Nle,Uw)=>{"use strict";var yle=Mw(),Qz=Mc(),zz=Pc(),Jz=V_(),Jc=U(),Xz=qo().upsertRecords,jz=Ye(),{getSchemaPath:Zz}=Qe(),e2=qc(),t2=K(),{handleHDBError:r2,hdb_errors:n2}=ne();Uw.exports=s2;async function s2(e){let t;try{t=Qz(e)}catch(u){throw r2(u,u.message,n2.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;zz(e,n,r.hash_attribute),e.schema!==Jc.SYSTEM_SCHEMA_NAME&&(n.includes(Jc.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(Jc.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(Jc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(Jc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await Jz(e.hdb_auth_header,r,n),i=Zz(e.schema,e.table),o=await jz.openEnvironment(i,e.table),c=await Xz(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await e2(e,c)}catch(u){t2.error(`unable to write transaction due to ${u.message}`)}return{written_hashes:c.written_hashes,schema_table:r,new_attributes:s,txn_time:c.txn_time}}a(s2,"lmdbUpsertRecords")});var Bw=R((wle,vw)=>{"use strict";var xp=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};vw.exports=xp});var xw=R((Dle,Hw)=>{"use strict";var Gp=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}};Hw.exports=Gp});var qw=R((Ule,Fw)=>{"use strict";var Fp=Ye(),{getTransactionAuditStorePath:i2}=Qe(),Mle=Bw(),Xc=at(),o2=Q(),Gw=xw(),a2=require("util").promisify,c2=a2(setTimeout),u2=1e4,l2=100;Fw.exports=_2;async function _2(e){let t=i2(e.schema,e.table),r=await Fp.openEnvironment(t,e.table,!0),n=Fp.listDBIs(r);Fp.initializeDBIs(r,Xc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new Gw;do s=await d2(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 c2(l2);while(s.transactions_deleted>0);return i}a(_2,"deleteAuditLogsBefore");async function d2(e,t){let r=new Gw;try{let n=e.dbis[Xc.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[Xc.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];o2.isEmpty(c)||(s=e.dbis[Xc.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let u=0;u<o.hash_values.length;u++)s=e.dbis[Xc.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[u],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>u2)break}return await s,r}catch(n){throw n}}a(d2,"deleteTransactions")});var Vw=R((vle,kw)=>{"use strict";var qp=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};kw.exports=qp});var Yw=R((xle,$w)=>{"use strict";var f2=Zn(),E2=Qc(),Hle=Vw(),es=U(),h2=Q(),kp=Ye(),m2=Hi(),p2=Wc(),S2=Vc(),{getSchemaPath:T2}=Qe();$w.exports=g2;async function g2(e,t=!0){let r;e.schema===es.SYSTEM_SCHEMA_NAME?r=m2[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await A2(e),s=T2(e.schema,e.table),i=await kp.openEnvironment(s,e.table);return t===!0&&await R2(e,i,r.hash_attribute),kp.dropDBI(i,e.attribute),n}a(g2,"lmdbDropAttribute");async function R2(e,t,r){let n=kp.openDBI(t,r),s,i=e.attribute;for(let{key:o,value:c,version:u}of n.getRange({start:!1,versions:!0})){let _={};for(let l in c)l!==i&&(_[l]=c[l]);s=t.dbis[r].put(o,_,u)}await s}a(R2,"removeAttributeFromAllObjects");async function A2(e){let t=new f2(es.SYSTEM_SCHEMA_NAME,es.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,es.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[es.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,es.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await p2(t)).filter(o=>o[es.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(h2.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[es.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new E2(es.SYSTEM_SCHEMA_NAME,es.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return S2(i)}a(A2,"dropAttributeFromSystem")});var Xw=R((qle,Jw)=>{"use strict";var Vp=Ye(),ra=at(),Fle=Mr(),$p=U(),Kw=Q(),{getTransactionAuditStorePath:O2}=Qe(),b2=Zo(),j_=Jo(),y2=K();Jw.exports=N2;async function N2(e){let t=O2(e.schema,e.table),r=await Vp.openEnvironment(t,e.table,!0),n=Vp.listDBIs(r);Vp.initializeDBIs(r,ra.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case $p.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return Ww(r,e.search_values);case $p.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,w2(r,e.search_values,s);case $p.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return I2(r,e.search_values);default:return Ww(r)}}a(N2,"readAuditLog");function Ww(e,t=[0,Date.now()]){Kw.isEmpty(t[0])&&(t[0]=0),Kw.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[ra.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 j_,s))}a(Ww,"searchTransactionsByTimestamp");function I2(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[ra.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,zw(e,i))}return Object.fromEntries(r)}a(I2,"searchTransactionsByUsername");function w2(e,t,r){let n=new Map;for(let c=0,u=t.length;c<u;c++){let _=t[c],l=b2.equals(e,ra.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,ra.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,_);for(let{value:d}of l){let f=Number(d);n.has(f)?n.get(f).push(_.toString()):n.set(f,[_.toString()])}}let s=Array.from(n.keys()),i=zw(e,s),o=new Map;for(let c=0;c<i.length;c++){let u=i[c],_=u.timestamp,l=n.get(_);Qw(u,"records",r,l,o),Qw(u,"original_records",r,l,o)}return Object.fromEntries(o)}a(w2,"searchTransactionsByHashValues");function Qw(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],u=c[r].toString();if(n.indexOf(u)>=0)if(s.has(u)){let _=s.get(u),l=_[_.length-1];if(l.timestamp===i)l[t]=[c];else{let d=new j_(e.operation,e.user_name,i,void 0);d[t]=[c],_.push(d)}}else{let _=new j_(e.operation,e.user_name,i,void 0);_[t]=[c],s.set(u,[_])}}}a(Qw,"loopRecords");function zw(e,t){let r=[];try{let n=e.dbis[ra.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 j_,i);r.push(o)}}catch(i){y2.warn(i)}return r}catch(n){throw n}}a(zw,"batchSearchTransactions")});var Zw=R((Yle,jw)=>{"use strict";var{getSchemaPath:Vle}=Qe(),$le=Ye(),{database:C2}=(Ae(),ie(qe));jw.exports={writeTransaction:D2};async function D2(e,t,r){return C2({database:e,table:t}).transaction(r)}a(D2,"writeTransaction")});var nC=R((Wle,rC)=>{"use strict";var{getSchemaPath:eC}=Qe(),tC=Ye();rC.exports={flush:L2,resetReadTxn:M2};async function L2(e,t){return(await tC.openEnvironment(eC(e,t),t.toString())).flushed}a(L2,"flush");async function M2(e,t){try{(await tC.openEnvironment(eC(e,t),t.toString())).resetReadTxn()}catch{}}a(M2,"resetReadTxn")});var aC=R((zle,oC)=>{"use strict";var{Readable:U2}=require("stream"),{getDatabases:P2}=(Ae(),ie(qe)),{readSync:v2,openSync:B2,createReadStream:sC}=require("fs"),{open:H2}=require("lmdb"),iC=yc(),x2=Nc(),{AUDIT_STORE_OPTIONS:G2}=(js(),ie(cC)),{INTERNAL_DBIS_NAME:F2,AUDIT_STORE_NAME:q2}=at();oC.exports=V2;var Yp=32768,k2=100;async function V2(e){let t=e.database||e.schema||"data",r=P2()[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 l=_.dbisDB,d=H2({noSync:!0,maxDbs:x2.MAX_DBS}),f,E=d.openDB(F2,new iC(!1)),h=l.useReadTransaction(),S=0,p=a(async function(A,g){g.encoding="binary",g.encoder=void 0;let L=d.openDB(A,g),v=l.openDB(A,g);for(let{key:P,version:k,value:H}of v.getRange({start:null,transaction:h,versions:v.useVersions}))f=L.put(P,H,k),S++%k2===0&&(await new Promise(X=>setTimeout(X,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:A,value:g}of l.getRange({transaction:h,start:!1}))if(s.some(L=>A.startsWith?.(L+"/"))){E.put(A,g);let[,L]=A.split("/"),v=!L,P=new iC(!v,v);await p(A,P)}e.include_audit&&await p(q2,Object.assign({},G2)),await f;let T=sC(d.path);return T.headers=u(),T.on("close",()=>{h.done(),d.close()}),T}let o=r[Object.keys(r)[0]].primaryStore,c=B2(o.path);return o.transaction(()=>{let _=Buffer.alloc(Yp);v2(c,_,0,Yp),o.resetReadTxn();let l=o.useReadTransaction();l.renew();let d=sC(null,{fd:c,start:Yp}),f=new U2.from(async function*(){yield _;for await(let E of d)l.openTimer&&(l.openTimer=0),yield E;l.done()}());return f.headers=u(),f});function u(){let _=new Map;return _.set("content-type","application/octet-stream"),_.set("content-disposition",`attachment; filename="${t}"`),_.set("date",n),_}}a(V2,"getBackup")});var _C=R((Xle,lC)=>{"use strict";var $2=K(),{handleHDBError:Y2}=ne(),K2=Ob(),W2=p_(),Q2=fp(),z2=RI(),J2=Vc(),X2=gp(),j2=WI(),Z2=rw(),eJ=Wc(),tJ=lw(),rJ=Rw(),nJ=ww(),sJ=Dw(),iJ=Pw(),oJ=qw(),aJ=Cp(),cJ=Yw(),uJ=Xw(),lJ=Zw(),uC=nC(),_J=aC(),Kp=class extends K2{static{a(this,"LMDBBridge")}async searchByConditions(t){return tJ(t)}async getDataByHash(t){return await X2(t)}async searchByHash(t){return await j2(t)}async getDataByValue(t,r){return await Z2(t,r)}async searchByValue(t){return await eJ(t)}async createSchema(t){return await z2(t)}async dropSchema(t){return await rJ(t)}async createTable(t,r){return await nJ(t,r)}async dropTable(t){return await aJ(t)}async createAttribute(t){return await W2(t)}async createRecords(t){return await Q2(t)}async updateRecords(t){return await sJ(t)}async upsertRecords(t){try{return await iJ(t)}catch(r){throw Y2(r,null,null,$2.ERR,r)}}async deleteRecords(t){return await J2(t)}async dropAttribute(t){return await cJ(t)}async deleteAuditLogsBefore(t){return await oJ(t)}async readAuditLog(t){return await uJ(t)}writeTransaction(t,r,n){return lJ.writeTransaction(t,r,n)}flush(t,r){return uC.flush(t,r)}resetReadTxn(t,r){return uC.resetReadTxn(t,r)}getBackup(t){return _J(t)}};lC.exports=Kp});function hJ(){EJ=setInterval(function(){for(let e of Wp)if(e.stale){let t=e[ye]?.url;hC.error(`Transaction was open too long and has been aborted, from table: ${e.lmdbDb?.name+(t?" path: "+t:"")}`),e.abort()}else e.stale=!0},fJ).unref()}var Qp,EC,hC,mC,pC,SC,dC,Wp,dJ,jc,fC,ji,Z_,fJ,EJ,zp=Re(()=>{Qp=B(Mr()),EC=B(ne()),hC=B(K());bn();mC=B(te()),pC=B(U()),SC=B(Q()),dC=100,Wp=new Set,dJ=(0,SC.convertToMS)(mC.get(pC.CONFIG_PARAMS.STORAGE_MAXTRANSACTIONQUEUETIME))||45e3,ji=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.readTxnsUsed=1,this.readTxn=this.lmdbDb.useReadTransaction(),this.readTxn.openTimer&&(this.readTxn.openTimer=0),Wp.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(Wp.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(jc&&!this.overloadChecked&&performance.now()-fC>dJ)throw new EC.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=t.timestamp||(0,Qp.getNextMonotonicTime)());let n=t.retries||0;if(this.validated<this.writes.length)try{let d=this.validated;this.validated=this.writes.length;for(let E=d;E<this.validated;E++)this.writes[E]?.validate?.(this.timestamp);let f;for(let E=d;E<this.validated;E++){let h=this.writes[E];h&&(h.before||h.beforeIntermediate)&&(f=!0)}if(f)return(async()=>{try{for(let E=0;E<2;E++){let h;for(let S=d;S<this.validated;S++){let p=this.writes[S];if(!p)continue;let T=p[E===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(E){throw this.abort(),E}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"),u=a(()=>{let d=this.writes[o++];if(d)if(d.key){n>0&&(d.entry=d.store.getEntry(d.key));let f=d.store.ifVersion(d.key,d.entry?.version??null,u);s=s||f}else u();else for(let f of this.writes)c(f)},"nextCondition"),_=this.lmdbDb;if(this.writes.length>0&&(_?.retryRisk&&(_.retryRisk*=.99),this.writes.length+(_?.retryRisk||0)<dC>>n?u():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 jc||(jc=s,fC=performance.now(),jc.then(()=>{jc=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)+dC/2),t?t.retries=n+1:t={retries:1},this.commit(t)));let l={txnTime:r};if(this.next){let d=this.next?.commit(t);if(d?.then)return d?.then(f=>({txnTime:r,next:f}));l.next=d}return l}abort(){for(;this.readTxnsUsed>0;)this.doneReadTxn();this.open=0,this.writes=[]}},Z_=class extends ji{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,Qp.getNextMonotonicTime)())}getReadTxn(){}},fJ=3e4;a(hJ,"startMonitoringTxns");hJ()});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 ji;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 u=n.commit({letItLinger:r?.letItLinger});return u.then?u.then(()=>c):c}function o(c){throw n.abort({}),c}}var TC,Zi=Re(()=>{TC=require("../index");bn();zp();a(ze,"transaction");(0,TC._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 wC={};Fe(wC,{ResourceBridge:()=>jp});function Zp({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 RC(e,t){let r=ts(e),n=Zp(e,r);if(!r)throw new Ln.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},o;ze(i,()=>new Promise(_=>o=_));let c=e.ids||e.hash_values,u=0;return{[Symbol.asyncIterator](){return{async next(){if(u<c.length){let _=c[u++],l=await r.get({id:_,lazy:s,select:n},i);return l=l&&td(l),t?{value:{key:_,value:l}}:{value:l}}else return o(),{done:!0}},return(_){return o(),{value:_,done:!0}},throw(_){return o(),{done:!0}}}}}}function ts(e){let t=e.database||e.schema||pJ,r=Er()[t];if(!r)throw(0,Ln.handleHDBError)(new Error,mJ.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function AC(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*OC(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:u}=s;n?.timestamp===c?(n.hash_values.push(o),n.records.push(u)):(n&&(yield n),n={operation:i,user_name:s.user,timestamp:c,hash_values:[o],records:[u]})}n&&(yield n)}var bC,ed,Ln,yC,NC,Mn,Jp,Xp,IC,mJ,pJ,SJ,TJ,gC,jp,CC=Re(()=>{"use strict";bC=B(_C()),ed=B(ea()),Ln=B(ne());Ae();yC=B(Mc()),NC=B(Pc()),Mn=B(U()),Jp=B(Rs()),Xp=B(Dn()),IC=B(Q());Zi();rd();({HDB_ERROR_MSGS:mJ}=Ln.hdb_errors),pJ="data",SJ=1e4,TJ=10,jp=class extends bC.default{static{a(this,"ResourceBridge")}constructor(t){super(t),gC=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,ed.default)(t,"conditions");if(r)throw(0,Ln.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=ts(t);if(!n)throw new Ln.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:Zp(t,n),sort:t.sort,allowFullScan:!0})}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 Ln.ClientError("A primary key must be specified with a `primary_key` property or with `attributes`");n=[{name:i,isPrimaryKey:!0},{name:"__createdtime__",indexed:!0},{name:"__updatedtime__",indexed:!0}]}ut({database:r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration})}async createAttribute(t){return await ts(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=ts(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=a((o,c,u)=>(c=Object.assign({},c),delete c[n],r.primaryStore.ifVersion(o,u,()=>r.primaryStore.put(o,c,u)).then(_=>{if(!_){let{value:l,version:d}=r.primaryStore.getEntry(o);return i(o,l,d)}})),"deleteRecord");for(let{key:o,value:c,version:u}of r.primaryStore.getRange({start:!0,versions:!0}))s=i(o,c,u),await new Promise(_=>setImmediate(_));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){ts(t).dropTable()}createSchema(t){return Zc({database:t.schema,table:null}),Jp.signalSchemaChange(new Xp.SchemaEventMsg(process.pid,Mn.OPERATIONS_ENUM.CREATE_SCHEMA,t.schema))}async dropSchema(t){await eS(t.schema),Jp.signalSchemaChange(new Xp.SchemaEventMsg(process.pid,Mn.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,gC.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,yC.default)(t);(0,NC.default)(t,n,r.primaryKey);let s,i=Er()[t.schema][t.table],o={user:t.hdb_user,expiresAt:t.expiresAt};return ze(o,async c=>{if(!i.schemaDefined){s=[];for(let l of n)i.attributes.find(f=>f.name==l)||s.push(l);s.length>0&&await i.addAttributes(s.map(l=>({name:l,indexed:!0})))}let u=[],_=[];for(let l of t.records){let d=await i.get(l[i.primaryKey],o);if(t.requires_existing&&!d||t.requires_no_existing&&d){_.push(l[i.primaryKey]);continue}d&&(d=td(d));for(let f in l)if(Object.prototype.hasOwnProperty.call(l,f)){let E=l[f];if(typeof E=="function")try{let h=E([[d]]);Array.isArray(h)&&(E=h[0].func_val,l[f]=E)}catch(h){throw h.message+="Trying to set key "+f+" on object"+JSON.stringify(l),h}}if(d)for(let f in d)Object.prototype.hasOwnProperty.call(l,f)||(l[f]=d[f]);await i.put(l,o),u.push(l[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:u,new_attributes:s,skipped_hashes:_}})}async deleteRecords(t){let r=Er()[t.schema][t.table],n={user:t.hdb_user};return ze(n,async s=>{let i=t.hash_values||t.records.map(u=>u[r.primaryKey]),o=[],c=[];for(let u of i)await r.delete(u,n)?o.push(u):c.push(u);return AC(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=Er()[t.schema][t.table];if(!r.createdTimeProperty)throw new Ln.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:Mn.VALUE_SEARCH_COMPARATORS.LESS}]}),s=!1,i=[],o=[],c=0,u=[],_=a(async()=>{let l=await this.deleteRecords({schema:t.schema,table:t.table,hash_values:u});i.push(...l.deleted_hashes),o.push(...l.skipped_hashes),await(0,IC.async_set_timeout)(TJ),u=[],s=!0},"chunkDelete");for await(let l of n)u.push(l[r.primaryKey]),c++,c%SJ===0&&await _();return u.length>0&&await _(),s?AC(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,ed.default)(t,"hashes");if(r)throw r;return RC(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of RC(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&Mn.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,ed.default)(t,"value");if(n)throw n;let s=ts(t);if(!s)throw new Ln.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===Mn.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,select:Zp(t,s)})}async getDataByValue(t,r){let n=new Map,s=ts(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){ts({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return ts(t).deleteHistory(t.timestamp)}async readAuditLog(t){let r=ts(t),n={};switch(t.search_type){case Mn.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 Mn.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:let s=t.search_values;for await(let i of OC(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return OC(r,t.search_values?.[0],t.search_values?.[1])}}};a(Zp,"getSelect");a(RC,"getRecords");a(ts,"getTable");a(AC,"createDeleteResponse");a(OC,"groupRecordsInHistory")});var In=R((d_e,DC)=>{"use strict";var{ResourceBridge:gJ}=(CC(),ie(wC)),RJ=te();RJ.initSync();var nd;function AJ(){return nd||(nd=new gJ,nd)}a(AJ,"getBridge");DC.exports=AJ()});var PC=R((E_e,UC)=>{"use strict";var LC=require("lodash"),eu=require("mathjs"),OJ=require("jsonata"),MC=Q();UC.exports={distinct_array:e=>Array.isArray(e)&&e.length>1?LC.uniqWith(e,LC.isEqual):e,searchJSON:bJ,mad:tu.bind(null,eu.mad),mean:tu.bind(null,eu.mean),mode:tu.bind(null,eu.mode),prod:tu.bind(null,eu.prod),median:tu.bind(null,eu.median)};function tu(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(tu,"aggregateFunction");function bJ(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(MC.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),MC.isEmpty(this.__ala__.res[r])){let n=OJ(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(bJ,"searchJSON")});var BC=R((m_e,vC)=>{"use strict";var pt=require("moment"),tS="YYYY-MM-DDTHH:mm:ss.SSSZZ";pt.suppressDeprecationWarnings=!0;vC.exports={current_date:()=>pt().utc().format("YYYY-MM-DD"),current_time:()=>pt().utc().format("HH:mm:ss.SSS"),extract:(e,t)=>{switch(t.toLowerCase()){case"year":return pt(e).utc().format("YYYY");case"month":return pt(e).utc().format("MM");case"day":return pt(e).utc().format("DD");case"hour":return pt(e).utc().format("HH");case"minute":return pt(e).utc().format("mm");case"second":return pt(e).utc().format("ss");case"millisecond":return pt(e).utc().format("SSS");default:break}},date:e=>pt(e).utc().format(tS),date_format:(e,t)=>pt(e).utc().format(t),date_add:(e,t,r)=>pt(e).utc().add(t,r).valueOf(),date_sub:(e,t,r)=>pt(e).utc().subtract(t,r).valueOf(),date_diff:(e,t,r)=>{let n=pt(e).utc(),s=pt(t).utc();return r?n.diff(s,r,!0):n.diff(s)},now:()=>pt().utc().valueOf(),get_server_time:()=>pt().format(tS),offset_utc:(e,t)=>pt(e).utc().utcOffset(t).format(tS)}});var FC=R((p_e,GC)=>{"use strict";var yJ=require("@turf/area"),NJ=require("@turf/length"),IJ=require("@turf/circle"),wJ=require("@turf/difference"),CJ=require("@turf/distance"),DJ=require("@turf/boolean-contains"),LJ=require("@turf/boolean-equal"),MJ=require("@turf/boolean-disjoint"),UJ=require("@turf/helpers"),HC=U(),Te=Q(),bs=K();GC.exports={geoArea:PJ,geoLength:vJ,geoCircle:BJ,geoDifference:HJ,geoDistance:xC,geoNear:xJ,geoContains:GJ,geoEqual:FJ,geoCrosses:qJ,geoConvert:kJ};function PJ(e){if(Te.isEmpty(e))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e));try{return yJ.default(e)}catch(t){return bs.trace(t,e),NaN}}a(PJ,"geoArea");function vJ(e,t){if(Te.isEmpty(e))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e));try{return NJ.default(e,{units:t||"kilometers"})}catch(r){return bs.trace(r,e),NaN}}a(vJ,"geoLength");function BJ(e,t,r){if(Te.isEmpty(e))return NaN;if(Te.isEmpty(t))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e));try{return IJ.default(e,t,{units:r||"kilometers"})}catch(n){return bs.trace(n,e,t),NaN}}a(BJ,"geoCircle");function HJ(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 wJ(e,t)}catch(r){return bs.trace(r,e,t),NaN}}a(HJ,"geoDifference");function xC(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 CJ.default(e,t,{units:r||"kilometers"})}catch(n){return bs.trace(n,e,t),NaN}}a(xC,"geoDistance");function xJ(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 xC(e,t,n)<=r}catch(s){return bs.trace(s,e,t),!1}}a(xJ,"geoNear");function GJ(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 DJ.default(e,t)}catch(r){return bs.trace(r,e,t),!1}}a(GJ,"geoContains");function FJ(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 LJ.default(e,t)}catch(r){return bs.trace(r,e,t),!1}}a(FJ,"geoEqual");function qJ(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!MJ.default(e,t)}catch(r){return bs.trace(r,e,t),!1}}a(qJ,"geoCrosses");function kJ(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(HC.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(HC.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Te.autoCastJSON(e)),UJ[t](e,r)}a(kJ,"geoConvert")});var sd=R((T_e,qC)=>{var eo=PC(),kr=BC(),rs=FC();qC.exports=e=>{e.aggr.mad=e.aggr.MAD=eo.mad,e.aggr.mean=e.aggr.MEAN=eo.mean,e.aggr.mode=e.aggr.MODE=eo.mode,e.aggr.prod=e.aggr.PROD=eo.prod,e.aggr.median=e.aggr.MEDIAN=eo.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=eo.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=eo.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=rs.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=rs.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=rs.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=rs.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=rs.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=rs.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=rs.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=rs.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=rs.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=rs.geoNear}});var YC=R((g_e,$C)=>{"use strict";var ru=require("lodash"),hr=require("alasql");hr.options.cache=!1;var VJ=sd(),kC=require("clone"),id=require("recursive-iterator"),le=K(),Ce=Q(),na=In(),$J=U(),{hdb_errors:YJ}=ne(),{getDatabases:VC}=(Ae(),ie(qe)),KJ="IS NULL",Un="There was a problem performing this search. Please check the logs and try again.";VJ(hr);var rS=class{static{a(this,"SQLSearch")}constructor(t,r){if(Ce.isEmpty(t))throw le.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(),Ce.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!Ce.isEmptyOrZeroLength(n))return le.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw le.error("Error thrown from checkEmptySQL in SQLSearch class method search."),le.error(n),new Error(Un)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw le.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),le.error(n),new Error(Un)}if(Object.keys(this.data).length===0)return le.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw le.error("Error thrown from processJoins in SQLSearch class method search."),le.error(n),new Error(Un)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw le.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),le.error(n),new Error(Un)}try{return t=await this._finalSQL(),t}catch(n){throw le.error("Error thrown from finalSQL in SQLSearch class method search."),le.error(n),new Error(Un)}}_getColumns(){let t=new id(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(kC(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=ru.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=VC()[r.databaseid][r.tableid].primaryKey,this.data[n].__merged_data={},this.data[n].__merged_attributes=[],this.data[n].__merged_attr_map={}})}_conditionsToFetchAttributeValues(){if(Ce.isEmpty(this.statement.where)){le.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new id(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!Ce.isEmpty(r)&&r.right)if(Ce.isNotEmptyAndHasValue(r.right.value)){let n=Ce.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new hr.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=Ce.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new hr.yy.LogicValue({value:i}):n instanceof hr.yy.StringValue&&Ce.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new hr.yy.NumValue({value:i}))});if(t){le.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new id(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(!Ce.isEmpty($J.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(Ce.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(Ce.isEmptyOrZeroLength(r.left.columnid)||Ce.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(Ce.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"=":!Ce.isEmpty(r.right.value)||!Ce.isEmpty(r.left.value)?n.add(Ce.isEmpty(r.right.value)?r.left.value:r.right.value):c=!0;break;case"IN":let u=Array.isArray(r.right)?r.right:r.left;for(let _=0;_<u.length;_++)if(u[_].value)n.add(u[_].value);else{c=!0;break}break;default:c=!0;break}this.exact_search_values[o].ignore=c,c?this.exact_search_values[o].values=new Set:this.exact_search_values[o].values=new Set([...this.exact_search_values[o].values,...n])}}}_setAliasesForColumns(){if(Ce.isEmptyOrZeroLength(this.all_table_attributes)&&Ce.isEmptyOrZeroLength(this.statement.from)&&Ce.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&&ru.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(Ce.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);Ce.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(Ce.isEmptyOrZeroLength(this.all_table_attributes)&&!Ce.isEmptyOrZeroLength(this.columns.columns))return t;if(Ce.isEmptyOrZeroLength(this.all_table_attributes)&&Ce.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await hr.promise(r)}catch(r){throw le.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),le.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(kC(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(Ce.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(KJ)>-1&&this.tables.forEach(s=>{let i={columnid:VC()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=ru.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]},u=!1,_=[s.table.databaseid,s.table.tableid,s.attribute].join("/");if(s.attribute===o&&(u=!0),!Ce.isEmpty(this.exact_search_values[_])&&!this.exact_search_values[_].ignore&&!Ce.isEmptyOrZeroLength(this.exact_search_values[_].values))if(u)try{c.hash_values=Array.from(this.exact_search_values[_].values);let l=await na.getDataByHash(c);for(let d of c.hash_values)l.get(d)&&!this.data[i].__merged_data[d]&&(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d))}catch(l){throw le.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),le.error(l),new Error(Un)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[_].values).map(async l=>{let d=Object.assign({},c);d.search_value=l;let f=await na.getDataByValue(d);for(let[E,h]of f)this.data[i].__merged_data[E]?this._updateMergedAttribute(i,E,s.attribute,h[s.attribute]):(this.data[i].__merged_data[E]=[...n[i]],this._updateMergedAttribute(i,E,s.attribute,h[s.attribute]),this._setMergedHashAttribute(i,E))}))}catch(l){throw le.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),le.error(l),new Error(Un)}else if(!Ce.isEmpty(this.comparator_search_values[_])&&!this.comparator_search_values[_].ignore&&!Ce.isEmptyOrZeroLength(this.comparator_search_values[_].comparators))try{let l=this.comparator_search_values[_].comparators;for(let d=0,f=l.length;d<f;d++){let E=l[d];c.search_attribute=E.attribute,c.search_value=E.search_value;let h=await na.getDataByValue(c,E.operation);if(u)for(let[S]of h)this.data[i].__merged_data[S]||(this.data[i].__merged_data[S]=[...n[i]],this._setMergedHashAttribute(i,S));else for(let[S,p]of h)this.data[i].__merged_data[S]?this._updateMergedAttribute(i,S,s.attribute,p[s.attribute]):(this.data[i].__merged_data[S]=[...n[i]],this._updateMergedAttribute(i,S,s.attribute,p[s.attribute]),this._setMergedHashAttribute(i,S))}}catch(l){throw le.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),le.error(l),new Error(Un)}else try{c.search_attribute=s.attribute,c.search_value="*";let l=await na.getDataByValue(c);if(u)for(let[d]of l)this.data[i].__merged_data[d]||(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d));else for(let[d,f]of l)this.data[i].__merged_data[d]?this._updateMergedAttribute(i,d,s.attribute,f[s.attribute]):(this.data[i].__merged_data[d]=[...n[i]],this._updateMergedAttribute(i,d,s.attribute,f[s.attribute]),this._setMergedHashAttribute(i,d))}catch(l){throw le.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),le.error(l),new Error(Un)}}}_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 hr.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 hr.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new hr.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 hr.yy.FuncValue:new hr.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(E=>{E.joinmode&&E.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(E.table);let h=E.joinmode+" JOIN ? AS "+(E.as?E.as:E.table.tableid);E.on&&(h+=" ON "+E.on.toString()),i.push(h),t.push(Object.values(this.data[`${E.table.databaseid_orig}_${E.table.as?E.table.as_orig:E.table.tableid_orig}`].__merged_data))});let o=[],c={};s.forEach(E=>{let h=this.data[`${E.databaseid_orig}_${E.as?E.as_orig:E.tableid_orig}`].__hash_name,S=E.as?E.as_orig:E.tableid_orig;o.push({key:`'${S}.${h}'`,schema:E.databaseid_orig,table:E.as?E.as_orig:E.tableid_orig,keys:new Set}),r.push(`${E.as?E.as:E.tableid}.\`${h}\` AS "${S}.${h}"`),c[E.as?E.as_orig:E.tableid_orig]=this.data[`${E.databaseid_orig}_${E.as?E.as_orig:E.tableid_orig}`].__merged_attributes});let u=this.statement.where?"WHERE "+this.statement.where:"";u=u.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(E=>{E.is_func?r.push(E.initial_select_column.toString()):E.initial_select_column.tableid?r.push(`${E.initial_select_column.tableid}.${E.initial_select_column.columnid} AS ${E.expression.columnid}`):r.push(`${E.initial_select_column.columnid} AS ${E.expression.columnid}`)}));let l="",d="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(l=this.statement.limit?"LIMIT "+this.statement.limit:"",d=this.statement.offset?"OFFSET "+this.statement.offset:"");let f=[];try{let E=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${u} ${_} ${l} ${d}`,h=this._convertColumnsToIndexes(E,s);f=await hr.promise(h,t),t=null}catch(E){throw le.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),le.error(E),new Error("There was a problem processing the data.")}if(f&&f.length>0){for(let E=0,h=f.length;E<h;E++){let S=f[E];o.forEach(p=>{S[p.key]!==null&&S[p.key]!==void 0&&p.keys.add(S[p.key])})}o.forEach(E=>{let h=Object.keys(this.data[`${E.schema}_${E.table}`].__merged_data),S=ru.difference(h,[...E.keys].map(p=>p.toString()));for(let p=0,T=S.length;p<T;p++){let A=S[p];delete this.data[`${E.schema}_${E.table}`].__merged_data[A]}})}return{existing_attributes:c,joined_length:f?f.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new id(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=ru.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 le.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),le.error(i),new Error(Un)}}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 l in i)o.push(i[l][0]);this.data[n].__merged_attributes.push(...s.columns);let c={schema:s.schema,table:s.table,hash_values:o,get_attributes:s.columns},u=await na.getDataByHash(c),_=s.columns.length;for(let l=0,d=o.length;l<d;l++){let f=o[l],E=u.get(f);for(let h=0;h<_;h++){let S=s.columns[h],p=E[S]===void 0?null:E[S];this.data[n].__merged_data[f].push(p)}}}}catch(r){throw le.error("Error thrown from getDataByHash function in SQLSearch class method getData."),le.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,u=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===u}).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();le.trace(`Final SQL: ${s}`),n=await hr.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),le.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw le.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),le.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 le.error(YJ.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),le.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 u=s[i],_=new RegExp(`${u}.\`${o}\``,"g"),l=`${u}.[${c}]`;n=n.replace(_,l)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let u=new RegExp(`\`${o}\``,"g"),_=`[${c}]`;n=n.replace(u,_)});return n}async _simpleSQLQuery(){let t=this.statement.columns.reduce((n,s)=>(s.as_orig&&s.as_orig!=s.columnid_orig?n[s.columnid_orig]=s.as_orig:n[s.columnid_orig]||(n[s.columnid_orig]=s.columnid_orig),n),{}),r=this.fetch_attributes.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]||(n[i]={}),n[i][t[s.attribute]]=null,n},{});for(let n of this.fetch_attributes){let s=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`,i={schema:n.table.databaseid,table:n.table.tableid,get_attributes:[n.attribute]};try{i.search_attribute=n.attribute,i.search_value="*";let o=await na.getDataByValue(i);for(let[c,u]of o)this.data[s].__merged_data[c]||(u[n.attribute]===void 0&&(u[n.attribute]=null),this.data[s].__merged_data[c]=Object.assign({},r[s])),this.data[s].__merged_data[c][t[n.attribute]]=u[n.attribute]??null}catch(o){throw le.error("There was an error when processing this SQL operation. Check your logs"),le.error(o),new Error(Un)}}return Object.values(Object.values(this.data)[0].__merged_data)}};$C.exports=rS});var Br=R((A_e,KC)=>{"use strict";var WJ=Rb();KC.exports={searchByConditions:zJ,searchByHash:JJ,searchByValue:XJ,search:jJ};var nS=In(),{transformReq:sS}=Q(),QJ=YC();async function zJ(e){return sS(e),nS.searchByConditions(e)}a(zJ,"searchByConditions");async function JJ(e){sS(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of nS.searchByHash(e))r&&t.push(r);return t}a(JJ,"searchByHash");async function XJ(e){sS(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of nS.searchByValue(e))t.push(r);return t}a(XJ,"searchByValue");function jJ(e,t){try{let r=new WJ(e);r.validate(),new QJ(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(jJ,"search")});var od=R((b_e,WC)=>{"use strict";var ZJ=In();WC.exports={writeTransaction:e4};function e4(e,t,r){return ZJ.writeTransaction(e,t,r)}a(e4,"writeTransaction")});var XC=R((I_e,JC)=>{"use strict";var t4=Br(),r4=ri(),QC=K(),n4=cn(),N_e=od(),s4=require("clone"),oS=require("alasql"),i4=sd(),zC=require("util"),o4=zC.promisify(r4.getTableSchema),a4=zC.promisify(t4.search),c4=U(),iS=Q();i4(oS);JC.exports={update:l4};var u4="There was a problem performing this update. Please check the logs and try again.";async function l4({statement:e,hdb_user:t}){let r=await o4(e.table.databaseid,e.table.tableid),n=_4(e.columns);iS.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=s4(s),c=iS.isEmpty(i)?"":` WHERE ${i.toString()}`,u=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,_=oS.parse(u).statements[0],l=await a4(_),d=d4(n,l);return f4(o,d,t)}a(l4,"update");function _4(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=oS.compile(`SELECT ${r.expression.toString()} AS [${c4.FUNC_VAL}] FROM ?`)}),t}catch(t){throw QC.error(t),new Error(u4)}}a(_4,"createUpdateRecord");function d4(e,t){return iS.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(d4,"buildUpdateRecords");async function f4(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await n4.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){QC.error(`Error delete new_attributes from update response: ${i}`)}return s}a(f4,"updateRecords")});var ZC=R((L_e,jC)=>{var E4=require("alasql"),h4=Br(),m4=K(),p4=In(),cS=require("util"),aS=Q(),S4=U(),T4=ri(),C_e=od(),D_e=cn(),g4="record",R4="successfully deleted",A4=cS.callbackify(N4),O4=cS.promisify(h4.search),b4=cS.promisify(T4.getTableSchema);jC.exports={convertDelete:A4};function y4(e){return`${e.deleted_hashes.length} ${g4}${e.deleted_hashes.length===1?"":"s"} ${R4}`}a(y4,"generateReturnMessage");async function N4({statement:e,hdb_user:t}){let r=await b4(e.table.databaseid,e.table.tableid);aS.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=aS.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=E4.parse(o).statements[0],u={operation:S4.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{u.records=await O4(c);let _=await p4.deleteRecords(u);return aS.isEmptyOrZeroLength(_.message)&&(_.message=y4(_)),delete _.txn_time,_}catch(_){throw m4.error(_),_.hdb_code?_.message:_}}a(N4,"convertDelete")});var sD=R((U_e,nD)=>{"use strict";var I4=ti(),{hdb_errors:eD}=ne(),{getDatabases:tD}=(Ae(),ie(qe));nD.exports={checkSchemaExists:rD,checkSchemaTableExists:w4,schema_describe:I4};async function rD(e){if(!tD()[e])return eD.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(rD,"checkSchemaExists");async function w4(e,t){let r=await rD(e);if(r)return r;if(!tD()[e][t])return eD.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(w4,"checkSchemaTableExists")});var ld=R((B_e,cD)=>{"use strict";var sa=h_(),ia=sD(),C4=K(),D4=require("uuid").v4,v_e=require("clone"),cd=Rs(),oa=U(),L4=require("util"),ui=In(),{handleHDBError:mr,hdb_errors:M4}=ne(),{HDB_ERROR_MSGS:ad,HTTP_STATUS_CODES:pr}=M4,{SchemaEventMsg:ud}=Dn(),iD=Nt(),{getDatabases:U4}=(Ae(),ie(qe)),{transformReq:aa}=Q();cD.exports={createSchema:P4,createSchemaStructure:oD,createTable:v4,createTableStructure:aD,createAttribute:F4,dropSchema:B4,dropTable:H4,dropAttribute:x4,getBackup:q4};async function P4(e){let t=await oD(e);return cd.signalSchemaChange(new ud(process.pid,e.operation,e.schema)),t}a(P4,"createSchema");async function oD(e){let t=sa.schema_object(e);if(t)throw mr(t,t.message,pr.BAD_REQUEST,void 0,void 0,!0);if(aa(e),!await ia.checkSchemaExists(e.schema))throw mr(new Error,ad.SCHEMA_EXISTS_ERR(e.schema),pr.BAD_REQUEST,oa.LOG_LEVELS.ERROR,ad.SCHEMA_EXISTS_ERR(e.schema),!0);return await ui.createSchema(e),`database '${e.schema}' successfully created`}a(oD,"createSchemaStructure");async function v4(e){return aa(e),e.hash_attribute=e.primary_key??e.hash_attribute,await aD(e)}a(v4,"createTable");async function aD(e){let t=sa.create_table_object(e);if(t)throw mr(t,t.message,pr.BAD_REQUEST,void 0,void 0,!0);if(sa.validateTableResidence(e.residence),!await ia.checkSchemaTableExists(e.schema,e.table))throw mr(new Error,ad.TABLE_EXISTS_ERR(e.schema,e.table),pr.BAD_REQUEST,oa.LOG_LEVELS.ERROR,ad.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:D4(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await ui.createTable(n,e);else throw mr(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",pr.BAD_REQUEST);else await ui.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}a(aD,"createTableStructure");async function B4(e){let t=!e.schema&&!e.database?new Error("database is required"):void 0,r=sa.schema_object(e),n=t??r;if(n)throw mr(n,n.message,pr.BAD_REQUEST,void 0,void 0,!0);aa(e);let s=await ia.checkSchemaExists(e.schema);if(s)throw mr(new Error,s,pr.NOT_FOUND,oa.LOG_LEVELS.ERROR,s,!0);let i=await ia.schema_describe.describeSchema({schema:e.schema}),o=Object.keys(global.hdb_schema[e.schema]);return await ui.dropSchema(e),cd.signalSchemaChange(new ud(process.pid,e.operation,e.schema)),await iD.purgeSchemaTableStreams(e.schema,o),`successfully deleted '${e.schema}'`}a(B4,"dropSchema");async function H4(e){let t=sa.table_object(e);if(t)throw mr(t,t.message,pr.BAD_REQUEST,void 0,void 0,!0);aa(e);let r=await ia.checkSchemaTableExists(e.schema,e.table);if(r)throw mr(new Error,r,pr.NOT_FOUND,oa.LOG_LEVELS.ERROR,r,!0);return await ui.dropTable(e),await iD.purgeTableStream(e.schema,e.table),`successfully deleted table '${e.schema}.${e.table}'`}a(H4,"dropTable");async function x4(e){let t=sa.attribute_object(e);if(t)throw mr(t,t.message,pr.BAD_REQUEST,void 0,void 0,!0);aa(e);let r=await ia.checkSchemaTableExists(e.schema,e.table);if(r)throw mr(new Error,r,pr.NOT_FOUND,oa.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw mr(new Error,"You cannot drop a hash attribute",pr.BAD_REQUEST,void 0,void 0,!0);if(oa.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw mr(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,pr.BAD_REQUEST,void 0,void 0,!0);try{return await ui.dropAttribute(e),G4(e),cd.signalSchemaChange(new ud(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw C4.error(`Got an error deleting attribute ${L4.inspect(e)}.`),n}}a(x4,"dropAttribute");function G4(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(G4,"dropAttributeFromGlobal");async function F4(e){aa(e);let t=U4()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw mr(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,pr.BAD_REQUEST,void 0,void 0,!0);return await ui.createAttribute(e),cd.signalSchemaChange(new ud(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}a(F4,"createAttribute");function q4(e){return ui.getBackup(e)}a(q4,"getBackup")});var lD=R((x_e,uD)=>{"use strict";var{OPERATIONS_ENUM:k4}=U(),uS=class{static{a(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=k4.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};uD.exports=uS});var lS=R((q_e,hD)=>{"use strict";var V4=In(),F_e=lD(),_d=Q(),dd=U(),$4=te(),{handleHDBError:_D,hdb_errors:Y4}=ne(),{HDB_ERROR_MSGS:dD,HTTP_STATUS_CODES:fD}=Y4,K4=Object.values(dd.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),ED="To use this operation audit log must be enabled in harperdb-config.yaml";hD.exports=W4;async function W4(e){if(_d.isEmpty(e.schema))throw new Error(dD.SCHEMA_REQUIRED_ERR);if(_d.isEmpty(e.table))throw new Error(dD.TABLE_REQUIRED_ERR);if(!$4.get(dd.CONFIG_PARAMS.LOGGING_AUDITLOG))throw _D(new Error,ED,fD.BAD_REQUEST,dd.LOG_LEVELS.ERROR,ED,!0);let t=_d.checkSchemaTableExist(e.schema,e.table);if(t)throw _D(new Error,t,fD.NOT_FOUND,dd.LOG_LEVELS.ERROR,t,!0);if(!_d.isEmpty(e.search_type)&&K4.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await V4.readAuditLog(e)}a(W4,"readAuditLog")});var pD=R((V_e,mD)=>{"use strict";var{OPERATIONS_ENUM:Q4}=U(),_S=class{static{a(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=Q4.GET_BACKUP,this.schema=t,this.table=r}};mD.exports=_S});var gD=R((W_e,TD)=>{"use strict";var z4=In(),Y_e=pD(),dS=Q(),J4=U(),K_e=te(),{handleHDBError:X4,hdb_errors:j4}=ne(),{HDB_ERROR_MSGS:SD,HTTP_STATUS_CODES:Z4}=j4;TD.exports=e3;async function e3(e){if(dS.isEmpty(e.schema))throw new Error(SD.SCHEMA_REQUIRED_ERR);if(dS.isEmpty(e.table))throw new Error(SD.TABLE_REQUIRED_ERR);let t=dS.checkSchemaTableExist(e.schema,e.table);if(t)throw X4(new Error,t,Z4.NOT_FOUND,J4.LOG_LEVELS.ERROR,t,!0);return await z4.getBackup(read_audit_log_object)}a(e3,"getBackup")});var ND=R((z_e,yD)=>{var li=require("validate.js"),AD=rt(),ca=U(),{handleHDBError:t3,hdb_errors:r3}=ne(),{HDB_ERROR_MSGS:_t,HTTP_STATUS_CODES:n3}=r3,fS=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),s3={STRUCTURE_USER:"structure_user"},RD=Object.values(ca.ROLE_TYPES_ENUM),i3="attribute_permissions",o3="attribute_name",{PERMS_CRUD_ENUM:ua}=ca,a3=[i3,...Object.values(ua)],OD=[ua.READ,ua.INSERT,ua.UPDATE],c3=[o3,...OD];function u3(e){let t=fS();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,bD(e,t)}a(u3,"addRoleValidation");function l3(e){let t=fS();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,bD(e,t)}a(l3,"alterRoleValidation");function _3(e){let t=fS();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,AD.validateObject(e,t)}a(_3,"dropRoleValidation");var d3=["operation","role","id","permission","hdb_user","hdb_auth_header"];function bD(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)d3.includes(n[o])||s.push(n[o]);s.length>0&&St(_t.INVALID_ROLE_JSON_KEYS(s),r);let i=AD.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{St(o,r)}),e.permission){let o=f3(e);o&&St(o,r),RD.forEach(c=>{e.permission[c]&&!li.isBoolean(e.permission[c])&&St(_t.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(RD.indexOf(o)<0){if(o===s3.STRUCTURE_USER){let u=e.permission[o];if(typeof u=="boolean")continue;if(Array.isArray(u)){for(let _=0,l=u.length;_<l;_++){let d=u[_];global.hdb_schema[d]||St(_t.SCHEMA_NOT_FOUND(d),r)}continue}St(_t.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){St(_t.SCHEMA_NOT_FOUND(o),r);continue}if(c.tables)for(let u in c.tables){let _=c.tables[u];if(!u||!global.hdb_schema[o][u]){St(_t.TABLE_NOT_FOUND(o,u),r);continue}if(Object.keys(_).forEach(l=>{a3.includes(l)||St(_t.INVALID_PERM_KEY(l),r,o,u)}),Object.values(ua).forEach(l=>{li.isDefined(_[l])?li.isBoolean(_[l])||St(_t.TABLE_PERM_NOT_BOOLEAN(l),r,o,u):St(_t.TABLE_PERM_MISSING(l),r,o,u)}),li.isDefined(_.attribute_permissions)){if(!li.isArray(_.attribute_permissions)){St(_t.ATTR_PERMS_NOT_ARRAY,r,o,u);continue}}else{St(_t.ATTR_PERMS_ARRAY_MISSING,r,o,u);continue}if(_.attribute_permissions){let l=global.hdb_schema[o][u].attributes.map(({attribute:f})=>f),d={read:!1,insert:!1,update:!1};for(let f in _.attribute_permissions){let E=_.attribute_permissions[f];if(Object.keys(E).forEach(S=>{!c3.includes(S)&&S!==ua.DELETE&&St(_t.INVALID_ATTR_PERM_KEY(S),r,o,u)}),!li.isDefined(E.attribute_name)){St(_t.ATTR_PERM_MISSING_NAME,r,o,u);continue}let h=E.attribute_name;if(!l.includes(h)){St(_t.INVALID_ATTRIBUTE_IN_PERMS(h),r,o,u);continue}OD.forEach(S=>{li.isDefined(E[S])?li.isBoolean(E[S])||St(_t.ATTR_PERM_NOT_BOOLEAN(S,h),r,o,u):St(_t.ATTR_PERM_MISSING(S,h),r,o,u)}),!d.read&&E.read===!0&&(d.read=!0),!d.insert&&E.insert===!0&&(d.insert=!0),!d.update&&E.update===!0&&(d.update=!0)}if(_.read===!1&&d.read===!0||_.insert===!1&&d.insert===!0||_.update===!1&&d.update===!0){let f=`${o}.${u}`;St(_t.MISMATCHED_TABLE_ATTR_PERMS(f),r,o,u)}}}}return E3(r)}a(bD,"customValidate");yD.exports={addRoleValidation:u3,alterRoleValidation:l3,dropRoleValidation:_3};function f3(e){let{operation:t,permission:r}=e;if(t===ca.OPERATIONS_ENUM.ADD_ROLE||t===ca.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 _t.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?ca.ROLE_TYPES_ENUM.SUPER_USER:ca.ROLE_TYPES_ENUM.CLUSTER_USER;return _t.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(f3,"validateNoSUPerms");function E3(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:_t.ROLE_PERMS_ERROR,...e};return t3(new Error,n,n3.BAD_REQUEST)}else return null}a(E3,"generateRolePermResponse");function St(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(St,"addPermError")});var TS=R((X_e,DD)=>{"use strict";var ID=cn(),wD=Br(),h3=Vi(),hS=ND(),mS=Rs(),m3=require("uuid").v4,p3=require("util"),fd=U(),S3=Q(),pS=wD.searchByValue,T3=wD.searchByHash,g3=p3.promisify(h3.delete),R3=Zn(),A3=ta(),{hdb_errors:O3,handleHDBError:to}=ne(),{HDB_ERROR_MSGS:CD,HTTP_STATUS_CODES:nu}=O3,{UserEventMsg:SS}=Dn();DD.exports={addRole:b3,alterRole:y3,dropRole:N3,listRoles:I3};function ES(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(ES,"scrubRoleDetails");async function b3(e){let t=hS.addRoleValidation(e);if(t)throw t;e=ES(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 pS(r)||[])}catch(i){throw to(i)}if(n&&n.length>0)throw to(new Error,CD.ROLE_ALREADY_EXISTS(e.role),nu.CONFLICT,void 0,void 0,!0);e.id||(e.id=m3());let s={operation:"insert",schema:"system",table:"hdb_role",hash_attribute:"id",records:[e]};return await ID.insert(s),mS.signalUserChange(new SS(process.pid)),e=ES(e),e}a(b3,"addRole");async function y3(e){let t=hS.alterRoleValidation(e);if(t)throw t;e=ES(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await ID.update(r)}catch(s){throw to(s)}if(n&&n?.message==="updated 0 of 1 records")throw to(new Error,"Invalid role id",nu.BAD_REQUEST,void 0,void 0,!0);return await mS.signalUserChange(new SS(process.pid)),e}a(y3,"alterRole");async function N3(e){let t=hS.dropRoleValidation(e);if(t)throw to(new Error,t,nu.BAD_REQUEST,void 0,void 0,!0);let r=new A3(fd.SYSTEM_SCHEMA_NAME,fd.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await T3(r));if(n.length===0)throw to(new Error,CD.ROLE_NOT_FOUND,nu.NOT_FOUND,void 0,void 0,!0);let s=new R3(fd.SYSTEM_SCHEMA_NAME,fd.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await pS(s)),o=!1;if(S3.isEmptyOrZeroLength(i)===!1){for(let u=0;u<i.length;u++)if(i[u].active===!0){o=!0;break}}if(o===!0)throw to(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,nu.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await g3(c),mS.signalUserChange(new SS(process.pid)),`${n[0].role} successfully deleted`}a(N3,"dropRole");async function I3(){return pS({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(I3,"listRoles")});var PD=R((Z_e,UD)=>{"use strict";var w3=te(),_i=require("joi"),C3=rt(),LD=require("moment"),D3=require("fs-extra"),gS=require("path"),L3=require("lodash"),su=U(),{LOG_LEVELS:ro}=U(),M3="YYYY-MM-DD hh:mm:ss",U3=gS.resolve(__dirname,"../logs");UD.exports=function(e){return C3.validateBySchema(e,P3)};var P3=_i.object({from:_i.custom(MD),until:_i.custom(MD),level:_i.valid(ro.NOTIFY,ro.FATAL,ro.ERROR,ro.WARN,ro.INFO,ro.DEBUG,ro.TRACE),order:_i.valid("asc","desc"),limit:_i.number().min(1),start:_i.number().min(0),log_name:_i.custom(v3)});function MD(e,t){if(LD(e,LD.ISO_8601).format(M3)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(MD,"validateDatetime");function v3(e,t){if(L3.invert(su.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=w3.get(su.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?su.LOG_NAMES.HDB:e,i=s===su.LOG_NAMES.INSTALL?gS.join(U3,su.LOG_NAMES.INSTALL):gS.join(n,s);return D3.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(v3,"validateReadLogPath")});var AS=R((tde,BD)=>{"use strict";var Ed=U(),B3=K(),H3=te(),x3=PD(),RS=require("path"),vD=require("fs-extra"),{once:G3}=require("events"),{handleHDBError:F3,hdb_errors:q3}=ne(),{PACKAGE_ROOT:k3}=U(),V3=RS.join(k3,"logs"),$3=1e3,Y3=200;BD.exports=K3;async function K3(e){let t=x3(e);if(t)throw F3(t,t.message,q3.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=H3.get(Ed.HDB_SETTINGS_NAMES.LOG_PATH_KEY),n=e.log_name===void 0?Ed.LOG_NAMES.HDB:e.log_name,s=n===Ed.LOG_NAMES.INSTALL?RS.join(V3,Ed.LOG_NAMES.INSTALL):RS.join(r,n),i=e.level!==void 0,o=i?e.level:void 0,c=e.from!==void 0,u=c?new Date(e.from):void 0,_=e.until!==void 0,l=_?new Date(e.until):void 0,d=e.limit===void 0?$3:e.limit,f=e.order===void 0?void 0:e.order,E=e.start===void 0?0:e.start,h=E+d,S=0;f==="desc"&&!u&&!l&&(S=Math.max(vD.statSync(s).size-(h+5)*Y3,0));let p=vD.createReadStream(s,{start:S});p.on("error",P=>{B3.error(P)});let T=0,A=[],g="",L;p.on("data",P=>{let k=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;P=g+P;let H=0,X;for(;(X=k.exec(P))&&!p.destroyed;){L&&(L.message=P.slice(H,X.index),v(L));let[z,J,me]=X,ce=me.split("] ["),de=ce[0],De=ce[1];ce.splice(0,2),L={timestamp:J,thread:de,level:De,tags:ce,message:""},H=X.index+z.length}g=P.slice(H)}),p.on("end",P=>{p.destroyed||L&&(L.message=g.trim(),v(L))}),p.resume();function v(P){let k,H,X;switch(!0){case(i&&c&&_):k=new Date(P.timestamp),H=new Date(u),X=new Date(l),P.level===o&&k>=H&&k<=X&&T<E?T++:P.level===o&&k>=H&&k<=X&&(di(P,f,A),T++,T===h&&p.destroy());break;case(i&&c):k=new Date(P.timestamp),H=new Date(u),P.level===o&&k>=H&&T<E?T++:P.level===o&&k>=H&&(di(P,f,A),T++,T===h&&p.destroy());break;case(i&&_):k=new Date(P.timestamp),X=new Date(l),P.level===o&&k<=X&&T<E?T++:P.level===o&&k<=X&&(di(P,f,A),T++,T===h&&p.destroy());break;case(c&&_):k=new Date(P.timestamp),H=new Date(u),X=new Date(l),k>=H&&k<=X&&T<E?T++:k>=H&&k<=X&&(di(P,f,A),T++,T===h&&p.destroy());break;case i:P.level===o&&T<E?T++:P.level===o&&(di(P,f,A),T++,T===h&&p.destroy());break;case c:k=new Date(P.timestamp),H=new Date(u),k>=H&&T<E?T++:k>=H&&T>=E&&(di(P,f,A),T++,T===h&&p.destroy());break;case _:k=new Date(P.timestamp),X=new Date(l),k<=X&&T<E?T++:k<=X&&T>=E&&(di(P,f,A),T++,T===h&&p.destroy());break;default:T<E?T++:(di(P,f,A),T++,T===h&&p.destroy())}}return a(v,"onLogMessage"),await G3(p,"close"),A}a(K3,"readLog");function di(e,t,r){t==="desc"?W3(e,r):t==="asc"?Q3(e,r):r.push(e)}a(di,"pushLineToResult");function W3(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(W3,"insertDescending");function Q3(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(Q3,"insertAscending")});var hd=R((ode,FD)=>{"use strict";var OS=require("joi"),{string:iu,boolean:HD,date:z3}=OS.types(),J3=rt(),{validateSchemaExists:nde,validateTableExists:sde,validateSchemaName:ide}=Qn(),X3=U(),j3=nt(),xD=te();xD.initSync();var Z3=iu.invalid(xD.get(X3.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(j3.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(),GD={operation:iu.valid("add_node","update_node","set_node_replication"),node_name:Z3,subscriptions:OS.array().items({table:iu.optional(),schema:iu.optional(),database:iu.optional(),subscribe:HD.required(),publish:HD.required().custom(tX),start_time:z3.iso()}).min(1).required()};function eX(e){return J3.validateBySchema(e,OS.object(GD))}a(eX,"addUpdateNodeValidator");function tX(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(tX,"checkForFalsy");FD.exports={addUpdateNodeValidator:eX,validation_schema:GD}});var kD=R((cde,qD)=>{var rX=rt(),nX={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};qD.exports=function(e){return rX.validateObject(e,nX)}});var yS=R((ude,VD)=>{"use strict";var sX=U().OPERATIONS_ENUM,bS=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}};VD.exports=bS});var YD=R((_de,$D)=>{"use strict";var iX={OPERATION:"operation",REFRESH:"refresh"},NS=class{static{a(this,"JWTTokens")}constructor(t,r){this.operation_token=t,this.refresh_token=r}},IS=class{static{a(this,"JWTRSAKeys")}constructor(t,r,n){this.public_key=t,this.private_key=r,this.passphrase=n}};$D.exports={JWTTokens:NS,TOKEN_TYPE_ENUM:iX,JWTRSAKeys:IS}});var cu=R((fde,zD)=>{"use strict";var au=require("jsonwebtoken"),wS=require("fs-extra"),CS=Q(),ln=U(),{handleHDBError:Sr,hdb_errors:oX}=ne(),{HTTP_STATUS_CODES:Tr,AUTHENTICATION_ERROR_MSGS:gr}=oX,ou=K(),KD=L_(),MS=un(),aX=cn().update,cX=yS(),uX=Rs(),{UserEventMsg:lX}=Dn(),fi=te();fi.initSync();var DS=require("path"),{JWTTokens:_X,JWTRSAKeys:dX,TOKEN_TYPE_ENUM:md}=YD(),fX=fi.get(ln.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY)?fi.get(ln.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY):"1d",EX=fi.get(ln.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY)?fi.get(ln.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY):"30d",pd="RS256",LS;zD.exports={createTokens:hX,validateOperationToken:pX,refreshOperationToken:mX,validateRefreshToken:QD};async function hX(e){if(CS.isEmpty(e)||typeof e!="object")throw Sr(new Error,gr.INVALID_AUTH_OBJECT,Tr.BAD_REQUEST,void 0,void 0,!0);if(CS.isEmpty(e.username))throw Sr(new Error,gr.USERNAME_REQUIRED,Tr.BAD_REQUEST,void 0,void 0,!0);if(CS.isEmpty(e.password))throw Sr(new Error,gr.PASSWORD_REQUIRED,Tr.BAD_REQUEST,void 0,void 0,!0);let t;try{if(t=await MS.findAndValidateUser(e.username,e.password),!t)throw Sr(new Error,gr.INVALID_CREDENTIALS,Tr.UNAUTHORIZED,void 0,void 0,!0)}catch(f){throw ou.error(f),Sr(new Error,gr.INVALID_CREDENTIALS,Tr.UNAUTHORIZED,void 0,void 0,!0)}let r=await Sd(),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 WD(i,r.private_key,r.passphrase),c=await au.sign(i,{key:r.private_key,passphrase:r.passphrase},{expiresIn:EX,algorithm:pd,subject:md.REFRESH}),u=KD.hash(c),_=new cX(ln.SYSTEM_SCHEMA_NAME,ln.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,[{username:e.username,refresh_token:u}]),l,d;try{l=await aX(_)}catch(f){ou.error(f),d=f}if(d!==void 0||l.skipped_hashes.length>0)throw Sr(new Error,gr.REFRESH_TOKEN_SAVE_FAILED,Tr.INTERNAL_SERVER_ERROR);return uX.signalUserChange(new lX(process.pid)),new _X(o,c)}a(hX,"createTokens");async function WD(e,t,r){return await au.sign(e,{key:t,passphrase:r},{expiresIn:fX,algorithm:pd,subject:md.OPERATION})}a(WD,"signOperationToken");async function Sd(){if(LS===void 0)try{let e=DS.join(fi.getHdbBasePath(),ln.LICENSE_KEY_DIR_NAME,ln.JWT_ENUM.JWT_PASSPHRASE_NAME),t=DS.join(fi.getHdbBasePath(),ln.LICENSE_KEY_DIR_NAME,ln.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r=DS.join(fi.getHdbBasePath(),ln.LICENSE_KEY_DIR_NAME,ln.JWT_ENUM.JWT_PUBLIC_KEY_NAME),n=(await wS.readFile(e)).toString(),s=(await wS.readFile(t)).toString(),i=(await wS.readFile(r)).toString();LS=new dX(i,s,n)}catch(e){throw ou.error(e),Sr(new Error,gr.NO_ENCRYPTION_KEYS,Tr.INTERNAL_SERVER_ERROR)}return LS}a(Sd,"getJWTRSAKeys");async function mX(e){if(!e)throw Sr(new Error,gr.INVALID_BODY,Tr.BAD_REQUEST,void 0,void 0,!0);if(!e.refresh_token)throw Sr(new Error,gr.REFRESH_TOKEN_REQUIRED,Tr.BAD_REQUEST,void 0,void 0,!0);await QD(e.refresh_token);let t=await Sd(),r=await au.decode(e.refresh_token);return{operation_token:await WD({username:r.username,super_user:r.super_user,cluster_user:r.cluster_user},t.private_key,t.passphrase)}}a(mX,"refreshOperationToken");async function pX(e){try{let t=await Sd(),r=await au.verify(e,t.public_key,{algorithms:pd,subject:md.OPERATION});return await MS.findAndValidateUser(r.username,void 0,!1)}catch(t){throw ou.warn(t),t.name&&t.name==="TokenExpiredError"?Sr(new Error,gr.TOKEN_EXPIRED,Tr.FORBIDDEN):Sr(new Error,gr.INVALID_TOKEN,Tr.UNAUTHORIZED)}}a(pX,"validateOperationToken");async function QD(e){let t;try{let r=await Sd(),n=await au.verify(e,r.public_key,{algorithms:pd,subject:md.REFRESH});t=await MS.findAndValidateUser(n.username,void 0,!1)}catch(r){throw ou.warn(r),r.name&&r.name==="TokenExpiredError"?Sr(new Error,gr.TOKEN_EXPIRED,Tr.FORBIDDEN):Sr(new Error,gr.INVALID_TOKEN,Tr.UNAUTHORIZED)}if(!KD.validate(t.refresh_token,e))throw Sr(new Error,gr.INVALID_TOKEN,Tr.UNAUTHORIZED);return t}a(QD,"validateRefreshToken")});var US=R((mde,jD)=>{"use strict";var SX=kD(),la=require("passport"),TX=require("passport-local").Strategy,gX=require("passport-http").BasicStrategy,RX=require("util"),AX=un(),XD=RX.callbackify(AX.findAndValidateUser),hde=Lr(),OX=U(),JD=cu();la.use(new TX(function(e,t,r){XD(e,t,r)}));la.use(new gX(function(e,t,r){XD(e,t,r)}));la.serializeUser(function(e,t){t(null,e)});la.deserializeUser(function(e,t){t(null,e)});function bX(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":la.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===OX.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?JD.validateRefreshToken(s).then(o=>{e.body.refresh_token=s,r(null,o)}).catch(o=>{r(o)}):JD.validateOperationToken(s).then(o=>{r(null,o)}).catch(o=>{r(o)});break;default:la.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(bX,"authorize");function yX(e,t){let r=SX(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(yX,"checkPermissions");jD.exports={authorize:bX,checkPermissions:yX}});var _a=R((Sde,ZD)=>{"use strict";var PS=class{static{a(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},vS=class{static{a(this,"NodeSubscription")}constructor(t,r,n,s){this.schema=t,this.table=r,this.publish=n,this.subscribe=s}};ZD.exports={Node:PS,NodeSubscription:vS}});var tL=R((gde,eL)=>{"use strict";var NX=U().OPERATIONS_ENUM,BS=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=NX.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};eL.exports=BS});var uu=R((Ade,rL)=>{"use strict";var HS=class{static{a(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},xS=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)}};rL.exports={RemotePayloadObject:HS,RemotePayloadSubscription:xS}});var sL=R((bde,nL)=>{"use strict";var GS=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}};nL.exports=GS});var aL=R((Cde,oL)=>{"use strict";var IX=sL(),Nde=at(),iL=Ye(),wX=K(),{getSchemaPath:Ide,getTransactionAuditStorePath:wde}=Qe(),{getDatabases:CX}=(Ae(),ie(qe));oL.exports=DX;async function DX(e){let t=new IX;try{let r=CX()[e.schema]?.[e.name],n=r.primaryStore.getStats(),s=r.auditStore?.getStats(),i=await iL.environmentDataSize(schema_path,e.name),o=await iL.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){wX.warn(`unable to stat table dbi due to ${r}`)}return t}a(DX,"lmdbGetTableSize")});var uL=R((Lde,cL)=>{"use strict";var FS=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}};cL.exports=FS});var da=R((Bde,EL)=>{"use strict";var LX=require("fs-extra"),MX=require("path"),Zt=require("systeminformation"),Ei=K(),lL=Nt(),Ude=nt(),gd=U(),UX=aL(),PX=ti(),{getThreadInfo:_L}=ct(),JS=te();JS.initSync();var vX=uL(),{openEnvironment:Pde}=Ye(),{getSchemaPath:vde}=Qe(),{database:BX,databases:dL}=(Ae(),ie(qe)),Td;EL.exports={getHDBProcessInfo:$S,getNetworkInfo:KS,getDiskInfo:YS,getMemoryInfo:VS,getCPUInfo:kS,getTimeInfo:qS,getSystemInformation:WS,systemInformation:HX,getTableSize:QS,getMetrics:zS};function qS(){return Zt.time()}a(qS,"getTimeInfo");async function kS(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:o,governor:c,socket:u,cache:_,...l}=await Zt.cpu();l.cpu_speed=await Zt.cpuCurrentSpeed();let{raw_currentload:d,raw_currentload_idle:f,raw_currentload_irq:E,raw_currentload_nice:h,raw_currentload_system:S,raw_currentload_user:p,cpus:T,...A}=await Zt.currentLoad();return A.cpus=[],T.forEach(g=>{let{raw_load:L,raw_load_idle:v,raw_load_irq:P,raw_load_nice:k,raw_load_system:H,raw_load_user:X,...z}=g;A.cpus.push(z)}),l.current_load=A,l}catch(e){return Ei.error(`error in getCPUInfo: ${e}`),{}}}a(kS,"getCPUInfo");async function VS(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await Zt.mem();return Object.assign(s,process.memoryUsage())}catch(e){return Ei.error(`error in getMemoryInfo: ${e}`),{}}}a(VS,"getMemoryInfo");async function $S(){let e={core:[],clustering:[]};try{let t=await Zt.processes(),r;try{r=Number.parseInt(await LX.readFile(MX.join(JS.get(gd.CONFIG_PARAMS.ROOTPATH),gd.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===gd.NODE_ERROR_CODES.ENOENT)Ei.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 Ei.error(`error in getHDBProcessInfo: ${t}`),e}}a($S,"getHDBProcessInfo");async function YS(){let e={};try{let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await Zt.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:u,..._}=await Zt.fsStats();return e.read_write=_,e.size=await Zt.fsSize(),e}catch(t){return Ei.error(`error in getDiskInfo: ${t}`),e}}a(YS,"getDiskInfo");async function KS(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return e.default_interface=await Zt.networkInterfaceDefault(),e.latency=await Zt.inetChecksite("google.com"),(await Zt.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:o,dhcp:c,dnsSuffix:u,ieee8021xAuth:_,ieee8021xState:l,carrier_changes:d,...f}=n;e.interfaces.push(f)}),(await Zt.networkStats()).forEach(n=>{let{rx_sec:s,tx_sec:i,ms:o,...c}=n;e.stats.push(c)}),e}catch(t){return Ei.error(`error in getNetworkInfo: ${t}`),e}}a(KS,"getNetworkInfo");async function WS(){if(Td!==void 0)return Td;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:o,...c}=await Zt.osInfo();e=c;let u=await Zt.versions("node, npm");return e.node_version=u.node,e.npm_version=u.npm,Td=e,Td}catch(t){return Ei.error(`error in getSystemInformation: ${t}`),e}}a(WS,"getSystemInformation");async function QS(){let e=[],t=await PX.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await UX(n));return e}a(QS,"getTableSize");async function zS(){let e={};for(let t in dL){let r=e[t]={};for(let n in dL[t])try{let s=BX({database:t,table:n}),i=s.getStats();i.readers=s.readerList().split(/\n\s+/).slice(1).map(o=>{let[c,u,_]=o.trim().split(" ");return{pid:c,thread:u,txnid:_}}),r[n]=i}catch(s){Ei.notify(`Error getting stats for table ${n}: ${s}`)}}return e}a(zS,"getMetrics");async function fL(){if(JS.get(gd.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{jsm:e}=await lL.getNATSReferences(),t=await lL.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(fL,"getNatsStreamInfo");async function HX(e){let t=new vX;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await WS(),t.time=qS(),t.cpu=await kS(),t.memory=await VS(),t.disk=await YS(),t.network=await KS(),t.harperdb_processes=await $S(),t.table_size=await QS(),t.metrics=await zS(),t.threads=await _L(),t.replication=await fL(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await WS();break;case"time":t.time=qS();break;case"cpu":t.cpu=await kS();break;case"memory":t.memory=await VS();break;case"disk":t.disk=await YS();break;case"network":t.network=await KS();break;case"harperdb_processes":t.harperdb_processes=await $S();break;case"table_size":t.table_size=await QS();break;case"database_metrics":case"metrics":t.metrics=await zS();break;case"threads":t.threads=await _L();break;case"replication":t.replication=await fL();break;default:break}return t}a(HX,"systemInformation")});var lu=R((xde,xX)=>{xX.exports={name:"harperdb",version:"4.3.13",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","cloud","enterprise","Fastify","NATS"],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.535.0","@aws-sdk/lib-storage":"3.535.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.0.11",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.10.1",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.1",papaparse:"5.4.1",passport:"0.6.0","passport-http":"0.3.0","passport-local":"1.0.0",pino:"8.16.0",pm2:"5.3.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.16.0",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 Ad=R((Gde,hL)=>{"use strict";hL.exports={version:GX,printVersion:FX};var Rd=lu();function GX(){if(Rd)return Rd.version}a(GX,"version");function FX(){Rd&&console.log(`HarperDB Version ${Rd.version}`)}a(FX,"printVersion")});var ys=R((Vde,TL)=>{"use strict";var qX=cn(),XS=Q(),kX=require("util"),no=U(),mL=te();mL.initSync();var VX=US(),pL=Br(),{Node:qde,NodeSubscription:kde}=_a(),$X=ta(),YX=tL(),{RemotePayloadObject:KX,RemotePayloadSubscription:WX}=uu(),{handleHDBError:QX,hdb_errors:zX}=ne(),{HTTP_STATUS_CODES:JX,HDB_ERROR_MSGS:XX}=zX,jX=Zn(),ZX=da(),ej=Ad(),{getDatabases:tj}=(Ae(),ie(qe)),rj=kX.promisify(VX.authorize),nj=pL.searchByHash,sj=pL.searchByValue;TL.exports={authHeaderToUser:ij,isEmpty:oj,getNodeRecord:aj,upsertNodeRecord:cj,buildNodePayloads:uj,checkClusteringEnabled:lj,getAllNodeRecords:_j,getSystemInfo:dj,reverseSubscription:SL};async function ij(e){let t={headers:{authorization:e.hdb_auth_header}};return e.hdb_user=await rj(t,null),e}a(ij,"authHeaderToUser");function oj(e){return e==null}a(oj,"isEmpty");async function aj(e){let t=new $X(no.SYSTEM_SCHEMA_NAME,no.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return nj(t)}a(aj,"getNodeRecord");async function cj(e){let t=new YX(no.SYSTEM_SCHEMA_NAME,no.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return qX.upsert(t)}a(cj,"upsertNodeRecord");function SL(e){if(XS.isEmpty(e.subscribe)||XS.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(SL,"reverseSubscription");function uj(e,t,r,n){let s=[];for(let i=0,o=e.length;i<o;i++){let c=e[i],{schema:u,table:_}=c,l=XS.getTableHashAttribute(u,_),{subscribe:d,publish:f}=SL(c),E=tj()[u]?.[_],h=new WX(u,_,l,f,d,c.start_time,E.schemaDefined?E.attributes:void 0);s.push(h)}return new KX(r,t,s,n)}a(uj,"buildNodePayloads");function lj(){if(!mL.get(no.CONFIG_PARAMS.CLUSTERING_ENABLED))throw QX(new Error,XX.CLUSTERING_NOT_ENABLED,JX.BAD_REQUEST,void 0,void 0,!0)}a(lj,"checkClusteringEnabled");async function _j(){let e=new jX(no.SYSTEM_SCHEMA_NAME,no.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await sj(e))}a(_j,"getAllNodeRecords");async function dj(){let e=await ZX.getSystemInformation();return{hdb_version:ej.version(),node_version:e.node_version,platform:e.platform}}a(dj,"getSystemInfo")});var jS=R((Yde,IL)=>{"use strict";var Od=Nt(),gL=Q(),RL=nt(),AL=U(),bd=K(),OL=ld(),fj=Lp(),{RemotePayloadObject:Ej}=uu(),{handleHDBError:bL,hdb_errors:hj}=ne(),{HTTP_STATUS_CODES:yL}=hj,{NodeSubscription:NL}=_a();IL.exports=mj;async function mj(e,t){let r;try{r=await Od.request(`${t}.${RL.REQUEST_SUFFIX}`,new Ej(AL.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),bd.trace("Response from remote describe all request:",r)}catch(o){bd.error(`addNode received error from describe all request to remote node: ${o}`);let c=Od.requestErrorHandler(o,"add_node",t);throw bL(new Error,c,yL.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===RL.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let o=`Error returned from remote node ${t}: ${r.message}`;throw bL(new Error,o,yL.INTERNAL_SERVER_ERROR,"error",o)}let n=r.message,s=[],i=[];for(let o of e){let{table:c}=o,u=o.database??o.schema??"data";if(u===AL.SYSTEM_SCHEMA_NAME){await Od.createLocalTableStream(u,c);let h=new NL(u,c,o.publish,o.subscribe);h.start_time=o.start_time,i.push(h);continue}let _=gL.doesSchemaExist(u),l=n[u]!==void 0,d=c?gL.doesTableExist(u,c):!0,f=c?n?.[u]?.[c]!==void 0:!0;if(!_&&!l||!d&&!f){s.push(o);continue}if(!_&&l&&(bd.trace(`addNode creating schema: ${u}`),await OL.createSchema({operation:"create_schema",schema:u})),!d&&f){bd.trace(`addNode creating table: ${c} in schema: ${u} with attributes ${JSON.stringify(n[u][c].attributes)}`);let h=new fj(u,c,n[u][c].hash_attribute);n[u][c].attributes&&(h.attributes=n[u][c].attributes),await OL.createTable(h)}await Od.createLocalTableStream(u,c);let E=new NL(u,c,o.publish,o.subscribe);E.start_time=o.start_time,i.push(E)}return{added:i,skipped:s}}a(mj,"reviewSubscriptions")});var wd=R((Wde,DL)=>{"use strict";var{handleHDBError:yd,hdb_errors:pj}=ne(),{HTTP_STATUS_CODES:Nd}=pj,{addUpdateNodeValidator:Sj}=hd(),Id=K(),CL=U(),wL=nt(),Tj=Q(),_u=Nt(),du=ys(),gj=te(),Rj=jS(),{Node:Aj,NodeSubscription:Oj}=_a(),{broadcast:bj}=ct(),yj="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",Nj="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",Ij=gj.get(CL.CONFIG_PARAMS.CLUSTERING_NODENAME);DL.exports=wj;async function wj(e,t=!1){Id.trace("addNode called with:",e),du.checkClusteringEnabled();let r=Sj(e);if(r)throw yd(r,r.message,Nd.BAD_REQUEST,void 0,void 0,!0);let n=e.node_name;if(!t){let d=await du.getNodeRecord(n);if(!Tj.isEmptyOrZeroLength(d))throw yd(new Error,`Node '${n}' has already been added, perform update_node to proceed.`,Nd.BAD_REQUEST,void 0,void 0,!0)}let{added:s,skipped:i}=await Rj(e.subscriptions,n),o={message:void 0,added:s,skipped:i};if(s.length===0)return o.message=yj,o;let c=du.buildNodePayloads(s,Ij,CL.OPERATIONS_ENUM.ADD_NODE,await du.getSystemInfo()),u=[];for(let d=0,f=s.length;d<f;d++){let E=s[d];s[d].start_time===void 0&&delete s[d].start_time,u.push(new Oj(E.schema,E.table,E.publish,E.subscribe))}Id.trace("addNode sending remote payload:",c);let _;try{_=await _u.request(`${n}.${wL.REQUEST_SUFFIX}`,c)}catch(d){Id.error(`addNode received error from request: ${d}`);for(let E=0,h=s.length;E<h;E++){let S=s[E];S.publish=!1,S.subscribe=!1,await _u.updateRemoteConsumer(S,n)}let f=_u.requestErrorHandler(d,"add_node",n);throw yd(new Error,f,Nd.INTERNAL_SERVER_ERROR,"error",f)}if(_.status===wL.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let d=`Error returned from remote node ${n}: ${_.message}`;throw yd(new Error,d,Nd.INTERNAL_SERVER_ERROR,"error",d)}Id.trace(_);for(let d=0,f=s.length;d<f;d++){let E=s[d];await _u.updateRemoteConsumer(E,n),E.subscribe===!0&&await _u.updateConsumerIterator(E.schema,E.table,n,"start")}let l=new Aj(n,u,_.system_info);return await du.upsertNodeRecord(l),bj({type:"nats_update"}),i.length>0?o.message=Nj:o.message=`Successfully added '${n}' to manifest`,o}a(wj,"addNode")});var tT=R((Jde,UL)=>{"use strict";var{handleHDBError:ZS,hdb_errors:Cj}=ne(),{HTTP_STATUS_CODES:eT}=Cj,{addUpdateNodeValidator:Dj}=hd(),fu=K(),ML=U(),LL=nt(),zde=Q(),Eu=Nt(),hu=ys(),Lj=te(),{cloneDeep:Mj}=require("lodash"),Uj=jS(),{Node:Pj,NodeSubscription:vj}=_a(),{broadcast:Bj}=ct(),Hj="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",Gj=Lj.get(ML.CONFIG_PARAMS.CLUSTERING_NODENAME);UL.exports=Fj;async function Fj(e){fu.trace("updateNode called with:",e),hu.checkClusteringEnabled();let t=Dj(e);if(t)throw ZS(t,t.message,eT.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await hu.getNodeRecord(r);s.length>0&&(n=Mj(s));let{added:i,skipped:o}=await Uj(e.subscriptions,r),c={message:void 0,updated:i,skipped:o};if(i.length===0)return c.message=Hj,c;let u=hu.buildNodePayloads(i,Gj,ML.OPERATIONS_ENUM.UPDATE_NODE,await hu.getSystemInfo());for(let l=0,d=i.length;l<d;l++){let f=i[l];fu.trace(`updateNode updating work stream for node: ${r} subscription:`,f),i[l].start_time===void 0&&delete i[l].start_time}fu.trace("updateNode sending remote payload:",u);let _;try{_=await Eu.request(`${r}.${LL.REQUEST_SUFFIX}`,u)}catch(l){fu.error(`updateNode received error from request: ${l}`);let d=Eu.requestErrorHandler(l,"update_node",r);throw ZS(new Error,d,eT.INTERNAL_SERVER_ERROR,"error",d)}if(_.status===LL.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let l=`Error returned from remote node ${r}: ${_.message}`;throw ZS(new Error,l,eT.INTERNAL_SERVER_ERROR,"error",l)}fu.trace(_);for(let l=0,d=i.length;l<d;l++){let f=i[l];await Eu.updateRemoteConsumer(f,r),f.subscribe===!0?await Eu.updateConsumerIterator(f.schema,f.table,r,"start"):await Eu.updateConsumerIterator(f.schema,f.table,r,"stop")}return n||(n=[new Pj(r,[],_.system_info)]),await qj(n[0],i,_.system_info),o.length>0?c.message=xj:c.message=`Successfully updated '${r}'`,c}a(Fj,"updateNode");async function qj(e,t,r){let n=e;for(let s=0,i=t.length;s<i;s++){let o=t[s],c=!1;for(let u=0,_=e.subscriptions.length;u<_;u++){let l=n.subscriptions[u];if(l.schema===o.schema&&l.table===o.table){l.publish=o.publish,l.subscribe=o.subscribe,c=!0;break}}c||n.subscriptions.push(new vj(o.schema,o.table,o.publish,o.subscribe))}n.system_info=r,await hu.upsertNodeRecord(n),Bj({type:"nats_update"})}a(qj,"updateNodeTable")});var xL=R((jde,HL)=>{"use strict";var BL=require("joi"),{string:PL}=BL.types(),kj=rt(),vL=U(),Vj=te(),$j=nt();HL.exports=Yj;function Yj(e){let t=PL.invalid(Vj.get(vL.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern($j.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=BL.object({operation:PL.valid(vL.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return kj.validateBySchema(e,r)}a(Yj,"removeNodeValidator")});var Dd=R((efe,VL)=>{"use strict";var{handleHDBError:GL,hdb_errors:Kj}=ne(),{HTTP_STATUS_CODES:FL}=Kj,Wj=xL(),mu=K(),qL=ys(),Qj=Q(),Cd=U(),kL=nt(),rT=Nt(),zj=te(),{RemotePayloadObject:Jj}=uu(),{NodeSubscription:Xj}=_a(),jj=Qc(),Zj=Vi(),{broadcast:eZ}=ct(),tZ=zj.get(Cd.CONFIG_PARAMS.CLUSTERING_NODENAME);VL.exports=rZ;async function rZ(e){mu.trace("removeNode called with:",e),qL.checkClusteringEnabled();let t=Wj(e);if(t)throw GL(t,t.message,FL.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await qL.getNodeRecord(r);if(Qj.isEmptyOrZeroLength(n))throw GL(new Error,`Node '${r}' was not found.`,FL.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new Jj(Cd.OPERATIONS_ENUM.REMOVE_NODE,tZ,[]),i,o=!1;for(let u=0,_=n.subscriptions.length;u<_;u++){let l=n.subscriptions[u];l.subscribe===!0&&await rT.updateConsumerIterator(l.schema,l.table,r,"stop");try{await rT.updateRemoteConsumer(new Xj(l.schema,l.table,!1,!1),r)}catch(d){mu.error(d)}}try{i=await rT.request(`${r}.${kL.REQUEST_SUFFIX}`,s),mu.trace("Remove node reply from remote node:",r,i)}catch(u){mu.error("removeNode received error from request:",u),o=!0}let c=new jj(Cd.SYSTEM_SCHEMA_NAME,Cd.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await Zj.deleteRecord(c),eZ({type:"nats_update"}),i?.status===kL.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||o?(mu.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(rZ,"removeNode")});var KL=R((rfe,YL)=>{"use strict";var $L=require("joi"),{string:nZ,array:sZ}=$L.types(),iZ=rt(),oZ=hd();YL.exports=aZ;function aZ(e){let t=$L.object({operation:nZ.valid("configure_cluster").required(),connections:sZ.items(oZ.validation_schema).required()});return iZ.validateBySchema(e,t)}a(aZ,"configureClusterValidator")});var nT=R((sfe,XL)=>{"use strict";var cZ=U(),Ld=K(),uZ=Q(),lZ=Dd(),_Z=wd(),WL=ys(),dZ=KL(),{handleHDBError:QL,hdb_errors:fZ}=ne(),{HTTP_STATUS_CODES:zL}=fZ,EZ="Configure cluster complete.",hZ="Failed to configure the cluster. Check the logs for more details.",mZ="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";XL.exports=pZ;async function pZ(e){Ld.trace("configure cluster called with:",e),WL.checkClusteringEnabled();let t=dZ(e);if(t)throw QL(t,t.message,zL.BAD_REQUEST,void 0,void 0,!0);let r=await WL.getAllNodeRecords(),n=[];for(let l=0,d=r.length;l<d;l++){let f=await JL(lZ,{operation:cZ.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[l].name},r[l].name);n.push(f)}Ld.trace("All results from configure_cluster remove node:",n);let s=[],i=e.connections.length;for(let l=0;l<i;l++){let d=e.connections[l],f=await JL(_Z,d,d.node_name);s.push(f)}Ld.trace("All results from configure_cluster add node:",s);let o=[],c=[],u=!1,_=n.concat(s);for(let l=0,d=_.length;l<d;l++){let f=_[l];f.status==="rejected"&&(Ld.error(f),o.includes(f.node_name)||o.push(f.node_name)),(f?.result?.message?.includes?.("Successfully")||f?.result?.includes?.("Successfully"))&&(u=!0),!(typeof f.result=="string"&&f.result.includes("Successfully removed")||f.status==="rejected")&&c.push({node_name:f?.node_name,subscriptions:f?.result})}if(uZ.isEmptyOrZeroLength(o))return{message:EZ,connections:c};if(u)return{message:mZ,failed_nodes:o,connections:c};throw QL(new Error,hZ,zL.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(pZ,"configureCluster");async function JL(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){return{node_name:r,error:n,status:"rejected"}}}a(JL,"functionWrapper")});var tM=R((ofe,eM)=>{"use strict";var pu=require("joi"),SZ=rt(),{validateSchemaExists:jL,validateTableExists:TZ,validateSchemaName:ZL}=Qn(),gZ=pu.object({operation:pu.string().valid("purge_stream"),schema:pu.string().custom(jL).custom(ZL).optional(),database:pu.string().custom(jL).custom(ZL).optional(),table:pu.string().custom(TZ).required()});function RZ(e){return SZ.validateBySchema(e,gZ)}a(RZ,"purgeStreamValidator");eM.exports=RZ});var sT=R((cfe,rM)=>{"use strict";var{handleHDBError:AZ,hdb_errors:OZ}=ne(),{HTTP_STATUS_CODES:bZ}=OZ,yZ=tM(),NZ=Nt(),IZ=ys();rM.exports=wZ;async function wZ(e){e.schema=e.schema??e.database;let t=yZ(e);if(t)throw AZ(t,t.message,bZ.BAD_REQUEST,void 0,void 0,!0);IZ.checkClusteringEnabled();let{schema:r,table:n,options:s}=e;return await NZ.purgeTableStream(r,n,s),`Successfully purged table '${r}.${n}'`}a(wZ,"purgeStream")});var aT=R((lfe,cM)=>{"use strict";var oT=ys(),CZ=Nt(),iM=te(),Md=U(),so=nt(),DZ=Q(),iT=K(),{RemotePayloadObject:LZ}=uu(),{ErrorCode:nM}=require("nats"),sM=iM.get(Md.CONFIG_PARAMS.CLUSTERING_ENABLED),oM=iM.get(Md.CONFIG_PARAMS.CLUSTERING_NODENAME);cM.exports={clusterStatus:MZ,buildNodeStatus:aM};async function MZ(){let e={node_name:oM,is_enabled:sM,connections:[]};if(!sM)return e;let t=await oT.getAllNodeRecords();if(DZ.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(aM(t[n],e.connections));return await Promise.allSettled(r),e}a(MZ,"clusterStatus");async function aM(e,t){let r=e.name,n=new LZ(Md.OPERATIONS_ENUM.CLUSTER_STATUS,oM,void 0,await oT.getSystemInfo()),s,i,o=so.CLUSTER_STATUS_STATUSES.OPEN;try{let u=Date.now();s=await CZ.request(so.REQUEST_SUBJECT(r),n),i=Date.now()-u,s.status===so.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=so.CLUSTER_STATUS_STATUSES.CLOSED,iT.error(`Error getting node status from ${r} `,s))}catch(u){iT.warn(`Error getting node status from ${r}`,u),u.code===nM.NoResponders?o=so.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:u.code===nM.Timeout?o=so.CLUSTER_STATUS_STATUSES.TIMEOUT:o=so.CLUSTER_STATUS_STATUSES.CLOSED}let c=new UZ(r,o,s?.message?.ports?.clustering,s?.message?.ports?.operations_api,i,s?.message?.uptime,e.subscriptions,s?.message?.system_info);try{let u={name:r,system_info:s?.message?.system_info};e.system_info?.hdb_version!==Md.PRE_4_0_0_VERSION&&await oT.upsertNodeRecord(u)}catch(u){iT.error("Cluster status encountered an error updating system info for node:",r,u)}t.push(c)}a(aM,"buildNodeStatus");function UZ(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(UZ,"NodeStatusObject")});var uT=R((dfe,uM)=>{"use strict";var{handleHDBError:PZ,hdb_errors:vZ}=ne(),{HTTP_STATUS_CODES:BZ}=vZ,HZ=Nt(),xZ=ys(),cT=Q(),Ud=require("joi"),GZ=rt(),FZ=2e3,qZ=Ud.object({timeout:Ud.number().min(1),connected_nodes:Ud.boolean(),routes:Ud.boolean()});uM.exports=kZ;async function kZ(e){xZ.checkClusteringEnabled();let t=GZ.validateBySchema(e,qZ);if(t)throw PZ(t,t.message,BZ.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||cT.autoCastBoolean(n),o=s===void 0||cT.autoCastBoolean(s),c={nodes:[]},u=await HZ.getServerList(r??FZ),_={};if(i)for(let l=0,d=u.length;l<d;l++){let f=u[l].statsz;f&&(_[u[l].server.name]=f.routes)}for(let l=0,d=u.length;l<d;l++){if(u[l].statsz)continue;let f=u[l].server,E=u[l].data;if(f.name.endsWith("-hub")){let h={name:f.name.slice(0,-4),response_time:u[l].response_time};i&&(h.connected_nodes=[],_[f.name]&&_[f.name].forEach(S=>{h.connected_nodes.includes(S.name.slice(0,-4))||h.connected_nodes.push(S.name.slice(0,-4))})),o&&(h.routes=E.cluster?.urls?E.cluster?.urls.map(S=>({host:S.split(":")[0],port:cT.autoCast(S.split(":")[1])})):[]),c.nodes.push(h)}}return c}a(kZ,"clusterNetwork")});var fM=R((Efe,dM)=>{"use strict";var lT=require("joi"),lM=rt(),{route_constraints:_M}=Vm();dM.exports={setRoutesValidator:VZ,deleteRoutesValidator:$Z};function VZ(e){let t=lT.object({server:lT.valid("hub","leaf").required(),routes:_M.required()});return lM.validateBySchema(e,t)}a(VZ,"setRoutesValidator");function $Z(e){let t=lT.object({routes:_M.required()});return lM.validateBySchema(e,t)}a($Z,"deleteRoutesValidator")});var dT=R((mfe,pM)=>{"use strict";var io=dr(),_T=Q(),Pd=U(),EM=fM(),{handleHDBError:hM,hdb_errors:YZ}=ne(),{HTTP_STATUS_CODES:mM}=YZ,KZ="cluster routes successfully set",WZ="cluster routes successfully deleted";pM.exports={setRoutes:QZ,getRoutes:zZ,deleteRoutes:JZ};function QZ(e){let t=EM.setRoutesValidator(e);if(t)throw hM(t,t.message,mM.BAD_REQUEST,void 0,void 0,!0);let r=io.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,u=e.routes.length;c<u;c++){let _=e.routes[c];_.port=_T.autoCast(_.port);let l=n.some(f=>f.host===_.host&&f.port===_.port),d=s.some(f=>f.host===_.host&&f.port===_.port);l||d?i.push(_):(n.push(_),o.push(_))}return e.server==="hub"?io.updateConfigValue(Pd.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,n):io.updateConfigValue(Pd.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n),{message:KZ,set:o,skipped:i}}a(QZ,"setRoutes");function zZ(){let e=io.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}a(zZ,"getRoutes");function JZ(e){let t=EM.deleteRoutesValidator(e);if(t)throw hM(t,t.message,mM.BAD_REQUEST,void 0,void 0,!0);let r=io.getClusteringRoutes(),n=r.hub_routes,s=r.leaf_routes,i=[],o=[],c=!1,u=!1;for(let _=0,l=e.routes.length;_<l;_++){let d=e.routes[_],f=!1;for(let E=0,h=n.length;E<h;E++){let S=n[E];if(d.host===S.host&&d.port===S.port){n.splice(E,1),f=!0,c=!0,i.push(d);break}}if(!f){let E=!0;for(let h=0,S=s.length;h<S;h++){let p=s[h];if(d.host===p.host&&d.port===p.port){s.splice(h,1),u=!0,E=!1,i.push(d);break}}E&&o.push(d)}}return c&&(n=_T.isEmptyOrZeroLength(n)?null:n,io.updateConfigValue(Pd.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,n)),u&&(s=_T.isEmptyOrZeroLength(s)?null:s,io.updateConfigValue(Pd.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,s)),{message:WZ,deleted:i,skipped:o}}a(JZ,"deleteRoutes")});var TM=R((Sfe,SM)=>{"use strict";var Su=require("alasql"),oo=require("recursive-iterator"),Pn=K(),XZ=Q(),Tu=U(),fT=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,ZZ(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=>Tu.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=>!Tu.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][Tu.PERMS_CRUD_ENUM.READ]){let c;t[i].tables[o].attribute_permissions.length>0?c=jZ(t[i].tables[o].attribute_permissions):c=global.hdb_schema[i][o].attributes.map(_=>({attribute_name:_.attribute}));let u=this.affected_attributes.get(i).get(o).filter(_=>!Tu.SEARCH_WILDCARDS.includes(_));c.forEach(({attribute_name:_})=>{let l=new Su.yy.Column({columnid:_});s.tableid&&(l.tableid=s.tableid),this.ast.columns.push(l),u.includes(_)||u.push(_)}),this.affected_attributes.get(i).set(o,u)}}),this.ast}};function jZ(e){return e.filter(t=>t[Tu.PERMS_CRUD_ENUM.READ])}a(jZ,"filterReadRestrictedAttrs");function ZZ(e,t,r,n,s){e5(e,t,r,n,s)}a(ZZ,"interpretAST");function gu(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(gu,"addSchemaTableToMap");function e5(e,t,r,n,s){if(!e){Pn.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof Su.yy.Insert?s5(e,t,r):e instanceof Su.yy.Select?t5(e,t,r,n,s):e instanceof Su.yy.Update?r5(e,t,r):e instanceof Su.yy.Delete?n5(e,t,r):Pn.error("AST in getRecordAttributesAST() is not a valid SQL type.")}a(e5,"getRecordAttributesAST");function t5(e,t,r,n,s){if(!e){Pn.info("getSelectAttributes: invalid SQL syntax tree");return}if(!e.from||e.from[0]===void 0)return;let i=e.from[0].databaseid;if(XZ.isEmptyOrZeroLength(i)){Pn.error("No schema specified");return}e.from.forEach(c=>{gu(c,t,r,n,s)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),gu(c.table,t,r,n,s)});let o=new oo(e.columns);for(let{node:c}of o)if(c&&c.columnid){let u=c.tableid,_=n.has(u)?n.get(u):i;if(u||(u=e.from[0].tableid),!t.get(_).has(u))if(r.has(u))u=r.get(u);else{Pn.info(`table specified as ${u} not found.`);return}t.get(_).get(u).indexOf(c.columnid)<0&&t.get(_).get(u).push(c.columnid)}if(e.where){let c=new oo(e.where),u=e.from[0].tableid;for(let{node:_}of c)if(_&&_.columnid){let l=_.tableid?_.tableid:u;if(!t.get(i).has(l))if(r.has(l))l=r.get(l);else{Pn.info(`table specified as ${l} not found.`);continue}t.get(i).get(l).indexOf(_.columnid)<0&&t.get(i).get(l).push(_.columnid)}}if(e.joins&&e.joins.forEach(c=>{let u=new oo(c.on);for(let{node:_}of u)if(_&&_.columnid){let l=_.tableid,d=s.get(l);if(!t.get(d).has(l))if(r.has(l))l=r.get(l);else{Pn.info(`table specified as ${l} not found.`);continue}t.get(d).get(l).indexOf(_.columnid)<0&&t.get(d).get(l).push(_.columnid)}}),e.order){let c=new oo(e.order);for(let{node:u}of c)if(u&&u.columnid){let _=u.tableid,l=n.has(_)?n.get(_):i;if(_||(_=e.from[0].tableid),!t.get(l).has(_))if(r.has(_))_=r.get(_);else{Pn.info(`table specified as ${_} not found.`);return}t.get(l).get(_).indexOf(u.columnid)<0&&t.get(l).get(_).push(u.columnid)}}}a(t5,"getSelectAttributes");function r5(e,t,r){if(!e){Pn.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new oo(e.columns),s=e.table.databaseid;gu(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&ET(e.table.tableid,s,i.columnid,t,r)}a(r5,"getUpdateAttributes");function n5(e,t,r){if(!e){Pn.info("getDeleteAttributes: invalid SQL syntax tree");return}let n=new oo(e.where),s=e.table.databaseid;gu(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&ET(e.table.tableid,s,i.columnid,t,r)}a(n5,"getDeleteAttributes");function s5(e,t,r){if(!e){Pn.info("getInsertAttributes: invalid SQL syntax tree");return}let n=new oo(e.columns),s=e.into.databaseid;gu(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&ET(e.into.tableid,s,i.columnid,t,r)}a(s5,"getInsertAttributes");function ET(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(ET,"pushAttribute");SM.exports=fT});var pT=R((gfe,OM)=>{var vd=Wi(),gM=require("chalk"),Vr=K(),RM=require("prompt"),{promisify:i5}=require("util"),hT=U(),o5=require("fs-extra"),a5=require("path"),c5=Q(),u5=Ad(),AM=te();AM.initSync();var l5=require("moment"),_5=i5(RM.get),d5=a5.join(AM.getHdbBasePath(),hT.LICENSE_KEY_DIR_NAME,hT.LICENSE_FILE_NAME,hT.LICENSE_FILE_NAME);OM.exports={getFingerprint:E5,setLicense:f5,parseLicense:mT,register:h5,getRegistrationInfo:p5};async function f5(e){if(e&&e.key&&e.company){try{Vr.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await mT(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw Vr.error(r),Vr.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}a(f5,"setLicense");async function E5(){let e={};try{e=await vd.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw Vr.error(r),Vr.error(t),new Error(r)}return e}a(E5,"getFingerprint");async function mT(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");Vr.info("Validating license input...");let r=vd.validateLicense(e,t);if(Vr.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(Vr.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(Vr.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{Vr.info("writing license to disk"),await o5.writeFile(d5,JSON.stringify({license_key:e,company:t}))}catch(n){throw Vr.error("Failed to write License"),n}return"Registration successful."}a(mT,"parseLicense");async function h5(){let e=await m5();return mT(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(h5,"register");async function m5(){let e=await vd.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:gM.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:gM.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{RM.start()}catch(n){Vr.error(n)}let r;try{r=await _5(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}a(m5,"promptForRegistration");async function p5(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await vd.getLicense()}catch(r){throw Vr.error(`There was an error when searching licenses due to: ${r.message}`),r}if(c5.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=u5.version(),e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=l5.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(p5,"getRegistrationInfo")});var yM=R((Afe,bM)=>{"use strict";var S5=nt(),ST=class{static{a(this,"HubConfigObject")}constructor(t,r,n,s,i,o,c,u,_,l,d,f,E,h){this.port=t,o===null&&(o=void 0),this.server_name=r+S5.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:u},this.leafnodes={port:_,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c}},this.cluster={name:l,port:d,routes:f,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c,verify:u}},this.accounts={SYS:{users:E},HDB:{users:h}},this.system_account="SYS"}};bM.exports=ST});var wM=R((bfe,IM)=>{"use strict";var NM=nt(),TT=class{static{a(this,"LeafConfigObject")}constructor(t,r,n,s,i,o,c,u,_,l,d){this.port=t,d===null&&(d=void 0),this.server_name=r+NM.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+NM.SERVER_SUFFIX.LEAF},this.tls={cert_file:_,key_file:l,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:u,jetstream:"enabled"}},this.system_account="SYS"}};IM.exports=TT});var DM=R((Nfe,CM)=>{"use strict";var gT=class{static{a(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};CM.exports=gT});var MM=R((wfe,LM)=>{"use strict";var T5=nt(),RT=class{static{a(this,"SysUserObject")}constructor(t,r){this.user=t+T5.SERVER_SUFFIX.ADMIN,this.password=r}};LM.exports=RT});var bT=R((Dfe,vM)=>{"use strict";var fa=require("path"),xd=require("fs-extra"),g5=yM(),R5=wM(),A5=DM(),O5=MM(),AT=un(),ha=Q(),Rr=dr(),Hd=U(),Ru=nt(),{CONFIG_PARAMS:dt}=Hd,ma=K(),Au=te(),UM=gs(),OT=Nt(),Ea="clustering",b5=1e4,PM=50;vM.exports={generateNatsConfig:N5,removeNatsConfig:I5,getHubConfigPath:y5};function y5(){let e=Au.get(dt.ROOTPATH);return fa.join(e,Ea,Ru.NATS_CONFIG_FILES.HUB_SERVER)}a(y5,"getHubConfigPath");async function N5(e=!1,t=void 0){Au.initSync();let r=Au.get(dt.ROOTPATH),n=fa.join(r,Ea,Ru.PID_FILES.HUB),s=fa.join(r,Ea,Ru.PID_FILES.LEAF),i=Rr.getConfigFromFile(dt.CLUSTERING_LEAFSERVER_STREAMS_PATH),o=fa.join(r,Ea,Ru.NATS_CONFIG_FILES.HUB_SERVER),c=fa.join(r,Ea,Ru.NATS_CONFIG_FILES.LEAF_SERVER),u=Rr.getConfigFromFile(dt.CLUSTERING_TLS_CERTIFICATE),_=Rr.getConfigFromFile(dt.CLUSTERING_TLS_PRIVATEKEY),l=Rr.getConfigFromFile(dt.CLUSTERING_TLS_CERT_AUTH),d=Rr.getConfigFromFile(dt.CLUSTERING_TLS_INSECURE),f=Rr.getConfigFromFile(dt.CLUSTERING_TLS_VERIFY),E=Rr.getConfigFromFile(dt.CLUSTERING_NODENAME),h=Rr.getConfigFromFile(dt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await OT.checkNATSServerInstalled()||Gd("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let S=await AT.listUsers(),p=Rr.getConfigFromFile(dt.CLUSTERING_USER),T=await AT.getClusterUser();(ha.isEmpty(T)||T.active!==!0)&&Gd(`Invalid cluster user '${p}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await Bd(dt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await Bd(dt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await Bd(dt.CLUSTERING_HUBSERVER_NETWORK_PORT),await Bd(dt.CLUSTERING_LEAFSERVER_NETWORK_PORT));let A=[],g=[];for(let[z,J]of S.entries())J.role.role===Hd.ROLE_TYPES_ENUM.CLUSTER_USER&&J.active&&(A.push(new O5(J.username,UM.decrypt(J.hash))),g.push(new A5(J.username,UM.decrypt(J.hash))));let L=[],{hub_routes:v}=Rr.getClusteringRoutes();if(!ha.isEmptyOrZeroLength(v))for(let z of v)L.push(`tls://${T.sys_name_encoded}:${T.uri_encoded_d_hash}@${z.host}:${z.port}`);let P=new g5(Rr.getConfigFromFile(dt.CLUSTERING_HUBSERVER_NETWORK_PORT),E,n,u,_,l,d,f,h,Rr.getConfigFromFile(dt.CLUSTERING_HUBSERVER_CLUSTER_NAME),Rr.getConfigFromFile(dt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),L,A,g);l==null&&(delete P.tls.ca_file,delete P.leafnodes.tls.ca_file),t=ha.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===Hd.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await xd.writeJson(o,P),ma.trace(`Hub server config written to ${o}`));let k=`tls://${T.sys_name_encoded}:${T.uri_encoded_d_hash}@0.0.0.0:${h}`,H=`tls://${T.uri_encoded_name}:${T.uri_encoded_d_hash}@0.0.0.0:${h}`,X=new R5(Rr.getConfigFromFile(dt.CLUSTERING_LEAFSERVER_NETWORK_PORT),E,s,i,[k],[H],A,g,u,_,l,d);l==null&&delete X.tls.ca_file,(t===void 0||t===Hd.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await xd.writeJson(c,X),ma.trace(`Leaf server config written to ${c}`))}a(N5,"generateNatsConfig");async function Bd(e){let t=Au.get(e);return ha.isEmpty(t)&&Gd(`port undefined for '${e}'`),await ha.isPortTaken(t)&&Gd(`'${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(Bd,"isPortAvailable");function Gd(e){let t=`Error generating clustering config: ${e}`;ma.error(t),console.error(t),process.exit(1)}a(Gd,"generateNatsConfigError");async function I5(e){let{port:t,config_file:r}=OT.getServerConfig(e),{username:n,decrypt_hash:s}=await AT.getClusterUser(),i=0,o=2e3;for(;i<PM;){try{let l=await OT.createConnection(t,n,s,!1);if(l.protocol.connected===!0){l.close();break}}catch(l){ma.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${l}`)}if(i++,i>=PM)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&&ma.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await ha.async_set_timeout(_)}let c="0".repeat(b5),u=fa.join(Au.get(dt.ROOTPATH),Ea,r);await xd.writeFile(u,c),await xd.remove(u),ma.notify(e,"started.")}a(I5,"removeNatsConfig")});var qM=R((Mfe,FM)=>{"use strict";var $r=te(),w5=Wi(),he=U(),Ou=nt(),Ns=require("path"),{PACKAGE_ROOT:qd}=U(),BM=te(),Fd=Q(),pa="/dev/null",C5=Ns.join(qd,"launchServiceScripts"),HM=Ns.join(qd,"utility/scripts"),D5=Ns.join(HM,he.HDB_RESTART_SCRIPT),xM=Ns.resolve(qd,"dependencies",`${process.platform}-${process.arch}`,Ou.NATS_BINARY_NAME);function GM(){let t=w5.licenseSearch().ram_allocation||he.RAM_ALLOCATION_ENUM.DEFAULT,r=he.MEM_SETTING_KEY+t,n={[he.PROCESS_NAME_ENV_PROP]:he.PROCESS_DESCRIPTORS.HDB,IS_SCRIPTED_SERVICE:!0};return Fd.noBootFile()&&(n[he.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Fd.getEnvCliRootPath()),{name:he.PROCESS_DESCRIPTORS.HDB,script:he.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:n,node_args:r,cwd:qd}}a(GM,"generateMainServerConfig");var L5=9930;function M5(){$r.initSync(!0);let e=$r.get(he.CONFIG_PARAMS.ROOTPATH),t=Ns.join(e,"clustering",Ou.NATS_CONFIG_FILES.HUB_SERVER),r=Ns.join($r.get(he.HDB_SETTINGS_NAMES.LOG_PATH_KEY),he.LOG_NAMES.HDB),n=BM.get(he.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=Ou.LOG_LEVEL_FLAGS[$r.get(he.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:he.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==L5?"-"+n:""),script:xM,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[he.PROCESS_NAME_ENV_PROP]:he.PROCESS_DESCRIPTORS.CLUSTERING_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return $r.get(he.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=pa,i.error_file=pa),i}a(M5,"generateNatsHubServerConfig");var U5=9940;function P5(){$r.initSync(!0);let e=$r.get(he.CONFIG_PARAMS.ROOTPATH),t=Ns.join(e,"clustering",Ou.NATS_CONFIG_FILES.LEAF_SERVER),r=Ns.join($r.get(he.HDB_SETTINGS_NAMES.LOG_PATH_KEY),he.LOG_NAMES.HDB),n=BM.get(he.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=Ou.LOG_LEVEL_FLAGS[$r.get(he.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:he.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==U5?"-"+n:""),script:xM,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[he.PROCESS_NAME_ENV_PROP]:he.PROCESS_DESCRIPTORS.CLUSTERING_LEAF},merge_logs:!0,out_file:r,error_file:r,instances:1};return $r.get(he.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=pa,i.error_file=pa),i}a(P5,"generateNatsLeafServerConfig");function v5(){$r.initSync();let e=Ns.join($r.get(he.CONFIG_PARAMS.LOGGING_ROOT),he.LOG_NAMES.HDB),t={name:he.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,script:he.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[he.PROCESS_NAME_ENV_PROP]:he.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:C5,autorestart:!1};return $r.get(he.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=pa,t.error_file=pa),t}a(v5,"generateClusteringUpgradeV4ServiceConfig");function B5(){let e={[he.PROCESS_NAME_ENV_PROP]:he.PROCESS_DESCRIPTORS.RESTART_HDB};return Fd.noBootFile()&&(e[he.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Fd.getEnvCliRootPath()),{...{name:he.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:HM},script:D5}}a(B5,"generateRestart");function H5(){return{apps:[GM()]}}a(H5,"generateAllServiceConfigs");FM.exports={generateAllServiceConfigs:H5,generateMainServerConfig:GM,generateRestart:B5,generateNatsHubServerConfig:M5,generateNatsLeafServerConfig:P5,generateClusteringUpgradeV4ServiceConfig:v5}});var tU=R((vfe,eU)=>{"use strict";var Pe=U(),x5=Q(),ws=bT(),kd=Nt(),Is=nt(),hi=qM(),Vd=te(),mi=K(),G5=ys(),{startWorker:kM,onMessageFromWorkers:F5}=ct(),q5=da(),Pfe=require("util"),k5=require("child_process"),V5=require("fs"),{execFile:$5}=k5,Ne;eU.exports={enterPM2Mode:Y5,start:pi,stop:yT,reload:$M,restart:YM,list:NT,describe:WM,connect:Cs,kill:J5,startAllServices:X5,startService:IT,getUniqueServicesList:QM,restartAllServices:j5,isServiceRegistered:zM,reloadStopStart:JM,restartHdb:KM,deleteProcess:Q5,startClusteringProcesses:jM,startClusteringThreads:ZM,isHdbRestartRunning:z5,isClusteringRunning:e8,stopClustering:Z5,reloadClustering:t8};var bu=!1;F5(e=>{e.type==="restart"&&Vd.initSync(!0)});function Y5(){bu=!0}a(Y5,"enterPM2Mode");function Cs(){return Ne||(Ne=require("pm2")),new Promise((e,t)=>{Ne.connect((r,n)=>{mi.setupConsoleLogging(),r&&t(r),e(n)})})}a(Cs,"connect");var Ar,K5=10,VM;function pi(e,t=!1){if(bu)return W5(e);let r=$5(e.script,e.args.split(" "),e);r.name=e.name,r.on("exit",async i=>{let o=Ar.indexOf(r);o>-1&&Ar.splice(o,1),!VM&&i!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<K5&&(V5.existsSync(ws.getHubConfigPath())?pi(e):(await ws.generateNatsConfig(!0),pi(e),await new Promise(c=>setTimeout(c,3e3)),await ws.removeNatsConfig(Pe.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await ws.removeNatsConfig(Pe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let n={serviceName:e.name.replace(/ /g,"-")};function s(i){let o=Vd.get(Pe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL),c=/\[\d+][^\[]+\[(\w+)]/g,u,_=0,l;for(;u=c.exec(i);){if(u.index&&Is.LOG_LEVEL_HIERARCHY[o]>=Is.LOG_LEVEL_HIERARCHY[l||"info"]){let E=l===Is.LOG_LEVELS.ERR||l===Is.LOG_LEVELS.WRN?mi.OUTPUTS.STDERR:mi.OUTPUTS.STDOUT;mi.logCustomLevel(l||"info",E,n,i.slice(_,u.index).trim())}let[d,f]=u;_=u.index+d.length,l=Is.LOG_LEVELS[f]}if(Is.LOG_LEVEL_HIERARCHY[o]>=Is.LOG_LEVEL_HIERARCHY[l||"info"]){let d=l===Is.LOG_LEVELS.ERR||l===Is.LOG_LEVELS.WRN?mi.OUTPUTS.STDERR:mi.OUTPUTS.STDOUT;mi.logCustomLevel(l||"info",d,n,i.slice(_).trim())}}if(a(s,"extractMessages"),r.stdout.on("data",s),r.stderr.on("data",s),r.unref(),Ar=[],!Ar&&!t){let i=a(()=>{VM=!0,Ar&&(Ar.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)}Ar.push(r)}a(pi,"start");function W5(e){return new Promise(async(t,r)=>{try{await Cs()}catch(n){r(n)}Ne.start(e,(n,s)=>{n&&(Ne.disconnect(),r(n)),Ne.disconnect(),t(s)})})}a(W5,"startWithPM2");function yT(e){if(!bu){for(let t of Ar||[])t.name===e&&(Ar.splice(Ar.indexOf(t),1),t.kill());return}return new Promise(async(t,r)=>{try{await Cs()}catch(n){r(n)}Ne.stop(e,async(n,s)=>{n&&(Ne.disconnect(),r(n)),Ne.delete(e,(i,o)=>{i&&(Ne.disconnect(),r(n)),Ne.disconnect(),t(o)})})})}a(yT,"stop");function $M(e){return new Promise(async(t,r)=>{try{await Cs()}catch(n){r(n)}Ne.reload(e,(n,s)=>{n&&(Ne.disconnect(),r(n)),Ne.disconnect(),t(s)})})}a($M,"reload");function YM(e){if(!bu)for(let t of Ar||[])t.name===e&&t.kill();return new Promise(async(t,r)=>{try{await Cs()}catch(n){r(n)}Ne.restart(e,(n,s)=>{Ne.disconnect(),t(s)})})}a(YM,"restart");function Q5(e){return new Promise(async(t,r)=>{try{await Cs()}catch(n){r(n)}Ne.delete(e,(n,s)=>{n&&(Ne.disconnect(),r(n)),Ne.disconnect(),t(s)})})}a(Q5,"deleteProcess");async function KM(){await pi(hi.generateRestart())}a(KM,"restartHdb");async function z5(){let e=await NT();for(let t in e)if(e[t].name===Pe.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}a(z5,"isHdbRestartRunning");function NT(){return new Promise(async(e,t)=>{try{await Cs()}catch(r){t(r)}Ne.list((r,n)=>{r&&(Ne.disconnect(),t(r)),Ne.disconnect(),e(n)})})}a(NT,"list");function WM(e){return new Promise(async(t,r)=>{try{await Cs()}catch(n){r(n)}Ne.describe(e,(n,s)=>{n&&(Ne.disconnect(),r(n)),Ne.disconnect(),t(s)})})}a(WM,"describe");function J5(){if(!bu){for(let e of Ar||[])e.kill();Ar=[];return}return new Promise(async(e,t)=>{try{await Cs()}catch(r){t(r)}Ne.killDaemon((r,n)=>{r&&(Ne.disconnect(),t(r)),Ne.disconnect(),e(n)})})}a(J5,"kill");async function X5(){try{await jM(),await ZM(),await pi(hi.generateAllServiceConfigs())}catch(e){throw Ne?.disconnect(),e}}a(X5,"startAllServices");async function IT(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case Pe.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=hi.generateMainServerConfig();break;case Pe.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=hi.generateNatsIngestServiceConfig();break;case Pe.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=hi.generateNatsReplyServiceConfig();break;case Pe.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=hi.generateNatsHubServerConfig(),await pi(r,t),await ws.removeNatsConfig(e);return;case Pe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=hi.generateNatsLeafServerConfig(),await pi(r,t),await ws.removeNatsConfig(e);return;case Pe.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=hi.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await pi(r)}catch(r){throw Ne?.disconnect(),r}}a(IT,"startService");async function QM(){try{let e=await NT(),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 Ne?.disconnect(),e}}a(QM,"getUniqueServicesList");async function j5(e=[]){try{let t=!1,r=await QM();for(let n=0,s=Object.values(r).length;n<s;n++){let o=Object.values(r)[n].name;e.includes(o)||(o===Pe.PROCESS_DESCRIPTORS.HDB?t=!0:await YM(o))}t&&await JM(Pe.PROCESS_DESCRIPTORS.HDB)}catch(t){throw Ne?.disconnect(),t}}a(j5,"restartAllServices");async function zM(e){if(Ar?.find(r=>r.name===e))return!0;let t=await q5.getHDBProcessInfo();return t.core.length&&t.core[0]?.parent==="PM2"}a(zM,"isServiceRegistered");async function JM(e){let t=Vd.get(Pe.CONFIG_PARAMS.THREADS_COUNT)??Vd.get(Pe.CONFIG_PARAMS.THREADS),r=await WM(e),n=x5.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await yT(e),await IT(e)):e===Pe.PROCESS_DESCRIPTORS.HDB?await KM():await $M(e)}a(JM,"reloadStopStart");var XM;async function jM(e=!1){for(let t in Pe.CLUSTERING_PROCESSES){let r=Pe.CLUSTERING_PROCESSES[t];await IT(r,e)}}a(jM,"startClusteringProcesses");async function ZM(){XM=kM(Pe.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,{name:Pe.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE});try{await kd.deleteLocalStream("__HARPERDB_WORK_QUEUE__")}catch{}await kd.updateLocalStreams();let e=await G5.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===Pe.PRE_4_0_0_VERSION){mi.info("Starting clustering upgrade 4.0.0 process"),kM(Pe.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}a(ZM,"startClusteringThreads");async function Z5(){for(let e in Pe.CLUSTERING_PROCESSES)if(e!==Pe.CLUSTERING_PROCESSES.CLUSTERING_INGEST_PROC_DESCRIPTOR)if(e===Pe.CLUSTERING_PROCESSES.CLUSTERING_REPLY_SERVICE_DESCRIPTOR)await XM.terminate();else{let t=Pe.CLUSTERING_PROCESSES[e];await yT(t)}}a(Z5,"stopClustering");async function e8(){for(let e in Pe.CLUSTERING_PROCESSES){let t=Pe.CLUSTERING_PROCESSES[e];if(await zM(t)===!1)return!1}return!0}a(e8,"isClusteringRunning");async function t8(){await ws.generateNatsConfig(!0),await kd.reloadNATSHub(),await kd.reloadNATSLeaf(),await ws.removeNatsConfig(Pe.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await ws.removeNatsConfig(Pe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}a(t8,"reloadClustering")});var cU={};Fe(cU,{compactOnStart:()=>r8,copyDb:()=>aU});async function r8(){Nu.notify("Running compact on start"),console.log("Running compact on start");let e=(0,wT.get)(Si.CONFIG_PARAMS.ROOTPATH),t=new Map,r=Er();try{for(let n in r){if(n==="system")continue;let s;for(let u in r[n]){s=r[n][u].primaryStore.path;break}if(!s){console.log("Couldn't find any tables in database",n);continue}let i=(0,$d.join)(e,"backup",n+".mdb"),o=(0,$d.join)(e,Si.DATABASES_DIR_NAME,n+"-copy.mdb"),c=await rU(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 aU(n,o),console.log("Backing up",n,"to",i),await(0,ao.move)(s,i,{overwrite:!0})}yu();for(let[n,{db_path:s,copy_dest:i}]of t)console.log("Moving copy compacted",n,"to",s),await(0,ao.move)(i,s,{overwrite:!0}),await(0,ao.remove)((0,$d.join)(e,Si.DATABASES_DIR_NAME,`${n}-copy.mdb-lock`));yu()}catch(n){Nu.error("Error compacting database, rolling back operation",n),console.error("Error compacting database, rolling back operation",n),(0,CT.updateConfigValue)(Si.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,ao.move)(o,i,{overwrite:!0})}catch(c){console.error(c)}}throw yu(),n}for(let[n,{backup_dest:s,record_count:i}]of t){let o=!0,c=await rU(n);if(console.log("Database",n,"after compact has a total record count of",c),i!==c){o=!1;let u=`There is a discrepancy between pre and post compact record count for database ${n}.
7
+ This can occur during early stages of install where the config file has not yet been created`);return}else throw bt.error(i),new Error(`Error reading HarperDB config file at ${r}`)}HY(n,r),Km(n);let s=n.toJSON();if(CY.config=s,yt=$o(s),yt.logging_rotation_rotate)for(let i in hN)yt[i]&&bt.error(`Config ${hN[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);bt.trace(LY)}}a(Ym,"initConfig");function HY(e,t){let r=e.getIn(["rootPath"]),n=!1;e.hasIn(["storage","path"])||(e.setIn(["storage","path"],wn.join(r,"database")),n=!0),e.hasIn(["clustering","leafServer","streams","path"])||(e.setIn(["clustering","leafServer","streams","path"],wn.join(r,"clustering","leaf")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],wn.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&&(bt.trace("Updating config file with missing config params"),_r.writeFileSync(t,String(e)))}a(HY,"checkForUpdatedConfig");function Km(e,t=!1){let r=e.toJSON();r.componentsRoot=r.componentsRoot??r?.customFunctions?.root,r?.http?.threads&&(r.threads=r?.http?.threads);let n=OY(r,t);if(n.error)throw P_.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(Km,"validateConfig");function xY(e,t){yt===void 0&&(yt={});let r=Cn[e.toLowerCase()];if(r===void 0){bt.trace(`Unable to update config object because config param '${e}' does not exist`);return}yt[r.toLowerCase()]=t}a(xY,"updateConfigObject");function gN(e,t,r=void 0,n=!1,s=!1,i=!1){yt===void 0&&Ym();let o=TN(Cn.hdb_root),c=wn.join(o,xr.HDB_CONFIG_FILE),u=ii(c),_;if(r===void 0&&e.toLowerCase()===Hr.DATABASES)_=t;else if(r===void 0){let f;if(i)f=e;else if(f=Cn[e.toLowerCase()],f===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let E=f.split("_"),h=$m(f,t);u.setIn([...E],h)}else for(let f in r){let E=Cn[f.toLowerCase()];if(E===Hr.HTTP_SECUREPORT&&r[f]===yt[Hr.HTTP_PORT]?.toString()&&u.setIn(["http","port"],null),E===Hr.OPERATIONSAPI_NETWORK_SECUREPORT&&r[f]===yt[Hr.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&u.setIn(["operationsApi","network","port"],null),E===Hr.DATABASES){_=r[f];continue}if(E?.startsWith("threads_")){let h=u.getIn(["threads"]);h>=0&&(u.deleteIn(["threads"]),u.setIn(["threads","count"],h))}if(!E&&(f.endsWith("_package")||f.endsWith("_port"))&&(E=f),E!==void 0){let h=E.split("_"),S=xr.LEGACY_CONFIG_PARAMS[f.toUpperCase()];S&&S.startsWith("customFunctions")&&u.hasIn(S.split("_"))&&(E=S,h=S.split("_"));let p=$m(E,r[f]);E==="rootPath"&&p?.endsWith("/")&&(p=p.slice(0,-1));try{h.length>1&&typeof u.getIn(h.slice(0,-1))=="boolean"&&u.deleteIn(h.slice(0,-1)),u.setIn([...h],p)}catch(T){bt.error(T)}}}_&&SN(u,_),Km(u);let l=u.getIn(["rootPath"]),d=wn.join(l,xr.HDB_CONFIG_FILE);n===!0&&GY(c,l),_r.writeFileSync(d,String(u)),s&&(yt=$o(u.toJSON())),bt.trace(`Config parameter: ${e} updated with value: ${t}`)}a(gN,"updateConfigValue");function GY(e,t){try{let r=wn.join(t,"backup",`${xr.HDB_CONFIG_FILE}.bak`);_r.copySync(e,r),bt.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){bt.error(MY),bt.error(r)}}a(GY,"backupConfigFile");var FY=["databases"];function $o(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)),B_=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])&&!FY.includes(i)){let o=r(n[i]);for(let c in o){if(!o.hasOwnProperty(c))continue;c!=="package"&&(i=i.toLowerCase());let u=i+"_"+c;!Hr[u.toUpperCase()]&&Cn[u]&&(s[Cn[u].toLowerCase()]=o[c]),s[u]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a($o,"flattenConfig");function $m(e,t){if(e===Hr.CLUSTERING_NODENAME||e===Hr.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(yY(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||Pt.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 Pt.autoCast(t)}a($m,"castConfigValue");function qY(){let e=Pt.getPropsFilePath(),t=Ki(e);return ii(t).toJSON()}a(qY,"getConfiguration");async function kY(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return gN(void 0,void 0,s,!0),PY}catch(i){throw typeof i=="string"||i instanceof String?IY(i,i,wY.BAD_REQUEST,void 0,void 0,!0):i}}a(kY,"setConfiguration");function Wm(){let e=Pt.getPropsFilePath();try{_r.accessSync(e,_r.constants.F_OK|_r.constants.R_OK)}catch(n){if(!Pt.noBootFile())throw bt.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=Ki(e);return ii(t).toJSON()}a(Wm,"readConfigFile");function ii(e){return bY.parseDocument(_r.readFileSync(e,"utf8"),{simpleKeys:!0})}a(ii,"parseYamlDoc");function VY(){let e=Wm(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=Pt.isEmptyOrZeroLength(t)?[]:t;let r=EN(t);if(r)throw P_.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=Pt.isEmptyOrZeroLength(n)?[]:n;let s=EN(n);if(s)throw P_.CONFIG_VALIDATION(s.message);if(!Pt.isEmptyOrZeroLength(n)&&!Pt.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!Pt.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw P_.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(VY,"getClusteringRoutes");function RN(e){let t=mN(e);yt={};for(let r in Cn){let n=t.get(r.toUpperCase());if(Pt.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=Cn[r].toLowerCase();s===Hr.LOGGING_ROOT?yt[s]=wn.dirname(n):yt[s]=n}return yt}a(RN,"initOldConfig");function $Y(e){let t=Wm();return NY.get(t,e.replaceAll("_","."))}a($Y,"getConfigFromFile");async function YY(e,t){let r=ii(Ki());r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),await _r.writeFile(Ki(),String(r))}a(YY,"addConfig");function KY(e){let t=Ki(Pt.getPropsFilePath()),r=ii(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=wn.join(n,xr.HDB_CONFIG_FILE);_r.writeFileSync(s,String(r))}a(KY,"deleteConfigFromFile");function WY(){return B_||(Ym(),B_)}a(WY,"getConfigObj")});var bN=R((Cce,ON)=>{"use strict";var H_=U(),x_=class{static{a(this,"BaseLicense")}constructor(t=0,r=H_.RAM_ALLOCATION_ENUM.DEFAULT,n=H_.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},Qm=class extends x_{static{a(this,"ExtendedLicense")}constructor(t=0,r=H_.RAM_ALLOCATION_ENUM.DEFAULT,n=H_.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};ON.exports={BaseLicense:x_,ExtendedLicense:Qm}});var Wi=R((Lce,DN)=>{"use strict";var Ko=require("fs-extra"),NN=L_(),IN=require("crypto"),QY=require("moment"),zY=require("uuid").v4,Xt=K(),Jm=require("path"),JY=Q(),oi=U(),{totalmem:yN}=require("os"),XY=bN().ExtendedLicense,Yo="invalid license key format",jY="061183",ZY="mofi25",eK="aes-256-cbc",tK=16,rK=32,wN=te();wN.initSync();var zm;DN.exports={validateLicense:CN,generateFingerPrint:sK,licenseSearch:Zm,getLicense:aK,checkMemoryLimit:cK};function Xm(){return Jm.join(wN.getHdbBasePath(),oi.LICENSE_KEY_DIR_NAME,oi.LICENSE_FILE_NAME)}a(Xm,"getLicenseDirPath");function nK(){let e=Xm();return Jm.join(e,oi.LICENSE_FILE_NAME)}a(nK,"getLicenseFilePath");function jm(){let e=Xm();return Jm.join(e,oi.REG_KEY_FILE_NAME)}a(jm,"getFingerPrintFilePath");async function sK(){let e=jm();try{return await Ko.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await iK();throw Xt.error(`Error writing fingerprint file to ${e}`),Xt.error(t),new Error("There was an error generating the fingerprint")}}a(sK,"generateFingerPrint");async function iK(){let e=zY(),t=NN.hash(e),r=jm();try{await Ko.mkdirp(Xm()),await Ko.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw Xt.error(`Error writing fingerprint file to ${r}`),Xt.error(n),new Error("There was an error generating the fingerprint")}return t}a(iK,"writeFingerprint");function CN(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:oi.RAM_ALLOCATION_ENUM.DEFAULT,version:oi.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return Xt.error("empty license key passed to validate."),r;let n=jm(),s=!1;try{s=Ko.statSync(n)}catch(i){Xt.error(i)}if(s){let i;try{i=Ko.readFileSync(n,"utf8")}catch{Xt.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(ZY),c=o[1];c=Buffer.concat([Buffer.from(c)],tK);let u=Buffer.concat([Buffer.from(i)],rK),_=IN.createDecipheriv(eK,u,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let l=null;try{l=_.update(o[0],"hex","utf8"),l.trim(),l+=_.final("utf8")}catch{let E=oK(o[0],i);if(E)l=E;else throw r.valid_license=!1,r.valid_machine=!1,console.error(Yo),Xt.error(Yo),new Error(Yo)}let d;if(isNaN(l))try{d=JSON.parse(l),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(Yo),Xt.error(Yo),new Error(Yo)}else r.exp_date=l;r.exp_date<QY().valueOf()&&(r.valid_date=!1),NN.validate(o[1],`${jY}${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||Xt.error("Invalid licence"),r}a(CN,"validateLicense");function oK(e,t){try{let r=IN.createDecipher("aes192",t),n=r.update(e,"hex","utf8");return n.trim(),n+=r.final("utf8"),n}catch{Xt.warn("Check old license failed")}}a(oK,"checkOldLicense");function Zm(){let e=new XY,t=[];try{t=Ko.readFileSync(nK(),"utf-8").split(oi.NEW_LINE)}catch(r){r.code==="ENOENT"?Xt.info("no license file found"):Xt.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if(JY.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=CN(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){Xt.error("There was an error parsing the license string."),Xt.error(s),e.ram_allocation=oi.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return zm=e,e}a(Zm,"licenseSearch");async function aK(){return zm||await Zm(),zm}a(aK,"getLicense");function cK(){let e=Zm().ram_allocation,t=process.constrainedMemory?.()||yN();if(t=Math.round(Math.min(t,yN())/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(cK,"checkMemoryLimit")});var un=R((Bce,KN)=>{"use strict";var PN="username is required",vN="nothing to update, must supply active, role or password to update",BN="password cannot be an empty string",HN="If role is specified, it cannot be empty.",xN="active must be true or false";KN.exports={addUser:pK,alterUser:SK,dropUser:gK,getSuperUser:bK,userInfo:RK,listUsers:F_,listUsersExternal:AK,setUsersToGlobal:Qo,findAndValidateUser:$N,getClusterUser:yK,USERNAME_REQUIRED:PN,ALTERUSER_NOTHING_TO_UPDATE:vN,EMPTY_PASSWORD:BN,EMPTY_ROLE:HN,ACTIVE_BOOLEAN:xN};var GN=cn(),uK=Vi(),rp=L_(),FN=nN(),qN=Br(),np=Rs(),Gr=Q(),kN=require("validate.js"),Oe=K(),{promisify:lK}=require("util"),sp=gs(),LN=U(),MN=nt(),_K=dr(),Uce=te(),Pce=Wi(),dK=Hi(),{table:vce}=(Ae(),ie(qe)),{handleHDBError:Xn,hdb_errors:fK}=ne(),{HTTP_STATUS_CODES:jn,AUTHENTICATION_ERROR_MSGS:ep,HDB_ERROR_MSGS:Wo}=fK,{UserEventMsg:ip}=Dn(),tp=require("lodash"),{server:op}=(ar(),ie(Ui)),EK=K();op.getUser=(e,t)=>$N(e,t,t!=null);var VN={username:!0,active:!0,role:!0,password:!0},UN=new Map,G_=qN.searchByValue,hK=qN.searchByHash,mK=lK(uK.delete);async function pK(e){let t=kN.cleanAttributes(e,VN),r=FN.addUserValidation(t);if(r)throw Xn(new Error,r.message,jn.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 G_(n),s=s&&Array.from(s)}catch(u){throw Oe.error("There was an error searching for a role in add user"),Oe.error(u),u}if(!s||s.length<1)throw Xn(new Error,Wo.ROLE_NAME_NOT_FOUND(t.role),jn.NOT_FOUND,void 0,void 0,!0);if(s.length>1)throw Xn(new Error,Wo.DUP_ROLES_FOUND(t.role),jn.CONFLICT,void 0,void 0,!0);s[0].permission.cluster_user===!0&&(t.hash=sp.encrypt(t.password)),t.password=rp.hash(t.password),t.role=s[0].id;let i={operation:"insert",schema:"system",table:"hdb_user",records:[t]},o;try{o=await GN.insert(i)}catch(u){throw Oe.error("There was an error searching for a user."),Oe.error(u),u}Oe.debug(o);try{await Qo()}catch(u){throw Oe.error("Got an error setting users to global"),Oe.error(u),u}if(o.skipped_hashes.length===1)throw Xn(new Error,Wo.USER_ALREADY_EXISTS(t.username),jn.CONFLICT,void 0,void 0,!0);let c=Object.assign({},t);return c.role=s[0],np.signalUserChange(new ip(process.pid)),`${c.username} successfully added`}a(pK,"addUser");async function SK(e){let t=kN.cleanAttributes(e,VN);if(Gr.isEmptyOrZeroLength(t.username))throw new Error(PN);if(Gr.isEmptyOrZeroLength(t.password)&&Gr.isEmptyOrZeroLength(t.role)&&Gr.isEmptyOrZeroLength(t.active))throw new Error(vN);if(!Gr.isEmpty(t.password)&&Gr.isEmptyOrZeroLength(t.password.trim()))throw new Error(BN);if(!Gr.isEmpty(t.active)&&!Gr.isBoolean(t.active))throw new Error(xN);let r=TK(t.username);if(!Gr.isEmpty(t.password)&&!Gr.isEmptyOrZeroLength(t.password.trim())&&(r&&(t.hash=sp.encrypt(t.password)),t.password=rp.hash(t.password)),t.role==="")throw new Error(HN);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 G_(i)||[])}catch(c){throw Oe.error("Got an error searching for a role."),Oe.error(c),c}if(!o||o.length===0){let c=Wo.ALTER_USER_ROLE_NOT_FOUND(t.role);throw Oe.error(c),Xn(new Error,c,jn.NOT_FOUND,void 0,void 0,!0)}if(o.length>1){let c=Wo.ALTER_USER_DUP_ROLES(t.role);throw Oe.error(c),Xn(new Error,c,jn.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 GN.update(n)}catch(i){throw Oe.error("Error during update."),Oe.error(i),i}try{await Qo()}catch(i){throw Oe.error("Got an error setting users to global"),Oe.error(i),i}return np.signalUserChange(new ip(process.pid)),s}a(SK,"alterUser");function TK(e){let t=!1,r=global.hdb_users.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(TK,"isClusterUser");async function gK(e){try{let t=FN.dropUserValidation(e);if(t)throw new Error(t);let r={table:"hdb_user",schema:"system",hash_values:[e.username]};if(Gr.isEmpty(global.hdb_users.get(e.username)))throw Xn(new Error,Wo.USER_NOT_EXIST(e.username),jn.NOT_FOUND,void 0,void 0,!0);let n;try{n=await mK(r)}catch(s){throw Oe.error("Got an error deleting a user."),Oe.error(s),s}Oe.debug(n);try{await Qo()}catch(s){throw Oe.error("Got an error setting users to global."),Oe.error(s),s}return np.signalUserChange(new ip(process.pid)),`${e.username} successfully deleted`}catch(t){throw t}}a(gK,"dropUser");async function RK(e){let t={};try{if(!e||!e.hdb_user)return"There was no user info in the body";t=tp.cloneDeep(e.hdb_user);let r={schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]},n;try{n=await hK(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(RK,"userInfo");async function AK(){let e;try{e=await F_()}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(AK,"listUsersExternal");async function F_(){try{let e={schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]},t;try{t=await G_(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]=tp.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 G_(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=tp.cloneDeep(o),o.role=r[o.role],OK(o.role),i.set(o.username,o);return i}catch(e){throw Oe.error("got an error listing users"),Oe.error(e),Gr.errorizeMessage(e)}return null}a(F_,"listUsers");function OK(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(dK)){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(OK,"appendSystemTablesToRole");async function Qo(){try{let e=await F_();global.hdb_users=e}catch(e){throw Oe.error(e),e}}a(Qo,"setUsersToGlobal");async function $N(e,t,r=!0){global.hdb_users||await Qo();let n=global.hdb_users.get(e);if(!n){if(!r)return{username:e};throw Xn(new Error,ep.GENERIC_AUTH_FAIL,jn.UNAUTHORIZED,void 0,void 0,!0)}if(n&&!n.active)throw Xn(new Error,ep.USER_INACTIVE,jn.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(UN.get(t)===n.password)return s;if(rp.validate(n.password,t))UN.set(t,n.password);else throw Xn(new Error,ep.GENERIC_AUTH_FAIL,jn.UNAUTHORIZED,void 0,void 0,!0)}return s}a($N,"findAndValidateUser");async function bK(){global.hdb_users||await Qo();for(let[,e]of global.hdb_users)if(e.role.role==="super_user")return e}a(bK,"getSuperUser");async function yK(){let e=await F_(),t=_K.getConfigFromFile(LN.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!Gr.isEmpty(r)&&r?.role?.role===LN.ROLE_TYPES_ENUM.CLUSTER_USER)return r.decrypt_hash=sp.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+MN.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+MN.SERVER_SUFFIX.ADMIN,r}a(yK,"getClusterUser");var YN=[];op.invalidateUser=function(e){for(let t of YN)try{t(e)}catch(r){EK.error("Error invalidating user",r)}};op.onInvalidatedUser=function(e){YN.push(e)}});var Gc=R((Fce,JN)=>{"use strict";var Qi=K(),Fr=U(),NK=by(),xce=ri(),Gce=ti(),IK=un(),{validateEvent:WN}=Dn(),xc=In(),wK=require("process"),{resetDatabases:CK}=(Ae(),ie(qe)),DK={[Fr.ITC_EVENT_TYPES.SCHEMA]:LK,[Fr.ITC_EVENT_TYPES.USER]:zN};async function LK(e){let t=WN(e);if(t){Qi.error(t);return}Qi.trace("ITC schemaHandler received schema event:",e),await NK(e.message),await MK(e.message)}a(LK,"schemaHandler");async function MK(e){try{xc.resetReadTxn(Fr.SYSTEM_SCHEMA_NAME,Fr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),xc.resetReadTxn(Fr.SYSTEM_SCHEMA_NAME,Fr.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),xc.resetReadTxn(Fr.SYSTEM_SCHEMA_NAME,Fr.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=CK();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){Qi.error(t)}}a(MK,"syncSchemaMetadata");var QN=[];async function zN(e){try{try{xc.resetReadTxn(Fr.SYSTEM_SCHEMA_NAME,Fr.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),xc.resetReadTxn(Fr.SYSTEM_SCHEMA_NAME,Fr.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){Qi.warn(r)}let t=WN(e);if(t){Qi.error(t);return}Qi.trace(`ITC userHandler ${Fr.HDB_ITC_CLIENT_PREFIX}${wK.pid} received user event:`,e),await IK.setUsersToGlobal();for(let r of QN)r()}catch(t){Qi.error(t)}}a(zN,"userHandler");zN.addListener=function(e){QN.push(e)};JN.exports=DK});var Dn=R((Kce,jN)=>{"use strict";var kce=K(),ap=Q(),UK=U(),{ITC_ERRORS:Fc}=Lr(),{parentPort:Vce,threadId:PK,isMainThread:vK,workerData:$ce}=require("worker_threads"),{onMessageFromWorkers:BK,broadcast:Yce,broadcastWithAcknowledgement:HK}=ct();jN.exports={sendItcEvent:xK,validateEvent:XN,SchemaEventMsg:GK,UserEventMsg:FK};var q_;BK(async(e,t)=>{q_=q_||Gc(),XN(e),q_[e.type]&&await q_[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function xK(e){return!vK&&e.message&&(e.message.originator=PK),HK(e)}a(xK,"sendItcEvent");function XN(e){if(typeof e!="object")return Fc.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||ap.isEmpty(e.type))return Fc.MISSING_TYPE;if(!e.hasOwnProperty("message")||ap.isEmpty(e.message))return Fc.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||ap.isEmpty(e.message.originator))return Fc.MISSING_ORIGIN;if(UK.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return Fc.INVALID_EVENT(e.type)}a(XN,"validateEvent");function GK(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(GK,"SchemaEventMsg");function FK(e){this.originator=e}a(FK,"UserEventMsg")});var Rs=R((zce,rI)=>{"use strict";var ZN=U(),Qce=Q(),k_=K(),eI=Ry(),zo,{sendItcEvent:tI}=Dn();function qK(e){try{k_.trace("signalSchemaChange called with message:",e),zo=zo||Gc();let t=new eI(ZN.ITC_EVENT_TYPES.SCHEMA,e);return zo.schema(t),tI(t)}catch(t){k_.error(t)}}a(qK,"signalSchemaChange");function kK(e){try{k_.trace("signalUserChange called with message:",e),zo=zo||Gc();let t=new eI(ZN.ITC_EVENT_TYPES.USER,e);return zo.user(t),tI(t)}catch(t){k_.error(t)}}a(kK,"signalUserChange");rI.exports={signalSchemaChange:qK,signalUserChange:kK}});var V_=R((Xce,sI)=>{"use strict";var nI=Q(),VK=U(),$K=K(),YK=p_(),KK=m_(),WK=Rs(),{SchemaEventMsg:QK}=Dn(),zK="already exists in";sI.exports=JK;async function JK(e,t,r){if(nI.isEmptyOrZeroLength(r))return r;let n=[];nI.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 XK(e,t.schema,t.name,i)})),s}a(JK,"lmdbCheckForNewAttributes");async function XK(e,t,r,n){let s=new KK(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await jK(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(zK))$K.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(XK,"createNewAttribute");async function jK(e){let t;return t=await YK(e),WK.signalSchemaChange(new QK(process.pid,VK.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(jK,"createAttribute")});var Jo=R((Zce,iI)=>{"use strict";var cp=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}};iI.exports=cp});var aI=R((tue,oI)=>{"use strict";var ZK=Jo(),eW=U().OPERATIONS_ENUM,up=class extends ZK{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(eW.INSERT,r,n,s,i),this.records=t}};oI.exports=up});var uI=R((nue,cI)=>{"use strict";var tW=Jo(),rW=U().OPERATIONS_ENUM,lp=class extends tW{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(rW.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};cI.exports=lp});var _I=R((iue,lI)=>{"use strict";var nW=Jo(),sW=U().OPERATIONS_ENUM,_p=class extends nW{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}};lI.exports=_p});var fI=R((aue,dI)=>{"use strict";var iW=Jo(),oW=U().OPERATIONS_ENUM,dp=class extends iW{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(oW.DELETE,n,s,t,i),this.original_records=r}};dI.exports=dp});var qc=R((lue,pI)=>{"use strict";var uue=require("path"),EI=Ye(),aW=aI(),cW=uI(),uW=_I(),lW=fI(),Xo=at(),hI=Q(),{CONFIG_PARAMS:_W}=U(),mI=te();mI.initSync();var $_=U().OPERATIONS_ENUM,{getTransactionAuditStorePath:dW}=Qe();pI.exports=fW;async function fW(e,t){if(mI.get(_W.LOGGING_AUDITLOG)===!1)return;let r=dW(e.schema,e.table),n=await EI.openEnvironment(r,e.table,!0),s=EW(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){EI.initializeDBIs(n,Xo.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Xo.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[Xo.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[Xo.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),hI.isEmpty(s.user_name)||n.dbis[Xo.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[Xo.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(fW,"writeTransaction");function EW(e,t){let r=hI.isEmpty(e.hdb_user)?void 0:e.hdb_user.username;if(e.operation===$_.INSERT)return new aW(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===$_.UPDATE)return new cW(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===$_.UPSERT)return new uW(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===$_.DELETE)return new lW(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(EW,"createTransactionObject")});var fp=R((fue,SI)=>{"use strict";var hW=Mc(),due=Uc(),kc=U(),mW=Pc(),pW=qo().insertRecords,SW=Ye(),TW=K(),gW=V_(),{getSchemaPath:RW}=Qe(),AW=qc();SI.exports=OW;async function OW(e){try{let{schema_table:t,attributes:r}=hW(e);mW(e,r,t.hash_attribute),e.schema!==kc.SYSTEM_SCHEMA_NAME&&(r.includes(kc.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(kc.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(kc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(kc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await gW(e.hdb_auth_header,t,r),s=RW(e.schema,e.table),i=await SW.openEnvironment(s,e.table),o=await pW(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await AW(e,o)}catch(c){TW.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(OW,"lmdbCreateRecords")});var RI=R((hue,gI)=>{"use strict";var TI=U(),bW=fp(),yW=Uc(),NW=require("fs-extra"),{getSchemaPath:IW}=Qe();gI.exports=wW;async function wW(e){let t=[{name:e.schema,createddate:Date.now()}],r=new yW(TI.SYSTEM_SCHEMA_NAME,TI.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await bW(r),await NW.mkdirp(IW(e.schema))}a(wW,"lmdbCreateSchema")});var OI=R((pue,AI)=>{"use strict";var Ep=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}};AI.exports=Ep});var II=R((Aue,NI)=>{"use strict";var bI=Ye(),hp=Mr(),mp=Lr().LMDB_ERRORS_ENUM,CW=at(),yI=K(),Tue=Q(),DW=require("lmdb"),LW=OI(),MW=U(),{OVERFLOW_MARKER:gue,MAX_SEARCH_KEY_LENGTH:Rue}=CW,UW=MW.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function PW(e,t,r,n){if(hp.validateEnv(e),t===void 0)throw new Error(mp.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(mp.IDS_REQUIRED):new Error(mp.IDS_MUST_BE_ITERABLE);try{let s=bI.listDBIs(e);bI.initializeDBIs(e,t,s);let i=new LW,o,c=[],u=[];for(let f=0,E=r.length;f<E;f++)try{o=r[f];let h=e.dbis[t].get(o);if(!h||n&&h[UW]>n){i.skipped.push(o);continue}let S=e.dbis[t].ifVersion(o,DW.IF_EXISTS,()=>{e.dbis[t].remove(o);for(let p=0;p<s.length;p++){let T=s[p];if(!h.hasOwnProperty(T)||T===t)continue;let A=e.dbis[T],g=h[T];if(g!=null)try{let L=hp.getIndexedValues(g);if(L)for(let v=0,P=L.length;v<P;v++)A.remove(L[v],o)}catch{yI.warn(`cannot delete from attribute: ${T}, ${g}:${o}`)}}});c.push(S),u.push(o),i.original_records.push(h)}catch(h){yI.warn(h),i.skipped.push(o)}let _=[],l=await Promise.all(c);for(let f=0,E=l.length;f<E;f++)l[f]===!0?i.deleted.push(u[f]):(i.skipped.push(u[f]),_.push(f));let d=0;for(let f=0;f<_.length;f++){let E=_[f];i.original_records.splice(E-d,1),d++}return i.txn_time=hp.getNextMonotonicTime(),i}catch(s){throw s}}a(PW,"deleteRecords");NI.exports={deleteRecords:PW}});var Vc=R((bue,CI)=>{"use strict";var jo=Q(),vW=II(),BW=Ye(),{getSchemaPath:HW}=Qe(),xW=qc(),GW=K();CI.exports=FW;async function FW(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(jo.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(jo.isEmptyOrZeroLength(e.hash_values)&&!jo.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let u=e.records[c][n];jo.isEmpty(u)||e.hash_values.push(u)}}if(jo.isEmptyOrZeroLength(e.hash_values))return wI([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(jo.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=HW(e.schema,e.table),i=await BW.openEnvironment(s,e.table),o=await vW.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await xW(e,o)}catch(c){GW.error(`unable to write transaction due to ${c.message}`)}return wI(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(FW,"lmdbDeleteRecords");function wI(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(wI,"createDeleteResponse")});var Sp=R((Iue,DI)=>{"use strict";var qW=U(),Nue=Mr();function pp(e,t){let r=Object.create(null);if(t.length===1&&qW.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(pp,"parseRow");function kW(e,t,r,n){let s=pp(r,e);n.push(s)}a(kW,"searchAll");function VW(e,t,r,n){let s=pp(r,e);n[t]=s}a(VW,"searchAllToMap");function $W(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a($W,"iterateDBI");function zi(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(zi,"pushResults");function YW(e,t,r,n,s,i){t.toString().endsWith(e)&&zi(t,r,n,s,i)}a(YW,"endsWith");function KW(e,t,r,n,s,i){t.toString().includes(e)&&zi(t,r,n,s,i)}a(KW,"contains");function WW(e,t,r,n,s,i){t>e&&zi(t,r,n,s,i)}a(WW,"greaterThanCompare");function QW(e,t,r,n,s,i){t>=e&&zi(t,r,n,s,i)}a(QW,"greaterThanEqualCompare");function zW(e,t,r,n,s,i){t<e&&zi(t,r,n,s,i)}a(zW,"lessThanCompare");function JW(e,t,r,n,s,i){t<=e&&zi(t,r,n,s,i)}a(JW,"lessThanEqualCompare");DI.exports={parseRow:pp,searchAll:kW,searchAllToMap:VW,iterateDBI:$W,endsWith:YW,contains:KW,greaterThanCompare:WW,greaterThanEqualCompare:QW,lessThanCompare:zW,lessThanEqualCompare:JW,pushResults:zi}});var Zo=R((Mue,HI)=>{"use strict";var ai=Ye(),Cue=K(),qr=Mr(),Y_=at(),lt=Lr().LMDB_ERRORS_ENUM,Due=Q(),XW=U(),K_=Sp(),{parseRow:jW}=K_,Lue=require("lmdb"),{OVERFLOW_MARKER:LI,MAX_SEARCH_KEY_LENGTH:ZW}=Y_;function MI(e,t,r,n=!1,s=void 0,i=void 0){return Ji(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(MI,"iterateFullIndex");function $c(e,t,r,n,s,i=!1,o=void 0,c=void 0,u=!1,_=!1){return Ji(e,t,r,(l,d,f,E)=>{let A={transaction:l,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!u:!_,exclusiveStart:i===!0?_:u};return E===r?(A.values=!1,d.getRange(A).map(g=>({value:g}))):d.getRange(A)})}a($c,"iterateRangeBetween");function Ji(e,t,r,n){let s=e.database||e,i=ai.openDBI(s,r);i[Y_.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&ai.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(Ji,"setupTransaction");function UI(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(LI)){if(!s)if(r)s=ai.openDBI(e,r);else{let u=ai.listDBIs(e);for(let _=0,l=u.length;_<l&&(s=ai.openDBI(e,u[_]),!s[Y_.DBI_DEFINITION_NAME].is_hash_attribute);_++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(UI,"getOverflowCheck");function eQ(e,t,r,n=!1,s=void 0,i=void 0){if(qr.validateEnv(e),t===void 0)throw new Error(lt.HASH_ATTRIBUTE_REQUIRED);return Ji(e,t,t,(o,c,u)=>(W_(r),r=Yc(u,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(_=>jW(_.value,r))))}a(eQ,"searchAll");function tQ(e,t,r,n=!1,s=void 0,i=void 0){if(qr.validateEnv(e),t===void 0)throw new Error(lt.HASH_ATTRIBUTE_REQUIRED);W_(r),r=Yc(e.database||e,r);let o=new Map;for(let{key:c,value:u}of MI(e,t,t,n,s,i))o.set(c,K_.parseRow(u,r));return o}a(tQ,"searchAllToMap");function rQ(e,t,r=!1,n=void 0,s=void 0){if(qr.validateEnv(e),t===void 0)throw new Error(lt.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=MI(e,void 0,t,r,n,s),c=o.transaction,u=UI(c.database,c,void 0,t);for(let{key:_,value:l}of o){let d=u(_,l);i[d]===void 0&&(i[d]=[]),i[d].push(l)}return i}a(rQ,"iterateDBI");function nQ(e,t){if(qr.validateEnv(e),t===void 0)throw new Error(lt.HASH_ATTRIBUTE_REQUIRED);return ai.statDBI(e,t).entryCount}a(nQ,"countAll");function sQ(e,t,r,n,s=!1,i=void 0,o=void 0){return ci(e,r,n),Ji(e,t,r,(c,u,_,l)=>(n=qr.convertKeyValueToWrite(n),l===r?u.get(n,{transaction:c,lazy:!0})===void 0?[]:[{key:n,value:n}]:u.getValues(n,{transaction:c,reverse:s,limit:i,offset:o}).map(d=>({key:n,value:d}))))}a(sQ,"equals");function iQ(e,t,r){return ci(e,t,r),ai.openDBI(e,t).getValuesCount(r)}a(iQ,"count");function oQ(e,t,r,n,s=!1,i=void 0,o=void 0){return ci(e,r,n),Ji(e,null,r,(c,u)=>{n=qr.convertKeyValueToWrite(n);let _=!0;typeof n=="number"&&(_=!1);let l;if(s===!0){let d;for(let f of u.getKeys({transaction:c,start:n}))if(!f.startsWith(n)){d=f;break}return d!==void 0&&(Number.isInteger(o)?o++:i++),l=u.getRange({transaction:c,start:d,end:void 0,reverse:s,limit:i,offset:o}).map(f=>{let{key:E}=f;if(E!==d){if(E.toString().startsWith(n))return f;if(_===!0)return l.DONE}}),l.filter(f=>f)}else return l=u.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(d=>{if(d.key.toString().startsWith(n))return d;if(_===!0)return l.DONE}),_?l:l.filter(d=>d)})}a(oQ,"startsWith");function aQ(e,t,r,n,s=!1,i=void 0,o=void 0){return PI(e,t,r,n,s,i,o,!0)}a(aQ,"endsWith");function PI(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return ci(e,r,n),Ji(e,null,r,(u,_,l,d)=>{let f=UI(l,u,d,r);return o=Number.isInteger(o)?o:0,_.getKeys({transaction:u,end:s?!1:void 0,reverse:s}).flatMap(E=>{let h=E.toString();return h.endsWith(LI)?_.getValues(E,{transaction:u}).map(S=>{let p=f(E,S);if(c?p.endsWith(n):p.includes(n))return{key:p,value:S}}).filter(S=>S):(c?h.endsWith(n):h.includes(n))?_[Y_.DBI_DEFINITION_NAME].is_hash_attribute?{key:E,value:E}:_.getValues(E,{transaction:u}).map(S=>({key:E,value:S})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a(PI,"contains");function cQ(e,t,r,n,s=!1,i=void 0,o=void 0){ci(e,r,n);let c=typeof n,u;return c==="string"?u="\uFFFF":c==="number"?u=1/0:c==="boolean"&&(u=!0),$c(e,t,r,n,u,s,i,o,!0,!1)}a(cQ,"greaterThan");function uQ(e,t,r,n,s=!1,i=void 0,o=void 0){ci(e,r,n);let c=typeof n,u;return c==="string"?u="\uFFFF":c==="number"?u=1/0:c==="boolean"&&(u=!0),$c(e,t,r,n,u,s,i,o,!1,!1)}a(uQ,"greaterThanEqual");function lQ(e,t,r,n,s=!1,i=void 0,o=void 0){ci(e,r,n);let c=typeof n,u;return c==="string"?u="\0":c==="number"?u=-1/0:c==="boolean"&&(u=!1),$c(e,t,r,u,n,s,i,o,!1,!0)}a(lQ,"lessThan");function _Q(e,t,r,n,s=!1,i=void 0,o=void 0){ci(e,r,n);let c=typeof n,u;return c==="string"?u="\0":c==="number"?u=-1/0:c==="boolean"&&(u=!1),$c(e,t,r,u,n,s,i,o,!1,!1)}a(_Q,"lessThanEqual");function dQ(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(qr.validateEnv(e),r===void 0)throw new Error(lt.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(lt.START_VALUE_REQUIRED);if(s===void 0)throw new Error(lt.END_VALUE_REQUIRED);if(n=qr.convertKeyValueToWrite(n),s=qr.convertKeyValueToWrite(s),n>s)throw new Error(lt.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return $c(e,t,r,n,s,i,o,c)}a(dQ,"between");function fQ(e,t,r,n){qr.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(lt.HASH_ATTRIBUTE_REQUIRED);if(W_(r),r=Yc(s,r),n===void 0)throw new Error(lt.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=K_.parseRow(c,r)),o}a(fQ,"searchByHash");function EQ(e,t,r){qr.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(lt.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(lt.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(EQ,"checkHashExists");function hQ(e,t,r,n,s=[]){return BI(e,t,r,n,s),vI(e,t,r,n,s).map(i=>i[1])}a(hQ,"batchSearchByHash");function mQ(e,t,r,n,s=[]){BI(e,t,r,n,s);let i=new Map;for(let[o,c]of vI(e,t,r,n,s))i.set(o,c);return i}a(mQ,"batchSearchByHashToMap");function vI(e,t,r,n,s=[]){return Ji(e,t,t,(i,o,c)=>{r=Yc(c,r);let u=r.length<3;return n.map(_=>{let l=c.dbis[t].get(_,{transaction:i,lazy:u});if(l)return[_,K_.parseRow(l,r)];s.push(_)}).filter(_=>_)})}a(vI,"batchHashSearch");function BI(e,t,r,n,s){if(qr.validateEnv(e),t===void 0)throw new Error(lt.HASH_ATTRIBUTE_REQUIRED);if(W_(r),n==null)throw new Error(lt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(lt.IDS_MUST_BE_ITERABLE)}a(BI,"initializeBatchSearchByHash");function W_(e){if(!Array.isArray(e))throw e===void 0?new Error(lt.FETCH_ATTRIBUTES_REQUIRED):new Error(lt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(W_,"validateFetchAttributes");function ci(e,t,r){if(qr.validateEnv(e),t===void 0)throw new Error(lt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(lt.SEARCH_VALUE_REQUIRED);if(r?.length>ZW)throw new Error(lt.SEARCH_VALUE_TOO_LARGE)}a(ci,"validateComparisonFunctions");function Yc(e,t){return t.length===1&&XW.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=ai.listDBIs(e)),t}a(Yc,"setGetWholeRowAttributes");HI.exports={searchAll:eQ,searchAllToMap:tQ,count:iQ,countAll:nQ,equals:sQ,startsWith:oQ,endsWith:aQ,contains:PI,searchByHash:fQ,setGetWholeRowAttributes:Yc,batchSearchByHash:hQ,batchSearchByHashToMap:mQ,checkHashExists:EQ,iterateDBI:rQ,greaterThan:cQ,greaterThanEqual:uQ,lessThan:lQ,lessThanEqual:_Q,between:dQ}});var ea=R((Pue,kI)=>{var xI=require("lodash"),GI=rt(),fe=require("joi"),pQ=Q(),{hdb_schema_table:Kc,checkValidTable:FI,hdb_table:qI,hdb_database:Q_}=Qn(),{handleHDBError:SQ,hdb_errors:TQ}=ne(),{getDatabases:gQ}=(Ae(),ie(qe)),{HTTP_STATUS_CODES:RQ}=TQ,AQ=fe.object({database:Q_,schema:Q_,table:qI,search_attribute:Kc,search_value:fe.any().required(),get_attributes:fe.array().min(1).items(fe.alternatives(Kc,fe.object())).optional(),desc:fe.bool(),limit:fe.number().integer().min(1),offset:fe.number().integer().min(0)}),OQ=fe.object({database:Q_,schema:Q_,table:qI,operator:fe.string().valid("and","or").default("and").lowercase(),offset:fe.number().integer().min(0),limit:fe.number().integer().min(1),get_attributes:fe.array().min(1).items(fe.alternatives(Kc,fe.object())).optional(),sort:fe.object({attribute:fe.alternatives(Kc,fe.array().min(1)),descending:fe.bool().optional()}).optional(),conditions:fe.array().min(1).items(fe.alternatives(fe.object({operator:fe.string().valid("and","or").default("and").lowercase(),conditions:fe.array()}),fe.object({search_attribute:fe.alternatives(Kc,fe.array().min(1)),search_type:fe.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:fe.when("search_type",{switch:[{is:"equals",then:fe.any()},{is:"between",then:fe.array().items(fe.alternatives([fe.string(),fe.number()])).length(2)}],otherwise:fe.alternatives(fe.string(),fe.number())}).required()}))).required()});kI.exports=function(e,t){let r=null;switch(t){case"value":r=GI.validateBySchema(e,AQ);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(FI("database",e.schema)),i(FI("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=GI.validateBySchema(e,OQ);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=pQ.checkGlobalSchemaTable(e.schema,e.table);if(s)return SQ(new Error,s,RQ.NOT_FOUND);let o=gQ()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let u=a(l=>{for(let d=0,f=l.conditions.length;d<f;d++){let E=l.conditions[d];E.conditions?u(E):c.push(E.search_attribute)}},"addConditions");t==="conditions"&&u(e);let _=xI.filter(c,l=>l!=="*"&&l.attribute!=="*"&&!Array.isArray(l)&&!l.name&&!xI.some(o,d=>d===l||d.attribute===l||d.attribute===l.attribute));if(_&&_.length>0){let l=_.join(", ");return l=l.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${l}'`)}}return r}});var Tp=R((Bue,VI)=>{"use strict";var bQ=Ye(),yQ=ea(),{getSchemaPath:NQ}=Qe();VI.exports=IQ;function IQ(e){let t=yQ(e,"hashes");if(t)throw t;let r=NQ(e.schema,e.table);return bQ.openEnvironment(r,e.table)}a(IQ,"initialize")});var gp=R((xue,$I)=>{"use strict";var wQ=Zo(),CQ=Tp();$I.exports=DQ;async function DQ(e){let t=await CQ(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return wQ.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(DQ,"lmdbGetDataByHash")});var ta=R((Fue,YI)=>{"use strict";var Rp=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};YI.exports=Rp});var WI=R((Vue,KI)=>{"use strict";var kue=ta(),LQ=Zo(),MQ=Tp();KI.exports=UQ;async function UQ(e){let t=await MQ(e),r=global.hdb_schema[e.schema][e.table];return LQ.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(UQ,"lmdbSearchByHash")});var Zn=R((Yue,QI)=>{"use strict";var Ap=class{static{a(this,"SearchObject")}constructor(t,r,n,s,i,o,c,u=!1,_=void 0,l=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=u,this.limit=_,this.offset=l}};QI.exports=Ap});var z_=R((Wue,ew)=>{"use strict";var jt=Zo(),PQ=Ye(),vQ=Q(),Ee=at(),Xi=U(),BQ=Hi(),zI=Lr().LMDB_ERRORS_ENUM,{getSchemaPath:HQ}=Qe(),As=Xi.SEARCH_WILDCARDS;async function xQ(e,t,r){let n;e.schema===Xi.SYSTEM_SCHEMA_NAME?n=BQ[e.table]:n=global.hdb_schema[e.schema][e.table];let s=ZI(e,n.hash_attribute,r,t);return XI(e,s,n.hash_attribute,r)}a(xQ,"prepSearch");async function XI(e,t,r,n){let s=HQ(e.schema,e.table),i=await PQ.openEnvironment(s,e.table),o=jI(i,e,t,r),c=o.transaction||i;if([Ee.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,Ee.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,Ee.SEARCH_TYPES.SEARCH_ALL,Ee.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(GQ(e,r)===!1){let l=e.search_attribute;if(l===r)return n?JI(o,()=>!0):o.map(f=>({[r]:f.key}));let d=a(f=>({[r]:f.value,[l]:f.key}),"toObject");return n?JI(o,d):o.map(d)}let _=e.search_attribute===r?o.map(l=>l.key):o.map(l=>l.value);return n===!0?jt.batchSearchByHashToMap(c,r,e.get_attributes,_):jt.batchSearchByHash(c,r,e.get_attributes,_)}a(XI,"executeSearch");function jI(e,t,r,n){let s,i=n;t.get_attributes.indexOf(n)<0&&(i=void 0);let{reverse:o,limit:c,offset:u}=t;switch(o=typeof o=="boolean"?o:!1,c=Number.isInteger(c)?c:void 0,u=Number.isInteger(u)?u:void 0,r){case Ee.SEARCH_TYPES.EQUALS:s=jt.equals(e,i,t.search_attribute,t.search_value,o,c,u);break;case Ee.SEARCH_TYPES.CONTAINS:s=jt.contains(e,i,t.search_attribute,t.search_value,o,c,u);break;case Ee.SEARCH_TYPES.ENDS_WITH:case Ee.SEARCH_TYPES._ENDS_WITH:s=jt.endsWith(e,i,t.search_attribute,t.search_value,o,c,u);break;case Ee.SEARCH_TYPES.STARTS_WITH:case Ee.SEARCH_TYPES._STARTS_WITH:s=jt.startsWith(e,i,t.search_attribute,t.search_value,o,c,u);break;case Ee.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return jt.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case Ee.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return jt.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case Ee.SEARCH_TYPES.SEARCH_ALL:return jt.searchAll(e,n,t.get_attributes,o,c,u);case Ee.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return jt.searchAllToMap(e,n,t.get_attributes,o,c,u);case Ee.SEARCH_TYPES.BETWEEN:s=jt.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,u);break;case Ee.SEARCH_TYPES.GREATER_THAN:case Ee.SEARCH_TYPES._GREATER_THAN:s=jt.greaterThan(e,i,t.search_attribute,t.search_value,o,c,u);break;case Ee.SEARCH_TYPES.GREATER_THAN_EQUAL:case Ee.SEARCH_TYPES._GREATER_THAN_EQUAL:s=jt.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,u);break;case Ee.SEARCH_TYPES.LESS_THAN:case Ee.SEARCH_TYPES._LESS_THAN:s=jt.lessThan(e,i,t.search_attribute,t.search_value,o,c,u);break;case Ee.SEARCH_TYPES.LESS_THAN_EQUAL:case Ee.SEARCH_TYPES._LESS_THAN_EQUAL:s=jt.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,u);break;default:return Object.create(null)}return s}a(jI,"searchByType");function JI(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(JI,"createMapFromIterable");function GQ(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(GQ,"checkToFetchMore");function ZI(e,t,r,n){if(vQ.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),As.indexOf(s)>-1)return r===!0?Ee.SEARCH_TYPES.SEARCH_ALL_TO_MAP:Ee.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(As[0])<0&&s.indexOf(As[1])<0)return c===!0?r===!0?Ee.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:Ee.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:Ee.SEARCH_TYPES.EQUALS;if(As.indexOf(i)>=0&&As.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),Ee.SEARCH_TYPES.CONTAINS;if(As.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),Ee.SEARCH_TYPES.ENDS_WITH;if(As.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),Ee.SEARCH_TYPES.STARTS_WITH;if(s.includes(As[0])||s.includes(As[1]))return Ee.SEARCH_TYPES.EQUALS;throw new Error(zI.UNKNOWN_SEARCH_TYPE)}else switch(n){case Xi.VALUE_SEARCH_COMPARATORS.BETWEEN:return Ee.SEARCH_TYPES.BETWEEN;case Xi.VALUE_SEARCH_COMPARATORS.GREATER:return Ee.SEARCH_TYPES.GREATER_THAN;case Xi.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return Ee.SEARCH_TYPES.GREATER_THAN_EQUAL;case Xi.VALUE_SEARCH_COMPARATORS.LESS:return Ee.SEARCH_TYPES.LESS_THAN;case Xi.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return Ee.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(zI.UNKNOWN_SEARCH_TYPE)}}a(ZI,"createSearchTypeFromSearchObject");ew.exports={executeSearch:XI,createSearchTypeFromSearchObject:ZI,prepSearch:xQ,searchByType:jI}});var rw=R((Jue,tw)=>{"use strict";var zue=Zn(),FQ=ea(),qQ=Q(),kQ=U(),VQ=z_();tw.exports=$Q;function $Q(e,t){if(!qQ.isEmpty(t)&&kQ.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=FQ(e,"value");if(n)throw n;return VQ.prepSearch(e,t,!0)}a($Q,"lmdbGetDataByValue")});var Wc=R((Zue,nw)=>{"use strict";var jue=Zn(),YQ=ea(),KQ=Q(),WQ=U(),QQ=z_();nw.exports=zQ;async function zQ(e,t){if(!KQ.isEmpty(t)&&WQ.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=YQ(e,"value");if(n)throw n;return QQ.prepSearch(e,t,!1)}a(zQ,"lmdbSearchByValue")});var iw=R((rle,sw)=>{"use strict";var tle=at(),Op=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}},bp=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},yp=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};sw.exports={SearchByConditionsObject:Op,SearchCondition:bp,SortAttribute:yp}});var lw=R((ole,uw)=>{"use strict";var sle=iw().SearchByConditionsObject,JQ=Zn(),XQ=ea(),Np=Zo(),J_=at(),{Resource:ile}=(bn(),ie(Ip)),cw=z_(),jQ=Sp(),ZQ=require("lodash"),{getSchemaPath:ez}=Qe(),ow=Ye(),{handleHDBError:tz,hdb_errors:rz}=ne(),{HTTP_STATUS_CODES:nz}=rz,sz=1e8;uw.exports=iz;async function iz(e){let t=XQ(e,"conditions");if(t)throw tz(t,t.message,nz.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 ow.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let _ of e.conditions)ow.openDBI(n,_.search_attribute);let i=ZQ.sortBy(e.conditions,_=>{if(_.estimated_count===void 0){let l=_.search_type;l===J_.SEARCH_TYPES.EQUALS?_.estimated_count=Np.count(n,_.search_attribute,_.search_value):l===J_.SEARCH_TYPES.CONTAINS||l===J_.SEARCH_TYPES.ENDS_WITH?_.estimated_count=1/0:_.estimated_count=sz}return _.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await aw(o,e,i[0],s.hash_attribute),u;if(!e.operator||e.operator.toLowerCase()==="and"){let _=n.dbis[s.hash_attribute],l=i.slice(1).map(cw.filterByType),d=l.length,f=Np.setGetWholeRowAttributes(n,e.get_attributes);u=c.map(E=>_.get(E,{transaction:o,lazy:!0})),d>0&&(u=u.filter(E=>{for(let h=0;h<d;h++)if(!l[h](E))return!1;return!0})),(e.offset||e.limit!==void 0)&&(u=u.slice(e.offset,e.limit!==void 0?(e.offset||0)+e.limit:void 0)),u=u.map(E=>jQ.parseRow(E,f))}else{for(let d=1;d<i.length;d++){let f=i[d],E=await aw(o,e,f,s.hash_attribute);c=c.concat(E)}let _=new Set,l=e.offset||0;c=c.filter(d=>_.has(d)?!1:(_.add(d),!0)).slice(l,e.limit&&e.limit+l),u=Np.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return u.onDone=()=>{o.done()},u}a(iz,"lmdbSearchByConditions");async function aw(e,t,r,n){let s=new JQ(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===J_.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,cw.searchByType(e,s,i,n).map(o=>o.value)}a(aw,"executeConditionSearch")});var Qc=R((cle,_w)=>{"use strict";var oz=U().OPERATIONS_ENUM,wp=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=oz.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};_w.exports=wp});var Cp=R((lle,Tw)=>{"use strict";var hw=Zn(),mw=Qc(),pw=Wc(),Sw=Vc(),fr=U(),dw=Q(),fw=Ye(),{getTransactionAuditStorePath:az,getSchemaPath:cz}=Qe(),Ew=K();Tw.exports=uz;async function uz(e){try{if(dw.isEmpty(global.hdb_schema[e.schema])||dw.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await lz(e),await _z(e);let t=cz(e.schema,e.table);try{await fw.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")Ew.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=az(e.schema,e.table);await fw.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")Ew.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(uz,"lmdbDropTable");async function lz(e){let t=new hw(fr.SYSTEM_SCHEMA_NAME,fr.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,fr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[fr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await pw(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 mw(fr.SYSTEM_SCHEMA_NAME,fr.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await Sw(s)}a(lz,"deleteAttributesFromSystem");async function _z(e){let t=new hw(fr.SYSTEM_SCHEMA_NAME,fr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,fr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[fr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,fr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,fr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await pw(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 mw(fr.SYSTEM_SCHEMA_NAME,fr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await Sw(s)}catch(i){throw i}}a(_z,"dropTableFromSystem")});var Rw=R((dle,gw)=>{"use strict";var dz=require("fs-extra"),fz=Zn(),Ez=ta(),hz=Qc(),mz=Cp(),pz=Vc(),Sz=gp(),Tz=Wc(),Os=U(),{getSchemaPath:gz}=Qe(),{handleHDBError:Rz,hdb_errors:Az}=ne(),{HDB_ERROR_MSGS:Oz,HTTP_STATUS_CODES:bz}=Az;gw.exports=yz;async function yz(e){let t;try{t=await Nz(e.schema);let r=new fz(Os.SYSTEM_SCHEMA_NAME,Os.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Os.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[Os.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await Tz(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await mz(c)}catch(u){if(u.message!=="invalid environment")throw u}}let s=new hz(Os.SYSTEM_SCHEMA_NAME,Os.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await pz(s);let i=gz(t);await dz.remove(i)}catch(r){throw r}}a(yz,"lmdbDropSchema");async function Nz(e){let t=new Ez(Os.SYSTEM_SCHEMA_NAME,Os.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[Os.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await Sz(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw Rz(new Error,Oz.SCHEMA_NOT_FOUND(e),bz.NOT_FOUND,void 0,void 0,!0);return n}a(Nz,"validateDropSchema")});var Lp=R((Ele,Aw)=>{"use strict";var Dp=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};Aw.exports=Dp});var bw=R((ple,Ow)=>{"use strict";var Iz=require("fs-extra"),X_=Ye(),{getTransactionAuditStorePath:wz}=Qe(),Mp=at(),mle=Lp();Ow.exports=Cz;async function Cz(e){let t;try{let r=wz(e.schema,e.table);await Iz.mkdirp(r),t=await X_.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{X_.createDBI(t,Mp.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),X_.createDBI(t,Mp.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),X_.createDBI(t,Mp.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(Cz,"createTransactionsAuditEnvironment")});var ww=R((Tle,Iw)=>{"use strict";var Up=U(),yw=Ye(),Dz=qo(),{getSystemSchemaPath:Lz,getSchemaPath:Mz}=Qe(),Uz=Hi(),Pz=p_(),Pp=m_(),vz=K(),Bz=bw(),Bp=Uz.hdb_table,Nw=[];for(let e=0;e<Bp.attributes.length;e++)Nw.push(Bp.attributes[e].attribute);Iw.exports=Hz;async function Hz(e,t){let r=Mz(t.schema,t.table),n=new Pp(t.schema,t.table,Up.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new Pp(t.schema,t.table,Up.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new Pp(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await yw.createEnvironment(r,t.table),e!==void 0){let o=await yw.openEnvironment(Lz(),Up.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await Dz.insertRecords(o,Bp.hash_attribute,Nw,[e]),n.skip_table_check=!0,s.skip_table_check=!0,i.skip_table_check=!0,await vp(n),await vp(s),await vp(i)}await Bz(t)}catch(o){throw o}}a(Hz,"lmdbCreateTable");async function vp(e){try{await Pz(e)}catch(t){vz.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(vp,"createAttribute")});var Dw=R((Rle,Cw)=>{"use strict";var xz=Mc(),Gz=Pc(),Fz=V_(),zc=U(),qz=qo().updateRecords,kz=Ye(),{getSchemaPath:Vz}=Qe(),$z=qc(),Yz=K();Cw.exports=Kz;async function Kz(e){try{let{schema_table:t,attributes:r}=xz(e);Gz(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 Fz(e.hdb_auth_header,t,r),s=Vz(e.schema,e.table),i=await kz.openEnvironment(s,e.table),o=await qz(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await $z(e,o)}catch(c){Yz.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(Kz,"lmdbUpdateRecords")});var Mw=R((Ole,Lw)=>{"use strict";var Wz=U().OPERATIONS_ENUM,Hp=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=Wz.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};Lw.exports=Hp});var Pw=R((Nle,Uw)=>{"use strict";var yle=Mw(),Qz=Mc(),zz=Pc(),Jz=V_(),Jc=U(),Xz=qo().upsertRecords,jz=Ye(),{getSchemaPath:Zz}=Qe(),e2=qc(),t2=K(),{handleHDBError:r2,hdb_errors:n2}=ne();Uw.exports=s2;async function s2(e){let t;try{t=Qz(e)}catch(u){throw r2(u,u.message,n2.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;zz(e,n,r.hash_attribute),e.schema!==Jc.SYSTEM_SCHEMA_NAME&&(n.includes(Jc.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(Jc.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(Jc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(Jc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await Jz(e.hdb_auth_header,r,n),i=Zz(e.schema,e.table),o=await jz.openEnvironment(i,e.table),c=await Xz(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await e2(e,c)}catch(u){t2.error(`unable to write transaction due to ${u.message}`)}return{written_hashes:c.written_hashes,schema_table:r,new_attributes:s,txn_time:c.txn_time}}a(s2,"lmdbUpsertRecords")});var Bw=R((wle,vw)=>{"use strict";var xp=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};vw.exports=xp});var xw=R((Dle,Hw)=>{"use strict";var Gp=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}};Hw.exports=Gp});var qw=R((Ule,Fw)=>{"use strict";var Fp=Ye(),{getTransactionAuditStorePath:i2}=Qe(),Mle=Bw(),Xc=at(),o2=Q(),Gw=xw(),a2=require("util").promisify,c2=a2(setTimeout),u2=1e4,l2=100;Fw.exports=_2;async function _2(e){let t=i2(e.schema,e.table),r=await Fp.openEnvironment(t,e.table,!0),n=Fp.listDBIs(r);Fp.initializeDBIs(r,Xc.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new Gw;do s=await d2(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 c2(l2);while(s.transactions_deleted>0);return i}a(_2,"deleteAuditLogsBefore");async function d2(e,t){let r=new Gw;try{let n=e.dbis[Xc.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[Xc.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];o2.isEmpty(c)||(s=e.dbis[Xc.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let u=0;u<o.hash_values.length;u++)s=e.dbis[Xc.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[u],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>u2)break}return await s,r}catch(n){throw n}}a(d2,"deleteTransactions")});var Vw=R((vle,kw)=>{"use strict";var qp=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};kw.exports=qp});var Yw=R((xle,$w)=>{"use strict";var f2=Zn(),E2=Qc(),Hle=Vw(),es=U(),h2=Q(),kp=Ye(),m2=Hi(),p2=Wc(),S2=Vc(),{getSchemaPath:T2}=Qe();$w.exports=g2;async function g2(e,t=!0){let r;e.schema===es.SYSTEM_SCHEMA_NAME?r=m2[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await A2(e),s=T2(e.schema,e.table),i=await kp.openEnvironment(s,e.table);return t===!0&&await R2(e,i,r.hash_attribute),kp.dropDBI(i,e.attribute),n}a(g2,"lmdbDropAttribute");async function R2(e,t,r){let n=kp.openDBI(t,r),s,i=e.attribute;for(let{key:o,value:c,version:u}of n.getRange({start:!1,versions:!0})){let _={};for(let l in c)l!==i&&(_[l]=c[l]);s=t.dbis[r].put(o,_,u)}await s}a(R2,"removeAttributeFromAllObjects");async function A2(e){let t=new f2(es.SYSTEM_SCHEMA_NAME,es.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,es.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[es.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,es.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await p2(t)).filter(o=>o[es.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(h2.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[es.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new E2(es.SYSTEM_SCHEMA_NAME,es.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return S2(i)}a(A2,"dropAttributeFromSystem")});var Xw=R((qle,Jw)=>{"use strict";var Vp=Ye(),ra=at(),Fle=Mr(),$p=U(),Kw=Q(),{getTransactionAuditStorePath:O2}=Qe(),b2=Zo(),j_=Jo(),y2=K();Jw.exports=N2;async function N2(e){let t=O2(e.schema,e.table),r=await Vp.openEnvironment(t,e.table,!0),n=Vp.listDBIs(r);Vp.initializeDBIs(r,ra.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case $p.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return Ww(r,e.search_values);case $p.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,w2(r,e.search_values,s);case $p.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return I2(r,e.search_values);default:return Ww(r)}}a(N2,"readAuditLog");function Ww(e,t=[0,Date.now()]){Kw.isEmpty(t[0])&&(t[0]=0),Kw.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[ra.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 j_,s))}a(Ww,"searchTransactionsByTimestamp");function I2(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[ra.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,zw(e,i))}return Object.fromEntries(r)}a(I2,"searchTransactionsByUsername");function w2(e,t,r){let n=new Map;for(let c=0,u=t.length;c<u;c++){let _=t[c],l=b2.equals(e,ra.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,ra.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,_);for(let{value:d}of l){let f=Number(d);n.has(f)?n.get(f).push(_.toString()):n.set(f,[_.toString()])}}let s=Array.from(n.keys()),i=zw(e,s),o=new Map;for(let c=0;c<i.length;c++){let u=i[c],_=u.timestamp,l=n.get(_);Qw(u,"records",r,l,o),Qw(u,"original_records",r,l,o)}return Object.fromEntries(o)}a(w2,"searchTransactionsByHashValues");function Qw(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],u=c[r].toString();if(n.indexOf(u)>=0)if(s.has(u)){let _=s.get(u),l=_[_.length-1];if(l.timestamp===i)l[t]=[c];else{let d=new j_(e.operation,e.user_name,i,void 0);d[t]=[c],_.push(d)}}else{let _=new j_(e.operation,e.user_name,i,void 0);_[t]=[c],s.set(u,[_])}}}a(Qw,"loopRecords");function zw(e,t){let r=[];try{let n=e.dbis[ra.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 j_,i);r.push(o)}}catch(i){y2.warn(i)}return r}catch(n){throw n}}a(zw,"batchSearchTransactions")});var Zw=R((Yle,jw)=>{"use strict";var{getSchemaPath:Vle}=Qe(),$le=Ye(),{database:C2}=(Ae(),ie(qe));jw.exports={writeTransaction:D2};async function D2(e,t,r){return C2({database:e,table:t}).transaction(r)}a(D2,"writeTransaction")});var nC=R((Wle,rC)=>{"use strict";var{getSchemaPath:eC}=Qe(),tC=Ye();rC.exports={flush:L2,resetReadTxn:M2};async function L2(e,t){return(await tC.openEnvironment(eC(e,t),t.toString())).flushed}a(L2,"flush");async function M2(e,t){try{(await tC.openEnvironment(eC(e,t),t.toString())).resetReadTxn()}catch{}}a(M2,"resetReadTxn")});var aC=R((zle,oC)=>{"use strict";var{Readable:U2}=require("stream"),{getDatabases:P2}=(Ae(),ie(qe)),{readSync:v2,openSync:B2,createReadStream:sC}=require("fs"),{open:H2}=require("lmdb"),iC=yc(),x2=Nc(),{AUDIT_STORE_OPTIONS:G2}=(js(),ie(cC)),{INTERNAL_DBIS_NAME:F2,AUDIT_STORE_NAME:q2}=at();oC.exports=V2;var Yp=32768,k2=100;async function V2(e){let t=e.database||e.schema||"data",r=P2()[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 l=_.dbisDB,d=H2({noSync:!0,maxDbs:x2.MAX_DBS}),f,E=d.openDB(F2,new iC(!1)),h=l.useReadTransaction(),S=0,p=a(async function(A,g){g.encoding="binary",g.encoder=void 0;let L=d.openDB(A,g),v=l.openDB(A,g);for(let{key:P,version:k,value:H}of v.getRange({start:null,transaction:h,versions:v.useVersions}))f=L.put(P,H,k),S++%k2===0&&(await new Promise(X=>setTimeout(X,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:A,value:g}of l.getRange({transaction:h,start:!1}))if(s.some(L=>A.startsWith?.(L+"/"))){E.put(A,g);let[,L]=A.split("/"),v=!L,P=new iC(!v,v);await p(A,P)}e.include_audit&&await p(q2,Object.assign({},G2)),await f;let T=sC(d.path);return T.headers=u(),T.on("close",()=>{h.done(),d.close()}),T}let o=r[Object.keys(r)[0]].primaryStore,c=B2(o.path);return o.transaction(()=>{let _=Buffer.alloc(Yp);v2(c,_,0,Yp),o.resetReadTxn();let l=o.useReadTransaction();l.renew();let d=sC(null,{fd:c,start:Yp}),f=new U2.from(async function*(){yield _;for await(let E of d)l.openTimer&&(l.openTimer=0),yield E;l.done()}());return f.headers=u(),f});function u(){let _=new Map;return _.set("content-type","application/octet-stream"),_.set("content-disposition",`attachment; filename="${t}"`),_.set("date",n),_}}a(V2,"getBackup")});var _C=R((Xle,lC)=>{"use strict";var $2=K(),{handleHDBError:Y2}=ne(),K2=Ob(),W2=p_(),Q2=fp(),z2=RI(),J2=Vc(),X2=gp(),j2=WI(),Z2=rw(),eJ=Wc(),tJ=lw(),rJ=Rw(),nJ=ww(),sJ=Dw(),iJ=Pw(),oJ=qw(),aJ=Cp(),cJ=Yw(),uJ=Xw(),lJ=Zw(),uC=nC(),_J=aC(),Kp=class extends K2{static{a(this,"LMDBBridge")}async searchByConditions(t){return tJ(t)}async getDataByHash(t){return await X2(t)}async searchByHash(t){return await j2(t)}async getDataByValue(t,r){return await Z2(t,r)}async searchByValue(t){return await eJ(t)}async createSchema(t){return await z2(t)}async dropSchema(t){return await rJ(t)}async createTable(t,r){return await nJ(t,r)}async dropTable(t){return await aJ(t)}async createAttribute(t){return await W2(t)}async createRecords(t){return await Q2(t)}async updateRecords(t){return await sJ(t)}async upsertRecords(t){try{return await iJ(t)}catch(r){throw Y2(r,null,null,$2.ERR,r)}}async deleteRecords(t){return await J2(t)}async dropAttribute(t){return await cJ(t)}async deleteAuditLogsBefore(t){return await oJ(t)}async readAuditLog(t){return await uJ(t)}writeTransaction(t,r,n){return lJ.writeTransaction(t,r,n)}flush(t,r){return uC.flush(t,r)}resetReadTxn(t,r){return uC.resetReadTxn(t,r)}getBackup(t){return _J(t)}};lC.exports=Kp});function hJ(){EJ=setInterval(function(){for(let e of Wp)if(e.stale){let t=e[ye]?.url;hC.error(`Transaction was open too long and has been aborted, from table: ${e.lmdbDb?.name+(t?" path: "+t:"")}`),e.abort()}else e.stale=!0},fJ).unref()}var Qp,EC,hC,mC,pC,SC,dC,Wp,dJ,jc,fC,ji,Z_,fJ,EJ,zp=Re(()=>{Qp=B(Mr()),EC=B(ne()),hC=B(K());bn();mC=B(te()),pC=B(U()),SC=B(Q()),dC=100,Wp=new Set,dJ=(0,SC.convertToMS)(mC.get(pC.CONFIG_PARAMS.STORAGE_MAXTRANSACTIONQUEUETIME))||45e3,ji=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.readTxnsUsed=1,this.readTxn=this.lmdbDb.useReadTransaction(),this.readTxn.openTimer&&(this.readTxn.openTimer=0),Wp.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(Wp.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(jc&&!this.overloadChecked&&performance.now()-fC>dJ)throw new EC.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=t.timestamp||(0,Qp.getNextMonotonicTime)());let n=t.retries||0;if(this.validated<this.writes.length)try{let d=this.validated;this.validated=this.writes.length;for(let E=d;E<this.validated;E++)this.writes[E]?.validate?.(this.timestamp);let f;for(let E=d;E<this.validated;E++){let h=this.writes[E];h&&(h.before||h.beforeIntermediate)&&(f=!0)}if(f)return(async()=>{try{for(let E=0;E<2;E++){let h;for(let S=d;S<this.validated;S++){let p=this.writes[S];if(!p)continue;let T=p[E===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(E){throw this.abort(),E}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"),u=a(()=>{let d=this.writes[o++];if(d)if(d.key){n>0&&(d.entry=d.store.getEntry(d.key));let f=d.store.ifVersion(d.key,d.entry?.version??null,u);s=s||f}else u();else for(let f of this.writes)c(f)},"nextCondition"),_=this.lmdbDb;if(this.writes.length>0&&(_?.retryRisk&&(_.retryRisk*=.99),this.writes.length+(_?.retryRisk||0)<dC>>n?u():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 jc||(jc=s,fC=performance.now(),jc.then(()=>{jc=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)+dC/2),t?t.retries=n+1:t={retries:1},this.commit(t)));let l={txnTime:r};if(this.next){let d=this.next?.commit(t);if(d?.then)return d?.then(f=>({txnTime:r,next:f}));l.next=d}return l}abort(){for(;this.readTxnsUsed>0;)this.doneReadTxn();this.open=0,this.writes=[]}},Z_=class extends ji{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,Qp.getNextMonotonicTime)())}getReadTxn(){}},fJ=3e4;a(hJ,"startMonitoringTxns");hJ()});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 ji;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 u=n.commit({letItLinger:r?.letItLinger});return u.then?u.then(()=>c):c}function o(c){throw n.abort({}),c}}var TC,Zi=Re(()=>{TC=require("../index");bn();zp();a(ze,"transaction");(0,TC._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 wC={};Fe(wC,{ResourceBridge:()=>jp});function Zp({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 RC(e,t){let r=ts(e),n=Zp(e,r);if(!r)throw new Ln.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},o;ze(i,()=>new Promise(_=>o=_));let c=e.ids||e.hash_values,u=0;return{[Symbol.asyncIterator](){return{async next(){if(u<c.length){let _=c[u++],l=await r.get({id:_,lazy:s,select:n},i);return l=l&&td(l),t?{value:{key:_,value:l}}:{value:l}}else return o(),{done:!0}},return(_){return o(),{value:_,done:!0}},throw(_){return o(),{done:!0}}}}}}function ts(e){let t=e.database||e.schema||pJ,r=Er()[t];if(!r)throw(0,Ln.handleHDBError)(new Error,mJ.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function AC(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*OC(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:u}=s;n?.timestamp===c?(n.hash_values.push(o),n.records.push(u)):(n&&(yield n),n={operation:i,user_name:s.user,timestamp:c,hash_values:[o],records:[u]})}n&&(yield n)}var bC,ed,Ln,yC,NC,Mn,Jp,Xp,IC,mJ,pJ,SJ,TJ,gC,jp,CC=Re(()=>{"use strict";bC=B(_C()),ed=B(ea()),Ln=B(ne());Ae();yC=B(Mc()),NC=B(Pc()),Mn=B(U()),Jp=B(Rs()),Xp=B(Dn()),IC=B(Q());Zi();rd();({HDB_ERROR_MSGS:mJ}=Ln.hdb_errors),pJ="data",SJ=1e4,TJ=10,jp=class extends bC.default{static{a(this,"ResourceBridge")}constructor(t){super(t),gC=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,ed.default)(t,"conditions");if(r)throw(0,Ln.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=ts(t);if(!n)throw new Ln.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:Zp(t,n),sort:t.sort,allowFullScan:!0})}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 Ln.ClientError("A primary key must be specified with a `primary_key` property or with `attributes`");n=[{name:i,isPrimaryKey:!0},{name:"__createdtime__",indexed:!0},{name:"__updatedtime__",indexed:!0}]}ut({database:r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration})}async createAttribute(t){return await ts(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=ts(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=a((o,c,u)=>(c=Object.assign({},c),delete c[n],r.primaryStore.ifVersion(o,u,()=>r.primaryStore.put(o,c,u)).then(_=>{if(!_){let{value:l,version:d}=r.primaryStore.getEntry(o);return i(o,l,d)}})),"deleteRecord");for(let{key:o,value:c,version:u}of r.primaryStore.getRange({start:!0,versions:!0}))s=i(o,c,u),await new Promise(_=>setImmediate(_));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){ts(t).dropTable()}createSchema(t){return Zc({database:t.schema,table:null}),Jp.signalSchemaChange(new Xp.SchemaEventMsg(process.pid,Mn.OPERATIONS_ENUM.CREATE_SCHEMA,t.schema))}async dropSchema(t){await eS(t.schema),Jp.signalSchemaChange(new Xp.SchemaEventMsg(process.pid,Mn.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,gC.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,yC.default)(t);(0,NC.default)(t,n,r.primaryKey);let s,i=Er()[t.schema][t.table],o={user:t.hdb_user,expiresAt:t.expiresAt};return ze(o,async c=>{if(!i.schemaDefined){s=[];for(let l of n)i.attributes.find(f=>f.name==l)||s.push(l);s.length>0&&await i.addAttributes(s.map(l=>({name:l,indexed:!0})))}let u=[],_=[];for(let l of t.records){let d=await i.get(l[i.primaryKey],o);if(t.requires_existing&&!d||t.requires_no_existing&&d){_.push(l[i.primaryKey]);continue}d&&(d=td(d));for(let f in l)if(Object.prototype.hasOwnProperty.call(l,f)){let E=l[f];if(typeof E=="function")try{let h=E([[d]]);Array.isArray(h)&&(E=h[0].func_val,l[f]=E)}catch(h){throw h.message+="Trying to set key "+f+" on object"+JSON.stringify(l),h}}if(d)for(let f in d)Object.prototype.hasOwnProperty.call(l,f)||(l[f]=d[f]);await i.put(l,o),u.push(l[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:u,new_attributes:s,skipped_hashes:_}})}async deleteRecords(t){let r=Er()[t.schema][t.table],n={user:t.hdb_user};return ze(n,async s=>{let i=t.hash_values||t.records.map(u=>u[r.primaryKey]),o=[],c=[];for(let u of i)await r.delete(u,n)?o.push(u):c.push(u);return AC(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=Er()[t.schema][t.table];if(!r.createdTimeProperty)throw new Ln.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:Mn.VALUE_SEARCH_COMPARATORS.LESS}]}),s=!1,i=[],o=[],c=0,u=[],_=a(async()=>{let l=await this.deleteRecords({schema:t.schema,table:t.table,hash_values:u});i.push(...l.deleted_hashes),o.push(...l.skipped_hashes),await(0,IC.async_set_timeout)(TJ),u=[],s=!0},"chunkDelete");for await(let l of n)u.push(l[r.primaryKey]),c++,c%SJ===0&&await _();return u.length>0&&await _(),s?AC(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,ed.default)(t,"hashes");if(r)throw r;return RC(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of RC(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&Mn.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,ed.default)(t,"value");if(n)throw n;let s=ts(t);if(!s)throw new Ln.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===Mn.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,select:Zp(t,s)})}async getDataByValue(t,r){let n=new Map,s=ts(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){ts({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return ts(t).deleteHistory(t.timestamp)}async readAuditLog(t){let r=ts(t),n={};switch(t.search_type){case Mn.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 Mn.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:let s=t.search_values;for await(let i of OC(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return OC(r,t.search_values?.[0],t.search_values?.[1])}}};a(Zp,"getSelect");a(RC,"getRecords");a(ts,"getTable");a(AC,"createDeleteResponse");a(OC,"groupRecordsInHistory")});var In=R((d_e,DC)=>{"use strict";var{ResourceBridge:gJ}=(CC(),ie(wC)),RJ=te();RJ.initSync();var nd;function AJ(){return nd||(nd=new gJ,nd)}a(AJ,"getBridge");DC.exports=AJ()});var PC=R((E_e,UC)=>{"use strict";var LC=require("lodash"),eu=require("mathjs"),OJ=require("jsonata"),MC=Q();UC.exports={distinct_array:e=>Array.isArray(e)&&e.length>1?LC.uniqWith(e,LC.isEqual):e,searchJSON:bJ,mad:tu.bind(null,eu.mad),mean:tu.bind(null,eu.mean),mode:tu.bind(null,eu.mode),prod:tu.bind(null,eu.prod),median:tu.bind(null,eu.median)};function tu(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(tu,"aggregateFunction");function bJ(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(MC.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),MC.isEmpty(this.__ala__.res[r])){let n=OJ(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(bJ,"searchJSON")});var BC=R((m_e,vC)=>{"use strict";var pt=require("moment"),tS="YYYY-MM-DDTHH:mm:ss.SSSZZ";pt.suppressDeprecationWarnings=!0;vC.exports={current_date:()=>pt().utc().format("YYYY-MM-DD"),current_time:()=>pt().utc().format("HH:mm:ss.SSS"),extract:(e,t)=>{switch(t.toLowerCase()){case"year":return pt(e).utc().format("YYYY");case"month":return pt(e).utc().format("MM");case"day":return pt(e).utc().format("DD");case"hour":return pt(e).utc().format("HH");case"minute":return pt(e).utc().format("mm");case"second":return pt(e).utc().format("ss");case"millisecond":return pt(e).utc().format("SSS");default:break}},date:e=>pt(e).utc().format(tS),date_format:(e,t)=>pt(e).utc().format(t),date_add:(e,t,r)=>pt(e).utc().add(t,r).valueOf(),date_sub:(e,t,r)=>pt(e).utc().subtract(t,r).valueOf(),date_diff:(e,t,r)=>{let n=pt(e).utc(),s=pt(t).utc();return r?n.diff(s,r,!0):n.diff(s)},now:()=>pt().utc().valueOf(),get_server_time:()=>pt().format(tS),offset_utc:(e,t)=>pt(e).utc().utcOffset(t).format(tS)}});var FC=R((p_e,GC)=>{"use strict";var yJ=require("@turf/area"),NJ=require("@turf/length"),IJ=require("@turf/circle"),wJ=require("@turf/difference"),CJ=require("@turf/distance"),DJ=require("@turf/boolean-contains"),LJ=require("@turf/boolean-equal"),MJ=require("@turf/boolean-disjoint"),UJ=require("@turf/helpers"),HC=U(),Te=Q(),bs=K();GC.exports={geoArea:PJ,geoLength:vJ,geoCircle:BJ,geoDifference:HJ,geoDistance:xC,geoNear:xJ,geoContains:GJ,geoEqual:FJ,geoCrosses:qJ,geoConvert:kJ};function PJ(e){if(Te.isEmpty(e))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e));try{return yJ.default(e)}catch(t){return bs.trace(t,e),NaN}}a(PJ,"geoArea");function vJ(e,t){if(Te.isEmpty(e))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e));try{return NJ.default(e,{units:t||"kilometers"})}catch(r){return bs.trace(r,e),NaN}}a(vJ,"geoLength");function BJ(e,t,r){if(Te.isEmpty(e))return NaN;if(Te.isEmpty(t))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e));try{return IJ.default(e,t,{units:r||"kilometers"})}catch(n){return bs.trace(n,e,t),NaN}}a(BJ,"geoCircle");function HJ(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 wJ(e,t)}catch(r){return bs.trace(r,e,t),NaN}}a(HJ,"geoDifference");function xC(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 CJ.default(e,t,{units:r||"kilometers"})}catch(n){return bs.trace(n,e,t),NaN}}a(xC,"geoDistance");function xJ(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 xC(e,t,n)<=r}catch(s){return bs.trace(s,e,t),!1}}a(xJ,"geoNear");function GJ(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 DJ.default(e,t)}catch(r){return bs.trace(r,e,t),!1}}a(GJ,"geoContains");function FJ(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 LJ.default(e,t)}catch(r){return bs.trace(r,e,t),!1}}a(FJ,"geoEqual");function qJ(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!MJ.default(e,t)}catch(r){return bs.trace(r,e,t),!1}}a(qJ,"geoCrosses");function kJ(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(HC.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(HC.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Te.autoCastJSON(e)),UJ[t](e,r)}a(kJ,"geoConvert")});var sd=R((T_e,qC)=>{var eo=PC(),kr=BC(),rs=FC();qC.exports=e=>{e.aggr.mad=e.aggr.MAD=eo.mad,e.aggr.mean=e.aggr.MEAN=eo.mean,e.aggr.mode=e.aggr.MODE=eo.mode,e.aggr.prod=e.aggr.PROD=eo.prod,e.aggr.median=e.aggr.MEDIAN=eo.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=eo.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=eo.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=rs.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=rs.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=rs.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=rs.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=rs.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=rs.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=rs.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=rs.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=rs.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=rs.geoNear}});var YC=R((g_e,$C)=>{"use strict";var ru=require("lodash"),hr=require("alasql");hr.options.cache=!1;var VJ=sd(),kC=require("clone"),id=require("recursive-iterator"),le=K(),Ce=Q(),na=In(),$J=U(),{hdb_errors:YJ}=ne(),{getDatabases:VC}=(Ae(),ie(qe)),KJ="IS NULL",Un="There was a problem performing this search. Please check the logs and try again.";VJ(hr);var rS=class{static{a(this,"SQLSearch")}constructor(t,r){if(Ce.isEmpty(t))throw le.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(),Ce.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!Ce.isEmptyOrZeroLength(n))return le.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw le.error("Error thrown from checkEmptySQL in SQLSearch class method search."),le.error(n),new Error(Un)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw le.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),le.error(n),new Error(Un)}if(Object.keys(this.data).length===0)return le.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw le.error("Error thrown from processJoins in SQLSearch class method search."),le.error(n),new Error(Un)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw le.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),le.error(n),new Error(Un)}try{return t=await this._finalSQL(),t}catch(n){throw le.error("Error thrown from finalSQL in SQLSearch class method search."),le.error(n),new Error(Un)}}_getColumns(){let t=new id(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(kC(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=ru.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=VC()[r.databaseid][r.tableid].primaryKey,this.data[n].__merged_data={},this.data[n].__merged_attributes=[],this.data[n].__merged_attr_map={}})}_conditionsToFetchAttributeValues(){if(Ce.isEmpty(this.statement.where)){le.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new id(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!Ce.isEmpty(r)&&r.right)if(Ce.isNotEmptyAndHasValue(r.right.value)){let n=Ce.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new hr.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=Ce.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new hr.yy.LogicValue({value:i}):n instanceof hr.yy.StringValue&&Ce.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new hr.yy.NumValue({value:i}))});if(t){le.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new id(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(!Ce.isEmpty($J.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(Ce.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(Ce.isEmptyOrZeroLength(r.left.columnid)||Ce.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(Ce.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"=":!Ce.isEmpty(r.right.value)||!Ce.isEmpty(r.left.value)?n.add(Ce.isEmpty(r.right.value)?r.left.value:r.right.value):c=!0;break;case"IN":let u=Array.isArray(r.right)?r.right:r.left;for(let _=0;_<u.length;_++)if(u[_].value)n.add(u[_].value);else{c=!0;break}break;default:c=!0;break}this.exact_search_values[o].ignore=c,c?this.exact_search_values[o].values=new Set:this.exact_search_values[o].values=new Set([...this.exact_search_values[o].values,...n])}}}_setAliasesForColumns(){if(Ce.isEmptyOrZeroLength(this.all_table_attributes)&&Ce.isEmptyOrZeroLength(this.statement.from)&&Ce.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&&ru.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(Ce.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);Ce.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(Ce.isEmptyOrZeroLength(this.all_table_attributes)&&!Ce.isEmptyOrZeroLength(this.columns.columns))return t;if(Ce.isEmptyOrZeroLength(this.all_table_attributes)&&Ce.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await hr.promise(r)}catch(r){throw le.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),le.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(kC(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(Ce.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(KJ)>-1&&this.tables.forEach(s=>{let i={columnid:VC()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=ru.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]},u=!1,_=[s.table.databaseid,s.table.tableid,s.attribute].join("/");if(s.attribute===o&&(u=!0),!Ce.isEmpty(this.exact_search_values[_])&&!this.exact_search_values[_].ignore&&!Ce.isEmptyOrZeroLength(this.exact_search_values[_].values))if(u)try{c.hash_values=Array.from(this.exact_search_values[_].values);let l=await na.getDataByHash(c);for(let d of c.hash_values)l.get(d)&&!this.data[i].__merged_data[d]&&(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d))}catch(l){throw le.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),le.error(l),new Error(Un)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[_].values).map(async l=>{let d=Object.assign({},c);d.search_value=l;let f=await na.getDataByValue(d);for(let[E,h]of f)this.data[i].__merged_data[E]?this._updateMergedAttribute(i,E,s.attribute,h[s.attribute]):(this.data[i].__merged_data[E]=[...n[i]],this._updateMergedAttribute(i,E,s.attribute,h[s.attribute]),this._setMergedHashAttribute(i,E))}))}catch(l){throw le.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),le.error(l),new Error(Un)}else if(!Ce.isEmpty(this.comparator_search_values[_])&&!this.comparator_search_values[_].ignore&&!Ce.isEmptyOrZeroLength(this.comparator_search_values[_].comparators))try{let l=this.comparator_search_values[_].comparators;for(let d=0,f=l.length;d<f;d++){let E=l[d];c.search_attribute=E.attribute,c.search_value=E.search_value;let h=await na.getDataByValue(c,E.operation);if(u)for(let[S]of h)this.data[i].__merged_data[S]||(this.data[i].__merged_data[S]=[...n[i]],this._setMergedHashAttribute(i,S));else for(let[S,p]of h)this.data[i].__merged_data[S]?this._updateMergedAttribute(i,S,s.attribute,p[s.attribute]):(this.data[i].__merged_data[S]=[...n[i]],this._updateMergedAttribute(i,S,s.attribute,p[s.attribute]),this._setMergedHashAttribute(i,S))}}catch(l){throw le.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),le.error(l),new Error(Un)}else try{c.search_attribute=s.attribute,c.search_value="*";let l=await na.getDataByValue(c);if(u)for(let[d]of l)this.data[i].__merged_data[d]||(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d));else for(let[d,f]of l)this.data[i].__merged_data[d]?this._updateMergedAttribute(i,d,s.attribute,f[s.attribute]):(this.data[i].__merged_data[d]=[...n[i]],this._updateMergedAttribute(i,d,s.attribute,f[s.attribute]),this._setMergedHashAttribute(i,d))}catch(l){throw le.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),le.error(l),new Error(Un)}}}_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 hr.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 hr.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new hr.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 hr.yy.FuncValue:new hr.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(E=>{E.joinmode&&E.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(E.table);let h=E.joinmode+" JOIN ? AS "+(E.as?E.as:E.table.tableid);E.on&&(h+=" ON "+E.on.toString()),i.push(h),t.push(Object.values(this.data[`${E.table.databaseid_orig}_${E.table.as?E.table.as_orig:E.table.tableid_orig}`].__merged_data))});let o=[],c={};s.forEach(E=>{let h=this.data[`${E.databaseid_orig}_${E.as?E.as_orig:E.tableid_orig}`].__hash_name,S=E.as?E.as_orig:E.tableid_orig;o.push({key:`'${S}.${h}'`,schema:E.databaseid_orig,table:E.as?E.as_orig:E.tableid_orig,keys:new Set}),r.push(`${E.as?E.as:E.tableid}.\`${h}\` AS "${S}.${h}"`),c[E.as?E.as_orig:E.tableid_orig]=this.data[`${E.databaseid_orig}_${E.as?E.as_orig:E.tableid_orig}`].__merged_attributes});let u=this.statement.where?"WHERE "+this.statement.where:"";u=u.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(E=>{E.is_func?r.push(E.initial_select_column.toString()):E.initial_select_column.tableid?r.push(`${E.initial_select_column.tableid}.${E.initial_select_column.columnid} AS ${E.expression.columnid}`):r.push(`${E.initial_select_column.columnid} AS ${E.expression.columnid}`)}));let l="",d="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(l=this.statement.limit?"LIMIT "+this.statement.limit:"",d=this.statement.offset?"OFFSET "+this.statement.offset:"");let f=[];try{let E=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${u} ${_} ${l} ${d}`,h=this._convertColumnsToIndexes(E,s);f=await hr.promise(h,t),t=null}catch(E){throw le.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),le.error(E),new Error("There was a problem processing the data.")}if(f&&f.length>0){for(let E=0,h=f.length;E<h;E++){let S=f[E];o.forEach(p=>{S[p.key]!==null&&S[p.key]!==void 0&&p.keys.add(S[p.key])})}o.forEach(E=>{let h=Object.keys(this.data[`${E.schema}_${E.table}`].__merged_data),S=ru.difference(h,[...E.keys].map(p=>p.toString()));for(let p=0,T=S.length;p<T;p++){let A=S[p];delete this.data[`${E.schema}_${E.table}`].__merged_data[A]}})}return{existing_attributes:c,joined_length:f?f.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new id(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=ru.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 le.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),le.error(i),new Error(Un)}}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 l in i)o.push(i[l][0]);this.data[n].__merged_attributes.push(...s.columns);let c={schema:s.schema,table:s.table,hash_values:o,get_attributes:s.columns},u=await na.getDataByHash(c),_=s.columns.length;for(let l=0,d=o.length;l<d;l++){let f=o[l],E=u.get(f);for(let h=0;h<_;h++){let S=s.columns[h],p=E[S]===void 0?null:E[S];this.data[n].__merged_data[f].push(p)}}}}catch(r){throw le.error("Error thrown from getDataByHash function in SQLSearch class method getData."),le.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,u=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===u}).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();le.trace(`Final SQL: ${s}`),n=await hr.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),le.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw le.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),le.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 le.error(YJ.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),le.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 u=s[i],_=new RegExp(`${u}.\`${o}\``,"g"),l=`${u}.[${c}]`;n=n.replace(_,l)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let u=new RegExp(`\`${o}\``,"g"),_=`[${c}]`;n=n.replace(u,_)});return n}async _simpleSQLQuery(){let t=this.statement.columns.reduce((n,s)=>(s.as_orig&&s.as_orig!=s.columnid_orig?n[s.columnid_orig]=s.as_orig:n[s.columnid_orig]||(n[s.columnid_orig]=s.columnid_orig),n),{}),r=this.fetch_attributes.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]||(n[i]={}),n[i][t[s.attribute]]=null,n},{});for(let n of this.fetch_attributes){let s=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`,i={schema:n.table.databaseid,table:n.table.tableid,get_attributes:[n.attribute]};try{i.search_attribute=n.attribute,i.search_value="*";let o=await na.getDataByValue(i);for(let[c,u]of o)this.data[s].__merged_data[c]||(u[n.attribute]===void 0&&(u[n.attribute]=null),this.data[s].__merged_data[c]=Object.assign({},r[s])),this.data[s].__merged_data[c][t[n.attribute]]=u[n.attribute]??null}catch(o){throw le.error("There was an error when processing this SQL operation. Check your logs"),le.error(o),new Error(Un)}}return Object.values(Object.values(this.data)[0].__merged_data)}};$C.exports=rS});var Br=R((A_e,KC)=>{"use strict";var WJ=Rb();KC.exports={searchByConditions:zJ,searchByHash:JJ,searchByValue:XJ,search:jJ};var nS=In(),{transformReq:sS}=Q(),QJ=YC();async function zJ(e){return sS(e),nS.searchByConditions(e)}a(zJ,"searchByConditions");async function JJ(e){sS(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of nS.searchByHash(e))r&&t.push(r);return t}a(JJ,"searchByHash");async function XJ(e){sS(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of nS.searchByValue(e))t.push(r);return t}a(XJ,"searchByValue");function jJ(e,t){try{let r=new WJ(e);r.validate(),new QJ(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(jJ,"search")});var od=R((b_e,WC)=>{"use strict";var ZJ=In();WC.exports={writeTransaction:e4};function e4(e,t,r){return ZJ.writeTransaction(e,t,r)}a(e4,"writeTransaction")});var XC=R((I_e,JC)=>{"use strict";var t4=Br(),r4=ri(),QC=K(),n4=cn(),N_e=od(),s4=require("clone"),oS=require("alasql"),i4=sd(),zC=require("util"),o4=zC.promisify(r4.getTableSchema),a4=zC.promisify(t4.search),c4=U(),iS=Q();i4(oS);JC.exports={update:l4};var u4="There was a problem performing this update. Please check the logs and try again.";async function l4({statement:e,hdb_user:t}){let r=await o4(e.table.databaseid,e.table.tableid),n=_4(e.columns);iS.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=s4(s),c=iS.isEmpty(i)?"":` WHERE ${i.toString()}`,u=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,_=oS.parse(u).statements[0],l=await a4(_),d=d4(n,l);return f4(o,d,t)}a(l4,"update");function _4(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=oS.compile(`SELECT ${r.expression.toString()} AS [${c4.FUNC_VAL}] FROM ?`)}),t}catch(t){throw QC.error(t),new Error(u4)}}a(_4,"createUpdateRecord");function d4(e,t){return iS.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(d4,"buildUpdateRecords");async function f4(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await n4.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){QC.error(`Error delete new_attributes from update response: ${i}`)}return s}a(f4,"updateRecords")});var ZC=R((L_e,jC)=>{var E4=require("alasql"),h4=Br(),m4=K(),p4=In(),cS=require("util"),aS=Q(),S4=U(),T4=ri(),C_e=od(),D_e=cn(),g4="record",R4="successfully deleted",A4=cS.callbackify(N4),O4=cS.promisify(h4.search),b4=cS.promisify(T4.getTableSchema);jC.exports={convertDelete:A4};function y4(e){return`${e.deleted_hashes.length} ${g4}${e.deleted_hashes.length===1?"":"s"} ${R4}`}a(y4,"generateReturnMessage");async function N4({statement:e,hdb_user:t}){let r=await b4(e.table.databaseid,e.table.tableid);aS.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=aS.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=E4.parse(o).statements[0],u={operation:S4.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{u.records=await O4(c);let _=await p4.deleteRecords(u);return aS.isEmptyOrZeroLength(_.message)&&(_.message=y4(_)),delete _.txn_time,_}catch(_){throw m4.error(_),_.hdb_code?_.message:_}}a(N4,"convertDelete")});var sD=R((U_e,nD)=>{"use strict";var I4=ti(),{hdb_errors:eD}=ne(),{getDatabases:tD}=(Ae(),ie(qe));nD.exports={checkSchemaExists:rD,checkSchemaTableExists:w4,schema_describe:I4};async function rD(e){if(!tD()[e])return eD.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(rD,"checkSchemaExists");async function w4(e,t){let r=await rD(e);if(r)return r;if(!tD()[e][t])return eD.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(w4,"checkSchemaTableExists")});var ld=R((B_e,cD)=>{"use strict";var sa=h_(),ia=sD(),C4=K(),D4=require("uuid").v4,v_e=require("clone"),cd=Rs(),oa=U(),L4=require("util"),ui=In(),{handleHDBError:mr,hdb_errors:M4}=ne(),{HDB_ERROR_MSGS:ad,HTTP_STATUS_CODES:pr}=M4,{SchemaEventMsg:ud}=Dn(),iD=Nt(),{getDatabases:U4}=(Ae(),ie(qe)),{transformReq:aa}=Q();cD.exports={createSchema:P4,createSchemaStructure:oD,createTable:v4,createTableStructure:aD,createAttribute:F4,dropSchema:B4,dropTable:H4,dropAttribute:x4,getBackup:q4};async function P4(e){let t=await oD(e);return cd.signalSchemaChange(new ud(process.pid,e.operation,e.schema)),t}a(P4,"createSchema");async function oD(e){let t=sa.schema_object(e);if(t)throw mr(t,t.message,pr.BAD_REQUEST,void 0,void 0,!0);if(aa(e),!await ia.checkSchemaExists(e.schema))throw mr(new Error,ad.SCHEMA_EXISTS_ERR(e.schema),pr.BAD_REQUEST,oa.LOG_LEVELS.ERROR,ad.SCHEMA_EXISTS_ERR(e.schema),!0);return await ui.createSchema(e),`database '${e.schema}' successfully created`}a(oD,"createSchemaStructure");async function v4(e){return aa(e),e.hash_attribute=e.primary_key??e.hash_attribute,await aD(e)}a(v4,"createTable");async function aD(e){let t=sa.create_table_object(e);if(t)throw mr(t,t.message,pr.BAD_REQUEST,void 0,void 0,!0);if(sa.validateTableResidence(e.residence),!await ia.checkSchemaTableExists(e.schema,e.table))throw mr(new Error,ad.TABLE_EXISTS_ERR(e.schema,e.table),pr.BAD_REQUEST,oa.LOG_LEVELS.ERROR,ad.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:D4(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await ui.createTable(n,e);else throw mr(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",pr.BAD_REQUEST);else await ui.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}a(aD,"createTableStructure");async function B4(e){let t=!e.schema&&!e.database?new Error("database is required"):void 0,r=sa.schema_object(e),n=t??r;if(n)throw mr(n,n.message,pr.BAD_REQUEST,void 0,void 0,!0);aa(e);let s=await ia.checkSchemaExists(e.schema);if(s)throw mr(new Error,s,pr.NOT_FOUND,oa.LOG_LEVELS.ERROR,s,!0);let i=await ia.schema_describe.describeSchema({schema:e.schema}),o=Object.keys(global.hdb_schema[e.schema]);return await ui.dropSchema(e),cd.signalSchemaChange(new ud(process.pid,e.operation,e.schema)),await iD.purgeSchemaTableStreams(e.schema,o),`successfully deleted '${e.schema}'`}a(B4,"dropSchema");async function H4(e){let t=sa.table_object(e);if(t)throw mr(t,t.message,pr.BAD_REQUEST,void 0,void 0,!0);aa(e);let r=await ia.checkSchemaTableExists(e.schema,e.table);if(r)throw mr(new Error,r,pr.NOT_FOUND,oa.LOG_LEVELS.ERROR,r,!0);return await ui.dropTable(e),await iD.purgeTableStream(e.schema,e.table),`successfully deleted table '${e.schema}.${e.table}'`}a(H4,"dropTable");async function x4(e){let t=sa.attribute_object(e);if(t)throw mr(t,t.message,pr.BAD_REQUEST,void 0,void 0,!0);aa(e);let r=await ia.checkSchemaTableExists(e.schema,e.table);if(r)throw mr(new Error,r,pr.NOT_FOUND,oa.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw mr(new Error,"You cannot drop a hash attribute",pr.BAD_REQUEST,void 0,void 0,!0);if(oa.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw mr(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,pr.BAD_REQUEST,void 0,void 0,!0);try{return await ui.dropAttribute(e),G4(e),cd.signalSchemaChange(new ud(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw C4.error(`Got an error deleting attribute ${L4.inspect(e)}.`),n}}a(x4,"dropAttribute");function G4(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(G4,"dropAttributeFromGlobal");async function F4(e){aa(e);let t=U4()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw mr(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,pr.BAD_REQUEST,void 0,void 0,!0);return await ui.createAttribute(e),cd.signalSchemaChange(new ud(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}a(F4,"createAttribute");function q4(e){return ui.getBackup(e)}a(q4,"getBackup")});var lD=R((x_e,uD)=>{"use strict";var{OPERATIONS_ENUM:k4}=U(),uS=class{static{a(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=k4.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};uD.exports=uS});var lS=R((q_e,hD)=>{"use strict";var V4=In(),F_e=lD(),_d=Q(),dd=U(),$4=te(),{handleHDBError:_D,hdb_errors:Y4}=ne(),{HDB_ERROR_MSGS:dD,HTTP_STATUS_CODES:fD}=Y4,K4=Object.values(dd.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),ED="To use this operation audit log must be enabled in harperdb-config.yaml";hD.exports=W4;async function W4(e){if(_d.isEmpty(e.schema))throw new Error(dD.SCHEMA_REQUIRED_ERR);if(_d.isEmpty(e.table))throw new Error(dD.TABLE_REQUIRED_ERR);if(!$4.get(dd.CONFIG_PARAMS.LOGGING_AUDITLOG))throw _D(new Error,ED,fD.BAD_REQUEST,dd.LOG_LEVELS.ERROR,ED,!0);let t=_d.checkSchemaTableExist(e.schema,e.table);if(t)throw _D(new Error,t,fD.NOT_FOUND,dd.LOG_LEVELS.ERROR,t,!0);if(!_d.isEmpty(e.search_type)&&K4.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await V4.readAuditLog(e)}a(W4,"readAuditLog")});var pD=R((V_e,mD)=>{"use strict";var{OPERATIONS_ENUM:Q4}=U(),_S=class{static{a(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=Q4.GET_BACKUP,this.schema=t,this.table=r}};mD.exports=_S});var gD=R((W_e,TD)=>{"use strict";var z4=In(),Y_e=pD(),dS=Q(),J4=U(),K_e=te(),{handleHDBError:X4,hdb_errors:j4}=ne(),{HDB_ERROR_MSGS:SD,HTTP_STATUS_CODES:Z4}=j4;TD.exports=e3;async function e3(e){if(dS.isEmpty(e.schema))throw new Error(SD.SCHEMA_REQUIRED_ERR);if(dS.isEmpty(e.table))throw new Error(SD.TABLE_REQUIRED_ERR);let t=dS.checkSchemaTableExist(e.schema,e.table);if(t)throw X4(new Error,t,Z4.NOT_FOUND,J4.LOG_LEVELS.ERROR,t,!0);return await z4.getBackup(read_audit_log_object)}a(e3,"getBackup")});var ND=R((z_e,yD)=>{var li=require("validate.js"),AD=rt(),ca=U(),{handleHDBError:t3,hdb_errors:r3}=ne(),{HDB_ERROR_MSGS:_t,HTTP_STATUS_CODES:n3}=r3,fS=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),s3={STRUCTURE_USER:"structure_user"},RD=Object.values(ca.ROLE_TYPES_ENUM),i3="attribute_permissions",o3="attribute_name",{PERMS_CRUD_ENUM:ua}=ca,a3=[i3,...Object.values(ua)],OD=[ua.READ,ua.INSERT,ua.UPDATE],c3=[o3,...OD];function u3(e){let t=fS();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,bD(e,t)}a(u3,"addRoleValidation");function l3(e){let t=fS();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,bD(e,t)}a(l3,"alterRoleValidation");function _3(e){let t=fS();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,AD.validateObject(e,t)}a(_3,"dropRoleValidation");var d3=["operation","role","id","permission","hdb_user","hdb_auth_header"];function bD(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)d3.includes(n[o])||s.push(n[o]);s.length>0&&St(_t.INVALID_ROLE_JSON_KEYS(s),r);let i=AD.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{St(o,r)}),e.permission){let o=f3(e);o&&St(o,r),RD.forEach(c=>{e.permission[c]&&!li.isBoolean(e.permission[c])&&St(_t.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(RD.indexOf(o)<0){if(o===s3.STRUCTURE_USER){let u=e.permission[o];if(typeof u=="boolean")continue;if(Array.isArray(u)){for(let _=0,l=u.length;_<l;_++){let d=u[_];global.hdb_schema[d]||St(_t.SCHEMA_NOT_FOUND(d),r)}continue}St(_t.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){St(_t.SCHEMA_NOT_FOUND(o),r);continue}if(c.tables)for(let u in c.tables){let _=c.tables[u];if(!u||!global.hdb_schema[o][u]){St(_t.TABLE_NOT_FOUND(o,u),r);continue}if(Object.keys(_).forEach(l=>{a3.includes(l)||St(_t.INVALID_PERM_KEY(l),r,o,u)}),Object.values(ua).forEach(l=>{li.isDefined(_[l])?li.isBoolean(_[l])||St(_t.TABLE_PERM_NOT_BOOLEAN(l),r,o,u):St(_t.TABLE_PERM_MISSING(l),r,o,u)}),li.isDefined(_.attribute_permissions)){if(!li.isArray(_.attribute_permissions)){St(_t.ATTR_PERMS_NOT_ARRAY,r,o,u);continue}}else{St(_t.ATTR_PERMS_ARRAY_MISSING,r,o,u);continue}if(_.attribute_permissions){let l=global.hdb_schema[o][u].attributes.map(({attribute:f})=>f),d={read:!1,insert:!1,update:!1};for(let f in _.attribute_permissions){let E=_.attribute_permissions[f];if(Object.keys(E).forEach(S=>{!c3.includes(S)&&S!==ua.DELETE&&St(_t.INVALID_ATTR_PERM_KEY(S),r,o,u)}),!li.isDefined(E.attribute_name)){St(_t.ATTR_PERM_MISSING_NAME,r,o,u);continue}let h=E.attribute_name;if(!l.includes(h)){St(_t.INVALID_ATTRIBUTE_IN_PERMS(h),r,o,u);continue}OD.forEach(S=>{li.isDefined(E[S])?li.isBoolean(E[S])||St(_t.ATTR_PERM_NOT_BOOLEAN(S,h),r,o,u):St(_t.ATTR_PERM_MISSING(S,h),r,o,u)}),!d.read&&E.read===!0&&(d.read=!0),!d.insert&&E.insert===!0&&(d.insert=!0),!d.update&&E.update===!0&&(d.update=!0)}if(_.read===!1&&d.read===!0||_.insert===!1&&d.insert===!0||_.update===!1&&d.update===!0){let f=`${o}.${u}`;St(_t.MISMATCHED_TABLE_ATTR_PERMS(f),r,o,u)}}}}return E3(r)}a(bD,"customValidate");yD.exports={addRoleValidation:u3,alterRoleValidation:l3,dropRoleValidation:_3};function f3(e){let{operation:t,permission:r}=e;if(t===ca.OPERATIONS_ENUM.ADD_ROLE||t===ca.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 _t.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?ca.ROLE_TYPES_ENUM.SUPER_USER:ca.ROLE_TYPES_ENUM.CLUSTER_USER;return _t.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(f3,"validateNoSUPerms");function E3(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:_t.ROLE_PERMS_ERROR,...e};return t3(new Error,n,n3.BAD_REQUEST)}else return null}a(E3,"generateRolePermResponse");function St(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(St,"addPermError")});var TS=R((X_e,DD)=>{"use strict";var ID=cn(),wD=Br(),h3=Vi(),hS=ND(),mS=Rs(),m3=require("uuid").v4,p3=require("util"),fd=U(),S3=Q(),pS=wD.searchByValue,T3=wD.searchByHash,g3=p3.promisify(h3.delete),R3=Zn(),A3=ta(),{hdb_errors:O3,handleHDBError:to}=ne(),{HDB_ERROR_MSGS:CD,HTTP_STATUS_CODES:nu}=O3,{UserEventMsg:SS}=Dn();DD.exports={addRole:b3,alterRole:y3,dropRole:N3,listRoles:I3};function ES(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(ES,"scrubRoleDetails");async function b3(e){let t=hS.addRoleValidation(e);if(t)throw t;e=ES(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 pS(r)||[])}catch(i){throw to(i)}if(n&&n.length>0)throw to(new Error,CD.ROLE_ALREADY_EXISTS(e.role),nu.CONFLICT,void 0,void 0,!0);e.id||(e.id=m3());let s={operation:"insert",schema:"system",table:"hdb_role",hash_attribute:"id",records:[e]};return await ID.insert(s),mS.signalUserChange(new SS(process.pid)),e=ES(e),e}a(b3,"addRole");async function y3(e){let t=hS.alterRoleValidation(e);if(t)throw t;e=ES(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await ID.update(r)}catch(s){throw to(s)}if(n&&n?.message==="updated 0 of 1 records")throw to(new Error,"Invalid role id",nu.BAD_REQUEST,void 0,void 0,!0);return await mS.signalUserChange(new SS(process.pid)),e}a(y3,"alterRole");async function N3(e){let t=hS.dropRoleValidation(e);if(t)throw to(new Error,t,nu.BAD_REQUEST,void 0,void 0,!0);let r=new A3(fd.SYSTEM_SCHEMA_NAME,fd.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await T3(r));if(n.length===0)throw to(new Error,CD.ROLE_NOT_FOUND,nu.NOT_FOUND,void 0,void 0,!0);let s=new R3(fd.SYSTEM_SCHEMA_NAME,fd.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await pS(s)),o=!1;if(S3.isEmptyOrZeroLength(i)===!1){for(let u=0;u<i.length;u++)if(i[u].active===!0){o=!0;break}}if(o===!0)throw to(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,nu.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await g3(c),mS.signalUserChange(new SS(process.pid)),`${n[0].role} successfully deleted`}a(N3,"dropRole");async function I3(){return pS({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(I3,"listRoles")});var PD=R((Z_e,UD)=>{"use strict";var w3=te(),_i=require("joi"),C3=rt(),LD=require("moment"),D3=require("fs-extra"),gS=require("path"),L3=require("lodash"),su=U(),{LOG_LEVELS:ro}=U(),M3="YYYY-MM-DD hh:mm:ss",U3=gS.resolve(__dirname,"../logs");UD.exports=function(e){return C3.validateBySchema(e,P3)};var P3=_i.object({from:_i.custom(MD),until:_i.custom(MD),level:_i.valid(ro.NOTIFY,ro.FATAL,ro.ERROR,ro.WARN,ro.INFO,ro.DEBUG,ro.TRACE),order:_i.valid("asc","desc"),limit:_i.number().min(1),start:_i.number().min(0),log_name:_i.custom(v3)});function MD(e,t){if(LD(e,LD.ISO_8601).format(M3)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(MD,"validateDatetime");function v3(e,t){if(L3.invert(su.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=w3.get(su.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?su.LOG_NAMES.HDB:e,i=s===su.LOG_NAMES.INSTALL?gS.join(U3,su.LOG_NAMES.INSTALL):gS.join(n,s);return D3.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(v3,"validateReadLogPath")});var AS=R((tde,BD)=>{"use strict";var Ed=U(),B3=K(),H3=te(),x3=PD(),RS=require("path"),vD=require("fs-extra"),{once:G3}=require("events"),{handleHDBError:F3,hdb_errors:q3}=ne(),{PACKAGE_ROOT:k3}=U(),V3=RS.join(k3,"logs"),$3=1e3,Y3=200;BD.exports=K3;async function K3(e){let t=x3(e);if(t)throw F3(t,t.message,q3.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=H3.get(Ed.HDB_SETTINGS_NAMES.LOG_PATH_KEY),n=e.log_name===void 0?Ed.LOG_NAMES.HDB:e.log_name,s=n===Ed.LOG_NAMES.INSTALL?RS.join(V3,Ed.LOG_NAMES.INSTALL):RS.join(r,n),i=e.level!==void 0,o=i?e.level:void 0,c=e.from!==void 0,u=c?new Date(e.from):void 0,_=e.until!==void 0,l=_?new Date(e.until):void 0,d=e.limit===void 0?$3:e.limit,f=e.order===void 0?void 0:e.order,E=e.start===void 0?0:e.start,h=E+d,S=0;f==="desc"&&!u&&!l&&(S=Math.max(vD.statSync(s).size-(h+5)*Y3,0));let p=vD.createReadStream(s,{start:S});p.on("error",P=>{B3.error(P)});let T=0,A=[],g="",L;p.on("data",P=>{let k=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;P=g+P;let H=0,X;for(;(X=k.exec(P))&&!p.destroyed;){L&&(L.message=P.slice(H,X.index),v(L));let[z,J,me]=X,ce=me.split("] ["),de=ce[0],De=ce[1];ce.splice(0,2),L={timestamp:J,thread:de,level:De,tags:ce,message:""},H=X.index+z.length}g=P.slice(H)}),p.on("end",P=>{p.destroyed||L&&(L.message=g.trim(),v(L))}),p.resume();function v(P){let k,H,X;switch(!0){case(i&&c&&_):k=new Date(P.timestamp),H=new Date(u),X=new Date(l),P.level===o&&k>=H&&k<=X&&T<E?T++:P.level===o&&k>=H&&k<=X&&(di(P,f,A),T++,T===h&&p.destroy());break;case(i&&c):k=new Date(P.timestamp),H=new Date(u),P.level===o&&k>=H&&T<E?T++:P.level===o&&k>=H&&(di(P,f,A),T++,T===h&&p.destroy());break;case(i&&_):k=new Date(P.timestamp),X=new Date(l),P.level===o&&k<=X&&T<E?T++:P.level===o&&k<=X&&(di(P,f,A),T++,T===h&&p.destroy());break;case(c&&_):k=new Date(P.timestamp),H=new Date(u),X=new Date(l),k>=H&&k<=X&&T<E?T++:k>=H&&k<=X&&(di(P,f,A),T++,T===h&&p.destroy());break;case i:P.level===o&&T<E?T++:P.level===o&&(di(P,f,A),T++,T===h&&p.destroy());break;case c:k=new Date(P.timestamp),H=new Date(u),k>=H&&T<E?T++:k>=H&&T>=E&&(di(P,f,A),T++,T===h&&p.destroy());break;case _:k=new Date(P.timestamp),X=new Date(l),k<=X&&T<E?T++:k<=X&&T>=E&&(di(P,f,A),T++,T===h&&p.destroy());break;default:T<E?T++:(di(P,f,A),T++,T===h&&p.destroy())}}return a(v,"onLogMessage"),await G3(p,"close"),A}a(K3,"readLog");function di(e,t,r){t==="desc"?W3(e,r):t==="asc"?Q3(e,r):r.push(e)}a(di,"pushLineToResult");function W3(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(W3,"insertDescending");function Q3(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(Q3,"insertAscending")});var hd=R((ode,FD)=>{"use strict";var OS=require("joi"),{string:iu,boolean:HD,date:z3}=OS.types(),J3=rt(),{validateSchemaExists:nde,validateTableExists:sde,validateSchemaName:ide}=Qn(),X3=U(),j3=nt(),xD=te();xD.initSync();var Z3=iu.invalid(xD.get(X3.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(j3.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(),GD={operation:iu.valid("add_node","update_node","set_node_replication"),node_name:Z3,subscriptions:OS.array().items({table:iu.optional(),schema:iu.optional(),database:iu.optional(),subscribe:HD.required(),publish:HD.required().custom(tX),start_time:z3.iso()}).min(1).required()};function eX(e){return J3.validateBySchema(e,OS.object(GD))}a(eX,"addUpdateNodeValidator");function tX(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(tX,"checkForFalsy");FD.exports={addUpdateNodeValidator:eX,validation_schema:GD}});var kD=R((cde,qD)=>{var rX=rt(),nX={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};qD.exports=function(e){return rX.validateObject(e,nX)}});var yS=R((ude,VD)=>{"use strict";var sX=U().OPERATIONS_ENUM,bS=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}};VD.exports=bS});var YD=R((_de,$D)=>{"use strict";var iX={OPERATION:"operation",REFRESH:"refresh"},NS=class{static{a(this,"JWTTokens")}constructor(t,r){this.operation_token=t,this.refresh_token=r}},IS=class{static{a(this,"JWTRSAKeys")}constructor(t,r,n){this.public_key=t,this.private_key=r,this.passphrase=n}};$D.exports={JWTTokens:NS,TOKEN_TYPE_ENUM:iX,JWTRSAKeys:IS}});var cu=R((fde,zD)=>{"use strict";var au=require("jsonwebtoken"),wS=require("fs-extra"),CS=Q(),ln=U(),{handleHDBError:Sr,hdb_errors:oX}=ne(),{HTTP_STATUS_CODES:Tr,AUTHENTICATION_ERROR_MSGS:gr}=oX,ou=K(),KD=L_(),MS=un(),aX=cn().update,cX=yS(),uX=Rs(),{UserEventMsg:lX}=Dn(),fi=te();fi.initSync();var DS=require("path"),{JWTTokens:_X,JWTRSAKeys:dX,TOKEN_TYPE_ENUM:md}=YD(),fX=fi.get(ln.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY)?fi.get(ln.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY):"1d",EX=fi.get(ln.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY)?fi.get(ln.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY):"30d",pd="RS256",LS;zD.exports={createTokens:hX,validateOperationToken:pX,refreshOperationToken:mX,validateRefreshToken:QD};async function hX(e){if(CS.isEmpty(e)||typeof e!="object")throw Sr(new Error,gr.INVALID_AUTH_OBJECT,Tr.BAD_REQUEST,void 0,void 0,!0);if(CS.isEmpty(e.username))throw Sr(new Error,gr.USERNAME_REQUIRED,Tr.BAD_REQUEST,void 0,void 0,!0);if(CS.isEmpty(e.password))throw Sr(new Error,gr.PASSWORD_REQUIRED,Tr.BAD_REQUEST,void 0,void 0,!0);let t;try{if(t=await MS.findAndValidateUser(e.username,e.password),!t)throw Sr(new Error,gr.INVALID_CREDENTIALS,Tr.UNAUTHORIZED,void 0,void 0,!0)}catch(f){throw ou.error(f),Sr(new Error,gr.INVALID_CREDENTIALS,Tr.UNAUTHORIZED,void 0,void 0,!0)}let r=await Sd(),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 WD(i,r.private_key,r.passphrase),c=await au.sign(i,{key:r.private_key,passphrase:r.passphrase},{expiresIn:EX,algorithm:pd,subject:md.REFRESH}),u=KD.hash(c),_=new cX(ln.SYSTEM_SCHEMA_NAME,ln.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,[{username:e.username,refresh_token:u}]),l,d;try{l=await aX(_)}catch(f){ou.error(f),d=f}if(d!==void 0||l.skipped_hashes.length>0)throw Sr(new Error,gr.REFRESH_TOKEN_SAVE_FAILED,Tr.INTERNAL_SERVER_ERROR);return uX.signalUserChange(new lX(process.pid)),new _X(o,c)}a(hX,"createTokens");async function WD(e,t,r){return await au.sign(e,{key:t,passphrase:r},{expiresIn:fX,algorithm:pd,subject:md.OPERATION})}a(WD,"signOperationToken");async function Sd(){if(LS===void 0)try{let e=DS.join(fi.getHdbBasePath(),ln.LICENSE_KEY_DIR_NAME,ln.JWT_ENUM.JWT_PASSPHRASE_NAME),t=DS.join(fi.getHdbBasePath(),ln.LICENSE_KEY_DIR_NAME,ln.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r=DS.join(fi.getHdbBasePath(),ln.LICENSE_KEY_DIR_NAME,ln.JWT_ENUM.JWT_PUBLIC_KEY_NAME),n=(await wS.readFile(e)).toString(),s=(await wS.readFile(t)).toString(),i=(await wS.readFile(r)).toString();LS=new dX(i,s,n)}catch(e){throw ou.error(e),Sr(new Error,gr.NO_ENCRYPTION_KEYS,Tr.INTERNAL_SERVER_ERROR)}return LS}a(Sd,"getJWTRSAKeys");async function mX(e){if(!e)throw Sr(new Error,gr.INVALID_BODY,Tr.BAD_REQUEST,void 0,void 0,!0);if(!e.refresh_token)throw Sr(new Error,gr.REFRESH_TOKEN_REQUIRED,Tr.BAD_REQUEST,void 0,void 0,!0);await QD(e.refresh_token);let t=await Sd(),r=await au.decode(e.refresh_token);return{operation_token:await WD({username:r.username,super_user:r.super_user,cluster_user:r.cluster_user},t.private_key,t.passphrase)}}a(mX,"refreshOperationToken");async function pX(e){try{let t=await Sd(),r=await au.verify(e,t.public_key,{algorithms:pd,subject:md.OPERATION});return await MS.findAndValidateUser(r.username,void 0,!1)}catch(t){throw ou.warn(t),t.name&&t.name==="TokenExpiredError"?Sr(new Error,gr.TOKEN_EXPIRED,Tr.FORBIDDEN):Sr(new Error,gr.INVALID_TOKEN,Tr.UNAUTHORIZED)}}a(pX,"validateOperationToken");async function QD(e){let t;try{let r=await Sd(),n=await au.verify(e,r.public_key,{algorithms:pd,subject:md.REFRESH});t=await MS.findAndValidateUser(n.username,void 0,!1)}catch(r){throw ou.warn(r),r.name&&r.name==="TokenExpiredError"?Sr(new Error,gr.TOKEN_EXPIRED,Tr.FORBIDDEN):Sr(new Error,gr.INVALID_TOKEN,Tr.UNAUTHORIZED)}if(!KD.validate(t.refresh_token,e))throw Sr(new Error,gr.INVALID_TOKEN,Tr.UNAUTHORIZED);return t}a(QD,"validateRefreshToken")});var US=R((mde,jD)=>{"use strict";var SX=kD(),la=require("passport"),TX=require("passport-local").Strategy,gX=require("passport-http").BasicStrategy,RX=require("util"),AX=un(),XD=RX.callbackify(AX.findAndValidateUser),hde=Lr(),OX=U(),JD=cu();la.use(new TX(function(e,t,r){XD(e,t,r)}));la.use(new gX(function(e,t,r){XD(e,t,r)}));la.serializeUser(function(e,t){t(null,e)});la.deserializeUser(function(e,t){t(null,e)});function bX(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":la.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===OX.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?JD.validateRefreshToken(s).then(o=>{e.body.refresh_token=s,r(null,o)}).catch(o=>{r(o)}):JD.validateOperationToken(s).then(o=>{r(null,o)}).catch(o=>{r(o)});break;default:la.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(bX,"authorize");function yX(e,t){let r=SX(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(yX,"checkPermissions");jD.exports={authorize:bX,checkPermissions:yX}});var _a=R((Sde,ZD)=>{"use strict";var PS=class{static{a(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},vS=class{static{a(this,"NodeSubscription")}constructor(t,r,n,s){this.schema=t,this.table=r,this.publish=n,this.subscribe=s}};ZD.exports={Node:PS,NodeSubscription:vS}});var tL=R((gde,eL)=>{"use strict";var NX=U().OPERATIONS_ENUM,BS=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=NX.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};eL.exports=BS});var uu=R((Ade,rL)=>{"use strict";var HS=class{static{a(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},xS=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)}};rL.exports={RemotePayloadObject:HS,RemotePayloadSubscription:xS}});var sL=R((bde,nL)=>{"use strict";var GS=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}};nL.exports=GS});var aL=R((Cde,oL)=>{"use strict";var IX=sL(),Nde=at(),iL=Ye(),wX=K(),{getSchemaPath:Ide,getTransactionAuditStorePath:wde}=Qe(),{getDatabases:CX}=(Ae(),ie(qe));oL.exports=DX;async function DX(e){let t=new IX;try{let r=CX()[e.schema]?.[e.name],n=r.primaryStore.getStats(),s=r.auditStore?.getStats(),i=await iL.environmentDataSize(schema_path,e.name),o=await iL.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){wX.warn(`unable to stat table dbi due to ${r}`)}return t}a(DX,"lmdbGetTableSize")});var uL=R((Lde,cL)=>{"use strict";var FS=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}};cL.exports=FS});var da=R((Bde,EL)=>{"use strict";var LX=require("fs-extra"),MX=require("path"),Zt=require("systeminformation"),Ei=K(),lL=Nt(),Ude=nt(),gd=U(),UX=aL(),PX=ti(),{getThreadInfo:_L}=ct(),JS=te();JS.initSync();var vX=uL(),{openEnvironment:Pde}=Ye(),{getSchemaPath:vde}=Qe(),{database:BX,databases:dL}=(Ae(),ie(qe)),Td;EL.exports={getHDBProcessInfo:$S,getNetworkInfo:KS,getDiskInfo:YS,getMemoryInfo:VS,getCPUInfo:kS,getTimeInfo:qS,getSystemInformation:WS,systemInformation:HX,getTableSize:QS,getMetrics:zS};function qS(){return Zt.time()}a(qS,"getTimeInfo");async function kS(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:o,governor:c,socket:u,cache:_,...l}=await Zt.cpu();l.cpu_speed=await Zt.cpuCurrentSpeed();let{raw_currentload:d,raw_currentload_idle:f,raw_currentload_irq:E,raw_currentload_nice:h,raw_currentload_system:S,raw_currentload_user:p,cpus:T,...A}=await Zt.currentLoad();return A.cpus=[],T.forEach(g=>{let{raw_load:L,raw_load_idle:v,raw_load_irq:P,raw_load_nice:k,raw_load_system:H,raw_load_user:X,...z}=g;A.cpus.push(z)}),l.current_load=A,l}catch(e){return Ei.error(`error in getCPUInfo: ${e}`),{}}}a(kS,"getCPUInfo");async function VS(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await Zt.mem();return Object.assign(s,process.memoryUsage())}catch(e){return Ei.error(`error in getMemoryInfo: ${e}`),{}}}a(VS,"getMemoryInfo");async function $S(){let e={core:[],clustering:[]};try{let t=await Zt.processes(),r;try{r=Number.parseInt(await LX.readFile(MX.join(JS.get(gd.CONFIG_PARAMS.ROOTPATH),gd.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===gd.NODE_ERROR_CODES.ENOENT)Ei.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 Ei.error(`error in getHDBProcessInfo: ${t}`),e}}a($S,"getHDBProcessInfo");async function YS(){let e={};try{let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await Zt.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:u,..._}=await Zt.fsStats();return e.read_write=_,e.size=await Zt.fsSize(),e}catch(t){return Ei.error(`error in getDiskInfo: ${t}`),e}}a(YS,"getDiskInfo");async function KS(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return e.default_interface=await Zt.networkInterfaceDefault(),e.latency=await Zt.inetChecksite("google.com"),(await Zt.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:o,dhcp:c,dnsSuffix:u,ieee8021xAuth:_,ieee8021xState:l,carrier_changes:d,...f}=n;e.interfaces.push(f)}),(await Zt.networkStats()).forEach(n=>{let{rx_sec:s,tx_sec:i,ms:o,...c}=n;e.stats.push(c)}),e}catch(t){return Ei.error(`error in getNetworkInfo: ${t}`),e}}a(KS,"getNetworkInfo");async function WS(){if(Td!==void 0)return Td;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:o,...c}=await Zt.osInfo();e=c;let u=await Zt.versions("node, npm");return e.node_version=u.node,e.npm_version=u.npm,Td=e,Td}catch(t){return Ei.error(`error in getSystemInformation: ${t}`),e}}a(WS,"getSystemInformation");async function QS(){let e=[],t=await PX.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await UX(n));return e}a(QS,"getTableSize");async function zS(){let e={};for(let t in dL){let r=e[t]={};for(let n in dL[t])try{let s=BX({database:t,table:n}),i=s.getStats();i.readers=s.readerList().split(/\n\s+/).slice(1).map(o=>{let[c,u,_]=o.trim().split(" ");return{pid:c,thread:u,txnid:_}}),r[n]=i}catch(s){Ei.notify(`Error getting stats for table ${n}: ${s}`)}}return e}a(zS,"getMetrics");async function fL(){if(JS.get(gd.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{jsm:e}=await lL.getNATSReferences(),t=await lL.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(fL,"getNatsStreamInfo");async function HX(e){let t=new vX;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await WS(),t.time=qS(),t.cpu=await kS(),t.memory=await VS(),t.disk=await YS(),t.network=await KS(),t.harperdb_processes=await $S(),t.table_size=await QS(),t.metrics=await zS(),t.threads=await _L(),t.replication=await fL(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await WS();break;case"time":t.time=qS();break;case"cpu":t.cpu=await kS();break;case"memory":t.memory=await VS();break;case"disk":t.disk=await YS();break;case"network":t.network=await KS();break;case"harperdb_processes":t.harperdb_processes=await $S();break;case"table_size":t.table_size=await QS();break;case"database_metrics":case"metrics":t.metrics=await zS();break;case"threads":t.threads=await _L();break;case"replication":t.replication=await fL();break;default:break}return t}a(HX,"systemInformation")});var lu=R((xde,xX)=>{xX.exports={name:"harperdb",version:"4.3.14",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","cloud","enterprise","Fastify","NATS"],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.535.0","@aws-sdk/lib-storage":"3.535.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.0.11",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.10.1",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.1",papaparse:"5.4.1",passport:"0.6.0","passport-http":"0.3.0","passport-local":"1.0.0",pino:"8.16.0",pm2:"5.3.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.16.0",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 Ad=R((Gde,hL)=>{"use strict";hL.exports={version:GX,printVersion:FX};var Rd=lu();function GX(){if(Rd)return Rd.version}a(GX,"version");function FX(){Rd&&console.log(`HarperDB Version ${Rd.version}`)}a(FX,"printVersion")});var ys=R((Vde,TL)=>{"use strict";var qX=cn(),XS=Q(),kX=require("util"),no=U(),mL=te();mL.initSync();var VX=US(),pL=Br(),{Node:qde,NodeSubscription:kde}=_a(),$X=ta(),YX=tL(),{RemotePayloadObject:KX,RemotePayloadSubscription:WX}=uu(),{handleHDBError:QX,hdb_errors:zX}=ne(),{HTTP_STATUS_CODES:JX,HDB_ERROR_MSGS:XX}=zX,jX=Zn(),ZX=da(),ej=Ad(),{getDatabases:tj}=(Ae(),ie(qe)),rj=kX.promisify(VX.authorize),nj=pL.searchByHash,sj=pL.searchByValue;TL.exports={authHeaderToUser:ij,isEmpty:oj,getNodeRecord:aj,upsertNodeRecord:cj,buildNodePayloads:uj,checkClusteringEnabled:lj,getAllNodeRecords:_j,getSystemInfo:dj,reverseSubscription:SL};async function ij(e){let t={headers:{authorization:e.hdb_auth_header}};return e.hdb_user=await rj(t,null),e}a(ij,"authHeaderToUser");function oj(e){return e==null}a(oj,"isEmpty");async function aj(e){let t=new $X(no.SYSTEM_SCHEMA_NAME,no.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return nj(t)}a(aj,"getNodeRecord");async function cj(e){let t=new YX(no.SYSTEM_SCHEMA_NAME,no.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return qX.upsert(t)}a(cj,"upsertNodeRecord");function SL(e){if(XS.isEmpty(e.subscribe)||XS.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(SL,"reverseSubscription");function uj(e,t,r,n){let s=[];for(let i=0,o=e.length;i<o;i++){let c=e[i],{schema:u,table:_}=c,l=XS.getTableHashAttribute(u,_),{subscribe:d,publish:f}=SL(c),E=tj()[u]?.[_],h=new WX(u,_,l,f,d,c.start_time,E.schemaDefined?E.attributes:void 0);s.push(h)}return new KX(r,t,s,n)}a(uj,"buildNodePayloads");function lj(){if(!mL.get(no.CONFIG_PARAMS.CLUSTERING_ENABLED))throw QX(new Error,XX.CLUSTERING_NOT_ENABLED,JX.BAD_REQUEST,void 0,void 0,!0)}a(lj,"checkClusteringEnabled");async function _j(){let e=new jX(no.SYSTEM_SCHEMA_NAME,no.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await sj(e))}a(_j,"getAllNodeRecords");async function dj(){let e=await ZX.getSystemInformation();return{hdb_version:ej.version(),node_version:e.node_version,platform:e.platform}}a(dj,"getSystemInfo")});var jS=R((Yde,IL)=>{"use strict";var Od=Nt(),gL=Q(),RL=nt(),AL=U(),bd=K(),OL=ld(),fj=Lp(),{RemotePayloadObject:Ej}=uu(),{handleHDBError:bL,hdb_errors:hj}=ne(),{HTTP_STATUS_CODES:yL}=hj,{NodeSubscription:NL}=_a();IL.exports=mj;async function mj(e,t){let r;try{r=await Od.request(`${t}.${RL.REQUEST_SUFFIX}`,new Ej(AL.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),bd.trace("Response from remote describe all request:",r)}catch(o){bd.error(`addNode received error from describe all request to remote node: ${o}`);let c=Od.requestErrorHandler(o,"add_node",t);throw bL(new Error,c,yL.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===RL.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let o=`Error returned from remote node ${t}: ${r.message}`;throw bL(new Error,o,yL.INTERNAL_SERVER_ERROR,"error",o)}let n=r.message,s=[],i=[];for(let o of e){let{table:c}=o,u=o.database??o.schema??"data";if(u===AL.SYSTEM_SCHEMA_NAME){await Od.createLocalTableStream(u,c);let h=new NL(u,c,o.publish,o.subscribe);h.start_time=o.start_time,i.push(h);continue}let _=gL.doesSchemaExist(u),l=n[u]!==void 0,d=c?gL.doesTableExist(u,c):!0,f=c?n?.[u]?.[c]!==void 0:!0;if(!_&&!l||!d&&!f){s.push(o);continue}if(!_&&l&&(bd.trace(`addNode creating schema: ${u}`),await OL.createSchema({operation:"create_schema",schema:u})),!d&&f){bd.trace(`addNode creating table: ${c} in schema: ${u} with attributes ${JSON.stringify(n[u][c].attributes)}`);let h=new fj(u,c,n[u][c].hash_attribute);n[u][c].attributes&&(h.attributes=n[u][c].attributes),await OL.createTable(h)}await Od.createLocalTableStream(u,c);let E=new NL(u,c,o.publish,o.subscribe);E.start_time=o.start_time,i.push(E)}return{added:i,skipped:s}}a(mj,"reviewSubscriptions")});var wd=R((Wde,DL)=>{"use strict";var{handleHDBError:yd,hdb_errors:pj}=ne(),{HTTP_STATUS_CODES:Nd}=pj,{addUpdateNodeValidator:Sj}=hd(),Id=K(),CL=U(),wL=nt(),Tj=Q(),_u=Nt(),du=ys(),gj=te(),Rj=jS(),{Node:Aj,NodeSubscription:Oj}=_a(),{broadcast:bj}=ct(),yj="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",Nj="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",Ij=gj.get(CL.CONFIG_PARAMS.CLUSTERING_NODENAME);DL.exports=wj;async function wj(e,t=!1){Id.trace("addNode called with:",e),du.checkClusteringEnabled();let r=Sj(e);if(r)throw yd(r,r.message,Nd.BAD_REQUEST,void 0,void 0,!0);let n=e.node_name;if(!t){let d=await du.getNodeRecord(n);if(!Tj.isEmptyOrZeroLength(d))throw yd(new Error,`Node '${n}' has already been added, perform update_node to proceed.`,Nd.BAD_REQUEST,void 0,void 0,!0)}let{added:s,skipped:i}=await Rj(e.subscriptions,n),o={message:void 0,added:s,skipped:i};if(s.length===0)return o.message=yj,o;let c=du.buildNodePayloads(s,Ij,CL.OPERATIONS_ENUM.ADD_NODE,await du.getSystemInfo()),u=[];for(let d=0,f=s.length;d<f;d++){let E=s[d];s[d].start_time===void 0&&delete s[d].start_time,u.push(new Oj(E.schema,E.table,E.publish,E.subscribe))}Id.trace("addNode sending remote payload:",c);let _;try{_=await _u.request(`${n}.${wL.REQUEST_SUFFIX}`,c)}catch(d){Id.error(`addNode received error from request: ${d}`);for(let E=0,h=s.length;E<h;E++){let S=s[E];S.publish=!1,S.subscribe=!1,await _u.updateRemoteConsumer(S,n)}let f=_u.requestErrorHandler(d,"add_node",n);throw yd(new Error,f,Nd.INTERNAL_SERVER_ERROR,"error",f)}if(_.status===wL.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let d=`Error returned from remote node ${n}: ${_.message}`;throw yd(new Error,d,Nd.INTERNAL_SERVER_ERROR,"error",d)}Id.trace(_);for(let d=0,f=s.length;d<f;d++){let E=s[d];await _u.updateRemoteConsumer(E,n),E.subscribe===!0&&await _u.updateConsumerIterator(E.schema,E.table,n,"start")}let l=new Aj(n,u,_.system_info);return await du.upsertNodeRecord(l),bj({type:"nats_update"}),i.length>0?o.message=Nj:o.message=`Successfully added '${n}' to manifest`,o}a(wj,"addNode")});var tT=R((Jde,UL)=>{"use strict";var{handleHDBError:ZS,hdb_errors:Cj}=ne(),{HTTP_STATUS_CODES:eT}=Cj,{addUpdateNodeValidator:Dj}=hd(),fu=K(),ML=U(),LL=nt(),zde=Q(),Eu=Nt(),hu=ys(),Lj=te(),{cloneDeep:Mj}=require("lodash"),Uj=jS(),{Node:Pj,NodeSubscription:vj}=_a(),{broadcast:Bj}=ct(),Hj="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",Gj=Lj.get(ML.CONFIG_PARAMS.CLUSTERING_NODENAME);UL.exports=Fj;async function Fj(e){fu.trace("updateNode called with:",e),hu.checkClusteringEnabled();let t=Dj(e);if(t)throw ZS(t,t.message,eT.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await hu.getNodeRecord(r);s.length>0&&(n=Mj(s));let{added:i,skipped:o}=await Uj(e.subscriptions,r),c={message:void 0,updated:i,skipped:o};if(i.length===0)return c.message=Hj,c;let u=hu.buildNodePayloads(i,Gj,ML.OPERATIONS_ENUM.UPDATE_NODE,await hu.getSystemInfo());for(let l=0,d=i.length;l<d;l++){let f=i[l];fu.trace(`updateNode updating work stream for node: ${r} subscription:`,f),i[l].start_time===void 0&&delete i[l].start_time}fu.trace("updateNode sending remote payload:",u);let _;try{_=await Eu.request(`${r}.${LL.REQUEST_SUFFIX}`,u)}catch(l){fu.error(`updateNode received error from request: ${l}`);let d=Eu.requestErrorHandler(l,"update_node",r);throw ZS(new Error,d,eT.INTERNAL_SERVER_ERROR,"error",d)}if(_.status===LL.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let l=`Error returned from remote node ${r}: ${_.message}`;throw ZS(new Error,l,eT.INTERNAL_SERVER_ERROR,"error",l)}fu.trace(_);for(let l=0,d=i.length;l<d;l++){let f=i[l];await Eu.updateRemoteConsumer(f,r),f.subscribe===!0?await Eu.updateConsumerIterator(f.schema,f.table,r,"start"):await Eu.updateConsumerIterator(f.schema,f.table,r,"stop")}return n||(n=[new Pj(r,[],_.system_info)]),await qj(n[0],i,_.system_info),o.length>0?c.message=xj:c.message=`Successfully updated '${r}'`,c}a(Fj,"updateNode");async function qj(e,t,r){let n=e;for(let s=0,i=t.length;s<i;s++){let o=t[s],c=!1;for(let u=0,_=e.subscriptions.length;u<_;u++){let l=n.subscriptions[u];if(l.schema===o.schema&&l.table===o.table){l.publish=o.publish,l.subscribe=o.subscribe,c=!0;break}}c||n.subscriptions.push(new vj(o.schema,o.table,o.publish,o.subscribe))}n.system_info=r,await hu.upsertNodeRecord(n),Bj({type:"nats_update"})}a(qj,"updateNodeTable")});var xL=R((jde,HL)=>{"use strict";var BL=require("joi"),{string:PL}=BL.types(),kj=rt(),vL=U(),Vj=te(),$j=nt();HL.exports=Yj;function Yj(e){let t=PL.invalid(Vj.get(vL.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern($j.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=BL.object({operation:PL.valid(vL.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return kj.validateBySchema(e,r)}a(Yj,"removeNodeValidator")});var Dd=R((efe,VL)=>{"use strict";var{handleHDBError:GL,hdb_errors:Kj}=ne(),{HTTP_STATUS_CODES:FL}=Kj,Wj=xL(),mu=K(),qL=ys(),Qj=Q(),Cd=U(),kL=nt(),rT=Nt(),zj=te(),{RemotePayloadObject:Jj}=uu(),{NodeSubscription:Xj}=_a(),jj=Qc(),Zj=Vi(),{broadcast:eZ}=ct(),tZ=zj.get(Cd.CONFIG_PARAMS.CLUSTERING_NODENAME);VL.exports=rZ;async function rZ(e){mu.trace("removeNode called with:",e),qL.checkClusteringEnabled();let t=Wj(e);if(t)throw GL(t,t.message,FL.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await qL.getNodeRecord(r);if(Qj.isEmptyOrZeroLength(n))throw GL(new Error,`Node '${r}' was not found.`,FL.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new Jj(Cd.OPERATIONS_ENUM.REMOVE_NODE,tZ,[]),i,o=!1;for(let u=0,_=n.subscriptions.length;u<_;u++){let l=n.subscriptions[u];l.subscribe===!0&&await rT.updateConsumerIterator(l.schema,l.table,r,"stop");try{await rT.updateRemoteConsumer(new Xj(l.schema,l.table,!1,!1),r)}catch(d){mu.error(d)}}try{i=await rT.request(`${r}.${kL.REQUEST_SUFFIX}`,s),mu.trace("Remove node reply from remote node:",r,i)}catch(u){mu.error("removeNode received error from request:",u),o=!0}let c=new jj(Cd.SYSTEM_SCHEMA_NAME,Cd.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await Zj.deleteRecord(c),eZ({type:"nats_update"}),i?.status===kL.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||o?(mu.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(rZ,"removeNode")});var KL=R((rfe,YL)=>{"use strict";var $L=require("joi"),{string:nZ,array:sZ}=$L.types(),iZ=rt(),oZ=hd();YL.exports=aZ;function aZ(e){let t=$L.object({operation:nZ.valid("configure_cluster").required(),connections:sZ.items(oZ.validation_schema).required()});return iZ.validateBySchema(e,t)}a(aZ,"configureClusterValidator")});var nT=R((sfe,XL)=>{"use strict";var cZ=U(),Ld=K(),uZ=Q(),lZ=Dd(),_Z=wd(),WL=ys(),dZ=KL(),{handleHDBError:QL,hdb_errors:fZ}=ne(),{HTTP_STATUS_CODES:zL}=fZ,EZ="Configure cluster complete.",hZ="Failed to configure the cluster. Check the logs for more details.",mZ="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";XL.exports=pZ;async function pZ(e){Ld.trace("configure cluster called with:",e),WL.checkClusteringEnabled();let t=dZ(e);if(t)throw QL(t,t.message,zL.BAD_REQUEST,void 0,void 0,!0);let r=await WL.getAllNodeRecords(),n=[];for(let l=0,d=r.length;l<d;l++){let f=await JL(lZ,{operation:cZ.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[l].name},r[l].name);n.push(f)}Ld.trace("All results from configure_cluster remove node:",n);let s=[],i=e.connections.length;for(let l=0;l<i;l++){let d=e.connections[l],f=await JL(_Z,d,d.node_name);s.push(f)}Ld.trace("All results from configure_cluster add node:",s);let o=[],c=[],u=!1,_=n.concat(s);for(let l=0,d=_.length;l<d;l++){let f=_[l];f.status==="rejected"&&(Ld.error(f),o.includes(f.node_name)||o.push(f.node_name)),(f?.result?.message?.includes?.("Successfully")||f?.result?.includes?.("Successfully"))&&(u=!0),!(typeof f.result=="string"&&f.result.includes("Successfully removed")||f.status==="rejected")&&c.push({node_name:f?.node_name,subscriptions:f?.result})}if(uZ.isEmptyOrZeroLength(o))return{message:EZ,connections:c};if(u)return{message:mZ,failed_nodes:o,connections:c};throw QL(new Error,hZ,zL.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(pZ,"configureCluster");async function JL(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){return{node_name:r,error:n,status:"rejected"}}}a(JL,"functionWrapper")});var tM=R((ofe,eM)=>{"use strict";var pu=require("joi"),SZ=rt(),{validateSchemaExists:jL,validateTableExists:TZ,validateSchemaName:ZL}=Qn(),gZ=pu.object({operation:pu.string().valid("purge_stream"),schema:pu.string().custom(jL).custom(ZL).optional(),database:pu.string().custom(jL).custom(ZL).optional(),table:pu.string().custom(TZ).required()});function RZ(e){return SZ.validateBySchema(e,gZ)}a(RZ,"purgeStreamValidator");eM.exports=RZ});var sT=R((cfe,rM)=>{"use strict";var{handleHDBError:AZ,hdb_errors:OZ}=ne(),{HTTP_STATUS_CODES:bZ}=OZ,yZ=tM(),NZ=Nt(),IZ=ys();rM.exports=wZ;async function wZ(e){e.schema=e.schema??e.database;let t=yZ(e);if(t)throw AZ(t,t.message,bZ.BAD_REQUEST,void 0,void 0,!0);IZ.checkClusteringEnabled();let{schema:r,table:n,options:s}=e;return await NZ.purgeTableStream(r,n,s),`Successfully purged table '${r}.${n}'`}a(wZ,"purgeStream")});var aT=R((lfe,cM)=>{"use strict";var oT=ys(),CZ=Nt(),iM=te(),Md=U(),so=nt(),DZ=Q(),iT=K(),{RemotePayloadObject:LZ}=uu(),{ErrorCode:nM}=require("nats"),sM=iM.get(Md.CONFIG_PARAMS.CLUSTERING_ENABLED),oM=iM.get(Md.CONFIG_PARAMS.CLUSTERING_NODENAME);cM.exports={clusterStatus:MZ,buildNodeStatus:aM};async function MZ(){let e={node_name:oM,is_enabled:sM,connections:[]};if(!sM)return e;let t=await oT.getAllNodeRecords();if(DZ.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(aM(t[n],e.connections));return await Promise.allSettled(r),e}a(MZ,"clusterStatus");async function aM(e,t){let r=e.name,n=new LZ(Md.OPERATIONS_ENUM.CLUSTER_STATUS,oM,void 0,await oT.getSystemInfo()),s,i,o=so.CLUSTER_STATUS_STATUSES.OPEN;try{let u=Date.now();s=await CZ.request(so.REQUEST_SUBJECT(r),n),i=Date.now()-u,s.status===so.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=so.CLUSTER_STATUS_STATUSES.CLOSED,iT.error(`Error getting node status from ${r} `,s))}catch(u){iT.warn(`Error getting node status from ${r}`,u),u.code===nM.NoResponders?o=so.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:u.code===nM.Timeout?o=so.CLUSTER_STATUS_STATUSES.TIMEOUT:o=so.CLUSTER_STATUS_STATUSES.CLOSED}let c=new UZ(r,o,s?.message?.ports?.clustering,s?.message?.ports?.operations_api,i,s?.message?.uptime,e.subscriptions,s?.message?.system_info);try{let u={name:r,system_info:s?.message?.system_info};e.system_info?.hdb_version!==Md.PRE_4_0_0_VERSION&&await oT.upsertNodeRecord(u)}catch(u){iT.error("Cluster status encountered an error updating system info for node:",r,u)}t.push(c)}a(aM,"buildNodeStatus");function UZ(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(UZ,"NodeStatusObject")});var uT=R((dfe,uM)=>{"use strict";var{handleHDBError:PZ,hdb_errors:vZ}=ne(),{HTTP_STATUS_CODES:BZ}=vZ,HZ=Nt(),xZ=ys(),cT=Q(),Ud=require("joi"),GZ=rt(),FZ=2e3,qZ=Ud.object({timeout:Ud.number().min(1),connected_nodes:Ud.boolean(),routes:Ud.boolean()});uM.exports=kZ;async function kZ(e){xZ.checkClusteringEnabled();let t=GZ.validateBySchema(e,qZ);if(t)throw PZ(t,t.message,BZ.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||cT.autoCastBoolean(n),o=s===void 0||cT.autoCastBoolean(s),c={nodes:[]},u=await HZ.getServerList(r??FZ),_={};if(i)for(let l=0,d=u.length;l<d;l++){let f=u[l].statsz;f&&(_[u[l].server.name]=f.routes)}for(let l=0,d=u.length;l<d;l++){if(u[l].statsz)continue;let f=u[l].server,E=u[l].data;if(f.name.endsWith("-hub")){let h={name:f.name.slice(0,-4),response_time:u[l].response_time};i&&(h.connected_nodes=[],_[f.name]&&_[f.name].forEach(S=>{h.connected_nodes.includes(S.name.slice(0,-4))||h.connected_nodes.push(S.name.slice(0,-4))})),o&&(h.routes=E.cluster?.urls?E.cluster?.urls.map(S=>({host:S.split(":")[0],port:cT.autoCast(S.split(":")[1])})):[]),c.nodes.push(h)}}return c}a(kZ,"clusterNetwork")});var fM=R((Efe,dM)=>{"use strict";var lT=require("joi"),lM=rt(),{route_constraints:_M}=Vm();dM.exports={setRoutesValidator:VZ,deleteRoutesValidator:$Z};function VZ(e){let t=lT.object({server:lT.valid("hub","leaf").required(),routes:_M.required()});return lM.validateBySchema(e,t)}a(VZ,"setRoutesValidator");function $Z(e){let t=lT.object({routes:_M.required()});return lM.validateBySchema(e,t)}a($Z,"deleteRoutesValidator")});var dT=R((mfe,pM)=>{"use strict";var io=dr(),_T=Q(),Pd=U(),EM=fM(),{handleHDBError:hM,hdb_errors:YZ}=ne(),{HTTP_STATUS_CODES:mM}=YZ,KZ="cluster routes successfully set",WZ="cluster routes successfully deleted";pM.exports={setRoutes:QZ,getRoutes:zZ,deleteRoutes:JZ};function QZ(e){let t=EM.setRoutesValidator(e);if(t)throw hM(t,t.message,mM.BAD_REQUEST,void 0,void 0,!0);let r=io.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,u=e.routes.length;c<u;c++){let _=e.routes[c];_.port=_T.autoCast(_.port);let l=n.some(f=>f.host===_.host&&f.port===_.port),d=s.some(f=>f.host===_.host&&f.port===_.port);l||d?i.push(_):(n.push(_),o.push(_))}return e.server==="hub"?io.updateConfigValue(Pd.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,n):io.updateConfigValue(Pd.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n),{message:KZ,set:o,skipped:i}}a(QZ,"setRoutes");function zZ(){let e=io.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}a(zZ,"getRoutes");function JZ(e){let t=EM.deleteRoutesValidator(e);if(t)throw hM(t,t.message,mM.BAD_REQUEST,void 0,void 0,!0);let r=io.getClusteringRoutes(),n=r.hub_routes,s=r.leaf_routes,i=[],o=[],c=!1,u=!1;for(let _=0,l=e.routes.length;_<l;_++){let d=e.routes[_],f=!1;for(let E=0,h=n.length;E<h;E++){let S=n[E];if(d.host===S.host&&d.port===S.port){n.splice(E,1),f=!0,c=!0,i.push(d);break}}if(!f){let E=!0;for(let h=0,S=s.length;h<S;h++){let p=s[h];if(d.host===p.host&&d.port===p.port){s.splice(h,1),u=!0,E=!1,i.push(d);break}}E&&o.push(d)}}return c&&(n=_T.isEmptyOrZeroLength(n)?null:n,io.updateConfigValue(Pd.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,n)),u&&(s=_T.isEmptyOrZeroLength(s)?null:s,io.updateConfigValue(Pd.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,s)),{message:WZ,deleted:i,skipped:o}}a(JZ,"deleteRoutes")});var TM=R((Sfe,SM)=>{"use strict";var Su=require("alasql"),oo=require("recursive-iterator"),Pn=K(),XZ=Q(),Tu=U(),fT=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,ZZ(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=>Tu.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=>!Tu.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][Tu.PERMS_CRUD_ENUM.READ]){let c;t[i].tables[o].attribute_permissions.length>0?c=jZ(t[i].tables[o].attribute_permissions):c=global.hdb_schema[i][o].attributes.map(_=>({attribute_name:_.attribute}));let u=this.affected_attributes.get(i).get(o).filter(_=>!Tu.SEARCH_WILDCARDS.includes(_));c.forEach(({attribute_name:_})=>{let l=new Su.yy.Column({columnid:_});s.tableid&&(l.tableid=s.tableid),this.ast.columns.push(l),u.includes(_)||u.push(_)}),this.affected_attributes.get(i).set(o,u)}}),this.ast}};function jZ(e){return e.filter(t=>t[Tu.PERMS_CRUD_ENUM.READ])}a(jZ,"filterReadRestrictedAttrs");function ZZ(e,t,r,n,s){e5(e,t,r,n,s)}a(ZZ,"interpretAST");function gu(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(gu,"addSchemaTableToMap");function e5(e,t,r,n,s){if(!e){Pn.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof Su.yy.Insert?s5(e,t,r):e instanceof Su.yy.Select?t5(e,t,r,n,s):e instanceof Su.yy.Update?r5(e,t,r):e instanceof Su.yy.Delete?n5(e,t,r):Pn.error("AST in getRecordAttributesAST() is not a valid SQL type.")}a(e5,"getRecordAttributesAST");function t5(e,t,r,n,s){if(!e){Pn.info("getSelectAttributes: invalid SQL syntax tree");return}if(!e.from||e.from[0]===void 0)return;let i=e.from[0].databaseid;if(XZ.isEmptyOrZeroLength(i)){Pn.error("No schema specified");return}e.from.forEach(c=>{gu(c,t,r,n,s)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),gu(c.table,t,r,n,s)});let o=new oo(e.columns);for(let{node:c}of o)if(c&&c.columnid){let u=c.tableid,_=n.has(u)?n.get(u):i;if(u||(u=e.from[0].tableid),!t.get(_).has(u))if(r.has(u))u=r.get(u);else{Pn.info(`table specified as ${u} not found.`);return}t.get(_).get(u).indexOf(c.columnid)<0&&t.get(_).get(u).push(c.columnid)}if(e.where){let c=new oo(e.where),u=e.from[0].tableid;for(let{node:_}of c)if(_&&_.columnid){let l=_.tableid?_.tableid:u;if(!t.get(i).has(l))if(r.has(l))l=r.get(l);else{Pn.info(`table specified as ${l} not found.`);continue}t.get(i).get(l).indexOf(_.columnid)<0&&t.get(i).get(l).push(_.columnid)}}if(e.joins&&e.joins.forEach(c=>{let u=new oo(c.on);for(let{node:_}of u)if(_&&_.columnid){let l=_.tableid,d=s.get(l);if(!t.get(d).has(l))if(r.has(l))l=r.get(l);else{Pn.info(`table specified as ${l} not found.`);continue}t.get(d).get(l).indexOf(_.columnid)<0&&t.get(d).get(l).push(_.columnid)}}),e.order){let c=new oo(e.order);for(let{node:u}of c)if(u&&u.columnid){let _=u.tableid,l=n.has(_)?n.get(_):i;if(_||(_=e.from[0].tableid),!t.get(l).has(_))if(r.has(_))_=r.get(_);else{Pn.info(`table specified as ${_} not found.`);return}t.get(l).get(_).indexOf(u.columnid)<0&&t.get(l).get(_).push(u.columnid)}}}a(t5,"getSelectAttributes");function r5(e,t,r){if(!e){Pn.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new oo(e.columns),s=e.table.databaseid;gu(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&ET(e.table.tableid,s,i.columnid,t,r)}a(r5,"getUpdateAttributes");function n5(e,t,r){if(!e){Pn.info("getDeleteAttributes: invalid SQL syntax tree");return}let n=new oo(e.where),s=e.table.databaseid;gu(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&ET(e.table.tableid,s,i.columnid,t,r)}a(n5,"getDeleteAttributes");function s5(e,t,r){if(!e){Pn.info("getInsertAttributes: invalid SQL syntax tree");return}let n=new oo(e.columns),s=e.into.databaseid;gu(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&ET(e.into.tableid,s,i.columnid,t,r)}a(s5,"getInsertAttributes");function ET(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(ET,"pushAttribute");SM.exports=fT});var pT=R((gfe,OM)=>{var vd=Wi(),gM=require("chalk"),Vr=K(),RM=require("prompt"),{promisify:i5}=require("util"),hT=U(),o5=require("fs-extra"),a5=require("path"),c5=Q(),u5=Ad(),AM=te();AM.initSync();var l5=require("moment"),_5=i5(RM.get),d5=a5.join(AM.getHdbBasePath(),hT.LICENSE_KEY_DIR_NAME,hT.LICENSE_FILE_NAME,hT.LICENSE_FILE_NAME);OM.exports={getFingerprint:E5,setLicense:f5,parseLicense:mT,register:h5,getRegistrationInfo:p5};async function f5(e){if(e&&e.key&&e.company){try{Vr.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await mT(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw Vr.error(r),Vr.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}a(f5,"setLicense");async function E5(){let e={};try{e=await vd.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw Vr.error(r),Vr.error(t),new Error(r)}return e}a(E5,"getFingerprint");async function mT(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");Vr.info("Validating license input...");let r=vd.validateLicense(e,t);if(Vr.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(Vr.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(Vr.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{Vr.info("writing license to disk"),await o5.writeFile(d5,JSON.stringify({license_key:e,company:t}))}catch(n){throw Vr.error("Failed to write License"),n}return"Registration successful."}a(mT,"parseLicense");async function h5(){let e=await m5();return mT(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(h5,"register");async function m5(){let e=await vd.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:gM.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:gM.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{RM.start()}catch(n){Vr.error(n)}let r;try{r=await _5(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}a(m5,"promptForRegistration");async function p5(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await vd.getLicense()}catch(r){throw Vr.error(`There was an error when searching licenses due to: ${r.message}`),r}if(c5.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=u5.version(),e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=l5.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(p5,"getRegistrationInfo")});var yM=R((Afe,bM)=>{"use strict";var S5=nt(),ST=class{static{a(this,"HubConfigObject")}constructor(t,r,n,s,i,o,c,u,_,l,d,f,E,h){this.port=t,o===null&&(o=void 0),this.server_name=r+S5.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:u},this.leafnodes={port:_,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c}},this.cluster={name:l,port:d,routes:f,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c,verify:u}},this.accounts={SYS:{users:E},HDB:{users:h}},this.system_account="SYS"}};bM.exports=ST});var wM=R((bfe,IM)=>{"use strict";var NM=nt(),TT=class{static{a(this,"LeafConfigObject")}constructor(t,r,n,s,i,o,c,u,_,l,d){this.port=t,d===null&&(d=void 0),this.server_name=r+NM.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+NM.SERVER_SUFFIX.LEAF},this.tls={cert_file:_,key_file:l,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:u,jetstream:"enabled"}},this.system_account="SYS"}};IM.exports=TT});var DM=R((Nfe,CM)=>{"use strict";var gT=class{static{a(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};CM.exports=gT});var MM=R((wfe,LM)=>{"use strict";var T5=nt(),RT=class{static{a(this,"SysUserObject")}constructor(t,r){this.user=t+T5.SERVER_SUFFIX.ADMIN,this.password=r}};LM.exports=RT});var bT=R((Dfe,vM)=>{"use strict";var fa=require("path"),xd=require("fs-extra"),g5=yM(),R5=wM(),A5=DM(),O5=MM(),AT=un(),ha=Q(),Rr=dr(),Hd=U(),Ru=nt(),{CONFIG_PARAMS:dt}=Hd,ma=K(),Au=te(),UM=gs(),OT=Nt(),Ea="clustering",b5=1e4,PM=50;vM.exports={generateNatsConfig:N5,removeNatsConfig:I5,getHubConfigPath:y5};function y5(){let e=Au.get(dt.ROOTPATH);return fa.join(e,Ea,Ru.NATS_CONFIG_FILES.HUB_SERVER)}a(y5,"getHubConfigPath");async function N5(e=!1,t=void 0){Au.initSync();let r=Au.get(dt.ROOTPATH),n=fa.join(r,Ea,Ru.PID_FILES.HUB),s=fa.join(r,Ea,Ru.PID_FILES.LEAF),i=Rr.getConfigFromFile(dt.CLUSTERING_LEAFSERVER_STREAMS_PATH),o=fa.join(r,Ea,Ru.NATS_CONFIG_FILES.HUB_SERVER),c=fa.join(r,Ea,Ru.NATS_CONFIG_FILES.LEAF_SERVER),u=Rr.getConfigFromFile(dt.CLUSTERING_TLS_CERTIFICATE),_=Rr.getConfigFromFile(dt.CLUSTERING_TLS_PRIVATEKEY),l=Rr.getConfigFromFile(dt.CLUSTERING_TLS_CERT_AUTH),d=Rr.getConfigFromFile(dt.CLUSTERING_TLS_INSECURE),f=Rr.getConfigFromFile(dt.CLUSTERING_TLS_VERIFY),E=Rr.getConfigFromFile(dt.CLUSTERING_NODENAME),h=Rr.getConfigFromFile(dt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await OT.checkNATSServerInstalled()||Gd("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let S=await AT.listUsers(),p=Rr.getConfigFromFile(dt.CLUSTERING_USER),T=await AT.getClusterUser();(ha.isEmpty(T)||T.active!==!0)&&Gd(`Invalid cluster user '${p}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await Bd(dt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await Bd(dt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await Bd(dt.CLUSTERING_HUBSERVER_NETWORK_PORT),await Bd(dt.CLUSTERING_LEAFSERVER_NETWORK_PORT));let A=[],g=[];for(let[z,J]of S.entries())J.role.role===Hd.ROLE_TYPES_ENUM.CLUSTER_USER&&J.active&&(A.push(new O5(J.username,UM.decrypt(J.hash))),g.push(new A5(J.username,UM.decrypt(J.hash))));let L=[],{hub_routes:v}=Rr.getClusteringRoutes();if(!ha.isEmptyOrZeroLength(v))for(let z of v)L.push(`tls://${T.sys_name_encoded}:${T.uri_encoded_d_hash}@${z.host}:${z.port}`);let P=new g5(Rr.getConfigFromFile(dt.CLUSTERING_HUBSERVER_NETWORK_PORT),E,n,u,_,l,d,f,h,Rr.getConfigFromFile(dt.CLUSTERING_HUBSERVER_CLUSTER_NAME),Rr.getConfigFromFile(dt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),L,A,g);l==null&&(delete P.tls.ca_file,delete P.leafnodes.tls.ca_file),t=ha.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===Hd.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await xd.writeJson(o,P),ma.trace(`Hub server config written to ${o}`));let k=`tls://${T.sys_name_encoded}:${T.uri_encoded_d_hash}@0.0.0.0:${h}`,H=`tls://${T.uri_encoded_name}:${T.uri_encoded_d_hash}@0.0.0.0:${h}`,X=new R5(Rr.getConfigFromFile(dt.CLUSTERING_LEAFSERVER_NETWORK_PORT),E,s,i,[k],[H],A,g,u,_,l,d);l==null&&delete X.tls.ca_file,(t===void 0||t===Hd.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await xd.writeJson(c,X),ma.trace(`Leaf server config written to ${c}`))}a(N5,"generateNatsConfig");async function Bd(e){let t=Au.get(e);return ha.isEmpty(t)&&Gd(`port undefined for '${e}'`),await ha.isPortTaken(t)&&Gd(`'${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(Bd,"isPortAvailable");function Gd(e){let t=`Error generating clustering config: ${e}`;ma.error(t),console.error(t),process.exit(1)}a(Gd,"generateNatsConfigError");async function I5(e){let{port:t,config_file:r}=OT.getServerConfig(e),{username:n,decrypt_hash:s}=await AT.getClusterUser(),i=0,o=2e3;for(;i<PM;){try{let l=await OT.createConnection(t,n,s,!1);if(l.protocol.connected===!0){l.close();break}}catch(l){ma.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${l}`)}if(i++,i>=PM)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&&ma.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await ha.async_set_timeout(_)}let c="0".repeat(b5),u=fa.join(Au.get(dt.ROOTPATH),Ea,r);await xd.writeFile(u,c),await xd.remove(u),ma.notify(e,"started.")}a(I5,"removeNatsConfig")});var qM=R((Mfe,FM)=>{"use strict";var $r=te(),w5=Wi(),he=U(),Ou=nt(),Ns=require("path"),{PACKAGE_ROOT:qd}=U(),BM=te(),Fd=Q(),pa="/dev/null",C5=Ns.join(qd,"launchServiceScripts"),HM=Ns.join(qd,"utility/scripts"),D5=Ns.join(HM,he.HDB_RESTART_SCRIPT),xM=Ns.resolve(qd,"dependencies",`${process.platform}-${process.arch}`,Ou.NATS_BINARY_NAME);function GM(){let t=w5.licenseSearch().ram_allocation||he.RAM_ALLOCATION_ENUM.DEFAULT,r=he.MEM_SETTING_KEY+t,n={[he.PROCESS_NAME_ENV_PROP]:he.PROCESS_DESCRIPTORS.HDB,IS_SCRIPTED_SERVICE:!0};return Fd.noBootFile()&&(n[he.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Fd.getEnvCliRootPath()),{name:he.PROCESS_DESCRIPTORS.HDB,script:he.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:n,node_args:r,cwd:qd}}a(GM,"generateMainServerConfig");var L5=9930;function M5(){$r.initSync(!0);let e=$r.get(he.CONFIG_PARAMS.ROOTPATH),t=Ns.join(e,"clustering",Ou.NATS_CONFIG_FILES.HUB_SERVER),r=Ns.join($r.get(he.HDB_SETTINGS_NAMES.LOG_PATH_KEY),he.LOG_NAMES.HDB),n=BM.get(he.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=Ou.LOG_LEVEL_FLAGS[$r.get(he.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:he.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==L5?"-"+n:""),script:xM,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[he.PROCESS_NAME_ENV_PROP]:he.PROCESS_DESCRIPTORS.CLUSTERING_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return $r.get(he.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=pa,i.error_file=pa),i}a(M5,"generateNatsHubServerConfig");var U5=9940;function P5(){$r.initSync(!0);let e=$r.get(he.CONFIG_PARAMS.ROOTPATH),t=Ns.join(e,"clustering",Ou.NATS_CONFIG_FILES.LEAF_SERVER),r=Ns.join($r.get(he.HDB_SETTINGS_NAMES.LOG_PATH_KEY),he.LOG_NAMES.HDB),n=BM.get(he.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=Ou.LOG_LEVEL_FLAGS[$r.get(he.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:he.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==U5?"-"+n:""),script:xM,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[he.PROCESS_NAME_ENV_PROP]:he.PROCESS_DESCRIPTORS.CLUSTERING_LEAF},merge_logs:!0,out_file:r,error_file:r,instances:1};return $r.get(he.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=pa,i.error_file=pa),i}a(P5,"generateNatsLeafServerConfig");function v5(){$r.initSync();let e=Ns.join($r.get(he.CONFIG_PARAMS.LOGGING_ROOT),he.LOG_NAMES.HDB),t={name:he.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,script:he.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[he.PROCESS_NAME_ENV_PROP]:he.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:C5,autorestart:!1};return $r.get(he.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=pa,t.error_file=pa),t}a(v5,"generateClusteringUpgradeV4ServiceConfig");function B5(){let e={[he.PROCESS_NAME_ENV_PROP]:he.PROCESS_DESCRIPTORS.RESTART_HDB};return Fd.noBootFile()&&(e[he.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Fd.getEnvCliRootPath()),{...{name:he.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:HM},script:D5}}a(B5,"generateRestart");function H5(){return{apps:[GM()]}}a(H5,"generateAllServiceConfigs");FM.exports={generateAllServiceConfigs:H5,generateMainServerConfig:GM,generateRestart:B5,generateNatsHubServerConfig:M5,generateNatsLeafServerConfig:P5,generateClusteringUpgradeV4ServiceConfig:v5}});var tU=R((vfe,eU)=>{"use strict";var Pe=U(),x5=Q(),ws=bT(),kd=Nt(),Is=nt(),hi=qM(),Vd=te(),mi=K(),G5=ys(),{startWorker:kM,onMessageFromWorkers:F5}=ct(),q5=da(),Pfe=require("util"),k5=require("child_process"),V5=require("fs"),{execFile:$5}=k5,Ne;eU.exports={enterPM2Mode:Y5,start:pi,stop:yT,reload:$M,restart:YM,list:NT,describe:WM,connect:Cs,kill:J5,startAllServices:X5,startService:IT,getUniqueServicesList:QM,restartAllServices:j5,isServiceRegistered:zM,reloadStopStart:JM,restartHdb:KM,deleteProcess:Q5,startClusteringProcesses:jM,startClusteringThreads:ZM,isHdbRestartRunning:z5,isClusteringRunning:e8,stopClustering:Z5,reloadClustering:t8};var bu=!1;F5(e=>{e.type==="restart"&&Vd.initSync(!0)});function Y5(){bu=!0}a(Y5,"enterPM2Mode");function Cs(){return Ne||(Ne=require("pm2")),new Promise((e,t)=>{Ne.connect((r,n)=>{mi.setupConsoleLogging(),r&&t(r),e(n)})})}a(Cs,"connect");var Ar,K5=10,VM;function pi(e,t=!1){if(bu)return W5(e);let r=$5(e.script,e.args.split(" "),e);r.name=e.name,r.on("exit",async i=>{let o=Ar.indexOf(r);o>-1&&Ar.splice(o,1),!VM&&i!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<K5&&(V5.existsSync(ws.getHubConfigPath())?pi(e):(await ws.generateNatsConfig(!0),pi(e),await new Promise(c=>setTimeout(c,3e3)),await ws.removeNatsConfig(Pe.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await ws.removeNatsConfig(Pe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let n={serviceName:e.name.replace(/ /g,"-")};function s(i){let o=Vd.get(Pe.CONFIG_PARAMS.CLUSTERING_LOGLEVEL),c=/\[\d+][^\[]+\[(\w+)]/g,u,_=0,l;for(;u=c.exec(i);){if(u.index&&Is.LOG_LEVEL_HIERARCHY[o]>=Is.LOG_LEVEL_HIERARCHY[l||"info"]){let E=l===Is.LOG_LEVELS.ERR||l===Is.LOG_LEVELS.WRN?mi.OUTPUTS.STDERR:mi.OUTPUTS.STDOUT;mi.logCustomLevel(l||"info",E,n,i.slice(_,u.index).trim())}let[d,f]=u;_=u.index+d.length,l=Is.LOG_LEVELS[f]}if(Is.LOG_LEVEL_HIERARCHY[o]>=Is.LOG_LEVEL_HIERARCHY[l||"info"]){let d=l===Is.LOG_LEVELS.ERR||l===Is.LOG_LEVELS.WRN?mi.OUTPUTS.STDERR:mi.OUTPUTS.STDOUT;mi.logCustomLevel(l||"info",d,n,i.slice(_).trim())}}if(a(s,"extractMessages"),r.stdout.on("data",s),r.stderr.on("data",s),r.unref(),Ar=[],!Ar&&!t){let i=a(()=>{VM=!0,Ar&&(Ar.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)}Ar.push(r)}a(pi,"start");function W5(e){return new Promise(async(t,r)=>{try{await Cs()}catch(n){r(n)}Ne.start(e,(n,s)=>{n&&(Ne.disconnect(),r(n)),Ne.disconnect(),t(s)})})}a(W5,"startWithPM2");function yT(e){if(!bu){for(let t of Ar||[])t.name===e&&(Ar.splice(Ar.indexOf(t),1),t.kill());return}return new Promise(async(t,r)=>{try{await Cs()}catch(n){r(n)}Ne.stop(e,async(n,s)=>{n&&(Ne.disconnect(),r(n)),Ne.delete(e,(i,o)=>{i&&(Ne.disconnect(),r(n)),Ne.disconnect(),t(o)})})})}a(yT,"stop");function $M(e){return new Promise(async(t,r)=>{try{await Cs()}catch(n){r(n)}Ne.reload(e,(n,s)=>{n&&(Ne.disconnect(),r(n)),Ne.disconnect(),t(s)})})}a($M,"reload");function YM(e){if(!bu)for(let t of Ar||[])t.name===e&&t.kill();return new Promise(async(t,r)=>{try{await Cs()}catch(n){r(n)}Ne.restart(e,(n,s)=>{Ne.disconnect(),t(s)})})}a(YM,"restart");function Q5(e){return new Promise(async(t,r)=>{try{await Cs()}catch(n){r(n)}Ne.delete(e,(n,s)=>{n&&(Ne.disconnect(),r(n)),Ne.disconnect(),t(s)})})}a(Q5,"deleteProcess");async function KM(){await pi(hi.generateRestart())}a(KM,"restartHdb");async function z5(){let e=await NT();for(let t in e)if(e[t].name===Pe.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}a(z5,"isHdbRestartRunning");function NT(){return new Promise(async(e,t)=>{try{await Cs()}catch(r){t(r)}Ne.list((r,n)=>{r&&(Ne.disconnect(),t(r)),Ne.disconnect(),e(n)})})}a(NT,"list");function WM(e){return new Promise(async(t,r)=>{try{await Cs()}catch(n){r(n)}Ne.describe(e,(n,s)=>{n&&(Ne.disconnect(),r(n)),Ne.disconnect(),t(s)})})}a(WM,"describe");function J5(){if(!bu){for(let e of Ar||[])e.kill();Ar=[];return}return new Promise(async(e,t)=>{try{await Cs()}catch(r){t(r)}Ne.killDaemon((r,n)=>{r&&(Ne.disconnect(),t(r)),Ne.disconnect(),e(n)})})}a(J5,"kill");async function X5(){try{await jM(),await ZM(),await pi(hi.generateAllServiceConfigs())}catch(e){throw Ne?.disconnect(),e}}a(X5,"startAllServices");async function IT(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case Pe.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=hi.generateMainServerConfig();break;case Pe.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=hi.generateNatsIngestServiceConfig();break;case Pe.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=hi.generateNatsReplyServiceConfig();break;case Pe.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=hi.generateNatsHubServerConfig(),await pi(r,t),await ws.removeNatsConfig(e);return;case Pe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=hi.generateNatsLeafServerConfig(),await pi(r,t),await ws.removeNatsConfig(e);return;case Pe.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=hi.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await pi(r)}catch(r){throw Ne?.disconnect(),r}}a(IT,"startService");async function QM(){try{let e=await NT(),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 Ne?.disconnect(),e}}a(QM,"getUniqueServicesList");async function j5(e=[]){try{let t=!1,r=await QM();for(let n=0,s=Object.values(r).length;n<s;n++){let o=Object.values(r)[n].name;e.includes(o)||(o===Pe.PROCESS_DESCRIPTORS.HDB?t=!0:await YM(o))}t&&await JM(Pe.PROCESS_DESCRIPTORS.HDB)}catch(t){throw Ne?.disconnect(),t}}a(j5,"restartAllServices");async function zM(e){if(Ar?.find(r=>r.name===e))return!0;let t=await q5.getHDBProcessInfo();return t.core.length&&t.core[0]?.parent==="PM2"}a(zM,"isServiceRegistered");async function JM(e){let t=Vd.get(Pe.CONFIG_PARAMS.THREADS_COUNT)??Vd.get(Pe.CONFIG_PARAMS.THREADS),r=await WM(e),n=x5.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await yT(e),await IT(e)):e===Pe.PROCESS_DESCRIPTORS.HDB?await KM():await $M(e)}a(JM,"reloadStopStart");var XM;async function jM(e=!1){for(let t in Pe.CLUSTERING_PROCESSES){let r=Pe.CLUSTERING_PROCESSES[t];await IT(r,e)}}a(jM,"startClusteringProcesses");async function ZM(){XM=kM(Pe.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,{name:Pe.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE});try{await kd.deleteLocalStream("__HARPERDB_WORK_QUEUE__")}catch{}await kd.updateLocalStreams();let e=await G5.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===Pe.PRE_4_0_0_VERSION){mi.info("Starting clustering upgrade 4.0.0 process"),kM(Pe.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}a(ZM,"startClusteringThreads");async function Z5(){for(let e in Pe.CLUSTERING_PROCESSES)if(e!==Pe.CLUSTERING_PROCESSES.CLUSTERING_INGEST_PROC_DESCRIPTOR)if(e===Pe.CLUSTERING_PROCESSES.CLUSTERING_REPLY_SERVICE_DESCRIPTOR)await XM.terminate();else{let t=Pe.CLUSTERING_PROCESSES[e];await yT(t)}}a(Z5,"stopClustering");async function e8(){for(let e in Pe.CLUSTERING_PROCESSES){let t=Pe.CLUSTERING_PROCESSES[e];if(await zM(t)===!1)return!1}return!0}a(e8,"isClusteringRunning");async function t8(){await ws.generateNatsConfig(!0),await kd.reloadNATSHub(),await kd.reloadNATSLeaf(),await ws.removeNatsConfig(Pe.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await ws.removeNatsConfig(Pe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}a(t8,"reloadClustering")});var cU={};Fe(cU,{compactOnStart:()=>r8,copyDb:()=>aU});async function r8(){Nu.notify("Running compact on start"),console.log("Running compact on start");let e=(0,wT.get)(Si.CONFIG_PARAMS.ROOTPATH),t=new Map,r=Er();try{for(let n in r){if(n==="system")continue;let s;for(let u in r[n]){s=r[n][u].primaryStore.path;break}if(!s){console.log("Couldn't find any tables in database",n);continue}let i=(0,$d.join)(e,"backup",n+".mdb"),o=(0,$d.join)(e,Si.DATABASES_DIR_NAME,n+"-copy.mdb"),c=await rU(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 aU(n,o),console.log("Backing up",n,"to",i),await(0,ao.move)(s,i,{overwrite:!0})}yu();for(let[n,{db_path:s,copy_dest:i}]of t)console.log("Moving copy compacted",n,"to",s),await(0,ao.move)(i,s,{overwrite:!0}),await(0,ao.remove)((0,$d.join)(e,Si.DATABASES_DIR_NAME,`${n}-copy.mdb-lock`));yu()}catch(n){Nu.error("Error compacting database, rolling back operation",n),console.error("Error compacting database, rolling back operation",n),(0,CT.updateConfigValue)(Si.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,ao.move)(o,i,{overwrite:!0})}catch(c){console.error(c)}}throw yu(),n}for(let[n,{backup_dest:s,record_count:i}]of t){let o=!0,c=await rU(n);if(console.log("Database",n,"after compact has a total record count of",c),i!==c){o=!1;let u=`There is a discrepancy between pre and post compact record count for database ${n}.
8
8
  Total record count before compaction: ${i}, total after: ${c}.
9
9
  Database backup has not been removed and can be found here: ${s}`;Nu.error(u),console.error(u)}(0,wT.get)(Si.CONFIG_PARAMS.STORAGE_COMPACTONSTARTKEEPBACKUP)===!0||o===!1||(console.log("Removing backup",s),await(0,ao.remove)(s))}(0,CT.updateConfigValue)(Si.CONFIG_PARAMS.STORAGE_COMPACTONSTART,!1)}async function rU(e){let t=await(0,oU.describeSchema)({database:e}),r=0;for(let n in t)r+=t[n].record_count;return r}async function aU(e,t){console.log("copyDb start");let r=Er()[e],n;for(let d in r){n=r[d].primaryStore.rootStore;break}let s=n.dbisDb,i=n.auditStore,o=(0,nU.open)(new sU.default(t)),c=o.openDB(Yd.INTERNAL_DBIS_NAME),u,_=0,l=s.useReadTransaction();try{for(let{key:E,value:h}of s.getRange({transaction:l})){let S=h.is_hash_attribute||h.isPrimaryKey,p,T;if(S&&(p=h.compression,T=Wd(),T?h.compression=T:delete h.compression,p?.dictionary?.toString()===T?.dictionary?.toString()&&(p=null,T=null)),c.put(E,h),!(S||h.indexed))continue;let A=new iU.default(!S,S);A.encoding="binary",A.compression=p;let g=n.openDB(E,A);g.decoder=null,A.compression=T;let L=o.openDB(E,A);L.encoder=null,console.log("copying",E,"from",e,"to",t),await f(g,L,S,l)}let d=n.openDB(Yd.AUDIT_STORE_NAME,Kd);console.log("copying audit log"),f(i,d,!1,l);async function f(E,h,S,p){let T=0,A=0;for(let{key:g,value:L,version:v}of E.getRange({start:null,versions:S,transaction:p}))u=h.put(g,L,v),T++,p.openTimer&&(p.openTimer=0),A+=(g?.length||10)+L.length,_++>5e3&&(await u,console.log("copied",T,"entries",A,"bytes"),_=0);console.log("finish copying, copied",T,"entries",A,"bytes")}a(f,"copyDbi"),await u,console.log("copied database "+e+" to "+t)}finally{l.done(),o.close()}}var nU,$d,ao,wT,sU,iU,Yd,Si,oU,CT,Nu,uU=Re(()=>{Ae();nU=require("lmdb"),$d=require("path"),ao=require("fs-extra"),wT=B(te()),sU=B(Nc()),iU=B(yc()),Yd=B(at()),Si=B(U());js();oU=B(ti()),CT=B(dr()),Nu=B(K());a(r8,"compactOnStart");a(rU,"getTotalDBRecordCount");a(aU,"copyDb")});var Xd=R((qfe,mU)=>{"use strict";var n8=require("minimist"),{isMainThread:LT,parentPort:dU}=require("worker_threads"),Xe=U(),{PROCESS_DESCRIPTORS_VALIDATE:Iu}=Xe,ns=K(),MT=Q(),zd=bT(),Qd=Nt(),Ffe=nt(),fU=dr(),ss=tU(),lU=da(),{compactOnStart:s8}=(uU(),ie(cU)),i8=Rh(),{restartWorkers:Jd,onMessageByType:o8}=ct(),{handleHDBError:a8,hdb_errors:c8}=ne(),{HTTP_STATUS_CODES:u8}=c8,Cu=te();Cu.initSync();var wu=`Restarting HarperDB. This may take up to ${Xe.RESTART_TIMEOUT_MS/1e3} seconds.`,l8="Restart is not available from the CLI when running in non-pm2 mode. Either call restart from the API or stop and start HarperDB.",_U="Clustering is not enabled so cannot be restarted",_8="Invalid service",Sa,_n;mU.exports={restart:EU,restartService:UT};LT&&o8(Xe.ITC_EVENT_TYPES.RESTART,e=>{e.workerType?UT({service:e.workerType}):EU({operation:"restart"})});async function EU(e){_n=Object.keys(e).length===0,Sa=await ss.isServiceRegistered(Xe.HDB_PROC_DESCRIPTOR);let t=n8(process.argv);if(t.service){await UT(t);return}if(_n&&!Sa){console.error(l8);return}if(_n&&console.log(wu),Sa){ss.enterPM2Mode(),ns.notify(wu);let r=i8(Object.keys(Xe.CONFIG_PARAM_MAP),!0);return MT.isEmptyOrZeroLength(Object.keys(r))||fU.updateConfigValue(void 0,void 0,r,!0,!0),d8(),wu}return LT?(ns.notify(wu),Cu.get(Xe.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await s8(),setTimeout(()=>{Jd()},50)):dU.postMessage({type:Xe.ITC_EVENT_TYPES.RESTART}),wu}a(EU,"restart");async function UT(e){let{service:t}=e;if(Xe.PROCESS_DESCRIPTORS_VALIDATE[t]===void 0)throw a8(new Error,_8,u8.BAD_REQUEST,void 0,void 0,!0);if(Sa=await ss.isServiceRegistered(Xe.HDB_PROC_DESCRIPTOR),!LT)return dU.postMessage({type:Xe.ITC_EVENT_TYPES.RESTART,workerType:t}),t==="custom_functions"&&(t="Custom Functions"),`Restarting ${t}`;let r;switch(t){case Iu.clustering:if(!Cu.get(Xe.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=_U;break}_n&&console.log("Restarting clustering"),ns.notify("Restarting clustering"),await hU();break;case Iu.clustering_config:case Iu["clustering config"]:if(!Cu.get(Xe.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=_U;break}_n&&console.log("Restarting clustering_config"),ns.notify("Restarting clustering_config"),await ss.reloadClustering();break;case"custom_functions":case"custom functions":case Iu.harperdb:case Iu.http_workers:if(_n&&!Sa){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}_n&&console.log("Restarting http_workers"),ns.notify("Restarting http_workers"),_n?await ss.restart(Xe.HDB_PROC_DESCRIPTOR):setTimeout(()=>{Jd("http")},200);break;default:r=`Unrecognized service: ${t}`;break}return r?(ns.error(r),_n&&console.error(r),r):(t==="custom_functions"&&(t="Custom Functions"),`Restarting ${t}`)}a(UT,"restartService");async function d8(){await hU(),await ss.restart(Xe.HDB_PROC_DESCRIPTOR),await MT.async_set_timeout(2e3),Cu.get(Xe.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await DT(),_n&&(await Qd.closeConnection(),process.exit(0))}a(d8,"restartPM2Mode");async function hU(){if(!fU.getConfigFromFile(Xe.CONFIG_PARAMS.CLUSTERING_ENABLED))return;if((await lU.getHDBProcessInfo()).clustering.length===0)ns.trace("Clustering not running, restart will start clustering services"),await zd.generateNatsConfig(!0),await ss.startClusteringProcesses(),await ss.startClusteringThreads(),await DT(),_n&&await Qd.closeConnection();else{await zd.generateNatsConfig(!0),Sa?(ns.trace("Restart clustering restarting PM2 managed Hub and Leaf servers"),await ss.restart(Xe.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await ss.restart(Xe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)):(await lU.getHDBProcessInfo()).clustering.forEach(s=>{ns.trace("Restart clustering killing process pid",s.pid),process.kill(s.pid)}),await MT.async_set_timeout(3e3),await DT(),await Qd.updateLocalStreams(),_n&&await Qd.closeConnection(),ns.trace("Restart clustering restarting ingest and reply service threads");let t=Jd(Xe.LAUNCH_SERVICE_SCRIPTS.NATS_INGEST_SERVICE),r=Jd(Xe.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE);await t,await r}}a(hU,"restartClustering");async function DT(){await zd.removeNatsConfig(Xe.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await zd.removeNatsConfig(Xe.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)}a(DT,"removeNatsConfig")});var IU=R(($fe,NU)=>{"use strict";var Vfe=require("lodash"),Or=U(),{handleHDBError:pU,hdb_errors:f8}=ne(),{HDB_ERROR_MSGS:E8,HTTP_STATUS_CODES:h8}=f8,PT=K();NU.exports={getRolePermissions:p8};var co=Object.create(null),m8=a(e=>({key:e,perms:{}}),"perms_template_obj"),RU=a((e=!1)=>({describe:e,tables:{}}),"schema_perms_template"),AU=a((e=!1,t=!1,r=!1,n=!1)=>({[Or.PERMS_CRUD_ENUM.READ]:e,[Or.PERMS_CRUD_ENUM.INSERT]:t,[Or.PERMS_CRUD_ENUM.UPDATE]:r,[Or.PERMS_CRUD_ENUM.DELETE]:n}),"permissions_template"),vT=a((e=!1,t=!1,r=!1,n=!1,s=!1)=>({attribute_permissions:[],describe:e,...AU(t,r,n,s)}),"table_perms_template"),SU=a((e,t=AU())=>({attribute_name:e,describe:yU(t),[Du]:t[Du],[BT]:t[BT],[HT]:t[HT]}),"attr_perms_template"),TU=a((e,t=!1)=>({attribute_name:e,describe:t,[Du]:t}),"timestamp_attr_perms_template"),{READ:Du,INSERT:BT,UPDATE:HT}=Or.PERMS_CRUD_ENUM,OU=Object.values(Or.PERMS_CRUD_ENUM),bU=[Du,BT,HT];function p8(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[Or.SYSTEM_SCHEMA_NAME],t=e.role;let n=JSON.stringify([e.__updatedtime__,r]);if(co[t]&&co[t].key===n)return co[t].perms;let s=S8(e,r);return co[t]?co[t].key=n:co[t]=m8(n),co[t].perms=s,s}catch(r){if(!e[Or.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]||e[Or.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]<Or.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 PT.error(n),PT.debug(r),pU(new Error,E8.OUTDATED_PERMS_TRANSLATION_ERROR,h8.BAD_REQUEST)}else{let n=`There was an error while translating role permissions for role: ${t}.
10
10
  ${r.stack}`;throw PT.error(n),pU(new Error)}}}a(p8,"getRolePermissions");function S8(e,t){let r=Object.create(null);r.super_user=!1;let n=e.permission;r[Or.SYSTEM_SCHEMA_NAME]=n[Or.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]=T8(t[i]);return}r[i]=RU(),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],u=t[i][o],_=g8(c,u);r[i].describe||OU.forEach(l=>{_[l]&&(r[i].describe=!0)}),r[i].tables[o]=_}else r[i].tables[o]=vT()})):Object.keys(t[i]).forEach(o=>{r[i].tables[o]=vT()})}),r}a(S8,"translateRolePermissions");function T8(e){let t=RU(!0);return Object.keys(e).forEach(r=>{t.tables[r]=vT(!0,!0,!0,!0,!0)}),t}a(T8,"createStructureUserPermissions");function g8(e,t){let{attribute_permissions:r}=e;if(r.length>0){let s=Object.assign({},e);s.attribute_permissions=[];let i=r.reduce((_,l)=>{let{attribute_name:d}=l,f=l;return Or.TIME_STAMP_NAMES.includes(d)&&(f=TU(d,l[Du])),_[d]=f,_},{}),o=t.primaryKey||t.hash_attribute,c=!!i[o],u=SU(o);return t.attributes.forEach(({attribute:_})=>{if(i[_]){let l=i[_];l.describe=yU(l),s.attribute_permissions.push(l),c||R8(l,u)}else if(_!==o){let l;Or.TIME_STAMP_NAMES.includes(_)?l=TU(_):l=SU(_),s.attribute_permissions.push(l)}}),c||s.attribute_permissions.push(u),s.describe=gU(s),s}else return e.describe=gU(e),e}a(g8,"getTableAttrPerms");function gU(e){return OU.filter(t=>e[t]).length>0}a(gU,"getSchemaTableDescribePerm");function yU(e){return bU.filter(t=>e[t]).length>0}a(yU,"getAttributeDescribePerm");function R8(e,t){bU.forEach(r=>{e[r]&&!t[r]&&(t[r]=!0,t.describe=!0)})}a(R8,"checkForHashPerms")});var wU={};Fe(wU,{Resources:()=>jd,keyArrayToString:()=>Ta,resetResources:()=>A8,resources:()=>Ti});function A8(){return Ti=new jd}function Ta(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var jd,Ti,Lu=Re(()=>{Zi();jd=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,u]of this){let _=2;for(;(_=c.indexOf("/",_))>-1;){let l=this.get(c.slice(0,_));l&&(l.hasSubPaths=!0),_+=2}}}getMatch(t,r){let n=2,s;for(;(n=t.indexOf("/",n))>-1;){let c=t.slice(0,n),u=this.get(c);if(u){if(u.relativeURL=t.slice(n),!u.hasSubPaths)return u;s=u}n+=2}if(s)return s;let i=t.indexOf("?"),o=i>-1?t.slice(0,i):t;return s=this.get(o),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(A8,"resetResources");a(Ta,"keyArrayToString")});var CU={};Fe(CU,{Headers:()=>gi,appendHeader:()=>xT});function xT(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 gi,Mu=Re(()=>{gi=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(xT,"appendHeader")});var Uu={};Fe(Uu,{authentication:()=>HU,bypassAuth:()=>C8,login:()=>L8,logout:()=>M8,start:()=>D8});function C8(){BU=!0}async function HU(e,t){let r=e.headers.asObject,n=r.authorization,s=r.cookie,i=r.origin,o=[];try{if(i){let E=e.isOperationsServer?N8?y8:[]:b8?O8:[];if(E.includes(i)||E.includes("*")){if(e.method==="OPTIONS"){let h=new gi([["Access-Control-Allow-Methods","POST, GET, PUT, DELETE, PATCH, OPTIONS"],["Access-Control-Allow-Headers","Accept, Content-Type, Authorization"],["Access-Control-Allow-Origin",i]]);return Zd&&h.set("Access-Control-Allow-Credentials","true"),{status:200,headers:h}}o.push("Access-Control-Allow-Origin",i),Zd&&o.push("Access-Control-Allow-Credentials","true")}}let u,_;if(Zd){i||(i=r.host);let E=(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session=",h=s?.split(/;\s+/)||[];for(let S of h)if(S.startsWith(E)){let p=S.indexOf(";");u=S.slice(E.length,p===-1?S.length:p),_=await LU.get(u);break}e.session=_||(_={})}let l=a((E,h,S)=>{let p=new ga.AuthAuditLog(E,h,vt.AUTH_AUDIT_TYPES.AUTHENTICATION,r["x-forwarded-for"]??e.ip,e.method,e.pathname);p.auth_strategy=S,u&&(p.session_id=u),r.referer&&(p.referer=r.referer),r.origin&&(p.origin=r.origin),h===vt.AUTH_AUDIT_STATUS.SUCCESS?DU.notify(p):DU.error(p)},"authAuditLog");if(e.mtlsConfig&&e.authorized){let E=e.mtlsConfig.user;E!==null?((E===void 0||E==="Common Name"||E==="CN")&&(E=e.peerCertificate.subject.CN),e.user=await et.getUser(E,null,null),l(E,vt.AUTH_AUDIT_STATUS.SUCCESS,"mTLS")):(0,ga.debug)("HTTPS/WSS mTLS authorized connection (mTLS did not authorize a user)","from",e.ip)}let d;if(!e.user)if(n){if(d=uo.get(n),!d){let E=n.indexOf(" "),h=n.slice(0,E),S=n.slice(E+1),p,T;try{switch(h){case"Basic":let A=atob(S),g=A.indexOf(":");p=A.slice(0,g),T=A.slice(g+1),d=p||T?await et.getUser(p,T,e):null;break;case"Bearer":try{d=await(0,ef.validateOperationToken)(S)}catch(L){if(L.message==="invalid token")try{return await(0,ef.validateRefreshToken)(S),c({status:-1})}catch{throw L}}break}}catch(A){return w8&&(uo.get(S)||(uo.set(S,S),l(p,vt.AUTH_AUDIT_STATUS.FAILURE,h))),c({status:401,body:lo({error:A.message},e)})}uo.set(n,d),I8&&l(d.username,vt.AUTH_AUDIT_STATUS.SUCCESS,h)}e.user=d}else _?.user?e.user=await et.getUser(_.user,null,e):(BU&&(e.ip?.includes("127.0.0.1")||e.ip=="::1")||e?._nodeRequest?.socket?.server?._pipeName&&e.ip===void 0)&&(e.user=await(0,UU.getSuperUser)());Zd&&(e.session.update=function(E){if(!u){u=(0,PU.v4)();let S=`${(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session="}${u}; Path=/; Expires=Tue, 01 Oct 8307 19:33:20 GMT; HttpOnly${e.protocol==="https"?"; SameSite=None; Secure":""}`;o?o.push("Set-Cookie",S):f?.headers?.set&&f.headers.set("Set-Cookie",S)}return e.protocol==="https"&&(o?(i&&o.push("Access-Control-Expose-Headers","X-Hdb-Session"),o.push("X-Hdb-Session","Secure")):f?.headers?.set&&(i&&f.headers.set("Access-Control-Expose-Headers","X-Hdb-Session"),f.headers.set("X-Hdb-Session","Secure"))),E.id=u,LU.put(E)},e.login=async function(E,h){e.user=await et.getUser(E,h,e),e.session.update({user:e.user.username})},(d&&!_||_?.user?.username!==d?.username)&&r["user-agent"]?.startsWith("Mozilla")&&e.session.update({user:e.user.username}));let f=await t(e);return f&&(f.status===401&&(r["user-agent"]?.startsWith("Mozilla")&&r.accept?.startsWith("text/html")&&Ti.loginPath?(f.status=302,f.headers.set("Location",Ti.loginPath(e))):f.headers.set("WWW-Authenticate","Basic")),c(f))}catch(u){throw c(u)}function c(u){let _=o.length;if(_>0){let l=u.headers;l||(u.headers=l=new gi);for(let d=0;d<_;){let f=o[d++];l.set(f,o[d++])}}return o=null,u}a(c,"applyResponseHeaders")}function D8({server:e,port:t}){e.http(HU,{port:t||"all"}),MU||(MU=!0,setInterval(()=>{uo=new Map},dn.get(vt.CONFIG_PARAMS.AUTHENTICATION_CACHETTL)).unref(),vU.user.addListener(()=>{uo=new Map}))}async function L8(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 M8(e){if(!e.baseRequest.session)throw new Error("No session for logout");return await e.baseRequest.session.update({user:null}),"Logout successful"}var UU,ef,PU,dn,vt,ga,vU,DU,O8,b8,y8,N8,LU,Zd,BU,I8,w8,uo,MU,tf=Re(()=>{UU=B(un());ar();Lu();ef=B(cu());Ae();PU=require("uuid"),dn=B(te()),vt=B(U()),ga=B(K()),vU=B(Gc());Mu();Ra();DU=(0,ga.loggerWithTag)("auth-event");dn.initSync();O8=dn.get(vt.CONFIG_PARAMS.HTTP_CORSACCESSLIST),b8=dn.get(vt.CONFIG_PARAMS.HTTP_CORS),y8=dn.get(vt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORSACCESSLIST),N8=dn.get(vt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORS),LU=ut({table:"hdb_session",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"user"}]}),Zd=dn.get(vt.CONFIG_PARAMS.AUTHENTICATION_ENABLESESSIONS)??!0,BU=dn.get(vt.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE,I8=dn.get(vt.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)??!1,w8=dn.get(vt.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)??!1,uo=new Map;et.onInvalidatedUser(()=>{uo=new Map});a(C8,"bypassAuth");a(HU,"authentication");a(D8,"start");a(L8,"login");a(M8,"logout")});var $U=R((tEe,VU)=>{"use strict";var Ie=require("joi"),xU=require("fs-extra"),GU=require("path"),Ls=rt(),FU=te(),qU=U(),kU=K(),{hdb_errors:U8}=ne(),{HDB_ERROR_MSGS:er}=U8,Ds=/^[a-zA-Z0-9-_]+$/;VU.exports={getDropCustomFunctionValidator:v8,setCustomFunctionValidator:B8,addComponentValidator:F8,dropCustomFunctionProjectValidator:q8,packageComponentValidator:k8,deployComponentValidator:V8,setComponentFileValidator:H8,getComponentFileValidator:G8,dropComponentFileValidator:x8};function rf(e,t,r){try{let n=FU.get(qU.CONFIG_PARAMS.COMPONENTSROOT),s=GU.join(n,t);return xU.existsSync(s)?e?t:r.message(er.PROJECT_EXISTS):e?r.message(er.NO_PROJECT):t}catch(n){return kU.error(n),r.message(er.VALIDATION_ERR)}}a(rf,"checkProjectExists");function Pu(e,t){return e.includes("..")?t.message("Invalid file path"):e}a(Pu,"checkFilePath");function P8(e,t,r,n){try{let s=FU.get(qU.CONFIG_PARAMS.COMPONENTSROOT),i=GU.join(s,e,t,r+".js");return xU.existsSync(i)?r:n.message(er.NO_FILE)}catch(s){return kU.error(s),n.message(er.VALIDATION_ERR)}}a(P8,"checkFileExists");function v8(e){let t=Ie.object({project:Ie.string().pattern(Ds).custom(rf.bind(null,!0)).required().messages({"string.pattern.base":er.BAD_PROJECT_NAME}),type:Ie.string().valid("helpers","routes").required(),file:Ie.string().pattern(Ds).custom(P8.bind(null,e.project,e.type)).custom(Pu).required().messages({"string.pattern.base":er.BAD_FILE_NAME})});return Ls.validateBySchema(e,t)}a(v8,"getDropCustomFunctionValidator");function B8(e){let t=Ie.object({project:Ie.string().pattern(Ds).custom(rf.bind(null,!0)).required().messages({"string.pattern.base":er.BAD_PROJECT_NAME}),type:Ie.string().valid("helpers","routes").required(),file:Ie.string().custom(Pu).required(),function_content:Ie.string().required()});return Ls.validateBySchema(e,t)}a(B8,"setCustomFunctionValidator");function H8(e){let t=Ie.object({project:Ie.string().pattern(Ds).required().messages({"string.pattern.base":er.BAD_PROJECT_NAME}),file:Ie.string().custom(Pu).required(),payload:Ie.string().allow("").optional(),encoding:Ie.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return Ls.validateBySchema(e,t)}a(H8,"setComponentFileValidator");function x8(e){let t=Ie.object({project:Ie.string().pattern(Ds).required().messages({"string.pattern.base":er.BAD_PROJECT_NAME}),file:Ie.string().custom(Pu).optional()});return Ls.validateBySchema(e,t)}a(x8,"dropComponentFileValidator");function G8(e){let t=Ie.object({project:Ie.string().required(),file:Ie.string().custom(Pu).required(),encoding:Ie.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return Ls.validateBySchema(e,t)}a(G8,"getComponentFileValidator");function F8(e){let t=Ie.object({project:Ie.string().pattern(Ds).custom(rf.bind(null,!1)).required().messages({"string.pattern.base":er.BAD_PROJECT_NAME})});return Ls.validateBySchema(e,t)}a(F8,"addComponentValidator");function q8(e){let t=Ie.object({project:Ie.string().pattern(Ds).custom(rf.bind(null,!0)).required().messages({"string.pattern.base":er.BAD_PROJECT_NAME})});return Ls.validateBySchema(e,t)}a(q8,"dropCustomFunctionProjectValidator");function k8(e){let t=Ie.object({project:Ie.string().pattern(Ds).required().messages({"string.pattern.base":er.BAD_PROJECT_NAME}),skip_node_modules:Ie.boolean()});return Ls.validateBySchema(e,t)}a(k8,"packageComponentValidator");function V8(e){let t=Ie.object({project:Ie.string().pattern(Ds).required().messages({"string.pattern.base":er.BAD_PROJECT_NAME}),payload:Ie.string().optional().messages({"string.pattern.base":er.BAD_PACKAGE}),package:Ie.string().optional()});return Ls.validateBySchema(e,t)}a(V8,"deployComponentValidator")});var af=R((nEe,XU)=>{"use strict";var nf=require("joi"),sf=require("path"),YU=require("fs-extra"),{exec:$8}=require("child_process"),Y8=require("util"),KU=Y8.promisify($8),vu=U(),{handleHDBError:Aa,hdb_errors:K8}=ne(),{HTTP_STATUS_CODES:Oa}=K8,Bu=te(),W8=rt(),ba=K();Bu.initSync();var GT=Bu.get(vu.CONFIG_PARAMS.COMPONENTSROOT),WU="npm install --omit=dev --json",Q8=`${WU} --dry-run`;XU.exports={installModules:j8,auditModules:Z8,installAllRootModules:z8,uninstallRootModule:J8,linkHarperdb:X8};async function z8(e=!1){await of(),await Hu(e?"npm install --ignore-scripts":"npm install",Bu.get(vu.CONFIG_PARAMS.ROOTPATH))}a(z8,"installAllRootModules");async function J8(e){await Hu(`npm uninstall ${e}`,Bu.get(vu.CONFIG_PARAMS.ROOTPATH))}a(J8,"uninstallRootModule");async function X8(){await of(),await Hu(`npm link ${vu.PACKAGE_ROOT}`,Bu.get(vu.CONFIG_PARAMS.ROOTPATH))}a(X8,"linkHarperdb");async function Hu(e,t=void 0){let r,n;try{({stdout:r,stderr:n}=await KU(e,{cwd:t}))}catch(s){throw new Error(s.stderr.replace(`
@@ -27,6 +27,6 @@ Database backup has not been removed and can be found here: ${s}`;Nu.error(u),co
27
27
  Connection: close\r
28
28
  \r
29
29
  `))}},25).unref()}o.close?.(()=>{if(xe.get(ft.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&fE()==0)try{JB(xe.get(ft.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET))}catch{}clearInterval(c),setTimeout(()=>{console.log("forced close server",i,_E),o.cantCleanupProperly||Dt.warn("Had to forcefully exit the thread",_E),process.exit(0)},5e3).unref()})}if(iH||process.env.DEV_MODE)try{require("inspector").close()}catch(i){Dt.info("Could not close debugger",i)}}}).ref();let e=[];if(XB&&!Mre)for(let t in ls){let r=ls[t];if(isNaN(t)&&fE()==0){Rre(t)&&JB(t),e.push(new Promise((s,i)=>{r.listen({path:t},()=>{s(),Dt.info("Domain socket listening on "+t)}).on("error",i)}));continue}let n;try{n=XB(+t,"::")}catch(s){console.error(`Unable to bind to port ${t}`,s);continue}e.push(new Promise((s,i)=>{r.listen({fd:n},()=>{s(),Dt.trace("Listening on port "+t,_E)}).on("error",i)}))}Promise.all(e).then(()=>{fl?.postMessage({type:ft.ITC_EVENT_TYPES.CHILD_STARTED})})})}a(oH,"startServers");eH||oH();function DR(e,t,r){let n=e?.read?e:new hre({fd:e,readable:!0,writable:!0,allowHalfOpen:!0}),s=ls[t];if(s.isSecure&&(n.startTime=performance.now()),s)typeof s=="function"?s(n):s.emit("connection",n),r&&n.emit("data",r);else{let i=a(o=>{setTimeout(()=>{let c=ls[t];c?(typeof c=="function"?c(n):c.emit("connection",n),r&&n.emit("data",r)):o<5?i(o+1):(Dt.error(`Server on port ${t} was not registered`),n.destroy())},1e3)},"retry");i(1)}return n}a(DR,"deliverSocket");var jB=new Map;function vre(e){let{port:t,event:r,data:n,requestId:s}=e,i;switch(i=jB.get(s),r){case"connection":i=DR(void 0,t),jB.set(s,i),i.write=(c,u,_)=>(fl.postMessage({requestId:s,event:"data",data:c.toString("latin1")}),_&&_(),!0),i.end=(c,u,_)=>(fl.postMessage({requestId:s,event:"end",data:c?.toString("latin1")}),_&&_(),!0);let o=i.destroy;i.destroy=()=>{o.call(i),fl.postMessage({requestId:s,event:"destroy"})};break;case"data":i._readableState.destroyed||i.emit("data",Buffer.from(n,"latin1"));break;case"drain":i._readableState.destroyed||i.emit("drain",{});break;case"end":i._readableState.destroyed||i.emit("end",{});break;case"error":i._readableState.destroyed||i.emit("error",{});break}}a(vre,"proxyRequest");function LR(e,t,r=!0){!+t&&t!==xe.get(ft.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&(t=parseInt(xe.get(ft.CONFIG_PARAMS.HTTP_PORT),10));let n=ls[t];if(n){let s=n.lastServer||n;if(s===e)throw new Error(`Can not register the same server twice for the same port ${t}`);if(r&&!!s.sessionIdContext!=!!e.sessionIdContext&&+t)throw new Error(`Can not mix secure HTTPS and insecure HTTP on the same port ${t}`);s.off("unhandled",ZB),s.on("unhandled",(i,o)=>{e.cantCleanupProperly&&(n.cantCleanupProperly=!0),e.emit("request",i,o)}),n.lastServer=e}else ls[t]=e;e.on("unhandled",ZB)}a(LR,"registerServer");function aH(e){let t=[],r=parseInt(e?.securePort);return r&&t.push({port:r,secure:!0}),r=parseInt(e?.port),r&&t.push({port:r,secure:!1}),t.length===0&&(t=[],xe.get(ft.CONFIG_PARAMS.HTTP_PORT)!=null&&t.push({port:xe.get(ft.CONFIG_PARAMS.HTTP_PORT),secure:xe.get(ft.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS)}),xe.get(ft.CONFIG_PARAMS.HTTP_SECUREPORT)!=null&&t.push({port:xe.get(ft.CONFIG_PARAMS.HTTP_SECUREPORT),secure:!0})),e?.isOperationsServer&&xe.get(ft.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&t.push({port:xe.get(ft.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET),secure:!1}),t}a(aH,"getPorts");function MR(e,t){for(let{port:r,secure:n}of aH(t))cH(r,n,t?.isOperationsServer),typeof e=="function"?wR[t?.runFirst?"unshift":"push"]({listener:e,port:t?.port||r}):(e.isSecure=n,LR(e,r,!1)),EE[r]=CR(wR,r),Ure=CR(Pre,r)}a(MR,"httpServer");function cH(e,t,r){if(!ks[e]){let n=r?"operationsApi_network":"http",s={keepAliveTimeout:xe.get(n+"_keepAliveTimeout"),headersTimeout:xe.get(n+"_headersTimeout"),requestTimeout:xe.get(n+"_timeout")},i=xe.get(n+"_mtls"),o=xe.get(n+"_mtls_required");if(t){n=r?"operationsApi_":"";let u=xe.get(n+"tls");Object.assign(s,{allowHTTP1:!0,rejectUnauthorized:!!o,requestCert:!!i,ticketKeys:tH(),maxHeaderSize:xe.get(ft.CONFIG_PARAMS.HTTP_MAXHEADERSIZE),SNICallback:lH(u)})}let c=wre();ks[e]=(t?Tre:pre)(s,async(u,_)=>{try{let d=performance.now(),f=new nH(u,_);r&&(f.isOperationsServer=!0);let E=await EE[e](f);if(!E){if(f._nodeResponse.statusCode)return;E=uH(f)}if(c?E.headers?.set?.("Server","Unlicensed HarperDB, this should only be used for educational and development purposes"):E.headers?.set?.("Server","HarperDB"),E.status===-1){for(let v of E.headers||[])_.setHeader(v[0],v[1]);return u.baseRequest=f,_.baseResponse=E,ks[e].emit("unhandled",u,_)}let h=E.status||200,S=performance.now(),p=S-d,T=E.body,A;if(!E.handlesHeaders){let v=E.headers||new rH;T?T.length>=0&&(typeof T=="string"?v.set("Content-Length",Buffer.byteLength(T)):v.set("Content-Length",T.length),A=!0):(v.set("Content-Length","0"),A=!0);let P=`hdb;dur=${p.toFixed(2)}`;E.wasCacheMiss&&(P+=", miss"),Nre(v,"Server-Timing",P,!0),_.writeHead(h,v&&(v[Symbol.iterator]?Array.from(v):v)),A&&_.end(T)}let g=f.handlerPath,L=f.method;if(dl(p,"duration",g,L,E.wasCacheMiss==null?void 0:E.wasCacheMiss?"cache-miss":"cache-hit"),Ire(h<400,"success",g,L),!A)if(T?.pipe){T.pipe(_),T.destroy&&_.on("close",()=>{T.destroy()});let v=0;T.on("data",P=>{v+=P.length}),T.on("end",()=>{dl(performance.now()-S,"transfer",g,L),dl(v,"bytes-sent",g,L)})}else T?.then?T.then(v=>{_.end(v)},l):_.end(T)}catch(d){l(d)}function l(d){let f=d.headers;_.writeHead(d.statusCode||500,f&&(f[Symbol.iterator]?Array.from(f):f)),_.end(d.toString()),d.statusCode?d.statusCode===500?Dt.warn(d):Dt.info(d):Dt.error(d)}a(l,"onError")}),i&&(ks[e].mtlsConfig=i),t&&(ks[e].on("secureConnection",u=>{u._parent.startTime&&dl(performance.now()-u._parent.startTime,"tls-handshake",e),dl(u.isSessionReused(),"tls-reused",e)}),ks[e].isSecure=!0,s.SNICallback(null,(u,_)=>{try{ka=_,_&&ks[e].setSecureContext(_.options)}finally{ka=null}})),LR(ks[e],e)}return ks[e]}a(cH,"getHTTPServer");function CR(e,t){let r=uH;for(let n=e.length;n>0;){let{listener:s,port:i}=e[--n];if(i===t||i==="all"){let o=r;r=a(c=>s(c,o),"next_callback")}}return r}a(CR,"makeCallbackChain");function uH(e){return e.user&&(e._nodeRequest.user=e.user),{status:-1,body:"Not found",headers:new rH}}a(uH,"unhandled");function Bre(e,t){MR(e,{requestOnly:!0,...t})}a(Bre,"onRequest");function Hre(e,t){let r;if(t.securePort){let n=Object.assign({},xe.get("tls"));t.mtls?.certificateAuthority&&(n.certificateAuthority=t.mtls.certificateAuthority);let s={rejectUnauthorized:!!t.mtls?.required,requestCert:!!t.mtls,SNICallback:lH(n)};r=bre(s,e),s.SNICallback(null,(i,o)=>{try{ka=o,o&&r.setSecureContext(o.options)}finally{ka=null}}),ls[t.securePort]=r}return t.port&&(r=mre(e),ls[t.port]=r),r}a(Hre,"onSocket");Object.defineProperty(Sre.prototype,"upgrade",{get(){return"connection"in this.headers&&"upgrade"in this.headers&&this.headers.connection.startsWith("Upgrade")&&this.headers.upgrade.toLowerCase()=="websocket"},set(e){}});function xre(e,t){let r;for(let{port:n,secure:s}of aH(t)){dE[n]||(dE[n]=new Are({server:r=cH(n,s)}),dE[n].on("connection",async(c,u)=>{try{let _=new nH(u);_.isWebSocket=!0;let l=EE[n](_),d=u.headers["sec-websocket-protocol"]||"",f=NR[n];if(d){let E;for(let h=0;h<f.length;h++){let S=f[h];S.protocol===d&&(E=!0,S.listener(c,_,l))}if(E)return}for(let E=0;E<f.length;E++){let h=f[E];h.protocol||h.listener(c,_,l)}}catch(_){Dt.warn("Error handling WebSocket connection",_)}}),dE[n].on("error",c=>{console.log("Error in setting up WebSocket server",c)}));let i=t?.subProtocol||"",o=NR[n];o||(o=NR[n]=[]),o.push({listener:e,protocol:i}),EE[n]=CR(wR,n)}return r}a(xre,"onWebSocket");function ZB(e,t){t.writeHead(404),t.end(`Not found
30
- `)}a(ZB,"defaultNotFound");function IR(e){return e.startsWith("-----BEGIN")?e:gre(e)}a(IR,"readPEM");function lH(e){let t=[];for(let s=0;e[s];s++)t.push(e[s]);t.length||t.push(e);let r=new Map,n;for(let s of t){let i=IR(s.privateKey),o=IR(s.certificate),c=s.certificateAuthority&&IR(s.certificateAuthority);if(!i||!o)throw new Error("Missing private key or certificate for secure server");let u={ciphers:xe.get("tls_ciphers"),ca:c,ticketKeys:tH()},_=Ore(u);_.options=u,u.instantiatedContext=_,_.context.setCert(o),_.context.setKey(i,void 0),u.cert=o,u.key=i,_.certStart=o.subarray(0,100).toString(),n||(n=_);let l=new Cre(o),d=s.hostname??s.host??s.hostnames??s.hosts??(l.subjectAltName?l.subjectAltName.split(",").map(f=>{let E=f.indexOf(":");return f.slice(E+1)}):[l.subject.match(/CN=(.*)/)?.[1]]);Array.isArray(d)||(d=[d]);for(let f of d)f?r.has(f)||r.set(f,_):Dt.error("No hostname found for certificate at",s.certificate)}return(s,i)=>{let o=r.get(s);o?(Dt.debug("Found certificate for",s,o.certStart),i(null,o)):(Dt.debug("No certificate found to match",s,"using the first certificate"),i(null,n))}}a(lH,"createSNICallback")});async function hH({clientId:e,user:t,clean:r,will:n,keepalive:s}){let i;if(e&&!r){let o=await PR.get(e,{returnNonexistent:!0});i=new HR(e,t,o),o&&(i.sessionWasPresent=!0)}else{if(e){let o=await PR.get(e);o&&o.delete()}i=new pE(e,t)}return n&&(n.id=e,n.user={username:t?.username},El.put(n)),s&&(i.keepalive=s,i.receivedPacket()),i}function vR(){return mE++,mE>65500&&(mE=1),mE}function BR(e,t,r){let{topic:n,retain:s}=e;e.data=t,e.async=!0,r.authorize=!0;let i=Ti.getMatch(n);if(!i)throw new Error(`Can not publish to topic ${n} as it does not exist, no resource has been defined to handle this topic`);e.url=i.relativeURL;let o=i.Resource;return ze(r,()=>s?t===void 0?o.delete(e,r):o.put(e,e.data,r):o.publish(e,e.data,r))}var dH,Ii,fH,EH,PR,El,mE,pE,HR,mH=Re(()=>{Ae();Lu();dH=B(Mr()),Ii=B(K());Zi();fH=B(ct()),EH=B(_H());ar();PR=ut({database:"system",table:"hdb_durable_session",attributes:[{name:"id",isPrimaryKey:!0},{name:"subscriptions",type:"array",elements:{attributes:[{name:"topic"},{name:"qos"},{name:"startTime"},{name:"acks"}]}}]}),El=ut({database:"system",table:"hdb_session_will",attributes:[{name:"id",isPrimaryKey:!0},{name:"topic",type:"string"},{name:"data"},{name:"qos",type:"number"},{name:"retain",type:"boolean"},{name:"user",type:"any"}]});(0,fH.getWorkerIndex)()===0&&(async()=>{await EH.when_components_loaded,await new Promise(e=>setTimeout(e,2e3));for await(let e of El.search({})){let t=e.data,r=Object.assign({},e);r.user?.username&&(r.user=await et.getUser(r.user.username)),ze(r,()=>{try{BR(r,t,r)}catch{(0,Ii.warn)("Failed to publish will",t)}El.delete(e.id,r)})}})();a(hH,"getSession");mE=1;a(vR,"getNextMessageId");pE=class{static{a(this,"SubscriptionsSession")}listener;sessionId;user;request;socket;subscriptions=[];awaitingAcks;sessionWasPresent;keepalive;keepaliveTimer;constructor(t,r){this.sessionId=t,this.user=r}async addSubscription(t,r,n){let{topic:s,rh:i,startTime:o}=t,c=s.indexOf("?"),u,_;if(c>-1?(u=s.slice(c),_=s.slice(0,c)):_=s,!_)throw new Error("No topic provided");if(_.indexOf(".")>-1)throw new Error("Dots are not allowed in topic names");let l=this.subscriptions.find(T=>T.topic===s),d;l?(d=i>0,l.end(),this.subscriptions.splice(this.subscriptions.indexOf(l),1)):d=i===2;let f={search:u,async:!0,user:this.user,startTime:o,omitCurrent:d,url:""};o&&(0,Ii.trace)("Resuming subscription from",s,"from",o);let E=Ti.getMatch(_);if(!E){let T=new Error(`The topic ${s} does not exist, no resource has been defined to handle this topic`);throw T.statusCode=404,T}if(f.url=E.relativeURL,f.url.indexOf("+")>-1||f.url.indexOf("#")>-1){let T=f.url.slice(1);if(T.indexOf("#")>-1&&T.indexOf("#")!==T.length-1)throw new Error("Multi-level wildcards can only be used at the end of a topic");if(f.isCollection=!0,T.indexOf("+")===T.length-1)f.onlyChildren=!0,f.url="/"+T.slice(0,T.length-1);else{let A=T.split("/"),g;for(let P=0;P<A.length;P++)if(A[P].indexOf("+")>-1)if(A[P]==="+")g=!0;else throw new Error("Single-level wildcards can only be used as a topic level (between or after slashes)");if(n&&g)throw new Error("Filters can not be combined");let L=!0;A[A.length-1]==="#"&&(A.length--,L=!1),g&&(n=a(P=>{let k=P.id;if(!Array.isArray(k)||L&&k.length!==A.length)return!1;for(let H=0;H<A.length;H++)if(A[H]!=="+"&&A[H]!==k[H])return!1;return!0},"filter"));let v=A.indexOf("+");f.url="/"+(v>-1?A.slice(0,v):A).concat("").join("/")}}let h=E.path,S=E.Resource,p=await ze(f,async()=>{let T=this.createContext();T.topic=s,T.retainHandling=i;let A=await S.subscribe(f,T);if(!A)throw new Error(`No subscription was returned from subscribe for topic ${s}`);if(!A[Symbol.asyncIterator])throw new Error(`Subscription is not (async) iterable for topic ${s}`);return(async()=>{for await(let g of A)try{let L;if(g.type&&g.type!=="put"&&g.type!=="delete"&&g.type!=="message"&&g.type!=="patch"||n&&!n(g))continue;r?(g.topic=s,L=this.needsAcknowledge(g)):(g.acknowledge?.(),L=vR());let v=g.id;Array.isArray(v)&&(v=Ta(v)),v==null&&(v=""),this.listener(h+"/"+v,g.value,L,t)}catch(L){(0,Ii.warn)(L)}})(),A});return p.topic=s,p.qos=t.qos,this.subscriptions.push(p),p}resume(){}needsAcknowledge(t){let r=vR();return t.acknowledge&&(this.awaitingAcks||(this.awaitingAcks=new Map),this.awaitingAcks.set(r,t.acknowledge)),r}acknowledge(t){let r=this.awaitingAcks?.get(t);r&&(this.awaitingAcks.delete(t),r())}async removeSubscription(t){let r=this.subscriptions.find(n=>n.topic===t);if(r)return r.end(),this.subscriptions.splice(this.subscriptions.indexOf(r),1),!0}async publish(t,r){return BR(t,r,this.createContext())}createContext(){let t={session:this,socket:this.socket,user:this.user,authorize:!0};return this.request&&(t.request=this.request,t.url=this.request.url,t.headers=this.request.headers),t}setListener(t){this.listener=t}disconnect(t){this.keepaliveTimer&&clearTimeout(this.keepaliveTimer);let r=this.createContext();ze(r,async()=>{try{if(!t){let n=await El.get(this.sessionId);n?.doesExist()&&await BR(n,n.data,r)}}finally{await El.delete(this.sessionId)}}).catch(n=>{(0,Ii.warn)(`Error publishing MQTT will for ${this.sessionId}`,n)});for(let n of this.subscriptions)n.end();this.subscriptions=[]}receivedPacket(){this.keepalive&&(clearTimeout(this.keepaliveTimer),this.keepaliveTimer=setTimeout(()=>{this.disconnect(!1)},this.keepalive*1500))}};a(BR,"publish");HR=class extends pE{static{a(this,"DurableSubscriptionsSession")}sessionRecord;constructor(t,r,n){super(t,r),this.sessionRecord=n||{id:t,subscriptions:[]}}async resume(){for(let t of this.sessionRecord.subscriptions||[])await this.resumeSubscription({omitCurrent:!0,topic:t.topic,qos:t.qos,startTime:t.startTime},!0,t.acks?r=>!t.acks.includes(r.timestamp):null)}resumeSubscription(t,r,n){return super.addSubscription(t,r,n)}needsAcknowledge(t){this.awaitingAcks||(this.awaitingAcks=new Map);let r=vR(),n={topic:t.topic,timestamp:t.timestamp};return t.acknowledge&&(n.acknowledge=t.acknowledge),this.awaitingAcks.set(r,n),r}acknowledge(t){let r=this.awaitingAcks.get(t);this.awaitingAcks.delete(t),r.acknowledge?.();let n=r.topic;for(let[,s]of this.awaitingAcks)if(s.topic===n&&s.timestamp<r.timestamp){for(let i of this.sessionRecord.subscriptions)if(i.topic===n){i.acks||(i.acks=[]),i.acks.push(r.timestamp),(0,Ii.trace)("Received ack",n,r.timestamp),this.sessionRecord.update();return}}for(let s of this.sessionRecord.subscriptions)s.topic===n&&(s.startTime=r.timestamp);this.sessionRecord.update()}async addSubscription(t,r){await this.resumeSubscription(t,r);let{qos:n,startTime:s}=t;return n>0&&!s&&this.saveSubscriptions(),t.qos}removeSubscription(t){let r=this.subscriptions.find(s=>s.topic===t),n=super.removeSubscription(t);return r.qos>0&&this.saveSubscriptions(),n}saveSubscriptions(){this.sessionRecord.subscriptions=this.subscriptions.map(t=>{let r=t.startTime;return r||(r=t.startTime=(0,dH.getNextMonotonicTime)()),(0,Ii.trace)("Added durable subscription",t.topic,r),{qos:t.qos,topic:t.topic,startTime:r}}),PR.put(this.sessionRecord)}}});var GR={};Fe(GR,{bypassAuth:()=>Gre,start:()=>Fre});function Gre(){RH=!0}function Fre({server:e,port:t,network:r,webSocket:n,securePort:s,requireAuthentication:i}){e.mqtt||(e.mqtt={requireAuthentication:i,sessions:new Set,events:new gH.EventEmitter},e.mqtt.events.on("error",()=>{}));let o=e.mqtt,c,u=r?.mtls;return n&&(c=e.ws((_,l,d)=>{if(_.protocol==="mqtt"){o.events.emit("connection",_),rr.debug("Received WebSocket connection for MQTT from",_._socket.remoteAddress);let{onMessage:f,onClose:E}=SH(_,(h,S)=>{if(_.send(h),S&&_._socket.writableNeedDrain)return new Promise(p=>this._socket.once("drain",p))},l,Promise.resolve(d).then(()=>l?.user),o);_.on("message",f),_.on("close",E),_.on("error",h=>{rr.info("WebSocket error",h)})}},Object.assign({subProtocol:"mqtt"},n))),(t||s)&&(c=e.socket(async _=>{let l;if(o.events.emit("connection",_),rr.debug(`Received ${_.getCertificate?"SSL":"TCP"} connection for MQTT from ${_.remoteAddress}`),u){if(_.authorized)try{let E=u.user;if(E!==null){(E===void 0||E==="Common Name"||E==="CN")&&(E=_.getPeerCertificate().subject.CN);try{l=await e.getUser(E,null,null),(0,Va.get)(Qt.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&TE.notify({username:l?.username,status:Qt.AUTH_AUDIT_STATUS.SUCCESS,type:Qt.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"MQTT mTLS",remote_address:_.remoteAddress})}catch(h){throw(0,Va.get)(Qt.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&TE.error({username:E,status:Qt.AUTH_AUDIT_STATUS.FAILURE,type:Qt.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"mqtt",remote_address:_.remoteAddress}),h}}else rr.debug("MQTT mTLS authorized connection (mTLS did not authorize a user)","from",_.remoteAddress)}catch(E){o.events.emit("error",E,_),rr.error(E)}else if(u.required)return rr.info(`Unauthorized connection attempt, no authorized client certificate provided, error: ${_.authorizationError}`),_.end()}!l&&RH&&_.remoteAddress.includes("127.0.0.1")&&(l=await(0,TH.getSuperUser)(),rr.debug("Auto-authorizing local connection",l?.username));let{onMessage:d,onClose:f}=SH(_,E=>_.write(E),null,l,o);_.on("data",d),_.on("close",f),_.on("error",E=>{rr.info("Socket error",E)})},{port:t,securePort:s,mtls:u})),c}function SH(e,t,r,n,s){pH||(pH=!0,ju(d=>{SE>0&&d.push({metric:"mqtt-connections",connections:SE,byThread:!0})}));let i;SE++;let o,c={protocolVersion:4},u=(0,gE.parser)({protocolVersion:5});function _(d){u.parse(d)}a(_,"onMessage");function l(){SE--,i||(i=!0,o?.disconnect?.(),s.events.emit("disconnected",o,e),s.sessions.delete(o),Qr(!1,"connection","mqtt","disconnect"),rr.debug("MQTT connection was closed",e.remoteAddress))}return a(l,"onClose"),u.on("packet",async d=>{n?.then&&(n=await n),o?.then&&await o;try{switch(o?.receivedPacket?.(),d.cmd){case"connect":if(c.protocolVersion=d.protocolVersion,d.username)try{n=await et.getUser(d.username,d.password.toString(),r),(0,Va.get)(Qt.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&TE.notify({username:n?.username,status:Qt.AUTH_AUDIT_STATUS.SUCCESS,type:Qt.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"MQTT",remote_address:e.remoteAddress})}catch(g){return(0,Va.get)(Qt.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&TE.error({username:d.username,status:Qt.AUTH_AUDIT_STATUS.FAILURE,type:Qt.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"mqtt",remote_address:e.remoteAddress}),s.events.emit("auth-failed",d,e,g),Qr(!1,"connection","mqtt","connect"),f({cmd:"connack",reasonCode:4,returnCode:134})}if(!n&&s.requireAuthentication)return s.events.emit("auth-failed",d,e),Qr(!1,"connection","mqtt","connect"),f({cmd:"connack",reasonCode:4,returnCode:134});try{if(s.authorizeClient?.(d,n),d.will){let g=e.deserialize||(e.deserialize=ho(r?.headers.get?.("content-type")));d.will.data=d.will.payload?.length>0?g(d.will.payload):void 0,delete d.will.payload}o=hH({user:n,...d}),o=await o,o.socket=e,r&&(o.request=r),s.sessions.add(o)}catch(g){return rr.error(g),s.events.emit("auth-failed",d,e,g),Qr(!1,"connection","mqtt","connect"),f({cmd:"connack",reasonCode:g.code||5,returnCode:g.code||128})}s.events.emit("connected",o,e),Qr(!0,"connection","mqtt","connect"),f({cmd:"connack",sessionPresent:o.sessionWasPresent,reasonCode:0,returnCode:0}),o.setListener((g,L,v,P)=>{try{let k=g.indexOf("/",1),H=k>0?g.slice(0,k):g;f({cmd:"publish",topic:g,payload:E(L),messageId:v||Math.floor(Math.random()*1e8),qos:P.qos},H)}catch(k){rr.error(k),o?.disconnect(),s.sessions.delete(o)}}),o.sessionWasPresent&&await o.resume();break;case"subscribe":let h=[];for(let g of d.subscriptions){let L;try{L=(await o.addSubscription(g,g.qos>=1)).qos||0}catch(v){s.events.emit("error",v,e,g,o),rr.error(v),L=c.protocolVersion<5?128:v.statusCode===403?135:v.statusCode===404?143:128}h.push(L)}await o.committed,f({cmd:"suback",granted:h,messageId:d.messageId});break;case"unsubscribe":{let g=[];for(let L of d.unsubscriptions)g.push(o.removeSubscription(L)?0:17);f({cmd:"unsuback",granted:g,messageId:d.messageId});break}case"pubrel":f({cmd:"pubcomp",messageId:d.messageId,reasonCode:0});return;case"publish":let S=d.qos===2?"pubrec":"puback",p=e.deserialize||(e.deserialize=ho(r?.headers.get?.("content-type"))),T=d.payload?.length>0?p(d.payload):void 0,A;try{A=await o.publish(d,T)}catch(g){s.events.emit("error",g,e,d,o),rr.warn(g),d.qos>0&&f({cmd:S,messageId:d.messageId,reasonCode:128},d.topic);break}d.qos>0&&f({cmd:S,messageId:d.messageId,reasonCode:A===!1?144:0},d.topic);break;case"pubrec":f({cmd:"pubrel",messageId:d.messageId,reasonCode:0});break;case"pubcomp":case"puback":o.acknowledge(d.messageId);break;case"pingreq":f({cmd:"pingresp"});break;case"disconnect":i=!0,o?.disconnect(!0),s.events.emit("disconnected",o,e),s.sessions.delete(o),Qr(!0,"connection","mqtt","disconnect"),rr.debug("Received disconnect command, closing MQTT session",e.remoteAddress),e.close?e.close():e.end();break}}catch(h){s.events.emit("error",h,e,d,o),rr.error(h),f({cmd:"disconnect"})}function f(h,S){let p=(0,gE.generate)(h,c);t(p),Wr(p.length,"bytes-sent",S,h.cmd,"mqtt")}a(f,"sendPacket");function E(h){return lo(h,r)}a(E,"serialize")}),{onMessage:_,onClose:l}}var gE,TH,Va,Qt,xR,gH,TE,rr,RH,pH,SE,AH=Re(()=>{gE=require("mqtt-packet");mH();TH=B(un());Ra();vs();ar();Va=B(te()),Qt=B(U()),xR=B(K()),gH=require("events"),TE=(0,xR.loggerWithTag)("auth-event"),rr=(0,xR.loggerWithTag)("mqtt"),RH=(0,Va.get)(Qt.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE;a(Gre,"bypassAuth");a(Fre,"start");SE=0;a(SH,"onSocket")});var lf={};Fe(lf,{component_errors:()=>Ya,loadComponent:()=>RE,loadComponentDirectories:()=>LH,setErrorReporter:()=>$re});function LH(e,t){t&&(qR=t),e&&(kR=e);let r=[];if((0,xn.existsSync)(FR)){let s=(0,xn.readdirSync)(FR,{withFileTypes:!0});for(let i of s){if(!i.isDirectory()&&!i.isSymbolicLink())continue;let o=i.name,c=(0,At.join)(FR,o);r.push(RE(c,qR,"hdb",!1))}}let n=process.env.RUN_HDB_APP;return n&&r.push(RE(n,qR,n,!1,null,process.env.DEV_MODE)),Promise.all(r).then(()=>{DH=!0})}function $re(e){ml=e}async function RE(e,t,r,n,s,i){if(!bH.has(e)){bH.set(e,!0),s&&(kR=s);try{let o;n&&(Ya=new Map);let c=(0,At.join)(e,n?"harperdb-config.yaml":"config.yaml");(0,xn.existsSync)(c)?o=n?(0,CH.getConfigObj)():(0,yH.parseDocument)((0,xn.readFileSync)(c,"utf8"),{simpleKeys:!0}).toJSON():o=VR;let u=[],_=n;for(let l in o){let d=o[l];if(Ya.set(n?l:(0,At.basename)(e),!1),!d)continue;let f,E=d.package;try{if(E){let A=e,g;for(;!(0,xn.existsSync)(g=(0,At.join)(A,"node_modules",l));)if(A=(0,At.dirname)(A),A.length<(0,wH.getHdbBasePath)().length){g=null;break}if(g)f=await RE(g,t,r,!1),_=!0;else throw new Error(`Unable to find package ${l}:${E}`)}else f=Vre[l];if(!f)continue;u.push(f);let h=a(A=>(A.origin=r,ut(A)),"ensureTable"),S=d.network||(d.port||d.securePort)&&d,p=S?.securePort||S?.https&&S.port,T=!S?.https&&S?.port;if($a.isMainThread&&(f=await f.startOnMainThread?.({server:et,ensureTable:h,port:T,securePort:p,resources:t,...d})||f,n&&S))for(let A of[T,p])try{if(+A&&!OH.includes(A)){let g=$R.get(YR.CONFIG_PARAMS.HTTP_SESSIONAFFINITY);g&&hl.default.warn("Session affinity is not recommended and may cause memory leaks"),(g||!iE)&&(OH.push(A),vB(A,g))}}catch(g){console.error("Error listening on socket",A,g,l)}if(t.isWorker&&(f=await f.start?.({server:et,ensureTable:h,port:T,securePort:p,resources:t,...d})||f),kR.set(f,!0),(f.handleFile||f.handleDirectory)&&d.files){if(d.files.includes(".."))throw(0,IH.handleHDBError)("Can not reference parent directories");let A=(0,At.join)(e,d.files).replace(/\\/g,"/"),g=A.indexOf("/*");if(g>-1&&d.files!==VR[l]?.files&&!(0,xn.existsSync)(A.slice(0,g)))throw new Error(`The path '${A.slice(0,g)}' does not exist and cannot be used as the base of the resolved 'files' path value '${d.files}'`);let L=(0,At.basename)(e),v=d.path||"/";v=v.startsWith("/")?v:v.startsWith("./")?"/"+L+v.slice(2):v==="."?"/"+L:"/"+L+"/"+v;let P,k,H;if(d.root){let z=d.root;z.startsWith("/")&&(z=z.slice(1)),z.endsWith("/")&&(z=z.slice(0,-1)),z+="/",k=(0,At.join)(e,z)}else(H=A.indexOf("/*"))>-1&&(k=A.slice(0,H+1),P=(0,At.relative)(e,k));let X=!1;if($a.isMainThread&&f.setupDirectory&&(X=await f.setupDirectory?.(v,k,t)),t.isWorker&&f.handleDirectory&&(X=await f.handleDirectory?.(v,k,t)),X)continue;for(let z of await(0,NH.default)(A,{onlyFiles:!1,objectMode:!0})){let{path:J,dirent:me}=z;_=!0;let ce=(0,At.relative)(e,J).replace(/\\/g,"/");if(P)if(ce.startsWith(P))ce=ce.slice(P.length+1);else throw new Error(`The root path '${d.root}' does not reference a valid part of the file path '${ce}'.The root path should be used to indicate the relative path/part of the file path for determining the exported web path.`);let de=v+(v.endsWith("/")?"":"/")+ce;try{if(me.isFile()){let De=await kre(J);$a.isMainThread&&await f.setupFile?.(De,de,J,t),t.isWorker&&await f.handleFile?.(De,de,J,t)}else $a.isMainThread&&await f.setupDirectory?.(de,J,t),t.isWorker&&await f.handleDirectory?.(de,J,t)}catch(De){De.message=`Could not load ${me.isFile()?"file":"directory"} '${J}'${d.module?" using '"+d.module+"'":""} for application '${e}' due to: ${De.message}`,ml?.(De),((0,Ka.getWorkerIndex)()===0?console:hl.default).error(De),t.set(d.path||"/",new pl(De)),Ya.set(n?l:(0,At.basename)(e),De.message)}}}}catch(h){h.message=`Could not load component '${l}' for application '${(0,At.basename)(e)}' due to: ${h.message}`,ml?.(h),((0,Ka.getWorkerIndex)()===0?console:hl.default).error(h),t.set(d.path||"/",new pl(h),null,!0),Ya.set(n?l:(0,At.basename)(e),h.message)}}if($a.isMainThread&&!DH&&i&&(0,Ka.watchDir)(e,async()=>LH()),o.extensionModule)return await t_((0,At.join)(e,o.extensionModule));if(!_&&t.isWorker){let l=`${e} did not load any modules, resources, or files, is this a valid component?`;ml?.(new Error(l)),((0,Ka.getWorkerIndex)()===0?console:hl.default).error(l),Ya.set((0,At.basename)(e),l)}}catch(o){console.error(`Could not load application directory ${e}`,o),o.message=`Could not load application due to ${o.message}`,ml?.(o),t.set("",new pl(o))}}}var xn,At,$a,yH,$R,YR,NH,Ka,hl,IH,wH,qre,CH,kre,FR,kR,DH,qR,Ya,Vre,VR,OH,bH,ml,pl,_f=Re(()=>{xn=require("fs"),At=require("path"),$a=require("worker_threads"),yH=require("yaml"),$R=B(te()),YR=B(U());JO();eb();tb();Hv();bB();DB();NH=B(require("fast-glob")),Ka=B(ct()),hl=B(K());vh();ar();IH=B(ne());bn();Ae();BB();wH=B(te()),qre=B(qB());tf();zB();AH();CH=B(dr());oE();({readFile:kre}=xn.promises),FR=$R.get(YR.CONFIG_PARAMS.COMPONENTSROOT),kR=new Map,Ya=new Map;a(LH,"loadComponentDirectories");Vre={REST:Mf,rest:Mf,graphqlSchema:Ph,jsResource:Hh,fastifyRoutes:uR,login:Gh,static:lR,operationsApi:qre,customFunctions:{},http:{},clustering:bR,authentication:Uu,mqtt:GR},VR={rest:!0,graphqlSchema:{files:"*.graphql"},jsResource:{files:"resources.js"},fastifyRoutes:{files:"routes/*.js",path:"."}};Object.defineProperty(VR,"static",{value:{files:"web/**"}});OH=[],bH=new Map;a($re,"setErrorReporter");a(RE,"loadComponent");pl=class extends kt{constructor(r){super();this.error=r}static{a(this,"ErrorResource")}get(){throw this.error}post(){throw this.error}put(){throw this.error}delete(){throw this.error}connect(){throw this.error}getResource(){return this}publish(){throw this.error}subscribe(){throw this.error}}});var UR=R((Lme,UH)=>{var{isMainThread:MH}=require("worker_threads"),{getTables:Yre}=(Ae(),ie(qe)),{loadComponentDirectories:Kre,loadComponent:Wre}=(_f(),ie(lf)),{resetResources:Qre}=(Lu(),ie(wU)),zre=qT(),Jre=dr(),{dirname:Xre}=require("path"),{getConnection:jre}=Nt(),Zre=te(),ene=U(),KR=new Map;async function tne(e=!1){!MH&&Zre.get(ene.CONFIG_PARAMS.CLUSTERING_ENABLED)&&jre();try{MH&&await zre()}catch(n){console.error(n)}let t=Qre();Yre(),t.isWorker=e,await Wre(Xre(Jre.getConfigFilePath()),t,"hdb",!0,KR),await Kre(KR,t);let r=[];for(let[n]of KR)n.ready&&r.push(n.ready());r.length>0&&await Promise.all(r)}a(tne,"loadRootComponents");UH.exports.loadRootComponents=tne});var ct=R((Ume,Ci)=>{"use strict";var{Worker:rne,MessageChannel:nne,parentPort:_s,isMainThread:XR,threadId:sne,workerData:Vs}=require("worker_threads"),{PACKAGE_ROOT:ine}=U(),{join:HH,isAbsolute:one,extname:ane}=require("path"),{server:xH}=(ar(),ie(Ui)),{watch:cne,readdir:une}=require("fs/promises"),{totalmem:PH}=require("os"),Sl=U(),GH=te(),$s=K(),{randomBytes:lne}=require("crypto"),{_assignPackageExport:_ne}=require("../index"),dne=U(),vH=1024*1024,wi=[],pn=[],fne=50,jR=1e4,Ene="restart",FH="request_thread_info",qH="resource_report",kH="thread_info",VH="added-port",hne="ack",WR;_ne("threads",pn);Ci.exports={startWorker:QR,restartWorkers:eA,shutdownWorkers:gne,workers:wi,setMonitorListener:wne,onMessageFromWorkers:Rne,onMessageByType:JH,broadcast:One,broadcastWithAcknowledgement:yne,setChildListenerByType:Tne,getWorkerIndex:$H,getWorkerCount:YH,getTicketKeys:WH,setMainIsWorker:pne,setTerminateTimeout:mne,restartNumber:Vs?.restartNumber||1};pn.onMessageByType=JH;pn.sendToThread=function(e,t){if(!t?.type)throw new Error("A message with a type must be provided");let r=pn.find(n=>n.threadId===e);if(r)return r.postMessage(t),!0};var ZR;function mne(e){jR=e}a(mne,"setTerminateTimeout");function $H(){return Vs?Vs.workerIndex:ZR?0:void 0}a($H,"getWorkerIndex");function YH(){return Vs?Vs.workerCount:ZR?1:void 0}a(YH,"getWorkerCount");function pne(e){ZR=e}a(pne,"setMainIsWorker");var KH=1,AE;function WH(){return AE||(AE=XR?lne(48):Vs.ticketKeys,AE)}a(WH,"getTicketKeys");Object.defineProperty(xH,"workerIndex",{get(){return $H()}});Object.defineProperty(xH,"workerCount",{get(){return YH()}});var QH={[FH](e,t){Nne(t)},[qH](e,t){Ine(t,e)}};function QR(e,t={}){let r=process.constrainedMemory?.()||PH();r=Math.min(r,PH(),2e4*vH);let n=GH.get(Sl.CONFIG_PARAMS.THREADS_MAXHEAPMEMORY)??Math.max(Math.floor(r/vH/(10+(t.threadCount||1)/4)),512),s=Math.min(Math.max(n>>6,16),64),i=[],o=[];for(let u of pn){let _=new nne;_.existingPort=u,i.push(_),o.push(_.port2)}ane(e)||(e+=".js");let c=new rne(one(e)?e:HH(ine,e),Object.assign({resourceLimits:{maxOldGenerationSizeMb:n,maxYoungGenerationSizeMb:s},execArgv:["--enable-source-maps"],argv:process.argv.slice(2),workerData:{addPorts:o,addThreadIds:i.map(u=>u.existingPort.threadId),workerIndex:t.workerIndex,workerCount:KH=t.threadCount,name:t.name,restartNumber:Ci.exports.restartNumber,ticketKeys:WH()},transferList:o},t));for(let{port1:u,existingPort:_}of i)_.postMessage({type:VH,port:u,threadId:c.threadId},[u]);return bE(c,!0),c.unexpectedRestarts=t.unexpectedRestarts||0,c.startCopy=()=>QR(e,t),c.on("error",u=>{$s.error(`Worker index ${t.workerIndex} error:`,u)}),c.on("exit",u=>{wi.splice(wi.indexOf(c),1),!c.wasShutdown&&t.autoRestart!==!1&&(c.unexpectedRestarts<fne?(t.unexpectedRestarts=c.unexpectedRestarts+1,QR(e,t)):$s.error(`Thread has been restarted ${c.restarts} times and will not be restarted`))}),c.on("message",u=>{QH[u.type]?.(u,c)}),wi.push(c),Dne(),t.onStarted&&t.onStarted(c),c.name=t.name,c}a(QR,"startWorker");var Sne=[Sl.THREAD_TYPES.HTTP];async function eA(e=null,t=Math.max(KH>3,1),r=!0){if(XR){if(r){let{loadRootComponents:o}=UR();await o()}Ci.exports.restartNumber++,t<1&&(t=t*wi.length);let n=[],s=[];for(let o of wi.slice(0)){if(e&&o.name!==e||o.wasShutdown)continue;$s.trace("sending shutdown request to ",o.threadId),o.postMessage({restartNumber:Ci.exports.restartNumber,type:Sl.ITC_EVENT_TYPES.SHUTDOWN}),o.wasShutdown=!0,o.emit("shutdown",{});let c=Sne.indexOf(o.name)>-1,u=new Promise(_=>{let l=setTimeout(()=>o.terminate(),jR*2).unref();o.on("exit",()=>{clearTimeout(l),n.splice(n.indexOf(u)),!c&&r&&o.startCopy(),_()})});if(n.push(u),c&&r){let _=o.startCopy(),l=new Promise(d=>{let f=a(E=>{E.type===dne.ITC_EVENT_TYPES.CHILD_STARTED&&($s.trace("Worker has started",_.threadId),d(),s.splice(s.indexOf(l)),_.off("message",f))},"startListener");$s.trace("Waiting for worker to start",_.threadId),_.on("message",f)});s.push(l),n.length>=t&&await Promise.race(n),s.length>=t&&await Promise.race(s)}}await Promise.all(n),await Promise.all(s);let{restartService:i}=Xd();r&&(e==="http"||!e)&&GH.get(Sl.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await i({service:"clustering"})}else _s.postMessage({type:Ene,workerType:e})}a(eA,"restartWorkers");function Tne(e,t){QH[e]=t}a(Tne,"setChildListenerByType");function gne(e){return eA(e,1/0,!1)}a(gne,"shutdownWorkers");var zH=[];function Rne(e){zH.push(e)}a(Rne,"onMessageFromWorkers");var zR=new Map;function JH(e,t){let r=zR.get(e);r||zR.set(e,r=[]),r.push(t)}a(JH,"onMessageByType");var Ane=10;async function One(e){let t=0;for(let r of pn)try{r.postMessage(e),t++>Ane&&(t=0,await new Promise(setImmediate))}catch(n){$s.error("Unable to send message to worker",n)}}a(One,"broadcast");var OE=new Map,bne=1;function yne(e){return new Promise(t=>{let r=0;for(let n of pn)try{let s=bne++,i=a(()=>{OE.delete(s),--r===0&&t(),n!==_s&&--n.refCount===0&&n.unref()},"ack_handler");i.port=n,n.ref(),n.refCount=(n.refCount||0)+1,OE.set(e.requestId=s,i),n.hasAckCloseListener||(n.hasAckCloseListener=!0,n.on(n.close?"close":"exit",()=>{for(let[,o]of OE)o.port===n&&o()})),n.postMessage(e),r++}catch(s){$s.error("Unable to send message to worker",s)}r===0&&t()})}a(yne,"broadcastWithAcknowledgement");function Nne(e){e.postMessage({type:kH,workers:XH()})}a(Nne,"sendThreadInfo");function XH(){let e=Date.now();return wi.map(t=>({threadId:t.threadId,name:t.name,heapTotal:t.resources?.heapTotal,heapUsed:t.resources?.heapUsed,externalMemory:t.resources?.external,arrayBuffers:t.resources?.arrayBuffers,sinceLastUpdate:e-t.resources?.updated,...t.recentELU}))}a(XH,"getChildWorkerInfo");function Ine(e,t){e.resources=t,e.resources.updated=Date.now()}a(Ine,"recordResourceReport");var JR;function wne(e){JR=e}a(wne,"setMonitorListener");var Cne=1e3,BH=!1;function Dne(){BH||(BH=!0,setInterval(()=>{for(let e of wi){let t=e.performance.eventLoopUtilization(),r;e.lastTotalELU?r=e.performance.eventLoopUtilization(t,e.lastTotalELU):r=t,e.lastTotalELU=t,e.recentELU=r}JR&&JR()},Cne).unref())}a(Dne,"startMonitoring");var Lne=1e3;if(_s){bE(_s);for(let e=0,t=Vs.addPorts.length;e<t;e++){let r=Vs.addPorts[e];r.threadId=Vs.addThreadIds[e],bE(r)}setInterval(()=>{let e=process.memoryUsage();_s.postMessage({type:qH,heapTotal:e.heapTotal,heapUsed:e.heapUsed,external:e.external,arrayBuffers:e.arrayBuffers})},Lne).unref(),WR=a(()=>new Promise((e,t)=>{_s.on("message",r),_s.postMessage({type:FH});function r(n){n.type===kH&&(_s.off("message",r),e(n.workers))}a(r,"receiveThreadInfo")}),"getThreadInfo")}else WR=XH;Ci.exports.getThreadInfo=WR;function bE(e,t){pn.push(e),e.on("message",r=>{if(r.type===VH)r.port.threadId=r.threadId,bE(r.port);else if(r.type===hne){let n=OE.get(r.id);n&&n()}else{for(let s of zH)s(r,e);let n=zR.get(r.type);if(n)for(let s of n)try{s(r,e)}catch(i){$s.error(i)}}}).on("close",()=>{pn.splice(pn.indexOf(e),1)}).on("exit",()=>{pn.splice(pn.indexOf(e),1)}),t?e.refCount=100:e.unref()}a(bE,"addPort");if(XR){let e,t,r=a(async(n,s)=>{s&&(e=s);for(let i of await une(n,{withFileTypes:!0}))i.isDirectory()&&i.name!=="node_modules"&&r(HH(n,i.name));try{for await(let{filename:i}of cne(n,{persistent:!1}))t&&clearTimeout(t),t=setTimeout(async()=>{e&&await e(),await eA(),console.log("Reloaded HarperDB components")},100)}catch(i){console.warn("Error trying to watch component directory",n,i)}},"watch_dir");Ci.exports.watchDir=r,process.env.WATCH_DIR&&r(process.env.WATCH_DIR)}else _s.on("message",async e=>{let{type:t}=e;t===Sl.ITC_EVENT_TYPES.SHUTDOWN&&(Ci.exports.restartNumber=e.restartNumber,_s.unref(),setTimeout(()=>{$s.warn("Thread did not voluntarily terminate",sne),process.exit(0)},jR).unref())})});var cC={};Fe(cC,{AUDIT_STORE_OPTIONS:()=>Kd,createAuditEntry:()=>o_,openAuditStore:()=>wE,readAuditEntry:()=>Ut,setAuditRetention:()=>Une,transactionKeyEncoder:()=>ox});function wE(e){let t=e.auditStore=e.openDB(nx.AUDIT_STORE_NAME,Kd);t.rootStore=e;let r=[];t.addDeleteRemovalCallback=function(i,o){return r[i]=o,{remove(){delete r[i]}}};let n=null;function s(i=yE){clearTimeout(n),n=setTimeout(async()=>{if(t.rootStore.status==="closed")return;let o=0,c;try{for(let{key:u,value:_}of t.getRange({start:0,snapshot:!1,end:Date.now()-tA})){if((_[0]&15)===sA){let l=Ut(_),d=l.tableId;r[d]?.(l.recordId)}if(c=t.remove(u),await new Promise(setImmediate),++o>=Mne){i=10;break}}await c}finally{o===0&&(i=Math.min(i<<1,tA/10)),s(i)}},i).unref()}return a(s,"scheduleAuditCleanup"),t.scheduleAuditCleanup=s,(0,IE.getWorkerIndex)()===(0,IE.getWorkerCount)()-1&&s(yE),t}function Une(e,t=yE){tA=e,yE=t}function o_(e,t,r,n,s,i,o){let c=ax[i];if(!c)throw new Error(`Invalid audit entry type ${i}`);let u=1;n&&(n>1?Wa.setFloat64(0,n):Sn.set(tm),u=9),f(0),f(t),d(r),Wa.setFloat64(u,e),u+=8,s?d(s):Sn[u++]=0,Sn[n?8:0]=c;let l=Sn.subarray(0,u);if(o)return Buffer.concat([l,o]);return l;function d(E){let h=u;u+=1,u=(0,Qa.writeKey)(E,Sn,u);let S=u-h-1;S>127?S>16383?(oA.error("Key or username was too large for audit entry",E),u=h+1,Sn[h]=0):(Sn.copyWithin(h+2,h+1,u),Wa.setUint16(h,S|32768),u++):Sn[h]=S}function f(E){E<128?Sn[u++]=E:E<16384?(Wa.setUint16(u,E|32768),u+=2):E<1056964608?(Wa.setUint32(u,E|3221225472),u+=4):(Sn[u]=255,Wa.setUint32(u+1,E),u+=5)}}function Ut(e){try{let t=e.dataView||(e.dataView=new iA(e.buffer,e.byteOffset,e.byteLength)),r;e[0]==66&&(r=t.readFloat64());let n=t.readInt(),s=t.readInt(),i=t.readInt(),o=t.readInt(),c=t.position,u=t.position+=o,_=t.readFloat64();o=t.readInt();let l=t.position,d=t.position+=o;return{type:ax[n&7],tableId:i,get recordId(){return rx(e,c,u)},version:_,previousLocalTime:r,get user(){return d>l?rx(e,l,d):void 0},getValue(f,E,h){if(n&rA||n&nA&&!E)return f.decoder.decode(e.subarray(t.position));if(n&nA&&h)return aA(f.getEntry(this.recordId),h,f)}}}catch(t){return oA.error("Reading audit entry error",t,e),{}}}function rx(e,t,r){let n=e.subarray(t,r);return(0,Qa.readKey)(n,0,r-t)}var Qa,NE,nx,sx,IE,ix,oA,Sn,Wa,ox,Kd,tA,Mne,yE,rA,nA,jH,sA,ZH,ex,tx,ax,iA,js=Re(()=>{Qa=require("ordered-binary"),NE=B(te()),nx=B(at()),sx=B(U()),IE=B(ct()),ix=B(Q());bc();oA=B(K());CE();(0,NE.initSync)();Sn=Buffer.alloc(1024),Wa=new DataView(Sn.buffer,Sn.byteOffset,1024),ox={writeKey(e,t,r){return e===Oc?(t.set(Oc,r),r+8):typeof e=="number"?((t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).setFloat64(r,e),r+8):(0,Qa.writeKey)(e,t,r)},readKey(e,t,r){return e[t]===66?(e.dataView||(e.dataView=new DataView(e.buffer,e.byteOffset,e.byteLength))).getFloat64(t):(0,Qa.readKey)(e,t,r)}},Kd={encoding:"binary",keyEncoder:ox},tA=(0,ix.convertToMS)((0,NE.get)(sx.CONFIG_PARAMS.LOGGING_AUDITRETENTION))||86400*3,Mne=1e3,yE=1e4;a(wE,"openAuditStore");a(Une,"setAuditRetention");rA=16,nA=32,jH=1,sA=2,ZH=3,ex=4,tx=5,ax={put:jH|rA,[jH]:"put",delete:sA,[sA]:"delete",message:ZH|rA,[ZH]:"message",invalidate:ex,[ex]:"invalidate",patch:tx|nA,[tx]:"patch"};a(o_,"createAuditEntry");a(Ut,"readAuditEntry");iA=class extends DataView{static{a(this,"Decoder")}position=0;readInt(){let t=this.getUint8(this.position++);return t>=128?t>=192?t===255?(t=this.getUint32(this.position),this.position+=4,t):(t=this.getUint32(this.position-1)&1073741823,this.position+=3,t):(t=this.getUint16(this.position-1)&32767,this.position++,t):t}readFloat64(){try{let t=this.getFloat64(this.position);return this.position+=8,t}catch{debugger}}};a(rx,"readKeySafely")});var cA={};Fe(cA,{add:()=>DE,applyReverse:()=>cx,getRecordAtTime:()=>aA,rebuildUpdateBefore:()=>LE});function DE(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n+BigInt(r.value):isNaN(e[t])?e[t]=r.value:e[t]=n+r.value}function LE(e,t){let r=null;for(let n in e)if(n in t){let s=t[n];if(s?.__op__){let i=e[n];if(i?.__op__)if(i.__op__===s.__op__)r||(r={}),r[n]=i;else throw new Error("Can not merge updates with different operations");else r||(r={}),r[n]=i,DE(r,n,s)}}else r||(r={}),r[n]=e[n];return r}function cx(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=Pne[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=ux}}function aA(e,t,r){let n=r.rootStore.auditStore,s=Object.assign({},e.value),i=e.localTime;for(;i>t;){let u=n.get(i),_=Ut(u);switch(_.type){case"put":s=_.getValue(r);break;case"patch":cx(s,_.getValue(r));break;case"delete":s=null}i=_.previousLocalTime}let o={},c=0;for(let u in s)s[u]===ux&&(o[u]=!0,c++);for(;c>0&&i>0;){let u=n.get(i),_=Ut(u),l;switch(_.type){case"put":l=_.getValue(r);break;case"patch":l=_.getValue(r);break}for(let d in l)o[d]&&(s[d]=l[d],o[d]=!1,c--);i=_.previousLocalTime}if(c>0)for(let u in o)s[u]=null;return s}var Pne,ux,CE=Re(()=>{js();a(DE,"add");DE.reverse=function(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n-BigInt(r.value):isNaN(e[t])||(e[t]=n-r.value)};Pne={add:DE};a(LE,"rebuildUpdateBefore");a(cx,"applyReverse");ux={};a(aA,"getRecordAtTime")});function Jr(e){return e[Ot]||(e[Ot]=Object.create(null))}function BE(e,t){let r=e.prototype,n={},s=t.attributes||t.properties||[];for(let o of s){let c=o.name,u,_;if(o.resolve)_={get(){return o.resolve(this,this[ye])},set(l){return o.set(this,l)},configurable:!0};else{switch(o.type){case"String":u=a(function(l){if(!(typeof l=="string"||l==null&&o.nullable!==!1))throw new Tn.ClientError(`${c} must be a string, attempt to assign ${l}`);Jr(this)[c]=l},"set");break;case"ID":u=a(function(l){if(!(typeof l=="string"||l?.length>0&&l.every?.(d=>typeof d=="string")||l==null&&o.nullable!==!1))throw new Tn.ClientError(`${c} must be a string, attempt to assign ${l}`);Jr(this)[c]=l},"set");break;case"Float":case"Number":u=a(function(l){let d=l?.__op__?l.value:l;if(!(typeof d=="number"||l==null&&o.nullable!==!1))throw new Tn.ClientError(`${c} must be a number, attempt to assign ${d}`);Jr(this)[c]=l},"set");break;case"Int":u=a(function(l){let d=l?.__op__?l.value:l;if(!(d>>0===d||l==null&&o.nullable!==!1))if(typeof d=="number"&&Math.abs((d>>0)-d)<=1)d=Math.round(d),l?.__op__?l.value=d:l=d;else throw new Tn.ClientError(`${c} must be an integer between -2147483648 and 2147483647, attempt to assign ${l}`);Jr(this)[c]=l},"set");break;case"Long":u=a(function(l){let d=l?.__op__?l.value:l;if(!(Math.round(d)===l&&Math.abs(d)<=9007199254740992||l==null&&o.nullable!==!1))if(typeof d=="number"&&Math.abs(d)<=9007199254740992)d=Math.round(d),l?.__op__?l.value=d:l=d;else throw new Tn.ClientError(`${c} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${l}`);Jr(this)[c]=l},"set");break;case"BigInt":u=a(function(l){let d=l?.__op__?l.value:l;if(!(typeof d=="bigint"||l==null&&o.nullable!==!1))if(typeof d=="string"||typeof d=="number")d=BigInt(d),l?.__op__?l.value=d:l=d;else throw new Tn.ClientError(`${c} must be a number, attempt to assign ${l}`);Jr(this)[c]=l},"set");break;case"Boolean":u=a(function(l){if(!(typeof l=="boolean"||l==null&&o.nullable!==!1))throw new Tn.ClientError(`${c} must be a boolean, attempt to assign ${l}`);Jr(this)[c]=l},"set");break;case"Date":u=a(function(l){if(!(l instanceof Date||l==null&&o.nullable!==!1))if(typeof l=="string"||typeof l=="number")l=new Date(l);else throw new Tn.ClientError(`${c} must be a Date, attempt to assign ${l}`);Jr(this)[c]=l},"set");break;case"Bytes":u=a(function(l){if(!(l instanceof Uint8Array||l==null&&o.nullable!==!1))throw new Tn.ClientError(`${c} must be a Buffer or Uint8Array, attempt to assign ${l}`);Jr(this)[c]=l},"set");break;case"Any":case void 0:u=a(function(l){Jr(this)[c]=l},"set");break;default:u=a(function(l){if(!(typeof l=="object"||l==null&&o.nullable!==!1))throw new Tn.ClientError(`${c} must be an object, attempt to assign ${l}`);Jr(this)[c]=l},"set")}_={get(){let l=this[Ot];if(l&&c in l){let f=l[c];if(f?.__op__){let E=this[_e]?.[c];return f.update(E)}return f}let d=this[_e]?.[c];if(d&&typeof d=="object"){let f=_x(d,o);if(f)return l||(l=this[Ot]=Object.create(null)),l[c]=f}return d},set:u,enumerable:!0,configurable:!0}}_.get.isAttribute=!0,n[c]=_,(!(c in r)||Object.getOwnPropertyDescriptor(r,c)?.get?.isAttribute)&&Object.defineProperty(r,c,_)}i("getProperty",function(o){let c=n[o];if(c)return c.get.call(this);let u=this[Ot];return u?.[o]!==void 0?u[o]:this[_e]?.[o]}),i("set",function(o,c){let u=n[o];if(u)return u.set.call(this,c);if(t.sealed)throw new Tn.ClientError("Can not add a property to a sealed table schema");Jr(this)[o]=c}),i("deleteProperty",function(o){Jr(this)[o]=void 0}),i("toJSON",function(){let o=this[Ot],c;for(let _ in o){c||(c=Object.assign({},this[_e]));let l=o[_];if(l?.__op__){let d=c[_];l=l.update(d)}c[_]=l}return Object.keys(this).length>0&&(c||(c=Object.assign({},this[_e])),Object.assign(c,this)),c||this[_e]}),r.get||i("get",r.getProperty),r.delete||i("delete",r.deleteProperty);function i(o,c){Object.defineProperty(r,o,{value:c,configurable:!0})}a(i,"setMethod")}function _x(e,t){let r;switch(e.constructor){case Object:return t?((r=t.TrackedObject)||(t.TrackedObject=r=class{static{a(this,"TrackedObject")}constructor(s){if(s?.[_e])throw new Error("Can not track an already tracked object, check for circular references");this[_e]=s}},BE(r,t)),new r(e)):new ME(e);case Array:let n=new PE(e.length);n[_e]=e;for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=_x(o,t?.elements)),n[s]=o}return n;default:return e}}function td(e){let t=e[Ot],r;for(let s in t){r||(r=Object.assign({},e[_e]));let i=t[s];if(i&&typeof i=="object")if(i.__op__){let o=r[s];i=i.update(o)}else i=td(i);r[s]=i}return Object.keys(e).length>0&&(r||(r=Object.assign({},e[_e])),Object.assign(r,e)),r||e[_e]}function No(e,t=e[Ot]){let r;if(lx.call(e,_e)&&e.constructor===Array&&!Object.isFrozen(e)){r=e;for(let n=0,s=e.length;n<s;n++){let i=e[n];if(i&&typeof i=="object"){let o=No(i);o!==i&&r===e&&(r=e.slice(0)),i=o}r[n]=i}return Object.freeze(r)}for(let n in t){r||(r=Object.assign({},e[_e]));let s=t[n];if(s&&typeof s=="object")if(s.__op__){let i=cA[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=No(s);r[n]=s}return r?Object.freeze(r):lx.call(e,_e)?e[_e]:e}function UE(e){let t=e[_e];if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[yo]||e.length!==t.length)return!0;for(let r=0,n=e.length;r<n;r++){let s=t[r],i=e[r];if(s&&i?.[_e]===s){if(UE(i))return!0}else return!0}}else{let r=e[Ot];if(r&&!t)return!0;for(let n in r){let s=r[n];if(s&&typeof s=="object"){let i=t[n];if(i&&s[_e]===i){if(UE(s))return!0}else return!0}else return!0}}return!1}var Tn,Ot,ME,lx,yo,PE,vE,rd=Re(()=>{bn();Tn=B(ne());CE();Ot=Symbol("own-data");a(Jr,"getChanges");a(BE,"assignTrackedAccessors");a(_x,"trackObject");ME=class{static{a(this,"GenericTrackedObject")}constructor(t){if(t?.[_e])throw new Error("Can not track an already tracked object, check for circular references");this[_e]=t}};BE(ME,{});a(td,"collapseData");lx=Object.prototype.hasOwnProperty;a(No,"deepFreeze");a(UE,"hasChanges");yo=Symbol.for("has-array-changes"),PE=class extends Array{static{a(this,"TrackedArray")}[yo];constructor(t){super(t)}splice(...t){return this[yo]=!0,super.splice(...t)}push(...t){return this[yo]=!0,super.push(...t)}pop(){return this[yo]=!0,super.pop()}unshift(...t){return this[yo]=!0,super.unshift(...t)}shift(){return this[yo]=!0,super.shift()}};PE.prototype.constructor=Array;vE=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var Ip={};Fe(Ip,{CONTEXT:()=>ye,ID_PROPERTY:()=>Le,IS_COLLECTION:()=>Gn,RECORD_PROPERTY:()=>_e,Resource:()=>kt,snake_case:()=>Bne,transformForSelect:()=>xE});function Bne(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function dx(e,t){if(Tl=!1,e==="")return null;if(e=e.slice(1),e.indexOf("/")===-1)return e===""?(Tl=!0,null):(e.startsWith("$")&&(e=parseInt(e,36)),t.coerceId(decodeURIComponent(e)));let r=e.split("/"),n=new lA;for(let s=0;s<r.length;s++){let i=r[s];if(!i&&s===r.length-1){Tl=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}function Xr(e,t){n.reliesOnPrototype=!0;let r=t.hasContent;return n;function n(s,i,o){let c,u,_,l;if(r?(o?(l=i,o=o[ye]||o):i?typeof s=="object"&&s&&(!Array.isArray(s)||typeof s[0]=="object")?(l=s,c=l[this.primaryKey]??null,o=i[ye]||i):l=i:(l=s,c=l[Le]??l[this.primaryKey]??null),c==null&&(_=!0)):i?o=i[ye]||i:s&&typeof s=="object"&&!Array.isArray(s)&&(o=s),c===void 0)if(typeof s=="string")c=s;else if(typeof s=="object"&&s)if(u=s,s[Symbol.iterator]){c=[],_=!0;for(let E of s){if(typeof E=="object"&&E)break;c.push(E)}c.length===0?c=null:(c.length===1&&(c=c[0]),u.slice&&(u=u.slice(c.length,u.length),u.length===0&&(u=null,_=!1)))}else{if(typeof(c=s.url)=="string"){let E=c.indexOf("?");if(E>-1){let S=this.parseQuery(c.slice(E+1));u?u=Object.assign(S,u):u=S,c=c.slice(0,E)}let h=this.parsePath(c,o,u);h?.id!==void 0?(h.query&&(u?u=Object.assign(h.query,u):u=h.query),_=h.isCollection,c=h.id):c=h}c===void 0&&(c=s.id??null,c==null&&(_=!0))}else c=s??null,c==null&&(_=!0);o||(o={});let d;if(u?.ensureLoaded!=null||u?.async||_?(d=Object.assign({},t),u?.ensureLoaded!=null&&(d.ensureLoaded=u.ensureLoaded),u?.async&&(d.async=u.async),_&&(d.isCollection=!0)):d=t,o.transaction){let E=this.getResource(c,o,d);return E.then?E.then(f):f(E)}else return ze(o,()=>{let E=this.getResource(c,o,d);return E.then?E.then(f):f(E)},d);function f(E){if(o.authorize){o.authorize=!1;let h=t.type==="read"?E.allowRead(o.user,u,o):t.type==="update"?E.doesExist?.()===!1?E.allowCreate(o.user,l,o):E.allowUpdate(o.user,l,o):t.type==="create"?E.allowCreate(o.user,l,o):E.allowDelete(o.user,u,o);if(h?.then)return h.then(S=>{if(!S)throw new HE(o.user);return typeof l?.then=="function"?l.then(p=>e(E,u,o,p)):e(E,u,o,l)});if(!h)throw new HE(o.user)}return typeof l?.then=="function"?l.then(h=>e(E,u,o,h)):e(E,u,o,l)}a(f,"authorizeActionOnResource")}}function jr(e,t){let r=new hx.ClientError(`The ${e.constructor.name} does not have a ${t} method implemented`,405);r.allow=[],r.method=t;for(let n of["get","put","post","delete","query","move","copy"])typeof e[n]=="function"&&r.allow.push(n);throw r}function uA(e,t,r){let n=e[_e];if(n){let s=e[Ot];return i=>{let o,c;return e.hasOwnProperty(i)&&typeof(o=e[i])!="function"?o:s&&i in s?s[i]:(c=t?.[i])?c(e,r):n[i]}}else return t?s=>{let i=t[s];return i?i(e,r):e[s]}:s=>e[s]}function xE(e,t){let r=t?.propertyResolvers,n=t[ye],s;if(typeof e=="string")return a(function o(c){return c.then?c.then(o):Array.isArray(c)?c.map(o):uA(c,r,n)(e)},"transform");if(typeof e=="object"){if(e.asArray)return a(function c(u){if(u.then)return u.then(c);if(Array.isArray(u))return u.map(c);let _=[],l=i(uA(u,r,n));for(let d of e)_.push(l(d));return _},"transform");let o=e.forceNulls;return a(function c(u){if(u.then)return u.then(c);if(Array.isArray(u))return u.map(f=>f&&typeof f=="object"?c(f):f);let _={},l=i(uA(u,r,n)),d;for(let f of e){let E=l(f);E===void 0&&o&&(E=null),E?.then?(d||(d=[]),d.push(E.then(h=>_[f.name||f]=h))):_[f.name||f]=E}return d?Promise.all(d).then(()=>_):_},"transform")}else throw new Error("Invalid select argument type "+typeof e);function i(o){return c=>{if(typeof c=="string")return o(c);if(typeof c=="object")if(c.name){s||(s={});let u=s[c.name];if(!u){let l=r[c.name]?.definition?.tableClass;u=s[c.name]=xE(c.select||c,l)}let _=o(c.name);return u(_)}else return o(c);else return c}}a(i,"handleProperty")}var fx,Ex,hx,ye,Le,Gn,_e,vne,kt,HE,Tl,lA,bn=Re(()=>{fx=require("crypto");pc();Ex=require("../index"),hx=B(ne());rd();Zi();Df();ye=Symbol.for("context"),Le=Symbol.for("primary-key"),Gn=Symbol("is-collection"),_e=Symbol("stored-record"),vne={json:"application/json",cbor:"application/cbor",msgpack:"application/x-msgpack",csv:"text/csv"},kt=class{static{a(this,"Resource")}static transactions;constructor(t,r){this[Le]=t;let n=r?.[ye];this[ye]=n!==void 0?n:r||null}static get=Xr(function(t,r,n,s){let i=t.get?.(r);if(i?.then)return i.then(o);return o(i);function o(c){let u;if((u=r?.select)&&c!=null&&!c.selectApplied){let _=xE(u,t.constructor);return typeof c?.map=="function"?c.map(_):_(c)}return c}},{type:"read",letItLinger:!0,ensureLoaded:!0,async:!0});static put=Xr(function(t,r,n,s){if(Array.isArray(s)&&t[Gn]){let i=[],o=n.authorize;for(let c of s){let u=t.constructor,_=u.getResource(c[u.primaryKey],n,{async:!0});_.then?i.push(_.then(l=>l.put(c,n))):i.push(_.put(c,n))}return Promise.all(i)}return t.put?t.put(s,r):jr(t,"put")},{hasContent:!0,type:"update"});static patch=Xr(function(t,r,n,s){return t.patch?t.patch(s,r):jr(t,"patch")},{hasContent:!0,type:"update"});static delete=Xr(function(t,r,n,s){return t.delete?t.delete(r):jr(t,"delete")},{hasContent:!1,type:"delete"});static getNewId(){return(0,fx.randomUUID)()}static create(t,r,n){let s;return t==null?s=this.getNewId():Array.isArray(t)&&typeof t[0]!="object"?s=[...t,this.getNewId()]:typeof t!="object"?s=[t,this.getNewId()]:(s=this.getNewId(),n=r,r=t),n||(n={}),ze(n,()=>{let i=new this(s,n),o=i.update?i.update(r,!0):jr(i,"update");return n.newLocation=s,n.createdResource=!0,o?.then?o.then(()=>s):s})}static invalidate=Xr(function(t,r,n,s){return t.invalidate?t.invalidate(r):jr(t,"delete")},{hasContent:!1,type:"update"});static post=Xr(function(t,r,n,s){return t[Le]!=null&&t.update?.(),t.post(s,r)},{hasContent:!0,type:"create"});static connect=Xr(function(t,r,n,s){return t.connect?t.connect(s,r):jr(t,"connect")},{hasContent:!0,type:"read"});static subscribe=Xr(function(t,r,n,s){return t.subscribe?t.subscribe(r):jr(t,"subscribe")},{type:"read"});static publish=Xr(function(t,r,n,s){return t[Le]!=null&&t.update?.(),t.publish?t.publish(s,r):jr(t,"publish")},{hasContent:!0,type:"create"});static search=Xr(function(t,r,n,s){let i=t.search?t.search(r):jr(t,"search"),o=n.select;if(o&&n.hasOwnProperty("select")&&i!=null&&!i.selectApplied){let c=xE(o,t.constructor);return i.map(c)}return i},{type:"read"});static query=Xr(function(t,r,n,s){return t.search?t.search(s,r):jr(t,"search")},{hasContent:!0,type:"read"});static copy=Xr(function(t,r,n,s){return t.copy?t.copy(s,r):jr(t,"copy")},{type:"create"});static move=Xr(function(t,r,n,s){return t.move?t.move(s,r):jr(t,"move")},{type:"delete"});post(t){if(this[Gn])return this.constructor.create(this[Le],t,this[ye]);jr(this,"post")}static isCollection(t){return t?.[Gn]}static coerceId(t){return t}static parseQuery(t){return Cf(t)}static parsePath(t,r,n){let s=t.indexOf(".");if(s>-1){let o=t.slice(s+1);t=t.slice(0,s);let c=r?.headers&&vne[o];if(c)r.headers.set("accept",c);else if(n)n.property=o;else return{query:{property:o},id:dx(t,this),isCollection:Tl}}let i=dx(t,this);return Tl?{id:i,isCollection:!0}:i}static getResource(t,r,n){let s,i=r[ye],o;typeof r.isCollection=="boolean"&&r.hasOwnProperty("isCollection")?o=r.isCollection:o=n?.isCollection;let c=o&&this.Collection||this;if(i||(i=i===void 0?r:{}),i.transaction){let u;if(i.resourceCache?u=i.resourceCache:u=i.resourceCache=[],u.asMap){let _=u.asMap.get(t);if(s=_?.find(l=>l.constructor===c),s)return s;_||u.asMap.set(t,_=[]),_.push(s=new c(t,i))}else{if(s=u.find(_=>_[Le]===t&&_.constructor===c),s)return s;if(u.push(s=new c(t,i)),u.length>10){let _=new Map;for(let l of u){let d=l[Le],f=_.get(d);f?f.push(l):_.set(d,[l])}i.resourceCache.length=0,i.resourceCache.asMap=_}}}else s=new c(t,i);return o&&(s[Gn]=!0),s}subscribe(t){return new On}connect(t){return t?.subscribe!==!1?this.subscribe?.(t):new On}allowRead(t){return t?.role.permission.super_user}allowUpdate(t){return t?.role.permission.super_user}allowCreate(t){return t?.role.permission.super_user}allowDelete(t){return t?.role.permission.super_user}getId(){return this[Le]}getContext(){return this[ye]}};kt.prototype[ye]=null;(0,Ex._assignPackageExport)("Resource",kt);a(Bne,"snake_case");HE=class extends Error{static{a(this,"AccessError")}constructor(t){t?(super("Unauthorized access to resource"),this.statusCode=403):(super("Must login"),this.statusCode=401)}};a(dx,"pathToId");lA=class extends Array{static{a(this,"MulitPartId")}toString(){return this.join("/")}};a(Xr,"transactional");a(jr,"missingMethod");a(uA,"selectFromObject");a(xE,"transformForSelect")});function Sx(e,t,r,n,s){let i=e.primaryStore.env.path,o=e.primaryStore.tableId,c;s?.crossThreads===!1?(c=px,Hne(e.primaryStore,e.auditStore)):(c=mx,e.primaryStore.env.hasSubscriptionCommitListener||(e.primaryStore.env.hasSubscriptionCommitListener=!0,e.primaryStore.on("committed",()=>{Tx(mx[i])})));let u=c[i]||(c[i]=[]);u.auditStore=e.auditStore,u.lastTxnTime==null&&(u.lastTxnTime=Date.now());let _=u[o];_||(_=u[o]=new Map,_.envs=u,_.tableId=o,_.store=e.primaryStore),t=Ta(t);let l=new dA(r);l.startTime=n;let d=_.get(t);return d?d.push(l):(_.set(t,d=[l]),d.tables=_,d.key=t),l.subscriptions=d,l}function Tx(e){if(!e)return;let t=e.auditStore;try{t.resetReadTxn()}catch(n){throw n.message+=" in "+path,n}let r;for(let{key:n,value:s}of t.getRange({start:e.lastTxnTime,exclusiveStart:!0})){e.lastTxnTime=n;let i=Ut(s),o=e[i.tableId];if(!o)continue;let c=i.recordId,u,_=Ta(i.recordId),l=0;do{let d=o.get(_);if(d){for(let E of d)if(!(l>0&&!(E.includeDescendants&&!(E.onlyChildren&&l>1)))){if(E.startTime>=n){(0,_A.info)("omitting",c,E.startTime,n);continue}try{let h;E.supportsTransactions&&E.txnInProgress!==i.version&&(h=!0,E.txnInProgress||(r?r.push(E):r=[E]),E.txnInProgress=i.version),E.listener(c,i,n,h)}catch(h){console.error(h),(0,_A.info)(h)}}}if(_==null)break;let f=_.lastIndexOf?.("/",_.length-2);f>-1?_=_.slice(0,f):_=null,l++}while(!0)}if(r)for(let n of r)n.txnInProgress=null,n.listener(null,{type:"end_txn"},e.lastTxnTime,!0)}function Hne(e,t){let r=t||e,n=r.env;if(!n.hasAfterCommitListener){n.hasAfterCommitListener=!0;let s=n.path;r.on("aftercommit",({next:i,last:o,txnId:c})=>{let u=px[s];if(!u)return;let _=a(()=>{r.threadLocalWrites||(r.threadLocalWrites=new Float64Array(r.getUserSharedBuffer("last-thread-local-write",new ArrayBuffer(8)))),u.txnTime=r.threadLocalWrites[0]||Date.now(),Tx(u),r.threadLocalWrites[0]=u.lastTxnTime,r.unlock("thread-local-writes")},"acquiredLock");r.attemptLock("thread-local-writes",_)&&_()})}}var _A,mx,px,dA,gx=Re(()=>{_A=B(K());pc();Lu();js();mx=Object.create(null),px=Object.create(null);a(Sx,"addSubscription");dA=class extends On{static{a(this,"Subscription")}listener;subscriptions;startTime;constructor(t){super(),this.listener=t,this.on("close",()=>this.end())}end(){if(this.subscriptions){if(this.subscriptions.splice(this.subscriptions.indexOf(this),1),this.subscriptions.length===0){let t=this.subscriptions.tables,r=this.subscriptions.key;if(t.delete(r),t.size===0){let n=t.envs,s=t.dbi;delete n[s]}}this.subscriptions=null}}toJSON(){return{name:"subscription"}}};a(Tx,"notifyFromTransactionData");a(Hne,"listenToCommits")});var Kg={};Fe(Kg,{coerceType:()=>GE,makeTable:()=>kE,setServerUtilities:()=>Kne,updateResource:()=>FE});function kE(e){let{primaryKey:t,indices:r,tableId:n,tableName:s,primaryStore:i,databasePath:o,databaseName:c,auditStore:u,schemaDefined:_,dbisDB:l,sealed:d}=e,{expirationMS:f,evictionMS:E,audit:h,trackDeletes:S}=e,{attributes:p}=e;p||(p=[]);let T=sm(i,n,u),A=0,g,L,v={},P=Promise.resolve(),k,H,X;for(let Y of p)(Y.assignCreatedTime||Y.name==="__createdtime__")&&(k=Y),(Y.assignUpdatedTime||Y.name==="__updatedtime__")&&(H=Y),Y.expiresAt&&(X=Y),Y.isPrimaryKey&&(v=Y);let z,J=[],me=[],ce=1,de=2,De={},ve={},Mt=864e5,Gl,Fl,Ks,xA=!1,lh,_h,IG=i.getRange({start:!1,end:!1}).constructor,wG=10,CG=6;h&&qA();class We extends kt{static name=s;static primaryStore=i;static auditStore=u;static primaryKey=t;static tableName=s;static indices=r;static audit=h;static databasePath=o;static databaseName=c;static attributes=p;static expirationTimer;static createdTimeProperty=k;static updatedTimeProperty=H;static propertyResolvers;static sources=[];static get expirationMS(){return f}static dbisDB=l;static schemaDefined=_;static sourcedFrom(m,O){O&&(this.sourceOptions=O,(O.expiration||O.eviction||O.scanInterval)&&this.setTTLExpiration(O)),O?.intermediateSource?(m.intermediateSource=!0,this.sources.unshift(m)):this.sources.push(m),L=m.get&&(!m.get.reliesOnPrototype||m.prototype.get);let I=a(D=>{let N=this.sources.slice(0,-1);if(N=N.filter(M=>M[D]&&(!M[D].reliesOnPrototype||M.prototype[D])),N.length>0)if(N.length===1){let M=N[0];return(q,C,x)=>{if(q?.source!==M)return M[D](C,x,q)}}else return(M,q,C)=>{let x=[];for(let G of N){if(M?.source===G)break;x.push(G[D](q,C,M))}return Promise.all(x)}},"getApplyToIntermediateSource"),y=this.sources[this.sources.length-1],b=a(D=>{if(y[D]&&(!y[D].reliesOnPrototype||y.prototype[D]))return(N,M,q)=>{if(!N?.source)return y[D](M,q,N)}},"getApplyToCanonicalSource");return De={put:b("put"),patch:b("patch"),delete:b("delete"),publish:b("publish")},ve={put:I("put"),patch:I("patch"),delete:I("delete"),publish:I("publish"),invalidate:I("invalidate")},(async()=>{let D=!1,N=a(async(M,q)=>{let C=M.value,x=M.table?tt[c][M.table]:We;if(c===qn.SYSTEM_SCHEMA_NAME&&(M.table===qn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME||M.table===qn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME)&&(D=!0),M.id===void 0&&(M.id=C[x.primaryKey],M.id===void 0))throw new Error("Replication message without an id "+JSON.stringify(M));M.source=m;let G=await x.getResource(M.id,q,za);switch(M.type){case"put":return G._writeUpdate(C,!0,za);case"patch":return G._writeUpdate(C,!1,za);case"delete":return G._writeDelete(za);case"publish":return G._writePublish(C,za);case"invalidate":return G.invalidate(za);default:je.error("Unknown operation",M.type,M.id)}},"writeUpdate");try{let M=m.subscribe;M&&S==null&&(S=!0);let q=m.subscribeOnThisThread?m.subscribeOnThisThread((0,wo.getWorkerIndex)()):(0,wo.getWorkerIndex)()===0,C=M&&q&&await m.subscribe?.({crossThreads:!1,inTransactionUpdates:!0,supportsTransactions:!0,omitCurrent:!0});if(C){let x;for await(let G of C)try{if(!(G.type==="transaction"?G.writes[0]:G)){je.error("Bad subscription event",G);continue}if(G.source=m,x)if(G.beginTxn)x.resolve();else{N(G,x);continue}if(G.type==="end_txn")continue;let pe=ze(G,()=>{if(G.type==="transaction"){let ee=[];for(let Ue of G.writes)try{ee.push(N(Ue,G))}catch(ae){throw ae.message+=" writing "+JSON.stringify(Ue)+" of event "+JSON.stringify(G),ae}return Promise.all(ee)}else if(G.type==="define_schema"){let ee=this.attributes.slice(0),Ue;for(let ae of G.attributes)ee.find(Ge=>Ge.name===ae.name)||(ee.push(ae),Ue=!0);Ue&&(ut({table:s,database:c,attributes:ee,origin:"cluster"}),Nl.signalSchemaChange(new Il.SchemaEventMsg(process.pid,qn.OPERATIONS_ENUM.CREATE_TABLE,c,s)))}else return G.beginTxn?(x=G,N(G,G),new Promise(ee=>{x.resolve=ee})):N(G,G)});D&&(await pe,Nl.signalUserChange(new Il.UserEventMsg(process.pid))),G.onCommit&&(pe?.then?pe.then(G.onCommit):G.onCommit())}catch(se){je.error("error in subscription handler",se)}}}catch(M){je.error(M)}})(),this}static getResource(m,O,I){let y=super.getResource(m,O,I);if(m!=null){rc(m);try{if(y.hasOwnProperty(_e))return y;if(typeof m=="object"&&m&&!Array.isArray(m))throw new Error(`Invalid id ${JSON.stringify(m)}`);let b=!I?.async||i.cache?.get(m),D=Rn(O),N=D.getReadTxn();if(N?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");return dh(m,O,{transaction:N},b,M=>{if(M?FE(y,M):y[_e]=null,O.onlyIfCached&&O.noCacheStore){if(!y.doesExist())throw new en.ServerError("Entry is not cached",504)}else if(I?.ensureLoaded){let q=fh(m,M,O,y);if(q)return D?.disregardReadTxn(),y[fA]=!0,hA(q,C=>(FE(y,C),y))}return y})}catch(b){throw b.message.includes("Unable to serialize object")&&(b.message+=": "+JSON.stringify(m)),b}}return y}ensureLoaded(){let m=fh(this[Le],this[Zr],this[ye]);if(m)return this[fA]=!0,hA(m,O=>{this[Zr]=O,this[_e]=O.value,this[bl]=O.version})}static setTTLExpiration(m){if(typeof m=="number")f=m*1e3,E||(E=0);else if(m&&typeof m=="object")f=m.expiration*1e3,E=(m.eviction||0)*1e3,Mt=m.scanInterval*1e3;else throw new Error("Invalid expiration value type");if(f<0)throw new Error("Expiration can not be negative");Mt=Mt||(f+E)/4,hh()}static enableAuditing(m=!0){h=m,m&&qA(),We.audit=m}static coerceId(m){return m===""?null:GE(m,v)}static async dropTable(){if(delete tt[c][s],c===o){for(let m of p)l.remove(We.tableName+"/"+m.name),r[m.name]?.drop();l.remove(We.tableName+"/"),i.drop(),await l.committed}else console.log("legacy dropTable"),await i.close(),await fs.remove(data_path),await fs.remove(data_path===standard_path?data_path+MDB_LOCK_FILE_SUFFIX:path.join(path.dirname(data_path),MDB_LEGACY_LOCK_FILE_NAME));Nl.signalSchemaChange(new Il.SchemaEventMsg(process.pid,qn.OPERATIONS_ENUM.DROP_TABLE,c,s))}get(m){if(typeof m=="string")return this.getProperty(m);if(this[Gn])return this.search(m);if(this[Le]===null){if(m?.conditions)return this.search(m);let O=We.getRecordCount();return{recordCount:O.recordCount,estimatedRecordRange:O.estimatedRange,records:"./",name:s,database:c,attributes:p}}if(m?.property)return this.getProperty(m.property);if(this.doesExist()||m?.ensureLoaded===!1||this[ye]?.returnNonexistent)return this}allowRead(m,O){let I=kl(m);if(I?.read){if(I.isSuperUser)return!0;let y=I.attribute_permissions,b=O?.select;if(y?.length>0||xA&&b){if(O||(O={}),b){let D=y?.length>0&&EA(y,"read");O.select=b.map(N=>{let M=N.name||N;if(!D||D[M]){let q=Ks[M]?.definition?.tableClass;if(q){if(N.name||(N={name:N}),!q.prototype.allowRead.call(null,m,N))return!1;if(!N.select)return N.name}return N}}).filter(Boolean)}else O.select=y.filter(D=>D.read&&!Ks[D.attribute_name]).map(D=>D.attribute_name);return O}else return!0}}allowUpdate(m,O){let I=kl(m);if(I?.update){let y=I.attribute_permissions;if(y?.length>0){let b=EA(y,"update");for(let D in O)if(!b[D])return!1;for(let D of y){let N=D.attribute_name;!D.update&&!(N in O)&&(O[N]=this.getProperty(N))}}return!0}}allowCreate(m,O){if(this[Gn]){let I=kl(m);if(I?.insert){let y=I.attribute_permissions;if(y?.length>0){let b=EA(y,"insert");for(let D in O)if(!b[D])return!1}else return!0}}else return this.allowUpdate(m,{})}allowDelete(m){return kl(m)?.delete}update(m,O){if(!Rn(this[ye]))throw new Error("Can not update a table resource outside of a transaction");if(m===!1)return this;let y;return typeof m=="object"&&m&&(O?(Object.isFrozen(m)&&(m=Object.assign({},m)),this[_e]={},this[Ot]=m):(y=this[Ot],y&&(m=Object.assign(y,m)),this[Ot]=y=m)),this._writeUpdate(this[Ot],O),this}addTo(m,O){if(typeof O=="number"||typeof O=="bigint")this[gl]===Ax?this.set(m,(+this.getProperty(m)||0)+O):(this[gl]||this.update(),this.set(m,new vE(O)));else throw new Error("Can not add a non-numeric value")}subtractFrom(m,O){if(typeof O=="number")return this.addTo(m,-O);throw new Error("Can not subtract a non-numeric value")}invalidate(m){let O=this[ye],I=this[Le];rc(I),Rn(this[ye]).addWrite({key:I,store:i,invalidated:!0,entry:this[Zr],nodeName:this[ye]?.nodeName,before:De.invalidate?.bind(this,O,I),beforeIntermediate:ve.invalidate?.bind(this,O,I),commit:(b,D)=>{if(D?.version>b)return;let N=null;for(let M in r)N||(N={}),N[M]=this.getProperty(M);T(I,N,this[Zr],b,Rl,h,this[ye],0,"invalidate")}})}static evict(m,O,I){let y=this.Source,b;if(!((L||h)&&(!O||(b=i.getEntry(m),!b||!O)||b.version!==I))){if(L){if(i.hasLock(m,b.version))return;let D;for(let N in r)D||(D={}),D[N]=O[N];if(D)return T(m,D,b,I,Al,null,null,0,null,!0)}return i.ifVersion(m,I,()=>{ql(m,O,null)}),h?T(m,null,b,I,Al,null,null,0,null,!0):i.remove(m,I)}}lock(){throw new Error("Not yet implemented")}static operation(m,O){return m.table||=s,m.schema||=c,wx.operation(m,O)}put(m){this.update(m,!0)}patch(m){this.update(m,!1)}_writeUpdate(m,O,I){let y=this[ye],b=Rn(y),D=this[Le];rc(D);let N=this[Zr];this[gl]=O?Ax:Vne;let M={key:D,store:i,entry:N,nodeName:y?.nodeName,validate:q=>{m||(m=this[Ot]),O||m&&UE(this[Ot]===m?this:m)?y?.source||(b.checkOverloaded(),this.validate(m,!O),H&&(m[H.name]=H.type==="Date"?new Date(q):H.type==="String"?new Date(q).toISOString():q),O&&(t&&m[t]!==D&&(m[t]=D),k&&(N?.value?m[k.name]=N?.value[k.name]:m[k.name]=k.type==="Date"?new Date(q):k.type==="String"?new Date(q).toISOString():q),m=No(m))):b.removeWrite(M)},before:O?De.put?()=>De.put(y,D,m):null:De.patch?()=>De.patch(y,D,m):De.put?()=>De.put(y,D,No(this)):null,beforeIntermediate:O?ve.put?()=>ve.put(y,D,m):null:ve.patch?()=>ve.patch(y,D,m):ve.put?()=>ve.put(y,D,No(this)):null,commit:(q,C,x)=>{if(x){if(y&&C?.version>(y.lastModified||0)&&(y.lastModified=C.version),this[Zr]=C,C?.value?.[_e])throw new Error("Can not assign a record to a record, check for circular references");O||(this[_e]=C?.value??null)}this[Ot]=void 0,this[bl]=q;let G=C?.value,se=m;if(this[gl]=0,C?.version>=q)if(h){let ae=C.localTime,Ge=C.version;for(;se&&(ae>q||Ge>=q&&ae>0);){let re=u.get(ae);if(!re)break;let j=Ut(re);if(Ge=j.version,Ge>q){if(j.type==="patch"){let Se=j.getValue(i);se=LE(se,Se)}else if(j.type==="put"||j.type==="delete")return}else if(Ge===q)return;ae=j.previousLocalTime}}else{if(O)return;se=LE(se,G)}let pe;if(O?pe=se:(this[_e]=G,pe=O?se:No(this,se)),this[_e]=pe,pe?.[_e])throw new Error("Can not assign a record to a record, check for circular references");let ee;O||(ee=m),ql(D,G,pe);let Ue=O?"put":"patch";T(D,pe,C,q,0,h,y,y.expiresAt||(f?f+Date.now():0),Ue,!1,ee)}};b.addWrite(M)}async delete(m){if(typeof m=="string")return this.deleteProperty(m);if(this[Gn]){for await(let O of this.search(m))(await We.getResource(O[t],this.getContext(),{ensureLoaded:!1}))._writeDelete(m);return}return this[_e]?this._writeDelete(m):!1}_writeDelete(m){let O=Rn(this[ye]),I=this[Le];rc(I);let y=this[ye];return O.addWrite({key:I,store:i,resource:this,nodeName:y?.nodeName,before:De.delete?.bind(this,y,I),beforeIntermediate:ve.delete?.bind(this,y,I),commit:(b,D,N)=>{let M=D?.value;N&&(y&&D?.version>(y.lastModified||0)&&(y.lastModified=D.version),FE(this,D)),!(D?.version>b)&&(ql(this[Le],M),je.trace("Write delete entry",I,b),h||S?(T(I,null,this[Zr],b,0,h,this[ye],0,"delete"),h||hh()):i.remove(this[Le]))}}),!0}search(m){let O=this[ye],I=Rn(O);if(!m)throw new Error("No query provided");let y=m.conditions;y?y.length===void 0&&(y=y[Symbol.iterator]?Array.from(y):[y]):y=Array.isArray(m)?m:m[Symbol.iterator]?Array.from(m):[],this[Le]&&(y=[{attribute:null,comparator:"prefix",value:this[Le]}].concat(y));let b,D={};function N(j,Se){let Be;switch(Se){case"and":case void 0:if(j.length<1)throw new Error('An "and" operator requires at least one condition');Be=!0;break;case"or":if(j.length<2)throw new Error('An "or" operator requires at least two conditions');break;default:throw new Error("Invalid operator "+Se)}let Vn=Be&&{},Ws;for(let $e of j){if($e.conditions){$e.conditions=N($e.conditions,$e.operator);continue}let Ft=$e[0]??$e.attribute,nn=Ft==null?v:Hs(p,Ft);if(nn){if(Be){let $n=vn(Ft),qt=Vn[$n];qt?(qt.push($e),Ws=!0):Vn[$n]=[$e]}(nn.type||Sg[$e.comparator])&&($e[1]===void 0?$e.value=q($e.value,nn):$e[1]=q($e[1],nn))}else if(Ft!=null)throw(0,en.handleHDBError)(new Error,`${Ft} is not a defined attribute`,404)}if(m.enforceExecutionOrder)return j;if(Ws)for(let $e in Vn){let Ft=Vn[$e],nn=Ft.length;if(nn>1)for(let $n=0;$n<nn;$n++){let qt=Ft[$n];if(qt.comparator==="ge"||qt.comparator==="greater_than_equal")for(let Qs=0;Qs<nn;Qs++){let Bo=Ft[Qs];(Bo.comparator==="le"||Bo.comparator==="less_than_equal")&&(qt.comparator="between",qt.value=[qt.value,Bo.value],j.splice(j.indexOf(Bo),1))}if(qt.comparator==="equals"||!qt.comparator){for(let Qs=0;Qs<nn;Qs++)if(Qs!==$n){let Bo=Ft[Qs];j.splice(j.indexOf(Bo),1)}break}}}return j}a(N,"prepareConditions");function M(j,Se){if(m.enforceExecutionOrder)return j;for(let Be of j)Be.conditions&&(Be.conditions=M(Be.conditions,Be.operator));return j.length>1&&Se!=="or"?(0,Ix.sortBy)(j,wf(We)):j}a(M,"orderConditions");function q(j,Se){return Array.isArray(j)?j.map(Be=>GE(Be,Se)):GE(j,Se)}a(q,"coerceTypedValues");let C=m.operator;(y.length>0||C)&&(y=N(y,C));let x=typeof m.sort=="object"&&m.sort,G;if(x&&C!=="or"){let j=x.attribute;if(b=y.find(Se=>vn(Se.attribute)===vn(j)),!b){let Se=Hs(p,j);if(!Se)throw(0,en.handleHDBError)(new Error,`${Array.isArray(j)?j.join("."):j} is not a defined attribute`,404);if(Se.indexed)b={attribute:j,comparator:"sort"},y.push(b);else if(y.length===0&&!m.allowFullScan)throw(0,en.handleHDBError)(new Error,`${Array.isArray(j)?j.join("."):j} is not indexed and not combined with any other conditions`,404)}b&&(b.descending=!!x.descending)}y=M(y,C),x&&(b&&y[0]===b?x.next&&(G={dbOrderedAttribute:x.attribute,attribute:x.next.attribute,descending:x.next.descending,next:x.next.next}):(b&&y.splice(y.indexOf(b),1),G=x));let se=m.select;if(y.length===0&&(y=[{attribute:t,comparator:"greater_than",value:!0}]),m.explain)return{conditions:y,operator:C,postOrdering:G,selectApplied:!!se};let pe=I.useReadTxn(),ee=Tg(y,C,We,pe,m,O,(j,Se)=>GA(j,se,O,pe,Se),D),Ue=m.ensureLoaded!==!1;G||(ee=re(ee));let ae=We.transformEntryForSelect(se,O,pe,D,Ue,!0),Ge=We.transformToOrderedSelect(ee,se,G,pe,O,ae);function re(j){return m.offset||m.limit!==void 0?j.slice(m.offset,m.limit!==void 0?(m.offset||0)+m.limit:void 0):j}return a(re,"applyOffset"),G&&(Ge=re(Ge)),Ge.onDone=()=>{Ge.onDone=null,I.doneReadTxn()},Ge.selectApplied=!0,Ge.getColumns=()=>{if(se){let j=[];for(let Se of se)Se==="*"?j.push(...p.map(Be=>Be.name)):j.push(Se.name||Se);return j}return p.map(j=>j.name)},Ge}static transformToOrderedSelect(m,O,I,y,b,D){let N=new IG;if(I){m=GA(m,O,y,b,null);let M;N.iterate=function(){let C,x=m[Symbol.asyncIterator]?m[Symbol.asyncIterator]():m[Symbol.iterator](),G,se=I.dbOrderedAttribute,pe,ee,Ue=!0;function ae(re){let j=re.next&&ae(re.next),Se=re.descending;return(Be,Vn)=>{let Ws=Eh(Be,re.attribute,y),$e=Eh(Vn,re.attribute,y),Ft=Se?(0,Co.compareKeys)($e,Ws):(0,Co.compareKeys)(Ws,$e);return Ft===0?j?.(Be,Vn)||0:Ft}}a(ae,"createComparator");let Ge=ae(I);return{async next(){let re;if(C)if(re=C.next(),re.done){if(G)return N.onDone&&N.onDone(),re}else return{value:await D.call(this,re.value)};M=[],pe&&M.push(pe);do if(re=await x.next(),re.done){if(G=!0,M.length)break;return N.onDone&&N.onDone(),re}else{let j=re.value;if(j?.then&&(j=await j),se){let Se=Eh(j,se,y);if(Ue)Ue=!1,ee=Se;else if(Se!==ee){ee=Se,pe=j;break}}M.push(j)}while(!0);return I.isGrouped,M.sort(Ge),C=M[Symbol.iterator](),re=C.next(),re.done?(N.onDone&&N.onDone(),re):{value:await D.call(this,re.value)}},return(){N.onDone&&N.onDone(),x.return()},throw(){N.onDone&&N.onDone(),x.throw()}}};let q=a(C=>{if(typeof O=="object"&&Array.isArray(C.attribute))for(let x=0;x<O.length;x++){let G=O[x],se;if(G.name===C.attribute[0]){for(se=G.sort||(G.sort={});se.next;)se=se.next;se.attribute=C.attribute.slice(1),se.descending=C.descending}else G===C.attribute[0]&&(O[x]=se={name:G,sort:{attribute:C.attribute.slice(1),descending:C.descending}})}C.next&&q(C.next)},"applySortingOnSelect");q(I)}else N.iterate=(m[Symbol.asyncIterator]||m[Symbol.iterator]).bind(m),N=N.map(D);return N}static transformEntryForSelect(m,O,I,y,b,D){if(m&&(m===t||m?.length===1&&m[0]===t)){let C=a(x=>(O?.transaction?.stale&&(O.transaction.stale=!1),x?.key??x),"transform");return m===t?C:m.asArray?x=>[C(x)]:x=>({[t]:C(x)})}let N;b&&L&&!m?.every(C=>{let x;return typeof C=="object"?x=C.name:x=C,r[x]||x===t})&&(N=!0);let M,q=a(function(C){let x;if(O?.transaction?.stale&&(O.transaction.stale=!1),C!=null){if(lh=C,x=C.value||C.deref?.(),!x&&(C.key===void 0||C.deref)){if(C=dh(C.key??C,O,{transaction:I,lazy:m?.length<4},this.isSync,G=>G),C?.then)return C.then(q.bind(this));x=C?.value}if(N&&(C.metadataFlags&(Rl|Al)||C.expiresAt&&C.expiresAt<Date.now())){let G=fh(C.key??C,C,O);if(G?.then)return G.then(q)}}if(x==null)return D?Io.SKIP:x;if(m&&!(m[0]==="*"&&m.length===1)){let G,se=a((ee,Ue)=>{let ae;typeof ee=="object"?ae=ee.name:ae=ee;let Ge=Ks?.[ae],re;if(Ge){let j=y?.[ae];if(j)if(j.hasMappings){let Be=Ge.from?x[Ge.from]:vn(C.key);re=j.get(Be),re||(re=[])}else re=j.fromRecord?.(x);else re=Ge(x,O,C);let Se=a(Be=>{if(Be&&typeof Be=="object"){let Vn=Ge.definition?.tableClass||We;M||(M={});let Ws=M[ae]||(M[ae]=Vn.transformEntryForSelect(ae===ee?null:ee.select||(Array.isArray(ee)?ee:null),O,I,j,b));if(Array.isArray(Be)){let $e=[],Ft=Vn.transformToOrderedSelect(Be,ee.select,typeof ee.sort=="object"&&ee.sort,O,I,Ws)[this.isSync?Symbol.iterator:Symbol.asyncIterator](),nn=a(qt=>{for(;!qt.done;){if(qt?.then)return qt.then(nn);$e.push(qt.value),qt=Ft.next()}Ue($e,ae)},"nextValue"),$n=nn(Ft.next());$n&&(G||(G=[]),G.push($n));return}else if(Be=Ws.call(this,Be),Be?.then){G||(G=[]),G.push(Be.then($e=>Ue($e,ae)));return}}Ue(Be,ae)},"handleResolvedValue");re?.then?(G||(G=[]),G.push(re.then(Se))):Se(re);return}else re=x[ae],re&&typeof re=="object"&&ae!==ee&&(re=We.transformEntryForSelect(ee.select||ee,O,I,null)({value:re}));Ue(re,ae)},"selectAttribute"),pe;if(typeof m=="string")se(m,ee=>{pe=ee});else if(Array.isArray(m))if(m.asArray)pe=[],m.forEach((ee,Ue)=>{ee==="*"?m[Ue]=x:se(ee,ae=>pe[Ue]=ae)});else{pe={};let ee=m.forceNulls;for(let Ue of m)if(Ue==="*")for(let ae in x)pe[ae]=x[ae];else se(Ue,(ae,Ge)=>{ae===void 0&&ee&&(ae=null),pe[Ge]=ae})}else throw new en.ClientError("Invalid select"+m);return G?Promise.all(G).then(()=>pe):pe}return x},"transform");return q}async subscribe(m){if(!u)throw new Error("Can not subscribe to a table without an audit log");h||ut({table:s,database:c,schemaDefined:_,attributes:p,audit:!0}),m||(m={});let O=!m.rawEvents,I=Sx(We,this[Le]??null,function(N,M,q,C){try{let x=M.getValue?.(i,O);if(!x&&M.type==="patch"&&O){let G=i.getEntry(N);G?.version===M.version?x=G.value:x=M.getValue?.(i,!0,q),M.type="put"}this.send({id:N,timestamp:q,value:x,version:M.version,type:M.type,beginTxn:C})}catch(x){je.error(x)}},m.startTime||0,m);this[Gn]&&(I.includeDescendants=!0,m.onlyChildren&&(I.onlyChildren=!0)),m.supportsTransactions&&(I.supportsTransactions=!0);let y=this[Le],b=m.previousCount;b>1e3&&(b=1e3);let D=m.startTime;if(this[Gn]){if(D){if(b)throw new en.ClientError("startTime and previousCount can not be combined for a table level subscription");for(let{key:N,value:M}of u.getRange({start:D,exclusiveStart:!0})){let q=Ut(M);if(q.tableId!==n)continue;let C=q.recordId;if(y==null||yx(y,C)){let x=q.getValue(i,O,N);I.send({id:C,timestamp:N,value:x,version:q.version,type:q.type})}I.startTime=N}}else if(b){let N=[];for(let{key:M,value:q}of u.getRange({start:"z",end:!1,reverse:!0}))try{let C=Ut(q);if(C.tableId!==n)continue;let x=C.recordId;if(y==null||yx(y,x)){let G=C.getValue(i,O,M);if(N.push({id:x,timestamp:M,value:G,version:C.version,type:C.type}),--b<=0)break}}catch(C){je.error("Error getting history entry",M,C)}for(let M=N.length;M>0;)I.send(N[--M]);N[0]&&(I.startTime=N[0].timestamp)}else if(!m.omitCurrent)for(let{key:N,value:M,version:q,localTime:C}of i.getRange({start:y??!1,end:y==null?void 0:[y,Co.MAXIMUM_KEY],versions:!0}))M&&I.send({id:N,timestamp:C,value:M,version:q,type:"put"})}else{b&&!D&&(D=0);let N=this[Zr]?.localTime;if(N===nm&&(i.cache?.delete(y),this[Zr]=i.getEntry(y),je.trace("re-retrieved record",N,this[Zr]?.localTime),N=this[Zr]?.localTime),je.trace("Subscription from",D,"from",y,N),D<N){let M=[],q=N;do{let C=u.get(q);if(C){m.omitCurrent=!0;let x=Ut(C),G=x.getValue(i,O,q);O&&(x.type="put"),M.push({id:y,value:G,timestamp:q,...x}),q=x.previousLocalTime}else break;b&&b--}while(q>D&&b!==0);for(let C=M.length;C>0;)I.send(M[--C]);I.startTime=N}!m.omitCurrent&&this.doesExist()&&I.send({id:y,timestamp:N,value:this,version:this[bl],type:"put"})}return m.listener&&I.on("data",m.listener),I}doesExist(){return!!(this[_e]||this[gl])}publish(m,O){this._writePublish(m,O)}_writePublish(m,O){let I=Rn(this[ye]),y=this[Le]||null;rc(y);let b=this[ye];I.addWrite({key:y,store:i,entry:this[Zr],nodeName:b?.nodeName,validate:()=>{b?.source||(I.checkOverloaded(),this.validate(m))},before:De.publish?.bind(this,b,y,m),beforeIntermediate:ve.publish?.bind(this,b,y,m),commit:(D,N,M)=>{N===void 0&&S&&!h&&hh(),T(y,N?.value??null,N,N?.version||D,0,!0,b,N?.expiresAt,"message",!1,m)}})}validate(m,O){let I,y=a((b,D,N)=>{if(D.type&&b!=null)if(O&&b.__op__&&(b=b.value),D.properties){typeof b!="object"&&(I||(I=[])).push(`Value ${Fn(b)} in property ${N} must be an object${D.type?" ("+D.type+")":""}`);let M=D.properties;for(let q=0,C=M.length;q<C;q++){let x=M[q],G=y(b[x.name],x,N+"."+x.name);G&&(b[x.name]=G)}if(D.sealed&&b!=null&&typeof b=="object")for(let q in b)M.find(C=>C.name===q)||(I||(I=[])).push(`Property ${q} is not allowed within object in property ${N}`)}else switch(D.type){case"Int":(typeof b!="number"||b>>0!==b)&&(I||(I=[])).push(`Value ${Fn(b)} in property ${N} must be an integer (from -2147483648 to 2147483647)`);break;case"Long":(typeof b!="number"||!(Math.floor(b)===b&&Math.abs(b)<=9007199254740992))&&(I||(I=[])).push(`Value ${Fn(b)} in property ${N} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof b!="number"&&(I||(I=[])).push(`Value ${Fn(b)} in property ${N} must be a number`);break;case"ID":typeof b=="string"||b?.length>0&&b.every?.(M=>typeof M=="string")||(I||(I=[])).push(`Value ${Fn(b)} in property ${N} must be a string, or an array of strings`);break;case"String":typeof b!="string"&&(I||(I=[])).push(`Value ${Fn(b)} in property ${N} must be a string`);break;case"Boolean":typeof b!="boolean"&&(I||(I=[])).push(`Value ${Fn(b)} in property ${N} must be a boolean`);break;case"Date":if(!(b instanceof Date)){if(typeof b=="string"||typeof b=="number")return new Date(b);(I||(I=[])).push(`Value ${Fn(b)} in property ${N} must be a Date`)}break;case"BigInt":if(typeof b!="bigint"){if(typeof b=="string"||typeof b=="number")return BigInt(b);(I||(I=[])).push(`Value ${Fn(b)} in property ${N} must be a bigint`)}break;case"Bytes":b instanceof Uint8Array||(I||(I=[])).push(`Value ${Fn(b)} in property ${N} must be a Buffer or Uint8Array`);break;case"array":if(Array.isArray(b)){if(D.elements)for(let M=0,q=b.length;M<q;M++){let C=b[M],x=y(C,D.elements,N+"[*]");x&&(b[M]=x)}}else(I||(I=[])).push(`Value ${Fn(b)} in property ${N} must be a Buffer or Uint8Array`);break}D.nullable===!1&&b==null&&(I||(I=[])).push(`Property ${N} is required (and not does not allow null values)`)},"validateValue");for(let b=0,D=p.length;b<D;b++){let N=p[b];if(!N.relationship&&(!O||N.name in m)){let M=y(m[N.name],N,N.name);M&&(m[N.name]=M)}}if(d)for(let b in m)p.find(D=>D.name===b)||(I||(I=[])).push(`Property ${b} is not allowed`);if(I)throw new en.ClientError(I.join(". "))}getUpdatedTime(){return this[bl]}wasLoadedFromSource(){return L?!!this[fA]:void 0}static async addAttributes(m){let O=p.slice(0);for(let I of m){if(!I.name)throw new en.ClientError("Attribute name is required");if(I.name.match(/[`/]/))throw new en.ClientError("Attribute names cannot include backticks or forward slashes");O.push(I)}return ut({table:s,database:c,schemaDefined:_,attributes:O}),We.indexingOperation}static async removeAttributes(m){let O=p.filter(I=>!m.includes(I.name));return ut({table:s,database:c,schemaDefined:_,attributes:O}),We.indexingOperation}static getRecordCount(m){let O=i.getStats().entryCount,I=5e3,y=1e3,b;O>I&&!m?.exactCount&&(b=y);let D=0;for(let{value:N}of i.getRange({start:!0,lazy:!0,limit:b}))N!=null&&D++;if(b){let N=D;D=0;for(let{value:Ue}of i.getRange({start:"\uFFFF",reverse:!0,lazy:!0,limit:b}))Ue!=null&&D++;let M=b*2,q=(D+N)/M,C=Math.pow((D-N+1)/b/2,2)+q*(1-q)/M,x=Math.max(Math.sqrt(C)*O,1),G=Math.round(q*O),se=Math.max(G-1.96*x,0),pe=Math.min(G+1.96*x,O),ee=Math.pow(10,Math.round(Math.log10(x)));return ee>G&&(ee=ee/10),D=Math.round(G/ee)*ee,{recordCount:D,estimatedRange:[Math.round(se),Math.round(pe)]}}return{recordCount:D}}static updatedAttributes(){Ks=this.propertyResolvers={$id:(m,O,I)=>({value:I.key}),$updatedtime:(m,O,I)=>I.version,$record:(m,O,I)=>I?{value:m}:m};for(let m of this.attributes){m.resolve=null;let O=m.relationship;if(O)if(m.indexed&&console.error("A relationship property can not be directly indexed, (but you may want to index the foreign key attribute)"),xA=!0,O.to)m.elements?.definition?(Ks[m.name]=m.resolve=(I,y,b)=>{let D=I[O.from?O.from:t],N=m.elements.definition.tableClass;return b?Da({attribute:O.to,value:D},Rn(y).getReadTxn(),!1,N,!1).asArray:N.search([{attribute:O.to,value:D}],y).asArray},m.set=()=>{throw new Error("Setting a one-to-many relationship property is not supported")},m.resolve.definition=m.elements.definition,O.from&&(m.resolve.from=O.from)):console.error(`The one-to-many/many-to-many relationship property "${m.name}" in table "${s}" must have an array type referencing a table as the elements`);else if(O.from){let I=m.definition||m.elements?.definition;I?(Ks[m.name]=m.resolve=(y,b,D)=>{let N=y[O.from];if(N!==void 0){if(m.elements){let M,q=N.map(C=>{let x=D?I.tableClass.primaryStore.getEntry(C,{transaction:Rn(b).getReadTxn()}):I.tableClass.get(C,b);return x?.then&&(M=!0),x});return O.filterMissing?M?Promise.all(q).then(C=>C.filter(Nx)):q.filter(Nx):M?Promise.all(q):q}return D?I.tableClass.primaryStore.getEntry(N,{transaction:Rn(b).getReadTxn()}):I.tableClass.get(N,b)}},m.set=(y,b)=>{if(Array.isArray(b)){let D=b.map(N=>N[Le]||N[I.tableClass.primaryKey]);y[O.from]=D}else{let D=b[Le]||b[I.tableClass.primaryKey];y[O.from]=D}},m.resolve.definition=m.definition||m.elements?.definition,m.resolve.from=O.from):console.error(`The relationship property "${m.name}" in table "${s}" must be a type that references a table`)}else console.error(`The relationship directive on "${m.name}" in table "${s}" must use either "from" or "to" arguments`)}BE(this,this)}static async deleteHistory(m=0){let O;for(let{key:I,value:y}of u.getRange({start:0,end:m}))await Ol(),Ut(y).tableId===n&&(O=u.remove(I));await O}static async*getHistory(m=0,O=1/0){for(let{key:I,value:y}of u.getRange({start:m,end:O})){await Ol();let b=Ut(y);b.tableId===n&&(yield{id:b.recordId,localTime:I,version:b.version,type:b.type,value:b.getValue(i,!0,I),user:b.user})}}static async getHistoryOfRecord(m){let O=[];if(m==null)throw new Error("An id is required");let I=i.getEntry(m);if(!I)return O;let y=I.localTime;if(!y)throw new Error("The entry does not have a local audit time");let b=0;do{await Ol();let D=u.get(y);if(D){let N=Ut(D);O.push({id:N.recordId,localTime:y,version:N.version,type:N.type,value:N.getValue(i,!0,y),user:N.user}),y=N.previousLocalTime}else break}while(b<1e3&&y);return O.reverse()}static cleanup(){z?.remove()}}We.updatedAttributes();let DG=We.prototype;return DG[kne]=!0,f&&We.setTTLExpiration(f/1e3),X&&LG(),We;function ql(Y,m,O){let I;for(let y in r){let b=r[y],D=b.isIndexing,N=O?.[y],M=m?.[y];if(N===M&&!D)continue;I=!0;let q=b.indexNulls,C=(0,yl.getIndexedValues)(N,q),x=(0,yl.getIndexedValues)(M,q);if(x?.length>0){let G=new Set(x);if(C=C?C.filter(se=>{if(G.has(se))G.delete(se);else return!0}):[],x=Array.from(G),(x.length>0||C.length>0)&&Rx){let se=x.concat(C).map(pe=>({key:pe,value:Y}));b.prefetch(se,bx)}for(let se=0,pe=x.length;se<pe;se++)b.remove(x[se],Y)}else C?.length>0&&Rx&&b.prefetch(C.map(G=>({key:G,value:Y})),bx);if(C)for(let G=0,se=C.length;G<se;G++)b.put(C[G],Y)}return I}a(ql,"updateIndices");function rc(Y){switch(typeof Y){case"number":return!0;case"string":if(Y.length<659)return!0;if(Y.length>Ox)throw new Error("Primary key size is too large: "+Y.length);break;case"object":if(Y===null)return!0;break;case"bigint":if(Y<2n**64n&&Y>-(2n**64n))return!0;break;default:throw new Error("Invalid primary key type: "+typeof Y)}if((0,Co.writeKey)(Y,$ne,0)>Ox)throw new Error("Primary key size is too large: "+Y.length);return!0}a(rc,"checkValidId");function dh(Y,m,O,I,y){let b=a(()=>{if(m?.transaction?.stale&&(m.transaction.stale=!1),O.transaction?.isDone)return y(null,Y);let D=i.getEntry(Y,O);return D&&m&&(D?.version>(m.lastModified||0)&&(m.lastModified=D.version),D?.localTime&&!m.lastRefreshed&&(m.lastRefreshed=D.localTime)),y(D,Y)},"whenPrefetched");return I?b():ce>0?(ce--,b()):new Promise((D,N)=>{ce===0?(ce--,i.prefetch([Y],()=>{M(),q()})):(J.push(Y),me.push(q),J.length>CG&&(ce--,M()));function M(){if(J.length>0){let C=me;i.prefetch(J,()=>{ce===-1?M():ce++;for(let x of C)x()}),J=[],me=[],de>2&&de--}else ce=de,de<wG&&de++}a(M,"prefetch");function q(){try{D(b())}catch(C){N(C)}}a(q,"load")})}a(dh,"loadLocalRecord");function kl(Y){if(!Y?.role)return;let m=Y.role.permission;if(m.super_user)return Yne;let O=m[c],I,y=O?.tables;if(y)return y[s];if(c==="data"&&(I=m[s])&&!I.tables)return I}a(kl,"getTablePermissions");function fh(Y,m,O,I){if(L){let y;if(O.noCache?y=!0:(m?(!m.value||m.metadataFlags&(Rl|Al)||m.expiresAt&&m.expiresAt<Date.now())&&(y=!0):y=!0,Qr(!y,"cache-hit",s)),y){let b=FA(Y,m,O).then(D=>(D?.value?.[_e]&&je.error("Can not assign a record with a record property"),O&&(D?.version>(O.lastModified||0)&&(O.lastModified=D.version),O.lastRefreshed=Date.now()),D));if(O?.onlyIfCached||m?.value&&I?.allowStaleWhileRevalidate?.(m,Y)){if(b.catch(D=>je.warn(D)),O?.onlyIfCached&&!I.doesExist())throw new en.ServerError("Entry is not cached",504);return}else return b}}}a(fh,"ensureLoadedFromSource");function Rn(Y){let m=Y?.transaction;if(m){if(!m.lmdbDb)return m.lmdbDb=i,m;do{if(m.lmdbDb?.path===i.path)return m;let O=m.next;if(!O)return m=m.next=new ji,m.lmdbDb=i,m;m=O}while(!0)}else return new Z_}a(Rn,"txnForContext");function Eh(Y,m,O){if(!Y)return;lh=Y;let I=Y.value||Y.deref?.()||(lh=i.getEntry(Y.key))?.value;if(typeof m=="object"){let b=Ks,D=I;for(let N=0,M=m.length;N<M;N++){let q=m[N],C=b?.[q];D=C&&D?C(D,O,!0)?.value:D?.[q],b=C?.definition?.tableClass?.propertyResolvers}return D}let y=Ks[m];return y?y(I,O):I[m]}a(Eh,"getAttributeValue");function GA(Y,m,O,I,y){let b=y?.length,D={transaction:I,lazy:b>0||typeof m=="string"||m?.length<4,alwaysPrefetch:!0},N;function M(q,C){let x=q?.value;if(!x)return Io.SKIP;for(let G=0;G<b;G++)if(!N?.includes(G)&&!y[G](x,q))return Io.SKIP;return C!==void 0&&(q.key=C),q}if(a(M,"processEntry"),b>0||!Y.hasEntries){let q=Y.map(C=>{if(N=null,typeof C=="object"&&C?.key!==void 0)return b>0?M(C):C;if(C==null)return Io.SKIP;for(let x=0;x<b;x++){let se=y[x].idFilter;if(se){if(!se(C))return Io.SKIP;N||(N=[]),N.push(x)}}return dh(C,O,D,!1,M)});return Array.isArray(Y)&&(q=q.filter(C=>C!==Io.SKIP)),q.hasEntries=!0,q}return Y}a(GA,"transformToEntries");async function FA(Y,m,O){let I=m?.metadataFlags,y=m?.version,b,D;if(!i.attemptLock(Y,y,()=>{clearTimeout(D);let C=i.getEntry(Y);!C||!C.value||C.metadataFlags&(Rl|Al)?b(FA(Y,i.getEntry(Y),O)):b(C)}))return new Promise(C=>{b=C,D=setTimeout(()=>{i.unlock(Y,y)},qne)});let N=m?.value,M={requestContext:O,replacingRecord:N,replacingVersion:y,source:null,resourceCache:O?.resourceCache},q=O?.responseHeaders;return new Promise((C,x)=>{let G;hA(ze(M,async se=>{let pe=performance.now(),ee,Ue,ae;try{for(let Se of We.sources)if(Se.get&&(!Se.get.reliesOnPrototype||Se.prototype.get)&&(M.source=Se,ee=await Se.get(Y,M),ee))break;ae=I&Rl;let re=M.lastModified||ae&&y;Ue=ae||re>y||!N,re||(re=(0,yl.getNextMonotonicTime)());let j=performance.now()-pe;if(Wr(j,"cache-resolution",s),q&&xT(q,"Server-Timing",`cache-resolve;dur=${j.toFixed(2)}`,!0),se.timestamp=re,f&&!M.expiresAt&&(M.expiresAt=Date.now()+f),ee){if(typeof ee!="object")throw new Error("Only objects can be cached and stored in tables");typeof ee.toJSON=="function"&&(ee=ee.toJSON()),t&&ee[t]!==Y&&(ee[t]=Y)}G=!0,C({version:re,value:ee})}catch(re){re.message+=` while resolving record ${Y} for ${s}`,N&&((re.code==="ECONNRESET"||re.code==="ECONNREFUSED"||re.code==="EAI_AGAIN")&&!O?.mustRevalidate||O?.staleIfError&&(re.statusCode===500||re.statusCode===502||re.statusCode===503||re.statusCode===504))?(C({version:y,value:N}),je.trace(re.message,"(returned stale record)")):x(re),M.transaction.abort();return}if(O?.noCacheStore){M.transaction.abort();return}Rn(M).addWrite({key:Y,store:i,entry:m,nodeName:"source",commit:(re,j)=>{if(j?.version!==y)return;let Se=ql(Y,N,ee);ee?(ve.put?.(M,Y,ee),T(Y,ee,j,re,0,h&&Ue||null,M,M.expiresAt,"put",!!ae)):(ve.delete?.(M,Y),h||S?T(Y,null,j,re,0,h&&Ue||null,M,0,"delete",!!ae):i.remove(Y,y))}})}),()=>{i.unlock(Y,y)},se=>{i.unlock(Y,y),G&&je.error("Error committing cache update",se)})})}a(FA,"getFromSource");function hh(){if(Mt!==Gl&&(Gl=Mt,(0,wo.getWorkerIndex)()===(0,wo.getWorkerCount)()-1)){if(Fl&&clearTimeout(Fl),!Mt)return;let Y=new Date;Y.setMonth(0),Y.setDate(1),Y.setHours(0),Y.setMinutes(0),Y.setSeconds(0);let m=Math.ceil((Date.now()-Y.getTime())/Mt)*Mt+Y.getTime(),O=a(I=>{je.trace(`Scheduled next cleanup scan at ${new Date(I)}ms`),Fl=setTimeout(()=>P=P.then(async()=>{if(O(Math.max(I+Mt,Date.now())),i.rootStore.status!=="open"){clearTimeout(Fl);return}let y=50,b=new Array(y),D=0;je.trace(`Starting cleanup scan for ${s}`);try{let N=0;for(let{key:M,value:q,version:C,expiresAt:x}of i.getRange({start:!1,snapshot:!1,versions:!0,lazy:!0})){let G;q===null&&!h&&C+Fne<Date.now()?G=i.remove(M,C):x&&x+E<Date.now()&&(G=We.evict(M,q,C),N++),G&&(await b[D],b[D]=G.catch(se=>{je.error("Cleanup error",se)}),++D>=y&&(D=0)),await Ol()}je.trace(`Finished cleanup scan for ${s}, evicted ${N} entries`)}catch(N){je.trace(`Error in cleanup scan for ${s}:`,N)}}),Math.min(I-Date.now(),2147483647)).unref()},"startNextTimer");O(m)}}a(hh,"scheduleCleanup");function qA(){z=u?.addDeleteRemovalCallback(n,Y=>{let m=i.getEntry(Y);m?.value===null&&i.remove(Y,m.version)})}a(qA,"addDeleteRemoval");function LG(){(0,wo.getWorkerIndex)()===0&&setInterval(async()=>{if(!_h){_h=!0;try{let Y=X.name,m=r[Y];if(!m)throw new Error(`expiresAt attribute ${X} must be indexed`);for(let O of m.getRange({start:!0,values:!1,end:Date.now(),snapshot:!1})){for(let I of m.getValues(O)){let y=i.getEntry(I);y?.value?y.value[Y]<Date.now()&&We.evict(I,y.value,y.version):i.ifVersion(I,y?.version,()=>m.remove(O,I))}await Ol()}}catch(Y){je.error("Error in evicting old records",Y)}finally{_h=!1}}},Gne).unref()}a(LG,"runRecordExpirationEviction")}function EA(e,t){let r=e.attr_object||(e.attr_object={}),n=r[t];if(n)return n;n=r[t]=Object.create(null);for(let s of e)n[s.attribute_name]=s[t];return n}function bx(){}function Kne(e){wx=e}function GE(e,t){let r=t?.type;return e===null?e:e===""&&r&&r!=="String"&&r!=="Any"?null:r==="Int"||r==="Long"?e==="null"?null:parseInt(e):r==="Float"?e==="null"?null:parseFloat(e):r==="BigInt"?e==="null"?null:BigInt(e):r==="Boolean"?e==="true"?!0:e==="false"?!1:e:r==="Date"?isNaN(e)?e==="null"?null:(Wne.test(e)||(e+="Z"),new Date(e)):new Date(+e):!r||r==="Any"?(0,qE.autoCast)(e):e}function yx(e,t){if(e==null)return!0;if(!Array.isArray(t))return e===t;if(Array.isArray(e)){let r=e.length;if(e[r-1]===null&&r--,t.length>=r){for(let n=0;n<r;n++)if(t[n]!==e[n])return!1;return!0}return!1}else if(t[0]===e)return!0}function hA(e,t,r){return e?.then?e.then(t,r):t(e)}function FE(e,t){e[Zr]=t,e[_e]=t?.value??null,e[bl]=t?.version}function Nx(e){return e!=null}function Fn(e){try{return JSON.stringify(e)}catch{return e}}var qn,Io,yl,Ix,wl,en,Nl,Il,je,Co,wo,qE,xne,wx,Gne,Fne,Rx,qne,bl,kne,Zr,gl,Ax,Vne,fA,za,Rl,Al,$ne,Ox,Yne,ppe,Wne,Ol,$f=Re(()=>{qn=B(U()),Io=require("lmdb"),yl=B(Mr()),Ix=require("lodash");bn();zp();wl=B(te());gx();en=B(ne()),Nl=B(Rs()),Il=B(Dn());Ae();Df();je=B(K());rd();Zi();Co=require("ordered-binary"),wo=B(ct());js();qE=B(Q());bc();vs();CE();Mu();xne=new Uint8Array(9);xne[8]=192;Gne=6e4,Fne=864e5;wl.initSync();Rx=wl.get(qn.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),qne=1e4,bl=Symbol.for("version"),kne=Symbol.for("incremental-update"),Zr=Symbol("entry"),gl=Symbol("is-saving"),Ax=1,Vne=2,fA=Symbol("loaded-from-source"),za={isNotification:!0,ensureLoaded:!1},Rl=1,Al=8,$ne=Buffer.allocUnsafeSlow(8192),Ox=1978,Yne={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},ppe=(0,qE.convertToMS)(wl.get(qn.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;a(kE,"makeTable");a(EA,"attributesAsObject");a(bx,"noop");a(Kne,"setServerUtilities");Wne=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;a(GE,"coerceType");a(yx,"isDescendantId");Ol=a(()=>new Promise(setImmediate),"rest");a(hA,"when");a(FE,"updateResource");a(Nx,"exists");a(Fn,"stringify")});var qe={};Fe(qe,{database:()=>Zc,databases:()=>tt,dropDatabase:()=>eS,dropTableMeta:()=>jne,getDatabases:()=>Er,getDefaultCompression:()=>Wd,getTables:()=>Qne,onUpdatedTable:()=>yR,readMetaDb:()=>Cl,resetDatabases:()=>yu,table:()=>ut,tables:()=>Ur});function Qne(){return WE||Er(),Ur||{}}function Er(){if(WE)return tt;WE=!0,ja=new Map;let e=(0,Et.getHdbBasePath)()&&(0,Ze.join)((0,Et.getHdbBasePath)(),Lt.DATABASES_DIR_NAME),t=(0,Et.get)(Lt.CONFIG_PARAMS.DATABASES)||{};if(process.env.SCHEMAS_DATA_PATH&&(t.data={path:process.env.SCHEMAS_DATA_PATH}),e=process.env.STORAGE_PATH||(0,Et.get)(Lt.CONFIG_PARAMS.STORAGE_PATH)||e&&((0,tn.existsSync)(e)?e:(0,Ze.join)((0,Et.getHdbBasePath)(),Lt.LEGACY_DATABASES_DIR_NAME)),!!e){if((0,tn.existsSync)(e))for(let r of(0,tn.readdirSync)(e,{withFileTypes:!0})){let n=(0,Ze.basename)(r.name,".mdb");r.isFile()&&(0,Ze.extname)(r.name).toLowerCase()===".mdb"&&!t[n]?.path&&Cl((0,Ze.join)(e,r.name),null,n)}if((0,tn.existsSync)((0,Xa.getBaseSchemaPath)())){for(let r of(0,tn.readdirSync)((0,Xa.getBaseSchemaPath)(),{withFileTypes:!0}))if(!r.isFile()){let n=(0,Ze.join)((0,Xa.getBaseSchemaPath)(),r.name),s=(0,Ze.join)((0,Xa.getTransactionAuditStoreBasePath)(),r.name);for(let i of(0,tn.readdirSync)(n,{withFileTypes:!0}))if(i.isFile()&&(0,Ze.extname)(i.name).toLowerCase()===".mdb"){let o=(0,Ze.join)(s,i.name);Cl((0,Ze.join)(n,i.name),(0,Ze.basename)(i.name,".mdb"),r.name,o,!0)}}}if(t)for(let r in t){let n=t[r],s=n.path;if((0,tn.existsSync)(s))for(let o of(0,tn.readdirSync)(s,{withFileTypes:!0}))o.isFile()&&(0,Ze.extname)(o.name).toLowerCase()===".mdb"&&Cl((0,Ze.join)(s,o.name),(0,Ze.basename)(o.name,".mdb"),r);let i=n.tables;if(i)for(let o in i){let c=i[o],u=(0,Ze.join)(c.path,(0,Ze.basename)(o+".mdb"));(0,tn.existsSync)(u)&&Cl(u,o,r,null,!0)}}for(let r in tt){let n=ja.get(r);if(n){let s=tt[r];r.includes("delete")&&gn.trace(`defined tables ${Array.from(n.keys())}`);for(let i in s)n.has(i)||(gn.trace(`delete table class ${i}`),delete s[i])}else if(delete tt[r],r==="data"){for(let s in Ur)delete Ur[s];delete Ur[zE]}}return ja=null,tt}}function yu(){WE=!1;for(let[,e]of Di)e.needsDeletion=!0;Er();for(let[e,t]of Di)t.needsDeletion&&!e.endsWith("system.mdb")&&(t.close(),Di.delete(e));return tt}function Cl(e,t,r=SA,n,s){let i=new mA.default(e,!1);try{let o=Di.get(e);o?o.needsDeletion=!1:(o=(0,$E.open)(i),Di.set(e,o));let c=new Do.default(!1),u=o.dbisDb||(o.dbisDb=o.openDB(VE.INTERNAL_DBIS_NAME,c)),_=o.auditStore;_||(n?(0,tn.existsSync)(n)&&(i.path=n,_=(0,$E.open)(i),_.isLegacy=!0):_=wE(o));let l=Mx(r),d=l[zE],f=new Map;for(let{key:E,value:h}of u.getRange({start:!1})){let[S,p]=E.toString().split("/");p===""?p=h.name:p||(p=S,S=t,h.name||(h.name=p,h.indexed=!h.is_hash_attribute)),d?.add(S);let T=f.get(S);T||f.set(S,T={attributes:[]}),(p==null||h.is_hash_attribute)&&(T.primary=h),p!=null&&T.attributes.push(h),Object.defineProperty(h,"key",{value:E,configurable:!0})}for(let[E,h]of f){let{attributes:S,primary:p}=h;if(!p){for(let J of S)if(J.is_hash_attribute||J.isPrimaryKey){p=J;break}if(!p){gn.fatal(`Unable to find a primary key attribute on table ${E}, with attributes: ${JSON.stringify(S)}`);continue}}let T=l[E],A={},g=[],L,v,P=typeof p.audit=="boolean"?p.audit:(0,Et.get)(Lt.CONFIG_PARAMS.LOGGING_AUDITLOG),k=p.trackDeletes,H=p.expiration,X=p.eviction,z=p.sealed;if(T)A=T.indices,g=T.attributes,T.schemaVersion++;else{L=p.tableId,L?L>=(u.get(Ja)||0)&&u.putSync(Ja,L+1):(p.tableId=L=u.get(Ja),L||(L=1),u.putSync(Ja,L+1),u.putSync(p.key,p));let J=new Do.default(!p.is_hash_attribute,p.is_hash_attribute);if(J.compression=p.compression,J.compression){let me=(0,Et.get)(Lt.CONFIG_PARAMS.STORAGE_COMPRESSION_THRESHOLD)||Lx;J.compression.threshold=me}v=a_(o.openDB(p.key,J)),v.rootStore=o,v.tableId=L}for(let J of S){J.attribute=J.name;try{if(!J.is_hash_attribute&&(J.indexed||J.attribute&&!J.name)){if(!A[J.name]){let ce=new Do.default(!J.is_hash_attribute,J.is_hash_attribute);A[J.name]=o.openDB(J.key,ce),A[J.name].indexNulls=J.indexNulls}let me=g.find(ce=>ce.name===J.name);me?g.splice(g.indexOf(me),1,J):g.push(J)}}catch(me){gn.error("Error trying to update attribute",J,g,A,me)}}if(!T){T=Ux(l,E,kE({primaryStore:v,auditStore:_,audit:P,sealed:z,expirationMS:H&&H*1e3,evictionMS:X&&X*1e3,trackDeletes:k,tableName:E,tableId:L,primaryKey:p.name,databasePath:s?r+"/"+E:r,databaseName:r,indices:A,attributes:S,schemaDefined:p.schemaDefined,dbisDB:u})),T.schemaVersion=1;for(let J of TA)J(T)}}return o}catch(o){throw o.message+=` opening database ${e}`,o}}function Mx(e){let t=tt[e];if(t||(e==="data"?t=tt[e]=Ur:e==="system"?Object.defineProperty(tt,"system",{value:t=Object.create(null),configurable:!0}):t=tt[e]=Object.create(null)),ja&&!ja.has(e)){let r=new Set;t[zE]=r,ja.set(e,r)}return t}function Ux(e,t,r){return e[t]=r,r}function Zc({database:e,table:t}){e||(e=SA),Er();let r=Mx(e),n=(0,Ze.join)((0,Et.getHdbBasePath)(),Lt.DATABASES_DIR_NAME),s=(0,Et.get)(Lt.CONFIG_PARAMS.DATABASES)||{};process.env.SCHEMAS_DATA_PATH&&(s.data={path:process.env.SCHEMAS_DATA_PATH});let i=t&&s[e]?.tables?.[t]?.path;n=i||s[e]?.path||process.env.STORAGE_PATH||(0,Et.get)(Lt.CONFIG_PARAMS.STORAGE_PATH)||((0,tn.existsSync)(n)?n:(0,Ze.join)((0,Et.getHdbBasePath)(),Lt.LEGACY_DATABASES_DIR_NAME));let o=(0,Ze.join)(n,(i?t:e)+".mdb"),c=Di.get(o);if(!c){let u=new mA.default(o,!1);c=(0,$E.open)(u),Di.set(o,c)}return c}async function eS(e){if(!tt[e])throw new Error("Schema does not exist");let t=tt[e];for(let r in t){let s=t[r].primaryStore.rootStore;Di.delete(s.path),s.status==="open"&&(await s.close(),await QE.remove(s.path))}if(e==="data"){for(let r in Ur)delete Ur[r];delete Ur[zE]}delete tt[e]}function ut({table:e,database:t,expiration:r,eviction:n,scanInterval:s,attributes:i,audit:o,sealed:c,trackDeletes:u,schemaDefined:_,origin:l}){t||(t=SA);let d=Zc({database:t,table:e}),f=tt[t],E=f?.[e];if(d.status==="closed")throw new Error(`Can not use a closed data store for ${e}`);let h,S,p,T;_==null&&(_=!0);let A=new Do.default(!1);for(let H of i)H.attribute&&!H.name?(H.name=H.attribute,H.indexed=!0):H.attribute=H.name,H.expiresAt&&(H.indexed=!0);let g,L;if(E){if(h=E.primaryKey,E.primaryStore.rootStore.status==="closed")throw new Error(`Can not use a closed data store from ${e} class`);E.attributes.splice(0,E.attributes.length,...i)}else{let H=d.auditStore;H||(H=wE(d)),S=i.find(me=>me.isPrimaryKey)||{},h=S.name,S.is_hash_attribute=!0,S.schemaDefined=_,S.compression=Wd(),u&&(S.trackDeletes=!0),o=S.audit=typeof o=="boolean"?o:(0,Et.get)(Lt.CONFIG_PARAMS.LOGGING_AUDITLOG),r&&(S.expiration=r),n&&(S.eviction=n),typeof c=="boolean"&&(S.sealed=c),l&&(S.origins?S.origins.includes(l)||S.origins.push(l):S.origins=[l]),gn.trace(`${e} table loading, opening primary store`);let X=new Do.default(!1,!0);X.compression=S.compression;let z=e+"/",J=a_(d.openDB(z,X));J.rootStore=d,T=d.dbisDb=d.openDB(VE.INTERNAL_DBIS_NAME,A),J.tableId=T.get(Ja),J.tableId||(J.tableId=1),T.putSync(Ja,J.tableId+1),S.tableId=J.tableId,E=Ux(f,e,kE({primaryStore:J,auditStore:H,audit:o,sealed:c,trackDeletes:u,expirationMS:r&&r*1e3,evictionMS:n&&n*1e3,primaryKey:h,tableName:e,tableId:J.tableId,databasePath:t,databaseName:t,indices:{},attributes:i,schemaDefined:_,dbisDB:T})),E.schemaVersion=1,g=!0,k(),T.put(z,S)}p=E.indices,T=T||(d.dbisDb=d.openDB(VE.INTERNAL_DBIS_NAME,A)),E.dbisDB=T;let v=[];for(let{key:H,value:X}of T.getRange({start:!0})){let[z,J]=H.toString().split("/");if(J===""&&(J=X.name),J){if(z!==e)continue}else J=z;if(!i.find(ce=>ce.name===J)?.indexed&&X.indexed&&!X.isPrimaryKey){k(),g=!0,T.remove(H);let ce=E.indices[z];ce&&v.push(ce)}}let P=[];try{for(let H of i||[]){if(H.relationship)continue;let X=e+"/"+(H.name||"");Object.defineProperty(H,"key",{value:X,configurable:!0});let z=T.get(X);if(H.isPrimaryKey){if(z=z||T.get(X=e+"/")||{},o!==E.audit||c!==c||(+r||void 0)!==(+z.expiration||void 0)||(+n||void 0)!==(+z.eviction||void 0)){let me=Object.assign({},z);typeof o=="boolean"&&(o&&E.enableAuditing(o),me.audit=o),r&&(me.expiration=+r),n&&(me.eviction=+n),c!==void 0&&(me.sealed=c),g=!0,k(),T.put(X,me)}continue}z?.attribute&&!z.name&&(z.indexed=!0);let J=!z||z.type!==H.type||z.indexed!==H.indexed||z.nullable!==H.nullable||JSON.stringify(z.attributes)!==JSON.stringify(H.attributes)||JSON.stringify(z.elements)!==JSON.stringify(H.elements);if(H.indexed){let me=new Do.default(!0,!1),ce=d.openDB(X,me);(J||z.indexingPID&&z.indexingPID!==process.pid||z.restartNumber<Dl.workerData?.restartNumber)&&(g=!0,k(),z=T.get(X),(J||z.indexingPID&&z.indexingPID!==process.pid||z.restartNumber<Dl.workerData?.restartNumber)&&(g=!0,H.indexNulls===void 0&&(H.indexNulls=!0),E.primaryStore.getStats().entryCount>0&&(H.lastIndexedKey=z?.lastIndexedKey||!1,H.indexingPID=process.pid,ce.isIndexing=!0,Object.defineProperty(H,"dbi",{value:ce}),P.push(H))),T.put(X,H)),z?.indexNulls&&H.indexNulls===void 0&&(H.indexNulls=!0),ce.indexNulls=H.indexNulls,p[H.name]=ce}else J&&(g=!0,k(),T.put(X,H))}}finally{L&&L()}if(g&&(E.schemaVersion++,E.updatedAttributes()),gn.trace(`${e} table loading, running index`),P.length>0||v.length>0?E.indexingOperation=Xne(E,P,v):g&&YE.signalSchemaChange(new KE.SchemaEventMsg(process.pid,"schema-change",E.databaseName,E.tableName)),E.origin=l,g)for(let H of TA)H(E,l!=="cluster");return(r||n||s)&&E.setTTLExpiration({expiration:r,eviction:n,scanInterval:s}),gn.trace(`${e} table loaded`),E;function k(){L||d.transactionSync(()=>({then(H){L=H}}))}a(k,"startTxn")}async function Xne(e,t,r){try{let n=e.schemaVersion;await YE.signalSchemaChange(new KE.SchemaEventMsg(process.pid,"schema-change",e.databaseName,e.tableName));let s;for(let u of r)s=u.drop();let i,o=0,c=t.length;if(await new Promise(u=>setImmediate(u)),c>0){let u=0;for(let{key:_,value:l,version:d}of e.primaryStore.getRange({start:t[0].lastIndexedKey,lazy:c<4,versions:!0,snapshot:!1}))if(l){if(u++,s=e.primaryStore.ifVersion(_,d,()=>{for(let f=0;f<c;f++){let E=t[f],h=E.name,S=(0,Cx.getIndexedValues)(l[h]);if(S)for(let p=0,T=S.length;p<T;p++)E.dbi.put(S[p],_)}}),s.then(()=>u--,f=>{u--,gn.error(f)}),Dl.workerData&&Dl.workerData.restartNumber!==Dx.restartNumber&&(i=!0),++o%100===0||i){for(let f of t)f.lastIndexedKey=_,e.dbisDB.put(f.key,f);if(i)return}u>zne?await s:u>Jne&&await new Promise(f=>setImmediate(f))}for(let _ of t)delete _.lastIndexedKey,delete _.indexingPID,_.dbi.isIndexing=!1,s=e.dbisDB.put(_.key,_)}await s,await YE.signalSchemaChange(new KE.SchemaEventMsg(process.pid,"indexing-finished",e.databaseName,e.tableName))}catch(n){gn.error("Error in indexing",n)}}function jne({table:e,database:t}){let r=Zc({database:t,table:e}),n=[],s=r.dbisDb;for(let i of s.getKeys({start:e+"/",end:e+"0"}))n.push(s.remove(i));return Promise.all(n)}function yR(e){TA.push(e)}function Wd(){let e=(0,Et.get)(Lt.CONFIG_PARAMS.STORAGE_COMPRESSION),t=(0,Et.get)(Lt.CONFIG_PARAMS.STORAGE_COMPRESSION_DICTIONARY),r=(0,Et.get)(Lt.CONFIG_PARAMS.STORAGE_COMPRESSION_THRESHOLD)||Lx,n={startingOffset:32};return t&&(n.dictionary=QE.readFileSync(t)),r&&(n.threshold=r),e&&n}var Et,VE,$E,Ze,tn,Xa,Do,mA,Lt,QE,pA,Cx,YE,KE,Dl,gn,Dx,SA,zE,Lx,Ur,tt,Ja,TA,WE,Di,ja,zne,Jne,Ae=Re(()=>{Et=B(te()),VE=B(at()),$E=require("lmdb"),Ze=require("path"),tn=require("fs"),Xa=B(Qe());$f();Do=B(yc()),mA=B(Nc()),Lt=B(U()),QE=B(require("fs-extra")),pA=require("../index"),Cx=B(Mr()),YE=B(Rs()),KE=B(Dn()),Dl=require("worker_threads"),gn=B(K()),Dx=B(ct());js();bc();SA="data",zE=Symbol("defined-tables"),Lx=((0,Et.get)(Lt.CONFIG_PARAMS.STORAGE_PAGESIZE)||4096)-60;(0,Et.initSync)();Ur=Object.create(null),tt=Object.create(null);(0,pA._assignPackageExport)("databases",tt);(0,pA._assignPackageExport)("tables",Ur);Ja=Symbol.for("next-table-id"),TA=[],Di=new Map;a(Qne,"getTables");a(Er,"getDatabases");a(yu,"resetDatabases");a(Cl,"readMetaDb");a(Mx,"ensureDB");a(Ux,"setTable");a(Zc,"database");a(eS,"dropDatabase");a(ut,"table");zne=1e3,Jne=10;a(Xne,"runIndexing");a(jne,"dropTableMeta");a(yR,"onUpdatedTable");a(Wd,"getDefaultCompression")});var Q=R((Npe,Wx)=>{"use strict";var Li=require("path"),xx=require("fs-extra"),wr=K(),Px=require("fs-extra"),JE=require("os"),Zne=require("net"),ese=require("recursive-iterator"),ot=U(),tse=gO(),vx=require("papaparse"),XE=require("moment"),{inspect:rse}=require("util"),Bx=require("is-number"),ype=require("lodash"),nse=require("minimist"),sse=require("https"),ise=require("http"),{hdb_errors:jE}=ne(),ose=/^((\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d:[0-5]\d\.\d+([+-][0-2]\d:[0-5]\d|Z))|(\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d:[0-5]\d([+-][0-2]\d:[0-5]\d|Z))|(\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d([+-][0-2]\d:[0-5]\d|Z)))$/,Gx=require("util").promisify(setTimeout),ase=100,cse=5,use="",lse=4,Hx={true:!0,TRUE:!0,FALSE:!1,false:!1,undefined:null,null:null,NULL:null,NaN:NaN};Wx.exports={isEmpty:rn,isEmptyOrZeroLength:ds,arrayHasEmptyValues:fse,arrayHasEmptyOrZeroLengthValues:Ese,buildFolderPath:hse,isBoolean:Fx,errorizeMessage:_se,stripFileExtension:pse,autoCast:Sse,autoCastJSON:qx,autoCastJSONDeep:RA,removeDir:Tse,compareVersions:gse,isCompatibleDataVersion:Rse,escapeRawValue:Ase,unescapeValue:Ose,stringifyProps:bse,timeoutPromise:Nse,isClusterOperation:wse,getClusterUser:Dse,checkGlobalSchemaTable:Cse,getHomeDir:Vx,getPropsFilePath:yse,promisifyPapaParse:Lse,removeBOM:$x,createEventPromise:Mse,checkProcessRunning:Use,checkSchemaTableExist:Pse,checkSchemaExists:Yx,checkTableExists:Kx,getStartOfTomorrowInSeconds:vse,getLimitKey:Bse,isObject:mse,isNotEmptyAndHasValue:dse,autoCasterIsNumberCheck:kx,backtickASTSchemaItems:Hse,isPortTaken:Ise,createForkArgs:xse,autoCastBoolean:Gse,async_set_timeout:Gx,getTableHashAttribute:Fse,doesSchemaExist:qse,doesTableExist:kse,stringifyObj:Vse,ms_to_time:$se,changeExtension:Yse,getEnvCliRootPath:AA,noBootFile:Kse,httpRequest:Wse,transformReq:Qse,convertToMS:zse,PACKAGE_ROOT:ot.PACKAGE_ROOT};function _se(e){return e instanceof Error?e:new Error(e)}a(_se,"errorizeMessage");function rn(e){return e==null}a(rn,"isEmpty");function dse(e){return!rn(e)&&(e||e===0||e===""||Fx(e))}a(dse,"isNotEmptyAndHasValue");function ds(e){return rn(e)||e.length===0||e.size===0}a(ds,"isEmptyOrZeroLength");function fse(e){if(rn(e))return!0;for(let t=0;t<e.length;t++)if(rn(e[t]))return!0;return!1}a(fse,"arrayHasEmptyValues");function Ese(e){if(ds(e))return!0;for(let t=0;t<e.length;t++)if(ds(e[t]))return!0;return!1}a(Ese,"arrayHasEmptyOrZeroLengthValues");function hse(...e){try{return e.join(Li.sep)}catch{console.error(e)}}a(hse,"buildFolderPath");function Fx(e){return rn(e)?!1:e===!0||e===!1}a(Fx,"isBoolean");function mse(e){return rn(e)?!1:typeof e=="object"}a(mse,"isObject");function pse(e){return ds(e)?use:e.slice(0,-lse)}a(pse,"stripFileExtension");function Sse(e){return rn(e)||e===""||typeof e!="string"?e:Hx[e]!==void 0?Hx[e]:kx(e)===!0?Number(e):ose.test(e)?new Date(e):e}a(Sse,"autoCast");function qx(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}a(qx,"autoCastJSON");function RA(e){if(e&&typeof e=="object"){if(Array.isArray(e))for(let t=0,r=e.length;t<r;t++){let n=e[t],s=RA(n);s!==n&&(e[t]=s)}else for(let t in e){let r=e[t],n=RA(r);n!==r&&(e[t]=n)}return e}else return qx(e)}a(RA,"autoCastJSONDeep");function kx(e){if(e.startsWith("0.")&&Bx(e))return!0;let t=e.toUpperCase().includes("E");return!!((e!=="0"&&e.startsWith("0"))===!1&&t===!1&&Bx(e))}a(kx,"autoCasterIsNumberCheck");async function Tse(e){if(ds(e))throw new Error(`Directory path: ${e} does not exist`);try{await Px.emptyDir(e),await Px.remove(e)}catch(t){throw wr.error(`Error removing files in ${e} -- ${t}`),t}}a(Tse,"removeDir");function gse(e,t){if(ds(e)){wr.info("Invalid current version sent as parameter.");return}if(ds(t)){wr.info("Invalid upgrade version sent as parameter.");return}let r,n=/(\.0+)+$/,s=e.version?e.version:e,i=t.version?t.version:t,o=s.replace(n,"").split("."),c=i.replace(n,"").split("."),u=Math.min(o.length,c.length);for(let _=0;_<u;_++)if(r=parseInt(o[_],10)-parseInt(c[_],10),r)return r;return o.length-c.length}a(gse,"compareVersions");function Rse(e,t,r=!1){let n=e.toString().split("."),s=t.toString().split(".");return n[0]===s[0]&&(!r||n[1]===s[1])}a(Rse,"isCompatibleDataVersion");function Ase(e){if(rn(e))return e;let t=String(e);return t==="."?ot.UNICODE_PERIOD:t===".."?ot.UNICODE_PERIOD+ot.UNICODE_PERIOD:t.replace(ot.FORWARD_SLASH_REGEX,ot.UNICODE_FORWARD_SLASH)}a(Ase,"escapeRawValue");function Ose(e){if(rn(e))return e;let t=String(e);return t===ot.UNICODE_PERIOD?".":t===ot.UNICODE_PERIOD+ot.UNICODE_PERIOD?"..":String(e).replace(ot.ESCAPED_FORWARD_SLASH_REGEX,"/")}a(Ose,"unescapeValue");function bse(e,t){if(rn(e))return wr.info("Properties object is null"),"";let r="";return e.each(function(n,s){try{if(t&&t[n]){let i=t[n];for(let o of i)r+=";"+o+JE.EOL}!ds(n)&&n[0]===";"?r+=" "+n+s+JE.EOL:ds(n)||(r+=n+"="+s+JE.EOL)}catch{wr.error(`Found bad property during upgrade with key ${n} and value: ${s}`)}}),r}a(bse,"stringifyProps");function Vx(){let e;try{e=JE.homedir()}catch{e=process.env.HOME}return e||(e="~/"),e}a(Vx,"getHomeDir");function yse(){let e=Li.join(Vx(),ot.HDB_HOME_DIR_NAME,ot.BOOT_PROPS_FILE_NAME);return xx.existsSync(e)||(e=Li.join(__dirname,"../","hdb_boot_properties.file")),e}a(yse,"getPropsFilePath");function Nse(e,t){let r,n;return n=new Promise(function(s){r=setTimeout(function(){s(t)},e)}),{promise:n,cancel:function(){clearTimeout(r)}}}a(Nse,"timeoutPromise");async function Ise(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let n=Zne.createServer().once("error",s=>{s.code==="EADDRINUSE"?t(!0):r(s)}).once("listening",()=>n.once("close",()=>t(!1)).close()).listen(e)})}a(Ise,"isPortTaken");function wse(e){try{return ot.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){wr.error(`Error checking operation against cluster ops ${t}`)}return!1}a(wse,"isClusterOperation");function Cse(e,t){let r=(Ae(),ie(qe)).getDatabases();if(!r[e])return jE.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e);if(!r[e][t])return jE.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(Cse,"checkGlobalSchemaTable");function Dse(e,t){if(rn(t)){wr.warn("No CLUSTERING_USER defined, clustering disabled");return}if(rn(e)||ds(e)){wr.warn("No users to search.");return}let r;try{let n=e.get(t);n&&n.role.permission.cluster_user===!0&&n.active===!0&&(r=n)}catch(n){wr.error(`unable to find cluster_user due to: ${n.message}`);return}if(r===void 0){wr.warn(`CLUSTERING_USER: ${t} not found or is not active.`);return}return r}a(Dse,"getClusterUser");function Lse(){vx.parsePromise=function(e,t,r){return new Promise(function(n,s){vx.parse(e,{header:!0,transformHeader:$x,chunk:t.bind(null,s),skipEmptyLines:!0,transform:r,dynamicTyping:!1,error:s,complete:n})})}}a(Lse,"promisifyPapaParse");function $x(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}a($x,"removeBOM");function Mse(e,t,r){return new Promise(n=>{t.once(e,s=>{let i=r;wr.info(`Got cluster status event response: ${rse(s)}`);try{i.cancel()}catch{wr.error("Error trying to cancel timeout.")}n(s)})})}a(Mse,"createEventPromise");async function Use(e){let t=!0,r=0;do await Gx(ase*r++),(await tse.findPs(e)).length>0&&(t=!1);while(t&&r<cse);if(t)throw new Error(`process ${e} was not started`)}a(Use,"checkProcessRunning");function Pse(e,t){let r=Yx(e);if(r)return r;let n=Kx(e,t);if(n)return n}a(Pse,"checkSchemaTableExist");function Yx(e){let{getDatabases:t}=(Ae(),ie(qe));if(!t()[e])return jE.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(Yx,"checkSchemaExists");function Kx(e,t){let{getDatabases:r}=(Ae(),ie(qe));if(!r()[e][t])return jE.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(Kx,"checkTableExists");function vse(){let e=XE().utc().add(1,ot.MOMENT_DAYS_TAG).startOf(ot.MOMENT_DAYS_TAG).unix(),t=XE().utc().unix();return e-t}a(vse,"getStartOfTomorrowInSeconds");function Bse(){return XE().utc().format("DD-MM-YYYY")}a(Bse,"getLimitKey");function Hse(e){try{let t=new ese(e);for(let{node:r}of t)r&&(r.columnid&&typeof r.columnid!="string"&&(r.columnid=r.columnid.toString()),r.columnid&&!r.columnid.startsWith("`")&&(r.columnid_orig=r.columnid,r.columnid=`\`${r.columnid}\``),r.tableid&&!r.tableid.startsWith("`")&&(r.tableid_orig=r.tableid,r.tableid=`\`${r.tableid}\``),r.databaseid&&!r.databaseid.startsWith("`")&&(r.databaseid_orig=r.databaseid,r.databaseid=`\`${r.databaseid}\``),r.as&&typeof r.as=="string"&&!r.as.startsWith("[")&&(r.as_orig=r.as,r.as=`\`${r.as}\``))}catch(t){wr.error("Got an error back ticking items."),wr.error(t)}}a(Hse,"backtickASTSchemaItems");function xse(e){return[e]}a(xse,"createForkArgs");function Gse(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(Gse,"autoCastBoolean");function Fse(e,t){let{getDatabases:r}=(Ae(),ie(qe)),n=r()[e]?.[t];return n?.primaryKey||n?.hash_attribute}a(Fse,"getTableHashAttribute");function qse(e){let{getDatabases:t}=(Ae(),ie(qe));return t()[e]!==void 0}a(qse,"doesSchemaExist");function kse(e,t){let{getDatabases:r}=(Ae(),ie(qe));return r()[e]?.[t]!==void 0}a(kse,"doesTableExist");function Vse(e){try{return JSON.stringify(e)}catch{return e}}a(Vse,"stringifyObj");function $se(e){let t=XE.duration(e),r=t.seconds()>0?t.seconds()+"s":"",n=t.minutes()>0?t.minutes()+"m ":"",s=t.hours()>0?t.hours()+"h ":"",i=t.days()>0?t.days()+"d ":"";return(t.years()>0?t.years()+"y ":"")+i+s+n+r}a($se,"ms_to_time");function Yse(e,t){let r=Li.basename(e,Li.extname(e));return Li.join(Li.dirname(e),r+t)}a(Yse,"changeExtension");function AA(){if(process.env[ot.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return process.env[ot.CONFIG_PARAMS.ROOTPATH.toUpperCase()];let e=nse(process.argv);if(e[ot.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return e[ot.CONFIG_PARAMS.ROOTPATH.toUpperCase()]}a(AA,"getEnvCliRootPath");var gA;function Kse(){if(gA)return gA;let e=AA();if(AA()&&xx.pathExistsSync(Li.join(e,ot.HDB_CONFIG_FILE)))return gA=!0,!0}a(Kse,"noBootFile");function Wse(e,t){let r;return e.protocol==="http:"?r=ise:r=sse,new Promise((n,s)=>{let i=r.request(e,o=>{o.setEncoding("utf8");let c={body:"",headers:o.headers};o.on("data",u=>{c.body+=u}),o.on("end",()=>{n(c)})});i.on("error",o=>{s(o)}),i.write(JSON.stringify(t)),i.end()})}a(Wse,"httpRequest");function Qse(e){if(!e.schema&&!e.database){e.schema=ot.DEFAULT_DATABASE_NAME;return}e.database&&(e.schema=e.database)}a(Qse,"transformReq");function zse(e){let t=0;if(typeof e=="number"&&(t=e),typeof e=="string")switch(t=parseFloat(e),e.slice(-1)){case"M":t*=86400*30;break;case"D":case"d":t*=86400;break;case"H":case"h":t*=3600;break;case"m":t*=60;break}return t*1e3}a(zse,"convertToMS")});var te=R((wpe,jx)=>{"use strict";var OA=require("fs-extra"),Lo=require("path"),Qx=require("os"),Jse=require("properties-reader"),Ml=K(),Ll=Q(),ue=U(),ZE=dr(),Xse="Error initializing environment manager",eh="BOOT_PROPS_FILE_PATH",zx=!1,jse={[ue.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[ue.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[ue.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},Ys={};jx.exports={BOOT_PROPS_FILE_PATH:eh,getHdbBasePath:Zse,setHdbBasePath:eie,get:Jx,initSync:rie,setProperty:Me,initTestEnvironment:sie,setCloneVar:nie};function Zse(){return Ys[ue.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(Zse,"getHdbBasePath");function eie(e){Ys[ue.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(eie,"setHdbBasePath");function Jx(e){let t=ZE.getConfigValue(e);return t===void 0?Ys[e]:t}a(Jx,"get");function Me(e,t){jse[e]&&(Ys[e]=t),ZE.updateConfigObject(e,t)}a(Me,"setProperty");function tie(){let e;try{e=Ll.getPropsFilePath(),OA.accessSync(e,OA.constants.F_OK|OA.constants.R_OK),zx=!0;let t=Jse(e);return Ys[ue.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(ue.HDB_SETTINGS_NAMES.INSTALL_USER),Ys[ue.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(ue.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),Ys[eh]=e,!0}catch{return Ml.trace(`Environment manager found no properties file at ${e}`),!1}}a(tie,"doesPropFileExist");function rie(e=!1){try{(zx||tie()||Ll.noBootFile())&&!Xx&&(ZE.initConfig(e),Ys[ue.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=ZE.getConfigValue(ue.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){Ml.error(Xse),Ml.error(t),console.error(t),process.exit(1)}}a(rie,"initSync");var Xx=!1;function nie(e){Xx=e}a(nie,"setCloneVar");function sie(e={}){try{let{keep_alive_timeout:t,headers_timeout:r,server_timeout:n,https_enabled:s,cors_enabled:i,cors_accesslist:o,local_studio_on:c}=e,u=Lo.join(__dirname,"../../","unitTests");Ys[eh]=Lo.join(u,"hdb_boot_properties.file"),Me(ue.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,Lo.join(u,"settings.test")),Me(ue.HDB_SETTINGS_NAMES.INSTALL_USER,Qx.userInfo()?Qx.userInfo().username:void 0),Me(ue.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),Me(ue.HDB_SETTINGS_NAMES.LOG_PATH_KEY,Lo.join(u,"envDir","log")),Me(ue.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),Me(ue.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),Me(ue.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),Me(ue.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,Lo.join(u,"envDir")),Me(ue.CONFIG_PARAMS.STORAGE_PATH,Lo.join(u,"envDir")),s&&(Me(ue.CONFIG_PARAMS.HTTP_SECUREPORT,Jx(ue.CONFIG_PARAMS.HTTP_PORT)),Me(ue.CONFIG_PARAMS.HTTP_PORT,null)),Me(ue.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,!!s),Me(ue.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),Me(ue.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,Ll.isEmpty(i)?!1:i),Me(ue.CONFIG_PARAMS.HTTP_CORS,Ll.isEmpty(i)?!1:i),Me(ue.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),Me(ue.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),Me(ue.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),Me(ue.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),Me(ue.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,Lo.resolve(__dirname,"../../unitTests/server/fastifyRoutes/custom_functions")),Me(ue.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,Ll.isEmpty(c)?!1:c),o&&(Me("CORS_ACCESSLIST",o),Me(ue.CONFIG_PARAMS.HTTP_CORSACCESSLIST,o)),n&&(Me(ue.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,n),Me(ue.CONFIG_PARAMS.HTTP_TIMEOUT,n)),t&&(Me(ue.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),Me(ue.CONFIG_PARAMS.HTTP_KEEPALIVETIMEOUT,t)),r&&(Me(ue.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),Me(ue.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${eh}. Please check your boot props and settings files`;Ml.fatal(r),Ml.error(t)}}a(sie,"initTestEnvironment")});var Nt=R((vpe,hG)=>{"use strict";var Gt=te();Gt.initSync();var iie=require("fs-extra"),oie=require("semver"),vl=require("path"),{monotonicFactory:aie}=require("ulidx"),eG=aie(),cie=require("util"),tG=require("child_process"),uie=cie.promisify(tG.exec),lie=tG.spawn,zt=nt(),we=U(),th=Q(),kn=K(),rh=gs(),_ie=od(),Ul=dr(),{broadcast:die,onMessageByType:fie,getWorkerIndex:Eie}=ct(),{isMainThread:rG}=require("worker_threads"),{Encoder:hie,decode:IA}=require("msgpackr"),nG=new hie,{isEmpty:vo}=th,sG=un(),Dpe=48*36e11;rG&&fie(we.ITC_EVENT_TYPES.RESTART,()=>{Cr=void 0,Po=void 0});var{connect:mie,StorageType:pie,RetentionPolicy:Sie,AckPolicy:wA,DeliverPolicy:CA,DiscardPolicy:Tie,NatsConnection:Lpe,JetStreamManager:Mpe,JetStreamClient:Upe,StringCodec:Ppe,JSONCodec:gie,createInbox:DA,headers:Rie,ErrorCode:Zx}=require("nats"),{PACKAGE_ROOT:Aie}=U(),Oie=lu(),{recordAction:bie}=(vs(),ie(Zu)),iG=gie(),yie="clustering",Nie=Oie.engines[zt.NATS_SERVER_NAME],Iie=vl.join(Aie,"dependencies"),NA=vl.join(Iie,`${process.platform}-${process.arch}`,zt.NATS_BINARY_NAME),bA,yA,Pl,Mo,Uo;hG.exports={runCommand:oG,checkNATSServerInstalled:wie,createConnection:LA,getConnection:Bl,getJetStreamManager:Hl,getJetStream:cG,getNATSReferences:Es,getServerList:Die,createLocalStream:MA,listStreams:uG,deleteLocalStream:Lie,getServerConfig:Za,listRemoteStreams:Mie,viewStream:Uie,viewStreamIterator:Pie,publishToStream:vie,request:xie,reloadNATS:UA,reloadNATSHub:Gie,reloadNATSLeaf:Fie,extractServerName:Hie,requestErrorHandler:qie,createLocalTableStream:fG,createTableStreams:$ie,purgeTableStream:EG,purgeSchemaTableStreams:Yie,getStreamInfo:Kie,updateLocalStreams:Qie,closeConnection:Cie,getJsmServerName:nh,addNatsMsgHeader:lG,clearClientCache:aG,updateRemoteConsumer:kie,createConsumer:_G,updateConsumerIterator:Vie};async function oG(e,t=void 0){let{stdout:r,stderr:n}=await uie(e,{cwd:t});if(n)throw new Error(n.replace(`
30
+ `)}a(ZB,"defaultNotFound");function IR(e){return e.startsWith("-----BEGIN")?e:gre(e)}a(IR,"readPEM");function lH(e){let t=[];for(let s=0;e[s];s++)t.push(e[s]);t.length||t.push(e);let r=new Map,n;for(let s of t){let i=IR(s.privateKey),o=IR(s.certificate),c=s.certificateAuthority&&IR(s.certificateAuthority);if(!i||!o)throw new Error("Missing private key or certificate for secure server");let u={ciphers:s.ciphers,ca:c,ticketKeys:tH()},_=Ore(u);_.options=u,u.instantiatedContext=_,_.context.setCert(o),_.context.setKey(i,void 0),u.cert=o,u.key=i,_.certStart=o.subarray(0,100).toString(),n||(n=_);let l=new Cre(o),d=s.hostname??s.host??s.hostnames??s.hosts??(l.subjectAltName?l.subjectAltName.split(",").map(f=>{let E=f.indexOf(":");return f.slice(E+1)}):[l.subject.match(/CN=(.*)/)?.[1]]);Array.isArray(d)||(d=[d]);for(let f of d)f?r.has(f)||r.set(f,_):Dt.error("No hostname found for certificate at",s.certificate)}return(s,i)=>{let o=r.get(s);o?(Dt.debug("Found certificate for",s,o.certStart),i(null,o)):(Dt.debug("No certificate found to match",s,"using the first certificate"),i(null,n))}}a(lH,"createSNICallback")});async function hH({clientId:e,user:t,clean:r,will:n,keepalive:s}){let i;if(e&&!r){let o=await PR.get(e,{returnNonexistent:!0});i=new HR(e,t,o),o&&(i.sessionWasPresent=!0)}else{if(e){let o=await PR.get(e);o&&o.delete()}i=new pE(e,t)}return n&&(n.id=e,n.user={username:t?.username},El.put(n)),s&&(i.keepalive=s,i.receivedPacket()),i}function vR(){return mE++,mE>65500&&(mE=1),mE}function BR(e,t,r){let{topic:n,retain:s}=e;e.data=t,e.async=!0,r.authorize=!0;let i=Ti.getMatch(n);if(!i)throw new Error(`Can not publish to topic ${n} as it does not exist, no resource has been defined to handle this topic`);e.url=i.relativeURL;let o=i.Resource;return ze(r,()=>s?t===void 0?o.delete(e,r):o.put(e,e.data,r):o.publish(e,e.data,r))}var dH,Ii,fH,EH,PR,El,mE,pE,HR,mH=Re(()=>{Ae();Lu();dH=B(Mr()),Ii=B(K());Zi();fH=B(ct()),EH=B(_H());ar();PR=ut({database:"system",table:"hdb_durable_session",attributes:[{name:"id",isPrimaryKey:!0},{name:"subscriptions",type:"array",elements:{attributes:[{name:"topic"},{name:"qos"},{name:"startTime"},{name:"acks"}]}}]}),El=ut({database:"system",table:"hdb_session_will",attributes:[{name:"id",isPrimaryKey:!0},{name:"topic",type:"string"},{name:"data"},{name:"qos",type:"number"},{name:"retain",type:"boolean"},{name:"user",type:"any"}]});(0,fH.getWorkerIndex)()===0&&(async()=>{await EH.when_components_loaded,await new Promise(e=>setTimeout(e,2e3));for await(let e of El.search({})){let t=e.data,r=Object.assign({},e);r.user?.username&&(r.user=await et.getUser(r.user.username)),ze(r,()=>{try{BR(r,t,r)}catch{(0,Ii.warn)("Failed to publish will",t)}El.delete(e.id,r)})}})();a(hH,"getSession");mE=1;a(vR,"getNextMessageId");pE=class{static{a(this,"SubscriptionsSession")}listener;sessionId;user;request;socket;subscriptions=[];awaitingAcks;sessionWasPresent;keepalive;keepaliveTimer;constructor(t,r){this.sessionId=t,this.user=r}async addSubscription(t,r,n){let{topic:s,rh:i,startTime:o}=t,c=s.indexOf("?"),u,_;if(c>-1?(u=s.slice(c),_=s.slice(0,c)):_=s,!_)throw new Error("No topic provided");if(_.indexOf(".")>-1)throw new Error("Dots are not allowed in topic names");let l=this.subscriptions.find(T=>T.topic===s),d;l?(d=i>0,l.end(),this.subscriptions.splice(this.subscriptions.indexOf(l),1)):d=i===2;let f={search:u,async:!0,user:this.user,startTime:o,omitCurrent:d,url:""};o&&(0,Ii.trace)("Resuming subscription from",s,"from",o);let E=Ti.getMatch(_);if(!E){let T=new Error(`The topic ${s} does not exist, no resource has been defined to handle this topic`);throw T.statusCode=404,T}if(f.url=E.relativeURL,f.url.indexOf("+")>-1||f.url.indexOf("#")>-1){let T=f.url.slice(1);if(T.indexOf("#")>-1&&T.indexOf("#")!==T.length-1)throw new Error("Multi-level wildcards can only be used at the end of a topic");if(f.isCollection=!0,T.indexOf("+")===T.length-1)f.onlyChildren=!0,f.url="/"+T.slice(0,T.length-1);else{let A=T.split("/"),g;for(let P=0;P<A.length;P++)if(A[P].indexOf("+")>-1)if(A[P]==="+")g=!0;else throw new Error("Single-level wildcards can only be used as a topic level (between or after slashes)");if(n&&g)throw new Error("Filters can not be combined");let L=!0;A[A.length-1]==="#"&&(A.length--,L=!1),g&&(n=a(P=>{let k=P.id;if(!Array.isArray(k)||L&&k.length!==A.length)return!1;for(let H=0;H<A.length;H++)if(A[H]!=="+"&&A[H]!==k[H])return!1;return!0},"filter"));let v=A.indexOf("+");f.url="/"+(v>-1?A.slice(0,v):A).concat("").join("/")}}let h=E.path,S=E.Resource,p=await ze(f,async()=>{let T=this.createContext();T.topic=s,T.retainHandling=i;let A=await S.subscribe(f,T);if(!A)throw new Error(`No subscription was returned from subscribe for topic ${s}`);if(!A[Symbol.asyncIterator])throw new Error(`Subscription is not (async) iterable for topic ${s}`);return(async()=>{for await(let g of A)try{let L;if(g.type&&g.type!=="put"&&g.type!=="delete"&&g.type!=="message"&&g.type!=="patch"||n&&!n(g))continue;r?(g.topic=s,L=this.needsAcknowledge(g)):(g.acknowledge?.(),L=vR());let v=g.id;Array.isArray(v)&&(v=Ta(v)),v==null&&(v=""),this.listener(h+"/"+v,g.value,L,t)}catch(L){(0,Ii.warn)(L)}})(),A});return p.topic=s,p.qos=t.qos,this.subscriptions.push(p),p}resume(){}needsAcknowledge(t){let r=vR();return t.acknowledge&&(this.awaitingAcks||(this.awaitingAcks=new Map),this.awaitingAcks.set(r,t.acknowledge)),r}acknowledge(t){let r=this.awaitingAcks?.get(t);r&&(this.awaitingAcks.delete(t),r())}async removeSubscription(t){let r=this.subscriptions.find(n=>n.topic===t);if(r)return r.end(),this.subscriptions.splice(this.subscriptions.indexOf(r),1),!0}async publish(t,r){return BR(t,r,this.createContext())}createContext(){let t={session:this,socket:this.socket,user:this.user,authorize:!0};return this.request&&(t.request=this.request,t.url=this.request.url,t.headers=this.request.headers),t}setListener(t){this.listener=t}disconnect(t){this.keepaliveTimer&&clearTimeout(this.keepaliveTimer);let r=this.createContext();ze(r,async()=>{try{if(!t){let n=await El.get(this.sessionId);n?.doesExist()&&await BR(n,n.data,r)}}finally{await El.delete(this.sessionId)}}).catch(n=>{(0,Ii.warn)(`Error publishing MQTT will for ${this.sessionId}`,n)});for(let n of this.subscriptions)n.end();this.subscriptions=[]}receivedPacket(){this.keepalive&&(clearTimeout(this.keepaliveTimer),this.keepaliveTimer=setTimeout(()=>{this.disconnect(!1)},this.keepalive*1500))}};a(BR,"publish");HR=class extends pE{static{a(this,"DurableSubscriptionsSession")}sessionRecord;constructor(t,r,n){super(t,r),this.sessionRecord=n||{id:t,subscriptions:[]}}async resume(){for(let t of this.sessionRecord.subscriptions||[])await this.resumeSubscription({omitCurrent:!0,topic:t.topic,qos:t.qos,startTime:t.startTime},!0,t.acks?r=>!t.acks.includes(r.timestamp):null)}resumeSubscription(t,r,n){return super.addSubscription(t,r,n)}needsAcknowledge(t){this.awaitingAcks||(this.awaitingAcks=new Map);let r=vR(),n={topic:t.topic,timestamp:t.timestamp};return t.acknowledge&&(n.acknowledge=t.acknowledge),this.awaitingAcks.set(r,n),r}acknowledge(t){let r=this.awaitingAcks.get(t);this.awaitingAcks.delete(t),r.acknowledge?.();let n=r.topic;for(let[,s]of this.awaitingAcks)if(s.topic===n&&s.timestamp<r.timestamp){for(let i of this.sessionRecord.subscriptions)if(i.topic===n){i.acks||(i.acks=[]),i.acks.push(r.timestamp),(0,Ii.trace)("Received ack",n,r.timestamp),this.sessionRecord.update();return}}for(let s of this.sessionRecord.subscriptions)s.topic===n&&(s.startTime=r.timestamp);this.sessionRecord.update()}async addSubscription(t,r){await this.resumeSubscription(t,r);let{qos:n,startTime:s}=t;return n>0&&!s&&this.saveSubscriptions(),t.qos}removeSubscription(t){let r=this.subscriptions.find(s=>s.topic===t),n=super.removeSubscription(t);return r.qos>0&&this.saveSubscriptions(),n}saveSubscriptions(){this.sessionRecord.subscriptions=this.subscriptions.map(t=>{let r=t.startTime;return r||(r=t.startTime=(0,dH.getNextMonotonicTime)()),(0,Ii.trace)("Added durable subscription",t.topic,r),{qos:t.qos,topic:t.topic,startTime:r}}),PR.put(this.sessionRecord)}}});var GR={};Fe(GR,{bypassAuth:()=>Gre,start:()=>Fre});function Gre(){RH=!0}function Fre({server:e,port:t,network:r,webSocket:n,securePort:s,requireAuthentication:i}){e.mqtt||(e.mqtt={requireAuthentication:i,sessions:new Set,events:new gH.EventEmitter},e.mqtt.events.on("error",()=>{}));let o=e.mqtt,c,u=r?.mtls;return n&&(c=e.ws((_,l,d)=>{if(_.protocol==="mqtt"){o.events.emit("connection",_),rr.debug("Received WebSocket connection for MQTT from",_._socket.remoteAddress);let{onMessage:f,onClose:E}=SH(_,(h,S)=>{if(_.send(h),S&&_._socket.writableNeedDrain)return new Promise(p=>this._socket.once("drain",p))},l,Promise.resolve(d).then(()=>l?.user),o);_.on("message",f),_.on("close",E),_.on("error",h=>{rr.info("WebSocket error",h)})}},Object.assign({subProtocol:"mqtt"},n))),(t||s)&&(c=e.socket(async _=>{let l;if(o.events.emit("connection",_),rr.debug(`Received ${_.getCertificate?"SSL":"TCP"} connection for MQTT from ${_.remoteAddress}`),u){if(_.authorized)try{let E=u.user;if(E!==null){(E===void 0||E==="Common Name"||E==="CN")&&(E=_.getPeerCertificate().subject.CN);try{l=await e.getUser(E,null,null),(0,Va.get)(Qt.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&TE.notify({username:l?.username,status:Qt.AUTH_AUDIT_STATUS.SUCCESS,type:Qt.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"MQTT mTLS",remote_address:_.remoteAddress})}catch(h){throw(0,Va.get)(Qt.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&TE.error({username:E,status:Qt.AUTH_AUDIT_STATUS.FAILURE,type:Qt.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"mqtt",remote_address:_.remoteAddress}),h}}else rr.debug("MQTT mTLS authorized connection (mTLS did not authorize a user)","from",_.remoteAddress)}catch(E){o.events.emit("error",E,_),rr.error(E)}else if(u.required)return rr.info(`Unauthorized connection attempt, no authorized client certificate provided, error: ${_.authorizationError}`),_.end()}!l&&RH&&_.remoteAddress.includes("127.0.0.1")&&(l=await(0,TH.getSuperUser)(),rr.debug("Auto-authorizing local connection",l?.username));let{onMessage:d,onClose:f}=SH(_,E=>_.write(E),null,l,o);_.on("data",d),_.on("close",f),_.on("error",E=>{rr.info("Socket error",E)})},{port:t,securePort:s,mtls:u})),c}function SH(e,t,r,n,s){pH||(pH=!0,ju(d=>{SE>0&&d.push({metric:"mqtt-connections",connections:SE,byThread:!0})}));let i;SE++;let o,c={protocolVersion:4},u=(0,gE.parser)({protocolVersion:5});function _(d){u.parse(d)}a(_,"onMessage");function l(){SE--,i||(i=!0,o?.disconnect?.(),s.events.emit("disconnected",o,e),s.sessions.delete(o),Qr(!1,"connection","mqtt","disconnect"),rr.debug("MQTT connection was closed",e.remoteAddress))}return a(l,"onClose"),u.on("packet",async d=>{n?.then&&(n=await n),o?.then&&await o;try{switch(o?.receivedPacket?.(),d.cmd){case"connect":if(c.protocolVersion=d.protocolVersion,d.username)try{n=await et.getUser(d.username,d.password.toString(),r),(0,Va.get)(Qt.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&TE.notify({username:n?.username,status:Qt.AUTH_AUDIT_STATUS.SUCCESS,type:Qt.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"MQTT",remote_address:e.remoteAddress})}catch(g){return(0,Va.get)(Qt.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&TE.error({username:d.username,status:Qt.AUTH_AUDIT_STATUS.FAILURE,type:Qt.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"mqtt",remote_address:e.remoteAddress}),s.events.emit("auth-failed",d,e,g),Qr(!1,"connection","mqtt","connect"),f({cmd:"connack",reasonCode:4,returnCode:134})}if(!n&&s.requireAuthentication)return s.events.emit("auth-failed",d,e),Qr(!1,"connection","mqtt","connect"),f({cmd:"connack",reasonCode:4,returnCode:134});try{if(s.authorizeClient?.(d,n),d.will){let g=e.deserialize||(e.deserialize=ho(r?.headers.get?.("content-type")));d.will.data=d.will.payload?.length>0?g(d.will.payload):void 0,delete d.will.payload}o=hH({user:n,...d}),o=await o,o.socket=e,r&&(o.request=r),s.sessions.add(o)}catch(g){return rr.error(g),s.events.emit("auth-failed",d,e,g),Qr(!1,"connection","mqtt","connect"),f({cmd:"connack",reasonCode:g.code||5,returnCode:g.code||128})}s.events.emit("connected",o,e),Qr(!0,"connection","mqtt","connect"),f({cmd:"connack",sessionPresent:o.sessionWasPresent,reasonCode:0,returnCode:0}),o.setListener((g,L,v,P)=>{try{let k=g.indexOf("/",1),H=k>0?g.slice(0,k):g;f({cmd:"publish",topic:g,payload:E(L),messageId:v||Math.floor(Math.random()*1e8),qos:P.qos},H)}catch(k){rr.error(k),o?.disconnect(),s.sessions.delete(o)}}),o.sessionWasPresent&&await o.resume();break;case"subscribe":let h=[];for(let g of d.subscriptions){let L;try{L=(await o.addSubscription(g,g.qos>=1)).qos||0}catch(v){s.events.emit("error",v,e,g,o),rr.error(v),L=c.protocolVersion<5?128:v.statusCode===403?135:v.statusCode===404?143:128}h.push(L)}await o.committed,f({cmd:"suback",granted:h,messageId:d.messageId});break;case"unsubscribe":{let g=[];for(let L of d.unsubscriptions)g.push(o.removeSubscription(L)?0:17);f({cmd:"unsuback",granted:g,messageId:d.messageId});break}case"pubrel":f({cmd:"pubcomp",messageId:d.messageId,reasonCode:0});return;case"publish":let S=d.qos===2?"pubrec":"puback",p=e.deserialize||(e.deserialize=ho(r?.headers.get?.("content-type"))),T=d.payload?.length>0?p(d.payload):void 0,A;try{A=await o.publish(d,T)}catch(g){s.events.emit("error",g,e,d,o),rr.warn(g),d.qos>0&&f({cmd:S,messageId:d.messageId,reasonCode:128},d.topic);break}d.qos>0&&f({cmd:S,messageId:d.messageId,reasonCode:A===!1?144:0},d.topic);break;case"pubrec":f({cmd:"pubrel",messageId:d.messageId,reasonCode:0});break;case"pubcomp":case"puback":o.acknowledge(d.messageId);break;case"pingreq":f({cmd:"pingresp"});break;case"disconnect":i=!0,o?.disconnect(!0),s.events.emit("disconnected",o,e),s.sessions.delete(o),Qr(!0,"connection","mqtt","disconnect"),rr.debug("Received disconnect command, closing MQTT session",e.remoteAddress),e.close?e.close():e.end();break}}catch(h){s.events.emit("error",h,e,d,o),rr.error(h),f({cmd:"disconnect"})}function f(h,S){let p=(0,gE.generate)(h,c);t(p),Wr(p.length,"bytes-sent",S,h.cmd,"mqtt")}a(f,"sendPacket");function E(h){return lo(h,r)}a(E,"serialize")}),{onMessage:_,onClose:l}}var gE,TH,Va,Qt,xR,gH,TE,rr,RH,pH,SE,AH=Re(()=>{gE=require("mqtt-packet");mH();TH=B(un());Ra();vs();ar();Va=B(te()),Qt=B(U()),xR=B(K()),gH=require("events"),TE=(0,xR.loggerWithTag)("auth-event"),rr=(0,xR.loggerWithTag)("mqtt"),RH=(0,Va.get)(Qt.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE;a(Gre,"bypassAuth");a(Fre,"start");SE=0;a(SH,"onSocket")});var lf={};Fe(lf,{component_errors:()=>Ya,loadComponent:()=>RE,loadComponentDirectories:()=>LH,setErrorReporter:()=>$re});function LH(e,t){t&&(qR=t),e&&(kR=e);let r=[];if((0,xn.existsSync)(FR)){let s=(0,xn.readdirSync)(FR,{withFileTypes:!0});for(let i of s){if(!i.isDirectory()&&!i.isSymbolicLink())continue;let o=i.name,c=(0,At.join)(FR,o);r.push(RE(c,qR,"hdb",!1))}}let n=process.env.RUN_HDB_APP;return n&&r.push(RE(n,qR,n,!1,null,process.env.DEV_MODE)),Promise.all(r).then(()=>{DH=!0})}function $re(e){ml=e}async function RE(e,t,r,n,s,i){if(!bH.has(e)){bH.set(e,!0),s&&(kR=s);try{let o;n&&(Ya=new Map);let c=(0,At.join)(e,n?"harperdb-config.yaml":"config.yaml");(0,xn.existsSync)(c)?o=n?(0,CH.getConfigObj)():(0,yH.parseDocument)((0,xn.readFileSync)(c,"utf8"),{simpleKeys:!0}).toJSON():o=VR;let u=[],_=n;for(let l in o){let d=o[l];if(Ya.set(n?l:(0,At.basename)(e),!1),!d)continue;let f,E=d.package;try{if(E){let A=e,g;for(;!(0,xn.existsSync)(g=(0,At.join)(A,"node_modules",l));)if(A=(0,At.dirname)(A),A.length<(0,wH.getHdbBasePath)().length){g=null;break}if(g)f=await RE(g,t,r,!1),_=!0;else throw new Error(`Unable to find package ${l}:${E}`)}else f=Vre[l];if(!f)continue;u.push(f);let h=a(A=>(A.origin=r,ut(A)),"ensureTable"),S=d.network||(d.port||d.securePort)&&d,p=S?.securePort||S?.https&&S.port,T=!S?.https&&S?.port;if($a.isMainThread&&(f=await f.startOnMainThread?.({server:et,ensureTable:h,port:T,securePort:p,resources:t,...d})||f,n&&S))for(let A of[T,p])try{if(+A&&!OH.includes(A)){let g=$R.get(YR.CONFIG_PARAMS.HTTP_SESSIONAFFINITY);g&&hl.default.warn("Session affinity is not recommended and may cause memory leaks"),(g||!iE)&&(OH.push(A),vB(A,g))}}catch(g){console.error("Error listening on socket",A,g,l)}if(t.isWorker&&(f=await f.start?.({server:et,ensureTable:h,port:T,securePort:p,resources:t,...d})||f),kR.set(f,!0),(f.handleFile||f.handleDirectory)&&d.files){if(d.files.includes(".."))throw(0,IH.handleHDBError)("Can not reference parent directories");let A=(0,At.join)(e,d.files).replace(/\\/g,"/"),g=A.indexOf("/*");if(g>-1&&d.files!==VR[l]?.files&&!(0,xn.existsSync)(A.slice(0,g)))throw new Error(`The path '${A.slice(0,g)}' does not exist and cannot be used as the base of the resolved 'files' path value '${d.files}'`);let L=(0,At.basename)(e),v=d.path||"/";v=v.startsWith("/")?v:v.startsWith("./")?"/"+L+v.slice(2):v==="."?"/"+L:"/"+L+"/"+v;let P,k,H;if(d.root){let z=d.root;z.startsWith("/")&&(z=z.slice(1)),z.endsWith("/")&&(z=z.slice(0,-1)),z+="/",k=(0,At.join)(e,z)}else(H=A.indexOf("/*"))>-1&&(k=A.slice(0,H+1),P=(0,At.relative)(e,k));let X=!1;if($a.isMainThread&&f.setupDirectory&&(X=await f.setupDirectory?.(v,k,t)),t.isWorker&&f.handleDirectory&&(X=await f.handleDirectory?.(v,k,t)),X)continue;for(let z of await(0,NH.default)(A,{onlyFiles:!1,objectMode:!0})){let{path:J,dirent:me}=z;_=!0;let ce=(0,At.relative)(e,J).replace(/\\/g,"/");if(P)if(ce.startsWith(P))ce=ce.slice(P.length+1);else throw new Error(`The root path '${d.root}' does not reference a valid part of the file path '${ce}'.The root path should be used to indicate the relative path/part of the file path for determining the exported web path.`);let de=v+(v.endsWith("/")?"":"/")+ce;try{if(me.isFile()){let De=await kre(J);$a.isMainThread&&await f.setupFile?.(De,de,J,t),t.isWorker&&await f.handleFile?.(De,de,J,t)}else $a.isMainThread&&await f.setupDirectory?.(de,J,t),t.isWorker&&await f.handleDirectory?.(de,J,t)}catch(De){De.message=`Could not load ${me.isFile()?"file":"directory"} '${J}'${d.module?" using '"+d.module+"'":""} for application '${e}' due to: ${De.message}`,ml?.(De),((0,Ka.getWorkerIndex)()===0?console:hl.default).error(De),t.set(d.path||"/",new pl(De)),Ya.set(n?l:(0,At.basename)(e),De.message)}}}}catch(h){h.message=`Could not load component '${l}' for application '${(0,At.basename)(e)}' due to: ${h.message}`,ml?.(h),((0,Ka.getWorkerIndex)()===0?console:hl.default).error(h),t.set(d.path||"/",new pl(h),null,!0),Ya.set(n?l:(0,At.basename)(e),h.message)}}if($a.isMainThread&&!DH&&i&&(0,Ka.watchDir)(e,async()=>LH()),o.extensionModule)return await t_((0,At.join)(e,o.extensionModule));if(!_&&t.isWorker){let l=`${e} did not load any modules, resources, or files, is this a valid component?`;ml?.(new Error(l)),((0,Ka.getWorkerIndex)()===0?console:hl.default).error(l),Ya.set((0,At.basename)(e),l)}}catch(o){console.error(`Could not load application directory ${e}`,o),o.message=`Could not load application due to ${o.message}`,ml?.(o),t.set("",new pl(o))}}}var xn,At,$a,yH,$R,YR,NH,Ka,hl,IH,wH,qre,CH,kre,FR,kR,DH,qR,Ya,Vre,VR,OH,bH,ml,pl,_f=Re(()=>{xn=require("fs"),At=require("path"),$a=require("worker_threads"),yH=require("yaml"),$R=B(te()),YR=B(U());JO();eb();tb();Hv();bB();DB();NH=B(require("fast-glob")),Ka=B(ct()),hl=B(K());vh();ar();IH=B(ne());bn();Ae();BB();wH=B(te()),qre=B(qB());tf();zB();AH();CH=B(dr());oE();({readFile:kre}=xn.promises),FR=$R.get(YR.CONFIG_PARAMS.COMPONENTSROOT),kR=new Map,Ya=new Map;a(LH,"loadComponentDirectories");Vre={REST:Mf,rest:Mf,graphqlSchema:Ph,jsResource:Hh,fastifyRoutes:uR,login:Gh,static:lR,operationsApi:qre,customFunctions:{},http:{},clustering:bR,authentication:Uu,mqtt:GR},VR={rest:!0,graphqlSchema:{files:"*.graphql"},jsResource:{files:"resources.js"},fastifyRoutes:{files:"routes/*.js",path:"."}};Object.defineProperty(VR,"static",{value:{files:"web/**"}});OH=[],bH=new Map;a($re,"setErrorReporter");a(RE,"loadComponent");pl=class extends kt{constructor(r){super();this.error=r}static{a(this,"ErrorResource")}get(){throw this.error}post(){throw this.error}put(){throw this.error}delete(){throw this.error}connect(){throw this.error}getResource(){return this}publish(){throw this.error}subscribe(){throw this.error}}});var UR=R((Lme,UH)=>{var{isMainThread:MH}=require("worker_threads"),{getTables:Yre}=(Ae(),ie(qe)),{loadComponentDirectories:Kre,loadComponent:Wre}=(_f(),ie(lf)),{resetResources:Qre}=(Lu(),ie(wU)),zre=qT(),Jre=dr(),{dirname:Xre}=require("path"),{getConnection:jre}=Nt(),Zre=te(),ene=U(),KR=new Map;async function tne(e=!1){!MH&&Zre.get(ene.CONFIG_PARAMS.CLUSTERING_ENABLED)&&jre();try{MH&&await zre()}catch(n){console.error(n)}let t=Qre();Yre(),t.isWorker=e,await Wre(Xre(Jre.getConfigFilePath()),t,"hdb",!0,KR),await Kre(KR,t);let r=[];for(let[n]of KR)n.ready&&r.push(n.ready());r.length>0&&await Promise.all(r)}a(tne,"loadRootComponents");UH.exports.loadRootComponents=tne});var ct=R((Ume,Ci)=>{"use strict";var{Worker:rne,MessageChannel:nne,parentPort:_s,isMainThread:XR,threadId:sne,workerData:Vs}=require("worker_threads"),{PACKAGE_ROOT:ine}=U(),{join:HH,isAbsolute:one,extname:ane}=require("path"),{server:xH}=(ar(),ie(Ui)),{watch:cne,readdir:une}=require("fs/promises"),{totalmem:PH}=require("os"),Sl=U(),GH=te(),$s=K(),{randomBytes:lne}=require("crypto"),{_assignPackageExport:_ne}=require("../index"),dne=U(),vH=1024*1024,wi=[],pn=[],fne=50,jR=1e4,Ene="restart",FH="request_thread_info",qH="resource_report",kH="thread_info",VH="added-port",hne="ack",WR;_ne("threads",pn);Ci.exports={startWorker:QR,restartWorkers:eA,shutdownWorkers:gne,workers:wi,setMonitorListener:wne,onMessageFromWorkers:Rne,onMessageByType:JH,broadcast:One,broadcastWithAcknowledgement:yne,setChildListenerByType:Tne,getWorkerIndex:$H,getWorkerCount:YH,getTicketKeys:WH,setMainIsWorker:pne,setTerminateTimeout:mne,restartNumber:Vs?.restartNumber||1};pn.onMessageByType=JH;pn.sendToThread=function(e,t){if(!t?.type)throw new Error("A message with a type must be provided");let r=pn.find(n=>n.threadId===e);if(r)return r.postMessage(t),!0};var ZR;function mne(e){jR=e}a(mne,"setTerminateTimeout");function $H(){return Vs?Vs.workerIndex:ZR?0:void 0}a($H,"getWorkerIndex");function YH(){return Vs?Vs.workerCount:ZR?1:void 0}a(YH,"getWorkerCount");function pne(e){ZR=e}a(pne,"setMainIsWorker");var KH=1,AE;function WH(){return AE||(AE=XR?lne(48):Vs.ticketKeys,AE)}a(WH,"getTicketKeys");Object.defineProperty(xH,"workerIndex",{get(){return $H()}});Object.defineProperty(xH,"workerCount",{get(){return YH()}});var QH={[FH](e,t){Nne(t)},[qH](e,t){Ine(t,e)}};function QR(e,t={}){let r=process.constrainedMemory?.()||PH();r=Math.min(r,PH(),2e4*vH);let n=GH.get(Sl.CONFIG_PARAMS.THREADS_MAXHEAPMEMORY)??Math.max(Math.floor(r/vH/(10+(t.threadCount||1)/4)),512),s=Math.min(Math.max(n>>6,16),64),i=[],o=[];for(let u of pn){let _=new nne;_.existingPort=u,i.push(_),o.push(_.port2)}ane(e)||(e+=".js");let c=new rne(one(e)?e:HH(ine,e),Object.assign({resourceLimits:{maxOldGenerationSizeMb:n,maxYoungGenerationSizeMb:s},execArgv:["--enable-source-maps"],argv:process.argv.slice(2),workerData:{addPorts:o,addThreadIds:i.map(u=>u.existingPort.threadId),workerIndex:t.workerIndex,workerCount:KH=t.threadCount,name:t.name,restartNumber:Ci.exports.restartNumber,ticketKeys:WH()},transferList:o},t));for(let{port1:u,existingPort:_}of i)_.postMessage({type:VH,port:u,threadId:c.threadId},[u]);return bE(c,!0),c.unexpectedRestarts=t.unexpectedRestarts||0,c.startCopy=()=>QR(e,t),c.on("error",u=>{$s.error(`Worker index ${t.workerIndex} error:`,u)}),c.on("exit",u=>{wi.splice(wi.indexOf(c),1),!c.wasShutdown&&t.autoRestart!==!1&&(c.unexpectedRestarts<fne?(t.unexpectedRestarts=c.unexpectedRestarts+1,QR(e,t)):$s.error(`Thread has been restarted ${c.restarts} times and will not be restarted`))}),c.on("message",u=>{QH[u.type]?.(u,c)}),wi.push(c),Dne(),t.onStarted&&t.onStarted(c),c.name=t.name,c}a(QR,"startWorker");var Sne=[Sl.THREAD_TYPES.HTTP];async function eA(e=null,t=Math.max(KH>3,1),r=!0){if(XR){if(r){let{loadRootComponents:o}=UR();await o()}Ci.exports.restartNumber++,t<1&&(t=t*wi.length);let n=[],s=[];for(let o of wi.slice(0)){if(e&&o.name!==e||o.wasShutdown)continue;$s.trace("sending shutdown request to ",o.threadId),o.postMessage({restartNumber:Ci.exports.restartNumber,type:Sl.ITC_EVENT_TYPES.SHUTDOWN}),o.wasShutdown=!0,o.emit("shutdown",{});let c=Sne.indexOf(o.name)>-1,u=new Promise(_=>{let l=setTimeout(()=>o.terminate(),jR*2).unref();o.on("exit",()=>{clearTimeout(l),n.splice(n.indexOf(u)),!c&&r&&o.startCopy(),_()})});if(n.push(u),c&&r){let _=o.startCopy(),l=new Promise(d=>{let f=a(E=>{E.type===dne.ITC_EVENT_TYPES.CHILD_STARTED&&($s.trace("Worker has started",_.threadId),d(),s.splice(s.indexOf(l)),_.off("message",f))},"startListener");$s.trace("Waiting for worker to start",_.threadId),_.on("message",f)});s.push(l),n.length>=t&&await Promise.race(n),s.length>=t&&await Promise.race(s)}}await Promise.all(n),await Promise.all(s);let{restartService:i}=Xd();r&&(e==="http"||!e)&&GH.get(Sl.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await i({service:"clustering"})}else _s.postMessage({type:Ene,workerType:e})}a(eA,"restartWorkers");function Tne(e,t){QH[e]=t}a(Tne,"setChildListenerByType");function gne(e){return eA(e,1/0,!1)}a(gne,"shutdownWorkers");var zH=[];function Rne(e){zH.push(e)}a(Rne,"onMessageFromWorkers");var zR=new Map;function JH(e,t){let r=zR.get(e);r||zR.set(e,r=[]),r.push(t)}a(JH,"onMessageByType");var Ane=10;async function One(e){let t=0;for(let r of pn)try{r.postMessage(e),t++>Ane&&(t=0,await new Promise(setImmediate))}catch(n){$s.error("Unable to send message to worker",n)}}a(One,"broadcast");var OE=new Map,bne=1;function yne(e){return new Promise(t=>{let r=0;for(let n of pn)try{let s=bne++,i=a(()=>{OE.delete(s),--r===0&&t(),n!==_s&&--n.refCount===0&&n.unref()},"ack_handler");i.port=n,n.ref(),n.refCount=(n.refCount||0)+1,OE.set(e.requestId=s,i),n.hasAckCloseListener||(n.hasAckCloseListener=!0,n.on(n.close?"close":"exit",()=>{for(let[,o]of OE)o.port===n&&o()})),n.postMessage(e),r++}catch(s){$s.error("Unable to send message to worker",s)}r===0&&t()})}a(yne,"broadcastWithAcknowledgement");function Nne(e){e.postMessage({type:kH,workers:XH()})}a(Nne,"sendThreadInfo");function XH(){let e=Date.now();return wi.map(t=>({threadId:t.threadId,name:t.name,heapTotal:t.resources?.heapTotal,heapUsed:t.resources?.heapUsed,externalMemory:t.resources?.external,arrayBuffers:t.resources?.arrayBuffers,sinceLastUpdate:e-t.resources?.updated,...t.recentELU}))}a(XH,"getChildWorkerInfo");function Ine(e,t){e.resources=t,e.resources.updated=Date.now()}a(Ine,"recordResourceReport");var JR;function wne(e){JR=e}a(wne,"setMonitorListener");var Cne=1e3,BH=!1;function Dne(){BH||(BH=!0,setInterval(()=>{for(let e of wi){let t=e.performance.eventLoopUtilization(),r;e.lastTotalELU?r=e.performance.eventLoopUtilization(t,e.lastTotalELU):r=t,e.lastTotalELU=t,e.recentELU=r}JR&&JR()},Cne).unref())}a(Dne,"startMonitoring");var Lne=1e3;if(_s){bE(_s);for(let e=0,t=Vs.addPorts.length;e<t;e++){let r=Vs.addPorts[e];r.threadId=Vs.addThreadIds[e],bE(r)}setInterval(()=>{let e=process.memoryUsage();_s.postMessage({type:qH,heapTotal:e.heapTotal,heapUsed:e.heapUsed,external:e.external,arrayBuffers:e.arrayBuffers})},Lne).unref(),WR=a(()=>new Promise((e,t)=>{_s.on("message",r),_s.postMessage({type:FH});function r(n){n.type===kH&&(_s.off("message",r),e(n.workers))}a(r,"receiveThreadInfo")}),"getThreadInfo")}else WR=XH;Ci.exports.getThreadInfo=WR;function bE(e,t){pn.push(e),e.on("message",r=>{if(r.type===VH)r.port.threadId=r.threadId,bE(r.port);else if(r.type===hne){let n=OE.get(r.id);n&&n()}else{for(let s of zH)s(r,e);let n=zR.get(r.type);if(n)for(let s of n)try{s(r,e)}catch(i){$s.error(i)}}}).on("close",()=>{pn.splice(pn.indexOf(e),1)}).on("exit",()=>{pn.splice(pn.indexOf(e),1)}),t?e.refCount=100:e.unref()}a(bE,"addPort");if(XR){let e,t,r=a(async(n,s)=>{s&&(e=s);for(let i of await une(n,{withFileTypes:!0}))i.isDirectory()&&i.name!=="node_modules"&&r(HH(n,i.name));try{for await(let{filename:i}of cne(n,{persistent:!1}))t&&clearTimeout(t),t=setTimeout(async()=>{e&&await e(),await eA(),console.log("Reloaded HarperDB components")},100)}catch(i){console.warn("Error trying to watch component directory",n,i)}},"watch_dir");Ci.exports.watchDir=r,process.env.WATCH_DIR&&r(process.env.WATCH_DIR)}else _s.on("message",async e=>{let{type:t}=e;t===Sl.ITC_EVENT_TYPES.SHUTDOWN&&(Ci.exports.restartNumber=e.restartNumber,_s.unref(),setTimeout(()=>{$s.warn("Thread did not voluntarily terminate",sne),process.exit(0)},jR).unref())})});var cC={};Fe(cC,{AUDIT_STORE_OPTIONS:()=>Kd,createAuditEntry:()=>o_,openAuditStore:()=>wE,readAuditEntry:()=>Ut,setAuditRetention:()=>Une,transactionKeyEncoder:()=>ox});function wE(e){let t=e.auditStore=e.openDB(nx.AUDIT_STORE_NAME,Kd);t.rootStore=e;let r=[];t.addDeleteRemovalCallback=function(i,o){return r[i]=o,{remove(){delete r[i]}}};let n=null;function s(i=yE){clearTimeout(n),n=setTimeout(async()=>{if(t.rootStore.status==="closed")return;let o=0,c;try{for(let{key:u,value:_}of t.getRange({start:0,snapshot:!1,end:Date.now()-tA})){if((_[0]&15)===sA){let l=Ut(_),d=l.tableId;r[d]?.(l.recordId)}if(c=t.remove(u),await new Promise(setImmediate),++o>=Mne){i=10;break}}await c}finally{o===0&&(i=Math.min(i<<1,tA/10)),s(i)}},i).unref()}return a(s,"scheduleAuditCleanup"),t.scheduleAuditCleanup=s,(0,IE.getWorkerIndex)()===(0,IE.getWorkerCount)()-1&&s(yE),t}function Une(e,t=yE){tA=e,yE=t}function o_(e,t,r,n,s,i,o){let c=ax[i];if(!c)throw new Error(`Invalid audit entry type ${i}`);let u=1;n&&(n>1?Wa.setFloat64(0,n):Sn.set(tm),u=9),f(0),f(t),d(r),Wa.setFloat64(u,e),u+=8,s?d(s):Sn[u++]=0,Sn[n?8:0]=c;let l=Sn.subarray(0,u);if(o)return Buffer.concat([l,o]);return l;function d(E){let h=u;u+=1,u=(0,Qa.writeKey)(E,Sn,u);let S=u-h-1;S>127?S>16383?(oA.error("Key or username was too large for audit entry",E),u=h+1,Sn[h]=0):(Sn.copyWithin(h+2,h+1,u),Wa.setUint16(h,S|32768),u++):Sn[h]=S}function f(E){E<128?Sn[u++]=E:E<16384?(Wa.setUint16(u,E|32768),u+=2):E<1056964608?(Wa.setUint32(u,E|3221225472),u+=4):(Sn[u]=255,Wa.setUint32(u+1,E),u+=5)}}function Ut(e){try{let t=e.dataView||(e.dataView=new iA(e.buffer,e.byteOffset,e.byteLength)),r;e[0]==66&&(r=t.readFloat64());let n=t.readInt(),s=t.readInt(),i=t.readInt(),o=t.readInt(),c=t.position,u=t.position+=o,_=t.readFloat64();o=t.readInt();let l=t.position,d=t.position+=o;return{type:ax[n&7],tableId:i,get recordId(){return rx(e,c,u)},version:_,previousLocalTime:r,get user(){return d>l?rx(e,l,d):void 0},getValue(f,E,h){if(n&rA||n&nA&&!E)return f.decoder.decode(e.subarray(t.position));if(n&nA&&h)return aA(f.getEntry(this.recordId),h,f)}}}catch(t){return oA.error("Reading audit entry error",t,e),{}}}function rx(e,t,r){let n=e.subarray(t,r);return(0,Qa.readKey)(n,0,r-t)}var Qa,NE,nx,sx,IE,ix,oA,Sn,Wa,ox,Kd,tA,Mne,yE,rA,nA,jH,sA,ZH,ex,tx,ax,iA,js=Re(()=>{Qa=require("ordered-binary"),NE=B(te()),nx=B(at()),sx=B(U()),IE=B(ct()),ix=B(Q());bc();oA=B(K());CE();(0,NE.initSync)();Sn=Buffer.alloc(1024),Wa=new DataView(Sn.buffer,Sn.byteOffset,1024),ox={writeKey(e,t,r){return e===Oc?(t.set(Oc,r),r+8):typeof e=="number"?((t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).setFloat64(r,e),r+8):(0,Qa.writeKey)(e,t,r)},readKey(e,t,r){return e[t]===66?(e.dataView||(e.dataView=new DataView(e.buffer,e.byteOffset,e.byteLength))).getFloat64(t):(0,Qa.readKey)(e,t,r)}},Kd={encoding:"binary",keyEncoder:ox},tA=(0,ix.convertToMS)((0,NE.get)(sx.CONFIG_PARAMS.LOGGING_AUDITRETENTION))||86400*3,Mne=1e3,yE=1e4;a(wE,"openAuditStore");a(Une,"setAuditRetention");rA=16,nA=32,jH=1,sA=2,ZH=3,ex=4,tx=5,ax={put:jH|rA,[jH]:"put",delete:sA,[sA]:"delete",message:ZH|rA,[ZH]:"message",invalidate:ex,[ex]:"invalidate",patch:tx|nA,[tx]:"patch"};a(o_,"createAuditEntry");a(Ut,"readAuditEntry");iA=class extends DataView{static{a(this,"Decoder")}position=0;readInt(){let t=this.getUint8(this.position++);return t>=128?t>=192?t===255?(t=this.getUint32(this.position),this.position+=4,t):(t=this.getUint32(this.position-1)&1073741823,this.position+=3,t):(t=this.getUint16(this.position-1)&32767,this.position++,t):t}readFloat64(){try{let t=this.getFloat64(this.position);return this.position+=8,t}catch{debugger}}};a(rx,"readKeySafely")});var cA={};Fe(cA,{add:()=>DE,applyReverse:()=>cx,getRecordAtTime:()=>aA,rebuildUpdateBefore:()=>LE});function DE(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n+BigInt(r.value):isNaN(e[t])?e[t]=r.value:e[t]=n+r.value}function LE(e,t){let r=null;for(let n in e)if(n in t){let s=t[n];if(s?.__op__){let i=e[n];if(i?.__op__)if(i.__op__===s.__op__)r||(r={}),r[n]=i;else throw new Error("Can not merge updates with different operations");else r||(r={}),r[n]=i,DE(r,n,s)}}else r||(r={}),r[n]=e[n];return r}function cx(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=Pne[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=ux}}function aA(e,t,r){let n=r.rootStore.auditStore,s=Object.assign({},e.value),i=e.localTime;for(;i>t;){let u=n.get(i),_=Ut(u);switch(_.type){case"put":s=_.getValue(r);break;case"patch":cx(s,_.getValue(r));break;case"delete":s=null}i=_.previousLocalTime}let o={},c=0;for(let u in s)s[u]===ux&&(o[u]=!0,c++);for(;c>0&&i>0;){let u=n.get(i),_=Ut(u),l;switch(_.type){case"put":l=_.getValue(r);break;case"patch":l=_.getValue(r);break}for(let d in l)o[d]&&(s[d]=l[d],o[d]=!1,c--);i=_.previousLocalTime}if(c>0)for(let u in o)s[u]=null;return s}var Pne,ux,CE=Re(()=>{js();a(DE,"add");DE.reverse=function(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n-BigInt(r.value):isNaN(e[t])||(e[t]=n-r.value)};Pne={add:DE};a(LE,"rebuildUpdateBefore");a(cx,"applyReverse");ux={};a(aA,"getRecordAtTime")});function Jr(e){return e[Ot]||(e[Ot]=Object.create(null))}function BE(e,t){let r=e.prototype,n={},s=t.attributes||t.properties||[];for(let o of s){let c=o.name,u,_;if(o.resolve)_={get(){return o.resolve(this,this[ye])},set(l){return o.set(this,l)},configurable:!0};else{switch(o.type){case"String":u=a(function(l){if(!(typeof l=="string"||l==null&&o.nullable!==!1))throw new Tn.ClientError(`${c} must be a string, attempt to assign ${l}`);Jr(this)[c]=l},"set");break;case"ID":u=a(function(l){if(!(typeof l=="string"||l?.length>0&&l.every?.(d=>typeof d=="string")||l==null&&o.nullable!==!1))throw new Tn.ClientError(`${c} must be a string, attempt to assign ${l}`);Jr(this)[c]=l},"set");break;case"Float":case"Number":u=a(function(l){let d=l?.__op__?l.value:l;if(!(typeof d=="number"||l==null&&o.nullable!==!1))throw new Tn.ClientError(`${c} must be a number, attempt to assign ${d}`);Jr(this)[c]=l},"set");break;case"Int":u=a(function(l){let d=l?.__op__?l.value:l;if(!(d>>0===d||l==null&&o.nullable!==!1))if(typeof d=="number"&&Math.abs((d>>0)-d)<=1)d=Math.round(d),l?.__op__?l.value=d:l=d;else throw new Tn.ClientError(`${c} must be an integer between -2147483648 and 2147483647, attempt to assign ${l}`);Jr(this)[c]=l},"set");break;case"Long":u=a(function(l){let d=l?.__op__?l.value:l;if(!(Math.round(d)===l&&Math.abs(d)<=9007199254740992||l==null&&o.nullable!==!1))if(typeof d=="number"&&Math.abs(d)<=9007199254740992)d=Math.round(d),l?.__op__?l.value=d:l=d;else throw new Tn.ClientError(`${c} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${l}`);Jr(this)[c]=l},"set");break;case"BigInt":u=a(function(l){let d=l?.__op__?l.value:l;if(!(typeof d=="bigint"||l==null&&o.nullable!==!1))if(typeof d=="string"||typeof d=="number")d=BigInt(d),l?.__op__?l.value=d:l=d;else throw new Tn.ClientError(`${c} must be a number, attempt to assign ${l}`);Jr(this)[c]=l},"set");break;case"Boolean":u=a(function(l){if(!(typeof l=="boolean"||l==null&&o.nullable!==!1))throw new Tn.ClientError(`${c} must be a boolean, attempt to assign ${l}`);Jr(this)[c]=l},"set");break;case"Date":u=a(function(l){if(!(l instanceof Date||l==null&&o.nullable!==!1))if(typeof l=="string"||typeof l=="number")l=new Date(l);else throw new Tn.ClientError(`${c} must be a Date, attempt to assign ${l}`);Jr(this)[c]=l},"set");break;case"Bytes":u=a(function(l){if(!(l instanceof Uint8Array||l==null&&o.nullable!==!1))throw new Tn.ClientError(`${c} must be a Buffer or Uint8Array, attempt to assign ${l}`);Jr(this)[c]=l},"set");break;case"Any":case void 0:u=a(function(l){Jr(this)[c]=l},"set");break;default:u=a(function(l){if(!(typeof l=="object"||l==null&&o.nullable!==!1))throw new Tn.ClientError(`${c} must be an object, attempt to assign ${l}`);Jr(this)[c]=l},"set")}_={get(){let l=this[Ot];if(l&&c in l){let f=l[c];if(f?.__op__){let E=this[_e]?.[c];return f.update(E)}return f}let d=this[_e]?.[c];if(d&&typeof d=="object"){let f=_x(d,o);if(f)return l||(l=this[Ot]=Object.create(null)),l[c]=f}return d},set:u,enumerable:!0,configurable:!0}}_.get.isAttribute=!0,n[c]=_,(!(c in r)||Object.getOwnPropertyDescriptor(r,c)?.get?.isAttribute)&&Object.defineProperty(r,c,_)}i("getProperty",function(o){let c=n[o];if(c)return c.get.call(this);let u=this[Ot];return u?.[o]!==void 0?u[o]:this[_e]?.[o]}),i("set",function(o,c){let u=n[o];if(u)return u.set.call(this,c);if(t.sealed)throw new Tn.ClientError("Can not add a property to a sealed table schema");Jr(this)[o]=c}),i("deleteProperty",function(o){Jr(this)[o]=void 0}),i("toJSON",function(){let o=this[Ot],c;for(let _ in o){c||(c=Object.assign({},this[_e]));let l=o[_];if(l?.__op__){let d=c[_];l=l.update(d)}c[_]=l}return Object.keys(this).length>0&&(c||(c=Object.assign({},this[_e])),Object.assign(c,this)),c||this[_e]}),r.get||i("get",r.getProperty),r.delete||i("delete",r.deleteProperty);function i(o,c){Object.defineProperty(r,o,{value:c,configurable:!0})}a(i,"setMethod")}function _x(e,t){let r;switch(e.constructor){case Object:return t?((r=t.TrackedObject)||(t.TrackedObject=r=class{static{a(this,"TrackedObject")}constructor(s){if(s?.[_e])throw new Error("Can not track an already tracked object, check for circular references");this[_e]=s}},BE(r,t)),new r(e)):new ME(e);case Array:let n=new PE(e.length);n[_e]=e;for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=_x(o,t?.elements)),n[s]=o}return n;default:return e}}function td(e){let t=e[Ot],r;for(let s in t){r||(r=Object.assign({},e[_e]));let i=t[s];if(i&&typeof i=="object")if(i.__op__){let o=r[s];i=i.update(o)}else i=td(i);r[s]=i}return Object.keys(e).length>0&&(r||(r=Object.assign({},e[_e])),Object.assign(r,e)),r||e[_e]}function No(e,t=e[Ot]){let r;if(lx.call(e,_e)&&e.constructor===Array&&!Object.isFrozen(e)){r=e;for(let n=0,s=e.length;n<s;n++){let i=e[n];if(i&&typeof i=="object"){let o=No(i);o!==i&&r===e&&(r=e.slice(0)),i=o}r[n]=i}return Object.freeze(r)}for(let n in t){r||(r=Object.assign({},e[_e]));let s=t[n];if(s&&typeof s=="object")if(s.__op__){let i=cA[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=No(s);r[n]=s}return r?Object.freeze(r):lx.call(e,_e)?e[_e]:e}function UE(e){let t=e[_e];if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[yo]||e.length!==t.length)return!0;for(let r=0,n=e.length;r<n;r++){let s=t[r],i=e[r];if(s&&i?.[_e]===s){if(UE(i))return!0}else return!0}}else{let r=e[Ot];if(r&&!t)return!0;for(let n in r){let s=r[n];if(s&&typeof s=="object"){let i=t[n];if(i&&s[_e]===i){if(UE(s))return!0}else return!0}else return!0}}return!1}var Tn,Ot,ME,lx,yo,PE,vE,rd=Re(()=>{bn();Tn=B(ne());CE();Ot=Symbol("own-data");a(Jr,"getChanges");a(BE,"assignTrackedAccessors");a(_x,"trackObject");ME=class{static{a(this,"GenericTrackedObject")}constructor(t){if(t?.[_e])throw new Error("Can not track an already tracked object, check for circular references");this[_e]=t}};BE(ME,{});a(td,"collapseData");lx=Object.prototype.hasOwnProperty;a(No,"deepFreeze");a(UE,"hasChanges");yo=Symbol.for("has-array-changes"),PE=class extends Array{static{a(this,"TrackedArray")}[yo];constructor(t){super(t)}splice(...t){return this[yo]=!0,super.splice(...t)}push(...t){return this[yo]=!0,super.push(...t)}pop(){return this[yo]=!0,super.pop()}unshift(...t){return this[yo]=!0,super.unshift(...t)}shift(){return this[yo]=!0,super.shift()}};PE.prototype.constructor=Array;vE=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var Ip={};Fe(Ip,{CONTEXT:()=>ye,ID_PROPERTY:()=>Le,IS_COLLECTION:()=>Gn,RECORD_PROPERTY:()=>_e,Resource:()=>kt,snake_case:()=>Bne,transformForSelect:()=>xE});function Bne(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function dx(e,t){if(Tl=!1,e==="")return null;if(e=e.slice(1),e.indexOf("/")===-1)return e===""?(Tl=!0,null):(e.startsWith("$")&&(e=parseInt(e,36)),t.coerceId(decodeURIComponent(e)));let r=e.split("/"),n=new lA;for(let s=0;s<r.length;s++){let i=r[s];if(!i&&s===r.length-1){Tl=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}function Xr(e,t){n.reliesOnPrototype=!0;let r=t.hasContent;return n;function n(s,i,o){let c,u,_,l;if(r?(o?(l=i,o=o[ye]||o):i?typeof s=="object"&&s&&(!Array.isArray(s)||typeof s[0]=="object")?(l=s,c=l[this.primaryKey]??null,o=i[ye]||i):l=i:(l=s,c=l[Le]??l[this.primaryKey]??null),c==null&&(_=!0)):i?o=i[ye]||i:s&&typeof s=="object"&&!Array.isArray(s)&&(o=s),c===void 0)if(typeof s=="string")c=s;else if(typeof s=="object"&&s)if(u=s,s[Symbol.iterator]){c=[],_=!0;for(let E of s){if(typeof E=="object"&&E)break;c.push(E)}c.length===0?c=null:(c.length===1&&(c=c[0]),u.slice&&(u=u.slice(c.length,u.length),u.length===0&&(u=null,_=!1)))}else{if(typeof(c=s.url)=="string"){let E=c.indexOf("?");if(E>-1){let S=this.parseQuery(c.slice(E+1));u?u=Object.assign(S,u):u=S,c=c.slice(0,E)}let h=this.parsePath(c,o,u);h?.id!==void 0?(h.query&&(u?u=Object.assign(h.query,u):u=h.query),_=h.isCollection,c=h.id):c=h}c===void 0&&(c=s.id??null,c==null&&(_=!0))}else c=s??null,c==null&&(_=!0);o||(o={});let d;if(u?.ensureLoaded!=null||u?.async||_?(d=Object.assign({},t),u?.ensureLoaded!=null&&(d.ensureLoaded=u.ensureLoaded),u?.async&&(d.async=u.async),_&&(d.isCollection=!0)):d=t,o.transaction){let E=this.getResource(c,o,d);return E.then?E.then(f):f(E)}else return ze(o,()=>{let E=this.getResource(c,o,d);return E.then?E.then(f):f(E)},d);function f(E){if(o.authorize){o.authorize=!1;let h=t.type==="read"?E.allowRead(o.user,u,o):t.type==="update"?E.doesExist?.()===!1?E.allowCreate(o.user,l,o):E.allowUpdate(o.user,l,o):t.type==="create"?E.allowCreate(o.user,l,o):E.allowDelete(o.user,u,o);if(h?.then)return h.then(S=>{if(!S)throw new HE(o.user);return typeof l?.then=="function"?l.then(p=>e(E,u,o,p)):e(E,u,o,l)});if(!h)throw new HE(o.user)}return typeof l?.then=="function"?l.then(h=>e(E,u,o,h)):e(E,u,o,l)}a(f,"authorizeActionOnResource")}}function jr(e,t){let r=new hx.ClientError(`The ${e.constructor.name} does not have a ${t} method implemented`,405);r.allow=[],r.method=t;for(let n of["get","put","post","delete","query","move","copy"])typeof e[n]=="function"&&r.allow.push(n);throw r}function uA(e,t,r){let n=e[_e];if(n){let s=e[Ot];return i=>{let o,c;return e.hasOwnProperty(i)&&typeof(o=e[i])!="function"?o:s&&i in s?s[i]:(c=t?.[i])?c(e,r):n[i]}}else return t?s=>{let i=t[s];return i?i(e,r):e[s]}:s=>e[s]}function xE(e,t){let r=t?.propertyResolvers,n=t[ye],s;if(typeof e=="string")return a(function o(c){return c.then?c.then(o):Array.isArray(c)?c.map(o):uA(c,r,n)(e)},"transform");if(typeof e=="object"){if(e.asArray)return a(function c(u){if(u.then)return u.then(c);if(Array.isArray(u))return u.map(c);let _=[],l=i(uA(u,r,n));for(let d of e)_.push(l(d));return _},"transform");let o=e.forceNulls;return a(function c(u){if(u.then)return u.then(c);if(Array.isArray(u))return u.map(f=>f&&typeof f=="object"?c(f):f);let _={},l=i(uA(u,r,n)),d;for(let f of e){let E=l(f);E===void 0&&o&&(E=null),E?.then?(d||(d=[]),d.push(E.then(h=>_[f.name||f]=h))):_[f.name||f]=E}return d?Promise.all(d).then(()=>_):_},"transform")}else throw new Error("Invalid select argument type "+typeof e);function i(o){return c=>{if(typeof c=="string")return o(c);if(typeof c=="object")if(c.name){s||(s={});let u=s[c.name];if(!u){let l=r[c.name]?.definition?.tableClass;u=s[c.name]=xE(c.select||c,l)}let _=o(c.name);return u(_)}else return o(c);else return c}}a(i,"handleProperty")}var fx,Ex,hx,ye,Le,Gn,_e,vne,kt,HE,Tl,lA,bn=Re(()=>{fx=require("crypto");pc();Ex=require("../index"),hx=B(ne());rd();Zi();Df();ye=Symbol.for("context"),Le=Symbol.for("primary-key"),Gn=Symbol("is-collection"),_e=Symbol("stored-record"),vne={json:"application/json",cbor:"application/cbor",msgpack:"application/x-msgpack",csv:"text/csv"},kt=class{static{a(this,"Resource")}static transactions;constructor(t,r){this[Le]=t;let n=r?.[ye];this[ye]=n!==void 0?n:r||null}static get=Xr(function(t,r,n,s){let i=t.get?.(r);if(i?.then)return i.then(o);return o(i);function o(c){let u;if((u=r?.select)&&c!=null&&!c.selectApplied){let _=xE(u,t.constructor);return typeof c?.map=="function"?c.map(_):_(c)}return c}},{type:"read",letItLinger:!0,ensureLoaded:!0,async:!0});static put=Xr(function(t,r,n,s){if(Array.isArray(s)&&t[Gn]){let i=[],o=n.authorize;for(let c of s){let u=t.constructor,_=u.getResource(c[u.primaryKey],n,{async:!0});_.then?i.push(_.then(l=>l.put(c,n))):i.push(_.put(c,n))}return Promise.all(i)}return t.put?t.put(s,r):jr(t,"put")},{hasContent:!0,type:"update"});static patch=Xr(function(t,r,n,s){return t.patch?t.patch(s,r):jr(t,"patch")},{hasContent:!0,type:"update"});static delete=Xr(function(t,r,n,s){return t.delete?t.delete(r):jr(t,"delete")},{hasContent:!1,type:"delete"});static getNewId(){return(0,fx.randomUUID)()}static create(t,r,n){let s;return t==null?s=this.getNewId():Array.isArray(t)&&typeof t[0]!="object"?s=[...t,this.getNewId()]:typeof t!="object"?s=[t,this.getNewId()]:(s=this.getNewId(),n=r,r=t),n||(n={}),ze(n,()=>{let i=new this(s,n),o=i.update?i.update(r,!0):jr(i,"update");return n.newLocation=s,n.createdResource=!0,o?.then?o.then(()=>s):s})}static invalidate=Xr(function(t,r,n,s){return t.invalidate?t.invalidate(r):jr(t,"delete")},{hasContent:!1,type:"update"});static post=Xr(function(t,r,n,s){return t[Le]!=null&&t.update?.(),t.post(s,r)},{hasContent:!0,type:"create"});static connect=Xr(function(t,r,n,s){return t.connect?t.connect(s,r):jr(t,"connect")},{hasContent:!0,type:"read"});static subscribe=Xr(function(t,r,n,s){return t.subscribe?t.subscribe(r):jr(t,"subscribe")},{type:"read"});static publish=Xr(function(t,r,n,s){return t[Le]!=null&&t.update?.(),t.publish?t.publish(s,r):jr(t,"publish")},{hasContent:!0,type:"create"});static search=Xr(function(t,r,n,s){let i=t.search?t.search(r):jr(t,"search"),o=n.select;if(o&&n.hasOwnProperty("select")&&i!=null&&!i.selectApplied){let c=xE(o,t.constructor);return i.map(c)}return i},{type:"read"});static query=Xr(function(t,r,n,s){return t.search?t.search(s,r):jr(t,"search")},{hasContent:!0,type:"read"});static copy=Xr(function(t,r,n,s){return t.copy?t.copy(s,r):jr(t,"copy")},{type:"create"});static move=Xr(function(t,r,n,s){return t.move?t.move(s,r):jr(t,"move")},{type:"delete"});post(t){if(this[Gn])return this.constructor.create(this[Le],t,this[ye]);jr(this,"post")}static isCollection(t){return t?.[Gn]}static coerceId(t){return t}static parseQuery(t){return Cf(t)}static parsePath(t,r,n){let s=t.indexOf(".");if(s>-1){let o=t.slice(s+1);t=t.slice(0,s);let c=r?.headers&&vne[o];if(c)r.headers.set("accept",c);else if(n)n.property=o;else return{query:{property:o},id:dx(t,this),isCollection:Tl}}let i=dx(t,this);return Tl?{id:i,isCollection:!0}:i}static getResource(t,r,n){let s,i=r[ye],o;typeof r.isCollection=="boolean"&&r.hasOwnProperty("isCollection")?o=r.isCollection:o=n?.isCollection;let c=o&&this.Collection||this;if(i||(i=i===void 0?r:{}),i.transaction){let u;if(i.resourceCache?u=i.resourceCache:u=i.resourceCache=[],u.asMap){let _=u.asMap.get(t);if(s=_?.find(l=>l.constructor===c),s)return s;_||u.asMap.set(t,_=[]),_.push(s=new c(t,i))}else{if(s=u.find(_=>_[Le]===t&&_.constructor===c),s)return s;if(u.push(s=new c(t,i)),u.length>10){let _=new Map;for(let l of u){let d=l[Le],f=_.get(d);f?f.push(l):_.set(d,[l])}i.resourceCache.length=0,i.resourceCache.asMap=_}}}else s=new c(t,i);return o&&(s[Gn]=!0),s}subscribe(t){return new On}connect(t){return t?.subscribe!==!1?this.subscribe?.(t):new On}allowRead(t){return t?.role.permission.super_user}allowUpdate(t){return t?.role.permission.super_user}allowCreate(t){return t?.role.permission.super_user}allowDelete(t){return t?.role.permission.super_user}getId(){return this[Le]}getContext(){return this[ye]}};kt.prototype[ye]=null;(0,Ex._assignPackageExport)("Resource",kt);a(Bne,"snake_case");HE=class extends Error{static{a(this,"AccessError")}constructor(t){t?(super("Unauthorized access to resource"),this.statusCode=403):(super("Must login"),this.statusCode=401)}};a(dx,"pathToId");lA=class extends Array{static{a(this,"MulitPartId")}toString(){return this.join("/")}};a(Xr,"transactional");a(jr,"missingMethod");a(uA,"selectFromObject");a(xE,"transformForSelect")});function Sx(e,t,r,n,s){let i=e.primaryStore.env.path,o=e.primaryStore.tableId,c;s?.crossThreads===!1?(c=px,Hne(e.primaryStore,e.auditStore)):(c=mx,e.primaryStore.env.hasSubscriptionCommitListener||(e.primaryStore.env.hasSubscriptionCommitListener=!0,e.primaryStore.on("committed",()=>{Tx(mx[i])})));let u=c[i]||(c[i]=[]);u.auditStore=e.auditStore,u.lastTxnTime==null&&(u.lastTxnTime=Date.now());let _=u[o];_||(_=u[o]=new Map,_.envs=u,_.tableId=o,_.store=e.primaryStore),t=Ta(t);let l=new dA(r);l.startTime=n;let d=_.get(t);return d?d.push(l):(_.set(t,d=[l]),d.tables=_,d.key=t),l.subscriptions=d,l}function Tx(e){if(!e)return;let t=e.auditStore;try{t.resetReadTxn()}catch(n){throw n.message+=" in "+path,n}let r;for(let{key:n,value:s}of t.getRange({start:e.lastTxnTime,exclusiveStart:!0})){e.lastTxnTime=n;let i=Ut(s),o=e[i.tableId];if(!o)continue;let c=i.recordId,u,_=Ta(i.recordId),l=0;do{let d=o.get(_);if(d){for(let E of d)if(!(l>0&&!(E.includeDescendants&&!(E.onlyChildren&&l>1)))){if(E.startTime>=n){(0,_A.info)("omitting",c,E.startTime,n);continue}try{let h;E.supportsTransactions&&E.txnInProgress!==i.version&&(h=!0,E.txnInProgress||(r?r.push(E):r=[E]),E.txnInProgress=i.version),E.listener(c,i,n,h)}catch(h){console.error(h),(0,_A.info)(h)}}}if(_==null)break;let f=_.lastIndexOf?.("/",_.length-2);f>-1?_=_.slice(0,f):_=null,l++}while(!0)}if(r)for(let n of r)n.txnInProgress=null,n.listener(null,{type:"end_txn"},e.lastTxnTime,!0)}function Hne(e,t){let r=t||e,n=r.env;if(!n.hasAfterCommitListener){n.hasAfterCommitListener=!0;let s=n.path;r.on("aftercommit",({next:i,last:o,txnId:c})=>{let u=px[s];if(!u)return;let _=a(()=>{r.threadLocalWrites||(r.threadLocalWrites=new Float64Array(r.getUserSharedBuffer("last-thread-local-write",new ArrayBuffer(8)))),u.txnTime=r.threadLocalWrites[0]||Date.now(),Tx(u),r.threadLocalWrites[0]=u.lastTxnTime,r.unlock("thread-local-writes")},"acquiredLock");r.attemptLock("thread-local-writes",_)&&_()})}}var _A,mx,px,dA,gx=Re(()=>{_A=B(K());pc();Lu();js();mx=Object.create(null),px=Object.create(null);a(Sx,"addSubscription");dA=class extends On{static{a(this,"Subscription")}listener;subscriptions;startTime;constructor(t){super(),this.listener=t,this.on("close",()=>this.end())}end(){if(this.subscriptions){if(this.subscriptions.splice(this.subscriptions.indexOf(this),1),this.subscriptions.length===0){let t=this.subscriptions.tables,r=this.subscriptions.key;if(t.delete(r),t.size===0){let n=t.envs,s=t.dbi;delete n[s]}}this.subscriptions=null}}toJSON(){return{name:"subscription"}}};a(Tx,"notifyFromTransactionData");a(Hne,"listenToCommits")});var Kg={};Fe(Kg,{coerceType:()=>GE,makeTable:()=>kE,setServerUtilities:()=>Kne,updateResource:()=>FE});function kE(e){let{primaryKey:t,indices:r,tableId:n,tableName:s,primaryStore:i,databasePath:o,databaseName:c,auditStore:u,schemaDefined:_,dbisDB:l,sealed:d}=e,{expirationMS:f,evictionMS:E,audit:h,trackDeletes:S}=e,{attributes:p}=e;p||(p=[]);let T=sm(i,n,u),A=0,g,L,v={},P=Promise.resolve(),k,H,X;for(let Y of p)(Y.assignCreatedTime||Y.name==="__createdtime__")&&(k=Y),(Y.assignUpdatedTime||Y.name==="__updatedtime__")&&(H=Y),Y.expiresAt&&(X=Y),Y.isPrimaryKey&&(v=Y);let z,J=[],me=[],ce=1,de=2,De={},ve={},Mt=864e5,Gl,Fl,Ks,xA=!1,lh,_h,IG=i.getRange({start:!1,end:!1}).constructor,wG=10,CG=6;h&&qA();class We extends kt{static name=s;static primaryStore=i;static auditStore=u;static primaryKey=t;static tableName=s;static indices=r;static audit=h;static databasePath=o;static databaseName=c;static attributes=p;static expirationTimer;static createdTimeProperty=k;static updatedTimeProperty=H;static propertyResolvers;static sources=[];static get expirationMS(){return f}static dbisDB=l;static schemaDefined=_;static sourcedFrom(m,O){O&&(this.sourceOptions=O,(O.expiration||O.eviction||O.scanInterval)&&this.setTTLExpiration(O)),O?.intermediateSource?(m.intermediateSource=!0,this.sources.unshift(m)):this.sources.push(m),L=m.get&&(!m.get.reliesOnPrototype||m.prototype.get);let I=a(D=>{let N=this.sources.slice(0,-1);if(N=N.filter(M=>M[D]&&(!M[D].reliesOnPrototype||M.prototype[D])),N.length>0)if(N.length===1){let M=N[0];return(q,C,x)=>{if(q?.source!==M)return M[D](C,x,q)}}else return(M,q,C)=>{let x=[];for(let G of N){if(M?.source===G)break;x.push(G[D](q,C,M))}return Promise.all(x)}},"getApplyToIntermediateSource"),y=this.sources[this.sources.length-1],b=a(D=>{if(y[D]&&(!y[D].reliesOnPrototype||y.prototype[D]))return(N,M,q)=>{if(!N?.source)return y[D](M,q,N)}},"getApplyToCanonicalSource");return De={put:b("put"),patch:b("patch"),delete:b("delete"),publish:b("publish")},ve={put:I("put"),patch:I("patch"),delete:I("delete"),publish:I("publish"),invalidate:I("invalidate")},(async()=>{let D=!1,N=a(async(M,q)=>{let C=M.value,x=M.table?tt[c][M.table]:We;if(c===qn.SYSTEM_SCHEMA_NAME&&(M.table===qn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME||M.table===qn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME)&&(D=!0),M.id===void 0&&(M.id=C[x.primaryKey],M.id===void 0))throw new Error("Replication message without an id "+JSON.stringify(M));M.source=m;let G=await x.getResource(M.id,q,za);switch(M.type){case"put":return G._writeUpdate(C,!0,za);case"patch":return G._writeUpdate(C,!1,za);case"delete":return G._writeDelete(za);case"publish":return G._writePublish(C,za);case"invalidate":return G.invalidate(za);default:je.error("Unknown operation",M.type,M.id)}},"writeUpdate");try{let M=m.subscribe;M&&S==null&&(S=!0);let q=m.subscribeOnThisThread?m.subscribeOnThisThread((0,wo.getWorkerIndex)()):(0,wo.getWorkerIndex)()===0,C=M&&q&&await m.subscribe?.({crossThreads:!1,inTransactionUpdates:!0,supportsTransactions:!0,omitCurrent:!0});if(C){let x;for await(let G of C)try{if(!(G.type==="transaction"?G.writes[0]:G)){je.error("Bad subscription event",G);continue}if(G.source=m,x)if(G.beginTxn)x.resolve();else{N(G,x);continue}if(G.type==="end_txn")continue;let pe=ze(G,()=>{if(G.type==="transaction"){let ee=[];for(let Ue of G.writes)try{ee.push(N(Ue,G))}catch(ae){throw ae.message+=" writing "+JSON.stringify(Ue)+" of event "+JSON.stringify(G),ae}return Promise.all(ee)}else if(G.type==="define_schema"){let ee=this.attributes.slice(0),Ue;for(let ae of G.attributes)ee.find(Ge=>Ge.name===ae.name)||(ee.push(ae),Ue=!0);Ue&&(ut({table:s,database:c,attributes:ee,origin:"cluster"}),Nl.signalSchemaChange(new Il.SchemaEventMsg(process.pid,qn.OPERATIONS_ENUM.CREATE_TABLE,c,s)))}else return G.beginTxn?(x=G,N(G,G),new Promise(ee=>{x.resolve=ee})):N(G,G)});D&&(await pe,Nl.signalUserChange(new Il.UserEventMsg(process.pid))),G.onCommit&&(pe?.then?pe.then(G.onCommit):G.onCommit())}catch(se){je.error("error in subscription handler",se)}}}catch(M){je.error(M)}})(),this}static getResource(m,O,I){let y=super.getResource(m,O,I);if(m!=null){rc(m);try{if(y.hasOwnProperty(_e))return y;if(typeof m=="object"&&m&&!Array.isArray(m))throw new Error(`Invalid id ${JSON.stringify(m)}`);let b=!I?.async||i.cache?.get(m),D=Rn(O),N=D.getReadTxn();if(N?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");return dh(m,O,{transaction:N},b,M=>{if(M?FE(y,M):y[_e]=null,O.onlyIfCached&&O.noCacheStore){if(!y.doesExist())throw new en.ServerError("Entry is not cached",504)}else if(I?.ensureLoaded){let q=fh(m,M,O,y);if(q)return D?.disregardReadTxn(),y[fA]=!0,hA(q,C=>(FE(y,C),y))}return y})}catch(b){throw b.message.includes("Unable to serialize object")&&(b.message+=": "+JSON.stringify(m)),b}}return y}ensureLoaded(){let m=fh(this[Le],this[Zr],this[ye]);if(m)return this[fA]=!0,hA(m,O=>{this[Zr]=O,this[_e]=O.value,this[bl]=O.version})}static setTTLExpiration(m){if(typeof m=="number")f=m*1e3,E||(E=0);else if(m&&typeof m=="object")f=m.expiration*1e3,E=(m.eviction||0)*1e3,Mt=m.scanInterval*1e3;else throw new Error("Invalid expiration value type");if(f<0)throw new Error("Expiration can not be negative");Mt=Mt||(f+E)/4,hh()}static enableAuditing(m=!0){h=m,m&&qA(),We.audit=m}static coerceId(m){return m===""?null:GE(m,v)}static async dropTable(){if(delete tt[c][s],c===o){for(let m of p)l.remove(We.tableName+"/"+m.name),r[m.name]?.drop();l.remove(We.tableName+"/"),i.drop(),await l.committed}else console.log("legacy dropTable"),await i.close(),await fs.remove(data_path),await fs.remove(data_path===standard_path?data_path+MDB_LOCK_FILE_SUFFIX:path.join(path.dirname(data_path),MDB_LEGACY_LOCK_FILE_NAME));Nl.signalSchemaChange(new Il.SchemaEventMsg(process.pid,qn.OPERATIONS_ENUM.DROP_TABLE,c,s))}get(m){if(typeof m=="string")return this.getProperty(m);if(this[Gn])return this.search(m);if(this[Le]===null){if(m?.conditions)return this.search(m);let O=We.getRecordCount();return{recordCount:O.recordCount,estimatedRecordRange:O.estimatedRange,records:"./",name:s,database:c,attributes:p}}if(m?.property)return this.getProperty(m.property);if(this.doesExist()||m?.ensureLoaded===!1||this[ye]?.returnNonexistent)return this}allowRead(m,O){let I=kl(m);if(I?.read){if(I.isSuperUser)return!0;let y=I.attribute_permissions,b=O?.select;if(y?.length>0||xA&&b){if(O||(O={}),b){let D=y?.length>0&&EA(y,"read");O.select=b.map(N=>{let M=N.name||N;if(!D||D[M]){let q=Ks[M]?.definition?.tableClass;if(q){if(N.name||(N={name:N}),!q.prototype.allowRead.call(null,m,N))return!1;if(!N.select)return N.name}return N}}).filter(Boolean)}else O.select=y.filter(D=>D.read&&!Ks[D.attribute_name]).map(D=>D.attribute_name);return O}else return!0}}allowUpdate(m,O){let I=kl(m);if(I?.update){let y=I.attribute_permissions;if(y?.length>0){let b=EA(y,"update");for(let D in O)if(!b[D])return!1;for(let D of y){let N=D.attribute_name;!D.update&&!(N in O)&&(O[N]=this.getProperty(N))}}return!0}}allowCreate(m,O){if(this[Gn]){let I=kl(m);if(I?.insert){let y=I.attribute_permissions;if(y?.length>0){let b=EA(y,"insert");for(let D in O)if(!b[D])return!1}else return!0}}else return this.allowUpdate(m,{})}allowDelete(m){return kl(m)?.delete}update(m,O){if(!Rn(this[ye]))throw new Error("Can not update a table resource outside of a transaction");if(m===!1)return this;let y;return typeof m=="object"&&m&&(O?(Object.isFrozen(m)&&(m=Object.assign({},m)),this[_e]={},this[Ot]=m):(y=this[Ot],y&&(m=Object.assign(y,m)),this[Ot]=y=m)),this._writeUpdate(this[Ot],O),this}addTo(m,O){if(typeof O=="number"||typeof O=="bigint")this[gl]===Ax?this.set(m,(+this.getProperty(m)||0)+O):(this[gl]||this.update(),this.set(m,new vE(O)));else throw new Error("Can not add a non-numeric value")}subtractFrom(m,O){if(typeof O=="number")return this.addTo(m,-O);throw new Error("Can not subtract a non-numeric value")}invalidate(m){let O=this[ye],I=this[Le];rc(I),Rn(this[ye]).addWrite({key:I,store:i,invalidated:!0,entry:this[Zr],nodeName:this[ye]?.nodeName,before:De.invalidate?.bind(this,O,I),beforeIntermediate:ve.invalidate?.bind(this,O,I),commit:(b,D)=>{if(D?.version>b)return;let N=null;for(let M in r)N||(N={}),N[M]=this.getProperty(M);T(I,N,this[Zr],b,Rl,h,this[ye],0,"invalidate")}})}static evict(m,O,I){let y=this.Source,b;if(!((L||h)&&(!O||(b=i.getEntry(m),!b||!O)||b.version!==I))){if(L){if(i.hasLock(m,b.version))return;let D;for(let N in r)D||(D={}),D[N]=O[N];if(D)return T(m,D,b,I,Al,null,null,0,null,!0)}return i.ifVersion(m,I,()=>{ql(m,O,null)}),h?T(m,null,b,I,Al,null,null,0,null,!0):i.remove(m,I)}}lock(){throw new Error("Not yet implemented")}static operation(m,O){return m.table||=s,m.schema||=c,wx.operation(m,O)}put(m){this.update(m,!0)}patch(m){this.update(m,!1)}_writeUpdate(m,O,I){let y=this[ye],b=Rn(y),D=this[Le];rc(D);let N=this[Zr];this[gl]=O?Ax:Vne;let M={key:D,store:i,entry:N,nodeName:y?.nodeName,validate:q=>{m||(m=this[Ot]),O||m&&UE(this[Ot]===m?this:m)?y?.source||(b.checkOverloaded(),this.validate(m,!O),H&&(m[H.name]=H.type==="Date"?new Date(q):H.type==="String"?new Date(q).toISOString():q),O&&(t&&m[t]!==D&&(m[t]=D),k&&(N?.value?m[k.name]=N?.value[k.name]:m[k.name]=k.type==="Date"?new Date(q):k.type==="String"?new Date(q).toISOString():q),m=No(m))):b.removeWrite(M)},before:O?De.put?()=>De.put(y,D,m):null:De.patch?()=>De.patch(y,D,m):De.put?()=>De.put(y,D,No(this)):null,beforeIntermediate:O?ve.put?()=>ve.put(y,D,m):null:ve.patch?()=>ve.patch(y,D,m):ve.put?()=>ve.put(y,D,No(this)):null,commit:(q,C,x)=>{if(x){if(y&&C?.version>(y.lastModified||0)&&(y.lastModified=C.version),this[Zr]=C,C?.value?.[_e])throw new Error("Can not assign a record to a record, check for circular references");O||(this[_e]=C?.value??null)}this[Ot]=void 0,this[bl]=q;let G=C?.value,se=m;if(this[gl]=0,C?.version>=q)if(h){let ae=C.localTime,Ge=C.version;for(;se&&(ae>q||Ge>=q&&ae>0);){let re=u.get(ae);if(!re)break;let j=Ut(re);if(Ge=j.version,Ge>q){if(j.type==="patch"){let Se=j.getValue(i);se=LE(se,Se)}else if(j.type==="put"||j.type==="delete")return}else if(Ge===q)return;ae=j.previousLocalTime}}else{if(O)return;se=LE(se,G)}let pe;if(O?pe=se:(this[_e]=G,pe=O?se:No(this,se)),this[_e]=pe,pe?.[_e])throw new Error("Can not assign a record to a record, check for circular references");let ee;O||(ee=m),ql(D,G,pe);let Ue=O?"put":"patch";T(D,pe,C,q,0,h,y,y.expiresAt||(f?f+Date.now():0),Ue,!1,ee)}};b.addWrite(M)}async delete(m){if(typeof m=="string")return this.deleteProperty(m);if(this[Gn]){for await(let O of this.search(m))(await We.getResource(O[t],this.getContext(),{ensureLoaded:!1}))._writeDelete(m);return}return this[_e]?this._writeDelete(m):!1}_writeDelete(m){let O=Rn(this[ye]),I=this[Le];rc(I);let y=this[ye];return O.addWrite({key:I,store:i,resource:this,nodeName:y?.nodeName,before:De.delete?.bind(this,y,I),beforeIntermediate:ve.delete?.bind(this,y,I),commit:(b,D,N)=>{let M=D?.value;N&&(y&&D?.version>(y.lastModified||0)&&(y.lastModified=D.version),FE(this,D)),!(D?.version>b)&&(ql(this[Le],M),je.trace("Write delete entry",I,b),h||S?(T(I,null,this[Zr],b,0,h,this[ye],0,"delete"),h||hh()):i.remove(this[Le]))}}),!0}search(m){let O=this[ye],I=Rn(O);if(!m)throw new Error("No query provided");let y=m.conditions;y?y.length===void 0&&(y=y[Symbol.iterator]?Array.from(y):[y]):y=Array.isArray(m)?m:m[Symbol.iterator]?Array.from(m):[],this[Le]&&(y=[{attribute:null,comparator:"prefix",value:this[Le]}].concat(y));let b,D={};function N(j,Se){let Be;switch(Se){case"and":case void 0:if(j.length<1)throw new Error('An "and" operator requires at least one condition');Be=!0;break;case"or":if(j.length<2)throw new Error('An "or" operator requires at least two conditions');break;default:throw new Error("Invalid operator "+Se)}let Vn=Be&&{},Ws;for(let $e of j){if($e.conditions){$e.conditions=N($e.conditions,$e.operator);continue}let Ft=$e[0]??$e.attribute,nn=Ft==null?v:Hs(p,Ft);if(nn){if(Be){let $n=vn(Ft),qt=Vn[$n];qt?(qt.push($e),Ws=!0):Vn[$n]=[$e]}(nn.type||Sg[$e.comparator])&&($e[1]===void 0?$e.value=q($e.value,nn):$e[1]=q($e[1],nn))}else if(Ft!=null)throw(0,en.handleHDBError)(new Error,`${Ft} is not a defined attribute`,404)}if(m.enforceExecutionOrder)return j;if(Ws)for(let $e in Vn){let Ft=Vn[$e],nn=Ft.length;if(nn>1)for(let $n=0;$n<nn;$n++){let qt=Ft[$n];if(qt.comparator==="ge"||qt.comparator==="greater_than_equal")for(let Qs=0;Qs<nn;Qs++){let Bo=Ft[Qs];(Bo.comparator==="le"||Bo.comparator==="less_than_equal")&&(qt.comparator="between",qt.value=[qt.value,Bo.value],j.splice(j.indexOf(Bo),1))}if(qt.comparator==="equals"||!qt.comparator){for(let Qs=0;Qs<nn;Qs++)if(Qs!==$n){let Bo=Ft[Qs];j.splice(j.indexOf(Bo),1)}break}}}return j}a(N,"prepareConditions");function M(j,Se){if(m.enforceExecutionOrder)return j;for(let Be of j)Be.conditions&&(Be.conditions=M(Be.conditions,Be.operator));return j.length>1&&Se!=="or"?(0,Ix.sortBy)(j,wf(We)):j}a(M,"orderConditions");function q(j,Se){return Array.isArray(j)?j.map(Be=>GE(Be,Se)):GE(j,Se)}a(q,"coerceTypedValues");let C=m.operator;(y.length>0||C)&&(y=N(y,C));let x=typeof m.sort=="object"&&m.sort,G;if(x&&C!=="or"){let j=x.attribute;if(b=y.find(Se=>vn(Se.attribute)===vn(j)),!b){let Se=Hs(p,j);if(!Se)throw(0,en.handleHDBError)(new Error,`${Array.isArray(j)?j.join("."):j} is not a defined attribute`,404);if(Se.indexed)b={attribute:j,comparator:"sort"},y.push(b);else if(y.length===0&&!m.allowFullScan)throw(0,en.handleHDBError)(new Error,`${Array.isArray(j)?j.join("."):j} is not indexed and not combined with any other conditions`,404)}b&&(b.descending=!!x.descending)}y=M(y,C),x&&(b&&y[0]===b?x.next&&(G={dbOrderedAttribute:x.attribute,attribute:x.next.attribute,descending:x.next.descending,next:x.next.next}):(b&&y.splice(y.indexOf(b),1),G=x));let se=m.select;if(y.length===0&&(y=[{attribute:t,comparator:"greater_than",value:!0}]),m.explain)return{conditions:y,operator:C,postOrdering:G,selectApplied:!!se};let pe=I.useReadTxn(),ee=Tg(y,C,We,pe,m,O,(j,Se)=>GA(j,se,O,pe,Se),D),Ue=m.ensureLoaded!==!1;G||(ee=re(ee));let ae=We.transformEntryForSelect(se,O,pe,D,Ue,!0),Ge=We.transformToOrderedSelect(ee,se,G,pe,O,ae);function re(j){return m.offset||m.limit!==void 0?j.slice(m.offset,m.limit!==void 0?(m.offset||0)+m.limit:void 0):j}return a(re,"applyOffset"),G&&(Ge=re(Ge)),Ge.onDone=()=>{Ge.onDone=null,I.doneReadTxn()},Ge.selectApplied=!0,Ge.getColumns=()=>{if(se){let j=[];for(let Se of se)Se==="*"?j.push(...p.map(Be=>Be.name)):j.push(Se.name||Se);return j}return p.map(j=>j.name)},Ge}static transformToOrderedSelect(m,O,I,y,b,D){let N=new IG;if(I){m=GA(m,O,y,b,null);let M;N.iterate=function(){let C,x=m[Symbol.asyncIterator]?m[Symbol.asyncIterator]():m[Symbol.iterator](),G,se=I.dbOrderedAttribute,pe,ee,Ue=!0;function ae(re){let j=re.next&&ae(re.next),Se=re.descending;return(Be,Vn)=>{let Ws=Eh(Be,re.attribute,y),$e=Eh(Vn,re.attribute,y),Ft=Se?(0,Co.compareKeys)($e,Ws):(0,Co.compareKeys)(Ws,$e);return Ft===0?j?.(Be,Vn)||0:Ft}}a(ae,"createComparator");let Ge=ae(I);return{async next(){let re;if(C)if(re=C.next(),re.done){if(G)return N.onDone&&N.onDone(),re}else return{value:await D.call(this,re.value)};M=[],pe&&M.push(pe);do if(re=await x.next(),re.done){if(G=!0,M.length)break;return N.onDone&&N.onDone(),re}else{let j=re.value;if(j?.then&&(j=await j),se){let Se=Eh(j,se,y);if(Ue)Ue=!1,ee=Se;else if(Se!==ee){ee=Se,pe=j;break}}M.push(j)}while(!0);return I.isGrouped,M.sort(Ge),C=M[Symbol.iterator](),re=C.next(),re.done?(N.onDone&&N.onDone(),re):{value:await D.call(this,re.value)}},return(){N.onDone&&N.onDone(),x.return()},throw(){N.onDone&&N.onDone(),x.throw()}}};let q=a(C=>{if(typeof O=="object"&&Array.isArray(C.attribute))for(let x=0;x<O.length;x++){let G=O[x],se;if(G.name===C.attribute[0]){for(se=G.sort||(G.sort={});se.next;)se=se.next;se.attribute=C.attribute.slice(1),se.descending=C.descending}else G===C.attribute[0]&&(O[x]=se={name:G,sort:{attribute:C.attribute.slice(1),descending:C.descending}})}C.next&&q(C.next)},"applySortingOnSelect");q(I)}else N.iterate=(m[Symbol.asyncIterator]||m[Symbol.iterator]).bind(m),N=N.map(D);return N}static transformEntryForSelect(m,O,I,y,b,D){if(m&&(m===t||m?.length===1&&m[0]===t)){let C=a(x=>(O?.transaction?.stale&&(O.transaction.stale=!1),x?.key??x),"transform");return m===t?C:m.asArray?x=>[C(x)]:x=>({[t]:C(x)})}let N;b&&L&&!m?.every(C=>{let x;return typeof C=="object"?x=C.name:x=C,r[x]||x===t})&&(N=!0);let M,q=a(function(C){let x;if(O?.transaction?.stale&&(O.transaction.stale=!1),C!=null){if(lh=C,x=C.value||C.deref?.(),!x&&(C.key===void 0||C.deref)){if(C=dh(C.key??C,O,{transaction:I,lazy:m?.length<4},this.isSync,G=>G),C?.then)return C.then(q.bind(this));x=C?.value}if(N&&(C.metadataFlags&(Rl|Al)||C.expiresAt&&C.expiresAt<Date.now())){let G=fh(C.key??C,C,O);if(G?.then)return G.then(q)}}if(x==null)return D?Io.SKIP:x;if(m&&!(m[0]==="*"&&m.length===1)){let G,se=a((ee,Ue)=>{let ae;typeof ee=="object"?ae=ee.name:ae=ee;let Ge=Ks?.[ae],re;if(Ge){let j=y?.[ae];if(j)if(j.hasMappings){let Be=Ge.from?x[Ge.from]:vn(C.key);re=j.get(Be),re||(re=[])}else re=j.fromRecord?.(x);else re=Ge(x,O,C);let Se=a(Be=>{if(Be&&typeof Be=="object"){let Vn=Ge.definition?.tableClass||We;M||(M={});let Ws=M[ae]||(M[ae]=Vn.transformEntryForSelect(ae===ee?null:ee.select||(Array.isArray(ee)?ee:null),O,I,j,b));if(Array.isArray(Be)){let $e=[],Ft=Vn.transformToOrderedSelect(Be,ee.select,typeof ee.sort=="object"&&ee.sort,O,I,Ws)[this.isSync?Symbol.iterator:Symbol.asyncIterator](),nn=a(qt=>{for(;!qt.done;){if(qt?.then)return qt.then(nn);$e.push(qt.value),qt=Ft.next()}Ue($e,ae)},"nextValue"),$n=nn(Ft.next());$n&&(G||(G=[]),G.push($n));return}else if(Be=Ws.call(this,Be),Be?.then){G||(G=[]),G.push(Be.then($e=>Ue($e,ae)));return}}Ue(Be,ae)},"handleResolvedValue");re?.then?(G||(G=[]),G.push(re.then(Se))):Se(re);return}else re=x[ae],re&&typeof re=="object"&&ae!==ee&&(re=We.transformEntryForSelect(ee.select||ee,O,I,null)({value:re}));Ue(re,ae)},"selectAttribute"),pe;if(typeof m=="string")se(m,ee=>{pe=ee});else if(Array.isArray(m))if(m.asArray)pe=[],m.forEach((ee,Ue)=>{ee==="*"?m[Ue]=x:se(ee,ae=>pe[Ue]=ae)});else{pe={};let ee=m.forceNulls;for(let Ue of m)if(Ue==="*")for(let ae in x)pe[ae]=x[ae];else se(Ue,(ae,Ge)=>{ae===void 0&&ee&&(ae=null),pe[Ge]=ae})}else throw new en.ClientError("Invalid select"+m);return G?Promise.all(G).then(()=>pe):pe}return x},"transform");return q}async subscribe(m){if(!u)throw new Error("Can not subscribe to a table without an audit log");h||ut({table:s,database:c,schemaDefined:_,attributes:p,audit:!0}),m||(m={});let O=!m.rawEvents,I=Sx(We,this[Le]??null,function(N,M,q,C){try{let x=M.getValue?.(i,O);if(!x&&M.type==="patch"&&O){let G=i.getEntry(N);G?.version===M.version?x=G.value:x=M.getValue?.(i,!0,q),M.type="put"}this.send({id:N,timestamp:q,value:x,version:M.version,type:M.type,beginTxn:C})}catch(x){je.error(x)}},m.startTime||0,m);this[Gn]&&(I.includeDescendants=!0,m.onlyChildren&&(I.onlyChildren=!0)),m.supportsTransactions&&(I.supportsTransactions=!0);let y=this[Le],b=m.previousCount;b>1e3&&(b=1e3);let D=m.startTime;if(this[Gn]){if(D){if(b)throw new en.ClientError("startTime and previousCount can not be combined for a table level subscription");for(let{key:N,value:M}of u.getRange({start:D,exclusiveStart:!0})){let q=Ut(M);if(q.tableId!==n)continue;let C=q.recordId;if(y==null||yx(y,C)){let x=q.getValue(i,O,N);I.send({id:C,timestamp:N,value:x,version:q.version,type:q.type})}I.startTime=N}}else if(b){let N=[];for(let{key:M,value:q}of u.getRange({start:"z",end:!1,reverse:!0}))try{let C=Ut(q);if(C.tableId!==n)continue;let x=C.recordId;if(y==null||yx(y,x)){let G=C.getValue(i,O,M);if(N.push({id:x,timestamp:M,value:G,version:C.version,type:C.type}),--b<=0)break}}catch(C){je.error("Error getting history entry",M,C)}for(let M=N.length;M>0;)I.send(N[--M]);N[0]&&(I.startTime=N[0].timestamp)}else if(!m.omitCurrent)for(let{key:N,value:M,version:q,localTime:C}of i.getRange({start:y??!1,end:y==null?void 0:[y,Co.MAXIMUM_KEY],versions:!0}))M&&I.send({id:N,timestamp:C,value:M,version:q,type:"put"})}else{b&&!D&&(D=0);let N=this[Zr]?.localTime;if(N===nm&&(i.cache?.delete(y),this[Zr]=i.getEntry(y),je.trace("re-retrieved record",N,this[Zr]?.localTime),N=this[Zr]?.localTime),je.trace("Subscription from",D,"from",y,N),D<N){let M=[],q=N;do{let C=u.get(q);if(C){m.omitCurrent=!0;let x=Ut(C),G=x.getValue(i,O,q);O&&(x.type="put"),M.push({id:y,value:G,timestamp:q,...x}),q=x.previousLocalTime}else break;b&&b--}while(q>D&&b!==0);for(let C=M.length;C>0;)I.send(M[--C]);I.startTime=N}!m.omitCurrent&&this.doesExist()&&I.send({id:y,timestamp:N,value:this,version:this[bl],type:"put"})}return m.listener&&I.on("data",m.listener),I}doesExist(){return!!(this[_e]||this[gl])}publish(m,O){this._writePublish(m,O)}_writePublish(m,O){let I=Rn(this[ye]),y=this[Le]||null;rc(y);let b=this[ye];I.addWrite({key:y,store:i,entry:this[Zr],nodeName:b?.nodeName,validate:()=>{b?.source||(I.checkOverloaded(),this.validate(m))},before:De.publish?.bind(this,b,y,m),beforeIntermediate:ve.publish?.bind(this,b,y,m),commit:(D,N,M)=>{N===void 0&&S&&!h&&hh(),T(y,N?.value??null,N,N?.version||D,0,!0,b,N?.expiresAt,"message",!1,m)}})}validate(m,O){let I,y=a((b,D,N)=>{if(D.type&&b!=null)if(O&&b.__op__&&(b=b.value),D.properties){typeof b!="object"&&(I||(I=[])).push(`Value ${Fn(b)} in property ${N} must be an object${D.type?" ("+D.type+")":""}`);let M=D.properties;for(let q=0,C=M.length;q<C;q++){let x=M[q],G=y(b[x.name],x,N+"."+x.name);G&&(b[x.name]=G)}if(D.sealed&&b!=null&&typeof b=="object")for(let q in b)M.find(C=>C.name===q)||(I||(I=[])).push(`Property ${q} is not allowed within object in property ${N}`)}else switch(D.type){case"Int":(typeof b!="number"||b>>0!==b)&&(I||(I=[])).push(`Value ${Fn(b)} in property ${N} must be an integer (from -2147483648 to 2147483647)`);break;case"Long":(typeof b!="number"||!(Math.floor(b)===b&&Math.abs(b)<=9007199254740992))&&(I||(I=[])).push(`Value ${Fn(b)} in property ${N} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof b!="number"&&(I||(I=[])).push(`Value ${Fn(b)} in property ${N} must be a number`);break;case"ID":typeof b=="string"||b?.length>0&&b.every?.(M=>typeof M=="string")||(I||(I=[])).push(`Value ${Fn(b)} in property ${N} must be a string, or an array of strings`);break;case"String":typeof b!="string"&&(I||(I=[])).push(`Value ${Fn(b)} in property ${N} must be a string`);break;case"Boolean":typeof b!="boolean"&&(I||(I=[])).push(`Value ${Fn(b)} in property ${N} must be a boolean`);break;case"Date":if(!(b instanceof Date)){if(typeof b=="string"||typeof b=="number")return new Date(b);(I||(I=[])).push(`Value ${Fn(b)} in property ${N} must be a Date`)}break;case"BigInt":if(typeof b!="bigint"){if(typeof b=="string"||typeof b=="number")return BigInt(b);(I||(I=[])).push(`Value ${Fn(b)} in property ${N} must be a bigint`)}break;case"Bytes":b instanceof Uint8Array||(I||(I=[])).push(`Value ${Fn(b)} in property ${N} must be a Buffer or Uint8Array`);break;case"array":if(Array.isArray(b)){if(D.elements)for(let M=0,q=b.length;M<q;M++){let C=b[M],x=y(C,D.elements,N+"[*]");x&&(b[M]=x)}}else(I||(I=[])).push(`Value ${Fn(b)} in property ${N} must be a Buffer or Uint8Array`);break}D.nullable===!1&&b==null&&(I||(I=[])).push(`Property ${N} is required (and not does not allow null values)`)},"validateValue");for(let b=0,D=p.length;b<D;b++){let N=p[b];if(!N.relationship&&(!O||N.name in m)){let M=y(m[N.name],N,N.name);M&&(m[N.name]=M)}}if(d)for(let b in m)p.find(D=>D.name===b)||(I||(I=[])).push(`Property ${b} is not allowed`);if(I)throw new en.ClientError(I.join(". "))}getUpdatedTime(){return this[bl]}wasLoadedFromSource(){return L?!!this[fA]:void 0}static async addAttributes(m){let O=p.slice(0);for(let I of m){if(!I.name)throw new en.ClientError("Attribute name is required");if(I.name.match(/[`/]/))throw new en.ClientError("Attribute names cannot include backticks or forward slashes");O.push(I)}return ut({table:s,database:c,schemaDefined:_,attributes:O}),We.indexingOperation}static async removeAttributes(m){let O=p.filter(I=>!m.includes(I.name));return ut({table:s,database:c,schemaDefined:_,attributes:O}),We.indexingOperation}static getRecordCount(m){let O=i.getStats().entryCount,I=5e3,y=1e3,b;O>I&&!m?.exactCount&&(b=y);let D=0;for(let{value:N}of i.getRange({start:!0,lazy:!0,limit:b}))N!=null&&D++;if(b){let N=D;D=0;for(let{value:Ue}of i.getRange({start:"\uFFFF",reverse:!0,lazy:!0,limit:b}))Ue!=null&&D++;let M=b*2,q=(D+N)/M,C=Math.pow((D-N+1)/b/2,2)+q*(1-q)/M,x=Math.max(Math.sqrt(C)*O,1),G=Math.round(q*O),se=Math.max(G-1.96*x,0),pe=Math.min(G+1.96*x,O),ee=Math.pow(10,Math.round(Math.log10(x)));return ee>G&&(ee=ee/10),D=Math.round(G/ee)*ee,{recordCount:D,estimatedRange:[Math.round(se),Math.round(pe)]}}return{recordCount:D}}static updatedAttributes(){Ks=this.propertyResolvers={$id:(m,O,I)=>({value:I.key}),$updatedtime:(m,O,I)=>I.version,$record:(m,O,I)=>I?{value:m}:m};for(let m of this.attributes){m.resolve=null;let O=m.relationship;if(O)if(m.indexed&&console.error("A relationship property can not be directly indexed, (but you may want to index the foreign key attribute)"),xA=!0,O.to)m.elements?.definition?(Ks[m.name]=m.resolve=(I,y,b)=>{let D=I[O.from?O.from:t],N=m.elements.definition.tableClass;return b?Da({attribute:O.to,value:D},Rn(y).getReadTxn(),!1,N,!1).asArray:N.search([{attribute:O.to,value:D}],y).asArray},m.set=()=>{throw new Error("Setting a one-to-many relationship property is not supported")},m.resolve.definition=m.elements.definition,O.from&&(m.resolve.from=O.from)):console.error(`The one-to-many/many-to-many relationship property "${m.name}" in table "${s}" must have an array type referencing a table as the elements`);else if(O.from){let I=m.definition||m.elements?.definition;I?(Ks[m.name]=m.resolve=(y,b,D)=>{let N=y[O.from];if(N!==void 0){if(m.elements){let M,q=N.map(C=>{let x=D?I.tableClass.primaryStore.getEntry(C,{transaction:Rn(b).getReadTxn()}):I.tableClass.get(C,b);return x?.then&&(M=!0),x});return O.filterMissing?M?Promise.all(q).then(C=>C.filter(Nx)):q.filter(Nx):M?Promise.all(q):q}return D?I.tableClass.primaryStore.getEntry(N,{transaction:Rn(b).getReadTxn()}):I.tableClass.get(N,b)}},m.set=(y,b)=>{if(Array.isArray(b)){let D=b.map(N=>N[Le]||N[I.tableClass.primaryKey]);y[O.from]=D}else{let D=b[Le]||b[I.tableClass.primaryKey];y[O.from]=D}},m.resolve.definition=m.definition||m.elements?.definition,m.resolve.from=O.from):console.error(`The relationship property "${m.name}" in table "${s}" must be a type that references a table`)}else console.error(`The relationship directive on "${m.name}" in table "${s}" must use either "from" or "to" arguments`)}BE(this,this)}static async deleteHistory(m=0){let O;for(let{key:I,value:y}of u.getRange({start:0,end:m}))await Ol(),Ut(y).tableId===n&&(O=u.remove(I));await O}static async*getHistory(m=0,O=1/0){for(let{key:I,value:y}of u.getRange({start:m,end:O})){await Ol();let b=Ut(y);b.tableId===n&&(yield{id:b.recordId,localTime:I,version:b.version,type:b.type,value:b.getValue(i,!0,I),user:b.user})}}static async getHistoryOfRecord(m){let O=[];if(m==null)throw new Error("An id is required");let I=i.getEntry(m);if(!I)return O;let y=I.localTime;if(!y)throw new Error("The entry does not have a local audit time");let b=0;do{await Ol();let D=u.get(y);if(D){let N=Ut(D);O.push({id:N.recordId,localTime:y,version:N.version,type:N.type,value:N.getValue(i,!0,y),user:N.user}),y=N.previousLocalTime}else break}while(b<1e3&&y);return O.reverse()}static cleanup(){z?.remove()}}We.updatedAttributes();let DG=We.prototype;return DG[kne]=!0,f&&We.setTTLExpiration(f/1e3),X&&LG(),We;function ql(Y,m,O){let I;for(let y in r){let b=r[y],D=b.isIndexing,N=O?.[y],M=m?.[y];if(N===M&&!D)continue;I=!0;let q=b.indexNulls,C=(0,yl.getIndexedValues)(N,q),x=(0,yl.getIndexedValues)(M,q);if(x?.length>0){let G=new Set(x);if(C=C?C.filter(se=>{if(G.has(se))G.delete(se);else return!0}):[],x=Array.from(G),(x.length>0||C.length>0)&&Rx){let se=x.concat(C).map(pe=>({key:pe,value:Y}));b.prefetch(se,bx)}for(let se=0,pe=x.length;se<pe;se++)b.remove(x[se],Y)}else C?.length>0&&Rx&&b.prefetch(C.map(G=>({key:G,value:Y})),bx);if(C)for(let G=0,se=C.length;G<se;G++)b.put(C[G],Y)}return I}a(ql,"updateIndices");function rc(Y){switch(typeof Y){case"number":return!0;case"string":if(Y.length<659)return!0;if(Y.length>Ox)throw new Error("Primary key size is too large: "+Y.length);break;case"object":if(Y===null)return!0;break;case"bigint":if(Y<2n**64n&&Y>-(2n**64n))return!0;break;default:throw new Error("Invalid primary key type: "+typeof Y)}if((0,Co.writeKey)(Y,$ne,0)>Ox)throw new Error("Primary key size is too large: "+Y.length);return!0}a(rc,"checkValidId");function dh(Y,m,O,I,y){let b=a(()=>{if(m?.transaction?.stale&&(m.transaction.stale=!1),O.transaction?.isDone)return y(null,Y);let D=i.getEntry(Y,O);return D&&m&&(D?.version>(m.lastModified||0)&&(m.lastModified=D.version),D?.localTime&&!m.lastRefreshed&&(m.lastRefreshed=D.localTime)),y(D,Y)},"whenPrefetched");return I?b():ce>0?(ce--,b()):new Promise((D,N)=>{ce===0?(ce--,i.prefetch([Y],()=>{M(),q()})):(J.push(Y),me.push(q),J.length>CG&&(ce--,M()));function M(){if(J.length>0){let C=me;i.prefetch(J,()=>{ce===-1?M():ce++;for(let x of C)x()}),J=[],me=[],de>2&&de--}else ce=de,de<wG&&de++}a(M,"prefetch");function q(){try{D(b())}catch(C){N(C)}}a(q,"load")})}a(dh,"loadLocalRecord");function kl(Y){if(!Y?.role)return;let m=Y.role.permission;if(m.super_user)return Yne;let O=m[c],I,y=O?.tables;if(y)return y[s];if(c==="data"&&(I=m[s])&&!I.tables)return I}a(kl,"getTablePermissions");function fh(Y,m,O,I){if(L){let y;if(O.noCache?y=!0:(m?(!m.value||m.metadataFlags&(Rl|Al)||m.expiresAt&&m.expiresAt<Date.now())&&(y=!0):y=!0,Qr(!y,"cache-hit",s)),y){let b=FA(Y,m,O).then(D=>(D?.value?.[_e]&&je.error("Can not assign a record with a record property"),O&&(D?.version>(O.lastModified||0)&&(O.lastModified=D.version),O.lastRefreshed=Date.now()),D));if(O?.onlyIfCached||m?.value&&I?.allowStaleWhileRevalidate?.(m,Y)){if(b.catch(D=>je.warn(D)),O?.onlyIfCached&&!I.doesExist())throw new en.ServerError("Entry is not cached",504);return}else return b}}}a(fh,"ensureLoadedFromSource");function Rn(Y){let m=Y?.transaction;if(m){if(!m.lmdbDb)return m.lmdbDb=i,m;do{if(m.lmdbDb?.path===i.path)return m;let O=m.next;if(!O)return m=m.next=new ji,m.lmdbDb=i,m;m=O}while(!0)}else return new Z_}a(Rn,"txnForContext");function Eh(Y,m,O){if(!Y)return;lh=Y;let I=Y.value||Y.deref?.()||(lh=i.getEntry(Y.key))?.value;if(typeof m=="object"){let b=Ks,D=I;for(let N=0,M=m.length;N<M;N++){let q=m[N],C=b?.[q];D=C&&D?C(D,O,!0)?.value:D?.[q],b=C?.definition?.tableClass?.propertyResolvers}return D}let y=Ks[m];return y?y(I,O):I[m]}a(Eh,"getAttributeValue");function GA(Y,m,O,I,y){let b=y?.length,D={transaction:I,lazy:b>0||typeof m=="string"||m?.length<4,alwaysPrefetch:!0},N;function M(q,C){let x=q?.value;if(!x)return Io.SKIP;for(let G=0;G<b;G++)if(!N?.includes(G)&&!y[G](x,q))return Io.SKIP;return C!==void 0&&(q.key=C),q}if(a(M,"processEntry"),b>0||!Y.hasEntries){let q=Y.map(C=>{if(N=null,typeof C=="object"&&C?.key!==void 0)return b>0?M(C):C;if(C==null)return Io.SKIP;for(let x=0;x<b;x++){let se=y[x].idFilter;if(se){if(!se(C))return Io.SKIP;N||(N=[]),N.push(x)}}return dh(C,O,D,!1,M)});return Array.isArray(Y)&&(q=q.filter(C=>C!==Io.SKIP)),q.hasEntries=!0,q}return Y}a(GA,"transformToEntries");async function FA(Y,m,O){let I=m?.metadataFlags,y=m?.version,b,D;if(!i.attemptLock(Y,y,()=>{clearTimeout(D);let C=i.getEntry(Y);!C||!C.value||C.metadataFlags&(Rl|Al)?b(FA(Y,i.getEntry(Y),O)):b(C)}))return new Promise(C=>{b=C,D=setTimeout(()=>{i.unlock(Y,y)},qne)});let N=m?.value,M={requestContext:O,replacingRecord:N,replacingVersion:y,source:null,resourceCache:O?.resourceCache},q=O?.responseHeaders;return new Promise((C,x)=>{let G;hA(ze(M,async se=>{let pe=performance.now(),ee,Ue,ae;try{for(let Se of We.sources)if(Se.get&&(!Se.get.reliesOnPrototype||Se.prototype.get)&&(M.source=Se,ee=await Se.get(Y,M),ee))break;ae=I&Rl;let re=M.lastModified||ae&&y;Ue=ae||re>y||!N,re||(re=(0,yl.getNextMonotonicTime)());let j=performance.now()-pe;if(Wr(j,"cache-resolution",s),q&&xT(q,"Server-Timing",`cache-resolve;dur=${j.toFixed(2)}`,!0),se.timestamp=re,f&&!M.expiresAt&&(M.expiresAt=Date.now()+f),ee){if(typeof ee!="object")throw new Error("Only objects can be cached and stored in tables");typeof ee.toJSON=="function"&&(ee=ee.toJSON()),t&&ee[t]!==Y&&(ee[t]=Y)}G=!0,C({version:re,value:ee})}catch(re){re.message+=` while resolving record ${Y} for ${s}`,N&&((re.code==="ECONNRESET"||re.code==="ECONNREFUSED"||re.code==="EAI_AGAIN")&&!O?.mustRevalidate||O?.staleIfError&&(re.statusCode===500||re.statusCode===502||re.statusCode===503||re.statusCode===504))?(C({version:y,value:N}),je.trace(re.message,"(returned stale record)")):x(re),M.transaction.abort();return}if(O?.noCacheStore){M.transaction.abort();return}Rn(M).addWrite({key:Y,store:i,entry:m,nodeName:"source",commit:(re,j)=>{if(j?.version!==y)return;let Se=ql(Y,N,ee);ee?(ve.put?.(M,Y,ee),T(Y,ee,j,re,0,h&&Ue||null,M,M.expiresAt,"put",!!ae)):(ve.delete?.(M,Y),h||S?T(Y,null,j,re,0,h&&Ue||null,M,0,"delete",!!ae):i.remove(Y,y))}})}),()=>{i.unlock(Y,y)},se=>{i.unlock(Y,y),G&&je.error("Error committing cache update",se)})})}a(FA,"getFromSource");function hh(){if(Mt!==Gl&&(Gl=Mt,(0,wo.getWorkerIndex)()===(0,wo.getWorkerCount)()-1)){if(Fl&&clearTimeout(Fl),!Mt)return;let Y=new Date;Y.setMonth(0),Y.setDate(1),Y.setHours(0),Y.setMinutes(0),Y.setSeconds(0);let m=Math.ceil((Date.now()-Y.getTime())/Mt)*Mt+Y.getTime(),O=a(I=>{je.trace(`Scheduled next cleanup scan at ${new Date(I)}ms`),Fl=setTimeout(()=>P=P.then(async()=>{if(O(Math.max(I+Mt,Date.now())),i.rootStore.status!=="open"){clearTimeout(Fl);return}let y=50,b=new Array(y),D=0;je.trace(`Starting cleanup scan for ${s}`);try{let N=0;for(let{key:M,value:q,version:C,expiresAt:x}of i.getRange({start:!1,snapshot:!1,versions:!0,lazy:!0})){let G;q===null&&!h&&C+Fne<Date.now()?G=i.remove(M,C):x&&x+E<Date.now()&&(G=We.evict(M,q,C),N++),G&&(await b[D],b[D]=G.catch(se=>{je.error("Cleanup error",se)}),++D>=y&&(D=0)),await Ol()}je.trace(`Finished cleanup scan for ${s}, evicted ${N} entries`)}catch(N){je.trace(`Error in cleanup scan for ${s}:`,N)}}),Math.min(I-Date.now(),2147483647)).unref()},"startNextTimer");O(m)}}a(hh,"scheduleCleanup");function qA(){z=u?.addDeleteRemovalCallback(n,Y=>{let m=i.getEntry(Y);m?.value===null&&i.remove(Y,m.version)})}a(qA,"addDeleteRemoval");function LG(){(0,wo.getWorkerIndex)()===0&&setInterval(async()=>{if(!_h){_h=!0;try{let Y=X.name,m=r[Y];if(!m)throw new Error(`expiresAt attribute ${X} must be indexed`);for(let O of m.getRange({start:!0,values:!1,end:Date.now(),snapshot:!1})){for(let I of m.getValues(O)){let y=i.getEntry(I);y?.value?y.value[Y]<Date.now()&&We.evict(I,y.value,y.version):i.ifVersion(I,y?.version,()=>m.remove(O,I))}await Ol()}}catch(Y){je.error("Error in evicting old records",Y)}finally{_h=!1}}},Gne).unref()}a(LG,"runRecordExpirationEviction")}function EA(e,t){let r=e.attr_object||(e.attr_object={}),n=r[t];if(n)return n;n=r[t]=Object.create(null);for(let s of e)n[s.attribute_name]=s[t];return n}function bx(){}function Kne(e){wx=e}function GE(e,t){let r=t?.type;return e===null?e:e===""&&r&&r!=="String"&&r!=="Any"?null:r==="Int"||r==="Long"?e==="null"?null:parseInt(e):r==="Float"?e==="null"?null:parseFloat(e):r==="BigInt"?e==="null"?null:BigInt(e):r==="Boolean"?e==="true"?!0:e==="false"?!1:e:r==="Date"?isNaN(e)?e==="null"?null:(Wne.test(e)||(e+="Z"),new Date(e)):new Date(+e):!r||r==="Any"?(0,qE.autoCast)(e):e}function yx(e,t){if(e==null)return!0;if(!Array.isArray(t))return e===t;if(Array.isArray(e)){let r=e.length;if(e[r-1]===null&&r--,t.length>=r){for(let n=0;n<r;n++)if(t[n]!==e[n])return!1;return!0}return!1}else if(t[0]===e)return!0}function hA(e,t,r){return e?.then?e.then(t,r):t(e)}function FE(e,t){e[Zr]=t,e[_e]=t?.value??null,e[bl]=t?.version}function Nx(e){return e!=null}function Fn(e){try{return JSON.stringify(e)}catch{return e}}var qn,Io,yl,Ix,wl,en,Nl,Il,je,Co,wo,qE,xne,wx,Gne,Fne,Rx,qne,bl,kne,Zr,gl,Ax,Vne,fA,za,Rl,Al,$ne,Ox,Yne,ppe,Wne,Ol,$f=Re(()=>{qn=B(U()),Io=require("lmdb"),yl=B(Mr()),Ix=require("lodash");bn();zp();wl=B(te());gx();en=B(ne()),Nl=B(Rs()),Il=B(Dn());Ae();Df();je=B(K());rd();Zi();Co=require("ordered-binary"),wo=B(ct());js();qE=B(Q());bc();vs();CE();Mu();xne=new Uint8Array(9);xne[8]=192;Gne=6e4,Fne=864e5;wl.initSync();Rx=wl.get(qn.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),qne=1e4,bl=Symbol.for("version"),kne=Symbol.for("incremental-update"),Zr=Symbol("entry"),gl=Symbol("is-saving"),Ax=1,Vne=2,fA=Symbol("loaded-from-source"),za={isNotification:!0,ensureLoaded:!1},Rl=1,Al=8,$ne=Buffer.allocUnsafeSlow(8192),Ox=1978,Yne={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},ppe=(0,qE.convertToMS)(wl.get(qn.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;a(kE,"makeTable");a(EA,"attributesAsObject");a(bx,"noop");a(Kne,"setServerUtilities");Wne=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;a(GE,"coerceType");a(yx,"isDescendantId");Ol=a(()=>new Promise(setImmediate),"rest");a(hA,"when");a(FE,"updateResource");a(Nx,"exists");a(Fn,"stringify")});var qe={};Fe(qe,{database:()=>Zc,databases:()=>tt,dropDatabase:()=>eS,dropTableMeta:()=>jne,getDatabases:()=>Er,getDefaultCompression:()=>Wd,getTables:()=>Qne,onUpdatedTable:()=>yR,readMetaDb:()=>Cl,resetDatabases:()=>yu,table:()=>ut,tables:()=>Ur});function Qne(){return WE||Er(),Ur||{}}function Er(){if(WE)return tt;WE=!0,ja=new Map;let e=(0,Et.getHdbBasePath)()&&(0,Ze.join)((0,Et.getHdbBasePath)(),Lt.DATABASES_DIR_NAME),t=(0,Et.get)(Lt.CONFIG_PARAMS.DATABASES)||{};if(process.env.SCHEMAS_DATA_PATH&&(t.data={path:process.env.SCHEMAS_DATA_PATH}),e=process.env.STORAGE_PATH||(0,Et.get)(Lt.CONFIG_PARAMS.STORAGE_PATH)||e&&((0,tn.existsSync)(e)?e:(0,Ze.join)((0,Et.getHdbBasePath)(),Lt.LEGACY_DATABASES_DIR_NAME)),!!e){if((0,tn.existsSync)(e))for(let r of(0,tn.readdirSync)(e,{withFileTypes:!0})){let n=(0,Ze.basename)(r.name,".mdb");r.isFile()&&(0,Ze.extname)(r.name).toLowerCase()===".mdb"&&!t[n]?.path&&Cl((0,Ze.join)(e,r.name),null,n)}if((0,tn.existsSync)((0,Xa.getBaseSchemaPath)())){for(let r of(0,tn.readdirSync)((0,Xa.getBaseSchemaPath)(),{withFileTypes:!0}))if(!r.isFile()){let n=(0,Ze.join)((0,Xa.getBaseSchemaPath)(),r.name),s=(0,Ze.join)((0,Xa.getTransactionAuditStoreBasePath)(),r.name);for(let i of(0,tn.readdirSync)(n,{withFileTypes:!0}))if(i.isFile()&&(0,Ze.extname)(i.name).toLowerCase()===".mdb"){let o=(0,Ze.join)(s,i.name);Cl((0,Ze.join)(n,i.name),(0,Ze.basename)(i.name,".mdb"),r.name,o,!0)}}}if(t)for(let r in t){let n=t[r],s=n.path;if((0,tn.existsSync)(s))for(let o of(0,tn.readdirSync)(s,{withFileTypes:!0}))o.isFile()&&(0,Ze.extname)(o.name).toLowerCase()===".mdb"&&Cl((0,Ze.join)(s,o.name),(0,Ze.basename)(o.name,".mdb"),r);let i=n.tables;if(i)for(let o in i){let c=i[o],u=(0,Ze.join)(c.path,(0,Ze.basename)(o+".mdb"));(0,tn.existsSync)(u)&&Cl(u,o,r,null,!0)}}for(let r in tt){let n=ja.get(r);if(n){let s=tt[r];r.includes("delete")&&gn.trace(`defined tables ${Array.from(n.keys())}`);for(let i in s)n.has(i)||(gn.trace(`delete table class ${i}`),delete s[i])}else if(delete tt[r],r==="data"){for(let s in Ur)delete Ur[s];delete Ur[zE]}}return ja=null,tt}}function yu(){WE=!1;for(let[,e]of Di)e.needsDeletion=!0;Er();for(let[e,t]of Di)t.needsDeletion&&!e.endsWith("system.mdb")&&(t.close(),Di.delete(e));return tt}function Cl(e,t,r=SA,n,s){let i=new mA.default(e,!1);try{let o=Di.get(e);o?o.needsDeletion=!1:(o=(0,$E.open)(i),Di.set(e,o));let c=new Do.default(!1),u=o.dbisDb||(o.dbisDb=o.openDB(VE.INTERNAL_DBIS_NAME,c)),_=o.auditStore;_||(n?(0,tn.existsSync)(n)&&(i.path=n,_=(0,$E.open)(i),_.isLegacy=!0):_=wE(o));let l=Mx(r),d=l[zE],f=new Map;for(let{key:E,value:h}of u.getRange({start:!1})){let[S,p]=E.toString().split("/");p===""?p=h.name:p||(p=S,S=t,h.name||(h.name=p,h.indexed=!h.is_hash_attribute)),d?.add(S);let T=f.get(S);T||f.set(S,T={attributes:[]}),(p==null||h.is_hash_attribute)&&(T.primary=h),p!=null&&T.attributes.push(h),Object.defineProperty(h,"key",{value:E,configurable:!0})}for(let[E,h]of f){let{attributes:S,primary:p}=h;if(!p){for(let J of S)if(J.is_hash_attribute||J.isPrimaryKey){p=J;break}if(!p){gn.fatal(`Unable to find a primary key attribute on table ${E}, with attributes: ${JSON.stringify(S)}`);continue}}let T=l[E],A={},g=[],L,v,P=typeof p.audit=="boolean"?p.audit:(0,Et.get)(Lt.CONFIG_PARAMS.LOGGING_AUDITLOG),k=p.trackDeletes,H=p.expiration,X=p.eviction,z=p.sealed;if(T)A=T.indices,g=T.attributes,T.schemaVersion++;else{L=p.tableId,L?L>=(u.get(Ja)||0)&&u.putSync(Ja,L+1):(p.tableId=L=u.get(Ja),L||(L=1),u.putSync(Ja,L+1),u.putSync(p.key,p));let J=new Do.default(!p.is_hash_attribute,p.is_hash_attribute);if(J.compression=p.compression,J.compression){let me=(0,Et.get)(Lt.CONFIG_PARAMS.STORAGE_COMPRESSION_THRESHOLD)||Lx;J.compression.threshold=me}v=a_(o.openDB(p.key,J)),v.rootStore=o,v.tableId=L}for(let J of S){J.attribute=J.name;try{if(!J.is_hash_attribute&&(J.indexed||J.attribute&&!J.name)){if(!A[J.name]){let ce=new Do.default(!J.is_hash_attribute,J.is_hash_attribute);A[J.name]=o.openDB(J.key,ce),A[J.name].indexNulls=J.indexNulls}let me=g.find(ce=>ce.name===J.name);me?g.splice(g.indexOf(me),1,J):g.push(J)}}catch(me){gn.error("Error trying to update attribute",J,g,A,me)}}if(!T){T=Ux(l,E,kE({primaryStore:v,auditStore:_,audit:P,sealed:z,expirationMS:H&&H*1e3,evictionMS:X&&X*1e3,trackDeletes:k,tableName:E,tableId:L,primaryKey:p.name,databasePath:s?r+"/"+E:r,databaseName:r,indices:A,attributes:S,schemaDefined:p.schemaDefined,dbisDB:u})),T.schemaVersion=1;for(let J of TA)J(T)}}return o}catch(o){throw o.message+=` opening database ${e}`,o}}function Mx(e){let t=tt[e];if(t||(e==="data"?t=tt[e]=Ur:e==="system"?Object.defineProperty(tt,"system",{value:t=Object.create(null),configurable:!0}):t=tt[e]=Object.create(null)),ja&&!ja.has(e)){let r=new Set;t[zE]=r,ja.set(e,r)}return t}function Ux(e,t,r){return e[t]=r,r}function Zc({database:e,table:t}){e||(e=SA),Er();let r=Mx(e),n=(0,Ze.join)((0,Et.getHdbBasePath)(),Lt.DATABASES_DIR_NAME),s=(0,Et.get)(Lt.CONFIG_PARAMS.DATABASES)||{};process.env.SCHEMAS_DATA_PATH&&(s.data={path:process.env.SCHEMAS_DATA_PATH});let i=t&&s[e]?.tables?.[t]?.path;n=i||s[e]?.path||process.env.STORAGE_PATH||(0,Et.get)(Lt.CONFIG_PARAMS.STORAGE_PATH)||((0,tn.existsSync)(n)?n:(0,Ze.join)((0,Et.getHdbBasePath)(),Lt.LEGACY_DATABASES_DIR_NAME));let o=(0,Ze.join)(n,(i?t:e)+".mdb"),c=Di.get(o);if(!c){let u=new mA.default(o,!1);c=(0,$E.open)(u),Di.set(o,c)}return c}async function eS(e){if(!tt[e])throw new Error("Schema does not exist");let t=tt[e];for(let r in t){let s=t[r].primaryStore.rootStore;Di.delete(s.path),s.status==="open"&&(await s.close(),await QE.remove(s.path))}if(e==="data"){for(let r in Ur)delete Ur[r];delete Ur[zE]}delete tt[e]}function ut({table:e,database:t,expiration:r,eviction:n,scanInterval:s,attributes:i,audit:o,sealed:c,trackDeletes:u,schemaDefined:_,origin:l}){t||(t=SA);let d=Zc({database:t,table:e}),f=tt[t],E=f?.[e];if(d.status==="closed")throw new Error(`Can not use a closed data store for ${e}`);let h,S,p,T;_==null&&(_=!0);let A=new Do.default(!1);for(let H of i)H.attribute&&!H.name?(H.name=H.attribute,H.indexed=!0):H.attribute=H.name,H.expiresAt&&(H.indexed=!0);let g,L;if(E){if(h=E.primaryKey,E.primaryStore.rootStore.status==="closed")throw new Error(`Can not use a closed data store from ${e} class`);E.attributes.splice(0,E.attributes.length,...i)}else{let H=d.auditStore;H||(H=wE(d)),S=i.find(me=>me.isPrimaryKey)||{},h=S.name,S.is_hash_attribute=!0,S.schemaDefined=_,S.compression=Wd(),u&&(S.trackDeletes=!0),o=S.audit=typeof o=="boolean"?o:(0,Et.get)(Lt.CONFIG_PARAMS.LOGGING_AUDITLOG),r&&(S.expiration=r),n&&(S.eviction=n),typeof c=="boolean"&&(S.sealed=c),l&&(S.origins?S.origins.includes(l)||S.origins.push(l):S.origins=[l]),gn.trace(`${e} table loading, opening primary store`);let X=new Do.default(!1,!0);X.compression=S.compression;let z=e+"/",J=a_(d.openDB(z,X));J.rootStore=d,T=d.dbisDb=d.openDB(VE.INTERNAL_DBIS_NAME,A),J.tableId=T.get(Ja),J.tableId||(J.tableId=1),T.putSync(Ja,J.tableId+1),S.tableId=J.tableId,E=Ux(f,e,kE({primaryStore:J,auditStore:H,audit:o,sealed:c,trackDeletes:u,expirationMS:r&&r*1e3,evictionMS:n&&n*1e3,primaryKey:h,tableName:e,tableId:J.tableId,databasePath:t,databaseName:t,indices:{},attributes:i,schemaDefined:_,dbisDB:T})),E.schemaVersion=1,g=!0,k(),T.put(z,S)}p=E.indices,T=T||(d.dbisDb=d.openDB(VE.INTERNAL_DBIS_NAME,A)),E.dbisDB=T;let v=[];for(let{key:H,value:X}of T.getRange({start:!0})){let[z,J]=H.toString().split("/");if(J===""&&(J=X.name),J){if(z!==e)continue}else J=z;if(!i.find(ce=>ce.name===J)?.indexed&&X.indexed&&!X.isPrimaryKey){k(),g=!0,T.remove(H);let ce=E.indices[z];ce&&v.push(ce)}}let P=[];try{for(let H of i||[]){if(H.relationship)continue;let X=e+"/"+(H.name||"");Object.defineProperty(H,"key",{value:X,configurable:!0});let z=T.get(X);if(H.isPrimaryKey){if(z=z||T.get(X=e+"/")||{},o!==E.audit||c!==c||(+r||void 0)!==(+z.expiration||void 0)||(+n||void 0)!==(+z.eviction||void 0)){let me=Object.assign({},z);typeof o=="boolean"&&(o&&E.enableAuditing(o),me.audit=o),r&&(me.expiration=+r),n&&(me.eviction=+n),c!==void 0&&(me.sealed=c),g=!0,k(),T.put(X,me)}continue}z?.attribute&&!z.name&&(z.indexed=!0);let J=!z||z.type!==H.type||z.indexed!==H.indexed||z.nullable!==H.nullable||JSON.stringify(z.attributes)!==JSON.stringify(H.attributes)||JSON.stringify(z.elements)!==JSON.stringify(H.elements);if(H.indexed){let me=new Do.default(!0,!1),ce=d.openDB(X,me);(J||z.indexingPID&&z.indexingPID!==process.pid||z.restartNumber<Dl.workerData?.restartNumber)&&(g=!0,k(),z=T.get(X),(J||z.indexingPID&&z.indexingPID!==process.pid||z.restartNumber<Dl.workerData?.restartNumber)&&(g=!0,H.indexNulls===void 0&&(H.indexNulls=!0),E.primaryStore.getStats().entryCount>0&&(H.lastIndexedKey=z?.lastIndexedKey||!1,H.indexingPID=process.pid,ce.isIndexing=!0,Object.defineProperty(H,"dbi",{value:ce}),P.push(H))),T.put(X,H)),z?.indexNulls&&H.indexNulls===void 0&&(H.indexNulls=!0),ce.indexNulls=H.indexNulls,p[H.name]=ce}else J&&(g=!0,k(),T.put(X,H))}}finally{L&&L()}if(g&&(E.schemaVersion++,E.updatedAttributes()),gn.trace(`${e} table loading, running index`),P.length>0||v.length>0?E.indexingOperation=Xne(E,P,v):g&&YE.signalSchemaChange(new KE.SchemaEventMsg(process.pid,"schema-change",E.databaseName,E.tableName)),E.origin=l,g)for(let H of TA)H(E,l!=="cluster");return(r||n||s)&&E.setTTLExpiration({expiration:r,eviction:n,scanInterval:s}),gn.trace(`${e} table loaded`),E;function k(){L||d.transactionSync(()=>({then(H){L=H}}))}a(k,"startTxn")}async function Xne(e,t,r){try{let n=e.schemaVersion;await YE.signalSchemaChange(new KE.SchemaEventMsg(process.pid,"schema-change",e.databaseName,e.tableName));let s;for(let u of r)s=u.drop();let i,o=0,c=t.length;if(await new Promise(u=>setImmediate(u)),c>0){let u=0;for(let{key:_,value:l,version:d}of e.primaryStore.getRange({start:t[0].lastIndexedKey,lazy:c<4,versions:!0,snapshot:!1}))if(l){if(u++,s=e.primaryStore.ifVersion(_,d,()=>{for(let f=0;f<c;f++){let E=t[f],h=E.name,S=(0,Cx.getIndexedValues)(l[h]);if(S)for(let p=0,T=S.length;p<T;p++)E.dbi.put(S[p],_)}}),s.then(()=>u--,f=>{u--,gn.error(f)}),Dl.workerData&&Dl.workerData.restartNumber!==Dx.restartNumber&&(i=!0),++o%100===0||i){for(let f of t)f.lastIndexedKey=_,e.dbisDB.put(f.key,f);if(i)return}u>zne?await s:u>Jne&&await new Promise(f=>setImmediate(f))}for(let _ of t)delete _.lastIndexedKey,delete _.indexingPID,_.dbi.isIndexing=!1,s=e.dbisDB.put(_.key,_)}await s,await YE.signalSchemaChange(new KE.SchemaEventMsg(process.pid,"indexing-finished",e.databaseName,e.tableName))}catch(n){gn.error("Error in indexing",n)}}function jne({table:e,database:t}){let r=Zc({database:t,table:e}),n=[],s=r.dbisDb;for(let i of s.getKeys({start:e+"/",end:e+"0"}))n.push(s.remove(i));return Promise.all(n)}function yR(e){TA.push(e)}function Wd(){let e=(0,Et.get)(Lt.CONFIG_PARAMS.STORAGE_COMPRESSION),t=(0,Et.get)(Lt.CONFIG_PARAMS.STORAGE_COMPRESSION_DICTIONARY),r=(0,Et.get)(Lt.CONFIG_PARAMS.STORAGE_COMPRESSION_THRESHOLD)||Lx,n={startingOffset:32};return t&&(n.dictionary=QE.readFileSync(t)),r&&(n.threshold=r),e&&n}var Et,VE,$E,Ze,tn,Xa,Do,mA,Lt,QE,pA,Cx,YE,KE,Dl,gn,Dx,SA,zE,Lx,Ur,tt,Ja,TA,WE,Di,ja,zne,Jne,Ae=Re(()=>{Et=B(te()),VE=B(at()),$E=require("lmdb"),Ze=require("path"),tn=require("fs"),Xa=B(Qe());$f();Do=B(yc()),mA=B(Nc()),Lt=B(U()),QE=B(require("fs-extra")),pA=require("../index"),Cx=B(Mr()),YE=B(Rs()),KE=B(Dn()),Dl=require("worker_threads"),gn=B(K()),Dx=B(ct());js();bc();SA="data",zE=Symbol("defined-tables"),Lx=((0,Et.get)(Lt.CONFIG_PARAMS.STORAGE_PAGESIZE)||4096)-60;(0,Et.initSync)();Ur=Object.create(null),tt=Object.create(null);(0,pA._assignPackageExport)("databases",tt);(0,pA._assignPackageExport)("tables",Ur);Ja=Symbol.for("next-table-id"),TA=[],Di=new Map;a(Qne,"getTables");a(Er,"getDatabases");a(yu,"resetDatabases");a(Cl,"readMetaDb");a(Mx,"ensureDB");a(Ux,"setTable");a(Zc,"database");a(eS,"dropDatabase");a(ut,"table");zne=1e3,Jne=10;a(Xne,"runIndexing");a(jne,"dropTableMeta");a(yR,"onUpdatedTable");a(Wd,"getDefaultCompression")});var Q=R((Npe,Wx)=>{"use strict";var Li=require("path"),xx=require("fs-extra"),wr=K(),Px=require("fs-extra"),JE=require("os"),Zne=require("net"),ese=require("recursive-iterator"),ot=U(),tse=gO(),vx=require("papaparse"),XE=require("moment"),{inspect:rse}=require("util"),Bx=require("is-number"),ype=require("lodash"),nse=require("minimist"),sse=require("https"),ise=require("http"),{hdb_errors:jE}=ne(),ose=/^((\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d:[0-5]\d\.\d+([+-][0-2]\d:[0-5]\d|Z))|(\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d:[0-5]\d([+-][0-2]\d:[0-5]\d|Z))|(\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d([+-][0-2]\d:[0-5]\d|Z)))$/,Gx=require("util").promisify(setTimeout),ase=100,cse=5,use="",lse=4,Hx={true:!0,TRUE:!0,FALSE:!1,false:!1,undefined:null,null:null,NULL:null,NaN:NaN};Wx.exports={isEmpty:rn,isEmptyOrZeroLength:ds,arrayHasEmptyValues:fse,arrayHasEmptyOrZeroLengthValues:Ese,buildFolderPath:hse,isBoolean:Fx,errorizeMessage:_se,stripFileExtension:pse,autoCast:Sse,autoCastJSON:qx,autoCastJSONDeep:RA,removeDir:Tse,compareVersions:gse,isCompatibleDataVersion:Rse,escapeRawValue:Ase,unescapeValue:Ose,stringifyProps:bse,timeoutPromise:Nse,isClusterOperation:wse,getClusterUser:Dse,checkGlobalSchemaTable:Cse,getHomeDir:Vx,getPropsFilePath:yse,promisifyPapaParse:Lse,removeBOM:$x,createEventPromise:Mse,checkProcessRunning:Use,checkSchemaTableExist:Pse,checkSchemaExists:Yx,checkTableExists:Kx,getStartOfTomorrowInSeconds:vse,getLimitKey:Bse,isObject:mse,isNotEmptyAndHasValue:dse,autoCasterIsNumberCheck:kx,backtickASTSchemaItems:Hse,isPortTaken:Ise,createForkArgs:xse,autoCastBoolean:Gse,async_set_timeout:Gx,getTableHashAttribute:Fse,doesSchemaExist:qse,doesTableExist:kse,stringifyObj:Vse,ms_to_time:$se,changeExtension:Yse,getEnvCliRootPath:AA,noBootFile:Kse,httpRequest:Wse,transformReq:Qse,convertToMS:zse,PACKAGE_ROOT:ot.PACKAGE_ROOT};function _se(e){return e instanceof Error?e:new Error(e)}a(_se,"errorizeMessage");function rn(e){return e==null}a(rn,"isEmpty");function dse(e){return!rn(e)&&(e||e===0||e===""||Fx(e))}a(dse,"isNotEmptyAndHasValue");function ds(e){return rn(e)||e.length===0||e.size===0}a(ds,"isEmptyOrZeroLength");function fse(e){if(rn(e))return!0;for(let t=0;t<e.length;t++)if(rn(e[t]))return!0;return!1}a(fse,"arrayHasEmptyValues");function Ese(e){if(ds(e))return!0;for(let t=0;t<e.length;t++)if(ds(e[t]))return!0;return!1}a(Ese,"arrayHasEmptyOrZeroLengthValues");function hse(...e){try{return e.join(Li.sep)}catch{console.error(e)}}a(hse,"buildFolderPath");function Fx(e){return rn(e)?!1:e===!0||e===!1}a(Fx,"isBoolean");function mse(e){return rn(e)?!1:typeof e=="object"}a(mse,"isObject");function pse(e){return ds(e)?use:e.slice(0,-lse)}a(pse,"stripFileExtension");function Sse(e){return rn(e)||e===""||typeof e!="string"?e:Hx[e]!==void 0?Hx[e]:kx(e)===!0?Number(e):ose.test(e)?new Date(e):e}a(Sse,"autoCast");function qx(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}a(qx,"autoCastJSON");function RA(e){if(e&&typeof e=="object"){if(Array.isArray(e))for(let t=0,r=e.length;t<r;t++){let n=e[t],s=RA(n);s!==n&&(e[t]=s)}else for(let t in e){let r=e[t],n=RA(r);n!==r&&(e[t]=n)}return e}else return qx(e)}a(RA,"autoCastJSONDeep");function kx(e){if(e.startsWith("0.")&&Bx(e))return!0;let t=e.toUpperCase().includes("E");return!!((e!=="0"&&e.startsWith("0"))===!1&&t===!1&&Bx(e))}a(kx,"autoCasterIsNumberCheck");async function Tse(e){if(ds(e))throw new Error(`Directory path: ${e} does not exist`);try{await Px.emptyDir(e),await Px.remove(e)}catch(t){throw wr.error(`Error removing files in ${e} -- ${t}`),t}}a(Tse,"removeDir");function gse(e,t){if(ds(e)){wr.info("Invalid current version sent as parameter.");return}if(ds(t)){wr.info("Invalid upgrade version sent as parameter.");return}let r,n=/(\.0+)+$/,s=e.version?e.version:e,i=t.version?t.version:t,o=s.replace(n,"").split("."),c=i.replace(n,"").split("."),u=Math.min(o.length,c.length);for(let _=0;_<u;_++)if(r=parseInt(o[_],10)-parseInt(c[_],10),r)return r;return o.length-c.length}a(gse,"compareVersions");function Rse(e,t,r=!1){let n=e.toString().split("."),s=t.toString().split(".");return n[0]===s[0]&&(!r||n[1]===s[1])}a(Rse,"isCompatibleDataVersion");function Ase(e){if(rn(e))return e;let t=String(e);return t==="."?ot.UNICODE_PERIOD:t===".."?ot.UNICODE_PERIOD+ot.UNICODE_PERIOD:t.replace(ot.FORWARD_SLASH_REGEX,ot.UNICODE_FORWARD_SLASH)}a(Ase,"escapeRawValue");function Ose(e){if(rn(e))return e;let t=String(e);return t===ot.UNICODE_PERIOD?".":t===ot.UNICODE_PERIOD+ot.UNICODE_PERIOD?"..":String(e).replace(ot.ESCAPED_FORWARD_SLASH_REGEX,"/")}a(Ose,"unescapeValue");function bse(e,t){if(rn(e))return wr.info("Properties object is null"),"";let r="";return e.each(function(n,s){try{if(t&&t[n]){let i=t[n];for(let o of i)r+=";"+o+JE.EOL}!ds(n)&&n[0]===";"?r+=" "+n+s+JE.EOL:ds(n)||(r+=n+"="+s+JE.EOL)}catch{wr.error(`Found bad property during upgrade with key ${n} and value: ${s}`)}}),r}a(bse,"stringifyProps");function Vx(){let e;try{e=JE.homedir()}catch{e=process.env.HOME}return e||(e="~/"),e}a(Vx,"getHomeDir");function yse(){let e=Li.join(Vx(),ot.HDB_HOME_DIR_NAME,ot.BOOT_PROPS_FILE_NAME);return xx.existsSync(e)||(e=Li.join(__dirname,"../","hdb_boot_properties.file")),e}a(yse,"getPropsFilePath");function Nse(e,t){let r,n;return n=new Promise(function(s){r=setTimeout(function(){s(t)},e)}),{promise:n,cancel:function(){clearTimeout(r)}}}a(Nse,"timeoutPromise");async function Ise(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let n=Zne.createServer().once("error",s=>{s.code==="EADDRINUSE"?t(!0):r(s)}).once("listening",()=>n.once("close",()=>t(!1)).close()).listen(e)})}a(Ise,"isPortTaken");function wse(e){try{return ot.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){wr.error(`Error checking operation against cluster ops ${t}`)}return!1}a(wse,"isClusterOperation");function Cse(e,t){let r=(Ae(),ie(qe)).getDatabases();if(!r[e])return jE.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e);if(!r[e][t])return jE.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(Cse,"checkGlobalSchemaTable");function Dse(e,t){if(rn(t)){wr.warn("No CLUSTERING_USER defined, clustering disabled");return}if(rn(e)||ds(e)){wr.warn("No users to search.");return}let r;try{let n=e.get(t);n&&n.role.permission.cluster_user===!0&&n.active===!0&&(r=n)}catch(n){wr.error(`unable to find cluster_user due to: ${n.message}`);return}if(r===void 0){wr.warn(`CLUSTERING_USER: ${t} not found or is not active.`);return}return r}a(Dse,"getClusterUser");function Lse(){vx.parsePromise=function(e,t,r){return new Promise(function(n,s){vx.parse(e,{header:!0,transformHeader:$x,chunk:t.bind(null,s),skipEmptyLines:!0,transform:r,dynamicTyping:!1,error:s,complete:n})})}}a(Lse,"promisifyPapaParse");function $x(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}a($x,"removeBOM");function Mse(e,t,r){return new Promise(n=>{t.once(e,s=>{let i=r;wr.info(`Got cluster status event response: ${rse(s)}`);try{i.cancel()}catch{wr.error("Error trying to cancel timeout.")}n(s)})})}a(Mse,"createEventPromise");async function Use(e){let t=!0,r=0;do await Gx(ase*r++),(await tse.findPs(e)).length>0&&(t=!1);while(t&&r<cse);if(t)throw new Error(`process ${e} was not started`)}a(Use,"checkProcessRunning");function Pse(e,t){let r=Yx(e);if(r)return r;let n=Kx(e,t);if(n)return n}a(Pse,"checkSchemaTableExist");function Yx(e){let{getDatabases:t}=(Ae(),ie(qe));if(!t()[e])return jE.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(Yx,"checkSchemaExists");function Kx(e,t){let{getDatabases:r}=(Ae(),ie(qe));if(!r()[e][t])return jE.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(Kx,"checkTableExists");function vse(){let e=XE().utc().add(1,ot.MOMENT_DAYS_TAG).startOf(ot.MOMENT_DAYS_TAG).unix(),t=XE().utc().unix();return e-t}a(vse,"getStartOfTomorrowInSeconds");function Bse(){return XE().utc().format("DD-MM-YYYY")}a(Bse,"getLimitKey");function Hse(e){try{let t=new ese(e);for(let{node:r}of t)r&&(r.columnid&&typeof r.columnid!="string"&&(r.columnid=r.columnid.toString()),r.columnid&&!r.columnid.startsWith("`")&&(r.columnid_orig=r.columnid,r.columnid=`\`${r.columnid}\``),r.tableid&&!r.tableid.startsWith("`")&&(r.tableid_orig=r.tableid,r.tableid=`\`${r.tableid}\``),r.databaseid&&!r.databaseid.startsWith("`")&&(r.databaseid_orig=r.databaseid,r.databaseid=`\`${r.databaseid}\``),r.as&&typeof r.as=="string"&&!r.as.startsWith("[")&&(r.as_orig=r.as,r.as=`\`${r.as}\``))}catch(t){wr.error("Got an error back ticking items."),wr.error(t)}}a(Hse,"backtickASTSchemaItems");function xse(e){return[e]}a(xse,"createForkArgs");function Gse(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(Gse,"autoCastBoolean");function Fse(e,t){let{getDatabases:r}=(Ae(),ie(qe)),n=r()[e]?.[t];return n?.primaryKey||n?.hash_attribute}a(Fse,"getTableHashAttribute");function qse(e){let{getDatabases:t}=(Ae(),ie(qe));return t()[e]!==void 0}a(qse,"doesSchemaExist");function kse(e,t){let{getDatabases:r}=(Ae(),ie(qe));return r()[e]?.[t]!==void 0}a(kse,"doesTableExist");function Vse(e){try{return JSON.stringify(e)}catch{return e}}a(Vse,"stringifyObj");function $se(e){let t=XE.duration(e),r=t.seconds()>0?t.seconds()+"s":"",n=t.minutes()>0?t.minutes()+"m ":"",s=t.hours()>0?t.hours()+"h ":"",i=t.days()>0?t.days()+"d ":"";return(t.years()>0?t.years()+"y ":"")+i+s+n+r}a($se,"ms_to_time");function Yse(e,t){let r=Li.basename(e,Li.extname(e));return Li.join(Li.dirname(e),r+t)}a(Yse,"changeExtension");function AA(){if(process.env[ot.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return process.env[ot.CONFIG_PARAMS.ROOTPATH.toUpperCase()];let e=nse(process.argv);if(e[ot.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return e[ot.CONFIG_PARAMS.ROOTPATH.toUpperCase()]}a(AA,"getEnvCliRootPath");var gA;function Kse(){if(gA)return gA;let e=AA();if(AA()&&xx.pathExistsSync(Li.join(e,ot.HDB_CONFIG_FILE)))return gA=!0,!0}a(Kse,"noBootFile");function Wse(e,t){let r;return e.protocol==="http:"?r=ise:r=sse,new Promise((n,s)=>{let i=r.request(e,o=>{o.setEncoding("utf8");let c={body:"",headers:o.headers};o.on("data",u=>{c.body+=u}),o.on("end",()=>{n(c)})});i.on("error",o=>{s(o)}),i.write(JSON.stringify(t)),i.end()})}a(Wse,"httpRequest");function Qse(e){if(!e.schema&&!e.database){e.schema=ot.DEFAULT_DATABASE_NAME;return}e.database&&(e.schema=e.database)}a(Qse,"transformReq");function zse(e){let t=0;if(typeof e=="number"&&(t=e),typeof e=="string")switch(t=parseFloat(e),e.slice(-1)){case"M":t*=86400*30;break;case"D":case"d":t*=86400;break;case"H":case"h":t*=3600;break;case"m":t*=60;break}return t*1e3}a(zse,"convertToMS")});var te=R((wpe,jx)=>{"use strict";var OA=require("fs-extra"),Lo=require("path"),Qx=require("os"),Jse=require("properties-reader"),Ml=K(),Ll=Q(),ue=U(),ZE=dr(),Xse="Error initializing environment manager",eh="BOOT_PROPS_FILE_PATH",zx=!1,jse={[ue.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[ue.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[ue.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},Ys={};jx.exports={BOOT_PROPS_FILE_PATH:eh,getHdbBasePath:Zse,setHdbBasePath:eie,get:Jx,initSync:rie,setProperty:Me,initTestEnvironment:sie,setCloneVar:nie};function Zse(){return Ys[ue.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(Zse,"getHdbBasePath");function eie(e){Ys[ue.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(eie,"setHdbBasePath");function Jx(e){let t=ZE.getConfigValue(e);return t===void 0?Ys[e]:t}a(Jx,"get");function Me(e,t){jse[e]&&(Ys[e]=t),ZE.updateConfigObject(e,t)}a(Me,"setProperty");function tie(){let e;try{e=Ll.getPropsFilePath(),OA.accessSync(e,OA.constants.F_OK|OA.constants.R_OK),zx=!0;let t=Jse(e);return Ys[ue.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(ue.HDB_SETTINGS_NAMES.INSTALL_USER),Ys[ue.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(ue.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),Ys[eh]=e,!0}catch{return Ml.trace(`Environment manager found no properties file at ${e}`),!1}}a(tie,"doesPropFileExist");function rie(e=!1){try{(zx||tie()||Ll.noBootFile())&&!Xx&&(ZE.initConfig(e),Ys[ue.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=ZE.getConfigValue(ue.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){Ml.error(Xse),Ml.error(t),console.error(t),process.exit(1)}}a(rie,"initSync");var Xx=!1;function nie(e){Xx=e}a(nie,"setCloneVar");function sie(e={}){try{let{keep_alive_timeout:t,headers_timeout:r,server_timeout:n,https_enabled:s,cors_enabled:i,cors_accesslist:o,local_studio_on:c}=e,u=Lo.join(__dirname,"../../","unitTests");Ys[eh]=Lo.join(u,"hdb_boot_properties.file"),Me(ue.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,Lo.join(u,"settings.test")),Me(ue.HDB_SETTINGS_NAMES.INSTALL_USER,Qx.userInfo()?Qx.userInfo().username:void 0),Me(ue.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),Me(ue.HDB_SETTINGS_NAMES.LOG_PATH_KEY,Lo.join(u,"envDir","log")),Me(ue.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),Me(ue.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),Me(ue.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),Me(ue.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,Lo.join(u,"envDir")),Me(ue.CONFIG_PARAMS.STORAGE_PATH,Lo.join(u,"envDir")),s&&(Me(ue.CONFIG_PARAMS.HTTP_SECUREPORT,Jx(ue.CONFIG_PARAMS.HTTP_PORT)),Me(ue.CONFIG_PARAMS.HTTP_PORT,null)),Me(ue.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,!!s),Me(ue.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),Me(ue.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,Ll.isEmpty(i)?!1:i),Me(ue.CONFIG_PARAMS.HTTP_CORS,Ll.isEmpty(i)?!1:i),Me(ue.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),Me(ue.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),Me(ue.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),Me(ue.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),Me(ue.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,Lo.resolve(__dirname,"../../unitTests/server/fastifyRoutes/custom_functions")),Me(ue.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,Ll.isEmpty(c)?!1:c),o&&(Me("CORS_ACCESSLIST",o),Me(ue.CONFIG_PARAMS.HTTP_CORSACCESSLIST,o)),n&&(Me(ue.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,n),Me(ue.CONFIG_PARAMS.HTTP_TIMEOUT,n)),t&&(Me(ue.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),Me(ue.CONFIG_PARAMS.HTTP_KEEPALIVETIMEOUT,t)),r&&(Me(ue.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),Me(ue.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${eh}. Please check your boot props and settings files`;Ml.fatal(r),Ml.error(t)}}a(sie,"initTestEnvironment")});var Nt=R((vpe,hG)=>{"use strict";var Gt=te();Gt.initSync();var iie=require("fs-extra"),oie=require("semver"),vl=require("path"),{monotonicFactory:aie}=require("ulidx"),eG=aie(),cie=require("util"),tG=require("child_process"),uie=cie.promisify(tG.exec),lie=tG.spawn,zt=nt(),we=U(),th=Q(),kn=K(),rh=gs(),_ie=od(),Ul=dr(),{broadcast:die,onMessageByType:fie,getWorkerIndex:Eie}=ct(),{isMainThread:rG}=require("worker_threads"),{Encoder:hie,decode:IA}=require("msgpackr"),nG=new hie,{isEmpty:vo}=th,sG=un(),Dpe=48*36e11;rG&&fie(we.ITC_EVENT_TYPES.RESTART,()=>{Cr=void 0,Po=void 0});var{connect:mie,StorageType:pie,RetentionPolicy:Sie,AckPolicy:wA,DeliverPolicy:CA,DiscardPolicy:Tie,NatsConnection:Lpe,JetStreamManager:Mpe,JetStreamClient:Upe,StringCodec:Ppe,JSONCodec:gie,createInbox:DA,headers:Rie,ErrorCode:Zx}=require("nats"),{PACKAGE_ROOT:Aie}=U(),Oie=lu(),{recordAction:bie}=(vs(),ie(Zu)),iG=gie(),yie="clustering",Nie=Oie.engines[zt.NATS_SERVER_NAME],Iie=vl.join(Aie,"dependencies"),NA=vl.join(Iie,`${process.platform}-${process.arch}`,zt.NATS_BINARY_NAME),bA,yA,Pl,Mo,Uo;hG.exports={runCommand:oG,checkNATSServerInstalled:wie,createConnection:LA,getConnection:Bl,getJetStreamManager:Hl,getJetStream:cG,getNATSReferences:Es,getServerList:Die,createLocalStream:MA,listStreams:uG,deleteLocalStream:Lie,getServerConfig:Za,listRemoteStreams:Mie,viewStream:Uie,viewStreamIterator:Pie,publishToStream:vie,request:xie,reloadNATS:UA,reloadNATSHub:Gie,reloadNATSLeaf:Fie,extractServerName:Hie,requestErrorHandler:qie,createLocalTableStream:fG,createTableStreams:$ie,purgeTableStream:EG,purgeSchemaTableStreams:Yie,getStreamInfo:Kie,updateLocalStreams:Qie,closeConnection:Cie,getJsmServerName:nh,addNatsMsgHeader:lG,clearClientCache:aG,updateRemoteConsumer:kie,createConsumer:_G,updateConsumerIterator:Vie};async function oG(e,t=void 0){let{stdout:r,stderr:n}=await uie(e,{cwd:t});if(n)throw new Error(n.replace(`
31
31
  `,""));return r.replace(`
32
32
  `,"")}a(oG,"runCommand");async function wie(){try{await iie.access(NA)}catch{return!1}let e=await oG(`${NA} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return oie.eq(t,Nie)}a(wie,"checkNATSServerInstalled");async function LA(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let o=await sG.getClusterUser();if(vo(o))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=o.username,r=o.decrypt_hash}kn.trace("create nats connection called");let i=await mie({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:Gt.get(we.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:Gt.get(we.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:Gt.get(we.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),kn.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(o=>{o&&kn.error("Error with Nats client connection, connection closed",o),aG()}),i}a(LA,"createConnection");function aG(){Cr=void 0,Mo=void 0,Uo=void 0,Po=void 0}a(aG,"clearClientCache");async function Cie(){Cr&&(await Cr.drain(),Cr=void 0,Mo=void 0,Uo=void 0,Po=void 0)}a(Cie,"closeConnection");var Cr,Po;async function Bl(){return Po||(Po=LA(Gt.get(we.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),Cr=await Po),Cr||Po}a(Bl,"getConnection");async function Hl(){if(Mo)return Mo;vo(Cr)&&await Bl();let{domain:e}=Za(we.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(vo(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return Mo=await Cr.jetstreamManager({domain:e,timeout:6e4}),Mo}a(Hl,"getJetStreamManager");async function cG(){if(Uo)return Uo;vo(Cr)&&await Bl();let{domain:e}=Za(we.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(vo(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return Uo=Cr.jetstream({domain:e,timeout:6e4}),Uo}a(cG,"getJetStream");async function Es(){let e=Cr||await Bl(),t=Mo||await Hl(),r=Uo||await cG();return{connection:e,jsm:t,js:r}}a(Es,"getNATSReferences");async function Die(e){let t=Gt.get(we.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await sG.getClusterUser(),s=await LA(t,r,n),i=DA(),o=s.subscribe(i),c=[],u,_=(async()=>{for await(let l of o){let d=iG.decode(l.data);d.response_time=Date.now()-u,c.push(d)}})();return u=Date.now(),await s.publish("$SYS.REQ.SERVER.PING.VARZ",void 0,{reply:i}),await s.publish("$SYS.REQ.SERVER.PING",void 0,{reply:i}),await s.flush(),await th.async_set_timeout(e),await o.drain(),await s.close(),await _,c}a(Die,"getServerList");async function MA(e,t){let{jsm:r}=await Es(),n=Gt.get(we.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Gt.get(we.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=Gt.get(we.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:pie.File,retention:Sie.Limits,subjects:t,discard:Tie.Old,max_msgs:s,max_bytes:i,max_age:n})}a(MA,"createLocalStream");async function uG(){let{jsm:e}=await Es(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}a(uG,"listStreams");async function Lie(e){let{jsm:t}=await Es();await t.streams.delete(e)}a(Lie,"deleteLocalStream");async function Mie(e){let{connection:t}=await Es(),r=[],n=DA(),s=t.subscribe(n),i=(async()=>{for await(let o of s)r.push(iG.decode(o.data))})();return await t.publish(`$JS.${e}.API.STREAM.LIST`,void 0,{reply:n}),await t.flush(),await s.drain(),await i,r}a(Mie,"listRemoteStreams");async function Uie(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Es(),i=eG(),o={durable_name:i,ack_policy:wA.Explicit};t&&(o.deliver_policy=CA.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),u=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];let _=[];for await(let l of u){let d=IA(l.data),f={nats_timestamp:l.info.timestampNanos,nats_sequence:l.info.streamSequence,entry:d};if(l.headers&&(f.origin=l.headers.get(zt.MSG_HEADERS.ORIGIN)),_.push(f),l.ack(),l.info.pending===0)break}return await c.delete(),_}a(Uie,"viewStream");async function*Pie(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Es(),i=eG(),o={durable_name:i,ack_policy:wA.Explicit};t&&(o.deliver_policy=CA.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),u=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];for await(let _ of u){let l=IA(_.data);l[0]||(l=[l]);for(let d of l){let f={nats_timestamp:_.info.timestampNanos,nats_sequence:_.info.streamSequence,entry:d};_.headers&&(f.origin=_.headers.get(zt.MSG_HEADERS.ORIGIN)),yield f}if(_.ack(),_.info.pending===0)break}await c.delete()}a(Pie,"viewStreamIterator");async function vie(e,t,r,n){kn.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=lG(n,r);let{js:s}=await Es(),i=await nh(),o=`${e}.${i}`,c=n instanceof Uint8Array?n:nG.encode(n);try{kn.trace(`publishToStream publishing to subject: ${o}`),bie(c.length,"bytes-sent",e,n.operation,"replication"),await s.publish(o,c,{headers:r})}catch(u){if(u.code&&u.code.toString()==="503")return dG(async()=>{try{await s.publish(o,c,{headers:r})}catch{if(u.code&&u.code.toString()==="503"){kn.trace(`publishToStream creating stream: ${t}`);let l=o.split(".");l[2]="*",await MA(t,[o]),await s.publish(o,c,{headers:r})}else throw u}});throw u}}a(vie,"publishToStream");function lG(e,t){t===void 0&&(t=Rie());let r=Gt.get(we.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(zt.MSG_HEADERS.ORIGIN)&&r&&t.append(zt.MSG_HEADERS.ORIGIN,r),t}a(lG,"addNatsMsgHeader");function Za(e){e=e.toLowerCase();let t=vl.join(Gt.get(we.CONFIG_PARAMS.ROOTPATH),yie);if(e===we.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return vo(yA)&&(yA={port:Ul.getConfigFromFile(we.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:Ul.getConfigFromFile(we.CONFIG_PARAMS.CLUSTERING_NODENAME)+zt.SERVER_SUFFIX.HUB,config_file:zt.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:vl.join(t,zt.PID_FILES.HUB),hdb_nats_path:t}),yA;if(e===we.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return vo(bA)&&(bA={port:Ul.getConfigFromFile(we.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:Ul.getConfigFromFile(we.CONFIG_PARAMS.CLUSTERING_NODENAME)+zt.SERVER_SUFFIX.LEAF,config_file:zt.NATS_CONFIG_FILES.LEAF_SERVER,domain:Ul.getConfigFromFile(we.CONFIG_PARAMS.CLUSTERING_NODENAME)+zt.SERVER_SUFFIX.LEAF,pid_file_path:vl.join(t,zt.PID_FILES.LEAF),hdb_nats_path:t}),bA;kn.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(Za,"getServerConfig");async function _G(e,t,r,n){try{await e.consumers.add(t,{ack_policy:wA.Explicit,durable_name:r,deliver_policy:CA.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}a(_G,"createConsumer");async function Bie(e,t,r){await e.consumers.delete(t,r)}a(Bie,"removeConsumer");function Hie(e){return e.split(".")[1]}a(Hie,"extractServerName");async function xie(e,t,r=6e4,n=DA()){if(!th.isObject(t))throw new Error("data param must be an object");let s=nG.encode(t),{connection:i}=await Es(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return IA(c.data)}a(xie,"request");function UA(e){return new Promise(async(t,r)=>{let n=lie(NA,["--signal",`reload=${e}`],{cwd:__dirname}),s,i;n.on("error",o=>{r(o)}),n.stdout.on("data",o=>{i+=o.toString()}),n.stderr.on("data",o=>{s+=o.toString()}),n.stderr.on("close",o=>{s&&r(s),t(i)})})}a(UA,"reloadNATS");async function Gie(){let{pid_file_path:e}=Za(we.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await UA(e)}a(Gie,"reloadNATSHub");async function Fie(){let{pid_file_path:e}=Za(we.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await UA(e)}a(Fie,"reloadNATSLeaf");function qie(e,t,r){let n;switch(e.code){case Zx.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case Zx.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}a(qie,"requestErrorHandler");async function kie(e,t){let r=t+zt.SERVER_SUFFIX.LEAF,{connection:n}=await Es(),{jsm:s}=await Jie(r),{schema:i,table:o}=e,c=rh.createNatsTableStreamName(i,o),u=e.start_time?e.start_time:new Date(Date.now()).toISOString();await dG(async()=>{if(e.subscribe===!0)await _G(s,c,n.info.server_name,u);else try{await Bie(s,c,n.info.server_name)}catch(_){kn.trace(_)}})}a(kie,"updateRemoteConsumer");async function Vie(e,t,r,n){let s=rh.createNatsTableStreamName(e,t),i=r+zt.SERVER_SUFFIX.LEAF,o={type:we.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!rG&&Eie()<Gt.get(we.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=lE();await c(o)}await die(o),n==="stop"&&await th.async_set_timeout(1e3)}a(Vie,"updateConsumerIterator");function dG(e){return _ie.writeTransaction(we.SYSTEM_SCHEMA_NAME,we.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(dG,"exclusiveLock");async function fG(e,t){let r=rh.createNatsTableStreamName(e,t),n=await nh(),s=Wie(e,t,n);await MA(r,[s])}a(fG,"createLocalTableStream");async function $ie(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await fG(n,s)}}a($ie,"createTableStreams");async function EG(e,t,r=void 0){if(Gt.get(we.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=rh.createNatsTableStreamName(e,t),{domain:s}=Za(we.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await Bl()).jetstreamManager({domain:s,timeout:24e4})).streams.purge(n,r)}catch(n){if(n.message==="stream not found")kn.warn(n);else throw n}}a(EG,"purgeTableStream");async function Yie(e,t){if(Gt.get(we.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await EG(e,t[r])}a(Yie,"purgeSchemaTableStreams");async function Kie(e){return(await Hl()).streams.info(e)}a(Kie,"getStreamInfo");function Wie(e,t,r){return`${zt.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}a(Wie,"createSubjectName");async function nh(){if(Pl)return Pl;if(Pl=(await Hl())?.nc?.info?.server_name,Pl===void 0)throw new Error("Unable to get jetstream manager server name");return Pl}a(nh,"getJsmServerName");async function Qie(){let e=await Hl(),t=await nh(),r=await uG();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let o=zie(n),c=i.split(".");if(c[c.length-1]===t&&!o||s.name==="__HARPERDB_WORK_QUEUE__")continue;let _=i.split(".");_[_.length-1]=t;let l=_.join(".");kn.trace(`Updating stream subject name from: ${i} to: ${l}`),s.subjects[0]=l,await e.streams.update(s.name,s)}}a(Qie,"updateLocalStreams");function zie(e){let{config:t}=e,r=!1,n=Gt.get(we.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Gt.get(we.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=Gt.get(we.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);return i=i===null?-1:i,n!==t.max_age&&(t.max_age=n,r=!0),s!==t.max_bytes&&(t.max_bytes=s,r=!0),i!==t.max_msgs&&(t.max_msgs=i,r=!0),r}a(zie,"updateStreamLimits");async function Jie(e){let t,r;try{t=await Cr.jetstream({domain:e}),r=await Cr.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw kn.error("Unable to connect to:",e),n}return{js:t,jsm:r}}a(Jie,"connectToRemoteJS")});var lE=R((Fpe,NG)=>{"use strict";var{decode:Xie}=require("msgpackr"),{isMainThread:Hpe,parentPort:xpe,threadId:Gpe}=require("worker_threads"),oh=Nt(),ec=nt(),BA=U(),nr=K(),vA=te(),jie=U(),{onMessageByType:Zie}=ct(),SG=gs(),{recordAction:eoe,recordActionBinary:toe}=(vs(),ie(Zu)),{publishToStream:roe}=oh,{ConsumerEvents:mG}=require("nats"),noe=Br(),{promisify:soe}=require("util"),TG=soe(setTimeout),ah=1e4,ch,ih,ioe,ooe,gG,xl=new Map,tc=new Map;NG.exports={initialize:RG,ingestConsumer:HA,setSubscription:aoe,setIgnoreOrigin:loe,getDatabaseSubscriptions:uoe,updateConsumer:AG};async function RG(){Zie(BA.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,async n=>{await AG(n)}),gG=!0,nr.notify("Initializing clustering ingest service.");let{connection:e,jsm:t,js:r}=await oh.getNATSReferences();ch=e,ih=e.info.server_name,ioe=t,ooe=r}a(RG,"initialize");async function AG(e){if(e.status==="start"){let{js:t,jsm:r}=await OG(e.node_domain_name);HA(e.stream_name,t,r,e.node_domain_name)}else if(e.status==="stop"){let t=xl.get(e.stream_name+e.node_domain_name);t&&(nr.notify("Closing ingest consumer for node:",e.node_domain_name,"stream:",e.stream_name),await t.close?.(),xl.set(e.stream_name+e.node_domain_name,"close")),tc.get(e.node_domain_name)==="failed"&&tc.set(e.node_domain_name,"close")}}a(AG,"updateConsumer");var uh=new Map;function aoe(e,t,r){let n=uh.get(e);n||uh.set(e,n=new Map),n.set(t,r),gG||RG().then(coe)}a(aoe,"setSubscription");async function coe(){let e=await noe.searchByValue({database:"system",table:"hdb_nodes",search_attribute:"name",search_value:"*"});for await(let t of e){let r=t.name+ec.SERVER_SUFFIX.LEAF,n,s;for(let i of t.subscriptions)if(i.subscribe===!0){if(!n&&({js:n,jsm:s}=await OG(r),!n))break;let{schema:o,table:c}=i,u=SG.createNatsTableStreamName(o,c);HA(u,n,s,r)}}}a(coe,"accessConsumers");async function OG(e){let t,r,n=1;for(;!r;)try{t=await ch.jetstream({domain:e}),r=await ch.jetstreamManager({domain:e,checkAPI:!1})}catch(s){if(tc.get(e)==="close")break;tc.set(e,"failed"),n%10===1&&nr.warn("Nats ingest attempting to connect to:",e,"Nats error:",s.message);let i=n++*100<ah?n++*100:ah;await TG(i)}return{js:t,jsm:r}}a(OG,"connectToRemoteJS");function uoe(){return uh}a(uoe,"getDatabaseSubscriptions");var bG;function loe(e){bG=e}a(loe,"setIgnoreOrigin");var yG=100,pG=new Array(yG),sh=0;async function HA(e,t,r,n){let{connection:s}=await oh.getNATSReferences();ch=s,ih=s.info.server_name;let i,o=1;for(;!i;)try{i=await t.consumers.get(e,ih),nr.notify("Initializing ingest consumer for node:",n,"stream:",e)}catch(_){if(tc.get(n)==="close")break;o%10===1&&nr.warn("Nats ingest error getting consumer:",n,"stream:",e,"Nats error:",_.message),_.code==="404"&&(nr.notify("Nats ingest creating consumer for node:",n,"stream:",e),i=await oh.createConsumer(r,e,ih,new Date(Date.now()).toISOString()));let l=o++*100<ah?o++*100:ah;await TG(l)}let c=!1,u;for(;!c;){if(xl.get(e+n)==="close"||tc.get(n)==="close"){xl.delete(e+n),c=!0;continue}u=await i.consume({max_messages:vA.get(BA.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS)??100,bind:!0}),xl.set(e+n,u);let _=!1;(async()=>{for await(let l of await u.status())if(l.type===mG.ConsumerDeleted&&(await u.close(),c=!0),l.type===mG.HeartbeatsMissed){let d=l.data;nr.trace(`${d} clustering ingest consumer heartbeats missed, node: ${n} stream: ${u.consumer.stream}`),d===100&&(nr.warn(`Restarting clustering ingest consumer due to missed heartbeat threshold being met, node: ${n} stream: ${u.consumer.stream}`),u.stop(),_=!0)}})();try{for await(let l of u)await pG[sh],pG[sh]=_oe(l).catch(d=>{nr.error(d)}),++sh>=yG&&(sh=0)}catch(l){l.message==="consumer deleted"?(nr.notify("Nats consumer deleted, closing messages for node:",n,"stream:",u.consumer.stream),await u.close(),c=!0):nr.error("Error consuming clustering ingest, restarting consumer",l)}}}a(HA,"ingestConsumer");async function _oe(e){let t=Xie(e.data);eoe(e.data.length,"bytes-received",e.subject,t.operation,"ingest"),nr.trace("Nats message processor message size:",e?.msg?._msg?.size,"bytes");let r=e.headers,n=!1,s=vA.get(BA.CONFIG_PARAMS.CLUSTERING_NODENAME);r.has(ec.MSG_HEADERS.TRANSACTED_NODES)&&r.values(ec.MSG_HEADERS.TRANSACTED_NODES).indexOf(s)>-1&&(n=!0);let i=r.get(ec.MSG_HEADERS.ORIGIN);if(n||(n=i===s&&!bG),toe(n,"echo",e.subject,t.operation,"ingest"),n){e.ack();return}r.append(ec.MSG_HEADERS.TRANSACTED_NODES,s);try{let{operation:o,schema:c,next:u,table:_,records:l,hash_values:d,__origin:f,expiresAt:E}=t;nr.trace("processing message:",o,c,_,(l?"records: "+l.map(L=>L?.id):"")+(d?"ids: "+d:""),"with sequence:",e.seq),nr.trace(`messageProcessor nats msg id: ${e.headers.get(ec.MSG_HEADERS.NATS_MSG_ID)}`);let h;l||(l=d);let S=new Promise(L=>h=L),{timestamp:p,user:T,node_name:A}=f||{},g=uh.get(c)?.get(_);if(!g)throw new Error("Missing table for replication message",_);if(o==="define_schema")t.type=o,t.onCommit=h,g.send(t);else if(l.length===1&&!u)g.send({type:PA(o),value:l[0],id:d?.[0],expiresAt:E,timestamp:p,table:_,onCommit:h,user:T,nodeName:A});else{let L=l.map((v,P)=>({type:PA(o),value:v,expiresAt:E,id:d?.[P],table:_}));for(;u;)L.push({type:PA(u.operation),value:u.record,expiresAt:u.expiresAt,id:u.id,table:u.table}),u=u.next;g.send({type:"transaction",writes:L,table:_,timestamp:p,onCommit:h,user:T,nodeName:A})}vA.get(jie.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&roe(e.subject.split(".").slice(0,-1).join("."),SG.createNatsTableStreamName(c,_),e.headers,e.data),await S}catch(o){nr.error(o)}e.ack()}a(_oe,"messageProcessor");function PA(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}a(PA,"convertOperation")});var doe=lE();(async()=>{try{await doe.initialize()}catch(e){console.error("Error launching Nats ingest service."),console.error(e)}})();