harperdb 4.0.5 → 4.0.6

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.
@@ -2,7 +2,7 @@
2
2
  `,Xw={READ:"read",INSERT:"insert",UPDATE:"update",DELETE:"delete"},Zw=["*","%"],zw="unauthorized_access",jw="func_val",eC={HASH_VALUE:"hash_value",TIMESTAMP:"timestamp",USERNAME:"username"},tC={JWT_PRIVATE_KEY_NAME:".jwtPrivate.key",JWT_PUBLIC_KEY_NAME:".jwtPublic.key",JWT_PASSPHRASE_NAME:".jwtPass"},rC="hdb_ipc_server",sC="hdb_ipc_client_",nC={RESTART:"restart",CHILD_STARTED:"child_started",CHILD_STOPPED:"child_stopped",SCHEMA:"schema",USER:"user",CLUSTER_STATUS_RESPONSE:"cluster_status_response",CLUSTER_STATUS_REQUEST:"cluster_status_request"},iC={HDB_CORE:"hdb_core",CUSTOM_FUNCTIONS:"custom_functions"},aC={STOPPED:"stopped",ONLINE:"online"},oC="3.x.x";eh.exports={LOCAL_HARPERDB_OPERATIONS:J,HDB_SUPPORT_ADDRESS:Kd,HDB_SUPPORT_URL:Qd,HDB_PRICING_URL:Ub,SUPPORT_HELP_MSG:yb,LICENSE_HELP_MSG:Jd,HDB_PROC_NAME:$d,HDB_PROC_DESCRIPTOR:J_,CLUSTERING_LEAF_PROC_DESCRIPTOR:da,CLUSTERING_HUB_PROC_DESCRIPTOR:Ea,SYSTEM_SCHEMA_NAME:Xb,HASH_FOLDER_NAME:Zb,HDB_HOME_DIR_NAME:zb,UPDATE_FILE_NAME:rw,LICENSE_KEY_DIR_NAME:ew,BOOT_PROPS_FILE_NAME:tw,JOB_TYPE_ENUM:Pw,JOB_STATUS_ENUM:bw,SYSTEM_TABLE_NAMES:Aw,SYSTEM_TABLE_HASH_ATTRIBUTES:Ow,OPERATIONS_ENUM:g,VALID_S3_FILE_TYPES:ww,S3_BUCKET_AUTH_KEYS:Cw,VALID_SQL_OPS_ENUM:Lw,GEO_CONVERSION_ENUM:yw,HDB_SETTINGS_NAMES:Zd,HDB_SETTINGS_NAMES_REVERSE_LOOKUP:Dw,SERVICE_ACTIONS_ENUM:Uw,CLUSTER_MESSAGE_TYPE_ENUM:Bw,CLUSTER_CONNECTION_DIRECTION_ENUM:vw,CLUSTER_EVENTS_DEFS_ENUM:Fw,PERIOD_REGEX:qb,DOUBLE_PERIOD_REGEX:Gb,UNICODE_PERIOD:Fb,FORWARD_SLASH_REGEX:Vb,UNICODE_FORWARD_SLASH:kb,ESCAPED_FORWARD_SLASH_REGEX:$b,ESCAPED_PERIOD_REGEX:xb,ESCAPED_DOUBLE_PERIOD_REGEX:Yb,REG_KEY_FILE_NAME:gw,RESTART_TIMEOUT_MS:iw,HDB_FILE_PERMISSIONS:aw,SCHEMA_DIR_NAME:_w,TRANSACTIONS_DIR_NAME:uw,LIMIT_COUNT_NAME:lw,ID_ATTRIBUTE_STRING:Ew,INSERT_MODULE_ENUM:mw,UPGRADE_JSON_FIELD_NAMES_ENUM:Rw,RESTART_CODE:sw,RESTART_CODE_NUM:nw,CLUSTER_OPERATIONS:Cr,SYSTEM_DEFAULT_ATTRIBUTE_NAMES:Nw,HDB_INTERNAL_SC_CHANNEL_PREFIX:dt,INTERNAL_SC_CHANNELS:pw,CLUSTERING_MESSAGE_TYPES:Ww,HDB_FILE_SUFFIX:jb,BLOB_FOLDER_NAME:ow,HDB_TRASH_DIR:cw,ORIGINATOR_SET_VALUE:Qw,LICENSE_VALUES:qw,RAM_ALLOCATION_ENUM:Gw,STORAGE_TYPES_ENUM:Hw,TIME_STAMP_NAMES_ENUM:zd,TIME_STAMP_NAMES:xw,PERMS_UPDATE_RELEASE_TIMESTAMP:Yw,SEARCH_NOT_FOUND_MESSAGE:Db,SEARCH_ATTRIBUTE_NOT_FOUND:Mb,LICENSE_ROLE_DENIED_RESPONSE:Pb,LICENSE_MAX_CONNS_REACHED:Bb,BASIC_LICENSE_MAX_NON_CU_ROLES:Wd,BASIC_LICENSE_CLUSTER_CONNECTION_LIMIT_WS_ERROR_CODE:Lb,VALUE_SEARCH_COMPARATORS:jd,VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP:Kw,LICENSE_FILE_NAME:Iw,WEBSOCKET_CLOSE_CODE_DESCRIPTION_LOOKUP:Vw,NEW_LINE:Jw,BASIC_LICENSE_MAX_CLUSTER_USER_ROLES:Hb,MOMENT_DAYS_TAG:Kb,API_TURNOVER_SEC:Wb,LOOPBACK:vb,CODE_EXTENSION:Fn,WILDCARD_SEARCH_VALUE:Qb,NODE_ERROR_CODES:kw,JAVASCRIPT_EXTENSION:kd,PERMS_CRUD_ENUM:Xw,UNAUTHORIZED_PERMISSION_NAME:zw,SEARCH_WILDCARDS:Zw,FUNC_VAL:jw,READ_AUDIT_LOG_SEARCH_TYPES_ENUM:eC,JWT_ENUM:tC,CLUSTERING_FLAG:$w,RUN_LOG:hw,INSTALL_LOG:dw,IPC_SERVER_MODULE:Yd,HDB_IPC_SERVER:rC,IPC_EVENT_TYPES:nC,HDB_IPC_CLIENT_PREFIX:sC,CUSTOM_FUNCTION_PROC_NAME:xd,CUSTOM_FUNCTION_PROC_DESCRIPTOR:la,SERVICES:iC,MEM_SETTING_KEY:Jb,HDB_RESTART_SCRIPT:Rb,PROCESS_DESCRIPTORS:Q_,SERVICE_SERVERS:Ib,SERVICE_SERVERS_CWD:ua,PROCESS_DESCRIPTORS_VALIDATE:Nb,LAUNCH_SERVICE_SCRIPTS:bb,LOG_LEVELS:pb,PROCESS_NAME_ENV_PROP:Sw,PROCESS_LOG_NAMES:Ob,PM2_PROCESS_STATUSES:aC,CONFIG_PARAM_MAP:Mw,CONFIG_PARAMS:f,HDB_CONFIG_FILE:fb,HDB_DEFAULT_CONFIG_FILE:Tb,ROLE_TYPES_ENUM:wb,BOOT_PROP_PARAMS:fw,INSTALL_PROMPTS:Tw,HDB_ROOT_DIR_NAME:mb,CLUSTERING_PROCESSES:gb,FOREGROUND_PID_FILE:Ab,PACKAGE_ROOT:Ht,PRE_4_0_0_VERSION:oC}});var z_=S((R1,sh)=>{"use strict";var th=require("minimist");sh.exports=cC;function cC(e=[],t=!1){if(!Array.isArray(e))return{};let r,s;t?(r=rh(process.env),s=rh(th(process.argv))):(r=process.env,s=th(process.argv));let n={};for(let i=0,o=e.length;i<o;i++){let c=e[i];s[c]!==void 0?n[c]=s[c].toString().trim():r[c]!==void 0&&(n[c]=r[c].toString().trim())}return n}a(cC,"assignCMDENVVariables");function rh(e){let t,r=Object.keys(e),s=r.length,n={};for(;s--;)t=r[s],n[t.toLowerCase()]=e[t];return n}a(rh,"objKeysToLowerCase")});var I=S((A1,uh)=>{"use strict";var rs=require("fs-extra"),ss=require("path"),ih=require("yaml"),ah=require("properties-reader"),me=T(),_C=z_(),uC=require("os"),{PACKAGE_ROOT:tu}=T(),rt={notify:7,fatal:6,error:5,warn:4,info:3,debug:2,trace:1},ha=ss.join(tu,"logs"),Lr=process.env.pm_id===void 0,lC=ss.join(tu,"config/yaml/",me.HDB_DEFAULT_CONFIG_FILE),ru=process.env.PROCESS_NAME===void 0?me.PROCESS_DESCRIPTORS.INSTALL:process.env.PROCESS_NAME,ks,Qt,cr,tt,j_,$s;$s===void 0&&oh();uh.exports={createLogFile:EC,notify:SC,fatal:fC,error:eu,warn:TC,info:dC,debug:hC,trace:_h,setLogLevel:RC,log_level:tt};function oh(){try{if($s===void 0){let e=mC();$s=ah(e),{level:tt,config_log_path:j_,to_file:Qt,to_stream:cr}=AC($s.get("settings_path"))}}catch(e){if($s=void 0,e.code===me.NODE_ERROR_CODES.ENOENT){let t=_C(Object.keys(me.CONFIG_PARAM_MAP),!0);for(let i in t){let o=me.CONFIG_PARAM_MAP[i];o&&o.toLowerCase();let c=t[i];if(o===me.CONFIG_PARAMS.LOGGING_LEVEL){tt=c;continue}if(o===me.CONFIG_PARAMS.LOGGING_STDSTREAMS){cr=c;continue}o===me.CONFIG_PARAMS.LOGGING_FILE&&(Qt=o)}let{default_level:r,default_to_file:s,default_to_stream:n}=OC();Qt=Qt===void 0?s:Qt,Qt=nh(Qt),cr=cr===void 0?n:cr,cr=nh(cr),tt=tt===void 0?r:tt,j_=ha;return}throw eu("Error initializing log settings"),eu(e),e}}a(oh,"initLogSettings");function EC(e,t){if(!Lr){_h("createLogFile should only be used if the process is not being managed by pm2");return}$s===void 0&&oh(),ru=t;let r;e===me.PROCESS_LOG_NAMES.INSTALL?r=ha:r=j_,Qt&&(ks=ss.join(r,e),rs.ensureFileSync(ks))}a(EC,"createLogFile");function ns(e,t){let r=new Date(Date.now()).toISOString(),s="",n=t.length,i=n-1;for(let o=0;o<n;o++){let c=t[o];c instanceof Error&&c.stack?s+=c.stack:typeof c=="object"?s+=JSON.stringify(c):s+=c,o<i&&(s+=" ")}return`{"process_name": "${ru}", "level": "${e}", "timestamp": "${r}", "message": "${s}"}
3
3
  `}a(ns,"createLogRecord");function ch(e){ks===void 0&&(ru=me.PROCESS_DESCRIPTORS.INSTALL,rs.ensureDirSync(ha),ks=ss.join(ha,me.PROCESS_LOG_NAMES.INSTALL),rs.ensureFileSync(ks)),rs.appendFileSync(ks,e)}a(ch,"writeToLogFile");function Sa(e){Qt&&ch(e),cr&&process.stdout.write(e)}a(Sa,"nonPm2LogStdOut");function su(e){Qt&&ch(e),cr&&process.stderr.write(e)}a(su,"nonPm2LogStdErr");function dC(...e){if(rt[tt]<=rt.info){let t=ns("info",e);if(Lr){Sa(t);return}process.stdout.write(t)}}a(dC,"info");function _h(...e){if(rt[tt]<=rt.trace){let t=ns("trace",e);if(Lr){Sa(t);return}process.stdout.write(t)}}a(_h,"trace");function eu(...e){if(rt[tt]<=rt.error){let t=ns("error",e);if(Lr){su(t);return}process.stderr.write(t)}}a(eu,"error");function hC(...e){if(rt[tt]<=rt.debug){let t=ns("debug",e);if(Lr){Sa(t);return}process.stdout.write(t)}}a(hC,"debug");function SC(...e){if(rt[tt]<=rt.notify){let t=ns("notify",e);if(Lr){Sa(t);return}process.stdout.write(t)}}a(SC,"notify");function fC(...e){if(rt[tt]<=rt.fatal){let t=ns("fatal",e);if(Lr){su(t);return}process.stderr.write(t)}}a(fC,"fatal");function TC(...e){if(rt[tt]<=rt.warn){let t=ns("warn",e);if(Lr){su(t);return}process.stderr.write(t)}}a(TC,"warn");function mC(){let e;try{e=uC.homedir()}catch{e=process.env.HOME}e||(e="~/");let t=ss.join(e,me.HDB_HOME_DIR_NAME,me.BOOT_PROPS_FILE_NAME);return rs.existsSync(t)||(t=ss.join(tu,"utility/hdb_boot_properties.file")),t}a(mC,"getPropsFilePath");function RC(e){tt=e}a(RC,"setLogLevel");function nh(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(nh,"autoCastBoolean");function AC(e){try{if(e.includes("config/settings.js")){let o=ah(e);return{level:o.get(me.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY),config_log_path:ss.dirname(o.get(me.HDB_SETTINGS_NAMES.LOG_PATH_KEY)),to_file:o.get(me.HDB_SETTINGS_NAMES.LOG_TO_FILE),to_stream:o.get(me.HDB_SETTINGS_NAMES.LOG_TO_STDSTREAMS)}}let t=ih.parseDocument(rs.readFileSync(e,"utf8")),r=t.getIn(["logging","level"]),s=t.getIn(["logging","root"]),n=t.getIn(["logging","file"]),i=t.getIn(["logging","stdStreams"]);return{level:r,config_log_path:s,to_file:n,to_stream:i}}catch(t){if(t.code===me.NODE_ERROR_CODES.ENOENT)throw t;console.error("Error accessing config file for logging"),console.error(t)}}a(AC,"getLogConfig");function OC(){try{let e=ih.parseDocument(rs.readFileSync(lC,"utf8")),t=e.getIn(["logging","level"]),r=e.getIn(["logging","file"]),s=e.getIn(["logging","stdStreams"]);return{default_level:t,default_to_file:r,default_to_stream:s}}catch(e){console.error("Error accessing default config file for logging"),console.error(e)}}a(OC,"getDefaultConfig")});var Eh=S((O1,lh)=>{"use strict";var pC=require("util"),NC=require("path"),gC=require("child_process"),IC=pC.promisify(gC.execFile),bC=1e3*1e3*10;lh.exports={findPs:wC};async function wC(e){let t={};try{await Promise.all(["comm","args","ppid","uid","%cpu","%mem"].map(async r=>{let{stdout:s}=await IC("ps",["wwxo",`pid,${r}`],{maxBuffer:bC});for(let n of s.trim().split(`
4
4
  `).slice(1)){n=n.trim();let[i]=n.split(" ",1),o=n.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,s])=>({pid:Number.parseInt(r,10),name:NC.basename(s.comm),cmd:s.args,ppid:Number.parseInt(s.ppid,10),uid:Number.parseInt(s.uid,10),cpu:Number.parseFloat(s["%cpu"]),memory:Number.parseFloat(s["%mem"])}))}a(wC,"findPs")});var Ye=S((p1,hh)=>{"use strict";var CC="__dbis__",LC="__environment_name__",UC="__dbi_defintion__",yC={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"},DC=["__createdtime__","__updatedtime__"],MC="\uFFFF",dh={TIMESTAMP:"timestamp",HASH_VALUE:"hash_value",USER_NAME:"user_name"},PC=Object.values(dh);hh.exports={INTERNAL_DBIS_NAME:CC,DBI_DEFINITION_NAME:UC,SEARCH_TYPES:yC,TIMESTAMP_NAMES:DC,MAX_SEARCH_KEY_LENGTH:256,ENVIRONMENT_NAME_KEY:LC,TRANSACTIONS_DBI_NAMES_ENUM:dh,TRANSACTIONS_DBIS:PC,OVERFLOW_MARKER:MC}});var Ke=S((N1,Nh)=>{"use strict";var Sh=T(),fh=Ye(),Th={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},mh=a(e=>`${e} Check logs and try again.`,"CHECK_LOGS_WRAPPER"),Rh={500:mh("There was an error processing your request."),400:"Invalid request"},BC=Rh[Th.INTERNAL_SERVER_ERROR],vC={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.`},HC={CONFIG_VALIDATION:e=>`HarperDB config file validation error: ${e}`},qC={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"},GC={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_ARRAY:"ids must be an array",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 ${fh.INTERNAL_DBIS_NAME}`,CANNOT_DROP_INTERNAL_DBIS_NAME:`cannot drop a dbi named ${fh.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"},FC={ATTR_NAME_LENGTH_ERR:e=>`transaction aborted due to attribute name ${e} being too long. Attribute names cannot be longer than ${Sh.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 ${Sh.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"},Ah={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"},VC={DEFAULT_INVALID_REQUEST:"Invalid request",OP_AUTH_PERMS_ERROR:"This operation is not authorized due to role restrictions and/or invalid schema 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' schema, tables and records are used internally by HarperDB and cannot be updated or removed."},kC={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 schema metadata for '${e}'`,SCHEMA_TABLE_PERM_ERROR:(e,t)=>`Your role does not have permission to view schema.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`},$C={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=>`Schema '${e}' does not exist`,SCHEMA_EXISTS_ERR:e=>`Schema '${e}' already exists`,TABLE_EXISTS_ERR:(e,t)=>`Table '${t}' already exists in schema '${e}'`,SCHEMA_REQUIRED_ERR:"schema is required",TABLE_NOT_FOUND:(e,t)=>`Table '${e}.${t}' does not exist`,TABLE_REQUIRED_ERR:"table is required"},xC={OUTER_JOIN_TRANSLATION_ERROR:"There was an error translating the final SQL outer join data."},YC={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`},Oh={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.`},ph={INVALID_IPC_DATA_TYPE:"Invalid IPC event data type, must be an object",MISSING_TYPE:"IPC event missing 'type'",MISSING_MSG:"IPC event missing 'message'",MISSING_ORIGIN:"IPC event message missing 'originator' property",INVALID_EVENT:e=>`IPC server received invalid event type: ${e}`},KC={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 customFunctions enabled to true in hdb/harperdb-config.yaml file."},WC={CLUSTERING_NOT_ENABLED:"Clustering must be enabled to perform this operation."},QC={...Ah,...qC,...vC,...VC,...kC,...$C,...xC,...YC,...FC,...Oh,...ph,...KC,...WC,...HC};Nh.exports={CHECK_LOGS_WRAPPER:mh,HDB_ERROR_MSGS:QC,DEFAULT_ERROR_MSGS:Rh,DEFAULT_ERROR_RESP:BC,HTTP_STATUS_CODES:Th,LMDB_ERRORS_ENUM:GC,AUTHENTICATION_ERROR_MSGS:Ah,VALIDATION_ERROR_MSGS:Oh,IPC_ERRORS:ph}});var D=S((g1,bh)=>{"use strict";var xs=Ke(),JC=I(),XC=T(),Vn=class extends Error{constructor(t,r,s,n,i){super(),Error.captureStackTrace(this,gh),this.http_resp_code=s||xs.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR,this.http_resp_msg=r||(xs.DEFAULT_ERROR_MSGS[s]?xs.DEFAULT_ERROR_MSGS[s]:xs.DEFAULT_ERROR_MSGS[xs.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR]),this.message=t.message?t.message:this.http_resp_msg,this.type=t.name,typeof this.message!="string"&&(this.stack=t.stack),i&&JC[n](i)}};a(Vn,"HdbError");function gh(e,t,r,s=XC.LOG_LEVELS.ERROR,n=null,i=!1){if(Ih(e))return e;let o=new Vn(e,t,r,s,n);return i&&delete o.stack,o}a(gh,"handleHDBError");function Ih(e){return e.__proto__.constructor.name===Vn.name}a(Ih,"isHDBError");bh.exports={isHDBError:Ih,handleHDBError:gh,hdb_errors:xs}});var b=S((b1,Vh)=>{"use strict";var is=require("path"),ZC=require("fs-extra"),Ie=I(),wh=require("fs-extra"),zC=require("truncate-utf8-bytes"),kn=require("os"),jC=require("net"),eL=require("recursive-iterator"),Ue=T(),Dh=Eh(),Ch=require("papaparse"),fa=require("moment"),{inspect:tL}=require("util"),Lh=require("is-number"),I1=require("lodash"),{hdb_errors:Ta}=D(),Mh=require("util").promisify(setTimeout),rL=100,sL=5,nL="",iL=4,Uh=255,yh={true:!0,false:!1,undefined:null,null:null,NaN:NaN};Vh.exports={isEmpty:ht,isEmptyOrZeroLength:Jt,arrayHasEmptyValues:cL,arrayHasEmptyOrZeroLengthValues:_L,buildFolderPath:uL,isBoolean:Ph,errorizeMessage:aL,stripFileExtension:EL,autoCast:dL,autoCastJSONDeep:nu,removeDir:SL,compareVersions:fL,isCompatibleDataVersion:TL,escapeRawValue:vh,unescapeValue:mL,stringifyProps:RL,valueConverter:AL,timeoutPromise:pL,isClusterOperation:gL,getClusterUser:wL,sendTransactionToSocketCluster:IL,checkGlobalSchemaTable:bL,getHomeDir:Hh,getPropsFilePath:OL,promisifyPapaParse:CL,removeBOM:qh,createEventPromise:LL,checkProcessRunning:UL,checkSchemaTableExist:yL,checkSchemaExists:Gh,checkTableExists:Fh,getStartOfTomorrowInSeconds:DL,getLimitKey:ML,isObject:lL,isNotEmptyAndHasValue:oL,autoCasterIsNumberCheck:Bh,backtickASTSchemaItems:PL,isPortTaken:NL,stopProcess:BL,createForkArgs:vL,autoCastBoolean:HL,async_set_timeout:Mh,getTableHashAttribute:qL,doesSchemaExist:GL,doesTableExist:FL,stringifyObj:VL,ms_to_time:kL,changeExtension:$L,PACKAGE_ROOT:Ue.PACKAGE_ROOT};function aL(e){return e instanceof Error?e:new Error(e)}a(aL,"errorizeMessage");function ht(e){return e==null}a(ht,"isEmpty");function oL(e){return!ht(e)&&(e||e===0||e===""||Ph(e))}a(oL,"isNotEmptyAndHasValue");function Jt(e){return ht(e)||e.length===0||e.size===0}a(Jt,"isEmptyOrZeroLength");function cL(e){if(ht(e))return!0;for(let t=0;t<e.length;t++)if(ht(e[t]))return!0;return!1}a(cL,"arrayHasEmptyValues");function _L(e){if(Jt(e))return!0;for(let t=0;t<e.length;t++)if(Jt(e[t]))return!0;return!1}a(_L,"arrayHasEmptyOrZeroLengthValues");function uL(...e){try{return e.join(is.sep)}catch{console.error(e)}}a(uL,"buildFolderPath");function Ph(e){return ht(e)?!1:e===!0||e===!1}a(Ph,"isBoolean");function lL(e){return ht(e)?!1:typeof e=="object"}a(lL,"isObject");function EL(e){return Jt(e)?nL:e.slice(0,-iL)}a(EL,"stripFileExtension");function dL(e){return ht(e)||e===""||typeof e!="string"?e:yh[e]!==void 0?yh[e]:Bh(e)===!0?Number(e):e}a(dL,"autoCast");function hL(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}a(hL,"autoCastJSON");function nu(e){if(e&&typeof e=="object"){if(Array.isArray(e))for(let t=0,r=e.length;t<r;t++){let s=e[t],n=nu(s);n!==s&&(e[t]=n)}else for(let t in e){let r=e[t],s=nu(r);s!==r&&(e[t]=s)}return e}else return hL(e)}a(nu,"autoCastJSONDeep");function Bh(e){if(e.startsWith("0.")&&Lh(e))return!0;let t=e.toUpperCase().includes("E");return!!((e!=="0"&&e.startsWith("0"))===!1&&t===!1&&Lh(e))}a(Bh,"autoCasterIsNumberCheck");async function SL(e){if(Jt(e))throw new Error(`Directory path: ${e} does not exist`);try{await wh.emptyDir(e),await wh.remove(e)}catch(t){throw Ie.error(`Error removing files in ${e} -- ${t}`),t}}a(SL,"removeDir");function fL(e,t){if(Jt(e)){Ie.info("Invalid current version sent as parameter.");return}if(Jt(t)){Ie.info("Invalid upgrade version sent as parameter.");return}let r,s=/(\.0+)+$/,n=e.version?e.version:e,i=t.version?t.version:t,o=n.replace(s,"").split("."),c=i.replace(s,"").split("."),_=Math.min(o.length,c.length);for(let u=0;u<_;u++)if(r=parseInt(o[u],10)-parseInt(c[u],10),r)return r;return o.length-c.length}a(fL,"compareVersions");function TL(e,t,r=!1){let s=e.toString().split("."),n=t.toString().split(".");return s[0]===n[0]&&(!r||s[1]===n[1])}a(TL,"isCompatibleDataVersion");function vh(e){if(ht(e))return e;let t=String(e);return t==="."?Ue.UNICODE_PERIOD:t===".."?Ue.UNICODE_PERIOD+Ue.UNICODE_PERIOD:t.replace(Ue.FORWARD_SLASH_REGEX,Ue.UNICODE_FORWARD_SLASH)}a(vh,"escapeRawValue");function mL(e){if(ht(e))return e;let t=String(e);return t===Ue.UNICODE_PERIOD?".":t===Ue.UNICODE_PERIOD+Ue.UNICODE_PERIOD?"..":String(e).replace(Ue.ESCAPED_FORWARD_SLASH_REGEX,"/")}a(mL,"unescapeValue");function RL(e,t){if(ht(e))return Ie.info("Properties object is null"),"";let r="";return e.each(function(s,n){try{if(t&&t[s]){let i=t[s];for(let o of i)r+=";"+o+kn.EOL}!Jt(s)&&s[0]===";"?r+=" "+s+n+kn.EOL:Jt(s)||(r+=s+"="+n+kn.EOL)}catch{Ie.error(`Found bad property during upgrade with key ${s} and value: ${n}`)}}),r}a(RL,"stringifyProps");function AL(e){let t;try{t=typeof e=="object"?JSON.stringify(e):e}catch(n){Ie.error(n),t=e}let r=String(vh(t)),s=Buffer.byteLength(r)>Uh?zC(r,Uh)+"/blob":r;return{value:t,value_stripped:r,value_path:s}}a(AL,"valueConverter");function Hh(){let e;try{e=kn.homedir()}catch{e=process.env.HOME}return e||(e="~/"),e}a(Hh,"getHomeDir");function OL(){let e=is.join(Hh(),Ue.HDB_HOME_DIR_NAME,Ue.BOOT_PROPS_FILE_NAME);return ZC.existsSync(e)||(e=is.join(__dirname,"../","hdb_boot_properties.file")),e}a(OL,"getPropsFilePath");function pL(e,t){let r,s;return s=new Promise(function(n){r=setTimeout(function(){n(t)},e)}),{promise:s,cancel:function(){clearTimeout(r)}}}a(pL,"timeoutPromise");async function NL(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let s=jC.createServer().once("error",n=>{n.code==="EADDRINUSE"?t(!0):r(n)}).once("listening",()=>s.once("close",()=>t(!1)).close()).listen(e)})}a(NL,"isPortTaken");function gL(e){try{return Ue.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){Ie.error(`Error checking operation against cluster ops ${t}`)}return!1}a(gL,"isClusterOperation");function IL(e,t,r){if(global.hdb_socket_client!==void 0){Ie.trace(`Sending transaction to channel: ${e}`);let{hdb_user:s,hdb_auth_header:n,...i}=t;i.__originator||(i.__originator={}),i.__transacted=!0,r&&(i.__originator[r]=Ue.ORIGINATOR_SET_VALUE),global.hdb_socket_client.publish(e,i)}}a(IL,"sendTransactionToSocketCluster");function bL(e,t){if(!global.hdb_schema[e])return Ta.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e);if(!global.hdb_schema[e]||!global.hdb_schema[e][t])return Ta.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(bL,"checkGlobalSchemaTable");function wL(e,t){if(ht(t)){Ie.warn("No CLUSTERING_USER defined, clustering disabled");return}if(ht(e)||Jt(e)){Ie.warn("No users to search.");return}let r;try{let s=e.get(t);s&&s.role.permission.cluster_user===!0&&s.active===!0&&(r=s)}catch(s){Ie.error(`unable to find cluster_user due to: ${s.message}`);return}if(r===void 0){Ie.warn(`CLUSTERING_USER: ${t} not found or is not active.`);return}return r}a(wL,"getClusterUser");function CL(){Ch.parsePromise=function(e,t){return new Promise(function(r,s){Ch.parse(e,{header:!0,transformHeader:qh,chunk:t.bind(null,s),skipEmptyLines:!0,dynamicTyping:!0,error:s,complete:r})})}}a(CL,"promisifyPapaParse");function qh(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}a(qh,"removeBOM");function LL(e,t,r){return new Promise(s=>{t.once(e,n=>{let i=r;Ie.info(`Got cluster status event response: ${tL(n)}`);try{i.cancel()}catch{Ie.error("Error trying to cancel timeout.")}s(n)})})}a(LL,"createEventPromise");async function UL(e){let t=!0,r=0;do await Mh(rL*r++),(await Dh.findPs(e)).length>0&&(t=!1);while(t&&r<sL);if(t)throw new Error(`process ${e} was not started`)}a(UL,"checkProcessRunning");function yL(e,t){let r=Gh(e);if(r)return r;let s=Fh(e,t);if(s)return s}a(yL,"checkSchemaTableExist");function Gh(e){if(!global.hdb_schema[e])return Ta.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(Gh,"checkSchemaExists");function Fh(e,t){if(!global.hdb_schema[e][t])return Ta.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(Fh,"checkTableExists");function DL(){let e=fa().utc().add(1,Ue.MOMENT_DAYS_TAG).startOf(Ue.MOMENT_DAYS_TAG).unix(),t=fa().utc().unix();return e-t}a(DL,"getStartOfTomorrowInSeconds");function ML(){return fa().utc().format("DD-MM-YYYY")}a(ML,"getLimitKey");function PL(e){try{let t=new eL(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){Ie.error("Got an error back ticking items."),Ie.error(t)}}a(PL,"backtickASTSchemaItems");async function BL(e){let t=kn.userInfo();(await Dh.findPs(e)).forEach(s=>{(t.uid==0||s.uid==t.uid)&&(process.kill(s.pid),Ie.trace(`Following process was killed by stopProcess: ${s.cmd}`))})}a(BL,"stopProcess");function vL(e){return[e]}a(vL,"createForkArgs");function HL(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(HL,"autoCastBoolean");function qL(e,t){return global.hdb_schema?.[e]?.[t]?.hash_attribute}a(qL,"getTableHashAttribute");function GL(e){return global?.hdb_schema?.[e]!==void 0}a(GL,"doesSchemaExist");function FL(e,t){return global?.hdb_schema?.[e]?.[t]!==void 0}a(FL,"doesTableExist");function VL(e){try{return JSON.stringify(e)}catch{return e}}a(VL,"stringifyObj");function kL(e){let t=fa.duration(e),r=t.seconds()>0?t.seconds()+"s":"",s=t.minutes()>0?t.minutes()+"m ":"",n=t.hours()>0?t.hours()+"h ":"",i=t.days()>0?t.days()+"d ":"";return(t.years()>0?t.years()+"y ":"")+i+n+s+r}a(kL,"ms_to_time");function $L(e,t){let r=is.basename(e,is.extname(e));return is.join(is.dirname(e),r+t)}a($L,"changeExtension")});var eS=S((C1,jh)=>{"use strict";var iu=require("recursive-iterator"),xL=require("alasql"),au=require("clone"),kh=b(),{handleHDBError:$h,hdb_errors:YL}=D(),{HDB_ERROR_MSGS:xh,HTTP_STATUS_CODES:Yh}=YL,KL=["DISTINCT_ARRAY"],Kh=Symbol("validateTables"),ou=Symbol("validateTable"),w1=Symbol("getAllColumns"),Wh=Symbol("validateAllColumns"),ma=Symbol("findColumn"),Qh=Symbol("validateOrderBy"),$n=Symbol("validateSegment"),cu=Symbol("validateColumn"),Jh=Symbol("setColumnsForTable"),Xh=Symbol("checkColumnsForAsterisk"),Zh=Symbol("validateGroupBy"),zh=Symbol("hasColumns"),Ra=class{constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[Kh](),this[Xh](),this[Wh]()}[Kh](){if(this[zh]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[ou](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[ou](t.table)})}}[zh](){let t=!1,r=new iu(this.statement);for(let{node:s,path:n}of r)if(s&&s.columnid){t=!0;break}return t}[ou](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;if(!global.hdb_schema[t.databaseid])throw $h(new Error,xh.SCHEMA_NOT_FOUND(t.databaseid),Yh.NOT_FOUND);if(!global.hdb_schema[t.databaseid][t.tableid])throw $h(new Error,xh.TABLE_NOT_FOUND(t.databaseid,t.tableid),Yh.NOT_FOUND);global.hdb_schema[t.databaseid][t.tableid].attributes.forEach(s=>{let n=au(s);n.table=au(t),this.attributes.push(n)})}[ma](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)}[Xh](){let t=new iu(this.statement.columns);for(let{node:r,path:s}of t)r&&r.columnid==="*"&&s.indexOf("expression")<0&&this[Jh](r.tableid)}[Jh](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&this.statement.columns.push(new xL.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[Wh](){this[$n](this.statement.columns,!1),this[$n](this.statement.joins,!1),this[$n](this.statement.where,!1),this[Zh](this.statement.group,!1),this[$n](this.statement.order,!0)}[$n](t,r){if(!t)return;let s=new iu(t),n=[];for(let{node:i,path:o}of s)!kh.isEmpty(i)&&!kh.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[Qh](i):n.push(this[cu](i)));return n}[Zh](t){if(!t)return;let r=[];if(this.statement.columns.forEach(s=>{if(!(s.funcid&&KL.indexOf(s.funcid.toUpperCase())>=0)){if(!s.aggregatorid&&!s.columnid){let n=au(s);delete n.as,r.push(n)}else if(s.columnid){let n=this[ma](s)[0];n&&r.push(n)}}}),this.statement.group.forEach(s=>{let n=null;if(!s.columnid)r.forEach((i,o)=>{if(i.toString()===s.toString()){n=i,r.splice(o,1);return}});else{let i=this[ma](s);if(!i||i.length===0)throw`unknown column '${s.toString()}' in group by`;if(i.length>1)throw`ambiguously defined column '${s.toString()}' in group by`;r.forEach((o,c)=>{if(o.attribute===i[0].attribute&&o.table.tableid===i[0].table.tableid){n=o,r.splice(c,1);return}})}if(!n)throw`group by column '${s.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`}[Qh](t){let r=this.statement.columns.filter(s=>s.as===t.columnid);if(r.length>1)throw`ambiguous column reference ${(t.tableid?t.tableid+".":"")+t.columnid} in order by`;r.length===0&&this[cu](t)}[cu](t){let r=this[ma](t),s=(t.tableid?t.tableid+".":"")+t.columnid;if(r.length===0)throw`unknown column ${s}`;if(r.length>1)throw`ambiguous column reference ${s}`;return r[0]}};a(Ra,"SelectValidator");jh.exports=Ra});var _u=S((L1,tS)=>{"use strict";var Aa=class{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")}};a(Aa,"BridgeMethods");tS.exports=Aa});var as=S((D1,iS)=>{"use strict";var rS=Ke().LMDB_ERRORS_ENUM,U1=require("lmdb"),WL=Ye(),y1=require("buffer").Buffer,QL=require("microtime"),{OVERFLOW_MARKER:sS,MAX_SEARCH_KEY_LENGTH:Oa}=WL,nS=["number","string","symbol","boolean","bigint"];function JL(e){if(!e)throw new Error(rS.ENV_REQUIRED);if(e.constructor.name!=="LMDBStore")throw new Error(rS.INVALID_ENVIRONMENT)}a(JL,"validateEnv");function XL(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(XL,"stringifyData");function ZL(e){return e instanceof Date?e.valueOf():e}a(ZL,"convertKeyValueToWrite");function zL(e){if(e==null)return;if(nS.includes(typeof e))return e.length>Oa?[e.slice(0,Oa)+sS]:[e];let t;if(Array.isArray(e)){t=[];for(let r=0,s=e.length;r<s;r++){let n=e[r];nS.includes(typeof n)&&(n.length>Oa?t.push(n.slice(0,Oa)+sS):t.push(n))}}return t}a(zL,"getIndexedValues");function jL(){let e=QL.now().toString(),t=e.length-3;return Number(e.slice(0,t)+"."+e.slice(t))}a(jL,"getMicroTime");iS.exports={validateEnv:JL,stringifyData:XL,convertKeyValueToWrite:ZL,getMicroTime:jL,getIndexedValues:zL}});var oS=S((M1,aS)=>{"use strict";var pa=class{constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};a(pa,"DBIDefinition");aS.exports=pa});var _S=S((P1,cS)=>{"use strict";var Na=class{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={validated:!0},this.randomAccessStructure=!0,this.freezeData=!0)}};a(Na,"OpenDBIObject");cS.exports=Na});var lS=S((B1,uS)=>{"use strict";var ga=class{constructor(t,r,s,n,i=!1,o=!1,c=void 0){this.path=t,this.mapSize=r,this.maxDbs=s,this.maxReaders=n,this.sharedStructuresKey=Symbol.for("structures"),this.readOnly=i,this.trackMetrics=!0,this.noSync=o,c!==void 0&&(this.overlappingSync=c)}};a(ga,"OpenEnvironmentObject");uS.exports=ga});var de=S((v1,ES)=>{"use strict";var st=require("validate.js");st.validators.type=function(e,t,r,s){return e===null||typeof e>"u"||st.validators.type.checks[t](e)?null:` must be a '${t}' value`};st.validators.type.checks={Object:function(e){return st.isObject(e)&&!st.isArray(e)},Array:st.isArray,Integer:st.isInteger,Number:st.isNumber,String:st.isString,Date:st.isDate,Boolean:function(e){return typeof e=="boolean"}};st.validators.hasValidFileExt=function(e,t){return!st.isString(e)||e===""||t.filter(r=>e.endsWith(r)).length>0?null:`must include one of the following valid file extensions - '${t.join("', '")}'`};ES.exports={validateObject:eU,validateObjectAsync:tU,validateBySchema:rU};function eU(e,t){if(!e||!t)return new Error("validateObject parameters were null");let r=st(e,t,{format:"flat"});return r?new Error(r):null}a(eU,"validateObject");async function tU(e,t){if(!e||!t)return new Error("validateObject parameters were null");try{await st.async(e,t,{format:"flat"})}catch(r){let s=r.join(",");return new Error(s)}return null}a(tU,"validateObjectAsync");function rU(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(rU,"validateBySchema")});var lu=S((H1,hS)=>{"use strict";var sU=require("fs-extra"),F=require("joi"),nU=require("os"),{boolean:ye,string:_r,number:Xt,array:uu}=F.types(),dS=require("path"),iU=I(),Ia=b(),aU=de(),oU="log",cU="custom_functions",_U="Invalid logging.rotation.maxSize unit. Available units are G, M or K",uU="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",lU="rootPath config parameter is undefined",EU="clustering.enabled config parameter is undefined",Ur=Xt.min(0).required(),ba=uu.items({host:_r.required(),port:Ur}).empty(null),xn;hS.exports={configValidator:dU,routesValidator:RU,route_constraints:ba};function dU(e){if(xn=e.rootPath,Ia.isEmpty(xn))throw lU;let t=ye.required(),r=F.valid("production","development").required(),s=Xt.min(1).max(1e3).empty(null).default(TU),n=_r.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(mU),i=F.custom(SU).messages({"any.custom":"{:#label} {:#error}"}),o=_r.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null),c=e.clustering?.enabled;if(Ia.isEmpty(c))throw EU;let _;return c===!0?_=F.object({enabled:t,hubServer:F.object({cluster:F.object({name:F.required().empty(null),network:F.object({port:Ur,routes:ba}).required()}).required(),leafNodes:F.object({network:F.object({port:Ur}).required()}).required(),network:F.object({port:Ur}).required()}).required(),leafServer:F.object({network:F.object({port:Ur,routes:ba}).required()}).required(),nodeName:o,tls:F.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:ye.required()}),user:F.string().required()}).required():_=F.object({enabled:t,tls:F.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:ye.required()})}).required(),F.object({clustering:_,customFunctions:F.object({enabled:t,network:F.object({cors:ye.required(),corsAccessList:uu.required(),headersTimeout:Xt.min(1).required(),https:ye.required(),keepAliveTimeout:Xt.min(1).required(),port:Ur,timeout:Xt.min(1).required()}),nodeEnv:r,root:n,tls:F.object({certificate:i,certificateAuthority:i,privateKey:i})}).required(),ipc:F.object({network:F.object({port:Ur})}).required(),localStudio:F.object({enabled:t}).required(),logging:F.object({file:ye.required(),level:F.valid("notify","fatal","error","warn","info","debug","trace"),rotation:F.object({compress:ye.required(),dateFormat:_r.required(),maxSize:_r.custom(fU).required(),retain:Xt.min(0).required(),rotate:ye.required(),rotateInterval:_r.required(),rotateModule:ye.required(),timezone:_r.required(),workerInterval:Xt.min(1).required()}).required(),root:n,stdStreams:ye.required(),auditLog:ye.required()}).required(),operationsApi:F.object({authentication:F.object({operationTokenTimeout:F.required(),refreshTokenTimeout:F.required()}).required(),foreground:ye.required(),network:F.object({cors:ye.required(),corsAccessList:uu.required(),headersTimeout:Xt.min(1).required(),https:ye.required(),keepAliveTimeout:Xt.min(1).required(),port:Ur,timeout:Xt.min(1).required()}).required(),nodeEnv:r,tls:F.object({certificate:i,certificateAuthority:i,privateKey:i})}).required(),rootPath:_r.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path").required(),http:F.object({threads:s}).required(),storage:F.object({writeAsync:ye.required(),overlappingSync:ye.optional()}).required()}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(dU,"configValidator");function hU(e){return sU.existsSync(e)?null:`Specified path ${e} does not exist.`}a(hU,"doesPathExist");function SU(e,t){if(e===null)return;F.assert(e,_r.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+\.pem+$/).messages({"string.pattern.base":"must be a valid directory path and specify a .pem file"}));let r=hU(e);return r?t.message(r):e}a(SU,"validatePemFile");function fU(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(_U);let s=e.slice(0,-1);if(isNaN(parseInt(s)))return t.message(uU)}a(fU,"validateRotationMaxSize");function TU(e,t){let r=t.state.path.join("."),s=nU.cpus().length,n=s-1;return n<=2&&(n=2),iU.info(`Detected ${s} cores on this machine, defaulting ${r} to ${n}`),n}a(TU,"setDefaultThreads");function mU(e,t){if(!Ia.isEmpty(t.original))return t.original;let r=t.state.path.join(".");if(Ia.isEmpty(xn))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"customFunctions.root":return dS.join(xn,cU);case"logging.root":return dS.join(xn,oU);default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(mU,"setDefaultRoot");function RU(e){let t=F.object({routes:ba});return aU.validateBySchema({routes:e},t)}a(RU,"routesValidator")});var ur=S((q1,OS)=>{"use strict";var re=T(),gt=b(),We=I(),{configValidator:AU,routesValidator:SS}=lu(),qt=require("fs-extra"),OU=require("yaml"),Ys=require("path"),pU=require("is-number"),La=require("properties-reader"),NU=require("lodash"),{handleHDBError:gU}=D(),{HTTP_STATUS_CODES:IU,HDB_ERROR_MSGS:wa}=Ke(),{PACKAGE_ROOT:bU}=T(),wU="Unable to get config value because config is uninitialized",CU="Config successfully initialized",LU="Error backing up config file",UU="Empty parameter sent to getConfigValue",fS=Ys.join(bU,"config","yaml",re.HDB_DEFAULT_CONFIG_FILE),yU="Configuration successfully set. You must restart HarperDB for new config settings to take effect.",Ca,nt;OS.exports={createConfigFile:DU,getDefaultConfig:MU,getConfigValue:TS,initConfig:mS,flattenConfig:os,updateConfigValue:RS,updateConfigObject:PU,getConfiguration:BU,setConfiguration:vU,readConfigFile:hu,getClusteringRoutes:HU,initOldConfig:AS,getConfigFromFile:qU};function DU(e){let t=Ks(fS);Ca=os(t.toJSON());for(let i in e){let o=re.CONFIG_PARAM_MAP[i.toLowerCase()];if(o!==void 0){let c=o.split("_"),_=Eu(o,e[i]);try{t.setIn([...c],_)}catch(u){We.error(u)}}}du(t);let r=t.toJSON();nt=os(r);let s=t.getIn(["rootPath"]),n=Ys.join(s,re.HDB_CONFIG_FILE);qt.createFileSync(n),qt.writeFileSync(n,String(t)),We.trace(`Config file written to ${n}`)}a(DU,"createConfigFile");function MU(e){if(Ca===void 0){let r=Ks(fS);Ca=os(r.toJSON())}let t=re.CONFIG_PARAM_MAP[e.toLowerCase()];if(t!==void 0)return Ca[t.toLowerCase()]}a(MU,"getDefaultConfig");function TS(e){if(gt.isEmpty(e)){We.error(UU);return}if(nt===void 0){We.trace(wU);return}let t=re.CONFIG_PARAM_MAP[e.toLowerCase()];if(t!==void 0)return nt[t.toLowerCase()]}a(TS,"getConfigValue");function mS(e=!1){if(nt===void 0||e){let t=gt.getPropsFilePath();try{qt.accessSync(t,qt.constants.F_OK|qt.constants.R_OK)}catch(o){throw We.error(o),new Error(`HarperDB properties file at path ${t} does not exist`)}let s=La(t).get(re.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),n;if(s.includes("config/settings.js"))try{AS(s);return}catch(o){if(o.code!==re.NODE_ERROR_CODES.ENOENT)throw o}try{n=Ks(s)}catch(o){if(o.code===re.NODE_ERROR_CODES.ENOENT){We.trace(`HarperDB config file not found at ${s}.
5
- This can occur during early stages of install where the config file has not yet been created`);return}else throw We.error(o),new Error(`Error reading HarperDB config file at ${s}`)}du(n);let i=n.toJSON();nt=os(i),We.trace(CU)}}a(mS,"initConfig");function du(e){let t=e.toJSON(),r=AU(t);if(r.error)throw wa.CONFIG_VALIDATION(r.error.message);e.setIn(["http","threads"],r.value.http.threads),e.setIn(["customFunctions","root"],r.value.customFunctions.root),e.setIn(["logging","root"],r.value.logging.root),e.setIn(["operationsApi","tls","certificate"],r.value.operationsApi.tls.certificate),e.setIn(["operationsApi","tls","privateKey"],r.value.operationsApi.tls.privateKey),e.setIn(["operationsApi","tls","certificateAuthority"],r.value.operationsApi.tls.certificateAuthority),e.setIn(["customFunctions","tls","certificate"],r.value.customFunctions.tls.certificate),e.setIn(["customFunctions","tls","privateKey"],r.value.customFunctions.tls.privateKey),e.setIn(["customFunctions","tls","certificateAuthority"],r.value.customFunctions.tls.certificateAuthority),e.setIn(["clustering","tls","certificate"],r.value.clustering.tls.certificate),e.setIn(["clustering","tls","privateKey"],r.value.clustering.tls.privateKey),e.setIn(["clustering","tls","certificateAuthority"],r.value.clustering.tls.certificateAuthority)}a(du,"validateConfig");function PU(e,t){nt===void 0&&(nt={});let r=re.CONFIG_PARAM_MAP[e.toLowerCase()];if(r===void 0){We.trace(`Unable to update config object because config param '${e}' does not exist`);return}nt[r.toLowerCase()]=t}a(PU,"updateConfigObject");function RS(e,t,r=void 0,s=!1,n=!1){nt===void 0&&mS();let i=TS(re.CONFIG_PARAM_MAP.hdb_root),o=Ys.join(i,re.HDB_CONFIG_FILE),c=Ks(o);if(r===void 0){let l=re.CONFIG_PARAM_MAP[e.toLowerCase()];if(l===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let E=l.split("_"),d=Eu(l,t);c.setIn([...E],d)}else for(let l in r){let E=re.CONFIG_PARAM_MAP[l.toLowerCase()];if(E!==void 0){let d=E.split("_"),h=Eu(E,r[l]);try{c.setIn([...d],h)}catch(m){We.error(m)}}}du(c);let _=c.getIn(["rootPath"]),u=Ys.join(_,re.HDB_CONFIG_FILE);if(s===!0)try{let l=Ys.join(_,"backup",`${re.HDB_CONFIG_FILE}.bak`);qt.copySync(o,l),We.trace(`Config file: ${o} backed up to: ${l}`)}catch(l){We.error(LU),We.error(l)}qt.writeFileSync(u,String(c)),n&&(nt=os(c.toJSON())),We.trace(`Config parameter: ${e} updated with value: ${t}`)}a(RS,"updateConfigValue");function os(e){let t={};for(let r in e)if(!!e.hasOwnProperty(r))if(typeof e[r]=="object"&&e[r]!==null&&!Array.isArray(e[r])){let s=os(e[r]);for(let n in s)!s.hasOwnProperty(n)||(t[r.toLowerCase()+"_"+n]=s[n])}else t[r.toLowerCase()]=e[r];return t}a(os,"flattenConfig");function Eu(e,t){if(e===re.CONFIG_PARAMS.CLUSTERING_NODENAME||e===re.CONFIG_PARAMS.CLUSTERING_USER){if(!isNaN(t))return t.toString();if(typeof t=="string"&&t.toLowerCase()==="true"||typeof t=="string"&&t.toLowerCase()==="false")return t}else{if(pU(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||gt.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 gt.autoCast(t)}a(Eu,"castConfigValue");function BU(){let e=gt.getPropsFilePath(),r=La(e).get(re.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY);return Ks(r).toJSON()}a(BU,"getConfiguration");async function vU(e){let{operation:t,hdb_user:r,hdb_auth_header:s,...n}=e;try{return RS(void 0,void 0,n,!0),yU}catch(i){throw typeof i=="string"||i instanceof String?gU(i,i,IU.BAD_REQUEST,void 0,void 0,!0):i}}a(vU,"setConfiguration");function hu(){let e=gt.getPropsFilePath();try{qt.accessSync(e,qt.constants.F_OK|qt.constants.R_OK)}catch(n){throw We.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let r=La(e).get(re.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY);return Ks(r).toJSON()}a(hu,"readConfigFile");function Ks(e){return OU.parseDocument(qt.readFileSync(e,"utf8"),{simpleKeys:!0})}a(Ks,"parseYamlDoc");function HU(){let e=hu(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=gt.isEmptyOrZeroLength(t)?[]:t;let r=SS(t);if(r)throw wa.CONFIG_VALIDATION(r.message);let s=e?.clustering?.leafServer?.network?.routes;s=gt.isEmptyOrZeroLength(s)?[]:s;let n=SS(s);if(n)throw wa.CONFIG_VALIDATION(n.message);if(!gt.isEmptyOrZeroLength(s)&&!gt.isEmptyOrZeroLength(t)){let i=t.filter(o=>s.some(c=>c.host===o.host&&c.port===o.port));if(!gt.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw wa.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:s}}a(HU,"getClusteringRoutes");function AS(e){let t=La(e);nt={};for(let r in re.CONFIG_PARAM_MAP){let s=t.get(r.toUpperCase());if(gt.isEmpty(s)||typeof s=="string"&&s.trim().length===0)continue;let n=re.CONFIG_PARAM_MAP[r].toLowerCase();n===re.CONFIG_PARAMS.LOGGING_ROOT?nt[n]=Ys.dirname(s):nt[n]=s}return nt}a(AS,"initOldConfig");function qU(e){let t=hu();return NU.get(t,e.replaceAll("_","."))}a(qU,"getConfigFromFile")});var Y=S((G1,NS)=>{"use strict";var Su=require("fs-extra"),Zt=require("path"),GU=require("os"),FU=require("properties-reader"),Yn=I(),Ws=b(),M=T(),Ua=ur(),VU="Error initializing environment manager",ya="BOOT_PROPS_FILE_PATH",pS=!1,kU={[M.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[M.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[M.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},lr={};NS.exports={BOOT_PROPS_FILE_PATH:ya,getHdbBasePath:$U,setHdbBasePath:xU,get:YU,initSync:WU,setProperty:x,initTestEnvironment:QU};function $U(){return lr[M.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a($U,"getHdbBasePath");function xU(e){lr[M.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(xU,"setHdbBasePath");function YU(e){let t=Ua.getConfigValue(e);return t===void 0?lr[e]:t}a(YU,"get");function x(e,t){kU[e]&&(lr[e]=t),Ua.updateConfigObject(e,t)}a(x,"setProperty");function KU(){let e;try{e=Ws.getPropsFilePath(),Su.accessSync(e,Su.constants.F_OK|Su.constants.R_OK),pS=!0;let t=FU(e);return lr[M.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(M.HDB_SETTINGS_NAMES.INSTALL_USER),lr[M.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(M.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),lr[ya]=e,!0}catch{return Yn.trace(`Environment manager found no properties file at ${e}`),!1}}a(KU,"doesPropFileExist");function WU(e=!1){try{(pS||KU())&&(Ua.initConfig(e),lr[M.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=Ua.getConfigValue(M.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){Yn.error(VU),Yn.error(t),console.error(t),process.exit(1)}}a(WU,"initSync");function QU(e={}){try{let{keep_alive_timeout:t,headers_timeout:r,server_timeout:s,https_enabled:n,cors_enabled:i,cors_accesslist:o,local_studio_on:c}=e,_=Zt.join(__dirname,"../../","unitTests");lr[ya]=Zt.join(_,"hdb_boot_properties.file"),x(M.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,Zt.join(_,"settings.test")),x(M.HDB_SETTINGS_NAMES.INSTALL_USER,GU.userInfo().username),x(M.HDB_SETTINGS_NAMES.PRIVATE_KEY_KEY,Zt.join(_,"envDir","utility","keys","privateKey.pem")),x(M.HDB_SETTINGS_NAMES.CERT_KEY,Zt.join(_,"envDir","utility","keys","certificate.pem")),x(M.CONFIG_PARAMS.CUSTOMFUNCTIONS_TLS_PRIVATEKEY,Zt.join(_,"envDir","utility","keys","privateKey.pem")),x(M.CONFIG_PARAMS.CUSTOMFUNCTIONS_TLS_CERTIFICATE,Zt.join(_,"envDir","utility","keys","certificate.pem")),x(M.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),x(M.HDB_SETTINGS_NAMES.LOG_PATH_KEY,Zt.join(_,"envDir","log")),x(M.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),x(M.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),x(M.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),x(M.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,Zt.join(_,"envDir")),x(M.HDB_SETTINGS_NAMES.HTTP_SECURE_ENABLED_KEY,Ws.isEmpty(n)?!0:n),x(M.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,Ws.isEmpty(n)?!0:n),x(M.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),x(M.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,Ws.isEmpty(i)?!1:i),x(M.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_CORS,Ws.isEmpty(i)?!1:i),x(M.HDB_SETTINGS_NAMES.IPC_SERVER_PORT,9383),x(M.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),x(M.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),x(M.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),x(M.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),x(M.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,Zt.resolve(__dirname,"../../unitTests/server/customFunctions/custom_functions")),x(M.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,Ws.isEmpty(c)?!1:c),o&&(x("CORS_ACCESSLIST",o),x(M.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_CORSACCESSLIST,o)),s&&(x(M.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,s),x(M.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_TIMEOUT,s)),t&&(x(M.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),x(M.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_KEEPALIVETIMEOUT,t)),r&&(x(M.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),x(M.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${ya}. Please check your boot props and settings files`;Yn.fatal(r),Yn.error(t)}}a(QU,"initTestEnvironment")});var X=S((V1,BS)=>{"use strict";var fu=require("lmdb"),It=require("fs-extra"),Gt=require("path"),Ma=as(),gS=I(),De=Ke().LMDB_ERRORS_ENUM,Pa=oS(),Tu=_S(),IS=lS(),yr=Ye(),F1=T(),Kn=Y();Kn.initSync();var bS=Kn.get("STORAGE_WRITEASYNC")===!0||Kn.get("STORAGE_WRITEASYNC")==="true"||Kn.get("STORAGE_WRITEASYNC")==="TRUE",wS=Kn.get("STORAGE_OVERLAPPINGSYNC"),CS=1024*1024*1024,LS=1e4,US=1e3,Ft=yr.INTERNAL_DBIS_NAME,yS=yr.DBI_DEFINITION_NAME,JU="data.mdb",XU="lock.mdb",Wn=".mdb",ZU="-lock",Da=class{constructor(t,r,s=!1){this.dbi=bt(t,r),this.key_type=this.dbi[yr.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[yr.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:s===!1}),this.cursor=new fu.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};a(Da,"TransactionCursor");function mu(e,t){if(e===void 0)throw new Error(De.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(De.ENV_NAME_REQUIRED)}a(mu,"pathEnvNameValidation");async function Ru(e,t,r=!0){try{await It.access(e)}catch(s){throw s.code==="ENOENT"?new Error(De.INVALID_BASE_PATH):s}try{let s=Gt.join(e,t+Wn);return await It.access(s,It.constants.R_OK|It.constants.F_OK),s}catch(s){if(s.code==="ENOENT")if(r)try{return await It.access(Gt.join(e,t,JU),It.constants.R_OK|It.constants.F_OK),Gt.join(e,t)}catch(n){if(n.code==="ENOENT")throw new Error(De.INVALID_ENVIRONMENT)}else throw new Error(De.INVALID_ENVIRONMENT);throw s}}a(Ru,"validateEnvironmentPath");function Ba(e,t){if(Ma.validateEnv(e),t===void 0)throw new Error(De.DBI_NAME_REQUIRED)}a(Ba,"validateEnvDBIName");async function zU(e,t,r=!1,s=!1){mu(e,t),t=t.toString();try{return await Ru(e,t,s),Au(e,t,r)}catch(n){if(n.message===De.INVALID_ENVIRONMENT){let i=Gt.join(e,t);await It.mkdirp(s?i:e);let o=new IS(s?i:i+Wn,CS,LS,US,!1,bS,wS),c=fu.open(o);c.dbis=Object.create(null);let _=new Tu(!1);c.openDB(Ft,_),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let u=Ou(e,t,r);return c[yr.ENVIRONMENT_NAME_KEY]=u,global.lmdb_map[u]=c,c}throw n}}a(zU,"createEnvironment");async function jU(e,t,r,s=!0){let n=await Au(e,t);if(r===void 0)throw new Error(De.DESTINATION_PATH_REQUIRED);try{await It.access(Gt.dirname(r))}catch(i){throw i.code==="ENOENT"?new Error(De.INVALID_DESTINATION_PATH):i}await n.backup(r,s)}a(jU,"copyEnvironment");async function Au(e,t,r=!1){mu(e,t),t=t.toString();let s=Ou(e,t,r);if(global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null)),global.lmdb_map[s]!==void 0)return global.lmdb_map[s];let n=await Ru(e,t),i=Gt.join(e,t+Wn),o=n!=i,c=new IS(n,CS,LS,US,o,bS,wS),_=fu.open(c);_.dbis=Object.create(null);let u=MS(_);for(let l=0;l<u.length;l++)bt(_,u[l]);return _[yr.ENVIRONMENT_NAME_KEY]=s,global.lmdb_map[s]=_,_}a(Au,"openEnvironment");async function ey(e,t,r=!1){mu(e,t),t=t.toString();let s=Gt.join(e,t+Wn),n=await Ru(e,t);if(global.lmdb_map!==void 0){let i=Ou(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await DS(o),delete global.lmdb_map[i]}}await It.remove(n),await It.remove(n===s?n+ZU:Gt.join(Gt.dirname(n),XU))}a(ey,"deleteEnvironment");async function DS(e){Ma.validateEnv(e);let t=e[yr.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(DS,"closeEnvironment");function Ou(e,t,r=!1){let n=`${Gt.basename(e)}.${t}`;return r===!0&&(n=`txn.${n}`),n}a(Ou,"getCachedEnvironmentName");function ty(e){Ma.validateEnv(e);let t=Object.create(null),r=bt(e,Ft);for(let{key:s,value:n}of r.getRange({start:!1}))if(s!==Ft)try{t[s]=Object.assign(new Pa,n)}catch{gS.warn(`an internal error occurred: unable to parse DBI Definition for ${s}`)}return t}a(ty,"listDBIDefinitions");function MS(e){Ma.validateEnv(e);let t=[],r=bt(e,Ft);for(let{key:s}of r.getRange({start:!1}))s!==Ft&&t.push(s);return t}a(MS,"listDBIs");function ry(e,t){let s=bt(e,Ft).getEntry(t),n=new Pa;if(s!==void 0){try{n=Object.assign(n,s.value)}catch{gS.warn(`an internal error occurred: unable to parse DBI Definition for ${s}`)}return n}}a(ry,"getDBIDefinition");function PS(e,t,r,s=!1){if(Ba(e,t),t=t.toString(),t===Ft)throw new Error(De.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return bt(e,t)}catch(n){if(n.message===De.DBI_DOES_NOT_EXIST){let i=new Tu(r,s===!0),o=e.openDB(t,i),c=new Pa(r===!0,s);return o[yS]=c,bt(e,Ft).putSync(t,c),e.dbis[t]=o,o}throw n}}a(PS,"createDBI");function bt(e,t){if(Ba(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==Ft?r=ry(e,t):r=new Pa,r===void 0)throw new Error(De.DBI_DOES_NOT_EXIST);let s;try{let n=new Tu(r.dup_sort,r.useVersions);if(s=e.openDB(t,n),s.db===void 0)throw new Error("MDB_NOTFOUND")}catch(n){throw n.message.includes("MDB_NOTFOUND")===!0?new Error(De.DBI_DOES_NOT_EXIST):n}return s[yS]=r,e.dbis[t]=s,s}a(bt,"openDBI");function sy(e,t){Ba(e,t),t=t.toString();let r=bt(e,t),s=r.getStats();return r[yr.DBI_DEFINITION_NAME].is_hash_attribute&&s.entryCount>0&&s.entryCount--,s}a(sy,"statDBI");async function ny(e,t){try{let r=Gt.join(e,t+Wn);return(await It.stat(r)).size}catch{throw new Error(De.INVALID_ENVIRONMENT)}}a(ny,"environmentDataSize");function iy(e,t){if(Ba(e,t),t=t.toString(),t===Ft)throw new Error(De.CANNOT_DROP_INTERNAL_DBIS_NAME);bt(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],bt(e,Ft).removeSync(t)}a(iy,"dropDBI");function ay(e,t,r){for(let s=0;s<r.length;s++){let n=r[s];if(!e.dbis[n])try{bt(e,n)}catch(i){if(i.message===De.DBI_DOES_NOT_EXIST)PS(e,n,n!==t,n===t);else throw i}}}a(ay,"initializeDBIs");BS.exports={openDBI:bt,openEnvironment:Au,createEnvironment:zU,listDBIs:MS,listDBIDefinitions:ty,createDBI:PS,dropDBI:iy,statDBI:sy,deleteEnvironment:ey,initializeDBIs:ay,TransactionCursor:Da,environmentDataSize:ny,copyEnvironment:jU,closeEnvironment:DS}});var HS=S((k1,vS)=>{"use strict";var va=class{constructor(t=[],r=[],s=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=s}};a(va,"InsertRecordsResponseObject");vS.exports=va});var GS=S(($1,qS)=>{"use strict";var Ha=class{constructor(t=[],r=[],s=void 0,n=[]){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=s,this.original_records=n}};a(Ha,"UpdateRecordsResponseObject");qS.exports=Ha});var VS=S((x1,FS)=>{"use strict";var qa=class{constructor(t=[],r=void 0,s=[]){this.written_hashes=t,this.txn_time=r,this.original_records=s}};a(qa,"UpsertRecordsResponseObject");FS.exports=qa});var Qs=S((Q1,$S)=>{"use strict";var oy=X(),cy=HS(),_y=GS(),uy=VS(),Jn=as(),Qn=Ke().LMDB_ERRORS_ENUM,ly=Ye(),Dr=T(),Ey=b(),dy=require("uuid"),Y1=require("lmdb"),{handleHDBError:hy,hdb_errors:Sy}=D(),{OVERFLOW_MARKER:K1,MAX_SEARCH_KEY_LENGTH:W1}=ly,pu=Dr.TIME_STAMP_NAMES_ENUM.CREATED_TIME,cs=Dr.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function fy(e,t,r,s,n=!0){bu(e,t,r,s),Nu(e,t,r);let i=new cy,o=[],c=[];for(let _=0;_<s.length;_++){let u=s[_];kS(u,!0,n);let l=Ty(e,t,r,u),E=u[t];o.push(l),c.push(E)}return gu(o,c,s,i)}a(fy,"insertRecords");function Ty(e,t,r,s){let n=s[t];return e.dbis[t].ifNoExists(n,()=>{for(let i=0;i<r.length;i++){let o=r[i];if(o===t||s.hasOwnProperty(o)===!1)continue;let c=s[o];if(typeof c=="function"){let u=c([[{}]]);Array.isArray(u)&&(c=u[0][Dr.FUNC_VAL],s[o]=c)}let _=Jn.getIndexedValues(c);if(_)for(let u=0,l=_.length;u<l;u++)e.dbis[o].put(_[u],n)}e.dbis[t].put(n,s,s[cs])})}a(Ty,"insertRecord");function my(e,t=[]){let r=0;for(let s=0;s<t.length;s++){let n=t[s];e.splice(n-r,1),r++}}a(my,"removeSkippedRecords");function kS(e,t,r=!0){let s=Date.now();(r===!0||!Number.isInteger(e[cs]))&&(e[cs]=s),t===!0?(r===!0||!Number.isInteger(e[pu]))&&(e[pu]=s):delete e[pu]}a(kS,"setTimestamps");function Nu(e,t,r){r.indexOf(Dr.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(Dr.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(Dr.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(Dr.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),oy.initializeDBIs(e,t,r)}a(Nu,"initializeTransaction");async function Ry(e,t,r,s,n=!0){bu(e,t,r,s),Nu(e,t,r);let i=new _y,o=[],c=[],_=[];for(let u=0;u<s.length;u++){let l=s[u],E=l[t],d;try{d=Iu(e,t,l,E,i,!0,n)}catch{i.skipped_hashes.push(E),o.push(u);continue}c.push(d),_.push(E)}return gu(c,_,s,i,o)}a(Ry,"updateRecords");async function Ay(e,t,r,s,n=!0){try{bu(e,t,r,s)}catch(_){throw hy(_,_.message,Sy.HTTP_STATUS_CODES.BAD_REQUEST)}Nu(e,t,r);let i=new uy,o=[],c=[];for(let _=0;_<s.length;_++){let u=s[_],l;Ey.isEmpty(u[t])?(l=dy.v4(),u[t]=l):l=u[t];let E=Iu(e,t,u,l,i,!1,n);o.push(E),c.push(l)}return gu(o,c,s,i)}a(Ay,"upsertRecords");async function gu(e,t,r,s,n=[]){let i=await Promise.all(e);for(let o=0,c=i.length;o<c;o++)i[o]===!0?s.written_hashes.push(t[o]):(s.skipped_hashes.push(t[o]),n.push(o));return s.txn_time=Jn.getMicroTime(),my(r,n),s}a(gu,"finalizeWrite");function Iu(e,t,r,s,n,i=!1,o=!0){let c=e.dbis[t],_=c.getEntry(s),u=_?.value,l=u;if(!u){if(i)return!1;u={}}if(kS(r,!l,o),Number.isInteger(r[cs])&&u[cs]>r[cs])return!1;l&&n.original_records.push(u);let E,d=a(()=>{for(let m in r){if(!r.hasOwnProperty(m)||m===t)continue;let R=r[m],C=e.dbis[m];if(C===void 0)continue;let L=u[m];if(typeof R=="function"){let z=R([[u]]);Array.isArray(z)&&(R=z[0][Dr.FUNC_VAL],r[m]=R)}if(R===L)continue;let B=Jn.getIndexedValues(L);if(B)for(let z=0,V=B.length;z<V;z++)C.remove(B[z],s);if(B=Jn.getIndexedValues(R),B)for(let z=0,V=B.length;z<V;z++)C.put(B[z],s)}let h=Object.assign({},u,r);c.put(s,h,h[cs])},"do_put");return _?E=c.ifVersion(s,_.version,d):E=c.ifNoExists(s,d),E.then(h=>h?!0:Iu(e,t,r,s,n,i,o))}a(Iu,"updateUpsertRecord");function Oy(e,t,r){if(Jn.validateEnv(e),t===void 0)throw new Error(Qn.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(Qn.WRITE_ATTRIBUTES_REQUIRED):new Error(Qn.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(Oy,"validateBasic");function bu(e,t,r,s){if(Oy(e,t,r),!Array.isArray(s))throw s===void 0?new Error(Qn.RECORDS_REQUIRED):new Error(Qn.RECORDS_MUST_BE_ARRAY)}a(bu,"validateWrite");$S.exports={insertRecords:fy,updateRecords:Ry,upsertRecords:Ay}});var te=S((J1,YS)=>{"use strict";var wu=T(),Js=Y(),Cu=require("path");Js.initSync();var Ga,Fa,Va;function xS(){if(Ga!==void 0)return Ga;if(Js.getHdbBasePath()!==void 0)return Ga=Cu.join(Js.getHdbBasePath(),wu.SCHEMA_DIR_NAME),Ga}a(xS,"getBaseSchemaPath");function py(){if(Fa!==void 0)return Fa;if(Js.getHdbBasePath()!==void 0)return Fa=Cu.join(xS(),wu.SYSTEM_SCHEMA_NAME),Fa}a(py,"getSystemSchemaPath");function Ny(){if(Va!==void 0)return Va;if(Js.getHdbBasePath()!==void 0)return Va=Cu.join(Js.getHdbBasePath(),wu.TRANSACTIONS_DIR_NAME),Va}a(Ny,"getTransactionAuditStorePath");YS.exports={getBaseSchemaPath:xS,getSystemSchemaPath:py,getTransactionAuditStorePath:Ny}});var Er=S((X1,QS)=>{"use strict";var WS=b(),KS=T(),$a=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Lu=require("joi"),ka={schema_format:{pattern:$a,message:"names cannot include backticks or forward slashes"},schema_length:{maximum:250,tooLong:"cannot exceed 250 characters"}},gy=Lu.alternatives(Lu.string().min(1).max(ka.schema_length.maximum).pattern($a).messages({"string.pattern.base":"{:#label} "+ka.schema_format.message}),Lu.number()).required();function Iy(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>ka.schema_length.maximum?`'${e}' maximum of 250 characters`:$a.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(Iy,"checkValidTable");function by(e,t){return WS.doesSchemaExist(e)?e:t.message(`Schema '${e}' does not exist`)}a(by,"validateSchemaExists");function wy(e,t){let r=t.state.ancestors[0].schema;return WS.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(wy,"validateTableExists");function Cy(e,t){return e.toLowerCase()===KS.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid schema name, '${KS.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(Cy,"validateSchemaName");QS.exports={common_validators:ka,schema_regex:$a,hdb_schema_table:gy,validateSchemaExists:by,validateTableExists:wy,validateSchemaName:Cy,checkValidTable:Iy}});var xa=S((Z1,JS)=>{var{common_validators:Mr}=Er(),Xn=de(),Vt="is required",Z={schema:{presence:!0,format:Mr.schema_format,length:Mr.schema_length},table:{presence:!0,format:Mr.schema_format,length:Mr.schema_length},attribute:{presence:!0,format:Mr.schema_format,length:Mr.schema_length},hash_attribute:{presence:!0,format:Mr.schema_format,length:Mr.schema_length}};function Zn(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(Zn,"makeAttributesStrings");function Ly(e){return e=Zn(e),Z.schema.presence={message:Vt},Z.table.presence=!1,Z.attribute.presence=!1,Z.hash_attribute.presence=!1,Xn.validateObject(e,Z)}a(Ly,"schema_object");function Uy(e){return e=Zn(e),Z.schema.presence={message:Vt},Z.table.presence={message:Vt},Z.attribute.presence=!1,Z.hash_attribute.presence=!1,Xn.validateObject(e,Z)}a(Uy,"table_object");function yy(e){return e=Zn(e),Z.schema.presence={message:Vt},Z.table.presence={message:Vt},Z.attribute.presence=!1,Z.hash_attribute.presence={message:Vt},Xn.validateObject(e,Z)}a(yy,"create_table_object");function Dy(e){return e=Zn(e),Z.schema.presence={message:Vt},Z.table.presence={message:Vt},Z.attribute.presence={message:Vt},Z.hash_attribute.presence=!1,Xn.validateObject(e,Z)}a(Dy,"attribute_object");function My(e){return e=Zn(e),Z.schema.presence={message:Vt},Z.table.presence={message:Vt},Z.attribute.presence=!1,Z.hash_attribute.presence=!1,Xn.validateObject(e,Z)}a(My,"describe_table");function Py(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(Py,"validateTableResidence");JS.exports={schema_object:Ly,create_table_object:yy,table_object:Uy,attribute_object:Dy,describe_table:My,validateTableResidence:Py}});var ZS=S((z1,XS)=>{"use strict";var By=require("uuid"),Ya=class{constructor(t,r,s,n){this.schema=t,this.table=r,this.attribute=s,this.id=n||By.v4(),this.schema_table=`${this.schema}.${this.table}`}};a(Ya,"CreateAttributeObject");XS.exports=Ya});var Wa=S((j1,zS)=>{"use strict";var vy=ZS(),Ka=class extends vy{constructor(t,r,s,n,i=!0,o=!1){super(t,r,s,n),this.dup_sort=i,this.is_hash_attribute=o}};a(Ka,"LMDBCreateAttributeObject");zS.exports=Ka});var ef=S((eJ,jS)=>{"use strict";jS.exports=qy;var Hy="inserted";function qy(e,t,r,s){let n={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:s};return e===Hy?(n.inserted_hashes=t,n):(n.update_hashes=t,n)}a(qy,"returnObject")});var Qa=S((tJ,rf)=>{"use strict";var Gy=T(),Uu=X(),Fy=Qs(),{getSystemSchemaPath:Vy,getBaseSchemaPath:ky}=te(),$y=require("path"),xy=ts(),Yy=xa(),Ky=Wa(),Wy=ef(),{handleHDBError:Qy,hdb_errors:Jy}=D(),Xy=b(),yu=xy.hdb_attribute,tf=[];for(let e=0;e<yu.attributes.length;e++)tf.push(yu.attributes[e].attribute);var Zy="inserted";rf.exports=zy;async function zy(e){let t=Yy.attribute_object(e);if(t)throw Qy(new Error,t.message,Jy.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=Xy.isEmpty(e.dup_sort)||e.dup_sort=="true";let r=[];if(global.hdb_schema[e.schema]&&global.hdb_schema[e.schema][e.table]&&(r=global.hdb_schema[e.schema][e.table].attributes),Array.isArray(r)&&r.length>0){for(let n of r)if(n.attribute===e.attribute)throw new Error(`attribute '${n.attribute}' already exists in ${e.schema}.${e.table}`)}let s=new Ky(e.schema,e.table,e.attribute,e.id);try{let n=await Uu.openEnvironment($y.join(ky(),e.schema.toString()),e.table);if(n.dbis[e.attribute]!==void 0)throw new Error(`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`);Uu.createDBI(n,e.attribute,e.dup_sort,e.is_hash_attribute);let i=await Uu.openEnvironment(Vy(),Gy.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:o,skipped_hashes:c}=await Fy.insertRecords(i,yu.hash_attribute,tf,[s]);return Wy(Zy,o,{records:[s]},c)}catch(n){throw n}}a(zy,"lmdbCreateAttribute")});var Mu=S((rJ,nf)=>{var{hdb_schema_table:sf}=Er(),jy=de(),Du=require("joi"),eD={undefined:"undefined",null:"null"},tD=a((e,t)=>{let r=Object.keys(e),s=r.length,n;for(let i=0;i<s;i++){let o=r[i];(!o||o.length===0||eD[o]!==void 0)&&(n===void 0?n=`Invalid attribute name: '${o}'`:n+=`. Invalid attribute name: '${o}'`)}return n?t.message(n):e},"custom_records_val"),rD=Du.object({schema:sf,table:sf,records:Du.array().items(Du.object().custom(tD)).required()});nf.exports=function(e){return jy.validateBySchema(e,rD)}});var Ja=S((nJ,of)=>{"use strict";var dr=b(),af=I(),sJ=Mu();of.exports=sD;function sD(e){if(dr.isEmpty(e))throw new Error("invalid update parameters defined.");if(dr.isEmptyOrZeroLength(e.schema))throw new Error("invalid schema specified.");if(dr.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");if(!Array.isArray(e.records))throw new Error("records must be an array");let t=global.hdb_schema[e.schema][e.table];if(dr.isEmpty(t))throw new Error(`could not retrieve schema:${e.schema} and table ${e.table}`);let r=t.hash_attribute,s=new Set,n={},i=!1;return e.operation==="update"&&(i=!0),e.records.forEach(o=>{if(i&&dr.isEmptyOrZeroLength(o[r]))throw af.error("a valid hash attribute must be provided with update record:",o),new Error("a valid hash attribute must be provided with update record, check log for more info");if(!dr.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw af.error(`a valid hash value must be provided with ${e.operation} record:`,o),new Error(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!dr.isEmpty(o[r])&&o[r]!==""&&s.has(dr.autoCast(o[r]))&&(o.skip=!0),s.add(dr.autoCast(o[r]));for(let c in o)n[c]=1}),n[r]=1,{schema_table:t,hashes:Array.from(s),attributes:Object.keys(n)}}a(sD,"insertUpdateValidate")});var zn=S((iJ,cf)=>{"use strict";var nD=T().OPERATIONS_ENUM,Xa=class{constructor(t,r,s,n,i=void 0){this.operation=nD.INSERT,this.schema=t,this.table=r,this.hash_attribute=s,this.records=n,this.__origin=i}};a(Xa,"InsertObject");cf.exports=Xa});var za=S((oJ,_f)=>{"use strict";var aJ=zn(),Za=T(),Bu=b(),Pu=I(),iD=require("uuid"),{handleHDBError:jn,hdb_errors:aD}=D(),{HDB_ERROR_MSGS:ei,HTTP_STATUS_CODES:ti}=aD;_f.exports=oD;function oD(e,t,r){for(let n=0;n<t.length;n++)cD(t[n]);let{records:s}=e;for(let n=0;n<s.length;n++){let i=s[n];_D(i,r,e.operation)}}a(oD,"processRows");function cD(e){if(Buffer.byteLength(String(e))>Za.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw jn(new Error,ei.ATTR_NAME_LENGTH_ERR(e),ti.BAD_REQUEST,void 0,void 0,!0);if(Bu.isEmptyOrZeroLength(e)||Bu.isEmpty(e.trim()))throw jn(new Error,ei.ATTR_NAME_NULLISH_ERR,ti.BAD_REQUEST,void 0,void 0,!0)}a(cD,"validateAttribute");function _D(e,t,r){if(!e.hasOwnProperty(t)||Bu.isEmptyOrZeroLength(e[t])){if(r===Za.OPERATIONS_ENUM.INSERT||r===Za.OPERATIONS_ENUM.UPSERT){e[t]=iD.v4();return}throw Pu.error("Update transaction aborted due to record with no hash value:",e),jn(new Error,ei.RECORD_MISSING_HASH_ERR,ti.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>Za.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw Pu.error(e),jn(new Error,ei.HASH_VAL_LENGTH_ERR,ti.BAD_REQUEST,void 0,void 0,!0);if(isNaN(e[t])&&e[t].includes("/"))throw Pu.error(e),jn(new Error,ei.INVALID_FORWARD_SLASH_IN_HASH_ERR,ti.BAD_REQUEST,void 0,void 0,!0)}a(_D,"validateHash")});var lf=S((cJ,uf)=>{"use strict";var ja=class{constructor(t,r){this.type=t,this.message=r}};a(ja,"IPCEventObject");uf.exports=ja});var Pr=S((_J,Ef)=>{"use strict";var uD=I(),vu=b(),lD=T(),{IPC_ERRORS:ri}=Ke();Ef.exports={sendIpcEvent:ED,validateEvent:dD,SchemaEventMsg:hD,UserEventMsg:SD};function ED(e){global.hdb_ipc?global.hdb_ipc.emitToServer(e):uD.warn("Tried to send event:",e,"to HDB IPC client but it does not exist")}a(ED,"sendIpcEvent");function dD(e){if(typeof e!="object")return ri.INVALID_IPC_DATA_TYPE;if(!e.hasOwnProperty("type")||vu.isEmpty(e.type))return ri.MISSING_TYPE;if(!e.hasOwnProperty("message")||vu.isEmpty(e.message))return ri.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||vu.isEmpty(e.message.originator))return ri.MISSING_ORIGIN;if(lD.IPC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return ri.INVALID_EVENT(e.type)}a(dD,"validateEvent");function hD(e,t,r,s=void 0,n=void 0){this.originator=e,this.operation=t,this.schema=r,this.table=s,this.attribute=n}a(hD,"SchemaEventMsg");function SD(e){this.originator=e}a(SD,"UserEventMsg")});var Xs=S((lJ,ff)=>{"use strict";var df=T(),uJ=b(),eo=I(),hf=lf(),{sendIpcEvent:Sf}=Pr();function fD(e){try{eo.trace("signalSchemaChange called with message:",e);let t=new hf(df.IPC_EVENT_TYPES.SCHEMA,e);Sf(t)}catch(t){eo.error(t)}}a(fD,"signalSchemaChange");function TD(e){try{eo.trace("signalUserChange called with message:",e);let t=new hf(df.IPC_EVENT_TYPES.USER,e);Sf(t)}catch(t){eo.error(t)}}a(TD,"signalUserChange");ff.exports={signalSchemaChange:fD,signalUserChange:TD}});var to=S((EJ,mf)=>{"use strict";var Tf=b(),mD=T(),RD=I(),AD=Qa(),OD=Wa(),pD=Xs(),{SchemaEventMsg:ND}=Pr(),gD="already exists in";mf.exports=ID;async function ID(e,t,r){try{if(Tf.isEmptyOrZeroLength(r))return r;let s=[];Tf.isEmptyOrZeroLength(t.attributes)||t.attributes.forEach(i=>{s.push(i.attribute)});let n=r.filter(i=>s.indexOf(i)<0);return n.length===0||await Promise.all(n.map(async i=>{await bD(e,t.schema,t.name,i)})),n}catch(s){throw s}}a(ID,"lmdbCheckForNewAttributes");async function bD(e,t,r,s){let n=new OD(t,r,s,void 0,!0);e&&(n.hdb_auth_header=e);try{await wD(n)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(gD))RD.warn(`attribute ${t}.${r}.${s} already exists`);else throw i}}a(bD,"createNewAttribute");async function wD(e){let t;try{return t=await AD(e),pD.signalSchemaChange(new ND(process.pid,mD.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}catch(r){throw r}}a(wD,"createAttribute")});var Zs=S((dJ,Rf)=>{"use strict";var ro=class{constructor(t,r,s,n,i=void 0){this.operation=t,this.user_name=r,this.timestamp=s,this.hash_values=n,this.origin=i}};a(ro,"LMDBTransactionObject");Rf.exports=ro});var Of=S((hJ,Af)=>{"use strict";var CD=Zs(),LD=T().OPERATIONS_ENUM,so=class extends CD{constructor(t,r,s,n,i=void 0){super(LD.INSERT,r,s,n,i),this.records=t}};a(so,"LMDBInsertTransactionObject");Af.exports=so});var Nf=S((SJ,pf)=>{"use strict";var UD=Zs(),yD=T().OPERATIONS_ENUM,no=class extends UD{constructor(t,r,s,n,i,o=void 0){super(yD.UPDATE,s,n,i,o),this.records=t,this.original_records=r}};a(no,"LMDBUpdateTransactionObject");pf.exports=no});var If=S((fJ,gf)=>{"use strict";var DD=Zs(),MD=T().OPERATIONS_ENUM,io=class extends DD{constructor(t,r,s,n,i,o=void 0){super(MD.UPSERT,s,n,i,o),this.records=t,this.original_records=r}};a(io,"LMDBUpsertTransactionObject");gf.exports=io});var wf=S((TJ,bf)=>{"use strict";var PD=Zs(),BD=T().OPERATIONS_ENUM,ao=class extends PD{constructor(t,r,s,n,i=void 0){super(BD.DELETE,s,n,t,i),this.original_records=r}};a(ao,"LMDBDeleteTransactionObject");bf.exports=ao});var si=S((mJ,yf)=>{"use strict";var vD=require("path"),Cf=X(),HD=Of(),qD=Nf(),GD=If(),FD=wf(),zs=Ye(),Lf=b(),{CONFIG_PARAMS:VD}=T(),Uf=Y();Uf.initSync();var oo=T().OPERATIONS_ENUM,{getTransactionAuditStorePath:kD}=te();yf.exports=$D;async function $D(e,t){if(Uf.get(VD.LOGGING_AUDITLOG)===!1)return;let r=vD.join(kD(),e.schema.toString()),s=await Cf.openEnvironment(r,e.table,!0),n=xD(e,t);if(!(n===void 0||n.hash_values.length===0)&&s!==void 0){Cf.initializeDBIs(s,zs.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,zs.TRANSACTIONS_DBIS);try{let i=n.timestamp;return await s.dbis[zs.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{s.dbis[zs.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,n),Lf.isEmpty(n.user_name)||s.dbis[zs.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(n.user_name,i);for(let o=0;o<n.hash_values.length;o++)s.dbis[zs.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(n.hash_values[o],i)})}catch(i){throw i}}}a($D,"writeTransaction");function xD(e,t){let r=Lf.isEmpty(e.hdb_user)?void 0:e.hdb_user.username;if(e.operation===oo.INSERT)return new HD(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===oo.UPDATE)return new qD(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===oo.UPSERT)return new GD(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===oo.DELETE)return new FD(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(xD,"createTransactionObject")});var Hu=S((AJ,Df)=>{"use strict";var YD=Ja(),RJ=zn(),js=T(),KD=za(),WD=Qs().insertRecords,QD=X(),JD=require("path"),XD=I(),ZD=to(),{getBaseSchemaPath:zD}=te(),jD=si();Df.exports=eM;async function eM(e){try{let{schema_table:t,attributes:r}=YD(e);KD(e,r,t.hash_attribute),e.schema!==js.SYSTEM_SCHEMA_NAME&&(r.includes(js.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(js.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(js.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(js.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await ZD(e.hdb_auth_header,t,r),n=JD.join(zD(),e.schema.toString()),i=await QD.openEnvironment(n,e.table),o=await WD(i,t.hash_attribute,r,e.records,e[js.CLUSTERING_FLAG]!==!0);try{await jD(e,o)}catch(c){XD.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:s,txn_time:o.txn_time}}catch(t){throw t}}a(eM,"lmdbCreateRecords")});var Bf=S((OJ,Pf)=>{"use strict";var Mf=T(),tM=Hu(),rM=zn(),sM=require("fs-extra"),nM=require("path"),{getBaseSchemaPath:iM}=te();Pf.exports=aM;async function aM(e){let t=[{name:e.schema,createddate:Date.now()}],r=new rM(Mf.SYSTEM_SCHEMA_NAME,Mf.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await tM(r),await sM.mkdirp(nM.join(iM(),e.schema.toString()))}a(aM,"lmdbCreateSchema")});var Hf=S((pJ,vf)=>{"use strict";var co=class{constructor(t=[],r=[],s=void 0,n=[]){this.deleted=t,this.skipped=r,this.txn_time=s,this.original_records=n}};a(co,"DeleteRecordsResponseObject");vf.exports=co});var Fu=S((bJ,Ff)=>{"use strict";var qf=X(),qu=as(),Gu=Ke().LMDB_ERRORS_ENUM,oM=Ye(),Gf=I(),NJ=b(),cM=require("lmdb"),_M=Hf(),{OVERFLOW_MARKER:gJ,MAX_SEARCH_KEY_LENGTH:IJ}=oM;async function uM(e,t,r){if(qu.validateEnv(e),t===void 0)throw new Error(Gu.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(Gu.IDS_REQUIRED):new Error(Gu.IDS_MUST_BE_ARRAY);try{let s=qf.listDBIs(e);qf.initializeDBIs(e,t,s);let n=new _M,i,o=[],c=[];for(let E=0,d=r.length;E<d;E++)try{i=r[E];let h=e.dbis[t].get(i);if(!h){n.skipped.push(i);continue}let m=e.dbis[t].ifVersion(i,cM.IF_EXISTS,()=>{e.dbis[t].remove(i);for(let R=0;R<s.length;R++){let C=s[R];if(!h.hasOwnProperty(C)||C===t)continue;let L=e.dbis[C],B=h[C];if(B!=null)try{let z=qu.getIndexedValues(B);if(z)for(let V=0,Q=z.length;V<Q;V++)L.remove(z[V],i)}catch{Gf.warn(`cannot delete from attribute: ${C}, ${B}:${i}`)}}});o.push(m),c.push(i),n.original_records.push(h)}catch(h){Gf.warn(h),n.skipped.push(i)}let _=[],u=await Promise.all(o);for(let E=0,d=u.length;E<d;E++)u[E]===!0?n.deleted.push(c[E]):(n.skipped.push(c[E]),_.push(E));let l=0;for(let E=0;E<_.length;E++){let d=_[E];n.original_records.splice(d-l,1),l++}return n.txn_time=qu.getMicroTime(),n}catch(s){throw s}}a(uM,"deleteRecords");Ff.exports={deleteRecords:uM}});var ni=S((wJ,kf)=>{"use strict";var en=b(),lM=Fu(),EM=X(),dM=require("path"),{getBaseSchemaPath:hM}=te(),SM=si(),fM=I();kf.exports=TM;async function TM(e,t=!0){let s=global.hdb_schema[e.schema][e.table].hash_attribute;if(en.isEmpty(s))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(en.isEmptyOrZeroLength(e.hash_values)&&!en.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let _=e.records[c][s];en.isEmpty(_)||e.hash_values.push(_)}}if(en.isEmptyOrZeroLength(e.hash_values))return Vf([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(en.isEmptyOrZeroLength(e.records)){e.records=[];for(let c=0;c<e.hash_values.length;c++)e.records[c]={[s]:e.hash_values[c]}}let n=dM.join(hM(),e.schema.toString()),i=await EM.openEnvironment(n,e.table),o=await lM.deleteRecords(i,s,e.hash_values);try{t===!0&&await SM(e,o)}catch(c){fM.error(`unable to write transaction due to ${c.message}`)}return Vf(o.deleted,o.skipped,o.txn_time)}catch(n){throw n}}a(TM,"lmdbDeleteRecords");function Vf(e,t,r){let s=e.length+t.length,n=s===1?"record":"records";return{message:`${e.length} of ${s} ${n} successfully deleted`,deleted_hashes:e,skipped_hashes:t,txn_time:r}}a(Vf,"createDeleteResponse")});var ku=S((LJ,$f)=>{"use strict";var mM=T(),CJ=as();function Vu(e,t){let r=Object.create(null);if(t.length===1&&mM.SEARCH_WILDCARDS.indexOf(t[0])>=0)Object.assign(r,e);else for(let s=0;s<t.length;s++){let n=t[s],i=e[n];r[n]=i===void 0?null:i}return r}a(Vu,"parseRow");function RM(e,t,r,s){let n=Vu(r,e);s.push(n)}a(RM,"searchAll");function AM(e,t,r,s){let n=Vu(r,e);s[t]=n}a(AM,"searchAllToMap");function OM(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(OM,"iterateDBI");function _s(e,t,r,s,n){let i=Object.create(null);i[n]=e;let o;s===n?o=e:(o=t,s!==void 0&&(i[s]=o)),r[0].push(o),r[1].push(i)}a(_s,"pushResults");function pM(e,t,r,s,n,i){t.toString().endsWith(e)&&_s(t,r,s,n,i)}a(pM,"endsWith");function NM(e,t,r,s,n,i){t.toString().includes(e)&&_s(t,r,s,n,i)}a(NM,"contains");function gM(e,t,r,s,n,i){t>e&&_s(t,r,s,n,i)}a(gM,"greaterThanCompare");function IM(e,t,r,s,n,i){t>=e&&_s(t,r,s,n,i)}a(IM,"greaterThanEqualCompare");function bM(e,t,r,s,n,i){t<e&&_s(t,r,s,n,i)}a(bM,"lessThanCompare");function wM(e,t,r,s,n,i){t<=e&&_s(t,r,s,n,i)}a(wM,"lessThanEqualCompare");$f.exports={parseRow:Vu,searchAll:RM,searchAllToMap:AM,iterateDBI:OM,endsWith:pM,contains:NM,greaterThanCompare:gM,greaterThanEqualCompare:IM,lessThanCompare:bM,lessThanEqualCompare:wM,pushResults:_s}});var tn=S((DJ,Jf)=>{"use strict";var wt=X(),CM=I(),St=as(),Br=Ye(),ce=Ke().LMDB_ERRORS_ENUM,UJ=b(),LM=T(),kt=ku(),yJ=require("lmdb"),{OVERFLOW_MARKER:xf,MAX_SEARCH_KEY_LENGTH:UM}=Br,ii={lazy:!0};function Yf(e,t,r,s,n=!1,i=void 0,o=void 0){let c=Object.create(null),_=wt.openDBI(e,r);_[Br.DBI_DEFINITION_NAME].is_hash_attribute&&(t=r);let u=$u(e,t,r);for(let{key:l,value:E}of _.getRange({start:n?void 0:!1,end:n?!1:void 0,limit:i,offset:o,reverse:n}))s(u(l,E),E,c,t,r);return c}a(Yf,"iterateFullIndex");function ai(e,t,r,s,n,i=!1,o=void 0,c=void 0,_=!1,u=!1){let l=[[],[]],E=wt.openDBI(e,r),d=$u(e,t,r);E[Br.DBI_DEFINITION_NAME].is_hash_attribute&&(t=r);let h=i===!0?s:n,m=i===!0?n:s,R=i===!0?!_:!u,C=i===!0?u:_;for(let{key:L,value:B}of E.getRange({start:m,end:h,reverse:i,limit:o,offset:c,inclusiveEnd:R,exclusiveStart:C}))kt.pushResults(d(L,B),B,l,t,r);return l}a(ai,"iterateRangeBetween");function $u(e,t,r){let s;return function(n,i){if(typeof n=="string"&&n.endsWith(xf)){if(!s)if(t)s=wt.openDBI(e,t);else{let c=wt.listDBIs(e);for(let _=0,u=c.length;_<u&&(s=wt.openDBI(e,c[_]),!s[Br.DBI_DEFINITION_NAME].is_hash_attribute);_++);}n=s.get(i,ii)[r]}return n}}a($u,"getOverflowCheck");function yM(e,t,r,s=!1,n=void 0,i=void 0){if(St.validateEnv(e),t===void 0)throw new Error(ce.HASH_ATTRIBUTE_REQUIRED);_o(r),r=oi(e,r);let o=[],c=wt.openDBI(e,t);for(let{key:_,value:u}of c.getRange({start:s?void 0:!1,end:s?!1:void 0,limit:n,offset:i,reverse:s}))kt.searchAll(r,_,u,o);return o}a(yM,"searchAll");function DM(e,t,r,s=!1,n=void 0,i=void 0){if(St.validateEnv(e),t===void 0)throw new Error(ce.HASH_ATTRIBUTE_REQUIRED);return _o(r),r=oi(e,r),Yf(e,t,t,kt.searchAllToMap.bind(null,r),s,n,i)}a(DM,"searchAllToMap");function MM(e,t,r=!1,s=void 0,n=void 0){if(St.validateEnv(e),t===void 0)throw new Error(ce.ATTRIBUTE_REQUIRED);return Yf(e,void 0,t,kt.iterateDBI,r,s,n)}a(MM,"iterateDBI");function PM(e,t){if(St.validateEnv(e),t===void 0)throw new Error(ce.HASH_ATTRIBUTE_REQUIRED);return wt.statDBI(e,t).entryCount}a(PM,"countAll");function BM(e,t,r,s,n=!1,i=void 0,o=void 0){vr(e,r,s);let c=wt.openDBI(e,r);s=St.convertKeyValueToWrite(s);let _=[[],[]];if(c[Br.DBI_DEFINITION_NAME].is_hash_attribute){t=r;let u=c.get(s,ii);u!==void 0&&kt.pushResults(s,u,_,t,r)}else for(let u of c.getValues(s,{reverse:n,limit:i,offset:o}))kt.pushResults(s,u,_,t,r);return _}a(BM,"equals");function vM(e,t,r){return vr(e,t,r),wt.openDBI(e,t).getValuesCount(r)}a(vM,"count");function HM(e,t,r,s,n=!1,i=void 0,o=void 0){vr(e,r,s);let c=[[],[]],_=wt.openDBI(e,r);_[Br.DBI_DEFINITION_NAME].is_hash_attribute&&(t=r),s=St.convertKeyValueToWrite(s);let u=!0;if(typeof s=="number"&&(u=!1),n===!0){let l;for(let E of _.getKeys({start:s}))if(!E.startsWith(s)){l=E;break}l!==void 0&&(Number.isInteger(o)?o++:i++);for(let{key:E,value:d}of _.getRange({start:l,end:void 0,reverse:n,limit:i,offset:o}))if(E!==l){if(E.toString().startsWith(s))kt.pushResults(E,d,c,t,r);else if(u===!0)break}}else for(let{key:l,value:E}of _.getRange({start:s,reverse:n,limit:i,offset:o}))if(l.toString().startsWith(s))kt.pushResults(l,E,c,t,r);else if(u===!0)break;return c}a(HM,"startsWith");function qM(e,t,r,s,n=!1,i=void 0,o=void 0){return Kf(e,t,r,s,n,i,o,!0)}a(qM,"endsWith");function Kf(e,t,r,s,n=!1,i=void 0,o=void 0,c=!1){vr(e,r,s);let _=[[],[]],u=wt.openDBI(e,r);u[Br.DBI_DEFINITION_NAME].is_hash_attribute&&(t=r);let l=$u(e,t,r);o=Number.isInteger(o)?o:0;for(let d of u.getKeys({end:n?!1:void 0,reverse:n})){if(i===0)break;let h=d.toString();if(h.endsWith(xf))for(let m of u.getValues(d)){let R=l(d,m);(c?R.endsWith(s):R.includes(s))&&E(R,m)}else if(c?h.endsWith(s):h.includes(s))if(u[Br.DBI_DEFINITION_NAME].is_hash_attribute)E(d,d);else for(let m of u.getValues(d))E(d,m)}function E(d,h){if(o>0){o--;return}i!==0&&(kt.pushResults(d,h,_,t,r),i--)}return a(E,"found_match"),_}a(Kf,"contains");function GM(e,t,r,s,n=!1,i=void 0,o=void 0){vr(e,r,s);let c=typeof s,_;return c==="string"?_="\uFFFF":c==="number"?_=1/0:c==="boolean"&&(_=!0),ai(e,t,r,s,_,n,i,o,!0,!1)}a(GM,"greaterThan");function FM(e,t,r,s,n=!1,i=void 0,o=void 0){vr(e,r,s);let c=typeof s,_;return c==="string"?_="\uFFFF":c==="number"?_=1/0:c==="boolean"&&(_=!0),ai(e,t,r,s,_,n,i,o,!1,!1)}a(FM,"greaterThanEqual");function VM(e,t,r,s,n=!1,i=void 0,o=void 0){vr(e,r,s);let c=typeof s,_;return c==="string"?_="\0":c==="number"?_=-1/0:c==="boolean"&&(_=!1),ai(e,t,r,_,s,n,i,o,!1,!0)}a(VM,"lessThan");function kM(e,t,r,s,n=!1,i=void 0,o=void 0){vr(e,r,s);let c=typeof s,_;return c==="string"?_="\0":c==="number"?_=-1/0:c==="boolean"&&(_=!1),ai(e,t,r,_,s,n,i,o,!1,!1)}a(kM,"lessThanEqual");function $M(e,t,r,s,n,i=!1,o=void 0,c=void 0){if(St.validateEnv(e),r===void 0)throw new Error(ce.ATTRIBUTE_REQUIRED);if(s===void 0)throw new Error(ce.START_VALUE_REQUIRED);if(n===void 0)throw new Error(ce.END_VALUE_REQUIRED);if(s=St.convertKeyValueToWrite(s),n=St.convertKeyValueToWrite(n),s>n)throw new Error(ce.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return ai(e,t,r,s,n,i,o,c)}a($M,"between");function xM(e,t,r,s){if(St.validateEnv(e),t===void 0)throw new Error(ce.HASH_ATTRIBUTE_REQUIRED);if(_o(r),r=oi(e,r),s===void 0)throw new Error(ce.ID_REQUIRED);let n=null,i=e.dbis[t].get(s,r.length<3?ii:void 0);return i&&(n=kt.parseRow(i,r)),n}a(xM,"searchByHash");function YM(e,t,r){if(St.validateEnv(e),t===void 0)throw new Error(ce.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(ce.ID_REQUIRED);let s=!0;return e.dbis[t].get(r,ii)===void 0&&(s=!1),s}a(YM,"checkHashExists");function KM(e,t,r,s,n=[]){Qf(e,t,r,s,n);let i=Wf(e,t,r,s,n);return Object.values(i)}a(KM,"batchSearchByHash");function WM(e,t,r,s,n=[]){return Qf(e,t,r,s,n),Wf(e,t,r,s,n)}a(WM,"batchSearchByHashToMap");function Wf(e,t,r,s,n=[]){r=oi(e,r);let i=Object.create(null),o=r.length<3?ii:void 0;for(let c=0;c<s.length;c++){let _=s[c];try{let u=e.dbis[t].get(_,o);if(u){let l=kt.parseRow(u,r);i[_]=l}else n.push(_)}catch(u){throw CM.warn(u),u}}return i}a(Wf,"batchHashSearch");function Qf(e,t,r,s,n){if(St.validateEnv(e),t===void 0)throw new Error(ce.HASH_ATTRIBUTE_REQUIRED);if(_o(r),!Array.isArray(s))throw s===void 0?new Error(ce.IDS_REQUIRED):new Error(ce.IDS_MUST_BE_ARRAY);Array.isArray(n)||(n=[])}a(Qf,"initializeBatchSearchByHash");function _o(e){if(!Array.isArray(e))throw e===void 0?new Error(ce.FETCH_ATTRIBUTES_REQUIRED):new Error(ce.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(_o,"validateFetchAttributes");function vr(e,t,r){if(St.validateEnv(e),t===void 0)throw new Error(ce.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(ce.SEARCH_VALUE_REQUIRED);if(r?.length>UM)throw new Error(ce.SEARCH_VALUE_TOO_LARGE)}a(vr,"validateComparisonFunctions");function oi(e,t){return t.length===1&&LM.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=wt.listDBIs(e)),t}a(oi,"setGetWholeRowAttributes");Jf.exports={searchAll:yM,searchAllToMap:DM,count:vM,countAll:PM,equals:BM,startsWith:HM,endsWith:qM,contains:Kf,searchByHash:xM,setGetWholeRowAttributes:oi,batchSearchByHash:KM,batchSearchByHashToMap:WM,checkHashExists:YM,iterateDBI:MM,greaterThan:GM,greaterThanEqual:FM,lessThan:VM,lessThanEqual:kM,between:$M}});var ci=S((PJ,jf)=>{var Xf=require("lodash"),Zf=de(),W=require("joi"),QM=b(),{hdb_schema_table:$t,checkValidTable:zf}=Er(),{handleHDBError:JM,hdb_errors:XM}=D(),{HTTP_STATUS_CODES:ZM}=XM,MJ=W.object({schema:$t,table:$t,hash_values:W.array().min(1).items(W.alternatives(W.string(),W.number())).required(),get_attributes:W.array().min(1).items($t).required()}),zM=W.object({schema:$t,table:$t,search_attribute:$t,search_value:W.any().required(),get_attributes:W.array().min(1).items($t).required(),desc:W.bool(),limit:W.number().integer().min(1),offset:W.number().integer().min(0)}),jM=W.object({schema:$t,table:$t,operator:W.string().valid("and","or").default("and").lowercase(),offset:W.number().integer().min(0),limit:W.number().integer().min(1),get_attributes:W.array().min(1).items($t).required(),conditions:W.array().min(1).items(W.object({search_attribute:$t,search_type:W.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between").required(),search_value:W.when("search_type",{switch:[{is:"equals",then:W.any()},{is:"between",then:W.array().items(W.alternatives([W.string(),W.number()])).length(2)}],otherwise:W.alternatives(W.string(),W.number())}).required()})).required()});jf.exports=function(e,t){let r=null;switch(t){case"value":r=Zf.validateBySchema(e,zM);break;case"hashes":let i=function(o){n?n+=". "+o:n=o};var s=i;a(i,"addError");let n;i(zf("schema",e.schema)),i(zf("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"),n&&(r=new Error(n.trim()));break;case"conditions":r=Zf.validateBySchema(e,jM);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let n=QM.checkGlobalSchemaTable(e.schema,e.table);if(n)return JM(new Error,n,ZM.NOT_FOUND);let o=global.hdb_schema[e.schema][e.table].attributes,c=[...e.get_attributes];if(t==="value"&&c.push(e.search_attribute),t==="conditions")for(let u=0,l=e.conditions.length;u<l;u++){let E=e.conditions[u];c.push(E.search_attribute)}let _=Xf.filter(c,u=>u!=="*"&&u.attribute!=="*"&&!Xf.some(o,l=>l===u||l.attribute===u||l.attribute===u.attribute));if(_&&_.length>0){let u=_.join(", ");return u=u.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${u}'`)}}return r}});var xu=S((BJ,eT)=>{"use strict";var eP=X(),tP=ci(),rP=require("path"),{getBaseSchemaPath:sP}=te();eT.exports=nP;function nP(e){let t=tP(e,"hashes");if(t)throw t;let r=rP.join(sP(),e.schema.toString());return eP.openEnvironment(r,e.table)}a(nP,"initialize")});var Yu=S((vJ,tT)=>{"use strict";var iP=tn(),aP=xu();tT.exports=oP;async function oP(e){try{let t=await aP(e),r=global.hdb_schema[e.schema][e.table];return iP.batchSearchByHashToMap(t,r.hash_attribute,e.get_attributes,e.hash_values)}catch(t){throw t}}a(oP,"lmdbGetDataByHash")});var us=S((HJ,rT)=>{"use strict";var uo=class{constructor(t,r,s,n){this.schema=t,this.table=r,this.hash_values=s,this.get_attributes=n}};a(uo,"SearchByHashObject");rT.exports=uo});var nT=S((GJ,sT)=>{"use strict";var qJ=us(),cP=tn(),_P=xu();sT.exports=uP;async function uP(e){try{let t=await _P(e),r=global.hdb_schema[e.schema][e.table];return cP.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}catch(t){throw t}}a(uP,"lmdbSearchByHash")});var xt=S((FJ,iT)=>{"use strict";var lo=class{constructor(t,r,s,n,i,o,c,_=!1,u=void 0,l=void 0){this.schema=t,this.table=r,this.search_attribute=s,this.search_value=n,this.hash_attribute=i,this.get_attributes=o,this.end_value=c,this.reverse=_,this.limit=u,this.offset=l}};a(lo,"SearchObject");iT.exports=lo});var Eo=S((VJ,uT)=>{"use strict";var Qe=tn(),lP=X(),EP=require("path"),dP=b(),U=Ye(),ls=T(),{getBaseSchemaPath:hP}=te(),SP=ts(),aT=Ke().LMDB_ERRORS_ENUM,{compareKeys:rn}=require("ordered-binary"),hr=ls.SEARCH_WILDCARDS;async function fP(e,t,r){let s;e.schema===ls.SYSTEM_SCHEMA_NAME?s=SP[e.table]:s=global.hdb_schema[e.schema][e.table];let n=_T(e,s.hash_attribute,r,t);return oT(e,n,s.hash_attribute,r)}a(fP,"prepSearch");async function oT(e,t,r,s){let n=EP.join(hP(),e.schema.toString()),i=await lP.openEnvironment(n,e.table),o=cT(i,e,t,r);if([U.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,U.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,U.SEARCH_TYPES.SEARCH_ALL,U.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(RP(e,r)===!1)return s===!0?mP(o):o[1];let _=o[0];return s===!0?Qe.batchSearchByHashToMap(i,r,e.get_attributes,_):Qe.batchSearchByHash(i,r,e.get_attributes,_)}a(oT,"executeSearch");function cT(e,t,r,s){let n,i=s;t.get_attributes.indexOf(s)<0&&(i=void 0);let{reverse:o,limit:c,offset:_}=t;switch(o=typeof o=="boolean"?o:!1,c=Number.isInteger(c)?c:void 0,_=Number.isInteger(_)?_:void 0,r){case U.SEARCH_TYPES.EQUALS:n=Qe.equals(e,i,t.search_attribute,t.search_value,o,c,_);break;case U.SEARCH_TYPES.CONTAINS:n=Qe.contains(e,i,t.search_attribute,t.search_value,o,c,_);break;case U.SEARCH_TYPES.ENDS_WITH:case U.SEARCH_TYPES._ENDS_WITH:n=Qe.endsWith(e,i,t.search_attribute,t.search_value,o,c,_);break;case U.SEARCH_TYPES.STARTS_WITH:case U.SEARCH_TYPES._STARTS_WITH:n=Qe.startsWith(e,i,t.search_attribute,t.search_value,o,c,_);break;case U.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return Qe.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case U.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return Qe.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case U.SEARCH_TYPES.SEARCH_ALL:return Qe.searchAll(e,s,t.get_attributes,o,c,_);case U.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return Qe.searchAllToMap(e,s,t.get_attributes,o,c,_);case U.SEARCH_TYPES.BETWEEN:n=Qe.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,_);break;case U.SEARCH_TYPES.GREATER_THAN:case U.SEARCH_TYPES._GREATER_THAN:n=Qe.greaterThan(e,i,t.search_attribute,t.search_value,o,c,_);break;case U.SEARCH_TYPES.GREATER_THAN_EQUAL:case U.SEARCH_TYPES._GREATER_THAN_EQUAL:n=Qe.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,_);break;case U.SEARCH_TYPES.LESS_THAN:case U.SEARCH_TYPES._LESS_THAN:n=Qe.lessThan(e,i,t.search_attribute,t.search_value,o,c,_);break;case U.SEARCH_TYPES.LESS_THAN_EQUAL:case U.SEARCH_TYPES._LESS_THAN_EQUAL:n=Qe.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,_);break;default:return Object.create(null)}return n}a(cT,"searchByType");function TP(e){let t=e.search_type,r=e.search_attribute,s=e.search_value;switch(t){case U.SEARCH_TYPES.EQUALS:return n=>n[r]===s;case U.SEARCH_TYPES.CONTAINS:return n=>typeof n[r]=="string"&&n[r].includes(s);case U.SEARCH_TYPES.ENDS_WITH:case U.SEARCH_TYPES._ENDS_WITH:return n=>typeof n[r]=="string"&&n[r].endsWith(s);case U.SEARCH_TYPES.STARTS_WITH:case U.SEARCH_TYPES._STARTS_WITH:return n=>typeof n[r]=="string"&&n[r].startsWith(s);case U.SEARCH_TYPES.BETWEEN:return n=>{let i=n[r];return rn(i,s[0])>=0&&rn(i,s[1])<=0};case U.SEARCH_TYPES.GREATER_THAN:case U.SEARCH_TYPES._GREATER_THAN:return n=>rn(n[r],s)>0;case U.SEARCH_TYPES.GREATER_THAN_EQUAL:case U.SEARCH_TYPES._GREATER_THAN_EQUAL:return n=>rn(n[r],s)>=0;case U.SEARCH_TYPES.LESS_THAN:case U.SEARCH_TYPES._LESS_THAN:return n=>rn(n[r],s)<0;case U.SEARCH_TYPES.LESS_THAN_EQUAL:case U.SEARCH_TYPES._LESS_THAN_EQUAL:return n=>rn(n[r],s)<=0;default:return Object.create(null)}}a(TP,"filterByType");function mP(e){let t=Object.create(null);for(let r=0,s=e[0].length;r<s;r++)t[e[0][r]]=e[1][r];return t}a(mP,"createMapFromArrays");function RP(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 s=!1;for(let n=0;n<e.get_attributes.length;n++)if(r.indexOf(e.get_attributes[n])<0){s=!0;break}return s}a(RP,"checkToFetchMore");function _T(e,t,r,s){if(dP.isEmpty(s)){let n=e.search_value;typeof n=="object"?n=JSON.stringify(n):n=n.toString();let i=n.charAt(0),o=n.charAt(n.length-1),c=!1;if(e.search_attribute===t&&(c=!0),hr.indexOf(n)>-1)return r===!0?U.SEARCH_TYPES.SEARCH_ALL_TO_MAP:U.SEARCH_TYPES.SEARCH_ALL;if(n.indexOf(hr[0])<0&&n.indexOf(hr[1])<0)return c===!0?r===!0?U.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:U.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:U.SEARCH_TYPES.EQUALS;if(hr.indexOf(i)>=0&&hr.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),U.SEARCH_TYPES.CONTAINS;if(hr.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),U.SEARCH_TYPES.ENDS_WITH;if(hr.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),U.SEARCH_TYPES.STARTS_WITH;if(n.includes(hr[0])||n.includes(hr[1]))return U.SEARCH_TYPES.EQUALS;throw new Error(aT.UNKNOWN_SEARCH_TYPE)}else switch(s){case ls.VALUE_SEARCH_COMPARATORS.BETWEEN:return U.SEARCH_TYPES.BETWEEN;case ls.VALUE_SEARCH_COMPARATORS.GREATER:return U.SEARCH_TYPES.GREATER_THAN;case ls.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return U.SEARCH_TYPES.GREATER_THAN_EQUAL;case ls.VALUE_SEARCH_COMPARATORS.LESS:return U.SEARCH_TYPES.LESS_THAN;case ls.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return U.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(aT.UNKNOWN_SEARCH_TYPE)}}a(_T,"createSearchTypeFromSearchObject");uT.exports={executeSearch:oT,createSearchTypeFromSearchObject:_T,prepSearch:fP,searchByType:cT,filterByType:TP}});var ET=S(($J,lT)=>{"use strict";var kJ=xt(),AP=ci(),OP=b(),pP=T(),NP=Eo();lT.exports=gP;async function gP(e,t){if(!OP.isEmpty(t)&&pP.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let s=AP(e,"value");if(s)throw s;let n=!0;try{return await NP.prepSearch(e,t,n)}catch(i){throw i}}a(gP,"lmdbGetDataByValue")});var sn=S((YJ,dT)=>{"use strict";var xJ=xt(),IP=ci(),bP=b(),wP=T(),CP=Eo();dT.exports=LP;async function LP(e,t){if(!bP.isEmpty(t)&&wP.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let s=IP(e,"value");if(s)throw s;let n=!1;try{return await CP.prepSearch(e,t,n)}catch(i){throw i}}a(LP,"lmdbSearchByValue")});var ST=S((WJ,hT)=>{"use strict";var KJ=Ye(),ho=class{constructor(t,r,s,n,i=void 0,o=void 0,c="and"){this.schema=t,this.table=r,this.get_attributes=s,this.limit=i,this.offset=o,this.conditions=n,this.operator=c}};a(ho,"SearchByConditionsObject");var So=class{constructor(t,r,s){this.search_attribute=t,this.search_type=r,this.search_value=s}};a(So,"SearchCondition");var fo=class{constructor(t,r){this.attribute=t,this.desc=r}};a(fo,"SortAttribute");hT.exports={SearchByConditionsObject:ho,SearchCondition:So,SortAttribute:fo}});var OT=S((JJ,AT)=>{"use strict";var QJ=ST().SearchByConditionsObject,UP=xt(),yP=ci(),Ku=tn(),To=Ye(),RT=Eo(),DP=ku(),fT=require("lodash"),{getBaseSchemaPath:MP}=te(),PP=require("path"),BP=X(),{handleHDBError:TT,hdb_errors:vP}=D(),{HTTP_STATUS_CODES:HP}=vP,qP=1e8,GP={lazy:!0};AT.exports=FP;async function FP(e){try{let t=yP(e,"conditions");if(t)throw TT(t,t.message,HP.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=PP.join(MP(),e.schema.toString()),s=await BP.openEnvironment(r,e.table),n=global.hdb_schema[e.schema][e.table],i=fT.sortBy(e.conditions,o=>{if(o.estimated_count===void 0){let c=o.search_type;c===To.SEARCH_TYPES.EQUALS?o.estimated_count=Ku.count(s,o.search_attribute,o.search_value):c===To.SEARCH_TYPES.CONTAINS||c===To.SEARCH_TYPES.ENDS_WITH?o.estimated_count=1/0:o.estimated_count=qP}return o.estimated_count});if(!e.operator||e.operator.toLowerCase()==="and"){let[o]=await mT(s,e,i[0],n.hash_attribute),c=s.dbis[n.hash_attribute],_=i.slice(1).map(RT.filterByType),u=_.length,l=[],E=Ku.setGetWholeRowAttributes(s,e.get_attributes),d=e.offset>-1?e.offset:0,h=e.limit>-1?e.limit:1/0;e:for(let m of o){let R=c.get(m,GP);for(let C=0;C<u;C++)if(!_[C](R))continue e;if(d>0){d--;continue}if(h<=0)break;h--,l.push(DP.parseRow(R,E))}return l}else{let o=[],c=[];for(let _ of i){let[u]=await mT(s,e,_,n.hash_attribute);c.push(u)}if(o=fT.union(...c),e.limit>0||e.offset>0){let _=Number.isInteger(e.limit)?e.limit:o.length;o=o.splice(e.offset,_)}return Ku.batchSearchByHash(s,n.hash_attribute,e.get_attributes,o)}}catch(t){throw TT(t)}}a(FP,"lmdbSearchByConditions");async function mT(e,t,r,s){let n=new UP(t.schema,t.table,void 0,void 0,s,t.get_attributes),i=r.search_type;return n.search_attribute=r.search_attribute,i===To.SEARCH_TYPES.BETWEEN?(n.search_value=r.search_value[0],n.end_value=r.search_value[1]):n.search_value=r.search_value,RT.searchByType(e,n,i,s)}a(mT,"executeConditionSearch")});var _i=S((XJ,pT)=>{"use strict";var VP=T().OPERATIONS_ENUM,mo=class{constructor(t,r,s,n=void 0){this.operation=VP.DELETE,this.schema=t,this.table=r,this.hash_values=s,this.__origin=n}};a(mo,"DeleteObject");pT.exports=mo});var Wu=S((ZJ,NT)=>{"use strict";var Ro=class{constructor(t,r,s){this.schema=t,this.table=r,this.attribute=s}};a(Ro,"DropAttributeObject");NT.exports=Ro});var Ju=S((jJ,gT)=>{"use strict";var kP=xt(),$P=_i(),zJ=Wu(),zt=T(),xP=b(),Qu=X(),YP=ts(),KP=sn(),WP=ni(),{getBaseSchemaPath:QP}=te(),JP=require("path");gT.exports=XP;async function XP(e,t=!0){let r;e.schema===zt.SYSTEM_SCHEMA_NAME?r=YP[e.table]:r=global.hdb_schema[e.schema][e.table];let s=await zP(e),n=JP.join(QP(),e.schema.toString()),i=await Qu.openEnvironment(n,e.table);return t===!0&&await ZP(e,i,r.hash_attribute),Qu.dropDBI(i,e.attribute),s}a(XP,"lmdbDropAttribute");async function ZP(e,t,r){let s=Qu.openDBI(t,r),n,i=e.attribute;for(let{key:o,value:c,version:_}of s.getRange({start:!1,versions:!0})){let u={};for(let l in c)l!==i&&(u[l]=c[l]);n=t.dbis[r].put(o,u,_)}await n}a(ZP,"removeAttributeFromAllObjects");async function zP(e){let t=new kP(zt.SYSTEM_SCHEMA_NAME,zt.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,zt.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[zt.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,zt.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),s=(await KP(t)).filter(o=>o[zt.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(xP.isEmptyOrZeroLength(s))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let n=s.map(o=>o[zt.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new $P(zt.SYSTEM_SCHEMA_NAME,zt.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);return WP(i)}a(zP,"dropAttributeFromSystem")});var CT=S((eX,wT)=>{"use strict";var jP=Ju(),eB=Wu(),IT=b(),bT=I(),tB=Ke().LMDB_ERRORS_ENUM;wT.exports=rB;async function rB(e){if(IT.isEmpty(global.hdb_schema[e.schema])||IT.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);let t=global.hdb_schema[e.schema][e.table],r;try{for(let s=0;s<t.attributes.length;s++){r=t.attributes[s].attribute;let n=new eB(e.schema,e.table,r);try{await jP(n,!1)}catch(i){i.message!==tB.DBI_DOES_NOT_EXIST&&bT.error(`unable to drop attribute ${e.schema}.${e.table}.${r}:`+i)}}}catch(s){throw bT.error(`Error dropping attribute ${r}`),s}}a(rB,"lmdbDropAllAttributes")});var Xu=S((rX,HT)=>{"use strict";var MT=xt(),PT=_i(),BT=sn(),vT=ni(),tX=CT(),it=T(),LT=b(),UT=X(),{getBaseSchemaPath:sB,getTransactionAuditStorePath:nB}=te(),yT=require("path"),DT=I();HT.exports=iB;async function iB(e){try{if(LT.isEmpty(global.hdb_schema[e.schema])||LT.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await aB(e),await oB(e);let t=yT.join(sB(),e.schema.toString());try{await UT.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")DT.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=yT.join(nB(),e.schema.toString());await UT.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")DT.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(iB,"lmdbDropTable");async function aB(e){let t=new MT(it.SYSTEM_SCHEMA_NAME,it.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,it.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[it.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=await BT(t),s=[];for(let i=0;i<r.length;i++){let o=r[i];s.push(o.id)}if(s.length===0)return;let n=new PT(it.SYSTEM_SCHEMA_NAME,it.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);await vT(n)}a(aB,"deleteAttributesFromSystem");async function oB(e){let t=new MT(it.SYSTEM_SCHEMA_NAME,it.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,it.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[it.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,it.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,it.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,s;try{r=await BT(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&&(s=o)}if(!s)throw new Error(`${e.schema}.${e.table} was not found`);let n=new PT(it.SYSTEM_SCHEMA_NAME,it.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[s.id]);try{await vT(n)}catch(i){throw i}}a(oB,"dropTableFromSystem")});var GT=S((nX,qT)=>{"use strict";var cB=require("fs-extra"),_B=xt(),uB=us(),lB=_i(),EB=Xu(),dB=ni(),hB=Yu(),SB=sn(),Sr=T(),sX=b(),fB=require("path"),{getBaseSchemaPath:TB}=te(),{handleHDBError:mB,hdb_errors:RB}=D(),{HDB_ERROR_MSGS:AB,HTTP_STATUS_CODES:OB}=RB;qT.exports=pB;async function pB(e){let t;try{t=await NB(e.schema);let r=new _B(Sr.SYSTEM_SCHEMA_NAME,Sr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),s=await SB(r);for(let o=0;o<s.length;o++){let c={schema:t,table:s[o].name};try{await EB(c)}catch(_){if(_.message!=="invalid environment")throw _}}let n=new lB(Sr.SYSTEM_SCHEMA_NAME,Sr.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await dB(n);let i=fB.join(TB(),t.toString());await cB.remove(i)}catch(r){throw r}}a(pB,"lmdbDropSchema");async function NB(e){let t=new uB(Sr.SYSTEM_SCHEMA_NAME,Sr.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,s;try{r=await hB(t)}catch(n){throw n}for(let n in r)r[n].name===e&&(s=e);if(!s)throw mB(new Error,AB.SCHEMA_NOT_FOUND(e),OB.NOT_FOUND,void 0,void 0,!0);return s}a(NB,"validateDropSchema")});var Zu=S((iX,FT)=>{"use strict";var Ao=class{constructor(t,r,s){this.schema=t,this.table=r,this.hash_attribute=s}};a(Ao,"CreateTableObject");FT.exports=Ao});var kT=S((oX,VT)=>{"use strict";var gB=require("path"),IB=require("fs-extra"),Oo=X(),{getTransactionAuditStorePath:bB}=te(),zu=Ye(),aX=Zu();VT.exports=wB;async function wB(e){let t;try{let r=gB.join(bB(),e.schema.toString());await IB.mkdirp(r),t=await Oo.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{Oo.createDBI(t,zu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),Oo.createDBI(t,zu.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),Oo.createDBI(t,zu.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(wB,"createTransactionsAuditEnvironment")});var KT=S((cX,YT)=>{"use strict";var ju=T(),$T=X(),CB=Qs(),LB=require("path"),{getSystemSchemaPath:UB,getBaseSchemaPath:yB}=te(),DB=ts(),MB=Qa(),el=Wa(),PB=I(),BB=kT(),rl=DB.hdb_table,xT=[];for(let e=0;e<rl.attributes.length;e++)xT.push(rl.attributes[e].attribute);YT.exports=vB;async function vB(e,t){let r=LB.join(yB(),t.schema.toString()),s=new el(t.schema,t.table,ju.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),n=new el(t.schema,t.table,ju.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new el(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await $T.createEnvironment(r,t.table),e!==void 0){let o=await $T.openEnvironment(UB(),ju.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await CB.insertRecords(o,rl.hash_attribute,xT,[e]),await tl(s),await tl(n),await tl(i)}await BB(t)}catch(o){throw o}}a(vB,"lmdbCreateTable");async function tl(e){try{await MB(e)}catch(t){PB.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(tl,"createAttribute")});var QT=S((_X,WT)=>{"use strict";var HB=Ja(),qB=za(),GB=to(),nn=T(),FB=Qs().updateRecords,VB=X(),kB=require("path"),{getBaseSchemaPath:$B}=te(),xB=si(),YB=I();WT.exports=KB;async function KB(e){try{let{schema_table:t,attributes:r}=HB(e);qB(e,r,t.hash_attribute),e.schema!==nn.SYSTEM_SCHEMA_NAME&&(r.includes(nn.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(nn.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(nn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(nn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await GB(e.hdb_auth_header,t,r),n=kB.join($B(),e.schema.toString()),i=await VB.openEnvironment(n,e.table),o=await FB(i,t.hash_attribute,r,e.records,e[nn.CLUSTERING_FLAG]!==!0);try{await xB(e,o)}catch(c){YB.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:s,txn_time:o.txn_time}}catch(t){throw t}}a(KB,"lmdbUpdateRecords")});var XT=S((uX,JT)=>{"use strict";var WB=T().OPERATIONS_ENUM,po=class{constructor(t,r,s,n=void 0){this.operation=WB.UPSERT,this.schema=t,this.table=r,this.records=s,this.__origin=n}};a(po,"UpsertObject");JT.exports=po});var zT=S((EX,ZT)=>{"use strict";var lX=XT(),QB=Ja(),JB=za(),XB=to(),an=T(),ZB=Qs().upsertRecords,zB=X(),jB=require("path"),{getBaseSchemaPath:ev}=te(),tv=si(),rv=I(),{handleHDBError:sv,hdb_errors:nv}=D();ZT.exports=iv;async function iv(e){let t;try{t=QB(e)}catch(_){throw sv(_,_.message,nv.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:s}=t;JB(e,s,r.hash_attribute),e.schema!==an.SYSTEM_SCHEMA_NAME&&(s.includes(an.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||s.push(an.TIME_STAMP_NAMES_ENUM.CREATED_TIME),s.includes(an.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||s.push(an.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await XB(e.hdb_auth_header,r,s),i=jB.join(ev(),e.schema.toString()),o=await zB.openEnvironment(i,e.table),c=await ZB(o,r.hash_attribute,s,e.records,e[an.CLUSTERING_FLAG]!==!0);try{await tv(e,c)}catch(_){rv.error(`unable to write transaction due to ${_.message}`)}return{written_hashes:c.written_hashes,schema_table:r,new_attributes:n,txn_time:c.txn_time}}a(iv,"lmdbUpsertRecords")});var nm=S((dX,sm)=>{"use strict";var av=xt(),jT=b(),em=I(),ov=sn(),tm=T(),cv=Fu().deleteRecords,_v=X(),uv=require("path"),{getBaseSchemaPath:lv}=te(),{promisify:Ev}=require("util"),dv=Ev(setTimeout),rm=1e4,hv=10;sm.exports=Sv;async function Sv(e){let t=global.hdb_schema[e.schema][e.table].hash_attribute;if(jT.isEmptyOrZeroLength(t))throw new Error(`Could not retrieve hash attribute for schema: ${e.schema} table: ${e.table}`);let r=Date.parse(e.date),s;try{let n=new av(e.schema,e.table,tm.TIME_STAMP_NAMES_ENUM.CREATED_TIME,r,void 0,[t]);s=await ov(n,tm.VALUE_SEARCH_COMPARATORS.LESS)}catch(n){throw em.error(`Error searching for date: ${e.date} in schema: ${e.schema} table: ${e.table}`),n}return jT.isEmptyOrZeroLength(s)?(em.trace("No records found to delete"),{message:"No records found to delete"}):await fv(e,s,t)}a(Sv,"lmdbDeleteRecordsBefore");async function fv(e,t,r){let s=uv.join(lv(),e.schema.toString()),n=await _v.openEnvironment(s,e.table),i={message:"",deleted_hashes:[],skipped_hashes:[]};for(let o=0,c=t.length;o<c;o+=rm){let _=t.slice(o,o+rm),u=[];for(let l=0,E=_.length;l<E;l++)u.push(_[l][r]);try{let l=await cv(n,r,u);i.deleted_hashes=i.deleted_hashes.concat(l.deleted),i.skipped_hashes=i.skipped_hashes.concat(l.skipped)}catch(l){throw l}await dv(hv)}return i.message=`${i.deleted_hashes.length} of ${i.deleted_hashes.length+i.skipped_hashes.length} records successfully deleted`,i}a(fv,"chunkDeletes")});var am=S((hX,im)=>{"use strict";var No=class{constructor(t,r,s){this.schema=t,this.table=r,this.timestamp=s}};a(No,"DeleteBeforeObject");im.exports=No});var cm=S((SX,om)=>{"use strict";var go=class{constructor(t=void 0,r=void 0,s=0){this.start_timestamp=t,this.end_timestamp=r,this.transactions_deleted=s}};a(go,"DeleteAuditLogsBeforeResults");om.exports=go});var lm=S((TX,um)=>{"use strict";var sl=X(),{getTransactionAuditStorePath:Tv}=te(),fX=am(),mv=require("path"),ui=Ye(),Rv=b(),_m=cm(),Av=require("util").promisify,Ov=Av(setTimeout),pv=1e4,Nv=100;um.exports=gv;async function gv(e){let t=mv.join(Tv(),e.schema),r=await sl.openEnvironment(t,e.table,!0),s=sl.listDBIs(r);sl.initializeDBIs(r,ui.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,s);let n,i=new _m;do n=await Iv(r,e.timestamp),i.start_timestamp===void 0&&(i.start_timestamp=n.start_timestamp),n.end_timestamp!==void 0&&(i.end_timestamp=n.end_timestamp),i.transactions_deleted+=n.transactions_deleted,await Ov(Nv);while(n.transactions_deleted>0);return i}a(gv,"deleteAuditLogsBefore");async function Iv(e,t){let r=new _m;try{let s=e.dbis[ui.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],n;for(let{key:i,value:o}of s.getRange({start:!1})){if(i>=t)break;r.start_timestamp===void 0&&(r.start_timestamp=i),n=s.remove(i);let c=o[ui.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];Rv.isEmpty(c)||(n=e.dbis[ui.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let _=0;_<o.hash_values.length;_++)n=e.dbis[ui.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[_],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>pv)break}return await n,r}catch(s){throw s}}a(Iv,"deleteTransactions")});var mm=S((mX,Tm)=>{"use strict";var nl=X(),on=Ye(),Em=as(),il=T(),dm=b(),{getTransactionAuditStorePath:bv}=te(),wv=require("path"),Cv=tn(),Io=Zs(),Lv=I();Tm.exports=Uv;async function Uv(e){let t=wv.join(bv(),e.schema),r=await nl.openEnvironment(t,e.table,!0),s=nl.listDBIs(r);nl.initializeDBIs(r,on.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,s);let n;switch(e.search_type){case il.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return hm(r,e.search_values);case il.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return n=global.hdb_schema[e.schema][e.table].hash_attribute,Dv(r,e.search_values,n);case il.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return yv(r,e.search_values);default:return hm(r)}}a(Uv,"readAuditLog");function hm(e,t=[0,Em.getMicroTime()]){dm.isEmpty(t[0])&&(t[0]=0),dm.isEmpty(t[1])&&(t[1]=Em.getMicroTime());let r=[];try{let s=e.dbis[on.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],n;for(let i of s.getKeys({start:t[1]}))if(i!==t[1]){n=i;break}for(let{value:i}of s.getRange({start:t[0],end:n})){let o=Object.assign(new Io,i);r.push(o)}return r}catch(s){throw s}}a(hm,"searchTransactionsByTimestamp");function yv(e,t=[]){let r=new Map;for(let s=0;s<t.length;s++){let n=t[s],i=[];for(let o of e.dbis[on.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(n))i.push(o);r.set(n,fm(e,i))}return Object.fromEntries(r)}a(yv,"searchTransactionsByUsername");function Dv(e,t,r){let s=new Map;for(let c=0,_=t.length;c<_;c++){let u=t[c],l=Cv.equals(e,on.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,on.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,u);for(let E=0,d=l[0].length;E<d;E++){let h=l[0][E],m=Number(h);s.has(m)?s.get(m).push(u.toString()):s.set(m,[u.toString()])}}let n=Array.from(s.keys()),i=fm(e,n),o=new Map;for(let c=0;c<i.length;c++){let _=i[c],u=_.timestamp,l=s.get(u);Sm(_,"records",r,l,o),Sm(_,"original_records",r,l,o)}return Object.fromEntries(o)}a(Dv,"searchTransactionsByHashValues");function Sm(e,t,r,s,n){let i=e.timestamp;if(e[t])for(let o=0;o<e[t].length;o++){let c=e[t][o],_=c[r].toString();if(s.indexOf(_)>=0)if(n.has(_)){let u=n.get(_),l=u[u.length-1];if(l.timestamp===i)l[t]=[c];else{let E=new Io(e.operation,e.user_name,i,void 0);E[t]=[c],u.push(E)}}else{let u=new Io(e.operation,e.user_name,i,void 0);u[t]=[c],n.set(_,[u])}}}a(Sm,"loopRecords");function fm(e,t){let r=[];try{let s=e.dbis[on.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP];for(let n=0;n<t.length;n++)try{let i=s.get(t[n]);if(i){let o=Object.assign(new Io,i);r.push(o)}}catch(i){Lv.warn(i)}return r}catch(s){throw s}}a(fm,"batchSearchTransactions")});var Am=S((RX,Rm)=>{"use strict";var Mv=require("path"),{getBaseSchemaPath:Pv}=te(),Bv=X();Rm.exports={writeTransaction:vv};async function vv(e,t,r){let s=Mv.join(Pv(),e);return(await Bv.openEnvironment(s,t)).transaction(r)}a(vv,"writeTransaction")});var pm=S((AX,Om)=>{"use strict";var Hv=require("path"),{getBaseSchemaPath:qv}=te(),Gv=X();Om.exports={flush:Fv};async function Fv(e,t){let r=Hv.join(qv(),e.toString());return(await Gv.openEnvironment(r,t.toString())).flushed}a(Fv,"flush")});var gm=S((OX,Nm)=>{"use strict";var Re=I(),{handleHDBError:Vv}=D(),kv=_u(),$v=Qa(),xv=Hu(),Yv=Bf(),Kv=ni(),Wv=Yu(),Qv=nT(),Jv=ET(),Xv=sn(),Zv=OT(),zv=GT(),jv=KT(),eH=QT(),tH=zT(),rH=nm(),sH=lm(),nH=Xu(),iH=Ju(),aH=mm(),oH=Am(),cH=pm(),bo=class extends kv{async searchByConditions(t){try{return Zv(t)}catch(r){throw Re.error(r),r}}async getDataByHash(t){try{return await Wv(t)}catch(r){throw Re.error(r),r}}async searchByHash(t){try{return await Qv(t)}catch(r){throw Re.error(r),r}}async getDataByValue(t,r){try{return await Jv(t,r)}catch(s){throw Re.error(s),s}}async searchByValue(t){try{return await Xv(t)}catch(r){throw Re.error(r),r}}async createSchema(t){try{return await Yv(t)}catch(r){throw Re.error(r),r}}async dropSchema(t){try{return await zv(t)}catch(r){throw Re.error(r),r}}async createTable(t,r){try{return await jv(t,r)}catch(s){throw Re.error(s),s}}async dropTable(t){try{return await nH(t)}catch(r){throw Re.error(r),r}}async createAttribute(t){try{return await $v(t)}catch(r){throw Re.error(r),r}}async createRecords(t){try{return await xv(t)}catch(r){throw Re.error(r),r}}async updateRecords(t){try{return await eH(t)}catch(r){throw Re.error(r),r}}async upsertRecords(t){try{return await tH(t)}catch(r){throw Vv(r,null,null,Re.ERR,r)}}async deleteRecords(t){try{return await Kv(t)}catch(r){throw Re.error(r),r}}async deleteRecordsBefore(t){try{return await rH(t)}catch(r){throw Re.error(r),r}}async dropAttribute(t){try{return await iH(t)}catch(r){throw Re.error(r),r}}async deleteAuditLogsBefore(t){try{return await sH(t)}catch(r){throw Re.error(r),r}}async readAuditLog(t){try{return await aH(t)}catch(r){throw Re.error(r),r}}writeTransaction(t,r,s){return oH.writeTransaction(t,r,s)}flush(t,r){return cH.flush(t,r)}};a(bo,"LMDBBridge");Nm.exports=bo});var fr=S((pX,bm)=>{"use strict";var _H=gm(),uH=_u(),lH=Y();lH.initSync();var Im;function EH(){return Im instanceof uH?Im:new _H}a(EH,"getBridge");bm.exports=EH()});var Um=S((NX,Lm)=>{"use strict";var wm=require("lodash"),li=require("mathjs"),dH=require("jsonata"),Cm=b();Lm.exports={distinct_array:e=>Array.isArray(e)&&e.length>1?wm.uniqWith(e,wm.isEqual):e,searchJSON:hH,mad:Ei.bind(null,li.mad),mean:Ei.bind(null,li.mean),mode:Ei.bind(null,li.mode),prod:Ei.bind(null,li.prod),median:Ei.bind(null,li.median)};function Ei(e,t,r,s){return s===1?t==null?[]:[t]:s===2?(t!=null&&r.push(t),r):r!=null&&r.length>0?e(r):null}a(Ei,"aggregateFunction");function hH(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(Cm.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),Cm.isEmpty(this.__ala__.res[r])){let s=dH(e);this.__ala__.res[r]=s}return this.__ala__.res[r].evaluate(t)}a(hH,"searchJSON")});var Dm=S((gX,ym)=>{"use strict";var he=require("moment"),al="YYYY-MM-DDTHH:mm:ss.SSSZZ";he.suppressDeprecationWarnings=!0;ym.exports={current_date:()=>he().utc().format("YYYY-MM-DD"),current_time:()=>he().utc().format("HH:mm:ss.SSS"),extract:(e,t)=>{switch(t.toLowerCase()){case"year":return he(e).utc().format("YYYY");case"month":return he(e).utc().format("MM");case"day":return he(e).utc().format("DD");case"hour":return he(e).utc().format("HH");case"minute":return he(e).utc().format("mm");case"second":return he(e).utc().format("ss");case"millisecond":return he(e).utc().format("SSS");default:break}},date:e=>he(e).utc().format(al),date_format:(e,t)=>he(e).utc().format(t),date_add:(e,t,r)=>he(e).utc().add(t,r).valueOf(),date_sub:(e,t,r)=>he(e).utc().subtract(t,r).valueOf(),date_diff:(e,t,r)=>{let s=he(e).utc(),n=he(t).utc();return r?s.diff(n,r,!0):s.diff(n)},now:()=>he().utc().valueOf(),get_server_time:()=>he().format(al),offset_utc:(e,t)=>he(e).utc().utcOffset(t).format(al)}});var vm=S((IX,Bm)=>{"use strict";var SH=require("@turf/area"),fH=require("@turf/length"),TH=require("@turf/circle"),mH=require("@turf/difference"),RH=require("@turf/distance"),AH=require("@turf/boolean-contains"),OH=require("@turf/boolean-equal"),pH=require("@turf/boolean-disjoint"),NH=require("@turf/helpers"),Mm=T(),k=b();Bm.exports={geoArea:gH,geoLength:IH,geoCircle:bH,geoDifference:wH,geoDistance:Pm,geoNear:CH,geoContains:LH,geoEqual:UH,geoCrosses:yH,geoConvert:DH};var ol="geo1 is required",cl="geo2 is required";function gH(e){if(k.isEmpty(e))throw new Error("geoJSON is required");return typeof e=="string"&&(e=k.autoCast(e)),SH.default(e)}a(gH,"geoArea");function IH(e,t){if(k.isEmpty(e))throw new Error("geoJSON is required");return typeof e=="string"&&(e=k.autoCast(e)),fH.default(e,{units:t||"kilometers"})}a(IH,"geoLength");function bH(e,t,r){if(k.isEmpty(e))throw new Error("point is required");if(k.isEmpty(t))throw new Error("radius is required");return typeof e=="string"&&(e=k.autoCast(e)),TH.default(e,t,{units:r||"kilometers"})}a(bH,"geoCircle");function wH(e,t){if(k.isEmpty(e))throw new Error("poly1 is required");if(k.isEmpty(t))throw new Error("poly2 is required");return typeof e=="string"&&(e=k.autoCast(e)),typeof t=="string"&&(t=k.autoCast(t)),mH(e,t)}a(wH,"geoDifference");function Pm(e,t,r){if(k.isEmpty(e))throw new Error("point1 is required");if(k.isEmpty(t))throw new Error("point2 is required");return typeof e=="string"&&(e=k.autoCast(e)),typeof t=="string"&&(t=k.autoCast(t)),RH.default(e,t,{units:r||"kilometers"})}a(Pm,"geoDistance");function CH(e,t,r,s){if(k.isEmpty(e))throw new Error("point1 is required");if(k.isEmpty(t))throw new Error("point2 is required");if(k.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=k.autoCast(e)),typeof t=="string"&&(t=k.autoCast(t)),isNaN(r))throw new Error("distance must be a number");return Pm(e,t,s)<=r}a(CH,"geoNear");function LH(e,t){if(k.isEmpty(e))throw new Error(ol);if(k.isEmpty(e))throw new Error(cl);return typeof e=="string"&&(e=k.autoCast(e)),typeof t=="string"&&(t=k.autoCast(t)),AH.default(e,t)}a(LH,"geoContains");function UH(e,t){if(k.isEmpty(e))throw new Error(ol);if(k.isEmpty(e))throw new Error(cl);return typeof e=="string"&&(e=k.autoCast(e)),typeof t=="string"&&(t=k.autoCast(t)),OH.default(e,t)}a(UH,"geoEqual");function yH(e,t){if(k.isEmpty(e))throw new Error(ol);if(k.isEmpty(e))throw new Error(cl);return typeof e=="string"&&(e=k.autoCast(e)),typeof t=="string"&&(t=k.autoCast(t)),!pH.default(e,t)}a(yH,"geoCrosses");function DH(e,t,r){if(k.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if(k.isEmpty(t))throw new Error("geo_type is required");if(k.isEmpty(Mm.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(Mm.GEO_CONVERSION_ENUM).join(",")}`);return NH[t](e,r)}a(DH,"geoConvert")});var wo=S((bX,Hm)=>{var Es=Um(),ft=Dm(),jt=vm();Hm.exports=e=>{e.aggr.mad=e.aggr.MAD=Es.mad,e.aggr.mean=e.aggr.MEAN=Es.mean,e.aggr.mode=e.aggr.MODE=Es.mode,e.aggr.prod=e.aggr.PROD=Es.prod,e.aggr.median=e.aggr.MEDIAN=Es.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=Es.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=Es.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=ft.current_date,e.fn.current_time=e.fn.CURRENT_TIME=ft.current_time,e.fn.extract=e.fn.EXTRACT=ft.extract,e.fn.date=e.fn.DATE=ft.date,e.fn.date_format=e.fn.DATE_FORMAT=ft.date_format,e.fn.date_add=e.fn.DATE_ADD=ft.date_add,e.fn.date_sub=e.fn.DATE_SUB=ft.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=ft.date_diff,e.fn.now=e.fn.NOW=ft.now,e.fn.offset_utc=e.fn.OFFSET_UTC=ft.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=ft.get_server_time,e.fn.getdate=e.fn.GETDATE=ft.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=ft.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=jt.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=jt.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=jt.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=jt.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=jt.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=jt.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=jt.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=jt.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=jt.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=jt.geoNear}});var Fm=S((wX,Gm)=>{"use strict";var di=require("lodash"),Me=require("alasql");Me.options.cache=!1;var MH=wo(),qm=require("clone"),Co=require("recursive-iterator"),v=I(),q=b(),cn=fr(),PH=T(),{hdb_errors:BH}=D(),vH="IS NULL",hi="There was a problem performing this search. Please check the logs and try again.";MH(Me);var Lo=class{constructor(t,r){if(q.isEmpty(t))throw v.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(),q.backtickASTSchemaItems(this.statement)}async search(){let t;try{let s=await this._checkEmptySQL();if(!q.isEmptyOrZeroLength(s))return v.trace("No results returned from checkEmptySQL SQLSearch method."),s}catch(s){throw v.error("Error thrown from checkEmptySQL in SQLSearch class method search."),v.error(s),new Error(hi)}try{let s=await this._getFetchAttributeValues();if(s)return s}catch(s){throw v.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),v.error(s),new Error(hi)}if(Object.keys(this.data).length===0)return v.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(s){throw v.error("Error thrown from processJoins in SQLSearch class method search."),v.error(s),new Error(hi)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(s){throw v.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),v.error(s),new Error(hi)}try{return t=await this._finalSQL(),t}catch(s){throw v.error("Error thrown from finalSQL in SQLSearch class method search."),v.error(s),new Error(hi)}}_getColumns(){let t=new Co(this.statement);for(let{node:r,path:s}of t)r&&r.columnid&&(this.columns[s[0]]||(this.columns[s[0]]=[]),this.columns[s[0]].push(qm(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=di.uniqBy(t,r=>[r.databaseid,r.tableid,r.as].join()),this.tables.forEach(r=>{let s=`${r.databaseid}_${r.as?r.as:r.tableid}`;this.data[s]={},this.data[s].__hash_name=global.hdb_schema[r.databaseid][r.tableid].hash_attribute,this.data[s].__merged_data={},this.data[s].__merged_attributes=[],this.data[s].__merged_attr_map={}})}_conditionsToFetchAttributeValues(){if(q.isEmpty(this.statement.where)){v.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new Co(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!q.isEmpty(r)&&r.right)if(q.isNotEmptyAndHasValue(r.right.value)){let s=q.autoCast(r.right.value);[!0,!1].indexOf(s)>=0?r.right=new Me.yy.LogicValue({value:s}):r.right instanceof Me.yy.StringValue&&!q.isEmpty(s)&&q.autoCasterIsNumberCheck(s.toString())&&(r.right=new Me.yy.NumValue({value:s}))}else Array.isArray(r.right)&&r.right.forEach((s,n)=>{let i=q.autoCast(s.value);[!0,!1].indexOf(i)>=0?r.right[n]=new Me.yy.LogicValue({value:i}):s instanceof Me.yy.StringValue&&q.autoCasterIsNumberCheck(i.toString())&&(r.right[n]=new Me.yy.NumValue({value:i}))});if(t){v.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new Co(this.statement.where))if(r&&r.left&&r.right&&(r.left.columnid||r.right.value)&&r.op){let s=new Set,n=r.left.columnid?r.left:r.right,i=this._findColumn(n);if(!i)continue;let o=[i.table.databaseid,i.table.tableid,i.attribute].join("/");if(!q.isEmpty(PH.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(q.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(q.isEmptyOrZeroLength(r.left.columnid)||q.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(q.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"=":!q.isEmpty(r.right.value)||!q.isEmpty(r.left.value)?s.add(q.isEmpty(r.right.value)?r.left.value:r.right.value):c=!0;break;case"IN":let _=Array.isArray(r.right)?r.right:r.left;for(let u=0;u<_.length;u++)if(_[u].value)s.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,...s])}}}_setAliasesForColumns(){if(q.isEmptyOrZeroLength(this.all_table_attributes)&&q.isEmptyOrZeroLength(this.statement.from)&&q.isEmptyOrZeroLength(this.columns.columns))return;let t=[],r={};this.statement.columns.forEach((s,n)=>{if(s.columnid==="*"){t.push(n);return}if(s.aggregatorid&&(this.has_aggregator=!0),!s.aggregatorid&&!s.funcid)if(s.as_orig=s.as?s.as:s.columnid,this.statement.joins)if(r[s.as_orig]>=0){let i=r[s.as_orig]+1;s.as=`[${s.as_orig+i}]`,r[s.as_orig]=i}else s.as=`[${s.as_orig}]`,r[s.as_orig]=0;else s.as=`[${s.as_orig}]`;!s.aggregatorid&&s.funcid&&s.args&&(s.as_orig=s.as?s.as:s.toString().replace(/'/g,'"'),s.as=`[${s.as_orig}]`),s.aggregatorid&&s.expression.columnid!=="*"&&(s.as_orig=s.as?s.as:s.expression.tableid?`${s.aggregatorid}(${s.expression.tableid}.${s.expression.columnid})`:`${s.aggregatorid}(${s.expression.columnid})`,s.as=`[${s.as_orig}]`)}),this.statement.columns.length>1&&t.length>0&&di.pullAt(this.statement.columns,t)}_findColumn(t){let r=this.all_table_attributes.filter(s=>{if(t.columnid_orig&&t.tableid_orig)return(s.table.as===t.tableid_orig||s.table.tableid===t.tableid_orig)&&s.attribute===t.columnid_orig;if(t.tableid)return(s.table.as===t.tableid||s.table.tableid===t.tableid)&&s.attribute===t.columnid;let n=t.columnid_orig?t.columnid_orig:t.columnid;return s.attribute===n});if(q.isEmptyOrZeroLength(r)){let s=this.columns.columns.filter(n=>n.as?t.columnid===n.as:!1);q.isEmptyOrZeroLength(s)||(r=this.all_table_attributes.filter(n=>n.attribute===s[0].columnid&&s[0].tableid&&s[0].tableid===(n.table.as?n.table.as:n.table.tableid)))}return r[0]}async _checkEmptySQL(){let t=[];if(q.isEmptyOrZeroLength(this.all_table_attributes)&&!q.isEmptyOrZeroLength(this.columns.columns))return t;if(q.isEmptyOrZeroLength(this.all_table_attributes)&&q.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await Me.promise(r)}catch(r){throw v.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),v.error(r),new Error("There was a problem with the SQL statement")}return t}_addFetchColumns(t){t&&t.length>0&&t.forEach(r=>{let s=this._findColumn(r);s&&this.fetch_attributes.push(qm(s))})}_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,s,n){let i=this.data[t].__merged_attr_map[s];this.data[t].__merged_data[r].splice(i,1,n)}async _getFetchAttributeValues(){if(q.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(vH)>-1&&this.tables.forEach(n=>{let i={columnid:global.hdb_schema[n.databaseid][n.tableid].hash_attribute,tableid:n.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=di.uniqBy(this.fetch_attributes,n=>[n.table.databaseid,n.table.as?n.table.as:n.table.tableid,n.attribute].join()),r)return await this._simpleSQLQuery();let s=this.fetch_attributes.reduce((n,i)=>{let o=`${i.table.databaseid}_${i.table.as?i.table.as:i.table.tableid}`,c=this.data[o].__hash_name;return n[o]||(n[o]=[],n[o].push(null),this._addColumnToMergedAttributes(o,c)),i.attribute!==c&&(n[o].push(null),this._addColumnToMergedAttributes(o,i.attribute)),n},{});for(let n of this.fetch_attributes){let i=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`,o=this.data[i].__hash_name,c={schema:n.table.databaseid,table:n.table.tableid,get_attributes:[n.attribute]},_=!1,u=[n.table.databaseid,n.table.tableid,n.attribute].join("/");if(n.attribute===o&&(_=!0),!q.isEmpty(this.exact_search_values[u])&&!this.exact_search_values[u].ignore&&!q.isEmptyOrZeroLength(this.exact_search_values[u].values))if(_)try{c.hash_values=Array.from(this.exact_search_values[u].values);let l=await cn.getDataByHash(c);for(let E of c.hash_values)E in l&&!this.data[i].__merged_data[E]&&(this.data[i].__merged_data[E]=[...s[i]],this._setMergedHashAttribute(i,E))}catch(l){v.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),v.error(l)}else try{c.search_attribute=n.attribute,await Promise.all(Array.from(this.exact_search_values[u].values).map(async l=>{let E=Object.assign({},c);E.search_value=l;let d=await cn.getDataByValue(E);for(let h in d)this.data[i].__merged_data[h]?this._updateMergedAttribute(i,h,n.attribute,d[h][n.attribute]):(this.data[i].__merged_data[h]=[...s[i]],this._updateMergedAttribute(i,h,n.attribute,d[h][n.attribute]),this._setMergedHashAttribute(i,q.autoCast(h)))}))}catch(l){v.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),v.error(l)}else if(!q.isEmpty(this.comparator_search_values[u])&&!this.comparator_search_values[u].ignore&&!q.isEmptyOrZeroLength(this.comparator_search_values[u].comparators))try{let l=this.comparator_search_values[u].comparators;for(let E=0,d=l.length;E<d;E++){let h=l[E];c.search_attribute=h.attribute,c.search_value=h.search_value;let m=await cn.getDataByValue(c,h.operation);if(_)for(let R in m)this.data[i].__merged_data[R]||(this.data[i].__merged_data[R]=[...s[i]],this._setMergedHashAttribute(i,q.autoCast(R)));else for(let R in m)this.data[i].__merged_data[R]?this._updateMergedAttribute(i,R,n.attribute,m[R][n.attribute]):(this.data[i].__merged_data[R]=[...s[i]],this._updateMergedAttribute(i,R,n.attribute,m[R][n.attribute]),this._setMergedHashAttribute(i,q.autoCast(R)))}}catch(l){v.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),v.error(l)}else try{c.search_attribute=n.attribute,c.search_value="*";let l=await cn.getDataByValue(c);if(_)for(let E in l)this.data[i].__merged_data[E]||(this.data[i].__merged_data[E]=[...s[i]],this._setMergedHashAttribute(i,q.autoCast(E)));else for(let E in l)this.data[i].__merged_data[E]?this._updateMergedAttribute(i,E,n.attribute,l[E][n.attribute]):(this.data[i].__merged_data[E]=[...s[i]],this._updateMergedAttribute(i,E,n.attribute,l[E][n.attribute]),this._setMergedHashAttribute(i,q.autoCast(E)))}catch(l){v.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),v.error(l)}}}_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 Me.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(n=>{let i=n.aggregatorid?n.expression:n,o=n.aggregatorid?n.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 s=r[0];if(t.is_func=!!s.funcid,t.is_aggregator=!!s.aggregatorid,s.as)if(s.as&&!t.expression.tableid)t.expression.columnid=s.as,t.expression.columnid_orig=s.as_orig;else{let n=new Me.yy.Column;n.columnid=s.as,n.columnid_orig=s.as_orig,t.expression=n}else{t.initial_select_column=Object.assign(new Me.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 n=t.is_func?new Me.yy.FuncValue:new Me.yy.Column;t.initial_select_column=Object.assign(n,s)}})}_addNonAggregatorsToFetchColumns(){let r=this.statement.order.filter(s=>!s.is_aggregator&&!s.is_ordinal).map(s=>s.is_func?{columnid:s.initial_select_column.args.filter(i=>!!i.columnid_orig)[0].columnid_orig}:{columnid:s.expression.columnid_orig});this._addFetchColumns(r)}async _processJoins(){let t=[],r=[],s=this.statement.from[0],n=[s],i=["? "+(s.as?" AS "+s.as:s.tableid)];t.push(Object.values(this.data[`${s.databaseid_orig}_${s.as?s.as_orig:s.tableid_orig}`].__merged_data)),this.statement.joins&&this.statement.joins.forEach(h=>{h.joinmode&&h.joinmode!=="INNER"&&(this.has_outer_join=!0),n.push(h.table);let m=h.joinmode+" JOIN ? AS "+(h.as?h.as:h.table.tableid);h.on&&(m+=" ON "+h.on.toString()),i.push(m),t.push(Object.values(this.data[`${h.table.databaseid_orig}_${h.table.as?h.table.as_orig:h.table.tableid_orig}`].__merged_data))});let o=[],c={};n.forEach(h=>{let m=this.data[`${h.databaseid_orig}_${h.as?h.as_orig:h.tableid_orig}`].__hash_name,R=h.as?h.as_orig:h.tableid_orig;o.push({key:`'${R}.${m}'`,schema:h.databaseid_orig,table:h.as?h.as_orig:h.tableid_orig,keys:new Set}),r.push(`${h.as?h.as:h.tableid}.\`${m}\` AS "${R}.${m}"`),c[h.as?h.as_orig:h.tableid_orig]=this.data[`${h.databaseid_orig}_${h.as?h.as_orig:h.tableid_orig}`].__merged_attributes});let _=this.statement.where?"WHERE "+this.statement.where:"",u="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(u="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(h=>{h.is_func?r.push(h.initial_select_column.toString()):h.initial_select_column.tableid?r.push(`${h.initial_select_column.tableid}.${h.initial_select_column.columnid} AS ${h.expression.columnid}`):r.push(`${h.initial_select_column.columnid} AS ${h.expression.columnid}`)}));let l="",E="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&(l=this.statement.limit?"LIMIT "+this.statement.limit:"",E=this.statement.offset?"OFFSET "+this.statement.offset:"");let d=[];try{let h=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${_} ${u} ${l} ${E}`,m=this._convertColumnsToIndexes(h,n);d=await Me.promise(m,t),t=null}catch(h){throw v.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),v.error(h),new Error("There was a problem processing the data.")}if(d&&d.length>0){for(let h=0,m=d.length;h<m;h++){let R=d[h];o.forEach(C=>{R[C.key]!==null&&R[C.key]!==void 0&&C.keys.add(R[C.key])})}o.forEach(h=>{let m=Object.keys(this.data[`${h.schema}_${h.table}`].__merged_data),R=di.difference(m,[...h.keys].map(C=>C.toString()));for(let C=0,L=R.length;C<L;C++){let B=R[C];delete this.data[`${h.schema}_${h.table}`].__merged_data[B]}})}return{existing_attributes:c,joined_length:d?d.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let s=[],n=new Co(this.columns);for(let{node:i}of n)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)&&s.push(o)}}s=di.uniqBy(s,i=>[i.table.databaseid,i.table.as?i.table.as:i.table.tableid,i.attribute].join());try{await this._getData(s)}catch(i){v.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),v.error(i)}}async _getData(t){try{let r=t.reduce((s,n)=>{let i=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`;return s[i]?s[i].columns.push(n.attribute):s[i]={schema:n.table.databaseid,table:n.table.tableid,columns:[n.attribute]},s},{});for(let s in r){let n=r[s],i=this.data[s].__merged_data,o=[];for(let l in i)o.push(i[l][0]);this.data[s].__merged_attributes.push(...n.columns);let c={schema:n.schema,table:n.table,hash_values:o,get_attributes:n.columns},_=await cn.getDataByHash(c),u=n.columns.length;for(let l=0,E=o.length;l<E;l++){let d=o[l],h=_[d];for(let m=0;m<u;m++){let R=n.columns[m],C=h[R]===void 0?null:h[R];this.data[s].__merged_data[d].push(C)}}}}catch(r){throw v.error("Error thrown from getDataByHash function in SQLSearch class method getData."),v.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(n=>{n.as=n.as?n.as:n.table.tableid,t.push(Object.values(this.data[`${n.table.databaseid_orig}_${n.table.as?n.table.as_orig:n.table.tableid_orig}`].__merged_data)),n.table.databaseid="",n.table.tableid="?"}),this.statement.order&&this.statement.order.forEach(n=>{if(n.is_ordinal)return;this.statement.columns.filter(o=>{let c=o.aggregatorid?o.expression:o,_=o.aggregatorid?o.as_orig:c.as_orig;return n.expression.tableid?c.columnid_orig===n.expression.columnid_orig&&c.tableid_orig===n.expression.tableid_orig:c.columnid_orig===n.expression.columnid_orig||n.expression.columnid_orig===_}).length===0&&(n.expression.columnid=n.initial_select_column.columnid)}),!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&(this.statement.limit&&delete this.statement.limit,this.statement.offset&&delete this.statement.offset);let s;try{let n=this._buildSQL();v.trace(`Final SQL: ${n}`),s=await Me.promise(n,t),this.has_outer_join&&(s=this._translateUndefinedValues(s)),v.trace(`Final AlaSQL results data included ${s.length} rows`)}catch(n){throw v.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),v.error(n),new Error("There was a problem running the generated sql.")}return s}_translateUndefinedValues(t){try{let r=[];for(let s of t){let n=Object.create(null);Object.keys(s).forEach(i=>{s[i]===void 0?n[i]=null:n[i]=s[i]}),r.push(n)}return r}catch(r){return v.error(BH.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),v.trace(r.stack),t}}_buildSQL(t=!0){let r=this.statement.toString();return this.statement.columns.forEach(s=>{if(s.funcid&&s.as){let n=s.toString().replace(" AS "+s.as,"");r=r.replace(s.toString(),n)}}),t===!0?this._convertColumnsToIndexes(r,this.tables):r}_convertColumnsToIndexes(t,r){let s=t,n={};r.forEach(i=>{i.databaseid_orig?n[`${i.databaseid_orig}_${i.as?i.as_orig:i.tableid_orig}`]=i.as?i.as:i.tableid:n[`${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 _=n[i],u=new RegExp(`${_}.\`${o}\``,"g"),l=`${_}.[${c}]`;s=s.replace(u,l)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let _=new RegExp(`\`${o}\``,"g"),u=`[${c}]`;s=s.replace(_,u)});return s}async _simpleSQLQuery(){let t=this.statement.columns.reduce((s,n)=>(n.as_orig&&n.as_orig!=n.columnid_orig?s[n.columnid_orig]=n.as_orig:s[n.columnid_orig]||(s[n.columnid_orig]=n.columnid_orig),s),{}),r=this.fetch_attributes.reduce((s,n)=>{let i=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`;return s[i]||(s[i]={}),s[i][t[n.attribute]]=null,s},{});for(let s of this.fetch_attributes){let n=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`,i={schema:s.table.databaseid,table:s.table.tableid,get_attributes:[s.attribute]};try{i.search_attribute=s.attribute,i.search_value="*";let o=await cn.getDataByValue(i);for(let c in o)this.data[n].__merged_data[c]||(this.data[n].__merged_data[c]=Object.assign({},r[n])),this.data[n].__merged_data[c][t[s.attribute]]=o[c][s.attribute]}catch(o){v.error("There was an error when processing this SQL operation. Check your logs"),v.error(o)}}return Object.values(Object.values(this.data)[0].__merged_data)}};a(Lo,"SQLSearch");Gm.exports=Lo});var Tt=S((CX,km)=>{"use strict";var HH=eS();km.exports={searchByConditions:VH,searchByHash:kH,searchByValue:$H,search:xH};var _l=fr(),Vm=require("util"),qH=Vm.callbackify(_l.searchByHash),GH=Vm.callbackify(_l.searchByValue),FH=Fm();async function VH(e){return _l.searchByConditions(e)}a(VH,"searchByConditions");function kH(e,t){try{qH(e,(r,s)=>{if(r){t(r);return}t(null,s)})}catch(r){return t(r)}}a(kH,"searchByHash");function $H(e,t){try{e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc),GH(e,(r,s)=>{if(r){t(r);return}t(null,s)})}catch(r){return t(r)}}a($H,"searchByValue");function xH(e,t){try{let r=new HH(e);r.validate(),new FH(r.statement,r.attributes).search().then(n=>{t(null,n)}).catch(n=>{t(n,null)})}catch(r){return t(r)}}a(xH,"search")});var Hr=S((LX,Km)=>{"use strict";var Si=require("crypto"),xm="aes-256-cbc",YH=32,KH=16,ul=64,Ym=32,WH=ul+Ym,$m=new Map;Km.exports={encrypt:QH,decrypt:JH,createNatsTableStreamName:XH};function QH(e){let t=Si.randomBytes(YH),r=Si.randomBytes(KH),s=Si.createCipheriv(xm,Buffer.from(t),r),n=s.update(e);n=Buffer.concat([n,s.final()]);let i=t.toString("hex"),o=r.toString("hex"),c=n.toString("hex");return i+o+c}a(QH,"encrypt");function JH(e){let t=e.substr(0,ul),r=e.substr(ul,Ym),s=e.substr(WH,e.length),n=Buffer.from(r,"hex"),i=Buffer.from(s,"hex"),o=Si.createDecipheriv(xm,Buffer.from(t,"hex"),n),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(JH,"decrypt");function XH(e,t){let r=`${e}.${t}`,s=$m.get(r);return s||(s=Si.createHash("md5").update(`${e}.${t}`).digest("hex"),$m.set(r,s)),s}a(XH,"createNatsTableStreamName")});var ds=S((UX,jm)=>{"use strict";var Qm=Tt(),qr=I(),Jm=xa(),ZH=require("lodash"),zH=require("path"),jH=Hr(),ll=b(),{promisify:Xm}=require("util"),j=T(),{handleHDBError:Uo,hdb_errors:eq}=D(),{HDB_ERROR_MSGS:yo,HTTP_STATUS_CODES:Zm}=eq,tq=Y();tq.initSync();var Wm=X(),rq=te(),fi=Xm(Qm.searchByValue),sq=Xm(Qm.searchByHash),_n="name",zm="hash_attribute",El="schema",nq="schema_table",iq="attribute";jm.exports={describeAll:aq,describeTable:Do,describeSchema:cq};async function aq(e){try{let t=ll.isEmptyOrZeroLength(e),r,s;t||(r=e.hdb_user.role.permission,s=r.super_user||r.cluster_user);let n={schema:j.SYSTEM_SCHEMA_NAME,table:j.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,search_attribute:_n,search_value:j.WILDCARD_SEARCH_VALUE,get_attributes:[_n]},i=await fi(n);if(ll.isEmptyOrZeroLength(i))return{};let o={},c={};for(let d in i)o[i[d].name]=!0,!t&&!s&&(c[i[d].name]=r[i[d].name].describe);let _={schema:j.SYSTEM_SCHEMA_NAME,table:j.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,search_attribute:j.ID_ATTRIBUTE_STRING,search_value:j.WILDCARD_SEARCH_VALUE,get_attributes:[zm,j.ID_ATTRIBUTE_STRING,_n,El]},u=await fi(_),l=[];for(let d of u)try{let h;if(t||s)h=await Do({schema:d.schema,table:d.name});else if(r&&r[d.schema].describe&&r[d.schema].tables[d.name].describe){let m=r[d.schema].tables[d.name].attribute_permissions;h=await Do({schema:d.schema,table:d.name},m)}h&&l.push(h)}catch(h){qr.error(h)}let E={};for(let d in l)t||s?(E[l[d].schema]==null&&(E[l[d].schema]={}),E[l[d].schema][l[d].name]=l[d],o[l[d].schema]&&delete o[l[d].schema]):c[l[d].schema]&&(E[l[d].schema]==null&&(E[l[d].schema]={}),E[l[d].schema][l[d].name]=l[d],o[l[d].schema]&&delete o[l[d].schema]);for(let d in o)t||s?E[d]={}:c[d]&&(E[d]={});return E}catch(t){return qr.error("Got an error in describeAll"),qr.error(t),Uo(new Error,yo.DESCRIBE_ALL_ERR)}}a(aq,"describeAll");async function Do(e,t){let{schema:r,table:s}=e;r=r.toString(),s=s.toString();let n=t;e.hdb_user&&!e.hdb_user.role.permission.super_user&&(n=e.hdb_user.role.permission[r].tables[s].attribute_permissions);let i={},o=Jm.describe_table(e);if(o)throw o;if(r===j.SYSTEM_SCHEMA_NAME)return global.hdb_schema[j.SYSTEM_SCHEMA_NAME][s];let c={schema:j.SYSTEM_SCHEMA_NAME,table:j.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,hash_attribute:j.SYSTEM_TABLE_HASH_ATTRIBUTES.TABLE_TABLE_HASH_ATTRIBUTE,search_attribute:_n,search_value:s,hash_values:[],get_attributes:[j.WILDCARD_SEARCH_VALUE]},_=await fi(c);if(!_||_.length===0)throw Uo(new Error,yo.TABLE_NOT_FOUND(e.schema,e.table),Zm.NOT_FOUND);for await(let u of _)try{if(u.schema!==r)continue;if(i=u,!i.hash_attribute)throw Uo(new Error,yo.INVALID_TABLE_ERR(i));let l={schema:j.SYSTEM_SCHEMA_NAME,table:j.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,hash_attribute:j.SYSTEM_TABLE_HASH_ATTRIBUTES.ATTRIBUTE_TABLE_HASH_ATTRIBUTE,search_attribute:nq,search_value:r+"."+s,get_attributes:[iq]},E=await fi(l);E=ZH.uniqBy(E,d=>d.attribute),n&&n.length>0&&(E=oq(n)),i.attributes=E,i.clustering_stream_name=jH.createNatsTableStreamName(u.schema,u.name);try{let d=zH.join(rq.getBaseSchemaPath(),i.schema.toString()),h=await Wm.openEnvironment(d,i.name),m=Wm.statDBI(h,i.hash_attribute);i.record_count=m.entryCount}catch(d){qr.warn(`unable to stat table dbi due to ${d}`)}}catch(l){qr.error(`There was an error getting attributes for table '${u.name}'`),qr.error(l)}return i}a(Do,"descTable");function oq(e){return e.reduce((t,r)=>(r.describe&&t.push({attribute:r.attribute_name}),t),[])}a(oq,"getAttrsByPerms");async function cq(e){let t=Jm.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 s=e.schema.toString(),n={schema:j.SYSTEM_SCHEMA_NAME,table:j.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,hash_attribute:j.SYSTEM_TABLE_HASH_ATTRIBUTES.TABLE_TABLE_HASH_ATTRIBUTE,search_attribute:El,search_value:s,hash_values:[],get_attributes:[zm,j.ID_ATTRIBUTE_STRING,_n,El]},i=await fi(n);if(i&&i.length<1){let o={schema:j.SYSTEM_SCHEMA_NAME,table:j.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,hash_attribute:j.SYSTEM_TABLE_HASH_ATTRIBUTES.SCHEMA_TABLE_HASH_ATTRIBUTE,hash_values:[s],get_attributes:[_n]},c=await sq(o);if(c&&c.length<1)throw Uo(new Error,yo.SCHEMA_NOT_FOUND(e.schema),Zm.NOT_FOUND);return{}}else{let o={};return await Promise.all(i.map(async c=>{try{let _;if(r&&r.tables[c.name]&&(_=r.tables[c.name]),ll.isEmpty(_)||_.describe){let u=await Do({schema:e.schema,table:c.name},_?_.attribute_permissions:null);u&&(o[u.name]=u)}}catch(_){qr.error(`Error describing schema table '${e.schema}.${c}'`),qr.error(_)}})),o}}a(cq,"describeSchema")});var Gr=S((MX,nR)=>{var yX=require("async"),un=ts(),DX=I(),{callbackify:rR,promisify:_q}=require("util");nR.exports={setSchemaDataToGlobal:eR,getTableSchema:Eq,getSystemSchema:hq,setSchemaDataToGlobalAsync:_q(eR)};var sR=ds(),uq=rR(sR.describeAll),lq=rR(sR.describeTable);function eR(e){uq(null,(t,r)=>{if(t){e(t);return}r.system||(r.system=un),global.hdb_schema=r,e(null,null)})}a(eR,"setSchemaDataToGlobal");function tR(e,t){return e==="system"?un[t]:global.hdb_schema[e][t]}a(tR,"returnSchema");function Eq(e,t,r){!global.hdb_schema||!global.hdb_schema[e]||!global.hdb_schema[e][t]?dq(e,t,s=>{if(s)return r(s);if(!global.hdb_schema[e])return r(`schema ${e} does not exist`);if(!global.hdb_schema[e]||!global.hdb_schema[e][t])return r(`table ${e}.${t} does not exist`);r(null,tR(e,t))}):r(null,tR(e,t))}a(Eq,"getTableSchema");function dq(e,t,r){let s={table:t,schema:e};if(e==="system"){global.hdb_schema?global.hdb_schema.system=un:global.hdb_schema={system:un},r();return}lq(s,(n,i)=>{if(n){r(n);return}if(!i.schema&&!i.name){r();return}global.hdb_schema||(global.hdb_schema={system:un}),global.hdb_schema[e]||(global.hdb_schema[e]={}),global.hdb_schema[e][t]=i,r()})}a(dq,"setTableDataToGlobal");function hq(){return un}a(hq,"getSystemSchema")});var oR=S((PX,aR)=>{"use strict";var dl=X(),Sq=I(),iR=Ke().LMDB_ERRORS_ENUM;aR.exports=fq;async function fq(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 dl.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==iR.ENV_REQUIRED)throw c}}break;case"drop_table":let s=`${e.schema}.${e.table}`,n=`txn.${s}`;try{await dl.closeEnvironment(global.lmdb_map[s]),await dl.closeEnvironment(global.lmdb_map[n])}catch(i){if(i.message!==iR.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){Sq.error(t)}}a(fq,"cleanLMDBMap")});var Lt=S((BX,uR)=>{"use strict";var Po=Mu(),Ct=b(),Tq=require("util"),Bo=fr(),mq=Gr(),hl=I(),{handleHDBError:Fr,hdb_errors:Rq}=D(),{HTTP_STATUS_CODES:hs}=Rq,Aq=Tq.promisify(mq.getTableSchema),Oq="updated",cR="inserted",_R="upserted";uR.exports={insert:Nq,update:gq,upsert:Iq,validation:pq,flush:bq};async function pq(e){if(Ct.isEmpty(e))throw new Error("invalid update parameters defined.");if(Ct.isEmptyOrZeroLength(e.schema))throw new Error("invalid schema specified.");if(Ct.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await Aq(e.schema,e.table),r=Po(e);if(r)throw r;if(!Array.isArray(e.records))throw new Error("records must be an array");let s=t.hash_attribute,n=new Set,i={},o=!1;return e.operation==="update"&&(o=!0),e.records.forEach(c=>{if(o&&Ct.isEmptyOrZeroLength(c[s]))throw hl.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(!Ct.isEmptyOrZeroLength(c[s])&&(c[s]==="null"||c[s]==="undefined"))throw hl.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[s]}" is not a valid hash attribute value`);!Ct.isEmpty(c[s])&&c[s]!==""&&n.has(Ct.autoCast(c[s]))&&(c.skip=!0),n.add(Ct.autoCast(c[s]));for(let _ in c)i[_]=1}),i[s]=1,{schema_table:t,hashes:Array.from(n),attributes:Object.keys(i)}}a(pq,"validation");async function Nq(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=Po(e);if(t)throw Fr(new Error,t.message,hs.BAD_REQUEST);let r=Ct.checkSchemaTableExist(e.schema,e.table);if(r)throw Fr(new Error,r,hs.BAD_REQUEST);try{let s=await Bo.createRecords(e);return Mo(cR,s.written_hashes,e,s.skipped_hashes,s.new_attributes,s.txn_time)}catch(s){throw s}}a(Nq,"insertData");async function gq(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=Po(e);if(t)throw Fr(new Error,t.message,hs.BAD_REQUEST);let r=Ct.checkSchemaTableExist(e.schema,e.table);if(r)throw Fr(new Error,r,hs.BAD_REQUEST);try{let s=await Bo.updateRecords(e);return Ct.isEmpty(s.existing_rows)?Mo(Oq,s.written_hashes,e,s.skipped_hashes,s.new_attributes,s.txn_time):Mo(s.update_action,[],e,s.hashes,void 0,s.txn_time)}catch(s){throw s}}a(gq,"updateData");async function Iq(e){if(e.operation!=="upsert")throw Fr(new Error,"invalid operation, must be upsert",hs.INTERNAL_SERVER_ERROR);let t=Po(e);if(t)throw Fr(new Error,t.message,hs.BAD_REQUEST);let r=Ct.checkSchemaTableExist(e.schema,e.table);if(r)throw Fr(new Error,r,hs.BAD_REQUEST);try{let s=await Bo.upsertRecords(e);return Mo(_R,s.written_hashes,e,[],s.new_attributes,s.txn_time)}catch(s){let n=`There was an error during an upsert op: ${s}`;throw Fr(s,null,null,hl.ERR,n)}}a(Iq,"upsertData");function Mo(e,t,r,s,n,i){let o={message:`${e} ${t.length} of ${t.length+s.length} records`,new_attributes:n,txn_time:i};return e===cR?(o.inserted_hashes=t,o.skipped_hashes=s,o):e===_R?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=s,o)}a(Mo,"returnObject");function bq(e){return Bo.flush(e.schema,e.table)}a(bq,"flush")});var fl=S((vX,dR)=>{var wq=de(),Sl=require("joi"),{hdb_schema_table:lR}=Er(),ER={schema:lR,table:lR},Cq={date:Sl.date().iso().required()},Lq={timestamp:Sl.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};dR.exports=function(e,t){let r=t==="timestamp"?{...ER,...Lq}:{...ER,...Cq},s=Sl.object(r);return wq.validateBySchema(e,s)}});var TR=S((HX,fR)=>{var Uq=de(),hR=require("joi"),{hdb_schema_table:SR}=Er(),yq=hR.object({schema:SR,table:SR,hash_values:hR.array().required()});fR.exports=function(e){return Uq.validateBySchema(e,yq)}});var RR=S((qX,mR)=>{"use strict";var vo=class{constructor(t,r,s,n,i){this.operation=t,this.schema=r,this.table=s,this.hash_attribute=n,this.records=i}};a(vo,"InsertObject");var Ho=class{constructor(t,r,s,n,i,o){this.schema=t,this.table=r,this.search_attribute=s,this.hash_attribute=n,this.get_attributes=i,this.search_value=o}};a(Ho,"NoSQLSeachObject");var qo=class{constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};a(qo,"DeleteResponseObject");mR.exports={InsertObject:vo,NoSQLSeachObject:Ho,DeleteResponseObject:qo}});var fs=S((GX,gR)=>{"use strict";var OR=fl(),Dq=TR(),Go=b(),AR=require("moment"),pR=I(),{promisify:Mq,callbackify:Pq}=require("util"),Ss=T(),Bq=Gr(),Tl=Mq(Bq.getTableSchema),ml=fr(),{DeleteResponseObject:vq}=RR(),{handleHDBError:Vr,hdb_errors:Hq}=D(),{HDB_ERROR_MSGS:Fo,HTTP_STATUS_CODES:kr}=Hq,qq="records successfully deleted",Gq=Pq(NR);gR.exports={delete:Gq,deleteRecord:NR,deleteFilesBefore:Fq,deleteAuditLogsBefore:Vq};async function Fq(e){let t=OR(e,"date");if(t)throw Vr(t,t.message,kr.BAD_REQUEST,void 0,void 0,!0);if(!AR(e.date,AR.ISO_8601).isValid())throw Vr(new Error,Fo.INVALID_DATE,kr.BAD_REQUEST,Ss.LOG_LEVELS.ERROR,Fo.INVALID_DATE,!0);let s=Go.checkSchemaTableExist(e.schema,e.table);if(s)throw Vr(new Error,s,kr.NOT_FOUND,Ss.LOG_LEVELS.ERROR,s,!0);try{let n=await ml.deleteRecordsBefore(e);if(await Tl(e.schema,e.table),pR.info(`Finished deleting files before ${e.date}`),n&&n.message)return n.message}catch(n){throw n}}a(Fq,"deleteFilesBefore");async function Vq(e){let t=OR(e,"timestamp");if(t)throw Vr(t,t.message,kr.BAD_REQUEST,void 0,void 0,!0);if(isNaN(e.timestamp))throw Vr(new Error,Fo.INVALID_VALUE("Timestamp"),kr.BAD_REQUEST,Ss.LOG_LEVELS.ERROR,Fo.INVALID_VALUE("Timestamp"),!0);let r=Go.checkSchemaTableExist(e.schema,e.table);if(r)throw Vr(new Error,r,kr.NOT_FOUND,Ss.LOG_LEVELS.ERROR,r,!0);try{let s=await ml.deleteAuditLogsBefore(e);return await Tl(e.schema,e.table),pR.info(`Finished deleting audit logs before ${e.timestamp}`),s}catch(s){throw s}}a(Vq,"deleteAuditLogsBefore");async function NR(e){let t=Dq(e);if(t)throw Vr(t,t.message,kr.BAD_REQUEST,void 0,void 0,!0);let r=Go.checkSchemaTableExist(e.schema,e.table);if(r)throw Vr(new Error,r,kr.NOT_FOUND,Ss.LOG_LEVELS.ERROR,r,!0);try{await Tl(e.schema,e.table);let s=await ml.deleteRecords(e);return Go.isEmptyOrZeroLength(s.message)&&(s.message=`${s.deleted_hashes.length} of ${e.hash_values.length} ${qq}`),s}catch(s){if(s.message===Ss.SEARCH_NOT_FOUND_MESSAGE){let n=new vq;return n.message=Ss.SEARCH_NOT_FOUND_MESSAGE,n.skipped_hashes=e.hash_values.length,n.deleted_hashes=0,n}throw s}}a(NR,"deleteRecord")});var Vo=S((FX,wR)=>{var kq=require("crypto"),IR=9;function $q(e){let t=Yq(IR),r=bR(e+t);return t+r}a($q,"createHash");function xq(e,t){let r=e.substr(0,IR),s=r+bR(t+r);return e===s}a(xq,"validateHash");function Yq(e){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ",r=t.length,s="";for(let n=0;n<e;n++){let i=Math.floor(Math.random()*r);s+=t[i]}return s}a(Yq,"generateSalt");function bR(e){return kq.createHash("md5").update(e).digest("hex")}a(bR,"md5");wR.exports={hash:$q,validate:xq}});var LR=S((VX,CR)=>{var Rl=de(),Je={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 Kq(e){return Je.password.presence=!0,Je.username.presence=!0,Je.role.presence=!0,Je.active.presence=!0,Rl.validateObject(e,Je)}a(Kq,"addUserValidation");function Wq(e){return Je.password.presence=!1,Je.username.presence=!0,Je.role.presence=!1,Je.active.presence=!1,Rl.validateObject(e,Je)}a(Wq,"alterUserValidation");function Qq(e){return Je.password.presence=!1,Je.username.presence=!0,Je.role.presence=!1,Je.active.presence=!1,Rl.validateObject(e,Je)}a(Qq,"dropUserValidation");CR.exports={addUserValidation:Kq,alterUserValidation:Wq,dropUserValidation:Qq}});var _e=S(($X,yR)=>{"use strict";var{platform:kX}=require("os"),Jq="nats-server.zip",Al="nats-server",Xq=process.platform==="win32"?`${Al}.exe`:Al,Ol="HDB",Zq=/^[^\s.,*>]+$/,UR="__request__",zq=a(e=>`${e}.${UR}`,"REQUEST_SUBJECT"),jq={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},eG={HUB:"hub.pid",LEAF:"leaf.pid"},tG={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},rG={stream_name:"__HARPERDB_WORK_QUEUE__",durable_name:"HDB_WORK_QUEUE",deliver_group:Ol,deliver_subject:"__HDB__.WORKQUEUE"},sG={stream_name:"__HARPERDB_SCHEMA_QUEUE__",durable_name:"HDB_SCHEMA_QUEUE",deliver_group:Ol,deliver_subject:"HDB.SCHEMAQUEUE"},nG={stream_name:"__HARPERDB_USER_QUEUE__",durable_name:"HDB_USER_QUEUE",deliver_group:Ol,deliver_subject:"HDB.USERQUEUE"},iG={SUCCESS:"success",ERROR:"error"},aG={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},oG={TXN:"txn",MSGID:"msgid"};yR.exports={NATS_SERVER_ZIP:Jq,NATS_SERVER_NAME:Al,NATS_BINARY_NAME:Xq,PID_FILES:eG,NATS_CONFIG_FILES:jq,SERVER_SUFFIX:tG,WORK_QUEUE_CONSUMER_NAMES:rG,SCHEMA_QUEUE_CONSUMER_NAMES:sG,USER_QUEUE_CONSUMER_NAMES:nG,NATS_TERM_CONSTRAINTS_RX:Zq,REQUEST_SUFFIX:UR,UPDATE_REMOTE_RESPONSE_STATUSES:iG,CLUSTER_STATUS_STATUSES:aG,REQUEST_SUBJECT:zq,SUBJECT_PREFIXES:oG}});var MR=S((xX,DR)=>{"use strict";var $r=T(),Ti=class{constructor(t=0,r=$r.STORAGE_TYPES_ENUM.LMDB,s=$r.LICENSE_VALUES.API_CALL_DEFAULT,n=$r.RAM_ALLOCATION_ENUM.DEFAULT,i=$r.LICENSE_VALUES.VERSION_DEFAULT,o){this.exp_date=t,this.storage_type=r,this.api_call=s,this.ram_allocation=n,this.version=i,this.fingerprint=o}};a(Ti,"BaseLicense");var ko=class extends Ti{constructor(t=0,r=$r.STORAGE_TYPES_ENUM.LMDB,s=$r.LICENSE_VALUES.API_CALL_DEFAULT,n=$r.RAM_ALLOCATION_ENUM.DEFAULT,i=$r.LICENSE_VALUES.VERSION_DEFAULT,o,c=!1){super(t,r,s,n,i,o),this.enterprise=c}};a(ko,"ExtendedLicense");DR.exports={BaseLicense:Ti,ExtendedLicense:ko}});var mi=S((YX,GR)=>{"use strict";var En=require("fs-extra"),PR=Vo(),BR=require("crypto"),cG=require("moment"),_G=require("uuid").v4,Xe=I(),Nl=require("path"),uG=b(),mt=T(),lG=MR().ExtendedLicense,ln="invalid license key format",EG="061183",dG="mofi25",hG="aes-256-cbc",SG=16,fG=32,vR=Y();vR.initSync();var pl;GR.exports={validateLicense:HR,generateFingerPrint:mG,licenseSearch:qR,getLicense:OG};function gl(){return Nl.join(vR.getHdbBasePath(),mt.LICENSE_KEY_DIR_NAME,mt.LICENSE_FILE_NAME)}a(gl,"getLicenseDirPath");function TG(){let e=gl();return Nl.join(e,mt.LICENSE_FILE_NAME)}a(TG,"getLicenseFilePath");function Il(){let e=gl();return Nl.join(e,mt.REG_KEY_FILE_NAME)}a(Il,"getFingerPrintFilePath");async function mG(){let e=Il();try{return await En.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await RG();throw Xe.error(`Error writing fingerprint file to ${e}`),Xe.error(t),new Error("There was an error generating the fingerprint")}}a(mG,"generateFingerPrint");async function RG(){let e=_G(),t=PR.hash(e),r=Il();try{await En.mkdirp(gl()),await En.writeFile(r,t)}catch(s){if(s.code==="EEXIST")return t;throw Xe.error(`Error writing fingerprint file to ${r}`),Xe.error(s),new Error("There was an error generating the fingerprint")}return t}a(RG,"writeFingerprint");function HR(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,storage_type:mt.STORAGE_TYPES_ENUM.LMDB,api_call:mt.LICENSE_VALUES.API_CALL_DEFAULT,ram_allocation:mt.RAM_ALLOCATION_ENUM.DEFAULT,version:mt.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return Xe.error("empty license key passed to validate."),r;let s=Il(),n=!1;try{n=En.statSync(s)}catch(i){Xe.error(i)}if(n){let i;try{i=En.readFileSync(s,"utf8")}catch{Xe.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(dG),c=o[1];c=Buffer.concat([Buffer.from(c)],SG);let _=Buffer.concat([Buffer.from(i)],fG),u=BR.createDecipheriv(hG,_,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let l=null;try{l=u.update(o[0],"hex","utf8"),l.trim(),l+=u.final("utf8")}catch{let h=AG(o[0],i);if(h)l=h;else throw r.valid_license=!1,r.valid_machine=!1,console.error(ln),Xe.error(ln),new Error(ln)}let E;if(isNaN(l))try{E=JSON.parse(l),r.api_call=E.api_call,r.version=E.version,r.storage_type=E.storage_type,r.exp_date=E.exp_date,isNaN(r.exp_date)&&(r.exp_date=new Date(r.exp_date).getTime()),E.ram_allocation&&(r.ram_allocation=E.ram_allocation)}catch{throw console.error(ln),Xe.error(ln),new Error(ln)}else r.exp_date=l;r.exp_date<cG().valueOf()&&(r.valid_date=!1),PR.validate(o[1],`${EG}${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||Xe.error("Invalid licence"),r}a(HR,"validateLicense");function AG(e,t){try{let r=BR.createDecipher("aes192",t),s=r.update(e,"hex","utf8");return s.trim(),s+=r.final("utf8"),s}catch{Xe.warn("Check old license failed")}}a(AG,"checkOldLicense");function qR(){let e=new lG;e.api_call=0;let t=[];try{t=En.readFileSync(TG(),"utf-8").split(mt.NEW_LINE)}catch(r){r.code==="ENOENT"?Xe.info("no license file found"):Xe.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let s=t[r];try{if(uG.isEmptyOrZeroLength(s))continue;let n=JSON.parse(s),i=HR(n.license_key,n.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.api_call+=i.api_call,e.ram_allocation=i.ram_allocation,e.storage_type=i.storage_type,e.enterprise=!0)}catch(n){Xe.error("There was an error parsing the license string."),Xe.error(n),e.api_call=mt.LICENSE_VALUES.API_CALL_DEFAULT,e.ram_allocation=mt.RAM_ALLOCATION_ENUM.DEFAULT,e.storage_type=mt.STORAGE_TYPES_ENUM.LMDB,e.enterprise=!1}}return e.api_call===0&&(e.api_call=mt.LICENSE_VALUES.API_CALL_DEFAULT),pl=e,e}a(qR,"licenseSearch");async function OG(){return pl||await qR(),pl}a(OG,"getLicense")});var xr=S((KX,jR)=>{"use strict";var $R="username is required",xR="nothing to update, must supply active, role or password to update",YR="password cannot be an empty string",KR="If role is specified, it cannot be empty.",WR="active must be true or false";jR.exports={addUser:LG,alterUser:UG,dropUser:DG,userInfo:MG,listUsers:xo,listUsersExternal:PG,setUsersToGlobal:Ri,findAndValidateUser:HG,getClusterUser:qG,USERNAME_REQUIRED:$R,ALTERUSER_NOTHING_TO_UPDATE:xR,EMPTY_PASSWORD:YR,EMPTY_ROLE:KR,ACTIVE_BOOLEAN:WR};var QR=Lt(),pG=fs(),wl=Vo(),JR=LR(),XR=Tt(),Cl=Xs(),be=b(),ZR=require("validate.js"),H=I(),{promisify:Ll}=require("util"),Ul=Hr(),Ts=T(),FR=_e(),NG=ur(),yl=Y(),gG=mi(),IG=ts(),{handleHDBError:er,hdb_errors:bG}=D(),{HTTP_STATUS_CODES:tr,AUTHENTICATION_ERROR_MSGS:bl,HDB_ERROR_MSGS:dn}=bG,{UserEventMsg:Dl}=Pr(),VR=require("lodash"),zR={username:!0,active:!0,role:!0,password:!0},kR=new Map,$o=Ll(XR.searchByValue),wG=Ll(XR.searchByHash),CG=Ll(pG.delete);async function LG(e){let t=ZR.cleanAttributes(e,zR),r=JR.addUserValidation(t);if(r)throw er(new Error,r.message,tr.BAD_REQUEST,void 0,void 0,!0);let s={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["id","permission","role"]},n;try{n=await $o(s)}catch(u){throw H.error("There was an error searching for a role in add user"),H.error(u),u}if(!n||n.length<1)throw er(new Error,dn.ROLE_NAME_NOT_FOUND(t.role),tr.NOT_FOUND,void 0,void 0,!0);if(n.length>1)throw er(new Error,dn.DUP_ROLES_FOUND(t.role),tr.CONFLICT,void 0,void 0,!0);n[0].permission.cluster_user===!0&&(t.hash=Ul.encrypt(t.password)),t.password=wl.hash(t.password),t.role=n[0].id;let i={operation:"insert",schema:"system",table:"hdb_user",records:[t]},o;try{o=await QR.insert(i)}catch(u){throw H.error("There was an error searching for a user."),H.error(u),u}H.debug(o);try{await Ri()}catch(u){throw H.error("Got an error setting users to global"),H.error(u),u}if(o.skipped_hashes.length===1)throw er(new Error,dn.USER_ALREADY_EXISTS(t.username),tr.CONFLICT,void 0,void 0,!0);let c=Object.assign({},t);c.role=n[0];let _={user:null};return _.user=c,be.sendTransactionToSocketCluster(Ts.INTERNAL_SC_CHANNELS.ADD_USER,_,yl.get(Ts.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY)),Cl.signalUserChange(new Dl(process.pid)),`${c.username} successfully added`}a(LG,"addUser");async function UG(e){let t=ZR.cleanAttributes(e,zR);if(be.isEmptyOrZeroLength(t.username))throw new Error($R);if(be.isEmptyOrZeroLength(t.password)&&be.isEmptyOrZeroLength(t.role)&&be.isEmptyOrZeroLength(t.active))throw new Error(xR);if(!be.isEmpty(t.password)&&be.isEmptyOrZeroLength(t.password.trim()))throw new Error(YR);if(!be.isEmpty(t.active)&&!be.isBoolean(t.active))throw new Error(WR);let r=yG(t.username);if(!be.isEmpty(t.password)&&!be.isEmptyOrZeroLength(t.password.trim())&&(r&&(t.hash=Ul.encrypt(t.password)),t.password=wl.hash(t.password)),t.role==="")throw new Error(KR);if(t.role){let o={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]},c;try{c=await $o(o)}catch(_){throw H.error("Got an error searching for a role."),H.error(_),_}if(!c||c.length===0){let _=dn.ALTER_USER_ROLE_NOT_FOUND(t.role);throw H.error(_),er(new Error,_,tr.NOT_FOUND,void 0,void 0,!0)}if(c.length>1){let _=dn.ALTER_USER_DUP_ROLES(t.role);throw H.error(_),er(new Error,_,tr.CONFLICT,void 0,void 0,!0)}t.role=c[0].id}let s={operation:"update",schema:"system",table:"hdb_user",records:[t]},n;try{n=await QR.update(s)}catch(o){throw H.error("Error during update."),H.error(o),o}try{await Ri()}catch(o){throw H.error("Got an error setting users to global"),H.error(o),o}let i={user:null};return i.user=t,be.sendTransactionToSocketCluster(Ts.INTERNAL_SC_CHANNELS.ALTER_USER,i,yl.get(Ts.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY)),Cl.signalUserChange(new Dl(process.pid)),n}a(UG,"alterUser");function yG(e){let t=!1,r=global.hdb_users.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(yG,"isClusterUser");async function DG(e){try{let t=JR.dropUserValidation(e);if(t)throw new Error(t);let r={table:"hdb_user",schema:"system",hash_values:[e.username]};if(be.isEmpty(global.hdb_users.get(e.username)))throw er(new Error,dn.USER_NOT_EXIST(e.username),tr.NOT_FOUND,void 0,void 0,!0);let s;try{s=await CG(r)}catch(i){throw H.error("Got an error deleting a user."),H.error(i),i}H.debug(s);try{await Ri()}catch(i){throw H.error("Got an error setting users to global."),H.error(i),i}let n={user:null};return n.user=e,be.sendTransactionToSocketCluster(Ts.INTERNAL_SC_CHANNELS.DROP_USER,n,yl.get(Ts.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY)),Cl.signalUserChange(new Dl(process.pid)),`${e.username} successfully deleted`}catch(t){throw t}}a(DG,"dropUser");async function MG(e){let t={};try{if(!e||!e.hdb_user)return"There was no user info in the body";t=e.hdb_user;let r={schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]},s;try{s=await wG(r)}catch(n){throw H.error("Got an error searching for a role."),H.error(n),n}t.role=s[0],delete t.password,delete t.refresh_token,delete t.hash}catch(r){throw H.error(r),r}return t}a(MG,"userInfo");async function PG(){let e;try{e=await xo()}catch(t){throw H.error("Got an error listing users."),H.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(PG,"listUsersExternal");async function xo(){try{let e={schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]},t;try{t=VR.cloneDeep(await $o(e))}catch(r){throw H.error("Got an error searching for roles."),H.error(r),r}if(!be.isEmptyOrZeroLength(t)){let r={};for(let o in t)r[t[o].id]=t[o];let s={schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]},n;try{n=VR.cloneDeep(await $o(s))}catch(o){throw H.error("Got an error searching for users."),H.error(o),o}let i=new Map;for(let o in n){let c=n[o];c.role=r[n[o].role],BG(c.role),i.set(c.username,c)}return(await gG.getLicense()).enterprise?i:vG(i)}}catch(e){throw H.error("got an error listing users"),H.error(e),be.errorizeMessage(e)}return null}a(xo,"listUsers");function BG(e){try{if(!e){H.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(IG)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}catch(t){H.error("Got an error trying to set system permissions."),H.error(t)}}a(BG,"appendSystemTablesToRole");function vG(e){try{if(H.info("No enterprise license found. System is limited to 1 clustering role and 1 user role"),!e)return new Map;let t=Object.create(null),r=new Map;e.forEach((n,i)=>{n.role.permission.cluster_user===void 0||n.role.permission.cluster_user===!1?n.role.permission.super_user===!0&&(t[n.role.id]||(t[n.role.id]=new Map),t[n.role.id].set(i,n)):r.set(i,n)});let s={role:void 0,count:0};return Object.keys(t).forEach(n=>{let i=t[n];i.size>=s.count&&(s.role=n,s.count=i.size)}),s.role===void 0?(H.error("No roles found with active users. This is bad."),new Map):(r=new Map([...r,...t[s.role]]),r)}catch(t){return H.error("error filtering users."),H.error(t),new Map}}a(vG,"nonEnterpriseFilter");async function Ri(){try{let e=await xo();global.hdb_users=e}catch(e){throw H.error(e),e}}a(Ri,"setUsersToGlobal");async function HG(e,t,r=!0){global.hdb_users||await Ri();let s=global.hdb_users.get(e);if(!s)throw er(new Error,bl.GENERIC_AUTH_FAIL,tr.UNAUTHORIZED,void 0,void 0,!0);if(s&&!s.active)throw er(new Error,bl.USER_INACTIVE,tr.UNAUTHORIZED,void 0,void 0,!0);let n={active:s.active,username:s.username};if(s.refresh_token&&(n.refresh_token=s.refresh_token),s.role&&(n.role=s.role),r===!0){if(kR.get(t)===s.password)return n;if(wl.validate(s.password,t))kR.set(t,s.password);else throw er(new Error,bl.GENERIC_AUTH_FAIL,tr.UNAUTHORIZED,void 0,void 0,!0)}return n}a(HG,"findAndValidateUser");async function qG(){let e=await xo(),t=NG.getConfigFromFile(Ts.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!be.isEmpty(r))return r.decrypt_hash=Ul.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+FR.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+FR.SERVER_SUFFIX.ADMIN,r}a(qG,"getClusterUser")});var nA=S((WX,sA)=>{"use strict";var ms=I(),Yo=T(),GG=oR(),eA=Gr(),FG=ds(),VG=xr(),{validateEvent:rA}=Pr(),kG={[Yo.IPC_EVENT_TYPES.SCHEMA]:$G,[Yo.IPC_EVENT_TYPES.USER]:YG};async function $G(e){let t=rA(e);if(t){ms.error(t);return}ms.trace(`IPC schemaHandler ${Yo.HDB_IPC_CLIENT_PREFIX}${process.pid} received schema event:`,e),await GG(e.message),await xG(e.message)}a($G,"schemaHandler");async function xG(e){try{if(global.hdb_schema!==void 0&&typeof global.hdb_schema=="object"&&e.operation!==void 0)switch(e.operation){case"drop_schema":delete global.hdb_schema[e.schema];break;case"drop_table":global.hdb_schema[e.schema]!==void 0&&delete global.hdb_schema[e.schema][e.table];break;case"create_schema":global.hdb_schema[e.schema]===void 0&&(global.hdb_schema[e.schema]={});break;case"create_table":case"create_attribute":global.hdb_schema[e.schema]===void 0&&(global.hdb_schema[e.schema]={}),global.hdb_schema[e.schema][e.table]=await FG.describeTable({schema:e.schema,table:e.table});break;default:eA.setSchemaDataToGlobal(tA);break}else eA.setSchemaDataToGlobal(tA)}catch(t){ms.error(t)}}a(xG,"syncSchemaMetadata");function tA(e){e&&ms.error(e)}a(tA,"handleErrorCallback");async function YG(e){try{let t=rA(e);if(t){ms.error(t);return}ms.trace(`IPC userHandler ${Yo.HDB_IPC_CLIENT_PREFIX}${process.pid} received user event:`,e),await VG.setUsersToGlobal()}catch(t){ms.error(t)}}a(YG,"userHandler");sA.exports=kG});var Ko=S((QX,iA)=>{"use strict";var KG=fr();iA.exports={writeTransaction:WG};function WG(e,t,r){return KG.writeTransaction(e,t,r)}a(WG,"writeTransaction")});var Ml=S((JX,QG)=>{QG.exports={name:"harperdb",version:"4.0.5",description:"HarperDB is a distributed SQL & NoSQL data platform focused on speed, flexibility, and ease of use.",keywords:["database","sql","nosql","api","distributed","cloud","enterprise","Fastify","NATS"],main:"harperdb.js",bin:{harperdb:"./bin/harperdb.js"},engines:{node:">=14.0.0","preferred-node":"18.13.0","go-lang":"1.19.3","nats-server":"2.9.8"},homepage:"https://www.harperdb.io/",bugs:"support@harperdb.io",author:{name:"HarperDB",email:"support@harperdb.io"},license:"See License in ./license/Community+Edition+and+Evaluation+End+User+License+Agreement.pdf",scripts:{submodules:"git submodule update --init --recursive",build:"eslint -c ./.eslintbuild bin/ data_layer/ security/ server/ sqlTranslator/ upgrade/ utility/ validation/",pretty:"eslint --fix bin/ data_layer/ security/ server/ sqlTranslator/ upgrade/ utility/ validation/",test:"rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license --storage_type=lmdb && npm run cover:upgrade && npm run cover:nats && npm run cover:cfserver && npm run cover:lmdbbridge && npm run cover:lmdbutility && npm run cover:hdbserver && npm run cover:main && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license --storage_type=lmdb","cover:main":"cd bin/ && nyc --no-clean --reporter=lcovonly ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --config '../unitTests/.mocharc-main.json'","cover:lmdbbridge":"cd bin/ && nyc --no-clean --reporter=lcovonly --retries 3 ../node_modules/mocha/bin/_mocha '../unitTests/data_layer/harperBridge/lmdbBridge/**/*.js' --parallel --config '../unitTests/.mocharc.json'","cover:lmdbutility":"cd bin/ && nyc --no-clean --reporter=lcovonly --retries 3 ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --parallel --config '../unitTests/.mocharc.json'","cover:hdbserver":"cd bin/ && nyc --no-clean --reporter=lcovonly ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --parallel --config '../unitTests/.mocharc.json'","cover:cfserver":"npm run submodules && cd bin/ && nyc --no-clean --reporter=lcovonly ../node_modules/mocha/bin/_mocha '../unitTests/server/customFunctions/customFunctionsServer-test.js' --config '../unitTests/.mocharc.json'","cover:nats":"cd bin/ && nyc --no-clean --reporter=lcovonly ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json'","cover:upgrade":"cd bin/ && nyc --no-clean --reporter=lcovonly ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.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/data_layer/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:{"@fastify/accepts-serializer":"5.1.0","@fastify/autoload":"5.4.0","@fastify/compress":"6.1.1","@fastify/cors":"8.1.0","@fastify/static":"6.5.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:"1.7.4",async:"3.2.3","aws-sdk":"2.1096.0",chalk:"4.1.2","cli-progress":"3.10.0",clone:"2.1.2",esbuild:"^0.14.49","fast-glob":"3.2.11",fastify:"4.8.1","fastify-plugin":"4.2.1","fill-range":"7.0.1","fs-extra":"10.0.1","human-readable-ids":"1.0.4",inquirer:"8.2.2","is-number":"7.0.0",joi:"17.6.0",json2csv:"5.0.7",jsonata:"1.8.6",jsonwebtoken:"8.5.1",lmdb:"2.7.6",lodash:"4.17.21",mathjs:"10.4.0",microtime:"3.1.1",minimist:"1.2.6",mkcert:"1.5.0",moment:"2.29.4",msgpackr:"1.8.2",nats:"2.9.2",needle:"3.1.0","node-ipc":"9.1.4","node-stream-zip":"1.15.0","normalize-path":"^3.0.0",ora:"5.4.1","ordered-binary":"1.3.0",papaparse:"5.3.2",passport:"0.6.0","passport-http":"0.3.0","passport-local":"1.0.0",pino:"8.3.1",pm2:"5.2.0",prompt:"1.2.2","properties-reader":"2.2.0","recursive-iterator":"3.3.0",semver:"7.3.5","stream-chain":"2.2.5","stream-json":"1.7.4",systeminformation:"5.12.4","tar-fs":"2.1.1","truncate-utf8-bytes":"1.0.2",ulidx:"0.3.0",uuid:"9.0.0","validate.js":"0.11.1",yaml:"1.10.2"},devDependencies:{axios:"0.27.2",chai:"4.3.4","chai-integer":"0.1.0",eslint:"8.22.0","eslint-config-prettier":"8.3.0","eslint-plugin-prettier":"3.4.1","eslint-plugin-radar":"0.2.1","hook-std":"2.0.0","intercept-stdout":"0.1.2",mocha:"8.3.2","mocha-teamcity-reporter":"3.0.0","mock-require":"3.0.3","mock-stdin":"1.0.0",newman:"5.2.3","newman-reporter-html":"1.0.5","newman-reporter-htmlextra":"1.21.0","newman-reporter-teamcity":"0.1.11","node-fetch":"2.6.7",nyc:"15.1.0",prettier:"2.3.2",rewire:"5.0.0",rimraf:"3.0.2",sinon:"10.0.0","sinon-chai":"3.7.0"},overrides:{"eslint-plugin-radar":{eslint:"8.22.0"},"newman-reporter-html":{newman:"5.2.3"}}}});var at=S((aZ,IA)=>{"use strict";var Tr=Y();Tr.initSync();var JG=require("fs-extra"),XG=require("semver"),gi=require("path"),{monotonicFactory:ZG}=require("ulidx"),zG=ZG(),oA=require("util"),cA=require("child_process"),jG=oA.promisify(cA.exec),eF=cA.spawn,ee=_e(),ie=T(),Gl=b(),mr=I(),Wo=Hr(),tF=Ko(),Ai=ur(),{encode:vl,decode:_A}=require("msgpackr"),{isEmpty:Rs}=Gl,uA=xr(),XX=us(),rF=Tt(),ZX=oA.promisify(rF.searchByHash),{connect:sF,StorageType:lA,RetentionPolicy:EA,AckPolicy:dA,DeliverPolicy:Hl,NatsConnection:zX,JetStreamManager:jX,JetStreamClient:eZ,StringCodec:tZ,JSONCodec:nF,createInbox:Fl,StreamSource:rZ,headers:iF,toJsMsg:aF,nuid:sZ,JetStreamOptions:nZ,ErrorCode:aA,nanos:iZ}=require("nats"),{PACKAGE_ROOT:oF}=T(),cF=Ml(),hA=nF(),_F="clustering",uF=cF.engines[ee.NATS_SERVER_NAME],lF=gi.join(oF,"dependencies"),ql=gi.join(lF,`${process.platform}-${process.arch}`,ee.NATS_BINARY_NAME),Pl,Bl,Oi,pi,Ni,Yt;IA.exports={runCommand:SA,checkNATSServerInstalled:EF,createConnection:Vl,getConnection:Qo,getJetStreamManager:hn,getJetStream:fA,getNATSReferences:Ut,getServerList:hF,createLocalStream:kl,listStreams:TA,deleteLocalStream:SF,getServerConfig:Ii,listRemoteStreams:fF,viewStream:TF,publishToStream:mF,createWorkQueueStream:RF,addSourceToWorkStream:mA,request:AF,removeSourceFromWorkStream:AA,reloadNATS:$l,reloadNATSHub:OF,reloadNATSLeaf:pF,extractServerName:RA,requestErrorHandler:NF,updateWorkStream:gF,createLocalTableStream:pA,createTableStreams:IF,purgeTableStream:NA,purgeSchemaTableStreams:bF,getStreamInfo:wF,updateNodeNameLocalStreams:CF,closeConnection:dF};async function SA(e,t=void 0){let{stdout:r,stderr:s}=await jG(e,{cwd:t});if(s)throw new Error(s.replace(`
5
+ This can occur during early stages of install where the config file has not yet been created`);return}else throw We.error(o),new Error(`Error reading HarperDB config file at ${s}`)}du(n);let i=n.toJSON();nt=os(i),We.trace(CU)}}a(mS,"initConfig");function du(e){let t=e.toJSON(),r=AU(t);if(r.error)throw wa.CONFIG_VALIDATION(r.error.message);e.setIn(["http","threads"],r.value.http.threads),e.setIn(["customFunctions","root"],r.value.customFunctions.root),e.setIn(["logging","root"],r.value.logging.root),e.setIn(["operationsApi","tls","certificate"],r.value.operationsApi.tls.certificate),e.setIn(["operationsApi","tls","privateKey"],r.value.operationsApi.tls.privateKey),e.setIn(["operationsApi","tls","certificateAuthority"],r.value.operationsApi.tls.certificateAuthority),e.setIn(["customFunctions","tls","certificate"],r.value.customFunctions.tls.certificate),e.setIn(["customFunctions","tls","privateKey"],r.value.customFunctions.tls.privateKey),e.setIn(["customFunctions","tls","certificateAuthority"],r.value.customFunctions.tls.certificateAuthority),e.setIn(["clustering","tls","certificate"],r.value.clustering.tls.certificate),e.setIn(["clustering","tls","privateKey"],r.value.clustering.tls.privateKey),e.setIn(["clustering","tls","certificateAuthority"],r.value.clustering.tls.certificateAuthority)}a(du,"validateConfig");function PU(e,t){nt===void 0&&(nt={});let r=re.CONFIG_PARAM_MAP[e.toLowerCase()];if(r===void 0){We.trace(`Unable to update config object because config param '${e}' does not exist`);return}nt[r.toLowerCase()]=t}a(PU,"updateConfigObject");function RS(e,t,r=void 0,s=!1,n=!1){nt===void 0&&mS();let i=TS(re.CONFIG_PARAM_MAP.hdb_root),o=Ys.join(i,re.HDB_CONFIG_FILE),c=Ks(o);if(r===void 0){let l=re.CONFIG_PARAM_MAP[e.toLowerCase()];if(l===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let E=l.split("_"),d=Eu(l,t);c.setIn([...E],d)}else for(let l in r){let E=re.CONFIG_PARAM_MAP[l.toLowerCase()];if(E!==void 0){let d=E.split("_"),h=Eu(E,r[l]);try{c.setIn([...d],h)}catch(m){We.error(m)}}}du(c);let _=c.getIn(["rootPath"]),u=Ys.join(_,re.HDB_CONFIG_FILE);if(s===!0)try{let l=Ys.join(_,"backup",`${re.HDB_CONFIG_FILE}.bak`);qt.copySync(o,l),We.trace(`Config file: ${o} backed up to: ${l}`)}catch(l){We.error(LU),We.error(l)}qt.writeFileSync(u,String(c)),n&&(nt=os(c.toJSON())),We.trace(`Config parameter: ${e} updated with value: ${t}`)}a(RS,"updateConfigValue");function os(e){let t={};for(let r in e)if(!!e.hasOwnProperty(r))if(typeof e[r]=="object"&&e[r]!==null&&!Array.isArray(e[r])){let s=os(e[r]);for(let n in s)!s.hasOwnProperty(n)||(t[r.toLowerCase()+"_"+n]=s[n])}else t[r.toLowerCase()]=e[r];return t}a(os,"flattenConfig");function Eu(e,t){if(e===re.CONFIG_PARAMS.CLUSTERING_NODENAME||e===re.CONFIG_PARAMS.CLUSTERING_USER){if(!isNaN(t))return t.toString();if(typeof t=="string"&&t.toLowerCase()==="true"||typeof t=="string"&&t.toLowerCase()==="false")return t}else{if(pU(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||gt.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 gt.autoCast(t)}a(Eu,"castConfigValue");function BU(){let e=gt.getPropsFilePath(),r=La(e).get(re.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY);return Ks(r).toJSON()}a(BU,"getConfiguration");async function vU(e){let{operation:t,hdb_user:r,hdb_auth_header:s,...n}=e;try{return RS(void 0,void 0,n,!0),yU}catch(i){throw typeof i=="string"||i instanceof String?gU(i,i,IU.BAD_REQUEST,void 0,void 0,!0):i}}a(vU,"setConfiguration");function hu(){let e=gt.getPropsFilePath();try{qt.accessSync(e,qt.constants.F_OK|qt.constants.R_OK)}catch(n){throw We.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let r=La(e).get(re.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY);return Ks(r).toJSON()}a(hu,"readConfigFile");function Ks(e){return OU.parseDocument(qt.readFileSync(e,"utf8"),{simpleKeys:!0})}a(Ks,"parseYamlDoc");function HU(){let e=hu(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=gt.isEmptyOrZeroLength(t)?[]:t;let r=SS(t);if(r)throw wa.CONFIG_VALIDATION(r.message);let s=e?.clustering?.leafServer?.network?.routes;s=gt.isEmptyOrZeroLength(s)?[]:s;let n=SS(s);if(n)throw wa.CONFIG_VALIDATION(n.message);if(!gt.isEmptyOrZeroLength(s)&&!gt.isEmptyOrZeroLength(t)){let i=t.filter(o=>s.some(c=>c.host===o.host&&c.port===o.port));if(!gt.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw wa.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:s}}a(HU,"getClusteringRoutes");function AS(e){let t=La(e);nt={};for(let r in re.CONFIG_PARAM_MAP){let s=t.get(r.toUpperCase());if(gt.isEmpty(s)||typeof s=="string"&&s.trim().length===0)continue;let n=re.CONFIG_PARAM_MAP[r].toLowerCase();n===re.CONFIG_PARAMS.LOGGING_ROOT?nt[n]=Ys.dirname(s):nt[n]=s}return nt}a(AS,"initOldConfig");function qU(e){let t=hu();return NU.get(t,e.replaceAll("_","."))}a(qU,"getConfigFromFile")});var Y=S((G1,NS)=>{"use strict";var Su=require("fs-extra"),Zt=require("path"),GU=require("os"),FU=require("properties-reader"),Yn=I(),Ws=b(),M=T(),Ua=ur(),VU="Error initializing environment manager",ya="BOOT_PROPS_FILE_PATH",pS=!1,kU={[M.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[M.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[M.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},lr={};NS.exports={BOOT_PROPS_FILE_PATH:ya,getHdbBasePath:$U,setHdbBasePath:xU,get:YU,initSync:WU,setProperty:x,initTestEnvironment:QU};function $U(){return lr[M.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a($U,"getHdbBasePath");function xU(e){lr[M.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(xU,"setHdbBasePath");function YU(e){let t=Ua.getConfigValue(e);return t===void 0?lr[e]:t}a(YU,"get");function x(e,t){kU[e]&&(lr[e]=t),Ua.updateConfigObject(e,t)}a(x,"setProperty");function KU(){let e;try{e=Ws.getPropsFilePath(),Su.accessSync(e,Su.constants.F_OK|Su.constants.R_OK),pS=!0;let t=FU(e);return lr[M.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(M.HDB_SETTINGS_NAMES.INSTALL_USER),lr[M.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(M.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),lr[ya]=e,!0}catch{return Yn.trace(`Environment manager found no properties file at ${e}`),!1}}a(KU,"doesPropFileExist");function WU(e=!1){try{(pS||KU())&&(Ua.initConfig(e),lr[M.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=Ua.getConfigValue(M.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){Yn.error(VU),Yn.error(t),console.error(t),process.exit(1)}}a(WU,"initSync");function QU(e={}){try{let{keep_alive_timeout:t,headers_timeout:r,server_timeout:s,https_enabled:n,cors_enabled:i,cors_accesslist:o,local_studio_on:c}=e,_=Zt.join(__dirname,"../../","unitTests");lr[ya]=Zt.join(_,"hdb_boot_properties.file"),x(M.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,Zt.join(_,"settings.test")),x(M.HDB_SETTINGS_NAMES.INSTALL_USER,GU.userInfo().username),x(M.HDB_SETTINGS_NAMES.PRIVATE_KEY_KEY,Zt.join(_,"envDir","utility","keys","privateKey.pem")),x(M.HDB_SETTINGS_NAMES.CERT_KEY,Zt.join(_,"envDir","utility","keys","certificate.pem")),x(M.CONFIG_PARAMS.CUSTOMFUNCTIONS_TLS_PRIVATEKEY,Zt.join(_,"envDir","utility","keys","privateKey.pem")),x(M.CONFIG_PARAMS.CUSTOMFUNCTIONS_TLS_CERTIFICATE,Zt.join(_,"envDir","utility","keys","certificate.pem")),x(M.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),x(M.HDB_SETTINGS_NAMES.LOG_PATH_KEY,Zt.join(_,"envDir","log")),x(M.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),x(M.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),x(M.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),x(M.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,Zt.join(_,"envDir")),x(M.HDB_SETTINGS_NAMES.HTTP_SECURE_ENABLED_KEY,Ws.isEmpty(n)?!0:n),x(M.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,Ws.isEmpty(n)?!0:n),x(M.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),x(M.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,Ws.isEmpty(i)?!1:i),x(M.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_CORS,Ws.isEmpty(i)?!1:i),x(M.HDB_SETTINGS_NAMES.IPC_SERVER_PORT,9383),x(M.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),x(M.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),x(M.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),x(M.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),x(M.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,Zt.resolve(__dirname,"../../unitTests/server/customFunctions/custom_functions")),x(M.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,Ws.isEmpty(c)?!1:c),o&&(x("CORS_ACCESSLIST",o),x(M.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_CORSACCESSLIST,o)),s&&(x(M.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,s),x(M.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_TIMEOUT,s)),t&&(x(M.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),x(M.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_KEEPALIVETIMEOUT,t)),r&&(x(M.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),x(M.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${ya}. Please check your boot props and settings files`;Yn.fatal(r),Yn.error(t)}}a(QU,"initTestEnvironment")});var X=S((V1,BS)=>{"use strict";var fu=require("lmdb"),It=require("fs-extra"),Gt=require("path"),Ma=as(),gS=I(),De=Ke().LMDB_ERRORS_ENUM,Pa=oS(),Tu=_S(),IS=lS(),yr=Ye(),F1=T(),Kn=Y();Kn.initSync();var bS=Kn.get("STORAGE_WRITEASYNC")===!0||Kn.get("STORAGE_WRITEASYNC")==="true"||Kn.get("STORAGE_WRITEASYNC")==="TRUE",wS=Kn.get("STORAGE_OVERLAPPINGSYNC"),CS=1024*1024*1024,LS=1e4,US=1e3,Ft=yr.INTERNAL_DBIS_NAME,yS=yr.DBI_DEFINITION_NAME,JU="data.mdb",XU="lock.mdb",Wn=".mdb",ZU="-lock",Da=class{constructor(t,r,s=!1){this.dbi=bt(t,r),this.key_type=this.dbi[yr.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[yr.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:s===!1}),this.cursor=new fu.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};a(Da,"TransactionCursor");function mu(e,t){if(e===void 0)throw new Error(De.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(De.ENV_NAME_REQUIRED)}a(mu,"pathEnvNameValidation");async function Ru(e,t,r=!0){try{await It.access(e)}catch(s){throw s.code==="ENOENT"?new Error(De.INVALID_BASE_PATH):s}try{let s=Gt.join(e,t+Wn);return await It.access(s,It.constants.R_OK|It.constants.F_OK),s}catch(s){if(s.code==="ENOENT")if(r)try{return await It.access(Gt.join(e,t,JU),It.constants.R_OK|It.constants.F_OK),Gt.join(e,t)}catch(n){if(n.code==="ENOENT")throw new Error(De.INVALID_ENVIRONMENT)}else throw new Error(De.INVALID_ENVIRONMENT);throw s}}a(Ru,"validateEnvironmentPath");function Ba(e,t){if(Ma.validateEnv(e),t===void 0)throw new Error(De.DBI_NAME_REQUIRED)}a(Ba,"validateEnvDBIName");async function zU(e,t,r=!1,s=!1){mu(e,t),t=t.toString();try{return await Ru(e,t,s),Au(e,t,r)}catch(n){if(n.message===De.INVALID_ENVIRONMENT){let i=Gt.join(e,t);await It.mkdirp(s?i:e);let o=new IS(s?i:i+Wn,CS,LS,US,!1,bS,wS),c=fu.open(o);c.dbis=Object.create(null);let _=new Tu(!1);c.openDB(Ft,_),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let u=Ou(e,t,r);return c[yr.ENVIRONMENT_NAME_KEY]=u,global.lmdb_map[u]=c,c}throw n}}a(zU,"createEnvironment");async function jU(e,t,r,s=!0){let n=await Au(e,t);if(r===void 0)throw new Error(De.DESTINATION_PATH_REQUIRED);try{await It.access(Gt.dirname(r))}catch(i){throw i.code==="ENOENT"?new Error(De.INVALID_DESTINATION_PATH):i}await n.backup(r,s)}a(jU,"copyEnvironment");async function Au(e,t,r=!1){mu(e,t),t=t.toString();let s=Ou(e,t,r);if(global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null)),global.lmdb_map[s]!==void 0)return global.lmdb_map[s];let n=await Ru(e,t),i=Gt.join(e,t+Wn),o=n!=i,c=new IS(n,CS,LS,US,o,bS,wS),_=fu.open(c);_.dbis=Object.create(null);let u=MS(_);for(let l=0;l<u.length;l++)bt(_,u[l]);return _[yr.ENVIRONMENT_NAME_KEY]=s,global.lmdb_map[s]=_,_}a(Au,"openEnvironment");async function ey(e,t,r=!1){mu(e,t),t=t.toString();let s=Gt.join(e,t+Wn),n=await Ru(e,t);if(global.lmdb_map!==void 0){let i=Ou(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await DS(o),delete global.lmdb_map[i]}}await It.remove(n),await It.remove(n===s?n+ZU:Gt.join(Gt.dirname(n),XU))}a(ey,"deleteEnvironment");async function DS(e){Ma.validateEnv(e);let t=e[yr.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(DS,"closeEnvironment");function Ou(e,t,r=!1){let n=`${Gt.basename(e)}.${t}`;return r===!0&&(n=`txn.${n}`),n}a(Ou,"getCachedEnvironmentName");function ty(e){Ma.validateEnv(e);let t=Object.create(null),r=bt(e,Ft);for(let{key:s,value:n}of r.getRange({start:!1}))if(s!==Ft)try{t[s]=Object.assign(new Pa,n)}catch{gS.warn(`an internal error occurred: unable to parse DBI Definition for ${s}`)}return t}a(ty,"listDBIDefinitions");function MS(e){Ma.validateEnv(e);let t=[],r=bt(e,Ft);for(let{key:s}of r.getRange({start:!1}))s!==Ft&&t.push(s);return t}a(MS,"listDBIs");function ry(e,t){let s=bt(e,Ft).getEntry(t),n=new Pa;if(s!==void 0){try{n=Object.assign(n,s.value)}catch{gS.warn(`an internal error occurred: unable to parse DBI Definition for ${s}`)}return n}}a(ry,"getDBIDefinition");function PS(e,t,r,s=!1){if(Ba(e,t),t=t.toString(),t===Ft)throw new Error(De.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return bt(e,t)}catch(n){if(n.message===De.DBI_DOES_NOT_EXIST){let i=new Tu(r,s===!0),o=e.openDB(t,i),c=new Pa(r===!0,s);return o[yS]=c,bt(e,Ft).putSync(t,c),e.dbis[t]=o,o}throw n}}a(PS,"createDBI");function bt(e,t){if(Ba(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==Ft?r=ry(e,t):r=new Pa,r===void 0)throw new Error(De.DBI_DOES_NOT_EXIST);let s;try{let n=new Tu(r.dup_sort,r.useVersions);if(s=e.openDB(t,n),s.db===void 0)throw new Error("MDB_NOTFOUND")}catch(n){throw n.message.includes("MDB_NOTFOUND")===!0?new Error(De.DBI_DOES_NOT_EXIST):n}return s[yS]=r,e.dbis[t]=s,s}a(bt,"openDBI");function sy(e,t){Ba(e,t),t=t.toString();let r=bt(e,t),s=r.getStats();return r[yr.DBI_DEFINITION_NAME].is_hash_attribute&&s.entryCount>0&&s.entryCount--,s}a(sy,"statDBI");async function ny(e,t){try{let r=Gt.join(e,t+Wn);return(await It.stat(r)).size}catch{throw new Error(De.INVALID_ENVIRONMENT)}}a(ny,"environmentDataSize");function iy(e,t){if(Ba(e,t),t=t.toString(),t===Ft)throw new Error(De.CANNOT_DROP_INTERNAL_DBIS_NAME);bt(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],bt(e,Ft).removeSync(t)}a(iy,"dropDBI");function ay(e,t,r){for(let s=0;s<r.length;s++){let n=r[s];if(!e.dbis[n])try{bt(e,n)}catch(i){if(i.message===De.DBI_DOES_NOT_EXIST)PS(e,n,n!==t,n===t);else throw i}}}a(ay,"initializeDBIs");BS.exports={openDBI:bt,openEnvironment:Au,createEnvironment:zU,listDBIs:MS,listDBIDefinitions:ty,createDBI:PS,dropDBI:iy,statDBI:sy,deleteEnvironment:ey,initializeDBIs:ay,TransactionCursor:Da,environmentDataSize:ny,copyEnvironment:jU,closeEnvironment:DS}});var HS=S((k1,vS)=>{"use strict";var va=class{constructor(t=[],r=[],s=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=s}};a(va,"InsertRecordsResponseObject");vS.exports=va});var GS=S(($1,qS)=>{"use strict";var Ha=class{constructor(t=[],r=[],s=void 0,n=[]){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=s,this.original_records=n}};a(Ha,"UpdateRecordsResponseObject");qS.exports=Ha});var VS=S((x1,FS)=>{"use strict";var qa=class{constructor(t=[],r=void 0,s=[]){this.written_hashes=t,this.txn_time=r,this.original_records=s}};a(qa,"UpsertRecordsResponseObject");FS.exports=qa});var Qs=S((Q1,$S)=>{"use strict";var oy=X(),cy=HS(),_y=GS(),uy=VS(),Jn=as(),Qn=Ke().LMDB_ERRORS_ENUM,ly=Ye(),Dr=T(),Ey=b(),dy=require("uuid"),Y1=require("lmdb"),{handleHDBError:hy,hdb_errors:Sy}=D(),{OVERFLOW_MARKER:K1,MAX_SEARCH_KEY_LENGTH:W1}=ly,pu=Dr.TIME_STAMP_NAMES_ENUM.CREATED_TIME,cs=Dr.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function fy(e,t,r,s,n=!0){bu(e,t,r,s),Nu(e,t,r);let i=new cy,o=[],c=[];for(let _=0;_<s.length;_++){let u=s[_];kS(u,!0,n);let l=Ty(e,t,r,u),E=u[t];o.push(l),c.push(E)}return gu(o,c,s,i)}a(fy,"insertRecords");function Ty(e,t,r,s){let n=s[t];return e.dbis[t].ifNoExists(n,()=>{for(let i=0;i<r.length;i++){let o=r[i];if(o===t||s.hasOwnProperty(o)===!1)continue;let c=s[o];if(typeof c=="function"){let u=c([[{}]]);Array.isArray(u)&&(c=u[0][Dr.FUNC_VAL],s[o]=c)}let _=Jn.getIndexedValues(c);if(_)for(let u=0,l=_.length;u<l;u++)e.dbis[o].put(_[u],n)}e.dbis[t].put(n,s,s[cs])})}a(Ty,"insertRecord");function my(e,t=[]){let r=0;for(let s=0;s<t.length;s++){let n=t[s];e.splice(n-r,1),r++}}a(my,"removeSkippedRecords");function kS(e,t,r=!0){let s=Date.now();(r===!0||!Number.isInteger(e[cs]))&&(e[cs]=s),t===!0?(r===!0||!Number.isInteger(e[pu]))&&(e[pu]=s):delete e[pu]}a(kS,"setTimestamps");function Nu(e,t,r){r.indexOf(Dr.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(Dr.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(Dr.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(Dr.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),oy.initializeDBIs(e,t,r)}a(Nu,"initializeTransaction");async function Ry(e,t,r,s,n=!0){bu(e,t,r,s),Nu(e,t,r);let i=new _y,o=[],c=[],_=[];for(let u=0;u<s.length;u++){let l=s[u],E=l[t],d;try{d=Iu(e,t,l,E,i,!0,n)}catch{i.skipped_hashes.push(E),o.push(u);continue}c.push(d),_.push(E)}return gu(c,_,s,i,o)}a(Ry,"updateRecords");async function Ay(e,t,r,s,n=!0){try{bu(e,t,r,s)}catch(_){throw hy(_,_.message,Sy.HTTP_STATUS_CODES.BAD_REQUEST)}Nu(e,t,r);let i=new uy,o=[],c=[];for(let _=0;_<s.length;_++){let u=s[_],l;Ey.isEmpty(u[t])?(l=dy.v4(),u[t]=l):l=u[t];let E=Iu(e,t,u,l,i,!1,n);o.push(E),c.push(l)}return gu(o,c,s,i)}a(Ay,"upsertRecords");async function gu(e,t,r,s,n=[]){let i=await Promise.all(e);for(let o=0,c=i.length;o<c;o++)i[o]===!0?s.written_hashes.push(t[o]):(s.skipped_hashes.push(t[o]),n.push(o));return s.txn_time=Jn.getMicroTime(),my(r,n),s}a(gu,"finalizeWrite");function Iu(e,t,r,s,n,i=!1,o=!0){let c=e.dbis[t],_=c.getEntry(s),u=_?.value,l=u;if(!u){if(i)return!1;u={}}if(kS(r,!l,o),Number.isInteger(r[cs])&&u[cs]>r[cs])return!1;l&&n.original_records.push(u);let E,d=a(()=>{for(let m in r){if(!r.hasOwnProperty(m)||m===t)continue;let R=r[m],C=e.dbis[m];if(C===void 0)continue;let L=u[m];if(typeof R=="function"){let z=R([[u]]);Array.isArray(z)&&(R=z[0][Dr.FUNC_VAL],r[m]=R)}if(R===L)continue;let B=Jn.getIndexedValues(L);if(B)for(let z=0,V=B.length;z<V;z++)C.remove(B[z],s);if(B=Jn.getIndexedValues(R),B)for(let z=0,V=B.length;z<V;z++)C.put(B[z],s)}let h=Object.assign({},u,r);c.put(s,h,h[cs])},"do_put");return _?E=c.ifVersion(s,_.version,d):E=c.ifNoExists(s,d),E.then(h=>h?!0:Iu(e,t,r,s,n,i,o))}a(Iu,"updateUpsertRecord");function Oy(e,t,r){if(Jn.validateEnv(e),t===void 0)throw new Error(Qn.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(Qn.WRITE_ATTRIBUTES_REQUIRED):new Error(Qn.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(Oy,"validateBasic");function bu(e,t,r,s){if(Oy(e,t,r),!Array.isArray(s))throw s===void 0?new Error(Qn.RECORDS_REQUIRED):new Error(Qn.RECORDS_MUST_BE_ARRAY)}a(bu,"validateWrite");$S.exports={insertRecords:fy,updateRecords:Ry,upsertRecords:Ay}});var te=S((J1,YS)=>{"use strict";var wu=T(),Js=Y(),Cu=require("path");Js.initSync();var Ga,Fa,Va;function xS(){if(Ga!==void 0)return Ga;if(Js.getHdbBasePath()!==void 0)return Ga=Cu.join(Js.getHdbBasePath(),wu.SCHEMA_DIR_NAME),Ga}a(xS,"getBaseSchemaPath");function py(){if(Fa!==void 0)return Fa;if(Js.getHdbBasePath()!==void 0)return Fa=Cu.join(xS(),wu.SYSTEM_SCHEMA_NAME),Fa}a(py,"getSystemSchemaPath");function Ny(){if(Va!==void 0)return Va;if(Js.getHdbBasePath()!==void 0)return Va=Cu.join(Js.getHdbBasePath(),wu.TRANSACTIONS_DIR_NAME),Va}a(Ny,"getTransactionAuditStorePath");YS.exports={getBaseSchemaPath:xS,getSystemSchemaPath:py,getTransactionAuditStorePath:Ny}});var Er=S((X1,QS)=>{"use strict";var WS=b(),KS=T(),$a=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Lu=require("joi"),ka={schema_format:{pattern:$a,message:"names cannot include backticks or forward slashes"},schema_length:{maximum:250,tooLong:"cannot exceed 250 characters"}},gy=Lu.alternatives(Lu.string().min(1).max(ka.schema_length.maximum).pattern($a).messages({"string.pattern.base":"{:#label} "+ka.schema_format.message}),Lu.number()).required();function Iy(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>ka.schema_length.maximum?`'${e}' maximum of 250 characters`:$a.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(Iy,"checkValidTable");function by(e,t){return WS.doesSchemaExist(e)?e:t.message(`Schema '${e}' does not exist`)}a(by,"validateSchemaExists");function wy(e,t){let r=t.state.ancestors[0].schema;return WS.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(wy,"validateTableExists");function Cy(e,t){return e.toLowerCase()===KS.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid schema name, '${KS.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(Cy,"validateSchemaName");QS.exports={common_validators:ka,schema_regex:$a,hdb_schema_table:gy,validateSchemaExists:by,validateTableExists:wy,validateSchemaName:Cy,checkValidTable:Iy}});var xa=S((Z1,JS)=>{var{common_validators:Mr}=Er(),Xn=de(),Vt="is required",Z={schema:{presence:!0,format:Mr.schema_format,length:Mr.schema_length},table:{presence:!0,format:Mr.schema_format,length:Mr.schema_length},attribute:{presence:!0,format:Mr.schema_format,length:Mr.schema_length},hash_attribute:{presence:!0,format:Mr.schema_format,length:Mr.schema_length}};function Zn(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(Zn,"makeAttributesStrings");function Ly(e){return e=Zn(e),Z.schema.presence={message:Vt},Z.table.presence=!1,Z.attribute.presence=!1,Z.hash_attribute.presence=!1,Xn.validateObject(e,Z)}a(Ly,"schema_object");function Uy(e){return e=Zn(e),Z.schema.presence={message:Vt},Z.table.presence={message:Vt},Z.attribute.presence=!1,Z.hash_attribute.presence=!1,Xn.validateObject(e,Z)}a(Uy,"table_object");function yy(e){return e=Zn(e),Z.schema.presence={message:Vt},Z.table.presence={message:Vt},Z.attribute.presence=!1,Z.hash_attribute.presence={message:Vt},Xn.validateObject(e,Z)}a(yy,"create_table_object");function Dy(e){return e=Zn(e),Z.schema.presence={message:Vt},Z.table.presence={message:Vt},Z.attribute.presence={message:Vt},Z.hash_attribute.presence=!1,Xn.validateObject(e,Z)}a(Dy,"attribute_object");function My(e){return e=Zn(e),Z.schema.presence={message:Vt},Z.table.presence={message:Vt},Z.attribute.presence=!1,Z.hash_attribute.presence=!1,Xn.validateObject(e,Z)}a(My,"describe_table");function Py(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(Py,"validateTableResidence");JS.exports={schema_object:Ly,create_table_object:yy,table_object:Uy,attribute_object:Dy,describe_table:My,validateTableResidence:Py}});var ZS=S((z1,XS)=>{"use strict";var By=require("uuid"),Ya=class{constructor(t,r,s,n){this.schema=t,this.table=r,this.attribute=s,this.id=n||By.v4(),this.schema_table=`${this.schema}.${this.table}`}};a(Ya,"CreateAttributeObject");XS.exports=Ya});var Wa=S((j1,zS)=>{"use strict";var vy=ZS(),Ka=class extends vy{constructor(t,r,s,n,i=!0,o=!1){super(t,r,s,n),this.dup_sort=i,this.is_hash_attribute=o}};a(Ka,"LMDBCreateAttributeObject");zS.exports=Ka});var ef=S((eJ,jS)=>{"use strict";jS.exports=qy;var Hy="inserted";function qy(e,t,r,s){let n={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:s};return e===Hy?(n.inserted_hashes=t,n):(n.update_hashes=t,n)}a(qy,"returnObject")});var Qa=S((tJ,rf)=>{"use strict";var Gy=T(),Uu=X(),Fy=Qs(),{getSystemSchemaPath:Vy,getBaseSchemaPath:ky}=te(),$y=require("path"),xy=ts(),Yy=xa(),Ky=Wa(),Wy=ef(),{handleHDBError:Qy,hdb_errors:Jy}=D(),Xy=b(),yu=xy.hdb_attribute,tf=[];for(let e=0;e<yu.attributes.length;e++)tf.push(yu.attributes[e].attribute);var Zy="inserted";rf.exports=zy;async function zy(e){let t=Yy.attribute_object(e);if(t)throw Qy(new Error,t.message,Jy.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=Xy.isEmpty(e.dup_sort)||e.dup_sort=="true";let r=[];if(global.hdb_schema[e.schema]&&global.hdb_schema[e.schema][e.table]&&(r=global.hdb_schema[e.schema][e.table].attributes),Array.isArray(r)&&r.length>0){for(let n of r)if(n.attribute===e.attribute)throw new Error(`attribute '${n.attribute}' already exists in ${e.schema}.${e.table}`)}let s=new Ky(e.schema,e.table,e.attribute,e.id);try{let n=await Uu.openEnvironment($y.join(ky(),e.schema.toString()),e.table);if(n.dbis[e.attribute]!==void 0)throw new Error(`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`);Uu.createDBI(n,e.attribute,e.dup_sort,e.is_hash_attribute);let i=await Uu.openEnvironment(Vy(),Gy.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:o,skipped_hashes:c}=await Fy.insertRecords(i,yu.hash_attribute,tf,[s]);return Wy(Zy,o,{records:[s]},c)}catch(n){throw n}}a(zy,"lmdbCreateAttribute")});var Mu=S((rJ,nf)=>{var{hdb_schema_table:sf}=Er(),jy=de(),Du=require("joi"),eD={undefined:"undefined",null:"null"},tD=a((e,t)=>{let r=Object.keys(e),s=r.length,n;for(let i=0;i<s;i++){let o=r[i];(!o||o.length===0||eD[o]!==void 0)&&(n===void 0?n=`Invalid attribute name: '${o}'`:n+=`. Invalid attribute name: '${o}'`)}return n?t.message(n):e},"custom_records_val"),rD=Du.object({schema:sf,table:sf,records:Du.array().items(Du.object().custom(tD)).required()});nf.exports=function(e){return jy.validateBySchema(e,rD)}});var Ja=S((nJ,of)=>{"use strict";var dr=b(),af=I(),sJ=Mu();of.exports=sD;function sD(e){if(dr.isEmpty(e))throw new Error("invalid update parameters defined.");if(dr.isEmptyOrZeroLength(e.schema))throw new Error("invalid schema specified.");if(dr.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");if(!Array.isArray(e.records))throw new Error("records must be an array");let t=global.hdb_schema[e.schema][e.table];if(dr.isEmpty(t))throw new Error(`could not retrieve schema:${e.schema} and table ${e.table}`);let r=t.hash_attribute,s=new Set,n={},i=!1;return e.operation==="update"&&(i=!0),e.records.forEach(o=>{if(i&&dr.isEmptyOrZeroLength(o[r]))throw af.error("a valid hash attribute must be provided with update record:",o),new Error("a valid hash attribute must be provided with update record, check log for more info");if(!dr.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw af.error(`a valid hash value must be provided with ${e.operation} record:`,o),new Error(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!dr.isEmpty(o[r])&&o[r]!==""&&s.has(dr.autoCast(o[r]))&&(o.skip=!0),s.add(dr.autoCast(o[r]));for(let c in o)n[c]=1}),n[r]=1,{schema_table:t,hashes:Array.from(s),attributes:Object.keys(n)}}a(sD,"insertUpdateValidate")});var zn=S((iJ,cf)=>{"use strict";var nD=T().OPERATIONS_ENUM,Xa=class{constructor(t,r,s,n,i=void 0){this.operation=nD.INSERT,this.schema=t,this.table=r,this.hash_attribute=s,this.records=n,this.__origin=i}};a(Xa,"InsertObject");cf.exports=Xa});var za=S((oJ,_f)=>{"use strict";var aJ=zn(),Za=T(),Bu=b(),Pu=I(),iD=require("uuid"),{handleHDBError:jn,hdb_errors:aD}=D(),{HDB_ERROR_MSGS:ei,HTTP_STATUS_CODES:ti}=aD;_f.exports=oD;function oD(e,t,r){for(let n=0;n<t.length;n++)cD(t[n]);let{records:s}=e;for(let n=0;n<s.length;n++){let i=s[n];_D(i,r,e.operation)}}a(oD,"processRows");function cD(e){if(Buffer.byteLength(String(e))>Za.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw jn(new Error,ei.ATTR_NAME_LENGTH_ERR(e),ti.BAD_REQUEST,void 0,void 0,!0);if(Bu.isEmptyOrZeroLength(e)||Bu.isEmpty(e.trim()))throw jn(new Error,ei.ATTR_NAME_NULLISH_ERR,ti.BAD_REQUEST,void 0,void 0,!0)}a(cD,"validateAttribute");function _D(e,t,r){if(!e.hasOwnProperty(t)||Bu.isEmptyOrZeroLength(e[t])){if(r===Za.OPERATIONS_ENUM.INSERT||r===Za.OPERATIONS_ENUM.UPSERT){e[t]=iD.v4();return}throw Pu.error("Update transaction aborted due to record with no hash value:",e),jn(new Error,ei.RECORD_MISSING_HASH_ERR,ti.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>Za.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw Pu.error(e),jn(new Error,ei.HASH_VAL_LENGTH_ERR,ti.BAD_REQUEST,void 0,void 0,!0);if(isNaN(e[t])&&e[t].includes("/"))throw Pu.error(e),jn(new Error,ei.INVALID_FORWARD_SLASH_IN_HASH_ERR,ti.BAD_REQUEST,void 0,void 0,!0)}a(_D,"validateHash")});var lf=S((cJ,uf)=>{"use strict";var ja=class{constructor(t,r){this.type=t,this.message=r}};a(ja,"IPCEventObject");uf.exports=ja});var Pr=S((_J,Ef)=>{"use strict";var uD=I(),vu=b(),lD=T(),{IPC_ERRORS:ri}=Ke();Ef.exports={sendIpcEvent:ED,validateEvent:dD,SchemaEventMsg:hD,UserEventMsg:SD};function ED(e){global.hdb_ipc?global.hdb_ipc.emitToServer(e):uD.warn("Tried to send event:",e,"to HDB IPC client but it does not exist")}a(ED,"sendIpcEvent");function dD(e){if(typeof e!="object")return ri.INVALID_IPC_DATA_TYPE;if(!e.hasOwnProperty("type")||vu.isEmpty(e.type))return ri.MISSING_TYPE;if(!e.hasOwnProperty("message")||vu.isEmpty(e.message))return ri.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||vu.isEmpty(e.message.originator))return ri.MISSING_ORIGIN;if(lD.IPC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return ri.INVALID_EVENT(e.type)}a(dD,"validateEvent");function hD(e,t,r,s=void 0,n=void 0){this.originator=e,this.operation=t,this.schema=r,this.table=s,this.attribute=n}a(hD,"SchemaEventMsg");function SD(e){this.originator=e}a(SD,"UserEventMsg")});var Xs=S((lJ,ff)=>{"use strict";var df=T(),uJ=b(),eo=I(),hf=lf(),{sendIpcEvent:Sf}=Pr();function fD(e){try{eo.trace("signalSchemaChange called with message:",e);let t=new hf(df.IPC_EVENT_TYPES.SCHEMA,e);Sf(t)}catch(t){eo.error(t)}}a(fD,"signalSchemaChange");function TD(e){try{eo.trace("signalUserChange called with message:",e);let t=new hf(df.IPC_EVENT_TYPES.USER,e);Sf(t)}catch(t){eo.error(t)}}a(TD,"signalUserChange");ff.exports={signalSchemaChange:fD,signalUserChange:TD}});var to=S((EJ,mf)=>{"use strict";var Tf=b(),mD=T(),RD=I(),AD=Qa(),OD=Wa(),pD=Xs(),{SchemaEventMsg:ND}=Pr(),gD="already exists in";mf.exports=ID;async function ID(e,t,r){try{if(Tf.isEmptyOrZeroLength(r))return r;let s=[];Tf.isEmptyOrZeroLength(t.attributes)||t.attributes.forEach(i=>{s.push(i.attribute)});let n=r.filter(i=>s.indexOf(i)<0);return n.length===0||await Promise.all(n.map(async i=>{await bD(e,t.schema,t.name,i)})),n}catch(s){throw s}}a(ID,"lmdbCheckForNewAttributes");async function bD(e,t,r,s){let n=new OD(t,r,s,void 0,!0);e&&(n.hdb_auth_header=e);try{await wD(n)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(gD))RD.warn(`attribute ${t}.${r}.${s} already exists`);else throw i}}a(bD,"createNewAttribute");async function wD(e){let t;try{return t=await AD(e),pD.signalSchemaChange(new ND(process.pid,mD.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}catch(r){throw r}}a(wD,"createAttribute")});var Zs=S((dJ,Rf)=>{"use strict";var ro=class{constructor(t,r,s,n,i=void 0){this.operation=t,this.user_name=r,this.timestamp=s,this.hash_values=n,this.origin=i}};a(ro,"LMDBTransactionObject");Rf.exports=ro});var Of=S((hJ,Af)=>{"use strict";var CD=Zs(),LD=T().OPERATIONS_ENUM,so=class extends CD{constructor(t,r,s,n,i=void 0){super(LD.INSERT,r,s,n,i),this.records=t}};a(so,"LMDBInsertTransactionObject");Af.exports=so});var Nf=S((SJ,pf)=>{"use strict";var UD=Zs(),yD=T().OPERATIONS_ENUM,no=class extends UD{constructor(t,r,s,n,i,o=void 0){super(yD.UPDATE,s,n,i,o),this.records=t,this.original_records=r}};a(no,"LMDBUpdateTransactionObject");pf.exports=no});var If=S((fJ,gf)=>{"use strict";var DD=Zs(),MD=T().OPERATIONS_ENUM,io=class extends DD{constructor(t,r,s,n,i,o=void 0){super(MD.UPSERT,s,n,i,o),this.records=t,this.original_records=r}};a(io,"LMDBUpsertTransactionObject");gf.exports=io});var wf=S((TJ,bf)=>{"use strict";var PD=Zs(),BD=T().OPERATIONS_ENUM,ao=class extends PD{constructor(t,r,s,n,i=void 0){super(BD.DELETE,s,n,t,i),this.original_records=r}};a(ao,"LMDBDeleteTransactionObject");bf.exports=ao});var si=S((mJ,yf)=>{"use strict";var vD=require("path"),Cf=X(),HD=Of(),qD=Nf(),GD=If(),FD=wf(),zs=Ye(),Lf=b(),{CONFIG_PARAMS:VD}=T(),Uf=Y();Uf.initSync();var oo=T().OPERATIONS_ENUM,{getTransactionAuditStorePath:kD}=te();yf.exports=$D;async function $D(e,t){if(Uf.get(VD.LOGGING_AUDITLOG)===!1)return;let r=vD.join(kD(),e.schema.toString()),s=await Cf.openEnvironment(r,e.table,!0),n=xD(e,t);if(!(n===void 0||n.hash_values.length===0)&&s!==void 0){Cf.initializeDBIs(s,zs.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,zs.TRANSACTIONS_DBIS);try{let i=n.timestamp;return await s.dbis[zs.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{s.dbis[zs.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,n),Lf.isEmpty(n.user_name)||s.dbis[zs.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(n.user_name,i);for(let o=0;o<n.hash_values.length;o++)s.dbis[zs.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(n.hash_values[o],i)})}catch(i){throw i}}}a($D,"writeTransaction");function xD(e,t){let r=Lf.isEmpty(e.hdb_user)?void 0:e.hdb_user.username;if(e.operation===oo.INSERT)return new HD(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===oo.UPDATE)return new qD(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===oo.UPSERT)return new GD(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===oo.DELETE)return new FD(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(xD,"createTransactionObject")});var Hu=S((AJ,Df)=>{"use strict";var YD=Ja(),RJ=zn(),js=T(),KD=za(),WD=Qs().insertRecords,QD=X(),JD=require("path"),XD=I(),ZD=to(),{getBaseSchemaPath:zD}=te(),jD=si();Df.exports=eM;async function eM(e){try{let{schema_table:t,attributes:r}=YD(e);KD(e,r,t.hash_attribute),e.schema!==js.SYSTEM_SCHEMA_NAME&&(r.includes(js.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(js.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(js.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(js.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await ZD(e.hdb_auth_header,t,r),n=JD.join(zD(),e.schema.toString()),i=await QD.openEnvironment(n,e.table),o=await WD(i,t.hash_attribute,r,e.records,e[js.CLUSTERING_FLAG]!==!0);try{await jD(e,o)}catch(c){XD.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:s,txn_time:o.txn_time}}catch(t){throw t}}a(eM,"lmdbCreateRecords")});var Bf=S((OJ,Pf)=>{"use strict";var Mf=T(),tM=Hu(),rM=zn(),sM=require("fs-extra"),nM=require("path"),{getBaseSchemaPath:iM}=te();Pf.exports=aM;async function aM(e){let t=[{name:e.schema,createddate:Date.now()}],r=new rM(Mf.SYSTEM_SCHEMA_NAME,Mf.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await tM(r),await sM.mkdirp(nM.join(iM(),e.schema.toString()))}a(aM,"lmdbCreateSchema")});var Hf=S((pJ,vf)=>{"use strict";var co=class{constructor(t=[],r=[],s=void 0,n=[]){this.deleted=t,this.skipped=r,this.txn_time=s,this.original_records=n}};a(co,"DeleteRecordsResponseObject");vf.exports=co});var Fu=S((bJ,Ff)=>{"use strict";var qf=X(),qu=as(),Gu=Ke().LMDB_ERRORS_ENUM,oM=Ye(),Gf=I(),NJ=b(),cM=require("lmdb"),_M=Hf(),{OVERFLOW_MARKER:gJ,MAX_SEARCH_KEY_LENGTH:IJ}=oM;async function uM(e,t,r){if(qu.validateEnv(e),t===void 0)throw new Error(Gu.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(Gu.IDS_REQUIRED):new Error(Gu.IDS_MUST_BE_ARRAY);try{let s=qf.listDBIs(e);qf.initializeDBIs(e,t,s);let n=new _M,i,o=[],c=[];for(let E=0,d=r.length;E<d;E++)try{i=r[E];let h=e.dbis[t].get(i);if(!h){n.skipped.push(i);continue}let m=e.dbis[t].ifVersion(i,cM.IF_EXISTS,()=>{e.dbis[t].remove(i);for(let R=0;R<s.length;R++){let C=s[R];if(!h.hasOwnProperty(C)||C===t)continue;let L=e.dbis[C],B=h[C];if(B!=null)try{let z=qu.getIndexedValues(B);if(z)for(let V=0,Q=z.length;V<Q;V++)L.remove(z[V],i)}catch{Gf.warn(`cannot delete from attribute: ${C}, ${B}:${i}`)}}});o.push(m),c.push(i),n.original_records.push(h)}catch(h){Gf.warn(h),n.skipped.push(i)}let _=[],u=await Promise.all(o);for(let E=0,d=u.length;E<d;E++)u[E]===!0?n.deleted.push(c[E]):(n.skipped.push(c[E]),_.push(E));let l=0;for(let E=0;E<_.length;E++){let d=_[E];n.original_records.splice(d-l,1),l++}return n.txn_time=qu.getMicroTime(),n}catch(s){throw s}}a(uM,"deleteRecords");Ff.exports={deleteRecords:uM}});var ni=S((wJ,kf)=>{"use strict";var en=b(),lM=Fu(),EM=X(),dM=require("path"),{getBaseSchemaPath:hM}=te(),SM=si(),fM=I();kf.exports=TM;async function TM(e,t=!0){let s=global.hdb_schema[e.schema][e.table].hash_attribute;if(en.isEmpty(s))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(en.isEmptyOrZeroLength(e.hash_values)&&!en.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let _=e.records[c][s];en.isEmpty(_)||e.hash_values.push(_)}}if(en.isEmptyOrZeroLength(e.hash_values))return Vf([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(en.isEmptyOrZeroLength(e.records)){e.records=[];for(let c=0;c<e.hash_values.length;c++)e.records[c]={[s]:e.hash_values[c]}}let n=dM.join(hM(),e.schema.toString()),i=await EM.openEnvironment(n,e.table),o=await lM.deleteRecords(i,s,e.hash_values);try{t===!0&&await SM(e,o)}catch(c){fM.error(`unable to write transaction due to ${c.message}`)}return Vf(o.deleted,o.skipped,o.txn_time)}catch(n){throw n}}a(TM,"lmdbDeleteRecords");function Vf(e,t,r){let s=e.length+t.length,n=s===1?"record":"records";return{message:`${e.length} of ${s} ${n} successfully deleted`,deleted_hashes:e,skipped_hashes:t,txn_time:r}}a(Vf,"createDeleteResponse")});var ku=S((LJ,$f)=>{"use strict";var mM=T(),CJ=as();function Vu(e,t){let r=Object.create(null);if(t.length===1&&mM.SEARCH_WILDCARDS.indexOf(t[0])>=0)Object.assign(r,e);else for(let s=0;s<t.length;s++){let n=t[s],i=e[n];r[n]=i===void 0?null:i}return r}a(Vu,"parseRow");function RM(e,t,r,s){let n=Vu(r,e);s.push(n)}a(RM,"searchAll");function AM(e,t,r,s){let n=Vu(r,e);s[t]=n}a(AM,"searchAllToMap");function OM(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(OM,"iterateDBI");function _s(e,t,r,s,n){let i=Object.create(null);i[n]=e;let o;s===n?o=e:(o=t,s!==void 0&&(i[s]=o)),r[0].push(o),r[1].push(i)}a(_s,"pushResults");function pM(e,t,r,s,n,i){t.toString().endsWith(e)&&_s(t,r,s,n,i)}a(pM,"endsWith");function NM(e,t,r,s,n,i){t.toString().includes(e)&&_s(t,r,s,n,i)}a(NM,"contains");function gM(e,t,r,s,n,i){t>e&&_s(t,r,s,n,i)}a(gM,"greaterThanCompare");function IM(e,t,r,s,n,i){t>=e&&_s(t,r,s,n,i)}a(IM,"greaterThanEqualCompare");function bM(e,t,r,s,n,i){t<e&&_s(t,r,s,n,i)}a(bM,"lessThanCompare");function wM(e,t,r,s,n,i){t<=e&&_s(t,r,s,n,i)}a(wM,"lessThanEqualCompare");$f.exports={parseRow:Vu,searchAll:RM,searchAllToMap:AM,iterateDBI:OM,endsWith:pM,contains:NM,greaterThanCompare:gM,greaterThanEqualCompare:IM,lessThanCompare:bM,lessThanEqualCompare:wM,pushResults:_s}});var tn=S((DJ,Jf)=>{"use strict";var wt=X(),CM=I(),St=as(),Br=Ye(),ce=Ke().LMDB_ERRORS_ENUM,UJ=b(),LM=T(),kt=ku(),yJ=require("lmdb"),{OVERFLOW_MARKER:xf,MAX_SEARCH_KEY_LENGTH:UM}=Br,ii={lazy:!0};function Yf(e,t,r,s,n=!1,i=void 0,o=void 0){let c=Object.create(null),_=wt.openDBI(e,r);_[Br.DBI_DEFINITION_NAME].is_hash_attribute&&(t=r);let u=$u(e,t,r);for(let{key:l,value:E}of _.getRange({start:n?void 0:!1,end:n?!1:void 0,limit:i,offset:o,reverse:n}))s(u(l,E),E,c,t,r);return c}a(Yf,"iterateFullIndex");function ai(e,t,r,s,n,i=!1,o=void 0,c=void 0,_=!1,u=!1){let l=[[],[]],E=wt.openDBI(e,r),d=$u(e,t,r);E[Br.DBI_DEFINITION_NAME].is_hash_attribute&&(t=r);let h=i===!0?s:n,m=i===!0?n:s,R=i===!0?!_:!u,C=i===!0?u:_;for(let{key:L,value:B}of E.getRange({start:m,end:h,reverse:i,limit:o,offset:c,inclusiveEnd:R,exclusiveStart:C}))kt.pushResults(d(L,B),B,l,t,r);return l}a(ai,"iterateRangeBetween");function $u(e,t,r){let s;return function(n,i){if(typeof n=="string"&&n.endsWith(xf)){if(!s)if(t)s=wt.openDBI(e,t);else{let c=wt.listDBIs(e);for(let _=0,u=c.length;_<u&&(s=wt.openDBI(e,c[_]),!s[Br.DBI_DEFINITION_NAME].is_hash_attribute);_++);}n=s.get(i,ii)[r]}return n}}a($u,"getOverflowCheck");function yM(e,t,r,s=!1,n=void 0,i=void 0){if(St.validateEnv(e),t===void 0)throw new Error(ce.HASH_ATTRIBUTE_REQUIRED);_o(r),r=oi(e,r);let o=[],c=wt.openDBI(e,t);for(let{key:_,value:u}of c.getRange({start:s?void 0:!1,end:s?!1:void 0,limit:n,offset:i,reverse:s}))kt.searchAll(r,_,u,o);return o}a(yM,"searchAll");function DM(e,t,r,s=!1,n=void 0,i=void 0){if(St.validateEnv(e),t===void 0)throw new Error(ce.HASH_ATTRIBUTE_REQUIRED);return _o(r),r=oi(e,r),Yf(e,t,t,kt.searchAllToMap.bind(null,r),s,n,i)}a(DM,"searchAllToMap");function MM(e,t,r=!1,s=void 0,n=void 0){if(St.validateEnv(e),t===void 0)throw new Error(ce.ATTRIBUTE_REQUIRED);return Yf(e,void 0,t,kt.iterateDBI,r,s,n)}a(MM,"iterateDBI");function PM(e,t){if(St.validateEnv(e),t===void 0)throw new Error(ce.HASH_ATTRIBUTE_REQUIRED);return wt.statDBI(e,t).entryCount}a(PM,"countAll");function BM(e,t,r,s,n=!1,i=void 0,o=void 0){vr(e,r,s);let c=wt.openDBI(e,r);s=St.convertKeyValueToWrite(s);let _=[[],[]];if(c[Br.DBI_DEFINITION_NAME].is_hash_attribute){t=r;let u=c.get(s,ii);u!==void 0&&kt.pushResults(s,u,_,t,r)}else for(let u of c.getValues(s,{reverse:n,limit:i,offset:o}))kt.pushResults(s,u,_,t,r);return _}a(BM,"equals");function vM(e,t,r){return vr(e,t,r),wt.openDBI(e,t).getValuesCount(r)}a(vM,"count");function HM(e,t,r,s,n=!1,i=void 0,o=void 0){vr(e,r,s);let c=[[],[]],_=wt.openDBI(e,r);_[Br.DBI_DEFINITION_NAME].is_hash_attribute&&(t=r),s=St.convertKeyValueToWrite(s);let u=!0;if(typeof s=="number"&&(u=!1),n===!0){let l;for(let E of _.getKeys({start:s}))if(!E.startsWith(s)){l=E;break}l!==void 0&&(Number.isInteger(o)?o++:i++);for(let{key:E,value:d}of _.getRange({start:l,end:void 0,reverse:n,limit:i,offset:o}))if(E!==l){if(E.toString().startsWith(s))kt.pushResults(E,d,c,t,r);else if(u===!0)break}}else for(let{key:l,value:E}of _.getRange({start:s,reverse:n,limit:i,offset:o}))if(l.toString().startsWith(s))kt.pushResults(l,E,c,t,r);else if(u===!0)break;return c}a(HM,"startsWith");function qM(e,t,r,s,n=!1,i=void 0,o=void 0){return Kf(e,t,r,s,n,i,o,!0)}a(qM,"endsWith");function Kf(e,t,r,s,n=!1,i=void 0,o=void 0,c=!1){vr(e,r,s);let _=[[],[]],u=wt.openDBI(e,r);u[Br.DBI_DEFINITION_NAME].is_hash_attribute&&(t=r);let l=$u(e,t,r);o=Number.isInteger(o)?o:0;for(let d of u.getKeys({end:n?!1:void 0,reverse:n})){if(i===0)break;let h=d.toString();if(h.endsWith(xf))for(let m of u.getValues(d)){let R=l(d,m);(c?R.endsWith(s):R.includes(s))&&E(R,m)}else if(c?h.endsWith(s):h.includes(s))if(u[Br.DBI_DEFINITION_NAME].is_hash_attribute)E(d,d);else for(let m of u.getValues(d))E(d,m)}function E(d,h){if(o>0){o--;return}i!==0&&(kt.pushResults(d,h,_,t,r),i--)}return a(E,"found_match"),_}a(Kf,"contains");function GM(e,t,r,s,n=!1,i=void 0,o=void 0){vr(e,r,s);let c=typeof s,_;return c==="string"?_="\uFFFF":c==="number"?_=1/0:c==="boolean"&&(_=!0),ai(e,t,r,s,_,n,i,o,!0,!1)}a(GM,"greaterThan");function FM(e,t,r,s,n=!1,i=void 0,o=void 0){vr(e,r,s);let c=typeof s,_;return c==="string"?_="\uFFFF":c==="number"?_=1/0:c==="boolean"&&(_=!0),ai(e,t,r,s,_,n,i,o,!1,!1)}a(FM,"greaterThanEqual");function VM(e,t,r,s,n=!1,i=void 0,o=void 0){vr(e,r,s);let c=typeof s,_;return c==="string"?_="\0":c==="number"?_=-1/0:c==="boolean"&&(_=!1),ai(e,t,r,_,s,n,i,o,!1,!0)}a(VM,"lessThan");function kM(e,t,r,s,n=!1,i=void 0,o=void 0){vr(e,r,s);let c=typeof s,_;return c==="string"?_="\0":c==="number"?_=-1/0:c==="boolean"&&(_=!1),ai(e,t,r,_,s,n,i,o,!1,!1)}a(kM,"lessThanEqual");function $M(e,t,r,s,n,i=!1,o=void 0,c=void 0){if(St.validateEnv(e),r===void 0)throw new Error(ce.ATTRIBUTE_REQUIRED);if(s===void 0)throw new Error(ce.START_VALUE_REQUIRED);if(n===void 0)throw new Error(ce.END_VALUE_REQUIRED);if(s=St.convertKeyValueToWrite(s),n=St.convertKeyValueToWrite(n),s>n)throw new Error(ce.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return ai(e,t,r,s,n,i,o,c)}a($M,"between");function xM(e,t,r,s){if(St.validateEnv(e),t===void 0)throw new Error(ce.HASH_ATTRIBUTE_REQUIRED);if(_o(r),r=oi(e,r),s===void 0)throw new Error(ce.ID_REQUIRED);let n=null,i=e.dbis[t].get(s,r.length<3?ii:void 0);return i&&(n=kt.parseRow(i,r)),n}a(xM,"searchByHash");function YM(e,t,r){if(St.validateEnv(e),t===void 0)throw new Error(ce.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(ce.ID_REQUIRED);let s=!0;return e.dbis[t].get(r,ii)===void 0&&(s=!1),s}a(YM,"checkHashExists");function KM(e,t,r,s,n=[]){Qf(e,t,r,s,n);let i=Wf(e,t,r,s,n);return Object.values(i)}a(KM,"batchSearchByHash");function WM(e,t,r,s,n=[]){return Qf(e,t,r,s,n),Wf(e,t,r,s,n)}a(WM,"batchSearchByHashToMap");function Wf(e,t,r,s,n=[]){r=oi(e,r);let i=Object.create(null),o=r.length<3?ii:void 0;for(let c=0;c<s.length;c++){let _=s[c];try{let u=e.dbis[t].get(_,o);if(u){let l=kt.parseRow(u,r);i[_]=l}else n.push(_)}catch(u){throw CM.warn(u),u}}return i}a(Wf,"batchHashSearch");function Qf(e,t,r,s,n){if(St.validateEnv(e),t===void 0)throw new Error(ce.HASH_ATTRIBUTE_REQUIRED);if(_o(r),!Array.isArray(s))throw s===void 0?new Error(ce.IDS_REQUIRED):new Error(ce.IDS_MUST_BE_ARRAY);Array.isArray(n)||(n=[])}a(Qf,"initializeBatchSearchByHash");function _o(e){if(!Array.isArray(e))throw e===void 0?new Error(ce.FETCH_ATTRIBUTES_REQUIRED):new Error(ce.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(_o,"validateFetchAttributes");function vr(e,t,r){if(St.validateEnv(e),t===void 0)throw new Error(ce.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(ce.SEARCH_VALUE_REQUIRED);if(r?.length>UM)throw new Error(ce.SEARCH_VALUE_TOO_LARGE)}a(vr,"validateComparisonFunctions");function oi(e,t){return t.length===1&&LM.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=wt.listDBIs(e)),t}a(oi,"setGetWholeRowAttributes");Jf.exports={searchAll:yM,searchAllToMap:DM,count:vM,countAll:PM,equals:BM,startsWith:HM,endsWith:qM,contains:Kf,searchByHash:xM,setGetWholeRowAttributes:oi,batchSearchByHash:KM,batchSearchByHashToMap:WM,checkHashExists:YM,iterateDBI:MM,greaterThan:GM,greaterThanEqual:FM,lessThan:VM,lessThanEqual:kM,between:$M}});var ci=S((PJ,jf)=>{var Xf=require("lodash"),Zf=de(),W=require("joi"),QM=b(),{hdb_schema_table:$t,checkValidTable:zf}=Er(),{handleHDBError:JM,hdb_errors:XM}=D(),{HTTP_STATUS_CODES:ZM}=XM,MJ=W.object({schema:$t,table:$t,hash_values:W.array().min(1).items(W.alternatives(W.string(),W.number())).required(),get_attributes:W.array().min(1).items($t).required()}),zM=W.object({schema:$t,table:$t,search_attribute:$t,search_value:W.any().required(),get_attributes:W.array().min(1).items($t).required(),desc:W.bool(),limit:W.number().integer().min(1),offset:W.number().integer().min(0)}),jM=W.object({schema:$t,table:$t,operator:W.string().valid("and","or").default("and").lowercase(),offset:W.number().integer().min(0),limit:W.number().integer().min(1),get_attributes:W.array().min(1).items($t).required(),conditions:W.array().min(1).items(W.object({search_attribute:$t,search_type:W.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between").required(),search_value:W.when("search_type",{switch:[{is:"equals",then:W.any()},{is:"between",then:W.array().items(W.alternatives([W.string(),W.number()])).length(2)}],otherwise:W.alternatives(W.string(),W.number())}).required()})).required()});jf.exports=function(e,t){let r=null;switch(t){case"value":r=Zf.validateBySchema(e,zM);break;case"hashes":let i=function(o){n?n+=". "+o:n=o};var s=i;a(i,"addError");let n;i(zf("schema",e.schema)),i(zf("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"),n&&(r=new Error(n.trim()));break;case"conditions":r=Zf.validateBySchema(e,jM);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let n=QM.checkGlobalSchemaTable(e.schema,e.table);if(n)return JM(new Error,n,ZM.NOT_FOUND);let o=global.hdb_schema[e.schema][e.table].attributes,c=[...e.get_attributes];if(t==="value"&&c.push(e.search_attribute),t==="conditions")for(let u=0,l=e.conditions.length;u<l;u++){let E=e.conditions[u];c.push(E.search_attribute)}let _=Xf.filter(c,u=>u!=="*"&&u.attribute!=="*"&&!Xf.some(o,l=>l===u||l.attribute===u||l.attribute===u.attribute));if(_&&_.length>0){let u=_.join(", ");return u=u.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${u}'`)}}return r}});var xu=S((BJ,eT)=>{"use strict";var eP=X(),tP=ci(),rP=require("path"),{getBaseSchemaPath:sP}=te();eT.exports=nP;function nP(e){let t=tP(e,"hashes");if(t)throw t;let r=rP.join(sP(),e.schema.toString());return eP.openEnvironment(r,e.table)}a(nP,"initialize")});var Yu=S((vJ,tT)=>{"use strict";var iP=tn(),aP=xu();tT.exports=oP;async function oP(e){try{let t=await aP(e),r=global.hdb_schema[e.schema][e.table];return iP.batchSearchByHashToMap(t,r.hash_attribute,e.get_attributes,e.hash_values)}catch(t){throw t}}a(oP,"lmdbGetDataByHash")});var us=S((HJ,rT)=>{"use strict";var uo=class{constructor(t,r,s,n){this.schema=t,this.table=r,this.hash_values=s,this.get_attributes=n}};a(uo,"SearchByHashObject");rT.exports=uo});var nT=S((GJ,sT)=>{"use strict";var qJ=us(),cP=tn(),_P=xu();sT.exports=uP;async function uP(e){try{let t=await _P(e),r=global.hdb_schema[e.schema][e.table];return cP.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}catch(t){throw t}}a(uP,"lmdbSearchByHash")});var xt=S((FJ,iT)=>{"use strict";var lo=class{constructor(t,r,s,n,i,o,c,_=!1,u=void 0,l=void 0){this.schema=t,this.table=r,this.search_attribute=s,this.search_value=n,this.hash_attribute=i,this.get_attributes=o,this.end_value=c,this.reverse=_,this.limit=u,this.offset=l}};a(lo,"SearchObject");iT.exports=lo});var Eo=S((VJ,uT)=>{"use strict";var Qe=tn(),lP=X(),EP=require("path"),dP=b(),U=Ye(),ls=T(),{getBaseSchemaPath:hP}=te(),SP=ts(),aT=Ke().LMDB_ERRORS_ENUM,{compareKeys:rn}=require("ordered-binary"),hr=ls.SEARCH_WILDCARDS;async function fP(e,t,r){let s;e.schema===ls.SYSTEM_SCHEMA_NAME?s=SP[e.table]:s=global.hdb_schema[e.schema][e.table];let n=_T(e,s.hash_attribute,r,t);return oT(e,n,s.hash_attribute,r)}a(fP,"prepSearch");async function oT(e,t,r,s){let n=EP.join(hP(),e.schema.toString()),i=await lP.openEnvironment(n,e.table),o=cT(i,e,t,r);if([U.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,U.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,U.SEARCH_TYPES.SEARCH_ALL,U.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(RP(e,r)===!1)return s===!0?mP(o):o[1];let _=o[0];return s===!0?Qe.batchSearchByHashToMap(i,r,e.get_attributes,_):Qe.batchSearchByHash(i,r,e.get_attributes,_)}a(oT,"executeSearch");function cT(e,t,r,s){let n,i=s;t.get_attributes.indexOf(s)<0&&(i=void 0);let{reverse:o,limit:c,offset:_}=t;switch(o=typeof o=="boolean"?o:!1,c=Number.isInteger(c)?c:void 0,_=Number.isInteger(_)?_:void 0,r){case U.SEARCH_TYPES.EQUALS:n=Qe.equals(e,i,t.search_attribute,t.search_value,o,c,_);break;case U.SEARCH_TYPES.CONTAINS:n=Qe.contains(e,i,t.search_attribute,t.search_value,o,c,_);break;case U.SEARCH_TYPES.ENDS_WITH:case U.SEARCH_TYPES._ENDS_WITH:n=Qe.endsWith(e,i,t.search_attribute,t.search_value,o,c,_);break;case U.SEARCH_TYPES.STARTS_WITH:case U.SEARCH_TYPES._STARTS_WITH:n=Qe.startsWith(e,i,t.search_attribute,t.search_value,o,c,_);break;case U.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return Qe.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case U.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return Qe.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case U.SEARCH_TYPES.SEARCH_ALL:return Qe.searchAll(e,s,t.get_attributes,o,c,_);case U.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return Qe.searchAllToMap(e,s,t.get_attributes,o,c,_);case U.SEARCH_TYPES.BETWEEN:n=Qe.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,_);break;case U.SEARCH_TYPES.GREATER_THAN:case U.SEARCH_TYPES._GREATER_THAN:n=Qe.greaterThan(e,i,t.search_attribute,t.search_value,o,c,_);break;case U.SEARCH_TYPES.GREATER_THAN_EQUAL:case U.SEARCH_TYPES._GREATER_THAN_EQUAL:n=Qe.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,_);break;case U.SEARCH_TYPES.LESS_THAN:case U.SEARCH_TYPES._LESS_THAN:n=Qe.lessThan(e,i,t.search_attribute,t.search_value,o,c,_);break;case U.SEARCH_TYPES.LESS_THAN_EQUAL:case U.SEARCH_TYPES._LESS_THAN_EQUAL:n=Qe.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,_);break;default:return Object.create(null)}return n}a(cT,"searchByType");function TP(e){let t=e.search_type,r=e.search_attribute,s=e.search_value;switch(t){case U.SEARCH_TYPES.EQUALS:return n=>n[r]===s;case U.SEARCH_TYPES.CONTAINS:return n=>typeof n[r]=="string"&&n[r].includes(s);case U.SEARCH_TYPES.ENDS_WITH:case U.SEARCH_TYPES._ENDS_WITH:return n=>typeof n[r]=="string"&&n[r].endsWith(s);case U.SEARCH_TYPES.STARTS_WITH:case U.SEARCH_TYPES._STARTS_WITH:return n=>typeof n[r]=="string"&&n[r].startsWith(s);case U.SEARCH_TYPES.BETWEEN:return n=>{let i=n[r];return rn(i,s[0])>=0&&rn(i,s[1])<=0};case U.SEARCH_TYPES.GREATER_THAN:case U.SEARCH_TYPES._GREATER_THAN:return n=>rn(n[r],s)>0;case U.SEARCH_TYPES.GREATER_THAN_EQUAL:case U.SEARCH_TYPES._GREATER_THAN_EQUAL:return n=>rn(n[r],s)>=0;case U.SEARCH_TYPES.LESS_THAN:case U.SEARCH_TYPES._LESS_THAN:return n=>rn(n[r],s)<0;case U.SEARCH_TYPES.LESS_THAN_EQUAL:case U.SEARCH_TYPES._LESS_THAN_EQUAL:return n=>rn(n[r],s)<=0;default:return Object.create(null)}}a(TP,"filterByType");function mP(e){let t=Object.create(null);for(let r=0,s=e[0].length;r<s;r++)t[e[0][r]]=e[1][r];return t}a(mP,"createMapFromArrays");function RP(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 s=!1;for(let n=0;n<e.get_attributes.length;n++)if(r.indexOf(e.get_attributes[n])<0){s=!0;break}return s}a(RP,"checkToFetchMore");function _T(e,t,r,s){if(dP.isEmpty(s)){let n=e.search_value;typeof n=="object"?n=JSON.stringify(n):n=n.toString();let i=n.charAt(0),o=n.charAt(n.length-1),c=!1;if(e.search_attribute===t&&(c=!0),hr.indexOf(n)>-1)return r===!0?U.SEARCH_TYPES.SEARCH_ALL_TO_MAP:U.SEARCH_TYPES.SEARCH_ALL;if(n.indexOf(hr[0])<0&&n.indexOf(hr[1])<0)return c===!0?r===!0?U.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:U.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:U.SEARCH_TYPES.EQUALS;if(hr.indexOf(i)>=0&&hr.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),U.SEARCH_TYPES.CONTAINS;if(hr.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),U.SEARCH_TYPES.ENDS_WITH;if(hr.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),U.SEARCH_TYPES.STARTS_WITH;if(n.includes(hr[0])||n.includes(hr[1]))return U.SEARCH_TYPES.EQUALS;throw new Error(aT.UNKNOWN_SEARCH_TYPE)}else switch(s){case ls.VALUE_SEARCH_COMPARATORS.BETWEEN:return U.SEARCH_TYPES.BETWEEN;case ls.VALUE_SEARCH_COMPARATORS.GREATER:return U.SEARCH_TYPES.GREATER_THAN;case ls.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return U.SEARCH_TYPES.GREATER_THAN_EQUAL;case ls.VALUE_SEARCH_COMPARATORS.LESS:return U.SEARCH_TYPES.LESS_THAN;case ls.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return U.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(aT.UNKNOWN_SEARCH_TYPE)}}a(_T,"createSearchTypeFromSearchObject");uT.exports={executeSearch:oT,createSearchTypeFromSearchObject:_T,prepSearch:fP,searchByType:cT,filterByType:TP}});var ET=S(($J,lT)=>{"use strict";var kJ=xt(),AP=ci(),OP=b(),pP=T(),NP=Eo();lT.exports=gP;async function gP(e,t){if(!OP.isEmpty(t)&&pP.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let s=AP(e,"value");if(s)throw s;let n=!0;try{return await NP.prepSearch(e,t,n)}catch(i){throw i}}a(gP,"lmdbGetDataByValue")});var sn=S((YJ,dT)=>{"use strict";var xJ=xt(),IP=ci(),bP=b(),wP=T(),CP=Eo();dT.exports=LP;async function LP(e,t){if(!bP.isEmpty(t)&&wP.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let s=IP(e,"value");if(s)throw s;let n=!1;try{return await CP.prepSearch(e,t,n)}catch(i){throw i}}a(LP,"lmdbSearchByValue")});var ST=S((WJ,hT)=>{"use strict";var KJ=Ye(),ho=class{constructor(t,r,s,n,i=void 0,o=void 0,c="and"){this.schema=t,this.table=r,this.get_attributes=s,this.limit=i,this.offset=o,this.conditions=n,this.operator=c}};a(ho,"SearchByConditionsObject");var So=class{constructor(t,r,s){this.search_attribute=t,this.search_type=r,this.search_value=s}};a(So,"SearchCondition");var fo=class{constructor(t,r){this.attribute=t,this.desc=r}};a(fo,"SortAttribute");hT.exports={SearchByConditionsObject:ho,SearchCondition:So,SortAttribute:fo}});var OT=S((JJ,AT)=>{"use strict";var QJ=ST().SearchByConditionsObject,UP=xt(),yP=ci(),Ku=tn(),To=Ye(),RT=Eo(),DP=ku(),fT=require("lodash"),{getBaseSchemaPath:MP}=te(),PP=require("path"),BP=X(),{handleHDBError:TT,hdb_errors:vP}=D(),{HTTP_STATUS_CODES:HP}=vP,qP=1e8,GP={lazy:!0};AT.exports=FP;async function FP(e){try{let t=yP(e,"conditions");if(t)throw TT(t,t.message,HP.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=PP.join(MP(),e.schema.toString()),s=await BP.openEnvironment(r,e.table),n=global.hdb_schema[e.schema][e.table],i=fT.sortBy(e.conditions,o=>{if(o.estimated_count===void 0){let c=o.search_type;c===To.SEARCH_TYPES.EQUALS?o.estimated_count=Ku.count(s,o.search_attribute,o.search_value):c===To.SEARCH_TYPES.CONTAINS||c===To.SEARCH_TYPES.ENDS_WITH?o.estimated_count=1/0:o.estimated_count=qP}return o.estimated_count});if(!e.operator||e.operator.toLowerCase()==="and"){let[o]=await mT(s,e,i[0],n.hash_attribute),c=s.dbis[n.hash_attribute],_=i.slice(1).map(RT.filterByType),u=_.length,l=[],E=Ku.setGetWholeRowAttributes(s,e.get_attributes),d=e.offset>-1?e.offset:0,h=e.limit>-1?e.limit:1/0;e:for(let m of o){let R=c.get(m,GP);for(let C=0;C<u;C++)if(!_[C](R))continue e;if(d>0){d--;continue}if(h<=0)break;h--,l.push(DP.parseRow(R,E))}return l}else{let o=[],c=[];for(let _ of i){let[u]=await mT(s,e,_,n.hash_attribute);c.push(u)}if(o=fT.union(...c),e.limit>0||e.offset>0){let _=Number.isInteger(e.limit)?e.limit:o.length;o=o.splice(e.offset,_)}return Ku.batchSearchByHash(s,n.hash_attribute,e.get_attributes,o)}}catch(t){throw TT(t)}}a(FP,"lmdbSearchByConditions");async function mT(e,t,r,s){let n=new UP(t.schema,t.table,void 0,void 0,s,t.get_attributes),i=r.search_type;return n.search_attribute=r.search_attribute,i===To.SEARCH_TYPES.BETWEEN?(n.search_value=r.search_value[0],n.end_value=r.search_value[1]):n.search_value=r.search_value,RT.searchByType(e,n,i,s)}a(mT,"executeConditionSearch")});var _i=S((XJ,pT)=>{"use strict";var VP=T().OPERATIONS_ENUM,mo=class{constructor(t,r,s,n=void 0){this.operation=VP.DELETE,this.schema=t,this.table=r,this.hash_values=s,this.__origin=n}};a(mo,"DeleteObject");pT.exports=mo});var Wu=S((ZJ,NT)=>{"use strict";var Ro=class{constructor(t,r,s){this.schema=t,this.table=r,this.attribute=s}};a(Ro,"DropAttributeObject");NT.exports=Ro});var Ju=S((jJ,gT)=>{"use strict";var kP=xt(),$P=_i(),zJ=Wu(),zt=T(),xP=b(),Qu=X(),YP=ts(),KP=sn(),WP=ni(),{getBaseSchemaPath:QP}=te(),JP=require("path");gT.exports=XP;async function XP(e,t=!0){let r;e.schema===zt.SYSTEM_SCHEMA_NAME?r=YP[e.table]:r=global.hdb_schema[e.schema][e.table];let s=await zP(e),n=JP.join(QP(),e.schema.toString()),i=await Qu.openEnvironment(n,e.table);return t===!0&&await ZP(e,i,r.hash_attribute),Qu.dropDBI(i,e.attribute),s}a(XP,"lmdbDropAttribute");async function ZP(e,t,r){let s=Qu.openDBI(t,r),n,i=e.attribute;for(let{key:o,value:c,version:_}of s.getRange({start:!1,versions:!0})){let u={};for(let l in c)l!==i&&(u[l]=c[l]);n=t.dbis[r].put(o,u,_)}await n}a(ZP,"removeAttributeFromAllObjects");async function zP(e){let t=new kP(zt.SYSTEM_SCHEMA_NAME,zt.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,zt.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[zt.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,zt.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),s=(await KP(t)).filter(o=>o[zt.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(xP.isEmptyOrZeroLength(s))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let n=s.map(o=>o[zt.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new $P(zt.SYSTEM_SCHEMA_NAME,zt.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);return WP(i)}a(zP,"dropAttributeFromSystem")});var CT=S((eX,wT)=>{"use strict";var jP=Ju(),eB=Wu(),IT=b(),bT=I(),tB=Ke().LMDB_ERRORS_ENUM;wT.exports=rB;async function rB(e){if(IT.isEmpty(global.hdb_schema[e.schema])||IT.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);let t=global.hdb_schema[e.schema][e.table],r;try{for(let s=0;s<t.attributes.length;s++){r=t.attributes[s].attribute;let n=new eB(e.schema,e.table,r);try{await jP(n,!1)}catch(i){i.message!==tB.DBI_DOES_NOT_EXIST&&bT.error(`unable to drop attribute ${e.schema}.${e.table}.${r}:`+i)}}}catch(s){throw bT.error(`Error dropping attribute ${r}`),s}}a(rB,"lmdbDropAllAttributes")});var Xu=S((rX,HT)=>{"use strict";var MT=xt(),PT=_i(),BT=sn(),vT=ni(),tX=CT(),it=T(),LT=b(),UT=X(),{getBaseSchemaPath:sB,getTransactionAuditStorePath:nB}=te(),yT=require("path"),DT=I();HT.exports=iB;async function iB(e){try{if(LT.isEmpty(global.hdb_schema[e.schema])||LT.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await aB(e),await oB(e);let t=yT.join(sB(),e.schema.toString());try{await UT.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")DT.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=yT.join(nB(),e.schema.toString());await UT.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")DT.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(iB,"lmdbDropTable");async function aB(e){let t=new MT(it.SYSTEM_SCHEMA_NAME,it.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,it.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[it.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=await BT(t),s=[];for(let i=0;i<r.length;i++){let o=r[i];s.push(o.id)}if(s.length===0)return;let n=new PT(it.SYSTEM_SCHEMA_NAME,it.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);await vT(n)}a(aB,"deleteAttributesFromSystem");async function oB(e){let t=new MT(it.SYSTEM_SCHEMA_NAME,it.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,it.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[it.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,it.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,it.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,s;try{r=await BT(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&&(s=o)}if(!s)throw new Error(`${e.schema}.${e.table} was not found`);let n=new PT(it.SYSTEM_SCHEMA_NAME,it.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[s.id]);try{await vT(n)}catch(i){throw i}}a(oB,"dropTableFromSystem")});var GT=S((nX,qT)=>{"use strict";var cB=require("fs-extra"),_B=xt(),uB=us(),lB=_i(),EB=Xu(),dB=ni(),hB=Yu(),SB=sn(),Sr=T(),sX=b(),fB=require("path"),{getBaseSchemaPath:TB}=te(),{handleHDBError:mB,hdb_errors:RB}=D(),{HDB_ERROR_MSGS:AB,HTTP_STATUS_CODES:OB}=RB;qT.exports=pB;async function pB(e){let t;try{t=await NB(e.schema);let r=new _B(Sr.SYSTEM_SCHEMA_NAME,Sr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),s=await SB(r);for(let o=0;o<s.length;o++){let c={schema:t,table:s[o].name};try{await EB(c)}catch(_){if(_.message!=="invalid environment")throw _}}let n=new lB(Sr.SYSTEM_SCHEMA_NAME,Sr.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await dB(n);let i=fB.join(TB(),t.toString());await cB.remove(i)}catch(r){throw r}}a(pB,"lmdbDropSchema");async function NB(e){let t=new uB(Sr.SYSTEM_SCHEMA_NAME,Sr.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,s;try{r=await hB(t)}catch(n){throw n}for(let n in r)r[n].name===e&&(s=e);if(!s)throw mB(new Error,AB.SCHEMA_NOT_FOUND(e),OB.NOT_FOUND,void 0,void 0,!0);return s}a(NB,"validateDropSchema")});var Zu=S((iX,FT)=>{"use strict";var Ao=class{constructor(t,r,s){this.schema=t,this.table=r,this.hash_attribute=s}};a(Ao,"CreateTableObject");FT.exports=Ao});var kT=S((oX,VT)=>{"use strict";var gB=require("path"),IB=require("fs-extra"),Oo=X(),{getTransactionAuditStorePath:bB}=te(),zu=Ye(),aX=Zu();VT.exports=wB;async function wB(e){let t;try{let r=gB.join(bB(),e.schema.toString());await IB.mkdirp(r),t=await Oo.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{Oo.createDBI(t,zu.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),Oo.createDBI(t,zu.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),Oo.createDBI(t,zu.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(wB,"createTransactionsAuditEnvironment")});var KT=S((cX,YT)=>{"use strict";var ju=T(),$T=X(),CB=Qs(),LB=require("path"),{getSystemSchemaPath:UB,getBaseSchemaPath:yB}=te(),DB=ts(),MB=Qa(),el=Wa(),PB=I(),BB=kT(),rl=DB.hdb_table,xT=[];for(let e=0;e<rl.attributes.length;e++)xT.push(rl.attributes[e].attribute);YT.exports=vB;async function vB(e,t){let r=LB.join(yB(),t.schema.toString()),s=new el(t.schema,t.table,ju.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),n=new el(t.schema,t.table,ju.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new el(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await $T.createEnvironment(r,t.table),e!==void 0){let o=await $T.openEnvironment(UB(),ju.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await CB.insertRecords(o,rl.hash_attribute,xT,[e]),await tl(s),await tl(n),await tl(i)}await BB(t)}catch(o){throw o}}a(vB,"lmdbCreateTable");async function tl(e){try{await MB(e)}catch(t){PB.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(tl,"createAttribute")});var QT=S((_X,WT)=>{"use strict";var HB=Ja(),qB=za(),GB=to(),nn=T(),FB=Qs().updateRecords,VB=X(),kB=require("path"),{getBaseSchemaPath:$B}=te(),xB=si(),YB=I();WT.exports=KB;async function KB(e){try{let{schema_table:t,attributes:r}=HB(e);qB(e,r,t.hash_attribute),e.schema!==nn.SYSTEM_SCHEMA_NAME&&(r.includes(nn.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(nn.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(nn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(nn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await GB(e.hdb_auth_header,t,r),n=kB.join($B(),e.schema.toString()),i=await VB.openEnvironment(n,e.table),o=await FB(i,t.hash_attribute,r,e.records,e[nn.CLUSTERING_FLAG]!==!0);try{await xB(e,o)}catch(c){YB.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:s,txn_time:o.txn_time}}catch(t){throw t}}a(KB,"lmdbUpdateRecords")});var XT=S((uX,JT)=>{"use strict";var WB=T().OPERATIONS_ENUM,po=class{constructor(t,r,s,n=void 0){this.operation=WB.UPSERT,this.schema=t,this.table=r,this.records=s,this.__origin=n}};a(po,"UpsertObject");JT.exports=po});var zT=S((EX,ZT)=>{"use strict";var lX=XT(),QB=Ja(),JB=za(),XB=to(),an=T(),ZB=Qs().upsertRecords,zB=X(),jB=require("path"),{getBaseSchemaPath:ev}=te(),tv=si(),rv=I(),{handleHDBError:sv,hdb_errors:nv}=D();ZT.exports=iv;async function iv(e){let t;try{t=QB(e)}catch(_){throw sv(_,_.message,nv.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:s}=t;JB(e,s,r.hash_attribute),e.schema!==an.SYSTEM_SCHEMA_NAME&&(s.includes(an.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||s.push(an.TIME_STAMP_NAMES_ENUM.CREATED_TIME),s.includes(an.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||s.push(an.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await XB(e.hdb_auth_header,r,s),i=jB.join(ev(),e.schema.toString()),o=await zB.openEnvironment(i,e.table),c=await ZB(o,r.hash_attribute,s,e.records,e[an.CLUSTERING_FLAG]!==!0);try{await tv(e,c)}catch(_){rv.error(`unable to write transaction due to ${_.message}`)}return{written_hashes:c.written_hashes,schema_table:r,new_attributes:n,txn_time:c.txn_time}}a(iv,"lmdbUpsertRecords")});var nm=S((dX,sm)=>{"use strict";var av=xt(),jT=b(),em=I(),ov=sn(),tm=T(),cv=Fu().deleteRecords,_v=X(),uv=require("path"),{getBaseSchemaPath:lv}=te(),{promisify:Ev}=require("util"),dv=Ev(setTimeout),rm=1e4,hv=10;sm.exports=Sv;async function Sv(e){let t=global.hdb_schema[e.schema][e.table].hash_attribute;if(jT.isEmptyOrZeroLength(t))throw new Error(`Could not retrieve hash attribute for schema: ${e.schema} table: ${e.table}`);let r=Date.parse(e.date),s;try{let n=new av(e.schema,e.table,tm.TIME_STAMP_NAMES_ENUM.CREATED_TIME,r,void 0,[t]);s=await ov(n,tm.VALUE_SEARCH_COMPARATORS.LESS)}catch(n){throw em.error(`Error searching for date: ${e.date} in schema: ${e.schema} table: ${e.table}`),n}return jT.isEmptyOrZeroLength(s)?(em.trace("No records found to delete"),{message:"No records found to delete"}):await fv(e,s,t)}a(Sv,"lmdbDeleteRecordsBefore");async function fv(e,t,r){let s=uv.join(lv(),e.schema.toString()),n=await _v.openEnvironment(s,e.table),i={message:"",deleted_hashes:[],skipped_hashes:[]};for(let o=0,c=t.length;o<c;o+=rm){let _=t.slice(o,o+rm),u=[];for(let l=0,E=_.length;l<E;l++)u.push(_[l][r]);try{let l=await cv(n,r,u);i.deleted_hashes=i.deleted_hashes.concat(l.deleted),i.skipped_hashes=i.skipped_hashes.concat(l.skipped)}catch(l){throw l}await dv(hv)}return i.message=`${i.deleted_hashes.length} of ${i.deleted_hashes.length+i.skipped_hashes.length} records successfully deleted`,i}a(fv,"chunkDeletes")});var am=S((hX,im)=>{"use strict";var No=class{constructor(t,r,s){this.schema=t,this.table=r,this.timestamp=s}};a(No,"DeleteBeforeObject");im.exports=No});var cm=S((SX,om)=>{"use strict";var go=class{constructor(t=void 0,r=void 0,s=0){this.start_timestamp=t,this.end_timestamp=r,this.transactions_deleted=s}};a(go,"DeleteAuditLogsBeforeResults");om.exports=go});var lm=S((TX,um)=>{"use strict";var sl=X(),{getTransactionAuditStorePath:Tv}=te(),fX=am(),mv=require("path"),ui=Ye(),Rv=b(),_m=cm(),Av=require("util").promisify,Ov=Av(setTimeout),pv=1e4,Nv=100;um.exports=gv;async function gv(e){let t=mv.join(Tv(),e.schema),r=await sl.openEnvironment(t,e.table,!0),s=sl.listDBIs(r);sl.initializeDBIs(r,ui.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,s);let n,i=new _m;do n=await Iv(r,e.timestamp),i.start_timestamp===void 0&&(i.start_timestamp=n.start_timestamp),n.end_timestamp!==void 0&&(i.end_timestamp=n.end_timestamp),i.transactions_deleted+=n.transactions_deleted,await Ov(Nv);while(n.transactions_deleted>0);return i}a(gv,"deleteAuditLogsBefore");async function Iv(e,t){let r=new _m;try{let s=e.dbis[ui.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],n;for(let{key:i,value:o}of s.getRange({start:!1})){if(i>=t)break;r.start_timestamp===void 0&&(r.start_timestamp=i),n=s.remove(i);let c=o[ui.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];Rv.isEmpty(c)||(n=e.dbis[ui.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let _=0;_<o.hash_values.length;_++)n=e.dbis[ui.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[_],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>pv)break}return await n,r}catch(s){throw s}}a(Iv,"deleteTransactions")});var mm=S((mX,Tm)=>{"use strict";var nl=X(),on=Ye(),Em=as(),il=T(),dm=b(),{getTransactionAuditStorePath:bv}=te(),wv=require("path"),Cv=tn(),Io=Zs(),Lv=I();Tm.exports=Uv;async function Uv(e){let t=wv.join(bv(),e.schema),r=await nl.openEnvironment(t,e.table,!0),s=nl.listDBIs(r);nl.initializeDBIs(r,on.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,s);let n;switch(e.search_type){case il.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return hm(r,e.search_values);case il.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return n=global.hdb_schema[e.schema][e.table].hash_attribute,Dv(r,e.search_values,n);case il.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return yv(r,e.search_values);default:return hm(r)}}a(Uv,"readAuditLog");function hm(e,t=[0,Em.getMicroTime()]){dm.isEmpty(t[0])&&(t[0]=0),dm.isEmpty(t[1])&&(t[1]=Em.getMicroTime());let r=[];try{let s=e.dbis[on.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],n;for(let i of s.getKeys({start:t[1]}))if(i!==t[1]){n=i;break}for(let{value:i}of s.getRange({start:t[0],end:n})){let o=Object.assign(new Io,i);r.push(o)}return r}catch(s){throw s}}a(hm,"searchTransactionsByTimestamp");function yv(e,t=[]){let r=new Map;for(let s=0;s<t.length;s++){let n=t[s],i=[];for(let o of e.dbis[on.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(n))i.push(o);r.set(n,fm(e,i))}return Object.fromEntries(r)}a(yv,"searchTransactionsByUsername");function Dv(e,t,r){let s=new Map;for(let c=0,_=t.length;c<_;c++){let u=t[c],l=Cv.equals(e,on.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,on.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,u);for(let E=0,d=l[0].length;E<d;E++){let h=l[0][E],m=Number(h);s.has(m)?s.get(m).push(u.toString()):s.set(m,[u.toString()])}}let n=Array.from(s.keys()),i=fm(e,n),o=new Map;for(let c=0;c<i.length;c++){let _=i[c],u=_.timestamp,l=s.get(u);Sm(_,"records",r,l,o),Sm(_,"original_records",r,l,o)}return Object.fromEntries(o)}a(Dv,"searchTransactionsByHashValues");function Sm(e,t,r,s,n){let i=e.timestamp;if(e[t])for(let o=0;o<e[t].length;o++){let c=e[t][o],_=c[r].toString();if(s.indexOf(_)>=0)if(n.has(_)){let u=n.get(_),l=u[u.length-1];if(l.timestamp===i)l[t]=[c];else{let E=new Io(e.operation,e.user_name,i,void 0);E[t]=[c],u.push(E)}}else{let u=new Io(e.operation,e.user_name,i,void 0);u[t]=[c],n.set(_,[u])}}}a(Sm,"loopRecords");function fm(e,t){let r=[];try{let s=e.dbis[on.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP];for(let n=0;n<t.length;n++)try{let i=s.get(t[n]);if(i){let o=Object.assign(new Io,i);r.push(o)}}catch(i){Lv.warn(i)}return r}catch(s){throw s}}a(fm,"batchSearchTransactions")});var Am=S((RX,Rm)=>{"use strict";var Mv=require("path"),{getBaseSchemaPath:Pv}=te(),Bv=X();Rm.exports={writeTransaction:vv};async function vv(e,t,r){let s=Mv.join(Pv(),e);return(await Bv.openEnvironment(s,t)).transaction(r)}a(vv,"writeTransaction")});var pm=S((AX,Om)=>{"use strict";var Hv=require("path"),{getBaseSchemaPath:qv}=te(),Gv=X();Om.exports={flush:Fv};async function Fv(e,t){let r=Hv.join(qv(),e.toString());return(await Gv.openEnvironment(r,t.toString())).flushed}a(Fv,"flush")});var gm=S((OX,Nm)=>{"use strict";var Re=I(),{handleHDBError:Vv}=D(),kv=_u(),$v=Qa(),xv=Hu(),Yv=Bf(),Kv=ni(),Wv=Yu(),Qv=nT(),Jv=ET(),Xv=sn(),Zv=OT(),zv=GT(),jv=KT(),eH=QT(),tH=zT(),rH=nm(),sH=lm(),nH=Xu(),iH=Ju(),aH=mm(),oH=Am(),cH=pm(),bo=class extends kv{async searchByConditions(t){try{return Zv(t)}catch(r){throw Re.error(r),r}}async getDataByHash(t){try{return await Wv(t)}catch(r){throw Re.error(r),r}}async searchByHash(t){try{return await Qv(t)}catch(r){throw Re.error(r),r}}async getDataByValue(t,r){try{return await Jv(t,r)}catch(s){throw Re.error(s),s}}async searchByValue(t){try{return await Xv(t)}catch(r){throw Re.error(r),r}}async createSchema(t){try{return await Yv(t)}catch(r){throw Re.error(r),r}}async dropSchema(t){try{return await zv(t)}catch(r){throw Re.error(r),r}}async createTable(t,r){try{return await jv(t,r)}catch(s){throw Re.error(s),s}}async dropTable(t){try{return await nH(t)}catch(r){throw Re.error(r),r}}async createAttribute(t){try{return await $v(t)}catch(r){throw Re.error(r),r}}async createRecords(t){try{return await xv(t)}catch(r){throw Re.error(r),r}}async updateRecords(t){try{return await eH(t)}catch(r){throw Re.error(r),r}}async upsertRecords(t){try{return await tH(t)}catch(r){throw Vv(r,null,null,Re.ERR,r)}}async deleteRecords(t){try{return await Kv(t)}catch(r){throw Re.error(r),r}}async deleteRecordsBefore(t){try{return await rH(t)}catch(r){throw Re.error(r),r}}async dropAttribute(t){try{return await iH(t)}catch(r){throw Re.error(r),r}}async deleteAuditLogsBefore(t){try{return await sH(t)}catch(r){throw Re.error(r),r}}async readAuditLog(t){try{return await aH(t)}catch(r){throw Re.error(r),r}}writeTransaction(t,r,s){return oH.writeTransaction(t,r,s)}flush(t,r){return cH.flush(t,r)}};a(bo,"LMDBBridge");Nm.exports=bo});var fr=S((pX,bm)=>{"use strict";var _H=gm(),uH=_u(),lH=Y();lH.initSync();var Im;function EH(){return Im instanceof uH?Im:new _H}a(EH,"getBridge");bm.exports=EH()});var Um=S((NX,Lm)=>{"use strict";var wm=require("lodash"),li=require("mathjs"),dH=require("jsonata"),Cm=b();Lm.exports={distinct_array:e=>Array.isArray(e)&&e.length>1?wm.uniqWith(e,wm.isEqual):e,searchJSON:hH,mad:Ei.bind(null,li.mad),mean:Ei.bind(null,li.mean),mode:Ei.bind(null,li.mode),prod:Ei.bind(null,li.prod),median:Ei.bind(null,li.median)};function Ei(e,t,r,s){return s===1?t==null?[]:[t]:s===2?(t!=null&&r.push(t),r):r!=null&&r.length>0?e(r):null}a(Ei,"aggregateFunction");function hH(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(Cm.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),Cm.isEmpty(this.__ala__.res[r])){let s=dH(e);this.__ala__.res[r]=s}return this.__ala__.res[r].evaluate(t)}a(hH,"searchJSON")});var Dm=S((gX,ym)=>{"use strict";var he=require("moment"),al="YYYY-MM-DDTHH:mm:ss.SSSZZ";he.suppressDeprecationWarnings=!0;ym.exports={current_date:()=>he().utc().format("YYYY-MM-DD"),current_time:()=>he().utc().format("HH:mm:ss.SSS"),extract:(e,t)=>{switch(t.toLowerCase()){case"year":return he(e).utc().format("YYYY");case"month":return he(e).utc().format("MM");case"day":return he(e).utc().format("DD");case"hour":return he(e).utc().format("HH");case"minute":return he(e).utc().format("mm");case"second":return he(e).utc().format("ss");case"millisecond":return he(e).utc().format("SSS");default:break}},date:e=>he(e).utc().format(al),date_format:(e,t)=>he(e).utc().format(t),date_add:(e,t,r)=>he(e).utc().add(t,r).valueOf(),date_sub:(e,t,r)=>he(e).utc().subtract(t,r).valueOf(),date_diff:(e,t,r)=>{let s=he(e).utc(),n=he(t).utc();return r?s.diff(n,r,!0):s.diff(n)},now:()=>he().utc().valueOf(),get_server_time:()=>he().format(al),offset_utc:(e,t)=>he(e).utc().utcOffset(t).format(al)}});var vm=S((IX,Bm)=>{"use strict";var SH=require("@turf/area"),fH=require("@turf/length"),TH=require("@turf/circle"),mH=require("@turf/difference"),RH=require("@turf/distance"),AH=require("@turf/boolean-contains"),OH=require("@turf/boolean-equal"),pH=require("@turf/boolean-disjoint"),NH=require("@turf/helpers"),Mm=T(),k=b();Bm.exports={geoArea:gH,geoLength:IH,geoCircle:bH,geoDifference:wH,geoDistance:Pm,geoNear:CH,geoContains:LH,geoEqual:UH,geoCrosses:yH,geoConvert:DH};var ol="geo1 is required",cl="geo2 is required";function gH(e){if(k.isEmpty(e))throw new Error("geoJSON is required");return typeof e=="string"&&(e=k.autoCast(e)),SH.default(e)}a(gH,"geoArea");function IH(e,t){if(k.isEmpty(e))throw new Error("geoJSON is required");return typeof e=="string"&&(e=k.autoCast(e)),fH.default(e,{units:t||"kilometers"})}a(IH,"geoLength");function bH(e,t,r){if(k.isEmpty(e))throw new Error("point is required");if(k.isEmpty(t))throw new Error("radius is required");return typeof e=="string"&&(e=k.autoCast(e)),TH.default(e,t,{units:r||"kilometers"})}a(bH,"geoCircle");function wH(e,t){if(k.isEmpty(e))throw new Error("poly1 is required");if(k.isEmpty(t))throw new Error("poly2 is required");return typeof e=="string"&&(e=k.autoCast(e)),typeof t=="string"&&(t=k.autoCast(t)),mH(e,t)}a(wH,"geoDifference");function Pm(e,t,r){if(k.isEmpty(e))throw new Error("point1 is required");if(k.isEmpty(t))throw new Error("point2 is required");return typeof e=="string"&&(e=k.autoCast(e)),typeof t=="string"&&(t=k.autoCast(t)),RH.default(e,t,{units:r||"kilometers"})}a(Pm,"geoDistance");function CH(e,t,r,s){if(k.isEmpty(e))throw new Error("point1 is required");if(k.isEmpty(t))throw new Error("point2 is required");if(k.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=k.autoCast(e)),typeof t=="string"&&(t=k.autoCast(t)),isNaN(r))throw new Error("distance must be a number");return Pm(e,t,s)<=r}a(CH,"geoNear");function LH(e,t){if(k.isEmpty(e))throw new Error(ol);if(k.isEmpty(e))throw new Error(cl);return typeof e=="string"&&(e=k.autoCast(e)),typeof t=="string"&&(t=k.autoCast(t)),AH.default(e,t)}a(LH,"geoContains");function UH(e,t){if(k.isEmpty(e))throw new Error(ol);if(k.isEmpty(e))throw new Error(cl);return typeof e=="string"&&(e=k.autoCast(e)),typeof t=="string"&&(t=k.autoCast(t)),OH.default(e,t)}a(UH,"geoEqual");function yH(e,t){if(k.isEmpty(e))throw new Error(ol);if(k.isEmpty(e))throw new Error(cl);return typeof e=="string"&&(e=k.autoCast(e)),typeof t=="string"&&(t=k.autoCast(t)),!pH.default(e,t)}a(yH,"geoCrosses");function DH(e,t,r){if(k.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if(k.isEmpty(t))throw new Error("geo_type is required");if(k.isEmpty(Mm.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(Mm.GEO_CONVERSION_ENUM).join(",")}`);return NH[t](e,r)}a(DH,"geoConvert")});var wo=S((bX,Hm)=>{var Es=Um(),ft=Dm(),jt=vm();Hm.exports=e=>{e.aggr.mad=e.aggr.MAD=Es.mad,e.aggr.mean=e.aggr.MEAN=Es.mean,e.aggr.mode=e.aggr.MODE=Es.mode,e.aggr.prod=e.aggr.PROD=Es.prod,e.aggr.median=e.aggr.MEDIAN=Es.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=Es.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=Es.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=ft.current_date,e.fn.current_time=e.fn.CURRENT_TIME=ft.current_time,e.fn.extract=e.fn.EXTRACT=ft.extract,e.fn.date=e.fn.DATE=ft.date,e.fn.date_format=e.fn.DATE_FORMAT=ft.date_format,e.fn.date_add=e.fn.DATE_ADD=ft.date_add,e.fn.date_sub=e.fn.DATE_SUB=ft.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=ft.date_diff,e.fn.now=e.fn.NOW=ft.now,e.fn.offset_utc=e.fn.OFFSET_UTC=ft.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=ft.get_server_time,e.fn.getdate=e.fn.GETDATE=ft.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=ft.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=jt.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=jt.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=jt.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=jt.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=jt.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=jt.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=jt.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=jt.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=jt.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=jt.geoNear}});var Fm=S((wX,Gm)=>{"use strict";var di=require("lodash"),Me=require("alasql");Me.options.cache=!1;var MH=wo(),qm=require("clone"),Co=require("recursive-iterator"),v=I(),q=b(),cn=fr(),PH=T(),{hdb_errors:BH}=D(),vH="IS NULL",hi="There was a problem performing this search. Please check the logs and try again.";MH(Me);var Lo=class{constructor(t,r){if(q.isEmpty(t))throw v.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(),q.backtickASTSchemaItems(this.statement)}async search(){let t;try{let s=await this._checkEmptySQL();if(!q.isEmptyOrZeroLength(s))return v.trace("No results returned from checkEmptySQL SQLSearch method."),s}catch(s){throw v.error("Error thrown from checkEmptySQL in SQLSearch class method search."),v.error(s),new Error(hi)}try{let s=await this._getFetchAttributeValues();if(s)return s}catch(s){throw v.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),v.error(s),new Error(hi)}if(Object.keys(this.data).length===0)return v.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(s){throw v.error("Error thrown from processJoins in SQLSearch class method search."),v.error(s),new Error(hi)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(s){throw v.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),v.error(s),new Error(hi)}try{return t=await this._finalSQL(),t}catch(s){throw v.error("Error thrown from finalSQL in SQLSearch class method search."),v.error(s),new Error(hi)}}_getColumns(){let t=new Co(this.statement);for(let{node:r,path:s}of t)r&&r.columnid&&(this.columns[s[0]]||(this.columns[s[0]]=[]),this.columns[s[0]].push(qm(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=di.uniqBy(t,r=>[r.databaseid,r.tableid,r.as].join()),this.tables.forEach(r=>{let s=`${r.databaseid}_${r.as?r.as:r.tableid}`;this.data[s]={},this.data[s].__hash_name=global.hdb_schema[r.databaseid][r.tableid].hash_attribute,this.data[s].__merged_data={},this.data[s].__merged_attributes=[],this.data[s].__merged_attr_map={}})}_conditionsToFetchAttributeValues(){if(q.isEmpty(this.statement.where)){v.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new Co(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!q.isEmpty(r)&&r.right)if(q.isNotEmptyAndHasValue(r.right.value)){let s=q.autoCast(r.right.value);[!0,!1].indexOf(s)>=0?r.right=new Me.yy.LogicValue({value:s}):r.right instanceof Me.yy.StringValue&&!q.isEmpty(s)&&q.autoCasterIsNumberCheck(s.toString())&&(r.right=new Me.yy.NumValue({value:s}))}else Array.isArray(r.right)&&r.right.forEach((s,n)=>{let i=q.autoCast(s.value);[!0,!1].indexOf(i)>=0?r.right[n]=new Me.yy.LogicValue({value:i}):s instanceof Me.yy.StringValue&&q.autoCasterIsNumberCheck(i.toString())&&(r.right[n]=new Me.yy.NumValue({value:i}))});if(t){v.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new Co(this.statement.where))if(r&&r.left&&r.right&&(r.left.columnid||r.right.value)&&r.op){let s=new Set,n=r.left.columnid?r.left:r.right,i=this._findColumn(n);if(!i)continue;let o=[i.table.databaseid,i.table.tableid,i.attribute].join("/");if(!q.isEmpty(PH.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(q.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(q.isEmptyOrZeroLength(r.left.columnid)||q.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(q.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"=":!q.isEmpty(r.right.value)||!q.isEmpty(r.left.value)?s.add(q.isEmpty(r.right.value)?r.left.value:r.right.value):c=!0;break;case"IN":let _=Array.isArray(r.right)?r.right:r.left;for(let u=0;u<_.length;u++)if(_[u].value)s.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,...s])}}}_setAliasesForColumns(){if(q.isEmptyOrZeroLength(this.all_table_attributes)&&q.isEmptyOrZeroLength(this.statement.from)&&q.isEmptyOrZeroLength(this.columns.columns))return;let t=[],r={};this.statement.columns.forEach((s,n)=>{if(s.columnid==="*"){t.push(n);return}if(s.aggregatorid&&(this.has_aggregator=!0),!s.aggregatorid&&!s.funcid)if(s.as_orig=s.as?s.as:s.columnid,this.statement.joins)if(r[s.as_orig]>=0){let i=r[s.as_orig]+1;s.as=`[${s.as_orig+i}]`,r[s.as_orig]=i}else s.as=`[${s.as_orig}]`,r[s.as_orig]=0;else s.as=`[${s.as_orig}]`;!s.aggregatorid&&s.funcid&&s.args&&(s.as_orig=s.as?s.as:s.toString().replace(/'/g,'"'),s.as=`[${s.as_orig}]`),s.aggregatorid&&s.expression.columnid!=="*"&&(s.as_orig=s.as?s.as:s.expression.tableid?`${s.aggregatorid}(${s.expression.tableid}.${s.expression.columnid})`:`${s.aggregatorid}(${s.expression.columnid})`,s.as=`[${s.as_orig}]`)}),this.statement.columns.length>1&&t.length>0&&di.pullAt(this.statement.columns,t)}_findColumn(t){let r=this.all_table_attributes.filter(s=>{if(t.columnid_orig&&t.tableid_orig)return(s.table.as===t.tableid_orig||s.table.tableid===t.tableid_orig)&&s.attribute===t.columnid_orig;if(t.tableid)return(s.table.as===t.tableid||s.table.tableid===t.tableid)&&s.attribute===t.columnid;let n=t.columnid_orig?t.columnid_orig:t.columnid;return s.attribute===n});if(q.isEmptyOrZeroLength(r)){let s=this.columns.columns.filter(n=>n.as?t.columnid===n.as:!1);q.isEmptyOrZeroLength(s)||(r=this.all_table_attributes.filter(n=>n.attribute===s[0].columnid&&s[0].tableid&&s[0].tableid===(n.table.as?n.table.as:n.table.tableid)))}return r[0]}async _checkEmptySQL(){let t=[];if(q.isEmptyOrZeroLength(this.all_table_attributes)&&!q.isEmptyOrZeroLength(this.columns.columns))return t;if(q.isEmptyOrZeroLength(this.all_table_attributes)&&q.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await Me.promise(r)}catch(r){throw v.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),v.error(r),new Error("There was a problem with the SQL statement")}return t}_addFetchColumns(t){t&&t.length>0&&t.forEach(r=>{let s=this._findColumn(r);s&&this.fetch_attributes.push(qm(s))})}_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,s,n){let i=this.data[t].__merged_attr_map[s];this.data[t].__merged_data[r].splice(i,1,n)}async _getFetchAttributeValues(){if(q.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(vH)>-1&&this.tables.forEach(n=>{let i={columnid:global.hdb_schema[n.databaseid][n.tableid].hash_attribute,tableid:n.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=di.uniqBy(this.fetch_attributes,n=>[n.table.databaseid,n.table.as?n.table.as:n.table.tableid,n.attribute].join()),r)return await this._simpleSQLQuery();let s=this.fetch_attributes.reduce((n,i)=>{let o=`${i.table.databaseid}_${i.table.as?i.table.as:i.table.tableid}`,c=this.data[o].__hash_name;return n[o]||(n[o]=[],n[o].push(null),this._addColumnToMergedAttributes(o,c)),i.attribute!==c&&(n[o].push(null),this._addColumnToMergedAttributes(o,i.attribute)),n},{});for(let n of this.fetch_attributes){let i=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`,o=this.data[i].__hash_name,c={schema:n.table.databaseid,table:n.table.tableid,get_attributes:[n.attribute]},_=!1,u=[n.table.databaseid,n.table.tableid,n.attribute].join("/");if(n.attribute===o&&(_=!0),!q.isEmpty(this.exact_search_values[u])&&!this.exact_search_values[u].ignore&&!q.isEmptyOrZeroLength(this.exact_search_values[u].values))if(_)try{c.hash_values=Array.from(this.exact_search_values[u].values);let l=await cn.getDataByHash(c);for(let E of c.hash_values)E in l&&!this.data[i].__merged_data[E]&&(this.data[i].__merged_data[E]=[...s[i]],this._setMergedHashAttribute(i,E))}catch(l){v.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),v.error(l)}else try{c.search_attribute=n.attribute,await Promise.all(Array.from(this.exact_search_values[u].values).map(async l=>{let E=Object.assign({},c);E.search_value=l;let d=await cn.getDataByValue(E);for(let h in d)this.data[i].__merged_data[h]?this._updateMergedAttribute(i,h,n.attribute,d[h][n.attribute]):(this.data[i].__merged_data[h]=[...s[i]],this._updateMergedAttribute(i,h,n.attribute,d[h][n.attribute]),this._setMergedHashAttribute(i,q.autoCast(h)))}))}catch(l){v.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),v.error(l)}else if(!q.isEmpty(this.comparator_search_values[u])&&!this.comparator_search_values[u].ignore&&!q.isEmptyOrZeroLength(this.comparator_search_values[u].comparators))try{let l=this.comparator_search_values[u].comparators;for(let E=0,d=l.length;E<d;E++){let h=l[E];c.search_attribute=h.attribute,c.search_value=h.search_value;let m=await cn.getDataByValue(c,h.operation);if(_)for(let R in m)this.data[i].__merged_data[R]||(this.data[i].__merged_data[R]=[...s[i]],this._setMergedHashAttribute(i,q.autoCast(R)));else for(let R in m)this.data[i].__merged_data[R]?this._updateMergedAttribute(i,R,n.attribute,m[R][n.attribute]):(this.data[i].__merged_data[R]=[...s[i]],this._updateMergedAttribute(i,R,n.attribute,m[R][n.attribute]),this._setMergedHashAttribute(i,q.autoCast(R)))}}catch(l){v.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),v.error(l)}else try{c.search_attribute=n.attribute,c.search_value="*";let l=await cn.getDataByValue(c);if(_)for(let E in l)this.data[i].__merged_data[E]||(this.data[i].__merged_data[E]=[...s[i]],this._setMergedHashAttribute(i,q.autoCast(E)));else for(let E in l)this.data[i].__merged_data[E]?this._updateMergedAttribute(i,E,n.attribute,l[E][n.attribute]):(this.data[i].__merged_data[E]=[...s[i]],this._updateMergedAttribute(i,E,n.attribute,l[E][n.attribute]),this._setMergedHashAttribute(i,q.autoCast(E)))}catch(l){v.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),v.error(l)}}}_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 Me.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(n=>{let i=n.aggregatorid?n.expression:n,o=n.aggregatorid?n.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 s=r[0];if(t.is_func=!!s.funcid,t.is_aggregator=!!s.aggregatorid,s.as)if(s.as&&!t.expression.tableid)t.expression.columnid=s.as,t.expression.columnid_orig=s.as_orig;else{let n=new Me.yy.Column;n.columnid=s.as,n.columnid_orig=s.as_orig,t.expression=n}else{t.initial_select_column=Object.assign(new Me.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 n=t.is_func?new Me.yy.FuncValue:new Me.yy.Column;t.initial_select_column=Object.assign(n,s)}})}_addNonAggregatorsToFetchColumns(){let r=this.statement.order.filter(s=>!s.is_aggregator&&!s.is_ordinal).map(s=>s.is_func?{columnid:s.initial_select_column.args.filter(i=>!!i.columnid_orig)[0].columnid_orig}:{columnid:s.expression.columnid_orig});this._addFetchColumns(r)}async _processJoins(){let t=[],r=[],s=this.statement.from[0],n=[s],i=["? "+(s.as?" AS "+s.as:s.tableid)];t.push(Object.values(this.data[`${s.databaseid_orig}_${s.as?s.as_orig:s.tableid_orig}`].__merged_data)),this.statement.joins&&this.statement.joins.forEach(h=>{h.joinmode&&h.joinmode!=="INNER"&&(this.has_outer_join=!0),n.push(h.table);let m=h.joinmode+" JOIN ? AS "+(h.as?h.as:h.table.tableid);h.on&&(m+=" ON "+h.on.toString()),i.push(m),t.push(Object.values(this.data[`${h.table.databaseid_orig}_${h.table.as?h.table.as_orig:h.table.tableid_orig}`].__merged_data))});let o=[],c={};n.forEach(h=>{let m=this.data[`${h.databaseid_orig}_${h.as?h.as_orig:h.tableid_orig}`].__hash_name,R=h.as?h.as_orig:h.tableid_orig;o.push({key:`'${R}.${m}'`,schema:h.databaseid_orig,table:h.as?h.as_orig:h.tableid_orig,keys:new Set}),r.push(`${h.as?h.as:h.tableid}.\`${m}\` AS "${R}.${m}"`),c[h.as?h.as_orig:h.tableid_orig]=this.data[`${h.databaseid_orig}_${h.as?h.as_orig:h.tableid_orig}`].__merged_attributes});let _=this.statement.where?"WHERE "+this.statement.where:"",u="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(u="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(h=>{h.is_func?r.push(h.initial_select_column.toString()):h.initial_select_column.tableid?r.push(`${h.initial_select_column.tableid}.${h.initial_select_column.columnid} AS ${h.expression.columnid}`):r.push(`${h.initial_select_column.columnid} AS ${h.expression.columnid}`)}));let l="",E="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&(l=this.statement.limit?"LIMIT "+this.statement.limit:"",E=this.statement.offset?"OFFSET "+this.statement.offset:"");let d=[];try{let h=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${_} ${u} ${l} ${E}`,m=this._convertColumnsToIndexes(h,n);d=await Me.promise(m,t),t=null}catch(h){throw v.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),v.error(h),new Error("There was a problem processing the data.")}if(d&&d.length>0){for(let h=0,m=d.length;h<m;h++){let R=d[h];o.forEach(C=>{R[C.key]!==null&&R[C.key]!==void 0&&C.keys.add(R[C.key])})}o.forEach(h=>{let m=Object.keys(this.data[`${h.schema}_${h.table}`].__merged_data),R=di.difference(m,[...h.keys].map(C=>C.toString()));for(let C=0,L=R.length;C<L;C++){let B=R[C];delete this.data[`${h.schema}_${h.table}`].__merged_data[B]}})}return{existing_attributes:c,joined_length:d?d.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let s=[],n=new Co(this.columns);for(let{node:i}of n)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)&&s.push(o)}}s=di.uniqBy(s,i=>[i.table.databaseid,i.table.as?i.table.as:i.table.tableid,i.attribute].join());try{await this._getData(s)}catch(i){v.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),v.error(i)}}async _getData(t){try{let r=t.reduce((s,n)=>{let i=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`;return s[i]?s[i].columns.push(n.attribute):s[i]={schema:n.table.databaseid,table:n.table.tableid,columns:[n.attribute]},s},{});for(let s in r){let n=r[s],i=this.data[s].__merged_data,o=[];for(let l in i)o.push(i[l][0]);this.data[s].__merged_attributes.push(...n.columns);let c={schema:n.schema,table:n.table,hash_values:o,get_attributes:n.columns},_=await cn.getDataByHash(c),u=n.columns.length;for(let l=0,E=o.length;l<E;l++){let d=o[l],h=_[d];for(let m=0;m<u;m++){let R=n.columns[m],C=h[R]===void 0?null:h[R];this.data[s].__merged_data[d].push(C)}}}}catch(r){throw v.error("Error thrown from getDataByHash function in SQLSearch class method getData."),v.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(n=>{n.as=n.as?n.as:n.table.tableid,t.push(Object.values(this.data[`${n.table.databaseid_orig}_${n.table.as?n.table.as_orig:n.table.tableid_orig}`].__merged_data)),n.table.databaseid="",n.table.tableid="?"}),this.statement.order&&this.statement.order.forEach(n=>{if(n.is_ordinal)return;this.statement.columns.filter(o=>{let c=o.aggregatorid?o.expression:o,_=o.aggregatorid?o.as_orig:c.as_orig;return n.expression.tableid?c.columnid_orig===n.expression.columnid_orig&&c.tableid_orig===n.expression.tableid_orig:c.columnid_orig===n.expression.columnid_orig||n.expression.columnid_orig===_}).length===0&&(n.expression.columnid=n.initial_select_column.columnid)}),!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&(this.statement.limit&&delete this.statement.limit,this.statement.offset&&delete this.statement.offset);let s;try{let n=this._buildSQL();v.trace(`Final SQL: ${n}`),s=await Me.promise(n,t),this.has_outer_join&&(s=this._translateUndefinedValues(s)),v.trace(`Final AlaSQL results data included ${s.length} rows`)}catch(n){throw v.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),v.error(n),new Error("There was a problem running the generated sql.")}return s}_translateUndefinedValues(t){try{let r=[];for(let s of t){let n=Object.create(null);Object.keys(s).forEach(i=>{s[i]===void 0?n[i]=null:n[i]=s[i]}),r.push(n)}return r}catch(r){return v.error(BH.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),v.trace(r.stack),t}}_buildSQL(t=!0){let r=this.statement.toString();return this.statement.columns.forEach(s=>{if(s.funcid&&s.as){let n=s.toString().replace(" AS "+s.as,"");r=r.replace(s.toString(),n)}}),t===!0?this._convertColumnsToIndexes(r,this.tables):r}_convertColumnsToIndexes(t,r){let s=t,n={};r.forEach(i=>{i.databaseid_orig?n[`${i.databaseid_orig}_${i.as?i.as_orig:i.tableid_orig}`]=i.as?i.as:i.tableid:n[`${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 _=n[i],u=new RegExp(`${_}.\`${o}\``,"g"),l=`${_}.[${c}]`;s=s.replace(u,l)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let _=new RegExp(`\`${o}\``,"g"),u=`[${c}]`;s=s.replace(_,u)});return s}async _simpleSQLQuery(){let t=this.statement.columns.reduce((s,n)=>(n.as_orig&&n.as_orig!=n.columnid_orig?s[n.columnid_orig]=n.as_orig:s[n.columnid_orig]||(s[n.columnid_orig]=n.columnid_orig),s),{}),r=this.fetch_attributes.reduce((s,n)=>{let i=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`;return s[i]||(s[i]={}),s[i][t[n.attribute]]=null,s},{});for(let s of this.fetch_attributes){let n=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`,i={schema:s.table.databaseid,table:s.table.tableid,get_attributes:[s.attribute]};try{i.search_attribute=s.attribute,i.search_value="*";let o=await cn.getDataByValue(i);for(let c in o)this.data[n].__merged_data[c]||(this.data[n].__merged_data[c]=Object.assign({},r[n])),this.data[n].__merged_data[c][t[s.attribute]]=o[c][s.attribute]}catch(o){v.error("There was an error when processing this SQL operation. Check your logs"),v.error(o)}}return Object.values(Object.values(this.data)[0].__merged_data)}};a(Lo,"SQLSearch");Gm.exports=Lo});var Tt=S((CX,km)=>{"use strict";var HH=eS();km.exports={searchByConditions:VH,searchByHash:kH,searchByValue:$H,search:xH};var _l=fr(),Vm=require("util"),qH=Vm.callbackify(_l.searchByHash),GH=Vm.callbackify(_l.searchByValue),FH=Fm();async function VH(e){return _l.searchByConditions(e)}a(VH,"searchByConditions");function kH(e,t){try{qH(e,(r,s)=>{if(r){t(r);return}t(null,s)})}catch(r){return t(r)}}a(kH,"searchByHash");function $H(e,t){try{e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc),GH(e,(r,s)=>{if(r){t(r);return}t(null,s)})}catch(r){return t(r)}}a($H,"searchByValue");function xH(e,t){try{let r=new HH(e);r.validate(),new FH(r.statement,r.attributes).search().then(n=>{t(null,n)}).catch(n=>{t(n,null)})}catch(r){return t(r)}}a(xH,"search")});var Hr=S((LX,Km)=>{"use strict";var Si=require("crypto"),xm="aes-256-cbc",YH=32,KH=16,ul=64,Ym=32,WH=ul+Ym,$m=new Map;Km.exports={encrypt:QH,decrypt:JH,createNatsTableStreamName:XH};function QH(e){let t=Si.randomBytes(YH),r=Si.randomBytes(KH),s=Si.createCipheriv(xm,Buffer.from(t),r),n=s.update(e);n=Buffer.concat([n,s.final()]);let i=t.toString("hex"),o=r.toString("hex"),c=n.toString("hex");return i+o+c}a(QH,"encrypt");function JH(e){let t=e.substr(0,ul),r=e.substr(ul,Ym),s=e.substr(WH,e.length),n=Buffer.from(r,"hex"),i=Buffer.from(s,"hex"),o=Si.createDecipheriv(xm,Buffer.from(t,"hex"),n),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(JH,"decrypt");function XH(e,t){let r=`${e}.${t}`,s=$m.get(r);return s||(s=Si.createHash("md5").update(`${e}.${t}`).digest("hex"),$m.set(r,s)),s}a(XH,"createNatsTableStreamName")});var ds=S((UX,jm)=>{"use strict";var Qm=Tt(),qr=I(),Jm=xa(),ZH=require("lodash"),zH=require("path"),jH=Hr(),ll=b(),{promisify:Xm}=require("util"),j=T(),{handleHDBError:Uo,hdb_errors:eq}=D(),{HDB_ERROR_MSGS:yo,HTTP_STATUS_CODES:Zm}=eq,tq=Y();tq.initSync();var Wm=X(),rq=te(),fi=Xm(Qm.searchByValue),sq=Xm(Qm.searchByHash),_n="name",zm="hash_attribute",El="schema",nq="schema_table",iq="attribute";jm.exports={describeAll:aq,describeTable:Do,describeSchema:cq};async function aq(e){try{let t=ll.isEmptyOrZeroLength(e),r,s;t||(r=e.hdb_user.role.permission,s=r.super_user||r.cluster_user);let n={schema:j.SYSTEM_SCHEMA_NAME,table:j.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,search_attribute:_n,search_value:j.WILDCARD_SEARCH_VALUE,get_attributes:[_n]},i=await fi(n);if(ll.isEmptyOrZeroLength(i))return{};let o={},c={};for(let d in i)o[i[d].name]=!0,!t&&!s&&(c[i[d].name]=r[i[d].name].describe);let _={schema:j.SYSTEM_SCHEMA_NAME,table:j.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,search_attribute:j.ID_ATTRIBUTE_STRING,search_value:j.WILDCARD_SEARCH_VALUE,get_attributes:[zm,j.ID_ATTRIBUTE_STRING,_n,El]},u=await fi(_),l=[];for(let d of u)try{let h;if(t||s)h=await Do({schema:d.schema,table:d.name});else if(r&&r[d.schema].describe&&r[d.schema].tables[d.name].describe){let m=r[d.schema].tables[d.name].attribute_permissions;h=await Do({schema:d.schema,table:d.name},m)}h&&l.push(h)}catch(h){qr.error(h)}let E={};for(let d in l)t||s?(E[l[d].schema]==null&&(E[l[d].schema]={}),E[l[d].schema][l[d].name]=l[d],o[l[d].schema]&&delete o[l[d].schema]):c[l[d].schema]&&(E[l[d].schema]==null&&(E[l[d].schema]={}),E[l[d].schema][l[d].name]=l[d],o[l[d].schema]&&delete o[l[d].schema]);for(let d in o)t||s?E[d]={}:c[d]&&(E[d]={});return E}catch(t){return qr.error("Got an error in describeAll"),qr.error(t),Uo(new Error,yo.DESCRIBE_ALL_ERR)}}a(aq,"describeAll");async function Do(e,t){let{schema:r,table:s}=e;r=r.toString(),s=s.toString();let n=t;e.hdb_user&&!e.hdb_user.role.permission.super_user&&(n=e.hdb_user.role.permission[r].tables[s].attribute_permissions);let i={},o=Jm.describe_table(e);if(o)throw o;if(r===j.SYSTEM_SCHEMA_NAME)return global.hdb_schema[j.SYSTEM_SCHEMA_NAME][s];let c={schema:j.SYSTEM_SCHEMA_NAME,table:j.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,hash_attribute:j.SYSTEM_TABLE_HASH_ATTRIBUTES.TABLE_TABLE_HASH_ATTRIBUTE,search_attribute:_n,search_value:s,hash_values:[],get_attributes:[j.WILDCARD_SEARCH_VALUE]},_=await fi(c);if(!_||_.length===0)throw Uo(new Error,yo.TABLE_NOT_FOUND(e.schema,e.table),Zm.NOT_FOUND);for await(let u of _)try{if(u.schema!==r)continue;if(i=u,!i.hash_attribute)throw Uo(new Error,yo.INVALID_TABLE_ERR(i));let l={schema:j.SYSTEM_SCHEMA_NAME,table:j.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,hash_attribute:j.SYSTEM_TABLE_HASH_ATTRIBUTES.ATTRIBUTE_TABLE_HASH_ATTRIBUTE,search_attribute:nq,search_value:r+"."+s,get_attributes:[iq]},E=await fi(l);E=ZH.uniqBy(E,d=>d.attribute),n&&n.length>0&&(E=oq(n)),i.attributes=E,i.clustering_stream_name=jH.createNatsTableStreamName(u.schema,u.name);try{let d=zH.join(rq.getBaseSchemaPath(),i.schema.toString()),h=await Wm.openEnvironment(d,i.name),m=Wm.statDBI(h,i.hash_attribute);i.record_count=m.entryCount}catch(d){qr.warn(`unable to stat table dbi due to ${d}`)}}catch(l){qr.error(`There was an error getting attributes for table '${u.name}'`),qr.error(l)}return i}a(Do,"descTable");function oq(e){return e.reduce((t,r)=>(r.describe&&t.push({attribute:r.attribute_name}),t),[])}a(oq,"getAttrsByPerms");async function cq(e){let t=Jm.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 s=e.schema.toString(),n={schema:j.SYSTEM_SCHEMA_NAME,table:j.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,hash_attribute:j.SYSTEM_TABLE_HASH_ATTRIBUTES.TABLE_TABLE_HASH_ATTRIBUTE,search_attribute:El,search_value:s,hash_values:[],get_attributes:[zm,j.ID_ATTRIBUTE_STRING,_n,El]},i=await fi(n);if(i&&i.length<1){let o={schema:j.SYSTEM_SCHEMA_NAME,table:j.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,hash_attribute:j.SYSTEM_TABLE_HASH_ATTRIBUTES.SCHEMA_TABLE_HASH_ATTRIBUTE,hash_values:[s],get_attributes:[_n]},c=await sq(o);if(c&&c.length<1)throw Uo(new Error,yo.SCHEMA_NOT_FOUND(e.schema),Zm.NOT_FOUND);return{}}else{let o={};return await Promise.all(i.map(async c=>{try{let _;if(r&&r.tables[c.name]&&(_=r.tables[c.name]),ll.isEmpty(_)||_.describe){let u=await Do({schema:e.schema,table:c.name},_?_.attribute_permissions:null);u&&(o[u.name]=u)}}catch(_){qr.error(`Error describing schema table '${e.schema}.${c}'`),qr.error(_)}})),o}}a(cq,"describeSchema")});var Gr=S((MX,nR)=>{var yX=require("async"),un=ts(),DX=I(),{callbackify:rR,promisify:_q}=require("util");nR.exports={setSchemaDataToGlobal:eR,getTableSchema:Eq,getSystemSchema:hq,setSchemaDataToGlobalAsync:_q(eR)};var sR=ds(),uq=rR(sR.describeAll),lq=rR(sR.describeTable);function eR(e){uq(null,(t,r)=>{if(t){e(t);return}r.system||(r.system=un),global.hdb_schema=r,e(null,null)})}a(eR,"setSchemaDataToGlobal");function tR(e,t){return e==="system"?un[t]:global.hdb_schema[e][t]}a(tR,"returnSchema");function Eq(e,t,r){!global.hdb_schema||!global.hdb_schema[e]||!global.hdb_schema[e][t]?dq(e,t,s=>{if(s)return r(s);if(!global.hdb_schema[e])return r(`schema ${e} does not exist`);if(!global.hdb_schema[e]||!global.hdb_schema[e][t])return r(`table ${e}.${t} does not exist`);r(null,tR(e,t))}):r(null,tR(e,t))}a(Eq,"getTableSchema");function dq(e,t,r){let s={table:t,schema:e};if(e==="system"){global.hdb_schema?global.hdb_schema.system=un:global.hdb_schema={system:un},r();return}lq(s,(n,i)=>{if(n){r(n);return}if(!i.schema&&!i.name){r();return}global.hdb_schema||(global.hdb_schema={system:un}),global.hdb_schema[e]||(global.hdb_schema[e]={}),global.hdb_schema[e][t]=i,r()})}a(dq,"setTableDataToGlobal");function hq(){return un}a(hq,"getSystemSchema")});var oR=S((PX,aR)=>{"use strict";var dl=X(),Sq=I(),iR=Ke().LMDB_ERRORS_ENUM;aR.exports=fq;async function fq(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 dl.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==iR.ENV_REQUIRED)throw c}}break;case"drop_table":let s=`${e.schema}.${e.table}`,n=`txn.${s}`;try{await dl.closeEnvironment(global.lmdb_map[s]),await dl.closeEnvironment(global.lmdb_map[n])}catch(i){if(i.message!==iR.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){Sq.error(t)}}a(fq,"cleanLMDBMap")});var Lt=S((BX,uR)=>{"use strict";var Po=Mu(),Ct=b(),Tq=require("util"),Bo=fr(),mq=Gr(),hl=I(),{handleHDBError:Fr,hdb_errors:Rq}=D(),{HTTP_STATUS_CODES:hs}=Rq,Aq=Tq.promisify(mq.getTableSchema),Oq="updated",cR="inserted",_R="upserted";uR.exports={insert:Nq,update:gq,upsert:Iq,validation:pq,flush:bq};async function pq(e){if(Ct.isEmpty(e))throw new Error("invalid update parameters defined.");if(Ct.isEmptyOrZeroLength(e.schema))throw new Error("invalid schema specified.");if(Ct.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await Aq(e.schema,e.table),r=Po(e);if(r)throw r;if(!Array.isArray(e.records))throw new Error("records must be an array");let s=t.hash_attribute,n=new Set,i={},o=!1;return e.operation==="update"&&(o=!0),e.records.forEach(c=>{if(o&&Ct.isEmptyOrZeroLength(c[s]))throw hl.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(!Ct.isEmptyOrZeroLength(c[s])&&(c[s]==="null"||c[s]==="undefined"))throw hl.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[s]}" is not a valid hash attribute value`);!Ct.isEmpty(c[s])&&c[s]!==""&&n.has(Ct.autoCast(c[s]))&&(c.skip=!0),n.add(Ct.autoCast(c[s]));for(let _ in c)i[_]=1}),i[s]=1,{schema_table:t,hashes:Array.from(n),attributes:Object.keys(i)}}a(pq,"validation");async function Nq(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=Po(e);if(t)throw Fr(new Error,t.message,hs.BAD_REQUEST);let r=Ct.checkSchemaTableExist(e.schema,e.table);if(r)throw Fr(new Error,r,hs.BAD_REQUEST);try{let s=await Bo.createRecords(e);return Mo(cR,s.written_hashes,e,s.skipped_hashes,s.new_attributes,s.txn_time)}catch(s){throw s}}a(Nq,"insertData");async function gq(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=Po(e);if(t)throw Fr(new Error,t.message,hs.BAD_REQUEST);let r=Ct.checkSchemaTableExist(e.schema,e.table);if(r)throw Fr(new Error,r,hs.BAD_REQUEST);try{let s=await Bo.updateRecords(e);return Ct.isEmpty(s.existing_rows)?Mo(Oq,s.written_hashes,e,s.skipped_hashes,s.new_attributes,s.txn_time):Mo(s.update_action,[],e,s.hashes,void 0,s.txn_time)}catch(s){throw s}}a(gq,"updateData");async function Iq(e){if(e.operation!=="upsert")throw Fr(new Error,"invalid operation, must be upsert",hs.INTERNAL_SERVER_ERROR);let t=Po(e);if(t)throw Fr(new Error,t.message,hs.BAD_REQUEST);let r=Ct.checkSchemaTableExist(e.schema,e.table);if(r)throw Fr(new Error,r,hs.BAD_REQUEST);try{let s=await Bo.upsertRecords(e);return Mo(_R,s.written_hashes,e,[],s.new_attributes,s.txn_time)}catch(s){let n=`There was an error during an upsert op: ${s}`;throw Fr(s,null,null,hl.ERR,n)}}a(Iq,"upsertData");function Mo(e,t,r,s,n,i){let o={message:`${e} ${t.length} of ${t.length+s.length} records`,new_attributes:n,txn_time:i};return e===cR?(o.inserted_hashes=t,o.skipped_hashes=s,o):e===_R?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=s,o)}a(Mo,"returnObject");function bq(e){return Bo.flush(e.schema,e.table)}a(bq,"flush")});var fl=S((vX,dR)=>{var wq=de(),Sl=require("joi"),{hdb_schema_table:lR}=Er(),ER={schema:lR,table:lR},Cq={date:Sl.date().iso().required()},Lq={timestamp:Sl.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};dR.exports=function(e,t){let r=t==="timestamp"?{...ER,...Lq}:{...ER,...Cq},s=Sl.object(r);return wq.validateBySchema(e,s)}});var TR=S((HX,fR)=>{var Uq=de(),hR=require("joi"),{hdb_schema_table:SR}=Er(),yq=hR.object({schema:SR,table:SR,hash_values:hR.array().required()});fR.exports=function(e){return Uq.validateBySchema(e,yq)}});var RR=S((qX,mR)=>{"use strict";var vo=class{constructor(t,r,s,n,i){this.operation=t,this.schema=r,this.table=s,this.hash_attribute=n,this.records=i}};a(vo,"InsertObject");var Ho=class{constructor(t,r,s,n,i,o){this.schema=t,this.table=r,this.search_attribute=s,this.hash_attribute=n,this.get_attributes=i,this.search_value=o}};a(Ho,"NoSQLSeachObject");var qo=class{constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};a(qo,"DeleteResponseObject");mR.exports={InsertObject:vo,NoSQLSeachObject:Ho,DeleteResponseObject:qo}});var fs=S((GX,gR)=>{"use strict";var OR=fl(),Dq=TR(),Go=b(),AR=require("moment"),pR=I(),{promisify:Mq,callbackify:Pq}=require("util"),Ss=T(),Bq=Gr(),Tl=Mq(Bq.getTableSchema),ml=fr(),{DeleteResponseObject:vq}=RR(),{handleHDBError:Vr,hdb_errors:Hq}=D(),{HDB_ERROR_MSGS:Fo,HTTP_STATUS_CODES:kr}=Hq,qq="records successfully deleted",Gq=Pq(NR);gR.exports={delete:Gq,deleteRecord:NR,deleteFilesBefore:Fq,deleteAuditLogsBefore:Vq};async function Fq(e){let t=OR(e,"date");if(t)throw Vr(t,t.message,kr.BAD_REQUEST,void 0,void 0,!0);if(!AR(e.date,AR.ISO_8601).isValid())throw Vr(new Error,Fo.INVALID_DATE,kr.BAD_REQUEST,Ss.LOG_LEVELS.ERROR,Fo.INVALID_DATE,!0);let s=Go.checkSchemaTableExist(e.schema,e.table);if(s)throw Vr(new Error,s,kr.NOT_FOUND,Ss.LOG_LEVELS.ERROR,s,!0);try{let n=await ml.deleteRecordsBefore(e);if(await Tl(e.schema,e.table),pR.info(`Finished deleting files before ${e.date}`),n&&n.message)return n.message}catch(n){throw n}}a(Fq,"deleteFilesBefore");async function Vq(e){let t=OR(e,"timestamp");if(t)throw Vr(t,t.message,kr.BAD_REQUEST,void 0,void 0,!0);if(isNaN(e.timestamp))throw Vr(new Error,Fo.INVALID_VALUE("Timestamp"),kr.BAD_REQUEST,Ss.LOG_LEVELS.ERROR,Fo.INVALID_VALUE("Timestamp"),!0);let r=Go.checkSchemaTableExist(e.schema,e.table);if(r)throw Vr(new Error,r,kr.NOT_FOUND,Ss.LOG_LEVELS.ERROR,r,!0);try{let s=await ml.deleteAuditLogsBefore(e);return await Tl(e.schema,e.table),pR.info(`Finished deleting audit logs before ${e.timestamp}`),s}catch(s){throw s}}a(Vq,"deleteAuditLogsBefore");async function NR(e){let t=Dq(e);if(t)throw Vr(t,t.message,kr.BAD_REQUEST,void 0,void 0,!0);let r=Go.checkSchemaTableExist(e.schema,e.table);if(r)throw Vr(new Error,r,kr.NOT_FOUND,Ss.LOG_LEVELS.ERROR,r,!0);try{await Tl(e.schema,e.table);let s=await ml.deleteRecords(e);return Go.isEmptyOrZeroLength(s.message)&&(s.message=`${s.deleted_hashes.length} of ${e.hash_values.length} ${qq}`),s}catch(s){if(s.message===Ss.SEARCH_NOT_FOUND_MESSAGE){let n=new vq;return n.message=Ss.SEARCH_NOT_FOUND_MESSAGE,n.skipped_hashes=e.hash_values.length,n.deleted_hashes=0,n}throw s}}a(NR,"deleteRecord")});var Vo=S((FX,wR)=>{var kq=require("crypto"),IR=9;function $q(e){let t=Yq(IR),r=bR(e+t);return t+r}a($q,"createHash");function xq(e,t){let r=e.substr(0,IR),s=r+bR(t+r);return e===s}a(xq,"validateHash");function Yq(e){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ",r=t.length,s="";for(let n=0;n<e;n++){let i=Math.floor(Math.random()*r);s+=t[i]}return s}a(Yq,"generateSalt");function bR(e){return kq.createHash("md5").update(e).digest("hex")}a(bR,"md5");wR.exports={hash:$q,validate:xq}});var LR=S((VX,CR)=>{var Rl=de(),Je={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 Kq(e){return Je.password.presence=!0,Je.username.presence=!0,Je.role.presence=!0,Je.active.presence=!0,Rl.validateObject(e,Je)}a(Kq,"addUserValidation");function Wq(e){return Je.password.presence=!1,Je.username.presence=!0,Je.role.presence=!1,Je.active.presence=!1,Rl.validateObject(e,Je)}a(Wq,"alterUserValidation");function Qq(e){return Je.password.presence=!1,Je.username.presence=!0,Je.role.presence=!1,Je.active.presence=!1,Rl.validateObject(e,Je)}a(Qq,"dropUserValidation");CR.exports={addUserValidation:Kq,alterUserValidation:Wq,dropUserValidation:Qq}});var _e=S(($X,yR)=>{"use strict";var{platform:kX}=require("os"),Jq="nats-server.zip",Al="nats-server",Xq=process.platform==="win32"?`${Al}.exe`:Al,Ol="HDB",Zq=/^[^\s.,*>]+$/,UR="__request__",zq=a(e=>`${e}.${UR}`,"REQUEST_SUBJECT"),jq={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},eG={HUB:"hub.pid",LEAF:"leaf.pid"},tG={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},rG={stream_name:"__HARPERDB_WORK_QUEUE__",durable_name:"HDB_WORK_QUEUE",deliver_group:Ol,deliver_subject:"__HDB__.WORKQUEUE"},sG={stream_name:"__HARPERDB_SCHEMA_QUEUE__",durable_name:"HDB_SCHEMA_QUEUE",deliver_group:Ol,deliver_subject:"HDB.SCHEMAQUEUE"},nG={stream_name:"__HARPERDB_USER_QUEUE__",durable_name:"HDB_USER_QUEUE",deliver_group:Ol,deliver_subject:"HDB.USERQUEUE"},iG={SUCCESS:"success",ERROR:"error"},aG={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},oG={TXN:"txn",MSGID:"msgid"};yR.exports={NATS_SERVER_ZIP:Jq,NATS_SERVER_NAME:Al,NATS_BINARY_NAME:Xq,PID_FILES:eG,NATS_CONFIG_FILES:jq,SERVER_SUFFIX:tG,WORK_QUEUE_CONSUMER_NAMES:rG,SCHEMA_QUEUE_CONSUMER_NAMES:sG,USER_QUEUE_CONSUMER_NAMES:nG,NATS_TERM_CONSTRAINTS_RX:Zq,REQUEST_SUFFIX:UR,UPDATE_REMOTE_RESPONSE_STATUSES:iG,CLUSTER_STATUS_STATUSES:aG,REQUEST_SUBJECT:zq,SUBJECT_PREFIXES:oG}});var MR=S((xX,DR)=>{"use strict";var $r=T(),Ti=class{constructor(t=0,r=$r.STORAGE_TYPES_ENUM.LMDB,s=$r.LICENSE_VALUES.API_CALL_DEFAULT,n=$r.RAM_ALLOCATION_ENUM.DEFAULT,i=$r.LICENSE_VALUES.VERSION_DEFAULT,o){this.exp_date=t,this.storage_type=r,this.api_call=s,this.ram_allocation=n,this.version=i,this.fingerprint=o}};a(Ti,"BaseLicense");var ko=class extends Ti{constructor(t=0,r=$r.STORAGE_TYPES_ENUM.LMDB,s=$r.LICENSE_VALUES.API_CALL_DEFAULT,n=$r.RAM_ALLOCATION_ENUM.DEFAULT,i=$r.LICENSE_VALUES.VERSION_DEFAULT,o,c=!1){super(t,r,s,n,i,o),this.enterprise=c}};a(ko,"ExtendedLicense");DR.exports={BaseLicense:Ti,ExtendedLicense:ko}});var mi=S((YX,GR)=>{"use strict";var En=require("fs-extra"),PR=Vo(),BR=require("crypto"),cG=require("moment"),_G=require("uuid").v4,Xe=I(),Nl=require("path"),uG=b(),mt=T(),lG=MR().ExtendedLicense,ln="invalid license key format",EG="061183",dG="mofi25",hG="aes-256-cbc",SG=16,fG=32,vR=Y();vR.initSync();var pl;GR.exports={validateLicense:HR,generateFingerPrint:mG,licenseSearch:qR,getLicense:OG};function gl(){return Nl.join(vR.getHdbBasePath(),mt.LICENSE_KEY_DIR_NAME,mt.LICENSE_FILE_NAME)}a(gl,"getLicenseDirPath");function TG(){let e=gl();return Nl.join(e,mt.LICENSE_FILE_NAME)}a(TG,"getLicenseFilePath");function Il(){let e=gl();return Nl.join(e,mt.REG_KEY_FILE_NAME)}a(Il,"getFingerPrintFilePath");async function mG(){let e=Il();try{return await En.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await RG();throw Xe.error(`Error writing fingerprint file to ${e}`),Xe.error(t),new Error("There was an error generating the fingerprint")}}a(mG,"generateFingerPrint");async function RG(){let e=_G(),t=PR.hash(e),r=Il();try{await En.mkdirp(gl()),await En.writeFile(r,t)}catch(s){if(s.code==="EEXIST")return t;throw Xe.error(`Error writing fingerprint file to ${r}`),Xe.error(s),new Error("There was an error generating the fingerprint")}return t}a(RG,"writeFingerprint");function HR(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,storage_type:mt.STORAGE_TYPES_ENUM.LMDB,api_call:mt.LICENSE_VALUES.API_CALL_DEFAULT,ram_allocation:mt.RAM_ALLOCATION_ENUM.DEFAULT,version:mt.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return Xe.error("empty license key passed to validate."),r;let s=Il(),n=!1;try{n=En.statSync(s)}catch(i){Xe.error(i)}if(n){let i;try{i=En.readFileSync(s,"utf8")}catch{Xe.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(dG),c=o[1];c=Buffer.concat([Buffer.from(c)],SG);let _=Buffer.concat([Buffer.from(i)],fG),u=BR.createDecipheriv(hG,_,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let l=null;try{l=u.update(o[0],"hex","utf8"),l.trim(),l+=u.final("utf8")}catch{let h=AG(o[0],i);if(h)l=h;else throw r.valid_license=!1,r.valid_machine=!1,console.error(ln),Xe.error(ln),new Error(ln)}let E;if(isNaN(l))try{E=JSON.parse(l),r.api_call=E.api_call,r.version=E.version,r.storage_type=E.storage_type,r.exp_date=E.exp_date,isNaN(r.exp_date)&&(r.exp_date=new Date(r.exp_date).getTime()),E.ram_allocation&&(r.ram_allocation=E.ram_allocation)}catch{throw console.error(ln),Xe.error(ln),new Error(ln)}else r.exp_date=l;r.exp_date<cG().valueOf()&&(r.valid_date=!1),PR.validate(o[1],`${EG}${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||Xe.error("Invalid licence"),r}a(HR,"validateLicense");function AG(e,t){try{let r=BR.createDecipher("aes192",t),s=r.update(e,"hex","utf8");return s.trim(),s+=r.final("utf8"),s}catch{Xe.warn("Check old license failed")}}a(AG,"checkOldLicense");function qR(){let e=new lG;e.api_call=0;let t=[];try{t=En.readFileSync(TG(),"utf-8").split(mt.NEW_LINE)}catch(r){r.code==="ENOENT"?Xe.info("no license file found"):Xe.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let s=t[r];try{if(uG.isEmptyOrZeroLength(s))continue;let n=JSON.parse(s),i=HR(n.license_key,n.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.api_call+=i.api_call,e.ram_allocation=i.ram_allocation,e.storage_type=i.storage_type,e.enterprise=!0)}catch(n){Xe.error("There was an error parsing the license string."),Xe.error(n),e.api_call=mt.LICENSE_VALUES.API_CALL_DEFAULT,e.ram_allocation=mt.RAM_ALLOCATION_ENUM.DEFAULT,e.storage_type=mt.STORAGE_TYPES_ENUM.LMDB,e.enterprise=!1}}return e.api_call===0&&(e.api_call=mt.LICENSE_VALUES.API_CALL_DEFAULT),pl=e,e}a(qR,"licenseSearch");async function OG(){return pl||await qR(),pl}a(OG,"getLicense")});var xr=S((KX,jR)=>{"use strict";var $R="username is required",xR="nothing to update, must supply active, role or password to update",YR="password cannot be an empty string",KR="If role is specified, it cannot be empty.",WR="active must be true or false";jR.exports={addUser:LG,alterUser:UG,dropUser:DG,userInfo:MG,listUsers:xo,listUsersExternal:PG,setUsersToGlobal:Ri,findAndValidateUser:HG,getClusterUser:qG,USERNAME_REQUIRED:$R,ALTERUSER_NOTHING_TO_UPDATE:xR,EMPTY_PASSWORD:YR,EMPTY_ROLE:KR,ACTIVE_BOOLEAN:WR};var QR=Lt(),pG=fs(),wl=Vo(),JR=LR(),XR=Tt(),Cl=Xs(),be=b(),ZR=require("validate.js"),H=I(),{promisify:Ll}=require("util"),Ul=Hr(),Ts=T(),FR=_e(),NG=ur(),yl=Y(),gG=mi(),IG=ts(),{handleHDBError:er,hdb_errors:bG}=D(),{HTTP_STATUS_CODES:tr,AUTHENTICATION_ERROR_MSGS:bl,HDB_ERROR_MSGS:dn}=bG,{UserEventMsg:Dl}=Pr(),VR=require("lodash"),zR={username:!0,active:!0,role:!0,password:!0},kR=new Map,$o=Ll(XR.searchByValue),wG=Ll(XR.searchByHash),CG=Ll(pG.delete);async function LG(e){let t=ZR.cleanAttributes(e,zR),r=JR.addUserValidation(t);if(r)throw er(new Error,r.message,tr.BAD_REQUEST,void 0,void 0,!0);let s={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["id","permission","role"]},n;try{n=await $o(s)}catch(u){throw H.error("There was an error searching for a role in add user"),H.error(u),u}if(!n||n.length<1)throw er(new Error,dn.ROLE_NAME_NOT_FOUND(t.role),tr.NOT_FOUND,void 0,void 0,!0);if(n.length>1)throw er(new Error,dn.DUP_ROLES_FOUND(t.role),tr.CONFLICT,void 0,void 0,!0);n[0].permission.cluster_user===!0&&(t.hash=Ul.encrypt(t.password)),t.password=wl.hash(t.password),t.role=n[0].id;let i={operation:"insert",schema:"system",table:"hdb_user",records:[t]},o;try{o=await QR.insert(i)}catch(u){throw H.error("There was an error searching for a user."),H.error(u),u}H.debug(o);try{await Ri()}catch(u){throw H.error("Got an error setting users to global"),H.error(u),u}if(o.skipped_hashes.length===1)throw er(new Error,dn.USER_ALREADY_EXISTS(t.username),tr.CONFLICT,void 0,void 0,!0);let c=Object.assign({},t);c.role=n[0];let _={user:null};return _.user=c,be.sendTransactionToSocketCluster(Ts.INTERNAL_SC_CHANNELS.ADD_USER,_,yl.get(Ts.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY)),Cl.signalUserChange(new Dl(process.pid)),`${c.username} successfully added`}a(LG,"addUser");async function UG(e){let t=ZR.cleanAttributes(e,zR);if(be.isEmptyOrZeroLength(t.username))throw new Error($R);if(be.isEmptyOrZeroLength(t.password)&&be.isEmptyOrZeroLength(t.role)&&be.isEmptyOrZeroLength(t.active))throw new Error(xR);if(!be.isEmpty(t.password)&&be.isEmptyOrZeroLength(t.password.trim()))throw new Error(YR);if(!be.isEmpty(t.active)&&!be.isBoolean(t.active))throw new Error(WR);let r=yG(t.username);if(!be.isEmpty(t.password)&&!be.isEmptyOrZeroLength(t.password.trim())&&(r&&(t.hash=Ul.encrypt(t.password)),t.password=wl.hash(t.password)),t.role==="")throw new Error(KR);if(t.role){let o={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]},c;try{c=await $o(o)}catch(_){throw H.error("Got an error searching for a role."),H.error(_),_}if(!c||c.length===0){let _=dn.ALTER_USER_ROLE_NOT_FOUND(t.role);throw H.error(_),er(new Error,_,tr.NOT_FOUND,void 0,void 0,!0)}if(c.length>1){let _=dn.ALTER_USER_DUP_ROLES(t.role);throw H.error(_),er(new Error,_,tr.CONFLICT,void 0,void 0,!0)}t.role=c[0].id}let s={operation:"update",schema:"system",table:"hdb_user",records:[t]},n;try{n=await QR.update(s)}catch(o){throw H.error("Error during update."),H.error(o),o}try{await Ri()}catch(o){throw H.error("Got an error setting users to global"),H.error(o),o}let i={user:null};return i.user=t,be.sendTransactionToSocketCluster(Ts.INTERNAL_SC_CHANNELS.ALTER_USER,i,yl.get(Ts.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY)),Cl.signalUserChange(new Dl(process.pid)),n}a(UG,"alterUser");function yG(e){let t=!1,r=global.hdb_users.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(yG,"isClusterUser");async function DG(e){try{let t=JR.dropUserValidation(e);if(t)throw new Error(t);let r={table:"hdb_user",schema:"system",hash_values:[e.username]};if(be.isEmpty(global.hdb_users.get(e.username)))throw er(new Error,dn.USER_NOT_EXIST(e.username),tr.NOT_FOUND,void 0,void 0,!0);let s;try{s=await CG(r)}catch(i){throw H.error("Got an error deleting a user."),H.error(i),i}H.debug(s);try{await Ri()}catch(i){throw H.error("Got an error setting users to global."),H.error(i),i}let n={user:null};return n.user=e,be.sendTransactionToSocketCluster(Ts.INTERNAL_SC_CHANNELS.DROP_USER,n,yl.get(Ts.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY)),Cl.signalUserChange(new Dl(process.pid)),`${e.username} successfully deleted`}catch(t){throw t}}a(DG,"dropUser");async function MG(e){let t={};try{if(!e||!e.hdb_user)return"There was no user info in the body";t=e.hdb_user;let r={schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]},s;try{s=await wG(r)}catch(n){throw H.error("Got an error searching for a role."),H.error(n),n}t.role=s[0],delete t.password,delete t.refresh_token,delete t.hash}catch(r){throw H.error(r),r}return t}a(MG,"userInfo");async function PG(){let e;try{e=await xo()}catch(t){throw H.error("Got an error listing users."),H.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(PG,"listUsersExternal");async function xo(){try{let e={schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]},t;try{t=VR.cloneDeep(await $o(e))}catch(r){throw H.error("Got an error searching for roles."),H.error(r),r}if(!be.isEmptyOrZeroLength(t)){let r={};for(let o in t)r[t[o].id]=t[o];let s={schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]},n;try{n=VR.cloneDeep(await $o(s))}catch(o){throw H.error("Got an error searching for users."),H.error(o),o}let i=new Map;for(let o in n){let c=n[o];c.role=r[n[o].role],BG(c.role),i.set(c.username,c)}return(await gG.getLicense()).enterprise?i:vG(i)}}catch(e){throw H.error("got an error listing users"),H.error(e),be.errorizeMessage(e)}return null}a(xo,"listUsers");function BG(e){try{if(!e){H.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(IG)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}catch(t){H.error("Got an error trying to set system permissions."),H.error(t)}}a(BG,"appendSystemTablesToRole");function vG(e){try{if(H.info("No enterprise license found. System is limited to 1 clustering role and 1 user role"),!e)return new Map;let t=Object.create(null),r=new Map;e.forEach((n,i)=>{n.role.permission.cluster_user===void 0||n.role.permission.cluster_user===!1?n.role.permission.super_user===!0&&(t[n.role.id]||(t[n.role.id]=new Map),t[n.role.id].set(i,n)):r.set(i,n)});let s={role:void 0,count:0};return Object.keys(t).forEach(n=>{let i=t[n];i.size>=s.count&&(s.role=n,s.count=i.size)}),s.role===void 0?(H.error("No roles found with active users. This is bad."),new Map):(r=new Map([...r,...t[s.role]]),r)}catch(t){return H.error("error filtering users."),H.error(t),new Map}}a(vG,"nonEnterpriseFilter");async function Ri(){try{let e=await xo();global.hdb_users=e}catch(e){throw H.error(e),e}}a(Ri,"setUsersToGlobal");async function HG(e,t,r=!0){global.hdb_users||await Ri();let s=global.hdb_users.get(e);if(!s)throw er(new Error,bl.GENERIC_AUTH_FAIL,tr.UNAUTHORIZED,void 0,void 0,!0);if(s&&!s.active)throw er(new Error,bl.USER_INACTIVE,tr.UNAUTHORIZED,void 0,void 0,!0);let n={active:s.active,username:s.username};if(s.refresh_token&&(n.refresh_token=s.refresh_token),s.role&&(n.role=s.role),r===!0){if(kR.get(t)===s.password)return n;if(wl.validate(s.password,t))kR.set(t,s.password);else throw er(new Error,bl.GENERIC_AUTH_FAIL,tr.UNAUTHORIZED,void 0,void 0,!0)}return n}a(HG,"findAndValidateUser");async function qG(){let e=await xo(),t=NG.getConfigFromFile(Ts.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!be.isEmpty(r))return r.decrypt_hash=Ul.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+FR.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+FR.SERVER_SUFFIX.ADMIN,r}a(qG,"getClusterUser")});var nA=S((WX,sA)=>{"use strict";var ms=I(),Yo=T(),GG=oR(),eA=Gr(),FG=ds(),VG=xr(),{validateEvent:rA}=Pr(),kG={[Yo.IPC_EVENT_TYPES.SCHEMA]:$G,[Yo.IPC_EVENT_TYPES.USER]:YG};async function $G(e){let t=rA(e);if(t){ms.error(t);return}ms.trace(`IPC schemaHandler ${Yo.HDB_IPC_CLIENT_PREFIX}${process.pid} received schema event:`,e),await GG(e.message),await xG(e.message)}a($G,"schemaHandler");async function xG(e){try{if(global.hdb_schema!==void 0&&typeof global.hdb_schema=="object"&&e.operation!==void 0)switch(e.operation){case"drop_schema":delete global.hdb_schema[e.schema];break;case"drop_table":global.hdb_schema[e.schema]!==void 0&&delete global.hdb_schema[e.schema][e.table];break;case"create_schema":global.hdb_schema[e.schema]===void 0&&(global.hdb_schema[e.schema]={});break;case"create_table":case"create_attribute":global.hdb_schema[e.schema]===void 0&&(global.hdb_schema[e.schema]={}),global.hdb_schema[e.schema][e.table]=await FG.describeTable({schema:e.schema,table:e.table});break;default:eA.setSchemaDataToGlobal(tA);break}else eA.setSchemaDataToGlobal(tA)}catch(t){ms.error(t)}}a(xG,"syncSchemaMetadata");function tA(e){e&&ms.error(e)}a(tA,"handleErrorCallback");async function YG(e){try{let t=rA(e);if(t){ms.error(t);return}ms.trace(`IPC userHandler ${Yo.HDB_IPC_CLIENT_PREFIX}${process.pid} received user event:`,e),await VG.setUsersToGlobal()}catch(t){ms.error(t)}}a(YG,"userHandler");sA.exports=kG});var Ko=S((QX,iA)=>{"use strict";var KG=fr();iA.exports={writeTransaction:WG};function WG(e,t,r){return KG.writeTransaction(e,t,r)}a(WG,"writeTransaction")});var Ml=S((JX,QG)=>{QG.exports={name:"harperdb",version:"4.0.6",description:"HarperDB is a distributed SQL & NoSQL data platform focused on speed, flexibility, and ease of use.",keywords:["database","sql","nosql","api","distributed","cloud","enterprise","Fastify","NATS"],main:"harperdb.js",bin:{harperdb:"./bin/harperdb.js"},engines:{node:">=14.0.0","preferred-node":"18.13.0","go-lang":"1.19.3","nats-server":"2.9.8"},homepage:"https://www.harperdb.io/",bugs:"support@harperdb.io",author:{name:"HarperDB",email:"support@harperdb.io"},license:"See License in ./license/Community+Edition+and+Evaluation+End+User+License+Agreement.pdf",scripts:{submodules:"git submodule update --init --recursive",build:"eslint -c ./.eslintbuild bin/ data_layer/ security/ server/ sqlTranslator/ upgrade/ utility/ validation/",pretty:"eslint --fix bin/ data_layer/ security/ server/ sqlTranslator/ upgrade/ utility/ validation/",test:"rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license --storage_type=lmdb && npm run cover:upgrade && npm run cover:nats && npm run cover:cfserver && npm run cover:lmdbbridge && npm run cover:lmdbutility && npm run cover:hdbserver && npm run cover:main && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license --storage_type=lmdb","cover:main":"cd bin/ && nyc --no-clean --reporter=lcovonly ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --config '../unitTests/.mocharc-main.json'","cover:lmdbbridge":"cd bin/ && nyc --no-clean --reporter=lcovonly --retries 3 ../node_modules/mocha/bin/_mocha '../unitTests/data_layer/harperBridge/lmdbBridge/**/*.js' --parallel --config '../unitTests/.mocharc.json'","cover:lmdbutility":"cd bin/ && nyc --no-clean --reporter=lcovonly --retries 3 ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --parallel --config '../unitTests/.mocharc.json'","cover:hdbserver":"cd bin/ && nyc --no-clean --reporter=lcovonly ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --parallel --config '../unitTests/.mocharc.json'","cover:cfserver":"npm run submodules && cd bin/ && nyc --no-clean --reporter=lcovonly ../node_modules/mocha/bin/_mocha '../unitTests/server/customFunctions/customFunctionsServer-test.js' --config '../unitTests/.mocharc.json'","cover:nats":"cd bin/ && nyc --no-clean --reporter=lcovonly ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json'","cover:upgrade":"cd bin/ && nyc --no-clean --reporter=lcovonly ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.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/data_layer/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:{"@fastify/accepts-serializer":"5.1.0","@fastify/autoload":"5.4.0","@fastify/compress":"6.1.1","@fastify/cors":"8.1.0","@fastify/static":"6.5.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:"1.7.4",async:"3.2.3","aws-sdk":"2.1096.0",chalk:"4.1.2","cli-progress":"3.10.0",clone:"2.1.2",esbuild:"^0.14.49","fast-glob":"3.2.11",fastify:"4.8.1","fastify-plugin":"4.2.1","fill-range":"7.0.1","fs-extra":"10.0.1","human-readable-ids":"1.0.4",inquirer:"8.2.2","is-number":"7.0.0",joi:"17.6.0",json2csv:"5.0.7",jsonata:"1.8.6",jsonwebtoken:"8.5.1",lmdb:"2.7.6",lodash:"4.17.21",mathjs:"10.4.0",microtime:"3.1.1",minimist:"1.2.6",mkcert:"1.5.0",moment:"2.29.4",msgpackr:"1.8.5",nats:"2.9.2",needle:"3.1.0","node-ipc":"9.1.4","node-stream-zip":"1.15.0","normalize-path":"^3.0.0",ora:"5.4.1","ordered-binary":"1.3.0",papaparse:"5.3.2",passport:"0.6.0","passport-http":"0.3.0","passport-local":"1.0.0",pino:"8.3.1",pm2:"5.2.0",prompt:"1.2.2","properties-reader":"2.2.0","recursive-iterator":"3.3.0",semver:"7.3.5","stream-chain":"2.2.5","stream-json":"1.7.4",systeminformation:"5.12.4","tar-fs":"2.1.1","truncate-utf8-bytes":"1.0.2",ulidx:"0.3.0",uuid:"9.0.0","validate.js":"0.11.1",yaml:"1.10.2"},devDependencies:{axios:"0.27.2",chai:"4.3.4","chai-integer":"0.1.0",eslint:"8.22.0","eslint-config-prettier":"8.3.0","eslint-plugin-prettier":"3.4.1","eslint-plugin-radar":"0.2.1","hook-std":"2.0.0","intercept-stdout":"0.1.2",mocha:"8.3.2","mocha-teamcity-reporter":"3.0.0","mock-require":"3.0.3","mock-stdin":"1.0.0",newman:"5.2.3","newman-reporter-html":"1.0.5","newman-reporter-htmlextra":"1.21.0","newman-reporter-teamcity":"0.1.11","node-fetch":"2.6.7",nyc:"15.1.0",prettier:"2.3.2",rewire:"5.0.0",rimraf:"3.0.2",sinon:"10.0.0","sinon-chai":"3.7.0"},overrides:{"eslint-plugin-radar":{eslint:"8.22.0"},lmdb:{msgpackr:"1.8.5"},"newman-reporter-html":{newman:"5.2.3"}}}});var at=S((aZ,IA)=>{"use strict";var Tr=Y();Tr.initSync();var JG=require("fs-extra"),XG=require("semver"),gi=require("path"),{monotonicFactory:ZG}=require("ulidx"),zG=ZG(),oA=require("util"),cA=require("child_process"),jG=oA.promisify(cA.exec),eF=cA.spawn,ee=_e(),ie=T(),Gl=b(),mr=I(),Wo=Hr(),tF=Ko(),Ai=ur(),{encode:vl,decode:_A}=require("msgpackr"),{isEmpty:Rs}=Gl,uA=xr(),XX=us(),rF=Tt(),ZX=oA.promisify(rF.searchByHash),{connect:sF,StorageType:lA,RetentionPolicy:EA,AckPolicy:dA,DeliverPolicy:Hl,NatsConnection:zX,JetStreamManager:jX,JetStreamClient:eZ,StringCodec:tZ,JSONCodec:nF,createInbox:Fl,StreamSource:rZ,headers:iF,toJsMsg:aF,nuid:sZ,JetStreamOptions:nZ,ErrorCode:aA,nanos:iZ}=require("nats"),{PACKAGE_ROOT:oF}=T(),cF=Ml(),hA=nF(),_F="clustering",uF=cF.engines[ee.NATS_SERVER_NAME],lF=gi.join(oF,"dependencies"),ql=gi.join(lF,`${process.platform}-${process.arch}`,ee.NATS_BINARY_NAME),Pl,Bl,Oi,pi,Ni,Yt;IA.exports={runCommand:SA,checkNATSServerInstalled:EF,createConnection:Vl,getConnection:Qo,getJetStreamManager:hn,getJetStream:fA,getNATSReferences:Ut,getServerList:hF,createLocalStream:kl,listStreams:TA,deleteLocalStream:SF,getServerConfig:Ii,listRemoteStreams:fF,viewStream:TF,publishToStream:mF,createWorkQueueStream:RF,addSourceToWorkStream:mA,request:AF,removeSourceFromWorkStream:AA,reloadNATS:$l,reloadNATSHub:OF,reloadNATSLeaf:pF,extractServerName:RA,requestErrorHandler:NF,updateWorkStream:gF,createLocalTableStream:pA,createTableStreams:IF,purgeTableStream:NA,purgeSchemaTableStreams:bF,getStreamInfo:wF,updateNodeNameLocalStreams:CF,closeConnection:dF};async function SA(e,t=void 0){let{stdout:r,stderr:s}=await jG(e,{cwd:t});if(s)throw new Error(s.replace(`
6
6
  `,""));return r.replace(`
7
7
  `,"")}a(SA,"runCommand");async function EF(){try{await JG.access(ql)}catch{return!1}let e=await SA(`${ql} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return XG.eq(t,uF)}a(EF,"checkNATSServerInstalled");async function Vl(e,t,r,s=!0,n="127.0.0.1"){return sF({name:n,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:s,tls:{keyFile:Tr.get(ie.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:Tr.get(ie.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:Tr.get(ie.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}})}a(Vl,"createConnection");async function dF(){Yt&&(await Yt.close(),Yt=void 0)}a(dF,"closeConnection");async function Qo(){if(!Yt){let e=await uA.getClusterUser();if(Rs(e))throw new Error("Unable to get nats connection. Cluster user is undefined.");let t=Tr.get(ie.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT);Yt=await Vl(t,e.username,e.decrypt_hash)}return Yt}a(Qo,"getConnection");async function hn(){if(pi)return pi;Rs(Yt)&&await Qo();let{domain:e}=Ii(ie.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(Rs(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return pi=await Yt.jetstreamManager({domain:e}),pi}a(hn,"getJetStreamManager");async function fA(){if(Ni)return Ni;Rs(Yt)&&await Qo();let{domain:e}=Ii(ie.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(Rs(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return Ni=Yt.jetstream({domain:e}),Ni}a(fA,"getJetStream");async function Ut(){let e=Yt||await Qo(),t=pi||await hn(),r=Ni||await fA();return{connection:e,jsm:t,js:r}}a(Ut,"getNATSReferences");async function hF(){let e=Tr.get(ie.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),{sys_name:t,decrypt_hash:r}=await uA.getClusterUser(),s=await Vl(e,t,r),n=Fl(),i=s.subscribe(n),o=[],c=(async()=>{for await(let _ of i)o.push(hA.decode(_.data))})();return await s.publish("$SYS.REQ.SERVER.PING.VARZ",void 0,{reply:n}),await s.flush(),await Gl.async_set_timeout(50),await i.drain(),await s.close(),await c,o}a(hF,"getServerList");async function kl(e,t){let{jsm:r}=await Ut();await r.streams.add({name:e,storage:lA.File,retention:EA.Limits,subjects:t})}a(kl,"createLocalStream");async function TA(){let{jsm:e}=await Ut(),t=await e.streams.list().next(),r=[];return t.forEach(s=>{r.push(s)}),r}a(TA,"listStreams");async function SF(e){let{jsm:t}=await Ut();await t.streams.delete(e)}a(SF,"deleteLocalStream");async function fF(e){let{connection:t}=await Ut(),r=[],s=Fl(),n=t.subscribe(s),i=(async()=>{for await(let o of n)r.push(hA.decode(o.data))})();return await t.publish(`$JS.${e}.API.STREAM.LIST`,void 0,{reply:s}),await t.flush(),await n.drain(),await i,r}a(fF,"listRemoteStreams");async function TF(e,t=void 0,r=void 0){let{jsm:s,connection:n}=await Ut(),i=zG(),o=[],c={ack_policy:dA.None,durable_name:i,deliver_subject:i,deliver_policy:Hl.All};t&&(c.deliver_policy=Hl.StartTime,c.opt_start_time=new Date(t).toISOString());try{await s.consumers.add(e,c);let _={timeout:2e3};r&&(_.max=r);let u=await n.subscribe(i,_);for await(let l of u){let E=aF(l),d=_A(E.data),h={nats_timestamp:E.info.timestampNanos,nats_sequence:E.info.streamSequence,entry:d,originators:[]},m=[];if(E.headers){let R=E.headers.get("originators");R&&(m=R.split(","),h.originators=m)}o.push(h),u.getPending()===1&&E.info.pending===0&&u.stop()}return await s.consumers.delete(e,i),o}catch(_){if(await s.consumers.delete(e,i),_.code==="TIMEOUT")return o;throw _}}a(TF,"viewStream");async function mF(e,t,r=[],s=[]){mr.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,r,"originators:",s);let{connection:n,js:i}=await Ut(),o=await Jo(),c=`${e}.${o}`,_=iF();s.push(o),_.append("originators",s.join());for(let u=0,l=r.length;u<l;u++)try{mr.trace(`publishToStream publishing to subject: ${c}, data:`,r[u]),await i.publish(c,vl(r[u]),{headers:_})}catch(E){if(E.code&&E.code.toString()==="503")mr.trace(`publishToStream creating stream: ${t}`),await kl(t,[c]),await i.publish(c,vl(r[u]),{headers:_});else throw E}}a(mF,"publishToStream");function Ii(e){e=e.toLowerCase();let t=gi.join(Tr.get(ie.CONFIG_PARAMS.ROOTPATH),_F);if(e===ie.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return Rs(Bl)&&(Bl={port:Ai.getConfigFromFile(ie.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:Ai.getConfigFromFile(ie.CONFIG_PARAMS.CLUSTERING_NODENAME)+ee.SERVER_SUFFIX.HUB,config_file:ee.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:gi.join(t,ee.PID_FILES.HUB),hdb_nats_path:t}),Bl;if(e===ie.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return Rs(Pl)&&(Pl={port:Ai.getConfigFromFile(ie.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:Ai.getConfigFromFile(ie.CONFIG_PARAMS.CLUSTERING_NODENAME)+ee.SERVER_SUFFIX.LEAF,config_file:ee.NATS_CONFIG_FILES.LEAF_SERVER,domain:Ai.getConfigFromFile(ie.CONFIG_PARAMS.CLUSTERING_NODENAME)+ee.SERVER_SUFFIX.LEAF,pid_file_path:gi.join(t,ee.PID_FILES.LEAF),hdb_nats_path:t}),Pl;mr.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(Ii,"getServerConfig");async function RF(e){let{jsm:t}=await Ut(),r=await Jo();try{await t.streams.add({name:e.stream_name,storage:lA.File,retention:EA.Workqueue,subjects:[`${ee.SUBJECT_PREFIXES.MSGID}.${r}`,`${ee.SUBJECT_PREFIXES.TXN}.${e.stream_name}.${r}`]})}catch(s){if(s.code!=="400")throw s}try{await t.consumers.info(e.stream_name,e.durable_name)}catch(s){if(s.code.toString()==="404")await t.consumers.add(e.stream_name,{ack_policy:dA.Explicit,deliver_subject:`${e.deliver_subject}.${r}`,durable_name:e.durable_name,deliver_policy:Hl.All,max_ack_pending:1e4,deliver_group:e.deliver_group,filter_subject:`${ee.SUBJECT_PREFIXES.TXN}.>`});else throw s}}a(RF,"createWorkQueueStream");async function mA(e,t,r){let{jsm:s}=await Ut(),n=await s.streams.info(t),i=RA(s.prefix),o=r.start_time?r.start_time:new Date(Date.now()).toISOString(),{schema:c,table:_}=r,u=Wo.createNatsTableStreamName(c,_),l=i===e,E,d,h=!1;if(!Array.isArray(n.config.sources)||n.config.sources.length===0)n.config.sources=[];else for(let R=0,C=n.config.sources.length;R<C;R++)if(E=n.config.sources[R],d=R,l&&E.name===u||!l&&E.name===u&&E.external&&E.external.api===`$JS.${e}.API`){h=!0;break}if(h===!0){if(E.opt_start_time===o)return;await OA(c,_,E,t),n.config.sources.splice(d,1),await s.streams.update(t,n.config)}let m={name:u,opt_start_time:o,filter_subject:`${ee.SUBJECT_PREFIXES.TXN}.>`};l||(m.external={api:`$JS.${e}.API`,deliver:""}),n.config.sources.push(m),await s.streams.update(t,n.config)}a(mA,"addSourceToWorkStream");function RA(e){return e.split(".")[1]}a(RA,"extractServerName");async function AA(e,t,r){let{schema:s,table:n}=r,i=Wo.createNatsTableStreamName(s,n),{jsm:o}=await Ut(),c=await o.streams.info(t);if(!Array.isArray(c.config.sources)||c.config.sources.length===0)return;let _=c.config.sources.length,u;for(;_--;)if(u=c.config.sources[_],u.name===i&&u.external.api===`$JS.${e}.API`){c.config.sources.splice(_,1);break}await o.streams.update(t,c.config),await OA(s,n,u,t)}a(AA,"removeSourceFromWorkStream");async function OA(e,t,r,s){let n=await hn(),i;try{i=gA(e,t,r.external.api.split(".")[1]),await n.streams.purge(s,{filter:i})}catch{mr.error("Error purging source subject",i,"from work stream",s)}}a(OA,"purgeSourceFromWorkStream");async function AF(e,t,r=2e3,s=Fl()){if(!Gl.isObject(t))throw new Error("data param must be an object");let n=vl(t),{connection:i}=await Ut(),o={timeout:r};s&&(o.reply=s,o.noMux=!0);let c=await i.request(e,n,o);return _A(c.data)}a(AF,"request");function $l(e){return new Promise(async(t,r)=>{let s=eF(ql,["--signal",`reload=${e}`],{cwd:__dirname}),n,i;s.on("error",o=>{r(o)}),s.stdout.on("data",o=>{i+=o.toString()}),s.stderr.on("data",o=>{n+=o.toString()}),s.stderr.on("close",o=>{n&&r(n),t(i)})})}a($l,"reloadNATS");async function OF(){let{pid_file_path:e}=Ii(ie.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await $l(e)}a(OF,"reloadNATSHub");async function pF(){let{pid_file_path:e}=Ii(ie.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await $l(e)}a(pF,"reloadNATSLeaf");function NF(e,t,r){let s;switch(e.code){case aA.NoResponders:s=`Unable to ${t}, node '${r}' is not listening.`;break;case aA.Timeout:s=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:s=e.message;break}return s}a(NF,"requestErrorHandler");async function gF(e,t){let r=t+ee.SERVER_SUFFIX.LEAF;await tF.writeTransaction(ie.SYSTEM_SCHEMA_NAME,ie.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,async()=>{e.subscribe===!0?await mA(r,ee.WORK_QUEUE_CONSUMER_NAMES.stream_name,e):await AA(r,ee.WORK_QUEUE_CONSUMER_NAMES.stream_name,e)})}a(gF,"updateWorkStream");async function pA(e,t){let r=Wo.createNatsTableStreamName(e,t),s=await Jo(),n=gA(e,t,s);await kl(r,[n])}a(pA,"createLocalTableStream");async function IF(e){for(let t=0,r=e.length;t<r;t++){let s=e[t].schema,n=e[t].table;await pA(s,n)}}a(IF,"createTableStreams");async function NA(e,t){if(Tr.get(ie.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let r=Wo.createNatsTableStreamName(e,t),{jsm:s}=await Ut();await s.streams.purge(r)}catch(r){if(r.message==="stream not found")mr.warn(r);else throw r}}a(NA,"purgeTableStream");async function bF(e,t){if(Tr.get(ie.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,s=t.length;r<s;r++)await NA(e,t[r])}a(bF,"purgeSchemaTableStreams");async function wF(e){return(await hn()).streams.info(e)}a(wF,"getStreamInfo");function gA(e,t,r){return`${ee.SUBJECT_PREFIXES.TXN}.${e}.${t}.${r}`}a(gA,"createSubjectName");async function Jo(){if(Oi)return Oi;if(Oi=(await hn())?.nc?.info?.server_name,Oi===void 0)throw new Error("Unable to get jetstream manager server name");return Oi}a(Jo,"getJsmServerName");async function CF(){let e=await hn(),t=await Jo(),r=await TA();for(let s of r){let n=s.config,i=n.subjects[0];if(!i)continue;let o=i.split(".");if(o[o.length-1]!==t){if(n.name===ee.SCHEMA_QUEUE_CONSUMER_NAMES.stream_name){let _=`${ee.SCHEMA_QUEUE_CONSUMER_NAMES.deliver_subject}.${t}`;mr.trace(`Updating stream subject name from: ${i} to: ${_}`),n.subjects[0]=_}else if(n.name===ee.WORK_QUEUE_CONSUMER_NAMES.stream_name){let _=`${ee.WORK_QUEUE_CONSUMER_NAMES.stream_name}.${t}`;mr.trace(`Updating stream subject name from: ${i} to: ${_}`),n.subjects[0]=_,await e.consumers.update(ee.WORK_QUEUE_CONSUMER_NAMES.stream_name,ee.WORK_QUEUE_CONSUMER_NAMES.durable_name,{deliver_subject:`${ee.WORK_QUEUE_CONSUMER_NAMES.deliver_subject}.${t}`})}else{let _=i.split(".");_[_.length-1]=t;let u=_.join(".");mr.trace(`Updating stream subject name from: ${i} to: ${u}`),n.subjects[0]=u}await e.streams.update(n.name,n)}}}a(CF,"updateNodeNameLocalStreams")});var xl=S((oZ,bA)=>{"use strict";var Xo=class{constructor(t,r,s){this.timestamp=t,this.user=r,this.node_name=s}};a(Xo,"ClusteringOriginObject");bA.exports=Xo});var As=S((cZ,LA)=>{"use strict";var wA=b(),wi=Y(),ue=T(),Yl=_e(),Sn=at(),Se=I(),CA=xl(),LF=Hr();wi.initSync();var fn=Yl.SCHEMA_QUEUE_CONSUMER_NAMES.stream_name,bi=Yl.SCHEMA_QUEUE_CONSUMER_NAMES.deliver_subject;LA.exports={sendAttributeTransaction:zo,postOperationHandler:yF};async function zo(e,t,r=[]){if(!!wi.get(ue.CONFIG_PARAMS.CLUSTERING_ENABLED)&&!wA.isEmptyOrZeroLength(e.new_attributes)&&t.schema!==ue.SYSTEM_SCHEMA_NAME){let s=t.hdb_user?.username,n=wi.get(ue.CONFIG_PARAMS.CLUSTERING_NODENAME);for(let i of e.new_attributes){let o={operation:ue.OPERATIONS_ENUM.CREATE_ATTRIBUTE,schema:t.schema,table:t.table,attribute:i,__origin:new CA(e.txn_time,s,n)};Se.trace(`sendAttributeTransaction publishing ${fn}`,o),await Sn.publishToStream(bi,fn,[o],r)}}}a(zo,"sendAttributeTransaction");async function Zo(e,t,r,s=[]){if(e.schema===ue.SYSTEM_SCHEMA_NAME)return;let n=UF(e,t,r);n&&(Se.trace(`sendOperationTransaction publishing to schema ${e.schema} table ${e.table} following transaction:`,n),await Sn.publishToStream(`${Yl.SUBJECT_PREFIXES.TXN}.${e.schema}.${e.table}`,LF.createNatsTableStreamName(e.schema,e.table),[n],s))}a(Zo,"sendOperationTransaction");function UF(e,t,r){if(wA.isEmptyOrZeroLength(t))return null;let s={operation:e.operation,schema:e.schema,table:e.table,__origin:r};return e.operation===ue.OPERATIONS_ENUM.DELETE?s.hash_values=t:s.records=e.records,s}a(UF,"convertCRUDOperationToTransaction");async function yF(e,t,r=[]){if(!wi.get(ue.CONFIG_PARAMS.CLUSTERING_ENABLED))return;Se.trace(`postOperationHandler called for operation ${e.operation} on schema.table: ${e.schema}.${e.table}`);let s=e.hdb_user?.username,n=wi.get(ue.CONFIG_PARAMS.CLUSTERING_NODENAME),i=new CA(t.txn_time,s,n);switch(e.operation){case ue.OPERATIONS_ENUM.INSERT:try{await Zo(e,t.inserted_hashes,i,r),await zo(t,e,r)}catch(o){Se.error("There was an error calling clustering postOperationHandler for insert."),Se.error(o)}break;case ue.OPERATIONS_ENUM.DELETE:try{await Zo(e,t.deleted_hashes,i,r)}catch(o){Se.error("There was an error calling clustering postOperationHandler for delete."),Se.error(o)}break;case ue.OPERATIONS_ENUM.UPDATE:try{await Zo(e,t.update_hashes,i,r),await zo(t,e,r)}catch(o){Se.error("There was an error calling clustering postOperationHandler for update."),Se.error(o)}break;case ue.OPERATIONS_ENUM.UPSERT:try{await Zo(e,t.upserted_hashes,i,r),await zo(t,e,r)}catch(o){Se.error("There was an error calling clustering postOperationHandler for upsert."),Se.error(o)}break;case ue.OPERATIONS_ENUM.CREATE_SCHEMA:try{let o={operation:ue.OPERATIONS_ENUM.CREATE_SCHEMA,schema:e.schema,__origin:i};await Sn.publishToStream(bi,fn,[o],r)}catch(o){Se.error("There was an error calling clustering postOperationHandler for create_schema."),Se.error(o)}break;case ue.OPERATIONS_ENUM.CREATE_TABLE:try{let o={operation:ue.OPERATIONS_ENUM.CREATE_TABLE,schema:e.schema,table:e.table,hash_attribute:e.hash_attribute,__origin:i};await Sn.publishToStream(bi,fn,[o],r)}catch(o){Se.error("There was an error calling clustering postOperationHandler for create_table."),Se.error(o)}break;case ue.OPERATIONS_ENUM.CREATE_ATTRIBUTE:try{let o={operation:ue.OPERATIONS_ENUM.CREATE_ATTRIBUTE,schema:e.schema,table:e.table,attribute:e.attribute,__origin:i};await Sn.publishToStream(bi,fn,[o],r)}catch(o){Se.error("There was an error calling clustering postOperationHandler for create_attribute."),Se.error(o)}break;case ue.OPERATIONS_ENUM.CSV_DATA_LOAD:try{let o={operation:ue.OPERATIONS_ENUM.CSV_DATA_LOAD,schema:e.schema,table:e.table,attribute:e.attribute};await Sn.publishToStream(bi,fn,[o],r)}catch(o){Se.error("There was an error calling clustering postOperationHandler for csv_data_load."),Se.error(o)}break;default:break}return t}a(yF,"postOperationHandler")});var PA=S((_Z,MA)=>{"use strict";var DF=Tt(),MF=Gr(),UA=I(),yA=Lt(),PF=Ko(),BF=require("clone"),Wl=require("alasql"),vF=wo(),DA=require("util"),HF=DA.promisify(MF.getTableSchema),qF=DA.promisify(DF.search),GF=T(),Kl=b(),FF=As();vF(Wl);MA.exports={update:kF};var VF="There was a problem performing this update. Please check the logs and try again.";async function kF({statement:e,hdb_user:t}){let r=await HF(e.table.databaseid,e.table.tableid),s=$F(e.columns);Kl.backtickASTSchemaItems(e);let{table:n,where:i}=e,o=BF(n),c=Kl.isEmpty(i)?"":` WHERE ${i.toString()}`,_=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${c}`,u=Wl.parse(_).statements[0],l=await PF.writeTransaction(r.schema,r.name,async()=>{let E=await qF(u),d=xF(s,E);return YF(o,d,t)});return await yA.flush({schema:r.schema,table:r.name}),l}a(kF,"update");function $F(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value:t[r.column.columnid]=Wl.compile(`SELECT ${r.expression.toString()} AS [${GF.FUNC_VAL}] FROM ?`)}),t}catch(t){throw UA.error(t),new Error(VF)}}a($F,"createUpdateRecord");function xF(e,t){return Kl.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(xF,"buildUpdateRecords");async function YF(e,t,r){let s={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r};try{let n=await yA.update(s);await FF.postOperationHandler(s,n);try{delete n.new_attributes,delete n.txn_time}catch(i){UA.error(`Error delete new_attributes from update response: ${i}`)}return n}catch(n){throw n}}a(YF,"updateRecords")});var vA=S((uZ,BA)=>{var KF=require("alasql"),WF=Tt(),QF=I(),JF=fr(),Jl=require("util"),Ql=b(),XF=T(),ZF=Gr(),zF=Ko(),jF=As(),e0=Lt(),t0="record",r0="successfully deleted",s0=Jl.callbackify(o0),n0=Jl.promisify(WF.search),i0=Jl.promisify(ZF.getTableSchema);BA.exports={convertDelete:s0};function a0(e){return`${e.deleted_hashes.length} ${t0}${e.deleted_hashes.length===1?"":"s"} ${r0}`}a(a0,"generateReturnMessage");async function o0({statement:e,hdb_user:t}){let r=await i0(e.table.databaseid,e.table.tableid);Ql.backtickASTSchemaItems(e);let{table:s,where:n}=e,i=Ql.isEmpty(n)?"":` WHERE ${n.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${i}`,c=KF.parse(o).statements[0],_={operation:XF.OPERATIONS_ENUM.DELETE,schema:s.databaseid_orig,table:s.tableid_orig,hdb_user:t};try{let u=await zF.writeTransaction(r.schema,r.name,async()=>(_.records=await n0(c),JF.deleteRecords(_)));return await e0.flush({schema:r.schema,table:r.name}),u.deleted_hashes.length>0&&await jF.postOperationHandler(_,u),Ql.isEmptyOrZeroLength(u.message)&&(u.message=a0(u)),delete u.txn_time,u}catch(u){throw QF.error(u),u.hdb_code?u.message:u}}a(o0,"convertDelete")});var GA=S((lZ,qA)=>{"use strict";var Zl=ds(),{hdb_errors:Xl}=D();qA.exports={checkSchemaExists:HA,checkSchemaTableExists:c0,schema_describe:Zl};async function HA(e){if(!global.hdb_schema[e])try{let t=await Zl.describeSchema({schema:e});global.hdb_schema[e]=t}catch{return Xl.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}}a(HA,"checkSchemaExists");async function c0(e,t){let r=await HA(e);if(r)return r;if(!global.hdb_schema[e][t])try{let s=await Zl.describeTable({schema:e,table:t});if(!s||Object.keys(s).length===0)return Xl.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t);global.hdb_schema[e][t]=s}catch{return Xl.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}}a(c0,"checkSchemaTableExists")});var jo=S((dZ,xA)=>{"use strict";var Tn=xa(),Os=GA(),FA=I(),_0=require("uuid").v4,EZ=require("clone"),Rn=Xs(),ps=T(),u0=require("util"),Ns=fr(),{handleHDBError:Pe,hdb_errors:l0}=D(),{HDB_ERROR_MSGS:mn,HTTP_STATUS_CODES:Be}=l0,{SchemaEventMsg:An}=Pr(),VA=at();xA.exports={createSchema:E0,createSchemaStructure:kA,createTable:d0,createTableStructure:$A,createAttribute:m0,dropSchema:h0,dropTable:S0,dropAttribute:f0};async function E0(e){try{let t=await kA(e);return Rn.signalSchemaChange(new An(process.pid,e.operation,e.schema)),t}catch(t){throw t}}a(E0,"createSchema");async function kA(e){let t=Tn.schema_object(e);if(t)throw Pe(t,t.message,Be.BAD_REQUEST,void 0,void 0,!0);if(!await Os.checkSchemaExists(e.schema))throw Pe(new Error,mn.SCHEMA_EXISTS_ERR(e.schema),Be.BAD_REQUEST,ps.LOG_LEVELS.ERROR,mn.SCHEMA_EXISTS_ERR(e.schema),!0);try{return await Ns.createSchema(e),`schema '${e.schema}' successfully created`}catch(r){throw r}}a(kA,"createSchemaStructure");async function d0(e){try{let t=await $A(e);return Rn.signalSchemaChange(new An(process.pid,e.operation,e.schema,e.table)),t}catch(t){throw t}}a(d0,"createTable");async function $A(e){let t=Tn.create_table_object(e);if(t)throw Pe(t,t.message,Be.BAD_REQUEST,void 0,void 0,!0);Tn.validateTableResidence(e.residence);let r=await Os.checkSchemaExists(e.schema);if(r)throw Pe(new Error,r,Be.NOT_FOUND,ps.LOG_LEVELS.ERROR,r,!0);if(!await Os.checkSchemaTableExists(e.schema,e.table))throw Pe(new Error,mn.TABLE_EXISTS_ERR(e.schema,e.table),Be.BAD_REQUEST,ps.LOG_LEVELS.ERROR,mn.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:_0(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await Ns.createTable(n,e);else throw Pe(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",Be.BAD_REQUEST);else await Ns.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(i){throw i}}a($A,"createTableStructure");async function h0(e){let t=Tn.schema_object(e);if(t)throw Pe(t,t.message,Be.BAD_REQUEST,void 0,void 0,!0);let r=await Os.checkSchemaExists(e.schema);if(r)throw Pe(new Error,r,Be.NOT_FOUND,ps.LOG_LEVELS.ERROR,r,!0);let s=await Os.schema_describe.describeSchema({schema:e.schema});global.hdb_schema[e.schema]=s;let n=Object.keys(global.hdb_schema[e.schema]);return await Ns.dropSchema(e),Rn.signalSchemaChange(new An(process.pid,e.operation,e.schema)),delete global.hdb_schema[e.schema],await VA.purgeSchemaTableStreams(e.schema,n),`successfully deleted schema '${e.schema}'`}a(h0,"dropSchema");async function S0(e){let t=Tn.table_object(e);if(t)throw Pe(t,t.message,Be.BAD_REQUEST,void 0,void 0,!0);let r=await Os.checkSchemaTableExists(e.schema,e.table);if(r)throw Pe(new Error,r,Be.NOT_FOUND,ps.LOG_LEVELS.ERROR,r,!0);return await Ns.dropTable(e),Rn.signalSchemaChange(new An(process.pid,e.operation,e.schema,e.table)),await VA.purgeTableStream(e.schema,e.table),`successfully deleted table '${e.schema}.${e.table}'`}a(S0,"dropTable");async function f0(e){let t=Tn.attribute_object(e);if(t)throw Pe(t,t.message,Be.BAD_REQUEST,void 0,void 0,!0);let r=await Os.checkSchemaTableExists(e.schema,e.table);if(r)throw Pe(new Error,r,Be.NOT_FOUND,ps.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw Pe(new Error,"You cannot drop a hash attribute",Be.BAD_REQUEST,void 0,void 0,!0);if(ps.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw Pe(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,Be.BAD_REQUEST,void 0,void 0,!0);try{return await Ns.dropAttribute(e),T0(e),Rn.signalSchemaChange(new An(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(s){throw FA.error(`Got an error deleting attribute ${u0.inspect(e)}.`),s}}a(f0,"dropAttribute");function T0(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(T0,"dropAttributeFromGlobal");async function m0(e){if(!global.hdb_schema[e.schema])throw Pe(new Error,mn.SCHEMA_NOT_FOUND(e.schema),Be.NOT_FOUND,void 0,void 0,!0);if(!global.hdb_schema[e.schema][e.table])throw Pe(new Error,mn.TABLE_NOT_FOUND(e.schema,e.table),Be.NOT_FOUND,void 0,void 0,!0);try{return await Ns.createAttribute(e),Rn.signalSchemaChange(new An(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}catch(t){throw FA.error(t),t}}a(m0,"createAttribute")});var KA=S((hZ,YA)=>{"use strict";var{OPERATIONS_ENUM:R0}=T(),ec=class{constructor(t,r,s=void 0,n=void 0){this.operation=R0.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=s,this.search_values=n}};a(ec,"ReadAuditLogObject");YA.exports=ec});var zl=S((fZ,ZA)=>{"use strict";var A0=fr(),SZ=KA(),tc=b(),rc=T(),O0=Y(),{handleHDBError:WA,hdb_errors:p0}=D(),{HDB_ERROR_MSGS:QA,HTTP_STATUS_CODES:JA}=p0,N0=Object.values(rc.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),XA="To use this operation audit log must be enabled in harperdb-config.yaml";ZA.exports=g0;async function g0(e){if(tc.isEmpty(e.schema))throw new Error(QA.SCHEMA_REQUIRED_ERR);if(tc.isEmpty(e.table))throw new Error(QA.TABLE_REQUIRED_ERR);if(!O0.get(rc.CONFIG_PARAMS.LOGGING_AUDITLOG))throw WA(new Error,XA,JA.BAD_REQUEST,rc.LOG_LEVELS.ERROR,XA,!0);let t=tc.checkSchemaTableExist(e.schema,e.table);if(t)throw WA(new Error,t,JA.NOT_FOUND,rc.LOG_LEVELS.ERROR,t,!0);if(!tc.isEmpty(e.search_type)&&N0.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await A0.readAuditLog(e)}a(g0,"readAuditLog")});var sO=S((TZ,rO)=>{var Yr=require("validate.js"),jA=de(),On=T(),{handleHDBError:I0,hdb_errors:b0}=D(),{HDB_ERROR_MSGS:le,HTTP_STATUS_CODES:w0}=b0,jl=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),C0={STRUCTURE_USER:"structure_user"},zA=Object.values(On.ROLE_TYPES_ENUM),L0="attribute_permissions",U0="attribute_name",{PERMS_CRUD_ENUM:pn}=On,y0=[L0,...Object.values(pn)],eO=[pn.READ,pn.INSERT,pn.UPDATE],D0=[U0,...eO];function M0(e){let t=jl();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,tO(e,t)}a(M0,"addRoleValidation");function P0(e){let t=jl();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,tO(e,t)}a(P0,"alterRoleValidation");function B0(e){let t=jl();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,jA.validateObject(e,t)}a(B0,"dropRoleValidation");var v0=["operation","role","id","permission","hdb_user","hdb_auth_header"];function tO(e,t){let r={main_permissions:[],schema_permissions:{}},s=Object.keys(e),n=[];for(let o=0,c=s.length;o<c;o++)v0.includes(s[o])||n.push(s[o]);n.length>0&&fe(le.INVALID_ROLE_JSON_KEYS(n),r);let i=jA.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{fe(o,r)}),e.permission){let o=H0(e);o&&fe(o,r),zA.forEach(c=>{e.permission[c]&&!Yr.isBoolean(e.permission[c])&&fe(le.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(zA.indexOf(o)<0){if(o===C0.STRUCTURE_USER){let _=e.permission[o];if(typeof _=="boolean")continue;if(Array.isArray(_)){for(let u=0,l=_.length;u<l;u++){let E=_[u];global.hdb_schema[E]||fe(le.SCHEMA_NOT_FOUND(E),r)}continue}fe(le.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){fe(le.SCHEMA_NOT_FOUND(o),r);continue}if(c.tables)for(let _ in c.tables){let u=c.tables[_];if(!_||!global.hdb_schema[o][_]){fe(le.TABLE_NOT_FOUND(o,_),r);continue}if(Object.keys(u).forEach(l=>{y0.includes(l)||fe(le.INVALID_PERM_KEY(l),r,o,_)}),Object.values(pn).forEach(l=>{Yr.isDefined(u[l])?Yr.isBoolean(u[l])||fe(le.TABLE_PERM_NOT_BOOLEAN(l),r,o,_):fe(le.TABLE_PERM_MISSING(l),r,o,_)}),Yr.isDefined(u.attribute_permissions)){if(!Yr.isArray(u.attribute_permissions)){fe(le.ATTR_PERMS_NOT_ARRAY,r,o,_);continue}}else{fe(le.ATTR_PERMS_ARRAY_MISSING,r,o,_);continue}if(u.attribute_permissions){let l=global.hdb_schema[o][_].attributes.map(({attribute:d})=>d),E={read:!1,insert:!1,update:!1};for(let d in u.attribute_permissions){let h=u.attribute_permissions[d];if(Object.keys(h).forEach(R=>{!D0.includes(R)&&R!==pn.DELETE&&fe(le.INVALID_ATTR_PERM_KEY(R),r,o,_)}),!Yr.isDefined(h.attribute_name)){fe(le.ATTR_PERM_MISSING_NAME,r,o,_);continue}let m=h.attribute_name;if(!l.includes(m)){fe(le.INVALID_ATTRIBUTE_IN_PERMS(m),r,o,_);continue}eO.forEach(R=>{Yr.isDefined(h[R])?Yr.isBoolean(h[R])||fe(le.ATTR_PERM_NOT_BOOLEAN(R,m),r,o,_):fe(le.ATTR_PERM_MISSING(R,m),r,o,_)}),!E.read&&h.read===!0&&(E.read=!0),!E.insert&&h.insert===!0&&(E.insert=!0),!E.update&&h.update===!0&&(E.update=!0)}if(u.read===!1&&E.read===!0||u.insert===!1&&E.insert===!0||u.update===!1&&E.update===!0){let d=`${o}.${_}`;fe(le.MISMATCHED_TABLE_ATTR_PERMS(d),r,o,_)}}}}return q0(r)}a(tO,"customValidate");rO.exports={addRoleValidation:M0,alterRoleValidation:P0,dropRoleValidation:B0};function H0(e){let{operation:t,permission:r}=e;if(t===On.OPERATIONS_ENUM.ADD_ROLE||t===On.OPERATIONS_ENUM.ALTER_ROLE){let s=r.super_user===!0,n=r.cluster_user===!0;if(Object.keys(r).length>1&&(s||n)){if(n&&s)return le.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?On.ROLE_TYPES_ENUM.SUPER_USER:On.ROLE_TYPES_ENUM.CLUSTER_USER;return le.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(H0,"validateNoSUPerms");function q0(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let s={error:le.ROLE_PERMS_ERROR,...e};return I0(new Error,s,w0.BAD_REQUEST)}else return null}a(q0,"generateRolePermResponse");function fe(e,t,r,s){if(!r)t.main_permissions.push(e);else{let n=s?r+"_"+s:r;t.schema_permissions[n]?t.schema_permissions[n].push(e):t.schema_permissions[n]=[e]}}a(fe,"addPermError")});var oE=S((mZ,_O)=>{"use strict";var nO=Lt(),iO=Tt(),G0=fs(),rE=sO(),sE=Xs(),F0=require("uuid").v4,nE=require("util"),V0=mi(),Rr=T(),aO=b(),iE=nE.promisify(iO.searchByValue),k0=nE.promisify(iO.searchByHash),$0=nE.promisify(G0.delete),x0=xt(),Y0=us(),{hdb_errors:K0,handleHDBError:Ci}=D(),{HDB_ERROR_MSGS:oO,HTTP_STATUS_CODES:eE}=K0,{UserEventMsg:aE}=Pr();_O.exports={addRole:W0,alterRole:J0,dropRole:X0,listRoles:cO};function tE(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(tE,"scrubRoleDetails");async function W0(e){let t=rE.addRoleValidation(e);if(t)throw t;if(!(await V0.getLicense()).enterprise){let o=await cO();if(Q0(e,o))throw new Error(`Your current license only supports ${Rr.BASIC_LICENSE_MAX_CLUSTER_USER_ROLES} cluster_user role. ${Rr.SUPPORT_HELP_MSG}`);if(o.length>=2)throw new Error(`Your current license only supports ${Rr.BASIC_LICENSE_MAX_NON_CU_ROLES+Rr.BASIC_LICENSE_MAX_CLUSTER_USER_ROLES} roles. ${Rr.SUPPORT_HELP_MSG}`)}e=tE(e);let s={schema:"system",table:"hdb_role",search_attribute:"role",search_value:e.role,hash_attribute:"id",get_attributes:["*"]},n;try{n=await iE(s)}catch(o){throw Ci(o)}if(n&&n.length>0)throw Ci(new Error,oO.ROLE_ALREADY_EXISTS(e.role),eE.CONFLICT,void 0,void 0,!0);e.id||(e.id=F0());let i={operation:"insert",schema:"system",table:"hdb_role",hash_attribute:"id",records:[e]};return await nO.insert(i),sE.signalUserChange(new aE(process.pid)),e=tE(e),e}a(W0,"addRole");function Q0(e,t){let r=!1;if(e.permission.cluster_user===!0)for(let s=0;s<t.length;s++){let i=t[s].permission;if(!aO.isEmpty(i)&&i.cluster_user===!0)return!0}return r}a(Q0,"checkClusterUserRole");async function J0(e){let t=rE.alterRoleValidation(e);if(t)throw t;e=tE(e);let r={operation:"update",schema:"system",table:"hdb_role",hash_attribute:"rolename",records:[e]};try{await nO.update(r)}catch(s){throw Ci(s)}return sE.signalUserChange(new aE(process.pid)),e}a(J0,"alterRole");async function X0(e){let t=rE.dropRoleValidation(e);if(t)throw Ci(new Error,t,eE.BAD_REQUEST,void 0,void 0,!0);let r=new Y0(Rr.SYSTEM_SCHEMA_NAME,Rr.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),s=await k0(r);if(s.length===0)throw Ci(new Error,oO.ROLE_NOT_FOUND,eE.NOT_FOUND,void 0,void 0,!0);let n=new x0(Rr.SYSTEM_SCHEMA_NAME,Rr.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=await iE(n),o=!1;if(aO.isEmptyOrZeroLength(i)===!1){for(let _=0;_<i.length;_++)if(i[_].active===!0){o=!0;break}}if(o===!0)throw new Error(`Cannot drop role ${s[0].role} as it has active user(s) tied to this role`);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await $0(c),sE.signalUserChange(new aE(process.pid)),`${s[0].role} successfully deleted`}a(X0,"dropRole");async function cO(){return iE({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(cO,"listRoles")});var dO=S((RZ,EO)=>{"use strict";var Z0=Y(),Kr=require("joi"),z0=de(),uO=require("moment"),j0=require("fs-extra"),cE=require("path"),eV=require("lodash"),Li=T(),{LOG_LEVELS:gs}=T(),tV="YYYY-MM-DD hh:mm:ss",rV=cE.resolve(__dirname,"../logs");EO.exports=function(e){return z0.validateBySchema(e,sV)};var sV=Kr.object({from:Kr.custom(lO),until:Kr.custom(lO),level:Kr.valid(gs.NOTIFY,gs.FATAL,gs.ERROR,gs.WARN,gs.INFO,gs.DEBUG,gs.TRACE),order:Kr.valid("asc","desc"),limit:Kr.number().min(1),start:Kr.number().min(0),log_name:Kr.custom(nV)});function lO(e,t){if(uO(e,uO.ISO_8601).format(tV)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(lO,"validateDatetime");function nV(e,t){if(eV.invert(Li.PROCESS_LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let s=Z0.get(Li.HDB_SETTINGS_NAMES.LOG_PATH_KEY),n=e===void 0?Li.PROCESS_LOG_NAMES.HDB:e,i=n===Li.PROCESS_LOG_NAMES.INSTALL?cE.join(rV,Li.PROCESS_LOG_NAMES.INSTALL):cE.join(s,n);return j0.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(nV,"validateReadLogPath")});var uE=S((AZ,SO)=>{"use strict";var sc=T(),hO=I(),iV=Y(),aV=dO(),_E=require("path"),oV=require("fs-extra"),cV=require("readline"),{once:_V}=require("events"),{handleHDBError:uV,hdb_errors:lV}=D(),{PACKAGE_ROOT:EV}=T(),dV=_E.join(EV,"logs"),hV=1e3;SO.exports=SV;async function SV(e){let t=aV(e);if(t)throw uV(t,t.message,lV.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=iV.get(sc.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e.log_name===void 0?sc.PROCESS_LOG_NAMES.HDB:e.log_name,n=s===sc.PROCESS_LOG_NAMES.INSTALL?_E.join(dV,sc.PROCESS_LOG_NAMES.INSTALL):_E.join(r,s),i=oV.createReadStream(n);i.on("error",z=>{hO.error(z)});let o=cV.createInterface({input:i,crlfDelay:1/0}),c=e.level!==void 0,_=c?e.level:void 0,u=e.from!==void 0,l=u?new Date(e.from):void 0,E=e.until!==void 0,d=E?new Date(e.until):void 0,h=e.limit===void 0?hV:e.limit,m=e.order===void 0?void 0:e.order,R=e.start===void 0?0:e.start,C=R+h,L=0,B=[];return o.on("line",z=>{let V,Q,ke,$e;try{V=JSON.parse(z)}catch(ca){hO.warn(ca.message);return}switch(!0){case(c&&u&&E):Q=new Date(V.timestamp),ke=new Date(l),$e=new Date(d),V.level===_&&Q>=ke&&Q<=$e&&L<R?L++:V.level===_&&Q>=ke&&Q<=$e&&(Qr(V,m,B),L++,L===C&&Wr(o));break;case(c&&u):Q=new Date(V.timestamp),ke=new Date(l),V.level===_&&Q>=ke&&L<R?L++:V.level===_&&Q>=ke&&(Qr(V,m,B),L++,L===C&&Wr(o));break;case(c&&E):Q=new Date(V.timestamp),$e=new Date(d),V.level===_&&Q<=$e&&L<R?L++:V.level===_&&Q<=$e&&(Qr(V,m,B),L++,L===C&&Wr(o));break;case(u&&E):Q=new Date(V.timestamp),ke=new Date(l),$e=new Date(d),Q>=ke&&Q<=$e&&L<R?L++:Q>=ke&&Q<=$e&&(Qr(V,m,B),L++,L===C&&Wr(o));break;case c:V.level===_&&L<R?L++:V.level===_&&(Qr(V,m,B),L++,L===C&&Wr(o));break;case u:Q=new Date(V.timestamp),ke=new Date(l),Q>=ke&&L<R?L++:Q>=ke&&L>=R&&(Qr(V,m,B),L++,L===C&&Wr(o));break;case E:Q=new Date(V.timestamp),$e=new Date(d),Q<=$e&&L<R?L++:Q<=$e&&L>=R&&(Qr(V,m,B),L++,L===C&&Wr(o));break;default:L<R?L++:(Qr(V,m,B),L++,L===C&&Wr(o))}}),await _V(o,"close"),B}a(SV,"readLog");function Wr(e){e.close(),e.removeAllListeners()}a(Wr,"endReadLine");function Qr(e,t,r){t==="desc"?fV(e,r):t==="asc"?TV(e,r):r.push(e)}a(Qr,"pushLineToResult");function fV(e,t){let r=new Date(e.timestamp),s=0,n=t.length;for(;s<n;){let i=s+n>>>1;new Date(t[i].timestamp)>r?s=i+1:n=i}t.splice(s,0,e)}a(fV,"insertDescending");function TV(e,t){let r=new Date(e.timestamp),s=0,n=t.length;for(;s<n;){let i=s+n>>>1;new Date(t[i].timestamp)<r?s=i+1:n=i}t.splice(s,0,e)}a(TV,"insertAscending")});var ic=S((NZ,mO)=>{"use strict";var lE=require("joi"),{string:nc,boolean:fO,date:mV}=lE.types(),RV=de(),{validateSchemaExists:OZ,validateTableExists:pZ,validateSchemaName:AV}=Er(),OV=T(),pV=_e(),NV=Y(),gV=nc.invalid(NV.get(OV.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(pV.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(),TO={operation:nc.valid("add_node","update_node"),node_name:gV,subscriptions:lE.array().items({table:nc.required(),schema:nc.custom(AV).required(),subscribe:fO.required(),publish:fO.required().custom(bV),start_time:mV.iso()}).min(1).required()};function IV(e){return RV.validateBySchema(e,lE.object(TO))}a(IV,"addUpdateNodeValidator");function bV(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(bV,"checkForFalsy");mO.exports={addUpdateNodeValidator:IV,validation_schema:TO}});var AO=S((gZ,RO)=>{var wV=de(),CV={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};RO.exports=function(e){return wV.validateObject(e,CV)}});var EE=S((IZ,OO)=>{"use strict";var LV=T().OPERATIONS_ENUM,ac=class{constructor(t,r,s,n=void 0){this.operation=LV.UPDATE,this.schema=t,this.table=r,this.records=s,this.__origin=n}};a(ac,"UpdateObject");OO.exports=ac});var NO=S((bZ,pO)=>{"use strict";var UV={OPERATION:"operation",REFRESH:"refresh"},oc=class{constructor(t,r){this.operation_token=t,this.refresh_token=r}};a(oc,"JWTTokens");var cc=class{constructor(t,r,s){this.public_key=t,this.private_key=r,this.passphrase=s}};a(cc,"JWTRSAKeys");pO.exports={JWTTokens:oc,TOKEN_TYPE_ENUM:UV,JWTRSAKeys:cc}});var Ec=S((wZ,wO)=>{"use strict";var yi=require("jsonwebtoken"),dE=require("fs-extra"),hE=b(),yt=T(),{handleHDBError:ot,hdb_errors:yV}=D(),{HTTP_STATUS_CODES:ct,AUTHENTICATION_ERROR_MSGS:_t}=yV,Ui=I(),gO=Vo(),TE=xr(),DV=Lt().update,MV=EE(),PV=Xs(),{UserEventMsg:BV}=Pr(),Jr=Y();Jr.initSync();var SE=require("path"),{JWTTokens:vV,JWTRSAKeys:HV,TOKEN_TYPE_ENUM:_c}=NO(),qV=Jr.get(yt.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY)?Jr.get(yt.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY):"1d",GV=Jr.get(yt.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY)?Jr.get(yt.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY):"30d",uc="RS256",fE;wO.exports={createTokens:FV,validateOperationToken:kV,refreshOperationToken:VV,validateRefreshToken:bO};async function FV(e){if(hE.isEmpty(e)||typeof e!="object")throw ot(new Error,_t.INVALID_AUTH_OBJECT,ct.BAD_REQUEST,void 0,void 0,!0);if(hE.isEmpty(e.username))throw ot(new Error,_t.USERNAME_REQUIRED,ct.BAD_REQUEST,void 0,void 0,!0);if(hE.isEmpty(e.password))throw ot(new Error,_t.PASSWORD_REQUIRED,ct.BAD_REQUEST,void 0,void 0,!0);let t;try{if(t=await TE.findAndValidateUser(e.username,e.password),!t)throw ot(new Error,_t.INVALID_CREDENTIALS,ct.UNAUTHORIZED,void 0,void 0,!0)}catch(d){throw Ui.error(d),ot(new Error,_t.INVALID_CREDENTIALS,ct.UNAUTHORIZED,void 0,void 0,!0)}let r=await lc(),s=!1,n=!1;t.role&&t.role.permission&&(s=t.role.permission.super_user===!0,n=t.role.permission.cluster_user===!0);let i={username:e.username,super_user:s,cluster_user:n},o=await IO(i,r.private_key,r.passphrase),c=await yi.sign(i,{key:r.private_key,passphrase:r.passphrase},{expiresIn:GV,algorithm:uc,subject:_c.REFRESH}),_=gO.hash(c),u=new MV(yt.SYSTEM_SCHEMA_NAME,yt.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,[{username:e.username,refresh_token:_}]),l,E;try{l=await DV(u)}catch(d){Ui.error(d),E=d}if(E!==void 0||l.skipped_hashes.length>0)throw ot(new Error,_t.REFRESH_TOKEN_SAVE_FAILED,ct.INTERNAL_SERVER_ERROR);return PV.signalUserChange(new BV(process.pid)),new vV(o,c)}a(FV,"createTokens");async function IO(e,t,r){return await yi.sign(e,{key:t,passphrase:r},{expiresIn:qV,algorithm:uc,subject:_c.OPERATION})}a(IO,"signOperationToken");async function lc(){if(fE===void 0)try{let e=SE.join(Jr.getHdbBasePath(),yt.LICENSE_KEY_DIR_NAME,yt.JWT_ENUM.JWT_PASSPHRASE_NAME),t=SE.join(Jr.getHdbBasePath(),yt.LICENSE_KEY_DIR_NAME,yt.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r=SE.join(Jr.getHdbBasePath(),yt.LICENSE_KEY_DIR_NAME,yt.JWT_ENUM.JWT_PUBLIC_KEY_NAME),s=(await dE.readFile(e)).toString(),n=(await dE.readFile(t)).toString(),i=(await dE.readFile(r)).toString();fE=new HV(i,n,s)}catch(e){throw Ui.error(e),ot(new Error,_t.NO_ENCRYPTION_KEYS,ct.INTERNAL_SERVER_ERROR)}return fE}a(lc,"getJWTRSAKeys");async function VV(e){if(!e)throw ot(new Error,_t.INVALID_BODY,ct.BAD_REQUEST,void 0,void 0,!0);if(!e.refresh_token)throw ot(new Error,_t.REFRESH_TOKEN_REQUIRED,ct.BAD_REQUEST,void 0,void 0,!0);await bO(e.refresh_token);let t=await lc(),r=await yi.decode(e.refresh_token);return{operation_token:await IO({username:r.username,super_user:r.super_user,cluster_user:r.cluster_user},t.private_key,t.passphrase)}}a(VV,"refreshOperationToken");async function kV(e){try{let t=await lc(),r=await yi.verify(e,t.public_key,{algorithms:uc,subject:_c.OPERATION});return await TE.findAndValidateUser(r.username,void 0,!1)}catch(t){throw Ui.warn(t),t.name&&t.name==="TokenExpiredError"?ot(new Error,_t.TOKEN_EXPIRED,ct.FORBIDDEN):ot(new Error,_t.INVALID_TOKEN,ct.UNAUTHORIZED)}}a(kV,"validateOperationToken");async function bO(e){let t;try{let r=await lc(),s=await yi.verify(e,r.public_key,{algorithms:uc,subject:_c.REFRESH});t=await TE.findAndValidateUser(s.username,void 0,!1)}catch(r){throw Ui.warn(r),r.name&&r.name==="TokenExpiredError"?ot(new Error,_t.TOKEN_EXPIRED,ct.FORBIDDEN):ot(new Error,_t.INVALID_TOKEN,ct.UNAUTHORIZED)}if(!gO.validate(t.refresh_token,e))throw ot(new Error,_t.INVALID_TOKEN,ct.UNAUTHORIZED);return t}a(bO,"validateRefreshToken")});var yO=S((LZ,UO)=>{"use strict";var $V=AO(),Nn=require("passport"),xV=require("passport-local").Strategy,YV=require("passport-http").BasicStrategy,KV=require("util"),WV=xr(),LO=KV.callbackify(WV.findAndValidateUser),CZ=Ke(),QV=T(),CO=Ec();Nn.use(new xV(function(e,t,r){LO(e,t,r)}));Nn.use(new YV(function(e,t,r){LO(e,t,r)}));Nn.serializeUser(function(e,t){t(null,e)});Nn.deserializeUser(function(e,t){t(null,e)});function JV(e,t,r){let s,n;if(e.headers&&e.headers.authorization){let o=e.headers.authorization.split(" ");s=o[0],n=o[1]}function i(o,c){return o?r(o):c?r(null,c):r("User not found")}switch(a(i,"handleResponse"),s){case"Basic":Nn.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body&&e.body.operation&&e.body.operation===QV.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?CO.validateRefreshToken(n).then(o=>{e.body.refresh_token=n,r(null,o)}).catch(o=>{r(o)}):CO.validateOperationToken(n).then(o=>{r(null,o)}).catch(o=>{r(o)});break;default:Nn.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(JV,"authorize");function XV(e,t){let r=$V(e);if(r){t(r);return}let s={authorized:!0,messages:[]},n=e.user.role;if(!n||!n.permission)return t("Invalid role");let i=JSON.parse(n.permission);if(i.super_user)return t(null,s);if(!i[e.schema])return s.authorized=!1,s.messages.push(`Not authorized to access ${e.schema} schema`),t(null,s);if(!i[e.schema].tables[e.table])return s.authorized=!1,s.messages.push(`Not authorized to access ${e.table} table`),t(null,s);if(!i[e.schema].tables[e.table][e.operation])return s.authorized=!1,s.messages.push(`Not authorized to access ${e.operation} on ${e.table} table`),t(null,s);if(i[e.schema].tables[e.table].attribute_permissions&&!e.attributes)return s.authorized=!1,s.messages.push(`${e.schema}.${e.table} has attribute permissions. Missing attributes to validate`),t(null,s);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]&&(s.authorized=!1,s.messages.push(`Not authorized to ${e.operation} ${o[c].attribute_name} `))}return t(null,s)}a(XV,"checkPermissions");UO.exports={authorize:JV,checkPermissions:XV}});var gn=S((UZ,DO)=>{"use strict";var dc=class{constructor(t,r,s){this.name=t,this.subscriptions=r,this.system_info=s}};a(dc,"Node");var hc=class{constructor(t,r,s,n){this.schema=t,this.table=r,this.publish=s,this.subscribe=n}};a(hc,"NodeSubscription");DO.exports={Node:dc,NodeSubscription:hc}});var PO=S((yZ,MO)=>{"use strict";var ZV=T().OPERATIONS_ENUM,Sc=class{constructor(t,r,s,n=void 0){this.operation=ZV.UPSERT,this.schema=t,this.table=r,this.records=s,this.__origin=n}};a(Sc,"UpsertObject");MO.exports=Sc});var Di=S((DZ,BO)=>{"use strict";var fc=class{constructor(t,r,s,n){this.operation=t,this.node_name=r,this.subscriptions=s,this.system_info=n}};a(fc,"RemotePayloadObject");var Tc=class{constructor(t,r,s,n,i,o){this.schema=t,this.table=r,this.hash_attribute=s,this.publish=n,this.subscribe=i,this.start_time=o}};a(Tc,"RemotePayloadSubscription");BO.exports={RemotePayloadObject:fc,RemotePayloadSubscription:Tc}});var HO=S((MZ,vO)=>{"use strict";var mc=class{constructor(t,r,s=0,n=0,i=0,o=0){this.schema=t,this.table=r,this.table_size=s,this.record_count=n,this.transaction_log_size=i,this.transaction_log_record_count=o}};a(mc,"TableSizeObject");vO.exports=mc});var VO=S((PZ,FO)=>{"use strict";var zV=HO(),qO=require("path"),GO=te(),jV=Ye(),In=X(),ek=I();FO.exports=tk;async function tk(e){let t=new zV;try{let r=qO.join(GO.getBaseSchemaPath(),e.schema.toString()),s=await In.openEnvironment(r,e.name),n=In.statDBI(s,e.hash_attribute),i=qO.join(GO.getTransactionAuditStorePath(),e.schema.toString()),o=await In.openEnvironment(i,e.name,!0),c=In.statDBI(o,jV.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP),_=await In.environmentDataSize(r,e.name),u=await In.environmentDataSize(i,e.name);t.schema=e.schema,t.table=e.name,t.table_size=_,t.record_count=n.entryCount,t.transaction_log_size=u,t.transaction_log_record_count=c.entryCount}catch(r){ek.warn(`unable to stat table dbi due to ${r}`)}return t}a(tk,"lmdbGetTableSize")});var $O=S((BZ,kO)=>{"use strict";var rk=T(),Rc=class{constructor(t){this.operator=rk.OPERATIONS_ENUM.SYSTEM_INFORMATION,this.attributes=t}};a(Rc,"SystemInformationOperation");kO.exports=Rc});var YO=S((vZ,xO)=>{"use strict";var Ac=class{constructor(t,r,s,n,i,o,c){this.system=t,this.time=r,this.cpu=s,this.memory=n,this.disk=i,this.network=o,this.harperdb_processes=c}};a(Ac,"SystemInformationObject");xO.exports=Ac});var pc=S((qZ,KO)=>{"use strict";var ve=require("systeminformation"),bn=I(),sk=T(),nk=VO(),ik=ds(),ak=Y();ak.initSync();var HZ=$O(),ok=YO(),Oc;KO.exports={getHDBProcessInfo:OE,getNetworkInfo:NE,getDiskInfo:pE,getMemoryInfo:AE,getCPUInfo:RE,getTimeInfo:mE,getSystemInformation:gE,systemInformation:ck,getTableSize:IE};function mE(){return ve.time()}a(mE,"getTimeInfo");async function RE(){try{let{family:e,model:t,stepping:r,revision:s,voltage:n,speedmin:i,speedmax:o,governor:c,socket:_,cache:u,...l}=await ve.cpu();l.cpu_speed=await ve.cpuCurrentSpeed();let{raw_currentload:E,raw_currentload_idle:d,raw_currentload_irq:h,raw_currentload_nice:m,raw_currentload_system:R,raw_currentload_user:C,cpus:L,...B}=await ve.currentLoad();return B.cpus=[],L.forEach(z=>{let{raw_load:V,raw_load_idle:Q,raw_load_irq:ke,raw_load_nice:$e,raw_load_system:ca,raw_load_user:_a,...wr}=z;B.cpus.push(wr)}),l.current_load=B,l}catch(e){return bn.error(`error in getCPUInfo: ${e}`),{}}}a(RE,"getCPUInfo");async function AE(){try{let{buffers:e,cached:t,slab:r,buffcache:s,...n}=await ve.mem();return n}catch(e){return bn.error(`error in getMemoryInfo: ${e}`),{}}}a(AE,"getMemoryInfo");async function OE(){let e={core:[],clustering:[]};try{return(await ve.processes()).list.forEach(r=>{r.params.includes(sk.HDB_PROC_NAME)?e.core.push(r):r.params.includes("socketcluster")&&e.clustering.push(r)}),e}catch(t){return bn.error(`error in getHDBProcessInfo: ${t}`),e}}a(OE,"getHDBProcessInfo");async function pE(){let e={};try{let{rIO_sec:t,wIO_sec:r,tIO_sec:s,ms:n,...i}=await ve.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:_,...u}=await ve.fsStats();return e.read_write=u,e.size=await ve.fsSize(),e}catch(t){return bn.error(`error in getDiskInfo: ${t}`),e}}a(pE,"getDiskInfo");async function NE(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return e.default_interface=await ve.networkInterfaceDefault(),e.latency=await ve.inetChecksite("google.com"),(await ve.networkInterfaces()).forEach(s=>{let{internal:n,virtual:i,mtu:o,dhcp:c,dnsSuffix:_,ieee8021xAuth:u,ieee8021xState:l,carrier_changes:E,...d}=s;e.interfaces.push(d)}),(await ve.networkStats()).forEach(s=>{let{rx_sec:n,tx_sec:i,ms:o,...c}=s;e.stats.push(c)}),e.connections=await ve.networkConnections(),e}catch(t){return bn.error(`error in getNetworkInfo: ${t}`),e}}a(NE,"getNetworkInfo");async function gE(){if(Oc!==void 0)return Oc;let e={};try{let{codepage:t,logofile:r,serial:s,build:n,servicepack:i,uefi:o,...c}=await ve.osInfo();e=c;let _=await ve.versions("node, npm");return e.node_version=_.node,e.npm_version=_.npm,Oc=e,Oc}catch(t){return bn.error(`error in getSystemInformation: ${t}`),e}}a(gE,"getSystemInformation");async function IE(){let e=[],t=await ik.describeAll();for(let r of Object.values(t))for(let s of Object.values(r))e.push(await nk(s));return e}a(IE,"getTableSize");async function ck(e){let t=new ok;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await gE(),t.time=mE(),t.cpu=await RE(),t.memory=await AE(),t.disk=await pE(),t.network=await NE(),t.harperdb_processes=await OE(),t.table_size=await IE(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await gE();break;case"time":t.time=mE();break;case"cpu":t.cpu=await RE();break;case"memory":t.memory=await AE();break;case"disk":t.disk=await pE();break;case"network":t.network=await NE();break;case"harperdb_processes":t.harperdb_processes=await OE();break;case"table_size":t.table_size=await IE();break;default:break}return t}a(ck,"systemInformation")});var bE=S((VZ,WO)=>{"use strict";var GZ=require("fs-extra"),FZ=I();WO.exports={version:_k,printVersion:lk,nodeVersion:uk};var Xr=Ml();function _k(){if(Xr)return Xr.version}a(_k,"version");function uk(){if(Xr&&Xr.engines&&Xr.engines["preferred-node"])return Xr.engines["preferred-node"]}a(uk,"nodeVersion");function lk(){Xr&&console.log(`HarperDB Version ${Xr.version}`)}a(lk,"printVersion")});var bs=S((xZ,ZO)=>{"use strict";var Ek=Lt(),wE=b(),CE=require("util"),Is=T(),QO=Y();QO.initSync();var dk=yO(),JO=Tt(),{Node:kZ,NodeSubscription:$Z}=gn(),hk=us(),Sk=PO(),{RemotePayloadObject:fk,RemotePayloadSubscription:Tk}=Di(),{handleHDBError:mk,hdb_errors:Rk}=D(),{HTTP_STATUS_CODES:Ak,HDB_ERROR_MSGS:Ok}=Rk,pk=xt(),Nk=pc(),gk=bE(),Ik=CE.promisify(dk.authorize),bk=CE.promisify(JO.searchByHash),wk=CE.promisify(JO.searchByValue);ZO.exports={authHeaderToUser:Ck,isEmpty:Lk,getNodeRecord:Uk,upsertNodeRecord:yk,buildNodePayloads:Dk,checkClusteringEnabled:Mk,getAllNodeRecords:Pk,getSystemInfo:Bk,reverseSubscription:XO};async function Ck(e){let t={headers:{authorization:e.hdb_auth_header}};return e.hdb_user=await Ik(t,null),e}a(Ck,"authHeaderToUser");function Lk(e){return e==null}a(Lk,"isEmpty");async function Uk(e){let t=new hk(Is.SYSTEM_SCHEMA_NAME,Is.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return bk(t)}a(Uk,"getNodeRecord");async function yk(e){let t=new Sk(Is.SYSTEM_SCHEMA_NAME,Is.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return Ek.upsert(t)}a(yk,"upsertNodeRecord");function XO(e){if(wE.isEmpty(e.subscribe)||wE.isEmpty(e.publish))throw new Error("Received invalid subscription object");let{schema:t,table:r,hash_attribute:s}=e,n={schema:t,table:r,hash_attribute:s};return e.subscribe===!0&&e.publish===!1?(n.subscribe=!1,n.publish=!0):e.subscribe===!1&&e.publish===!0?(n.subscribe=!0,n.publish=!1):(n.subscribe=e.subscribe,n.publish=e.publish),n}a(XO,"reverseSubscription");function Dk(e,t,r,s){let n=[];for(let i=0,o=e.length;i<o;i++){let c=e[i],{schema:_,table:u}=c,l=wE.getTableHashAttribute(_,u),{subscribe:E,publish:d}=XO(c),h=new Tk(_,u,l,d,E,c.start_time);n.push(h)}return new fk(r,t,n,s)}a(Dk,"buildNodePayloads");function Mk(){if(!QO.get(Is.CONFIG_PARAMS.CLUSTERING_ENABLED))throw mk(new Error,Ok.CLUSTERING_NOT_ENABLED,Ak.BAD_REQUEST,void 0,void 0,!0)}a(Mk,"checkClusteringEnabled");async function Pk(){let e=new pk(Is.SYSTEM_SCHEMA_NAME,Is.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return wk(e)}a(Pk,"getAllNodeRecords");async function Bk(){let e=await Nk.getSystemInformation();return{hdb_version:gk.version(),node_version:e.node_version,platform:e.platform}}a(Bk,"getSystemInfo")});var UE=S((YZ,sp)=>{"use strict";var LE=at(),zO=b(),jO=_e(),vk=T(),Nc=I(),ep=jo(),Hk=Zu(),{RemotePayloadObject:qk}=Di(),{handleHDBError:tp,hdb_errors:Gk}=D(),{HTTP_STATUS_CODES:rp}=Gk,{NodeSubscription:Fk}=gn();sp.exports=Vk;async function Vk(e,t){let r;try{r=await LE.request(`${t}.${jO.REQUEST_SUFFIX}`,new qk(vk.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),Nc.trace("Response from remote describe all request:",r)}catch(o){Nc.error(`addNode received error from describe all request to remote node: ${o}`);let c=LE.requestErrorHandler(o,"add_node",t);throw tp(new Error,c,rp.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===jO.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let o=`Error returned from remote node ${t}: ${r.message}`;throw tp(new Error,o,rp.INTERNAL_SERVER_ERROR,"error",o)}let s=r.message,n=[],i=[];for(let o of e){let{schema:c,table:_}=o,u=zO.doesSchemaExist(c),l=s[c]!==void 0,E=zO.doesTableExist(c,_),d=s?.[c]?.[_]!==void 0;if(!u&&!l||!E&&!d){n.push(o);continue}if(!u&&l&&(Nc.trace(`addNode creating schema: ${c}`),await ep.createSchema({operation:"create_schema",schema:c})),!E&&d){Nc.trace(`addNode creating table: ${_} in schema: ${c}`);let m=new Hk(c,_,s[c][_].hash_attribute);await ep.createTable(m)}await LE.createLocalTableStream(c,_);let h=new Fk(c,_,o.publish,o.subscribe);h.start_time=o.start_time,i.push(h)}return{added:i,skipped:n}}a(Vk,"reviewSubscriptions")});var bc=S((KZ,ap)=>{"use strict";var{handleHDBError:gc,hdb_errors:kk}=D(),{HTTP_STATUS_CODES:Ic}=kk,{addUpdateNodeValidator:$k}=ic(),Mi=I(),ip=T(),np=_e(),xk=b(),yE=at(),Pi=bs(),Yk=Y(),Kk=UE(),{Node:Wk,NodeSubscription:Qk}=gn(),Jk="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",Xk="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",Zk=Yk.get(ip.CONFIG_PARAMS.CLUSTERING_NODENAME);ap.exports=zk;async function zk(e,t=!1){Mi.trace("addNode called with:",e),Pi.checkClusteringEnabled();let r=$k(e);if(r)throw gc(r,r.message,Ic.BAD_REQUEST,void 0,void 0,!0);let s=e.node_name;if(!t){let E=await Pi.getNodeRecord(s);if(!xk.isEmptyOrZeroLength(E))throw gc(new Error,`Node '${s}' has already been added, perform update_node to proceed.`,Ic.BAD_REQUEST,void 0,void 0,!0)}let{added:n,skipped:i}=await Kk(e.subscriptions,s),o={message:void 0,added:n,skipped:i};if(n.length===0)return o.message=Jk,o;let c=Pi.buildNodePayloads(n,Zk,ip.OPERATIONS_ENUM.ADD_NODE,await Pi.getSystemInfo());Mi.trace("addNode sending remote payload:",c);let _;try{_=await yE.request(`${s}.${np.REQUEST_SUFFIX}`,c)}catch(E){Mi.error(`addNode received error from request: ${E}`);let d=yE.requestErrorHandler(E,"add_node",s);throw gc(new Error,d,Ic.INTERNAL_SERVER_ERROR,"error",d)}if(_.status===np.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let E=`Error returned from remote node ${s}: ${_.message}`;throw gc(new Error,E,Ic.INTERNAL_SERVER_ERROR,"error",E)}Mi.trace(_);let u=[];for(let E=0,d=n.length;E<d;E++){let h=n[E];Mi.trace("Add node updating work stream for node:",s,"subscriptions:",h),await yE.updateWorkStream(h,s),n[E].start_time===void 0&&delete n[E].start_time,u.push(new Qk(h.schema,h.table,h.publish,h.subscribe))}let l=new Wk(s,u,_.system_info);return await Pi.upsertNodeRecord(l),i.length>0?o.message=Xk:o.message=`Successfully added '${s}' to manifest`,o}a(zk,"addNode")});var ME=S((WZ,_p)=>{"use strict";var{handleHDBError:wc,hdb_errors:jk}=D(),{HTTP_STATUS_CODES:Cc}=jk,{addUpdateNodeValidator:e$}=ic(),Bi=I(),cp=T(),op=_e(),t$=b(),DE=at(),vi=bs(),r$=Y(),{cloneDeep:s$}=require("lodash"),n$=UE(),{NodeSubscription:i$}=gn(),a$="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",o$="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",c$=r$.get(cp.CONFIG_PARAMS.CLUSTERING_NODENAME);_p.exports=_$;async function _$(e){Bi.trace("updateNode called with:",e),vi.checkClusteringEnabled();let t=e$(e);if(t)throw wc(t,t.message,Cc.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,s=s$(await vi.getNodeRecord(r));if(t$.isEmptyOrZeroLength(s))throw wc(new Error,`Node '${r}' has not been added, perform add_node to proceed.`,Cc.BAD_REQUEST,void 0,void 0,!0);let{added:n,skipped:i}=await n$(e.subscriptions,r),o={message:void 0,updated:n,skipped:i};if(n.length===0)return o.message=a$,o;let c=vi.buildNodePayloads(n,c$,cp.OPERATIONS_ENUM.UPDATE_NODE,await vi.getSystemInfo());Bi.trace("updateNode sending remote payload:",c);let _;try{_=await DE.request(`${r}.${op.REQUEST_SUFFIX}`,c)}catch(u){Bi.error(`updateNode received error from request: ${u}`);let l=DE.requestErrorHandler(u,"update_node",r);throw wc(new Error,l,Cc.INTERNAL_SERVER_ERROR,"error",l)}if(_.status===op.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let u=`Error returned from remote node ${r}: ${_.message}`;throw wc(new Error,u,Cc.INTERNAL_SERVER_ERROR,"error",u)}Bi.trace(_);for(let u=0,l=n.length;u<l;u++){let E=n[u];Bi.trace(`updateNode updating work stream for node: ${r} subscription:`,E),await DE.updateWorkStream(E,r),n[u].start_time===void 0&&delete n[u].start_time}return await u$(s[0],n,_.system_info),i.length>0?o.message=o$:o.message=`Successfully updated '${r}'`,o}a(_$,"updateNode");async function u$(e,t,r){let s=e;for(let n=0,i=t.length;n<i;n++){let o=t[n],c=!1;for(let _=0,u=e.subscriptions.length;_<u;_++){let l=s.subscriptions[_];if(l.schema===o.schema&&l.table===o.table){l.publish=o.publish,l.subscribe=o.subscribe,c=!0;break}}c||s.subscriptions.push(new i$(o.schema,o.table,o.publish,o.subscribe))}s.system_info=r,await vi.upsertNodeRecord(s)}a(u$,"updateNodeTable")});var hp=S((QZ,dp)=>{"use strict";var Ep=require("joi"),{string:up}=Ep.types(),l$=de(),lp=T(),E$=Y(),d$=_e();dp.exports=h$;function h$(e){let t=up.invalid(E$.get(lp.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(d$.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=Ep.object({operation:up.valid(lp.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return l$.validateBySchema(e,r)}a(h$,"removeNodeValidator")});var Uc=S((JZ,Ap)=>{"use strict";var{handleHDBError:Sp,hdb_errors:S$}=D(),{HTTP_STATUS_CODES:fp}=S$,f$=hp(),Hi=I(),Tp=bs(),T$=b(),Lc=T(),mp=_e(),Rp=at(),m$=Y(),{RemotePayloadObject:R$}=Di(),{NodeSubscription:A$}=gn(),O$=_i(),p$=fs(),N$=m$.get(Lc.CONFIG_PARAMS.CLUSTERING_NODENAME);Ap.exports=g$;async function g$(e){Hi.trace("removeNode called with:",e),Tp.checkClusteringEnabled();let t=f$(e);if(t)throw Sp(t,t.message,fp.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,s=await Tp.getNodeRecord(r);if(T$.isEmptyOrZeroLength(s))throw Sp(new Error,`Node '${r}' was not found.`,fp.BAD_REQUEST,void 0,void 0,!0);s=s[0];let n=new R$(Lc.OPERATIONS_ENUM.REMOVE_NODE,N$,[]),i,o=!1;try{i=await Rp.request(`${r}.${mp.REQUEST_SUFFIX}`,n),Hi.trace("Remove node reply from remote node:",r,i)}catch(_){Hi.error("removeNode received error from request:",_),o=!0}for(let _=0,u=s.subscriptions.length;_<u;_++){let l=s.subscriptions[_];Hi.trace(`Remove node removing subscription: ${l.schema}.${l.table} for node: ${r}`);let E=new A$(l.schema,l.table,!1,!1);await Rp.updateWorkStream(E,r)}let c=new O$(Lc.SYSTEM_SCHEMA_NAME,Lc.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await p$.deleteRecord(c),i?.status===mp.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||o?(Hi.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(g$,"removeNode")});var Np=S((XZ,pp)=>{"use strict";var Op=require("joi"),{string:I$,array:b$}=Op.types(),w$=de(),C$=ic();pp.exports=L$;function L$(e){let t=Op.object({operation:I$.valid("configure_cluster").required(),connections:b$.items(C$.validation_schema).required()});return w$.validateBySchema(e,t)}a(L$,"configureClusterValidator")});var PE=S((ZZ,Cp)=>{"use strict";var U$=T(),yc=I(),y$=b(),D$=Uc(),M$=bc(),gp=bs(),P$=Np(),{handleHDBError:Ip,hdb_errors:B$}=D(),{HTTP_STATUS_CODES:bp}=B$,v$="Configure cluster complete.",H$="Failed to configure the cluster. Check the logs for more details.",q$="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";Cp.exports=G$;async function G$(e){yc.trace("configure cluster called with:",e),gp.checkClusteringEnabled();let t=P$(e);if(t)throw Ip(t,t.message,bp.BAD_REQUEST,void 0,void 0,!0);let r=await gp.getAllNodeRecords(),s=[];for(let d=0,h=r.length;d<h;d++)s.push(wp(D$,{operation:U$.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[d].name},r[d].name));let n=await Promise.allSettled(s);yc.trace("All results from configure_cluster remove node:",n);let i=[],o=e.connections.length;for(let d=0;d<o;d++){let h=e.connections[d];i.push(wp(M$,h,h.node_name))}let c=await Promise.allSettled(i);yc.trace("All results from configure_cluster add node:",c);let _=[],u=[],l=!1,E=n.concat(c);for(let d=0,h=E.length;d<h;d++){let m=E[d];m.status==="rejected"&&(yc.error(m.reason),_.includes(m.reason.node_name)||_.push(m.reason.node_name)),m.status==="fulfilled"&&(l=!0);let R=m?.value?.result;typeof R=="string"&&R.includes("Successfully removed")||m.status==="rejected"||u.push({node_name:m?.value?.node_name,subscriptions:m?.value?.result})}if(y$.isEmptyOrZeroLength(_))return{message:v$,connections:u};if(l)return{message:q$,failed_nodes:_,connections:u};throw Ip(new Error,H$,bp.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(G$,"configureCluster");async function wp(e,t,r){try{return{node_name:r,result:await e(t)}}catch(s){throw{node_name:r,error:s}}}a(wp,"functionWrapper")});var HE=S((zZ,Pp)=>{"use strict";var vE=bs(),F$=at(),yp=Y(),Dc=T(),ws=_e(),V$=b(),BE=I(),{RemotePayloadObject:k$}=Di(),{ErrorCode:Lp}=require("nats"),Up=yp.get(Dc.CONFIG_PARAMS.CLUSTERING_ENABLED),Dp=yp.get(Dc.CONFIG_PARAMS.CLUSTERING_NODENAME);Pp.exports={clusterStatus:$$,buildNodeStatus:Mp};async function $$(){let e={node_name:Dp,is_enabled:Up,connections:[]};if(!Up)return e;let t=await vE.getAllNodeRecords();if(V$.isEmptyOrZeroLength(t))return e;let r=[];for(let s=0,n=t.length;s<n;s++)r.push(Mp(t[s],e.connections));return await Promise.allSettled(r),e}a($$,"clusterStatus");async function Mp(e,t){let r=e.name,s=new k$(Dc.OPERATIONS_ENUM.CLUSTER_STATUS,Dp,void 0,await vE.getSystemInfo()),n,i,o=ws.CLUSTER_STATUS_STATUSES.OPEN;try{let _=Date.now();n=await F$.request(ws.REQUEST_SUBJECT(r),s),i=Date.now()-_,n.status===ws.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=ws.CLUSTER_STATUS_STATUSES.CLOSED,BE.error(`Error getting node status from ${r} `,n))}catch(_){BE.warn(`Error getting node status from ${r}`,_),_.code===Lp.NoResponders?o=ws.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:_.code===Lp.Timeout?o=ws.CLUSTER_STATUS_STATUSES.TIMEOUT:o=ws.CLUSTER_STATUS_STATUSES.CLOSED}let c=new x$(r,o,n?.message?.ports?.clustering,n?.message?.ports?.operations_api,i,n?.message?.uptime,e.subscriptions,n?.message?.system_info);try{let _={name:r,system_info:n?.message?.system_info};e.system_info?.hdb_version!==Dc.PRE_4_0_0_VERSION&&await vE.upsertNodeRecord(_)}catch(_){BE.error("Cluster status encountered an error updating system info for node:",r,_)}t.push(c)}a(Mp,"buildNodeStatus");function x$(e,t,r,s,n,i,o,c){this.node_name=e,this.status=t,this.ports={clustering:r,operations_api:s},this.latency_ms=n,this.uptime=i,this.subscriptions=o,this.system_info=c}a(x$,"NodeStatusObject")});var qp=S((jZ,Hp)=>{"use strict";var qE=require("joi"),Bp=de(),{route_constraints:vp}=lu();Hp.exports={setRoutesValidator:Y$,deleteRoutesValidator:K$};function Y$(e){let t=qE.object({server:qE.valid("hub","leaf").required(),routes:vp.required()});return Bp.validateBySchema(e,t)}a(Y$,"setRoutesValidator");function K$(e){let t=qE.object({routes:vp.required()});return Bp.validateBySchema(e,t)}a(K$,"deleteRoutesValidator")});var FE=S((e3,kp)=>{"use strict";var Cs=ur(),GE=b(),Mc=T(),Gp=qp(),{handleHDBError:Fp,hdb_errors:W$}=D(),{HTTP_STATUS_CODES:Vp}=W$,Q$="cluster routes successfully set",J$="cluster routes successfully deleted";kp.exports={setRoutes:X$,getRoutes:Z$,deleteRoutes:z$};function X$(e){let t=Gp.setRoutesValidator(e);if(t)throw Fp(t,t.message,Vp.BAD_REQUEST,void 0,void 0,!0);let r=Cs.getClusteringRoutes(),s=e.server==="hub"?r.hub_routes:r.leaf_routes,n=e.server==="hub"?r.leaf_routes:r.hub_routes,i=[],o=[];for(let c=0,_=e.routes.length;c<_;c++){let u=e.routes[c];u.port=GE.autoCast(u.port);let l=s.some(d=>d.host===u.host&&d.port===u.port),E=n.some(d=>d.host===u.host&&d.port===u.port);l||E?i.push(u):(s.push(u),o.push(u))}return e.server==="hub"?Cs.updateConfigValue(Mc.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,s):Cs.updateConfigValue(Mc.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,s),{message:Q$,set:o,skipped:i}}a(X$,"setRoutes");function Z$(){let e=Cs.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}a(Z$,"getRoutes");function z$(e){let t=Gp.deleteRoutesValidator(e);if(t)throw Fp(t,t.message,Vp.BAD_REQUEST,void 0,void 0,!0);let r=Cs.getClusteringRoutes(),s=r.hub_routes,n=r.leaf_routes,i=[],o=[],c=!1,_=!1;for(let u=0,l=e.routes.length;u<l;u++){let E=e.routes[u],d=!1;for(let h=0,m=s.length;h<m;h++){let R=s[h];if(E.host===R.host&&E.port===R.port){s.splice(h,1),d=!0,c=!0,i.push(E);break}}if(!d){let h=!0;for(let m=0,R=n.length;m<R;m++){let C=n[m];if(E.host===C.host&&E.port===C.port){n.splice(m,1),_=!0,h=!1,i.push(E);break}}h&&o.push(E)}}return c&&(s=GE.isEmptyOrZeroLength(s)?null:s,Cs.updateConfigValue(Mc.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,s)),_&&(n=GE.isEmptyOrZeroLength(n)?null:n,Cs.updateConfigValue(Mc.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n)),{message:J$,deleted:i,skipped:o}}a(z$,"deleteRoutes")});var xp=S((t3,$p)=>{"use strict";var qi=require("alasql"),Ls=require("recursive-iterator"),Kt=I(),j$=b(),Gi=T(),Pc=class{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,tx(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(n=>Gi.SEARCH_WILDCARDS.includes(n.columnid));if(r.length===0)return this.ast;let s=this.ast.from[0].databaseid;return this.ast.columns=this.ast.columns.filter(n=>!Gi.SEARCH_WILDCARDS.includes(n.columnid)),r.forEach(n=>{let i=this.table_to_schema_lookup.has(n.tableid)?this.table_to_schema_lookup.get(n.tableid):s,o=this.table_lookup.has(n.tableid)?this.table_lookup.get(n.tableid):this.ast.from[0].tableid;if(t[i]&&t[i].tables[o]&&t[i].tables[o][Gi.PERMS_CRUD_ENUM.READ]){let c;t[i].tables[o].attribute_permissions.length>0?c=ex(t[i].tables[o].attribute_permissions):c=global.hdb_schema[i][o].attributes.map(u=>({attribute_name:u.attribute}));let _=this.affected_attributes.get(i).get(o).filter(u=>!Gi.SEARCH_WILDCARDS.includes(u));c.forEach(({attribute_name:u})=>{let l=new qi.yy.Column({columnid:u});n.tableid&&(l.tableid=n.tableid),this.ast.columns.push(l),_.includes(u)||_.push(u)}),this.affected_attributes.get(i).set(o,_)}}),this.ast}};a(Pc,"sql_statement_bucket");function ex(e){return e.filter(t=>t[Gi.PERMS_CRUD_ENUM.READ])}a(ex,"filterReadRestrictedAttrs");function tx(e,t,r,s,n){rx(e,t,r,s,n)}a(tx,"interpretAST");function Fi(e,t,r,s,n){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),s&&!s.has(e.as)&&s.set(e.as,e.databaseid)),n)){let i=e.databaseid,o=e.tableid;e.as&&(o=e.as),n.set(o,i)}}a(Fi,"addSchemaTableToMap");function rx(e,t,r,s,n){if(!e){Kt.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof qi.yy.Insert?ax(e,t,r):e instanceof qi.yy.Select?sx(e,t,r,s,n):e instanceof qi.yy.Update?nx(e,t,r):e instanceof qi.yy.Delete?ix(e,t,r):Kt.error("AST in getRecordAttributesAST() is not a valid SQL type.")}a(rx,"getRecordAttributesAST");function sx(e,t,r,s,n){if(!e){Kt.info("getSelectAttributes: invalid SQL syntax tree");return}if(!e.from||e.from[0]===void 0)return;let i=e.from[0].databaseid;if(j$.isEmptyOrZeroLength(i)){Kt.error("No schema specified");return}e.from.forEach(c=>{Fi(c,t,r,s,n)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),Fi(c.table,t,r,s,n)});let o=new Ls(e.columns);for(let{node:c}of o)if(c&&c.columnid){let _=c.tableid,u=s.has(_)?s.get(_):i;if(_||(_=e.from[0].tableid),!t.get(u).has(_))if(r.has(_))_=r.get(_);else{Kt.info(`table specified as ${_} not found.`);return}t.get(u).get(_).indexOf(c.columnid)<0&&t.get(u).get(_).push(c.columnid)}if(e.where){let c=new Ls(e.where),_=e.from[0].tableid;for(let{node:u}of c)if(u&&u.columnid){let l=u.tableid?u.tableid:_;if(!t.get(i).has(l))if(r.has(l))l=r.get(l);else{Kt.info(`table specified as ${l} not found.`);continue}t.get(i).get(l).indexOf(u.columnid)<0&&t.get(i).get(l).push(u.columnid)}}if(e.joins&&e.joins.forEach(c=>{let _=new Ls(c.on);for(let{node:u}of _)if(u&&u.columnid){let l=u.tableid,E=n.get(l);if(!t.get(E).has(l))if(r.has(l))l=r.get(l);else{Kt.info(`table specified as ${l} not found.`);continue}t.get(E).get(l).indexOf(u.columnid)<0&&t.get(E).get(l).push(u.columnid)}}),e.order){let c=new Ls(e.order);for(let{node:_}of c)if(_&&_.columnid){let u=_.tableid,l=s.has(u)?s.get(u):i;if(u||(u=e.from[0].tableid),!t.get(l).has(u))if(r.has(u))u=r.get(u);else{Kt.info(`table specified as ${u} not found.`);return}t.get(l).get(u).indexOf(_.columnid)<0&&t.get(l).get(u).push(_.columnid)}}}a(sx,"getSelectAttributes");function nx(e,t,r){if(!e){Kt.info("getUpdateAttributes: invalid SQL syntax tree");return}let s=new Ls(e.columns),n=e.table.databaseid;Fi(e.table,t,r);for(let{node:i}of s)i&&i.columnid&&VE(e.table.tableid,n,i.columnid,t,r)}a(nx,"getUpdateAttributes");function ix(e,t,r){if(!e){Kt.info("getDeleteAttributes: invalid SQL syntax tree");return}let s=new Ls(e.where),n=e.table.databaseid;Fi(e.table,t,r);for(let{node:i}of s)i&&i.columnid&&VE(e.table.tableid,n,i.columnid,t,r)}a(ix,"getDeleteAttributes");function ax(e,t,r){if(!e){Kt.info("getInsertAttributes: invalid SQL syntax tree");return}let s=new Ls(e.columns),n=e.into.databaseid;Fi(e.into,t,r);for(let{node:i}of s)i&&i.columnid&&VE(e.into.tableid,n,i.columnid,t,r)}a(ax,"getInsertAttributes");function VE(e,t,r,s,n){if(!s.get(t))return;let i=e;s.get(t).has(i)||(i=n.get(i)),s.get(t).get(i).push(r)}a(VE,"pushAttribute");$p.exports=Pc});var Wp=S((r3,Kp)=>{var ox=require("os"),Yp=Y();Kp.exports={checkPermission:cx};function cx(){if(ox.userInfo().username!==Yp.get("install_user"))throw new Error(`Error: Must execute as ${Yp.get("install_user")}`)}a(cx,"checkPermission")});var $E=S((s3,zp)=>{var vc=mi(),Qp=require("chalk"),rr=I(),Jp=Wp(),Xp=require("prompt"),{promisify:_x}=require("util"),Bc=T(),ux=require("fs-extra"),lx=require("path"),Ex=b(),dx=bE(),Zp=Y();Zp.initSync();var hx=require("moment"),Sx=_x(Xp.get),fx=lx.join(Zp.getHdbBasePath(),Bc.LICENSE_KEY_DIR_NAME,Bc.LICENSE_FILE_NAME,Bc.LICENSE_FILE_NAME);zp.exports={getFingerprint:mx,setLicense:Tx,parseLicense:kE,register:Rx,getRegistrationInfo:Ox};async function Tx(e){if(e&&e.key&&e.company){try{rr.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await kE(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw rr.error(r),rr.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}a(Tx,"setLicense");async function mx(){try{Jp.checkPermission()}catch(t){throw rr.error(t),new Error("You do not have permission to generate a fingerprint.")}let e={};try{e=await vc.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw rr.error(r),rr.error(t),new Error(r)}return e}a(mx,"getFingerprint");async function kE(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");console.log("Validating license input...");let r=vc.validateLicense(e,t);if(console.log("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(console.log("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(console.log(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{rr.info("writing license to disk"),await ux.writeFile(fx,JSON.stringify({license_key:e,company:t}))}catch(s){throw rr.error("Failed to write License"),s}return"Registration successful."}a(kE,"parseLicense");async function Rx(){let e=await Ax();return kE(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(Rx,"register");async function Ax(){try{Jp.checkPermission()}catch(s){return console.error(s.message)}let e=await vc.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:Qp.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:Qp.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{Xp.start()}catch(s){rr.error(s)}let r;try{r=await Sx(t)}catch(s){throw console.error("There was a problem prompting for registration input. Exiting."),s}return r}a(Ax,"promptForRegistration");async function Ox(){let e={registered:!1,version:null,storage_type:null,ram_allocation:null,license_expiration_date:null},t;try{t=await vc.getLicense()}catch(r){throw rr.error(`There was an error when searching licenses due to: ${r.message}`),r}if(Ex.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=dx.version(),e.storage_type=Bc.STORAGE_TYPES_ENUM.LMDB,e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=hx.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(Ox,"getRegistrationInfo")});var eN=S((n3,jp)=>{"use strict";var px=_e(),Hc=class{constructor(t,r,s,n,i,o,c,_,u,l,E,d,h){this.port=t,o===null&&(o=void 0),this.server_name=r+px.SERVER_SUFFIX.HUB,this.pid_file=s,this.max_payload=1e7,this.jetstream={enabled:!1},this.tls={cert_file:n,key_file:i,ca_file:o,insecure:c},this.leafnodes={port:_,tls:{cert_file:n,key_file:i,ca_file:o,insecure:c}},this.cluster={name:u,port:l,routes:E,tls:{cert_file:n,key_file:i,ca_file:o,insecure:c}},this.accounts={SYS:{users:d},HDB:{users:h}},this.system_account="SYS"}};a(Hc,"HubConfigObject");jp.exports=Hc});var sN=S((i3,rN)=>{"use strict";var tN=_e(),qc=class{constructor(t,r,s,n,i,o,c,_,u,l,E){this.port=t,E===null&&(E=void 0),this.server_name=r+tN.SERVER_SUFFIX.LEAF,this.pid_file=s,this.max_payload=1e7,this.jetstream={enabled:!0,store_dir:n,domain:r+tN.SERVER_SUFFIX.LEAF},this.tls={cert_file:u,key_file:l,ca_file:E,insecure:!0},this.leafnodes={remotes:[{tls:{ca_file:E,insecure:!0},urls:i,account:"SYS"},{tls:{ca_file:E,insecure:!0},urls:o,account:"HDB"}]},this.accounts={SYS:{users:c},HDB:{users:_,jetstream:"enabled"}},this.system_account="SYS"}};a(qc,"LeafConfigObject");rN.exports=qc});var iN=S((a3,nN)=>{"use strict";var Gc=class{constructor(t,r){this.user=t,this.password=r}};a(Gc,"HdbUserObject");nN.exports=Gc});var oN=S((o3,aN)=>{"use strict";var Nx=_e(),Fc=class{constructor(t,r){this.user=t+Nx.SERVER_SUFFIX.ADMIN,this.password=r}};a(Fc,"SysUserObject");aN.exports=Fc});var KE=S((c3,uN)=>{"use strict";var wn=require("path"),xc=require("fs-extra"),gx=eN(),Ix=sN(),bx=iN(),wx=oN(),xE=xr(),Ln=b(),Dt=ur(),$c=T(),Vc=_e(),{CONFIG_PARAMS:we}=$c,Yc=I(),Kc=Y(),cN=Hr(),YE=at(),Cn="clustering",Cx=1e4,_N=5;uN.exports={generateNatsConfig:Lx,removeNatsConfig:Ux};async function Lx(e=!1,t=void 0){Kc.initSync();let r=Kc.get(we.ROOTPATH),s=wn.join(r,Cn,Vc.PID_FILES.HUB),n=wn.join(r,Cn,Vc.PID_FILES.LEAF),i=wn.join(r,Cn,"leaf"),o=wn.join(r,Cn,Vc.NATS_CONFIG_FILES.HUB_SERVER),c=wn.join(r,Cn,Vc.NATS_CONFIG_FILES.LEAF_SERVER),_=Dt.getConfigFromFile(we.CLUSTERING_TLS_CERTIFICATE),u=Dt.getConfigFromFile(we.CLUSTERING_TLS_PRIVATEKEY),l=Dt.getConfigFromFile(we.CLUSTERING_TLS_CERT_AUTH),E=Dt.getConfigFromFile(we.CLUSTERING_TLS_INSECURE),d=Dt.getConfigFromFile(we.CLUSTERING_NODENAME),h=Dt.getConfigFromFile(we.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await YE.checkNATSServerInstalled()||Wc("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let m=await xE.listUsers(),R=Dt.getConfigFromFile(we.CLUSTERING_USER),C=await xE.getClusterUser();(Ln.isEmpty(C)||C.active!==!0)&&Wc(`invalid cluster user '${R}'`),e||(await kc(we.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await kc(we.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await kc(we.CLUSTERING_HUBSERVER_NETWORK_PORT),await kc(we.CLUSTERING_LEAFSERVER_NETWORK_PORT));let L=[],B=[];for(let[_a,wr]of m.entries())wr.role.role===$c.ROLE_TYPES_ENUM.CLUSTER_USER&&wr.active&&(L.push(new wx(wr.username,cN.decrypt(wr.hash))),B.push(new bx(wr.username,cN.decrypt(wr.hash))));let z=[],{hub_routes:V}=Dt.getClusteringRoutes();if(!Ln.isEmptyOrZeroLength(V))for(let _a of V)z.push(`tls://${C.sys_name_encoded}:${C.uri_encoded_d_hash}@${_a.host}:${_a.port}`);let Q=new gx(Dt.getConfigFromFile(we.CLUSTERING_HUBSERVER_NETWORK_PORT),d,s,_,u,l,E,h,Dt.getConfigFromFile(we.CLUSTERING_HUBSERVER_CLUSTER_NAME),Dt.getConfigFromFile(we.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),z,L,B);t=Ln.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===$c.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await xc.writeJson(o,Q),Yc.trace(`Hub server config written to ${o}`));let ke=`tls://${C.sys_name_encoded}:${C.uri_encoded_d_hash}@0.0.0.0:${h}`,$e=`tls://${C.uri_encoded_name}:${C.uri_encoded_d_hash}@0.0.0.0:${h}`,ca=new Ix(Dt.getConfigFromFile(we.CLUSTERING_LEAFSERVER_NETWORK_PORT),d,n,i,[ke],[$e],L,B,_,u,l,E);(t===void 0||t===$c.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await xc.writeJson(c,ca),Yc.trace(`Leaf server config written to ${c}`))}a(Lx,"generateNatsConfig");async function kc(e){let t=Kc.get(e);Ln.isEmpty(t)&&Wc(`port undefined for '${e}'`),await Ln.isPortTaken(t)&&Wc(`'${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.`)}a(kc,"isPortAvailable");function Wc(e){let t=`Error generating clustering config: ${e}`;Yc.error(t),console.error(t),process.exit(1)}a(Wc,"generateNatsConfigError");async function Ux(e){let{port:t,config_file:r}=YE.getServerConfig(e),{username:s,decrypt_hash:n}=await xE.getClusterUser(),i=0,o=500;for(;i<_N;){try{let u=await YE.createConnection(t,s,n,!1);if(u.protocol.connected===!0){u.close();break}}catch(u){Yc.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${u}`)}if(i++,i>=_N)throw new Error(`Operations API timed out attempting to connect to ${e}. This is commonly caused by incorrect clustering config. Check the ${e} log for further details.`);await Ln.async_set_timeout(o*i)}let c="0".repeat(Cx),_=wn.join(Kc.get(we.ROOTPATH),Cn,r);await xc.writeFile(_,c),await xc.remove(_)}a(Ux,"removeNatsConfig")});var Jc=S((_3,TN)=>{"use strict";var se=Y(),lN=mi(),w=T(),WE=_e(),Ae=require("path"),{PACKAGE_ROOT:Qc}=T(),Ee="/dev/null",Un=Ae.join(Qc,"launchServiceScripts"),EN=Ae.join(Qc,"utility/scripts"),yx=Ae.join(EN,w.HDB_RESTART_SCRIPT),dN=Ae.resolve(Qc,"dependencies",`${process.platform}-${process.arch}`,WE.NATS_BINARY_NAME),He,qe;function sr(){(He===void 0||qe===void 0)&&(se.initSync(),He=se.get(w.HDB_SETTINGS_NAMES.LOG_TO_FILE),qe=se.get(w.HDB_SETTINGS_NAMES.LOG_PATH_KEY))}a(sr,"initLogConfig");function hN(){sr();let e=Ae.join(qe,w.PROCESS_LOG_NAMES.IPC),t={name:w.PROCESS_DESCRIPTORS.IPC,exec_mode:"fork",env:{[w.PROCESS_NAME_ENV_PROP]:w.PROCESS_DESCRIPTORS.IPC},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:w.SERVICE_SERVERS_CWD.IPC};return He||(t.out_file=Ee,t.error_file=Ee),{...t,script:w.SERVICE_SERVERS.IPC}}a(hN,"generateIPCServerConfig");function SN(){sr(),se.initSync(),He=se.get(w.HDB_SETTINGS_NAMES.LOG_TO_FILE),qe=se.get(w.HDB_SETTINGS_NAMES.LOG_PATH_KEY);let e=Ae.join(qe,w.PROCESS_LOG_NAMES.HDB),t=lN.licenseSearch(),r=t.ram_allocation?w.MEM_SETTING_KEY+t.ram_allocation:w.MEM_SETTING_KEY+w.RAM_ALLOCATION_ENUM.DEFAULT,s={name:w.PROCESS_DESCRIPTORS.HDB,script:w.LAUNCH_SERVICE_SCRIPTS.HDB,exec_mode:"cluster",env:{[w.PROCESS_NAME_ENV_PROP]:w.PROCESS_DESCRIPTORS.HDB},merge_logs:!0,out_file:e,error_file:e,instances:se.get(w.CONFIG_PARAMS.HTTP_THREADS),node_args:r,cwd:Un};return He||(s.out_file=Ee,s.error_file=Ee),s}a(SN,"generateHDBServerConfig");function fN(){sr(),se.initSync(),He=se.get(w.HDB_SETTINGS_NAMES.LOG_TO_FILE),qe=se.get(w.HDB_SETTINGS_NAMES.LOG_PATH_KEY);let e=Ae.join(qe,w.PROCESS_LOG_NAMES.CUSTOM_FUNCTIONS),t=lN.licenseSearch(),r=t.ram_allocation?w.MEM_SETTING_KEY+t.ram_allocation:w.MEM_SETTING_KEY+w.RAM_ALLOCATION_ENUM.DEFAULT,s={name:w.PROCESS_DESCRIPTORS.CUSTOM_FUNCTIONS,script:w.LAUNCH_SERVICE_SCRIPTS.CUSTOM_FUNCTIONS,exec_mode:"cluster",env:{[w.PROCESS_NAME_ENV_PROP]:w.PROCESS_DESCRIPTORS.CUSTOM_FUNCTIONS},merge_logs:!0,out_file:e,error_file:e,instances:se.get(w.CONFIG_PARAMS.HTTP_THREADS),node_args:r,cwd:Un};return He||(s.out_file=Ee,s.error_file=Ee),s}a(fN,"generateCFServerConfig");function Dx(){sr(),se.initSync(),He=se.get(w.HDB_SETTINGS_NAMES.LOG_TO_FILE),qe=se.get(w.HDB_SETTINGS_NAMES.LOG_PATH_KEY);let e=se.get(w.CONFIG_PARAMS.ROOTPATH),t=Ae.join(e,"clustering",WE.NATS_CONFIG_FILES.HUB_SERVER),r=Ae.join(qe,w.PROCESS_LOG_NAMES.CLUSTERING_HUB),s={name:w.PROCESS_DESCRIPTORS.CLUSTERING_HUB,script:dN,args:`-c ${t}`,exec_mode:"fork",env:{[w.PROCESS_NAME_ENV_PROP]:w.PROCESS_DESCRIPTORS.CLUSTERING_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return He||(s.out_file=Ee,s.error_file=Ee),s}a(Dx,"generateNatsHubServerConfig");function Mx(){sr(),se.initSync(),He=se.get(w.HDB_SETTINGS_NAMES.LOG_TO_FILE),qe=se.get(w.HDB_SETTINGS_NAMES.LOG_PATH_KEY);let e=se.get(w.CONFIG_PARAMS.ROOTPATH),t=Ae.join(e,"clustering",WE.NATS_CONFIG_FILES.LEAF_SERVER),r=Ae.join(qe,w.PROCESS_LOG_NAMES.CLUSTERING_LEAF),s={name:w.PROCESS_DESCRIPTORS.CLUSTERING_LEAF,script:dN,args:`-c ${t}`,exec_mode:"fork",env:{[w.PROCESS_NAME_ENV_PROP]:w.PROCESS_DESCRIPTORS.CLUSTERING_LEAF},merge_logs:!0,out_file:r,error_file:r,instances:1};return He||(s.out_file=Ee,s.error_file=Ee),s}a(Mx,"generateNatsLeafServerConfig");function Px(){sr(),se.initSync();let e=Ae.join(qe,w.PROCESS_LOG_NAMES.CLUSTERING_INGEST_SERVICE),t={name:w.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE,script:w.LAUNCH_SERVICE_SCRIPTS.NATS_INGEST_SERVICE,exec_mode:"cluster",env:{[w.PROCESS_NAME_ENV_PROP]:w.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:Un};return He||(t.out_file=Ee,t.error_file=Ee),t}a(Px,"generateNatsIngestServiceConfig");function Bx(){sr(),se.initSync();let e=Ae.join(qe,w.PROCESS_LOG_NAMES.CLUSTERING_REPLY_SERVICE),t={name:w.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE,script:w.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,exec_mode:"cluster",env:{[w.PROCESS_NAME_ENV_PROP]:w.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:Un};return He||(t.out_file=Ee,t.error_file=Ee),t}a(Bx,"generateNatsReplyServiceConfig");function vx(){sr(),se.initSync();let e=Ae.join(qe,w.PROCESS_LOG_NAMES.CLUSTERING_UPGRADE),t={name:w.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,script:w.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[w.PROCESS_NAME_ENV_PROP]:w.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:Un,autorestart:!1};return He||(t.out_file=Ee,t.error_file=Ee),t}a(vx,"generateClusteringUpgradeV4ServiceConfig");function Hx(){sr();let e=Ae.join(qe,w.PROCESS_LOG_NAMES.PM2),t={name:w.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:{[w.PROCESS_NAME_ENV_PROP]:w.PROCESS_DESCRIPTORS.RESTART_HDB},merge_logs:!0,out_file:e,error_file:e,instances:1,autorestart:!1,cwd:EN};return He||(t.out_file=Ee,t.error_file=Ee),{...t,script:yx}}a(Hx,"generateRestart");function qx(e){sr();let t=Ae.join(qe,w.PROCESS_LOG_NAMES.JOBS),r=Ae.join(Qc,"server/jobs"),s={name:`JOB-${e}`,exec_mode:"fork",env:{[w.PROCESS_NAME_ENV_PROP]:`JOB-${e}`},merge_logs:!0,out_file:t,error_file:t,instances:1,cwd:Un,autorestart:!1};return He||(s.out_file=Ee,s.error_file=Ee),{...s,script:Ae.join(r,"jobProcess.js")}}a(qx,"generateJobConfig");function Gx(){return{apps:[hN(),SN(),fN()]}}a(Gx,"generateAllServiceConfigs");TN.exports={generateAllServiceConfigs:Gx,generateIPCServerConfig:hN,generateHDBServerConfig:SN,generateCFServerConfig:fN,generateRestart:Hx,generateNatsHubServerConfig:Dx,generateNatsLeafServerConfig:Mx,generateNatsIngestServiceConfig:Px,generateNatsReplyServiceConfig:Bx,generateClusteringUpgradeV4ServiceConfig:vx,generateJobConfig:qx}});var ki=S((u3,CN)=>{"use strict";var P=T(),Xc=b(),Vi=KE(),Zc=at(),Fx=_e(),$=require("pm2"),Vx=require("fs-extra"),Ar=Jc(),ut=Y(),Or=I(),kx=Jc(),$x=bs(),xx=require("util"),RN=xx.promisify(require("child_process").exec),AN=require("path");CN.exports={start:Us,stop:jc,reload:pN,restart:NN,list:JE,describe:e_,connect:nr,kill:IN,startAllServices:eY,startService:zc,getUniqueServicesList:XE,restartAllServices:tY,stopAllServices:rY,isServiceRegistered:bN,reloadStopStart:QE,restartHdb:gN,deleteProcess:zx,configureLogRotate:iY,startClustering:wN,isHdbRestartRunning:jx,isClusteringRunning:oY,stopClustering:aY,reloadClustering:cY};var{PACKAGE_ROOT:Yx}=T(),Kx="2.7.0",ON=AN.join(Yx,"node_modules/pm2/bin/pm2"),Wx="Log rotate installed.",Qx="Error installing log rotate.",Jx="Log rotate updated.",Xx="Error updating log rotate.",Zx="The number of HarperDB processes running is different from the settings value. To restart and update the number HarperDB processes running you must stop and then start HarperDB";function nr(){return new Promise((e,t)=>{$.connect((r,s)=>{r&&t(r),e(s)})})}a(nr,"connect");function Us(e){return new Promise(async(t,r)=>{try{await nr()}catch(s){r(s)}$.start(e,(s,n)=>{s&&($.disconnect(),r(s)),$.disconnect(),t(n)})})}a(Us,"start");function jc(e){return new Promise(async(t,r)=>{try{await nr()}catch(s){r(s)}$.stop(e,(s,n)=>{s&&($.disconnect(),r(s)),$.delete(e,(i,o)=>{i&&($.disconnect(),r(s)),$.disconnect(),t(o)})})})}a(jc,"stop");function pN(e){return new Promise(async(t,r)=>{try{await nr()}catch(s){r(s)}$.reload(e,(s,n)=>{s&&($.disconnect(),r(s)),$.disconnect(),t(n)})})}a(pN,"reload");function NN(e){return new Promise(async(t,r)=>{try{await nr()}catch(s){r(s)}$.restart(e,(s,n)=>{s&&($.disconnect(),r(s)),$.disconnect(),t(n)})})}a(NN,"restart");function zx(e){return new Promise(async(t,r)=>{try{await nr()}catch(s){r(s)}$.delete(e,(s,n)=>{s&&($.disconnect(),r(s)),$.disconnect(),t(n)})})}a(zx,"deleteProcess");async function gN(){await Us(kx.generateRestart())}a(gN,"restartHdb");async function jx(){let e=await JE();for(let t in e)if(e[t].name===P.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}a(jx,"isHdbRestartRunning");function JE(){return new Promise(async(e,t)=>{try{await nr()}catch(r){t(r)}$.list((r,s)=>{r&&($.disconnect(),t(r)),$.disconnect(),e(s)})})}a(JE,"list");function e_(e){return new Promise(async(t,r)=>{try{await nr()}catch(s){r(s)}$.describe(e,(s,n)=>{s&&($.disconnect(),r(s)),$.disconnect(),t(n)})})}a(e_,"describe");function IN(){return new Promise(async(e,t)=>{try{await nr()}catch(r){t(r)}$.killDaemon((r,s)=>{r&&($.disconnect(),t(r)),$.disconnect(),e(s)})})}a(IN,"kill");async function eY(){try{await wN(),await Us(Ar.generateAllServiceConfigs())}catch(e){throw $.disconnect(),e}}a(eY,"startAllServices");async function zc(e){try{let t;switch(e=e.toLowerCase(),e){case P.PROCESS_DESCRIPTORS.IPC.toLowerCase():t=Ar.generateIPCServerConfig();break;case P.PROCESS_DESCRIPTORS.HDB.toLowerCase():t=Ar.generateHDBServerConfig();break;case P.PROCESS_DESCRIPTORS.CUSTOM_FUNCTIONS.toLowerCase():t=Ar.generateCFServerConfig();break;case P.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():t=Ar.generateNatsIngestServiceConfig();break;case P.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():t=Ar.generateNatsReplyServiceConfig();break;case P.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():t=Ar.generateNatsHubServerConfig(),await Us(t),await Vi.removeNatsConfig(e);return;case P.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():t=Ar.generateNatsLeafServerConfig(),await Us(t),await Vi.removeNatsConfig(e);return;case P.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():t=Ar.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await Us(t)}catch(t){throw $.disconnect(),t}}a(zc,"startService");async function XE(){try{let e=await JE(),t={};for(let r=0,s=e.length;r<s;r++){let n=e[r];t[n.name]===void 0&&(t[n.name]={name:n.name,exec_mode:n.pm2_env.exec_mode})}return t}catch(e){throw $.disconnect(),e}}a(XE,"getUniqueServicesList");async function tY(e=[]){try{let t=!1,r=await XE();for(let s=0,n=Object.values(r).length;s<n;s++){let i=Object.values(r)[s],o=i.name;e.includes(o)||(i.exec_mode==="cluster_mode"?o===P.PROCESS_DESCRIPTORS.HDB?t=!0:await QE(o):await NN(o))}t&&await QE(P.PROCESS_DESCRIPTORS.HDB)}catch(t){throw $.disconnect(),t}}a(tY,"restartAllServices");async function rY(){try{let e=await XE();for(let t=0,r=Object.values(e).length;t<r;t++){let s=Object.values(e)[t];await jc(s.name)}if(await IN(),ut.get(P.CONFIG_PARAMS.OPERATIONSAPI_FOREGROUND)===!0){let t=(await Vx.readFile(AN.join(ut.get(P.HDB_SETTINGS_NAMES.HDB_ROOT_KEY),P.FOREGROUND_PID_FILE))).toString();try{process.kill(t,"SIGTERM")}catch(r){Or.warn(`Error terminating foreground process: ${r}`)}}}catch(e){throw $.disconnect(),e}}a(rY,"stopAllServices");async function bN(e){return!Xc.isEmptyOrZeroLength(await e_(e))}a(bN,"isServiceRegistered");async function QE(e){let t=e===P.PROCESS_DESCRIPTORS.HDB?ut.get(P.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES):ut.get(P.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES),r=await e_(e),s=Xc.isEmptyOrZeroLength(r)?0:r.length;t!==s?e===P.PROCESS_DESCRIPTORS.HDB?Or.error(Zx):(await jc(e),await zc(e)):e===P.PROCESS_DESCRIPTORS.HDB?await gN():await pN(e)}a(QE,"reloadStopStart");function sY(){return new Promise(async(e,t)=>{try{await nr()}catch(r){t(r)}$.stop(P.PROCESS_DESCRIPTORS.PM2_LOGROTATE,(r,s)=>{r&&($.disconnect(),t(r)),$.disconnect(),e(s)})})}a(sY,"stopLogrotate");async function nY(){let{stdout:e,stderr:t}=await RN(`${process.platform==="win32"?"node":""} ${ON} install pm2-logrotate@${Kx}`);if(Or.debug(`loadLogRotate stdout: ${e}`),t)throw Or.error(Qx),t;Or.info(Wx)}a(nY,"installLogRotate");async function mN(){let e={max_size:ut.get(P.HDB_SETTINGS_NAMES.LOG_ROTATE_MAX_SIZE),retain:ut.get(P.HDB_SETTINGS_NAMES.LOG_ROTATE_RETAIN),compress:ut.get(P.HDB_SETTINGS_NAMES.LOG_ROTATE_COMPRESS),dateFormat:ut.get(P.HDB_SETTINGS_NAMES.LOG_ROTATE_DATE_FORMAT),rotateModule:ut.get(P.HDB_SETTINGS_NAMES.LOG_ROTATE_ROTATE_MODULE),workerInterval:ut.get(P.HDB_SETTINGS_NAMES.LOG_ROTATE_WORKER_INTERVAL),rotateInterval:ut.get(P.HDB_SETTINGS_NAMES.LOG_ROTATE_ROTATE_INTERVAL),TZ:ut.get(P.HDB_SETTINGS_NAMES.LOG_ROTATE_TIMEZONE)},t="";for(let n in e)t+=`${process.platform==="win32"?"node":""} ${ON} set pm2-logrotate:${n} ${e[n]}`,n!=="TZ"&&(t+=" && ");let{stdout:r,stderr:s}=await RN(t);if(Or.debug(`updateLogRotateConfig stdout: ${r}`),s)throw Or.error(Xx),s;Or.info(Jx)}a(mN,"updateLogRotateConfig");async function iY(){ut.initSync();let e=Xc.autoCastBoolean(ut.get(P.HDB_SETTINGS_NAMES.LOG_ROTATE)),t=await e_(P.PROCESS_DESCRIPTORS.PM2_LOGROTATE),r,s=!1;if(Xc.isEmptyOrZeroLength(t)||(s=!0,r=t[0].pm2_env.status),e&&!s){await nY(),await mN();return}if(e&&s){await Us(P.PROCESS_DESCRIPTORS.PM2_LOGROTATE),await mN();return}!e&&r===P.PM2_PROCESS_STATUSES.ONLINE&&await sY()}a(iY,"configureLogRotate");async function wN(){for(let t in P.CLUSTERING_PROCESSES){let r=P.CLUSTERING_PROCESSES[t];await zc(r)}await Zc.createWorkQueueStream(Fx.WORK_QUEUE_CONSUMER_NAMES),await Zc.updateNodeNameLocalStreams();let e=await $x.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===P.PRE_4_0_0_VERSION){Or.info("Starting clustering upgrade 4.0.0 process"),await zc(P.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0);break}}a(wN,"startClustering");async function aY(){for(let e in P.CLUSTERING_PROCESSES){let t=P.CLUSTERING_PROCESSES[e];await jc(t)}}a(aY,"stopClustering");async function oY(){for(let e in P.CLUSTERING_PROCESSES){let t=P.CLUSTERING_PROCESSES[e];if(await bN(t)===!1)return!1}return!0}a(oY,"isClusteringRunning");async function cY(){await Vi.generateNatsConfig(!0),await Zc.reloadNATSHub(),await Zc.reloadNATSLeaf(),await Vi.removeNatsConfig(P.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await Vi.removeNatsConfig(P.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}a(cY,"reloadClustering")});var td=S((l3,MN)=>{"use strict";var y=T(),K=I(),t_=b(),_Y=z_(),ZE=KE(),ed=at(),uY=_e(),UN=require("minimist"),{handleHDBError:zE,hdb_errors:lY}=D(),$i=ur(),{HTTP_STATUS_CODES:jE}=lY,G,LN=`Restarting HarperDB. This may take up to ${y.RESTART_TIMEOUT_MS/1e3} seconds.`,ys="HarperDB is currently restarting and must complete before another HarperDB restart can be initialized.",EY="Invalid service",dY="'service' is required",hY="Restarting all services",SY="Clustering is not enabled so cannot be restarted";MN.exports={stop:TY,restartProcesses:fY,restartService:yN};async function fY(){K.createLogFile(y.PROCESS_LOG_NAMES.CLI,y.PROCESS_DESCRIPTORS.STOP);try{G===void 0&&(G=ki());let e=_Y(Object.keys(y.CONFIG_PARAM_MAP),!0);t_.isEmptyOrZeroLength(Object.keys(e))||$i.updateConfigValue(void 0,void 0,e,!0,!0);let t=$i.getConfigFromFile(y.CONFIG_PARAMS.CLUSTERING_ENABLED),r=$i.getConfigFromFile(y.CONFIG_PARAMS.CUSTOMFUNCTIONS_ENABLED),s=UN(process.argv);if(!t_.isEmpty(s.service)){if(typeof s.service!="string"){let c=`Restart service argument expected a string but received: ${s.service}`;return K.error(c),c}let o=s.service.split(",");for(let c of o){let _=c.toLowerCase();if(_===y.HDB_PROC_DESCRIPTOR.toLowerCase()&&await G.isHdbRestartRunning()===!0){K.notify(ys),console.error(ys);continue}if(y.PROCESS_DESCRIPTORS_VALIDATE[_]===void 0){console.error(`Restart received unrecognized service command argument: ${_}`),K.error(`Restart received unrecognized service command argument: ${_}`);continue}let u=y.PROCESS_DESCRIPTORS_VALIDATE[_];if(console.log(`Restarting ${u}`),K.trace(`Restarting ${u}`),u===y.PROCESS_DESCRIPTORS.PM2_LOGROTATE)await G.configureLogRotate();else if(_.toLowerCase().includes("clustering"))await yn(_);else if(await G.isServiceRegistered(u))u===y.PROCESS_DESCRIPTORS.CUSTOM_FUNCTIONS&&!r?(await G.stop(y.PROCESS_DESCRIPTORS.CUSTOM_FUNCTIONS),K.trace(`Stopping ${y.PROCESS_DESCRIPTORS.CUSTOM_FUNCTIONS}`)):await yN({service:u});else if(u===y.PROCESS_DESCRIPTORS.CUSTOM_FUNCTIONS)if(r)await G.startService(u),K.trace(`Starting ${u}`);else{let l=`${u} is not enabled in harperdb-config.yaml and cannot be restarted.`;K.error(l),console.log(l)}else await G.startService(u);K.notify(`${u} successfully restarted.`)}return}if(await G.isHdbRestartRunning()===!0)return K.notify(ys),console.error(ys),ys;console.log(LN),t&&await DN();let n=await G.isServiceRegistered(y.PROCESS_DESCRIPTORS.CUSTOM_FUNCTIONS);r&&!n&&(await G.startService(y.PROCESS_DESCRIPTORS.CUSTOM_FUNCTIONS),K.trace(`Starting ${y.PROCESS_DESCRIPTORS.CUSTOM_FUNCTIONS}`));let i=[y.PROCESS_DESCRIPTORS.CLUSTERING_HUB,y.PROCESS_DESCRIPTORS.CLUSTERING_LEAF,y.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE,y.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE];return!r&&n&&(i.push(y.PROCESS_DESCRIPTORS.CUSTOM_FUNCTIONS),await G.stop(y.PROCESS_DESCRIPTORS.CUSTOM_FUNCTIONS),K.trace(`Stopping ${y.PROCESS_DESCRIPTORS.CUSTOM_FUNCTIONS}`)),await G.configureLogRotate(),K.notify(hY),await G.restartAllServices(i),LN}catch(e){let t=`There was an error restarting HarperDB. ${e}`;return K.error(t),t}}a(fY,"restartProcesses");async function yN(e){if(K.createLogFile(y.PROCESS_LOG_NAMES.CLI,y.PROCESS_DESCRIPTORS.STOP),G===void 0&&(G=ki()),t_.isEmpty(e.service))throw zE(new Error,dY,jE.BAD_REQUEST,void 0,void 0,!0);let t=e.service.toLowerCase();if(y.PROCESS_DESCRIPTORS_VALIDATE[t]===void 0)throw zE(new Error,EY,jE.BAD_REQUEST,void 0,void 0,!0);let r=$i.getConfigFromFile(y.CONFIG_PARAMS.CUSTOMFUNCTIONS_ENABLED),s=y.PROCESS_DESCRIPTORS_VALIDATE[t];if(s===y.PROCESS_DESCRIPTORS.HDB){if(await G.isHdbRestartRunning()===!0)return K.notify(ys),ys;await G.reloadStopStart(s)}else if(s===y.PROCESS_DESCRIPTORS.PM2_LOGROTATE)await G.configureLogRotate();else if(s.toLowerCase().includes("clustering"))await yn(s);else if(s===y.PROCESS_DESCRIPTORS.CUSTOM_FUNCTIONS||s===y.SERVICES.CUSTOM_FUNCTIONS){let i=await G.isServiceRegistered(s);if(r)i?(await G.reloadStopStart(s),K.trace(`Reloading ${s}`)):(await G.startService(s),K.trace(`Starting ${s}`));else if(!r&&i)await G.stop(s),K.trace(`Stopping ${s}`);else{let o=`${s} is not enabled in harperdb-config.yaml and cannot be restarted.`;throw K.error(o),zE(new Error,o,jE.BAD_REQUEST,void 0,void 0,!0)}}else await G.restart(s);let n=`Restarting ${s}`;return K.notify(n),n}a(yN,"restartService");async function TY(){K.createLogFile(y.PROCESS_LOG_NAMES.CLI,y.PROCESS_DESCRIPTORS.STOP);try{G===void 0&&(G=ki());let e=UN(process.argv);if(t_.isEmpty(e.service))console.log("Stopping HarperDB."),await G.stopAllServices(),K.notify("HarperDB has stopped");else{if(typeof e.service!="string"){let r=`Stop service argument expected a string but received: ${e.service}`;K.error(r),console.log(r)}let t=e.service.split(",");for(let r of t){let s=r.toLowerCase();if(y.PROCESS_DESCRIPTORS_VALIDATE[s]===void 0){K.error(`Stop received unrecognized service command argument: ${s}`);continue}s==="clustering"?await G.stopClustering():await G.stop(y.PROCESS_DESCRIPTORS_VALIDATE[s]);let n=`${y.PROCESS_DESCRIPTORS_VALIDATE[s]} successfully stopped.`;K.notify(n),console.log(n)}}}catch(e){throw console.error(e),e}}a(TY,"stop");async function DN(){await yn(y.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await yn(y.PROCESS_DESCRIPTORS.CLUSTERING_LEAF),await yn(y.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE),await yn(y.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE),await ed.updateNodeNameLocalStreams(),await ed.closeConnection()}a(DN,"restartAllClusteringServices");async function yn(e){e=y.PROCESS_DESCRIPTORS_VALIDATE[e.toLowerCase()];let t=$i.getConfigFromFile(y.CONFIG_PARAMS.CLUSTERING_ENABLED),r=e==="clustering",s=e==="clustering config",n=r?void 0:await G.isServiceRegistered(e),i=r||s?await G.isClusteringRunning():void 0;switch(!0){case s:if(!i){K.error(SY);break}await G.reloadClustering();break;case(r&&i&&!t):await G.stopClustering();break;case(r&&!i&&t):await G.startClustering();break;case(r&&i&&t):await DN();break;case(r&&!i&&!t):K.error(`${e} is not enabled in harperdb-config.yaml and cannot be restarted.`);break;case(n&&!t):await G.stop(e),K.trace(`Stopping ${e}`);break;case(!n&&t):e!==y.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE&&e!==y.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE&&await ZE.generateNatsConfig(!0,e),await G.startService(e),K.trace(`Starting ${e}`),e===y.PROCESS_DESCRIPTORS.CLUSTERING_LEAF&&await ed.createWorkQueueStream(uY.WORK_QUEUE_CONSUMER_NAMES);break;case(!n&&!t):K.error(`${e} is not enabled in harperdb-config.yaml and cannot be restarted.`);break;case(n&&t):e===y.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE||e===y.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE?await G.reload(e):(await ZE.generateNatsConfig(!0,e),await G.restart(e),await ZE.removeNatsConfig(e));break;default:K.error(`Error restarting ${e}`)}}a(yn,"restartClustering")});var xN=S((d3,$N)=>{"use strict";var E3=require("lodash"),Ze=T(),{handleHDBError:PN,hdb_errors:mY}=D(),{HDB_ERROR_MSGS:RY,HTTP_STATUS_CODES:AY}=mY,rd=I();$N.exports={getRolePermissions:pY};var Ds=Object.create(null),OY=a(e=>({key:e,perms:{}}),"perms_template_obj"),qN=a((e=!1)=>({describe:e,tables:{}}),"schema_perms_template"),GN=a((e=!1,t=!1,r=!1,s=!1)=>({[Ze.PERMS_CRUD_ENUM.READ]:e,[Ze.PERMS_CRUD_ENUM.INSERT]:t,[Ze.PERMS_CRUD_ENUM.UPDATE]:r,[Ze.PERMS_CRUD_ENUM.DELETE]:s}),"permissions_template"),sd=a((e=!1,t=!1,r=!1,s=!1,n=!1)=>({attribute_permissions:[],describe:e,...GN(t,r,s,n)}),"table_perms_template"),BN=a((e,t=GN())=>({attribute_name:e,describe:kN(t),[xi]:t[xi],[nd]:t[nd],[id]:t[id]}),"attr_perms_template"),vN=a((e,t=!1)=>({attribute_name:e,describe:t,[xi]:t}),"timestamp_attr_perms_template"),{READ:xi,INSERT:nd,UPDATE:id}=Ze.PERMS_CRUD_ENUM,FN=Object.values(Ze.PERMS_CRUD_ENUM),VN=[xi,nd,id];function pY(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[Ze.SYSTEM_SCHEMA_NAME],t=e.role;let s=JSON.stringify([e.__updatedtime__,r]);if(Ds[t]&&Ds[t].key===s)return Ds[t].perms;let n=NY(e,r);return Ds[t]?Ds[t].key=s:Ds[t]=OY(s),Ds[t].perms=n,n}catch(r){if(!e[Ze.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]||e[Ze.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]<Ze.PERMS_UPDATE_RELEASE_TIMESTAMP){let s=`Role permissions for role '${t}' must be updated to align with new structure from the 2.2.0 release.`;throw rd.error(s),rd.debug(r),PN(new Error,RY.OUTDATED_PERMS_TRANSLATION_ERROR,AY.BAD_REQUEST)}else{let s=`There was an error while translating role permissions for role: ${t}.
8
8
  ${r.stack}`;throw rd.error(s),PN(new Error)}}}a(pY,"getRolePermissions");function NY(e,t){let r=Object.create(null);r.super_user=!1;let s=e.permission;r[Ze.SYSTEM_SCHEMA_NAME]=s[Ze.SYSTEM_SCHEMA_NAME],r.structure_user=s.structure_user;let n=Array.isArray(e.permission.structure_user)||e.permission.structure_user===!0?e.permission.structure_user:[];return Object.keys(t).forEach(i=>{if(n===!0||n.indexOf(i)>-1){r[i]=gY(t[i]);return}r[i]=qN(),s[i]?Object.keys(t[i]).forEach(o=>{if(s[i].tables[o]){let c=s[i].tables[o],_=t[i][o],u=IY(c,_);r[i].describe||FN.forEach(l=>{u[l]&&(r[i].describe=!0)}),r[i].tables[o]=u}else r[i].tables[o]=sd()}):Object.keys(t[i]).forEach(o=>{r[i].tables[o]=sd()})}),r}a(NY,"translateRolePermissions");function gY(e){let t=qN(!0);return Object.keys(e).forEach(r=>{t.tables[r]=sd(!0,!0,!0,!0,!0)}),t}a(gY,"createStructureUserPermissions");function IY(e,t){let{attribute_permissions:r}=e;if(r.length>0){let n=Object.assign({},e);n.attribute_permissions=[];let i=r.reduce((u,l)=>{let{attribute_name:E}=l,d=l;return Ze.TIME_STAMP_NAMES.includes(E)&&(d=vN(E,l[xi])),u[E]=d,u},{}),o=t[Ze.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_HASH_ATTRIBUTE_KEY],c=!!i[o],_=BN(o);return t.attributes.forEach(({attribute:u})=>{if(i[u]){let l=i[u];l.describe=kN(l),n.attribute_permissions.push(l),c||bY(l,_)}else if(u!==o){let l;Ze.TIME_STAMP_NAMES.includes(u)?l=vN(u):l=BN(u),n.attribute_permissions.push(l)}}),c||n.attribute_permissions.push(_),n.describe=HN(n),n}else return e.describe=HN(e),e}a(IY,"getTableAttrPerms");function HN(e){return FN.filter(t=>e[t]).length>0}a(HN,"getSchemaTableDescribePerm");function kN(e){return VN.filter(t=>e[t]).length>0}a(kN,"getAttributeDescribePerm");function bY(e,t){VN.forEach(r=>{e[r]&&!t[r]&&(t[r]=!0,t.describe=!0)})}a(bY,"checkForHashPerms")});var ZN=S((h3,XN)=>{"use strict";var Te=require("joi"),YN=require("fs-extra"),KN=require("path"),Dn=de(),WN=Y(),QN=T(),JN=I(),{hdb_errors:wY}=D(),{HDB_ERROR_MSGS:lt}=wY,Zr=/^[a-zA-Z0-9-_]+$/;XN.exports={getDropCustomFunctionValidator:LY,setCustomFunctionValidator:UY,addCustomFunctionProjectValidator:yY,dropCustomFunctionProjectValidator:DY,packageCustomFunctionProjectValidator:MY,deployCustomFunctionProjectValidator:PY};function Yi(e,t,r){try{let s=WN.get(QN.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY),n=KN.join(s,t);return YN.existsSync(n)?e?t:r.message(lt.PROJECT_EXISTS):e?r.message(lt.NO_PROJECT):t}catch(s){return JN.error(s),r.message(lt.VALIDATION_ERR)}}a(Yi,"checkProjectExists");function CY(e,t,r,s){try{let n=WN.get(QN.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY),i=KN.join(n,e,t,r+".js");return YN.existsSync(i)?r:s.message(lt.NO_FILE)}catch(n){return JN.error(n),s.message(lt.VALIDATION_ERR)}}a(CY,"checkFileExists");function LY(e){let t=Te.object({project:Te.string().pattern(Zr).custom(Yi.bind(null,!0)).required().messages({"string.pattern.base":lt.BAD_PROJECT_NAME}),type:Te.string().valid("helpers","routes").required(),file:Te.string().pattern(Zr).custom(CY.bind(null,e.project,e.type)).required().messages({"string.pattern.base":lt.BAD_FILE_NAME})});return Dn.validateBySchema(e,t)}a(LY,"getDropCustomFunctionValidator");function UY(e){let t=Te.object({project:Te.string().pattern(Zr).custom(Yi.bind(null,!0)).required().messages({"string.pattern.base":lt.BAD_PROJECT_NAME}),type:Te.string().valid("helpers","routes").required(),file:Te.string().pattern(Zr).required().messages({"string.pattern.base":lt.BAD_FILE_NAME}),function_content:Te.string().required()});return Dn.validateBySchema(e,t)}a(UY,"setCustomFunctionValidator");function yY(e){let t=Te.object({project:Te.string().pattern(Zr).custom(Yi.bind(null,!1)).required().messages({"string.pattern.base":lt.BAD_PROJECT_NAME})});return Dn.validateBySchema(e,t)}a(yY,"addCustomFunctionProjectValidator");function DY(e){let t=Te.object({project:Te.string().pattern(Zr).custom(Yi.bind(null,!0)).required().messages({"string.pattern.base":lt.BAD_PROJECT_NAME})});return Dn.validateBySchema(e,t)}a(DY,"dropCustomFunctionProjectValidator");function MY(e){let t=Te.object({project:Te.string().pattern(Zr).custom(Yi.bind(null,!0)).required().messages({"string.pattern.base":lt.BAD_PROJECT_NAME}),skip_node_modules:Te.boolean()});return Dn.validateBySchema(e,t)}a(MY,"packageCustomFunctionProjectValidator");function PY(e){let t=Te.object({project:Te.string().pattern(Zr).required().messages({"string.pattern.base":lt.BAD_PROJECT_NAME}),payload:Te.string().required().messages({"string.pattern.base":lt.BAD_PACKAGE})});return Dn.validateBySchema(e,t)}a(PY,"deployCustomFunctionProjectValidator")});var cd=S((S3,eg)=>{"use strict";var Ce=require("fs-extra"),r_=require("fast-glob"),ne=require("path"),zN=require("tar-fs"),jN=require("uuid").v4,Ki=require("normalize-path"),Ms=ZN(),Le=I(),Rt=T(),At=Y(),{PACKAGE_ROOT:BY}=T(),{handleHDBError:ze,hdb_errors:vY}=D(),{HDB_ERROR_MSGS:zr,HTTP_STATUS_CODES:je}=vY,HY=ne.join(BY,"custom_function_template"),ad=ne.join(At.get(Rt.HDB_SETTINGS_NAMES.HDB_ROOT_KEY),"tmp");function od(){let e=At.get(Rt.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY);if(!(e==="true"||e===!0||e==="TRUE"))throw ze(new Error,zr.NOT_ENABLED,je.BAD_REQUEST,void 0,void 0,!0)}a(od,"isCFEnabled");function qY(){Le.trace("getting custom api status");let e={};try{e={is_enabled:At.get(Rt.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY),port:At.get(Rt.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY),directory:At.get(Rt.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY)}}catch(t){throw ze(new Error,zr.FUNCTION_STATUS,je.INTERNAL_SERVER_ERROR,Le.ERR,t)}return e}a(qY,"customFunctionsStatus");function GY(){Le.trace("getting custom api endpoints");let e={},t=At.get(Rt.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY);try{r_.sync(Ki(`${t}/*`),{onlyDirectories:!0}).forEach(s=>{let n=s.split("/").pop();e[n]={routes:r_.sync(Ki(`${s}/routes/*.js`)).map(i=>i.split("/").pop().split(".js")[0]),helpers:r_.sync(Ki(`${s}/helpers/*.js`)).map(i=>i.split("/").pop().split(".js")[0]),static:Ce.existsSync(Ki(`${s}/static`))&&r_.sync(Ki(`${s}/static/**/*`)).length}})}catch(r){throw ze(new Error,zr.GET_FUNCTIONS,je.INTERNAL_SERVER_ERROR,Le.ERR,r)}return e}a(GY,"getCustomFunctions");function FY(e){e.project&&(e.project=ne.parse(e.project).name),e.file&&(e.file=ne.parse(e.file).name);let t=Ms.getDropCustomFunctionValidator(e);if(t)throw ze(t,t.message,je.BAD_REQUEST);Le.trace("getting custom api endpoint file content");let r=At.get(Rt.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY),{project:s,type:n,file:i}=e,o=ne.join(r,s,n,i+".js");try{return Ce.readFileSync(o,{encoding:"utf8"})}catch(c){throw ze(new Error,zr.GET_FUNCTION,je.INTERNAL_SERVER_ERROR,Le.ERR,c)}}a(FY,"getCustomFunction");function VY(e){od(),e.project&&(e.project=ne.parse(e.project).name),e.file&&(e.file=ne.parse(e.file).name);let t=Ms.setCustomFunctionValidator(e);if(t)throw ze(t,t.message,je.BAD_REQUEST);Le.trace("setting custom function file content");let r=At.get(Rt.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY),{project:s,type:n,file:i,function_content:o}=e;try{return Ce.outputFileSync(ne.join(r,s,n,i+".js"),o),`Successfully updated custom function: ${i}.js`}catch(c){throw ze(new Error,zr.SET_FUNCTION,je.INTERNAL_SERVER_ERROR,Le.ERR,c)}}a(VY,"setCustomFunction");function kY(e){e.project&&(e.project=ne.parse(e.project).name),e.file&&(e.file=ne.parse(e.file).name);let t=Ms.getDropCustomFunctionValidator(e);if(t)throw ze(t,t.message,je.BAD_REQUEST);Le.trace("dropping custom function file");let r=At.get(Rt.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY),{project:s,type:n,file:i}=e;try{return Ce.unlinkSync(ne.join(r,s,n,i+".js")),`Successfully deleted custom function: ${i}.js`}catch(o){throw ze(new Error,zr.DROP_FUNCTION,je.INTERNAL_SERVER_ERROR,Le.ERR,o)}}a(kY,"dropCustomFunction");function $Y(e){od(),e.project&&(e.project=ne.parse(e.project).name);let t=Ms.addCustomFunctionProjectValidator(e);if(t)throw ze(t,t.message,je.BAD_REQUEST);Le.trace("adding custom function project");let r=At.get(Rt.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY),{project:s}=e;try{let n=ne.join(r,s);return Ce.mkdirSync(n,{recursive:!0}),Ce.copySync(HY,n),`Successfully created custom function project: ${s}`}catch(n){throw ze(new Error,zr.ADD_FUNCTION,je.INTERNAL_SERVER_ERROR,Le.ERR,n)}}a($Y,"addCustomFunctionProject");function xY(e){e.project&&(e.project=ne.parse(e.project).name);let t=Ms.dropCustomFunctionProjectValidator(e);if(t)throw ze(t,t.message,je.BAD_REQUEST);Le.trace("dropping custom function project");let r=At.get(Rt.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY),{project:s}=e;try{let n=ne.join(r,s);return Ce.rmSync(n,{recursive:!0}),`Successfully deleted project: ${s}`}catch(n){throw ze(new Error,zr.DROP_FUNCTION_PROJECT,je.INTERNAL_SERVER_ERROR,Le.ERR,n)}}a(xY,"dropCustomFunctionProject");async function YY(e){e.project&&(e.project=ne.parse(e.project).name);let t=Ms.packageCustomFunctionProjectValidator(e);if(t)throw ze(t,t.message,je.BAD_REQUEST);Le.trace("packaging custom function project");let r=At.get(Rt.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY),{project:s}=e,n=ne.join(r,s),i=jN();if(!Ce.existsSync(n)){let l=`Unable to locate custom function project: ${s}`;throw Le.error(l),l}Ce.ensureDirSync(ad);let c=ne.join(ad,`${i}.tar`),_={};(e.skip_node_modules===!0||e.skip_node_modules==="true")&&(_={ignore:l=>l.includes(ne.join(n,"node_modules"))}),zN.pack(n,_).pipe(Ce.createWriteStream(c)),await new Promise(l=>setTimeout(l,2e3));let u=Ce.readFileSync(c,{encoding:"base64"});return Ce.unlinkSync(c),{project:s,payload:u,file:c}}a(YY,"packageCustomFunctionProject");async function KY(e){od(),e.project&&(e.project=ne.parse(e.project).name);let t=Ms.deployCustomFunctionProjectValidator(e);if(t)throw ze(t,t.message,je.BAD_REQUEST);Le.trace("deploying custom function project");let r=At.get(Rt.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY),{project:s,payload:n,file:i}=e,o=ne.join(r,s);await Ce.ensureDir(o);let c,_;do c=ne.join(ad,jN()+".tar"),_=await Ce.pathExists(c);while(_);await Ce.outputFile(c,n,{encoding:"base64"});let u=Ce.createReadStream(c);return u.pipe(zN.extract(o)),await new Promise(l=>u.on("end",l)),await Ce.unlink(c),`Successfully deployed project: ${s}`}a(KY,"deployCustomFunctionProject");eg.exports={customFunctionsStatus:qY,getCustomFunctions:GY,getCustomFunction:FY,setCustomFunction:VY,dropCustomFunction:kY,addCustomFunctionProject:$Y,dropCustomFunctionProject:xY,packageCustomFunctionProject:YY,deployCustomFunctionProject:KY}});var _d=S((f3,rg)=>{"use strict";var ir=require("joi"),tg=de();rg.exports={readTransactionLogValidator:WY,deleteTransactionLogsBeforeValidator:QY};function WY(e){let t=ir.object({schema:ir.string().required(),table:ir.string().required(),from:ir.date().timestamp(),to:ir.date().timestamp(),limit:ir.number().min(1)});return tg.validateBySchema(e,t)}a(WY,"readTransactionLogValidator");function QY(e){let t=ir.object({schema:ir.string().required(),table:ir.string().required(),timestamp:ir.date().timestamp().required()});return tg.validateBySchema(e,t)}a(QY,"deleteTransactionLogsBeforeValidator")});var n_=S((T3,og)=>{"use strict";var ud=T(),s_=at(),sg=b(),ng=Y(),ig=Hr(),{handleHDBError:Mn,hdb_errors:JY}=D(),{HTTP_STATUS_CODES:Pn}=JY,{readTransactionLogValidator:XY,deleteTransactionLogsBeforeValidator:ZY}=_d(),ag="This operation relies on clustering and cannot run with it disable.",zY="Logs successfully deleted from transaction log.",jY="All logs successfully deleted from transaction log.";og.exports={readTransactionLog:eK,deleteTransactionLogsBefore:tK};async function eK(e){let t=XY(e);if(t)throw Mn(t,t.message,Pn.BAD_REQUEST,void 0,void 0,!0);if(!ng.get(ud.CONFIG_PARAMS.CLUSTERING_ENABLED))throw Mn(new Error,ag,Pn.NOT_FOUND,void 0,void 0,!0);let{schema:r,table:s}=e,n=sg.checkSchemaTableExist(r,s);if(n)throw Mn(new Error,n,Pn.NOT_FOUND,void 0,void 0,!0);let i=ig.createNatsTableStreamName(r,s),o=await s_.viewStream(i,parseInt(e.from),e.limit),c=[];for(let _=0,u=o.length;_<u;_++){let l=o[_],E=Math.floor(l?.nats_timestamp/1e6);if(e.to&&E>e.to)break;let d={operation:l?.entry?.operation,user:l?.entry?.__origin?.user,timestamp:E,records:l?.entry?.records};l?.entry?.operation===ud.OPERATIONS_ENUM.DELETE&&(d.hash_values=l?.entry?.hash_values),c.push(d)}return c}a(eK,"readTransactionLog");async function tK(e){let t=ZY(e);if(t)throw Mn(t,t.message,Pn.BAD_REQUEST,void 0,void 0,!0);if(!ng.get(ud.CONFIG_PARAMS.CLUSTERING_ENABLED))throw Mn(new Error,ag,Pn.NOT_FOUND,void 0,void 0,!0);let{schema:r,table:s,timestamp:n}=e,i=sg.checkSchemaTableExist(r,s);if(i)throw Mn(new Error,i,Pn.NOT_FOUND,void 0,void 0,!0);let o=ig.createNatsTableStreamName(r,s),{jsm:c}=await s_.getNATSReferences(),_=await s_.getStreamInfo(o),u=new Date(_.state.first_ts).getTime();if(n<=u)return`No transactions exist before: ${n}`;let l=zY,E,d=new Date(_.state.last_ts).getTime();return n>d?(E=_.state.last_seq+1,l=jY):E=(await s_.viewStream(o,parseInt(n),1))[0].nats_sequence,await c.streams.purge(o,{seq:E}),l}a(tK,"deleteTransactionLogsBefore")});var Ed=S((m3,Tg)=>{"use strict";var i_=require("joi"),a_=require("path"),cg=require("fs-extra"),{exec:rK}=require("child_process"),sK=require("util"),_g=sK.promisify(rK),nK=T(),{handleHDBError:Bn,hdb_errors:iK}=D(),{HTTP_STATUS_CODES:vn}=iK,ug=Y(),aK=de(),o_=I();ug.initSync();var ld=ug.get(nK.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY),lg="npm install --omit=dev --json",oK=`${lg} --dry-run`;Tg.exports={installModules:cK,auditModules:_K};async function Eg(e,t=void 0){let{stdout:r,stderr:s}=await _g(e,{cwd:t});if(s)throw new Error(s.replace(`