harperdb 4.3.29 → 4.3.30

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -6,7 +6,7 @@ Caused by:`))):typeof _=="object"?n+=JSON.stringify(_):n+=_,c<i&&(n+=" ")}return
6
6
  `).slice(1)){s=s.trim();let[i]=s.split(" ",1),o=s.slice(i.length+1).trim();t[i]===void 0&&(t[i]={}),t[i][r]=o}}))}catch(r){throw r}return Object.entries(t).filter(([,r])=>r.comm&&r.args&&r.ppid&&r.uid&&r["%cpu"]&&r["%mem"]&&r.args.includes(e)).map(([r,n])=>({pid:Number.parseInt(r,10),name:wk.basename(n.comm),cmd:n.args,ppid:Number.parseInt(n.ppid,10),uid:Number.parseInt(n.uid,10),cpu:Number.parseFloat(n["%cpu"]),memory:Number.parseFloat(n["%mem"])}))}a(Mk,"findPs")});var dt=g((Hoe,DO)=>{"use strict";var Pk="__dbis__",Uk="__txns__",vk="__environment_name__",Bk="__dbi_defintion__",Hk={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"},xk=["__createdtime__","__updatedtime__"],Gk="\uFFFF",CO={TIMESTAMP:"timestamp",HASH_VALUE:"hash_value",USER_NAME:"user_name"},Fk=Object.values(CO);DO.exports={AUDIT_STORE_NAME:Uk,INTERNAL_DBIS_NAME:Pk,DBI_DEFINITION_NAME:Bk,SEARCH_TYPES:Hk,TIMESTAMP_NAMES:xk,MAX_SEARCH_KEY_LENGTH:256,ENVIRONMENT_NAME_KEY:vk,TRANSACTIONS_DBI_NAMES_ENUM:CO,TRANSACTIONS_DBIS:Fk,OVERFLOW_MARKER:Gk}});var vr=g((xoe,GO)=>{"use strict";var LO=P(),MO=dt(),PO={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},UO=a(e=>`${e} Check logs and try again.`,"CHECK_LOGS_WRAPPER"),vO={500:UO("There was an error processing your request."),400:"Invalid request"},qk=vO[PO.INTERNAL_SERVER_ERROR],kk={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.`},Vk={CONFIG_VALIDATION:e=>`HarperDB config file validation error: ${e}`},$k={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"},Yk={BASE_PATH_REQUIRED:"base_path is required",DESTINATION_PATH_REQUIRED:"destination_path is required",ENV_NAME_REQUIRED:"env_name is required",INVALID_BASE_PATH:"invalid base_path",INVALID_DESTINATION_PATH:"invalid destination_path",INVALID_ENVIRONMENT:"invalid environment",ENV_REQUIRED:"env is required",DBI_NAME_REQUIRED:"dbi_name is required",DBI_DOES_NOT_EXIST:"dbi does not exist",HASH_ATTRIBUTE_REQUIRED:"hash_attribute is required",ID_REQUIRED:"id is required",IDS_REQUIRED:"ids is required",IDS_MUST_BE_ITERABLE:"ids must be iterable",FETCH_ATTRIBUTES_REQUIRED:"fetch_attributes is required",FETCH_ATTRIBUTES_MUST_BE_ARRAY:"fetch_attributes must be an array",ATTRIBUTE_REQUIRED:"attribute is required",SEARCH_VALUE_REQUIRED:"search_value is required",SEARCH_VALUE_TOO_LARGE:"search_value is too long",WRITE_ATTRIBUTES_REQUIRED:"write_attributes is required",WRITE_ATTRIBUTES_MUST_BE_ARRAY:"write_attributes must be an array",RECORDS_REQUIRED:"records is required",RECORDS_MUST_BE_ARRAY:"records must be an array",CANNOT_CREATE_INTERNAL_DBIS_NAME:`cannot create a dbi named ${MO.INTERNAL_DBIS_NAME}`,CANNOT_DROP_INTERNAL_DBIS_NAME:`cannot drop a dbi named ${MO.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"},Kk={ATTR_NAME_LENGTH_ERR:e=>`transaction aborted due to attribute name ${e} being too long. Attribute names cannot be longer than ${LO.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 ${LO.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"},BO={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"},Wk={DEFAULT_INVALID_REQUEST:"Invalid request",OP_AUTH_PERMS_ERROR:"This operation is not authorized due to role restrictions and/or invalid database items",OP_IS_SU_ONLY:e=>`Operation '${e}' is restricted to 'super_user' roles`,OP_NOT_FOUND:e=>`Operation '${e}' not found`,SYSTEM_TIMESTAMP_PERMS_ERR:"Internal timestamp attributes - '__createdtime_' and '__updatedtime__' - cannot be inserted to or updated by HDB users.",UNKNOWN_OP_AUTH_ERROR:(e,t,r)=>`There was an error authorizing ${e} op on table '${t}.${r}'`,USER_HAS_NO_PERMS:e=>`User ${e} has no role or permissions. Please assign the user a valid role.`,DROP_SYSTEM:"The 'system' database, tables and records are used internally by HarperDB and cannot be updated or removed."},Qk={ATTR_PERM_MISSING:(e,t)=>`${e.toUpperCase()} attribute permission missing for '${t}'`,ATTR_PERM_MISSING_NAME:"Permission object in 'attribute_permission' missing an 'attribute_name'",ATTR_PERM_NOT_BOOLEAN:(e,t)=>`${e.toUpperCase()} attribute permission for '${t}' must be a boolean`,ATTR_PERMS_ARRAY_MISSING:"Missing 'attribute_permissions' array",ATTR_PERMS_NOT_ARRAY:"Value for 'attribute_permissions' must be an array",INVALID_ATTRIBUTE_IN_PERMS:e=>`Invalid attribute '${e}' in 'attribute_permissions'`,INVALID_PERM_KEY:e=>`Invalid table permission key value '${e}'`,INVALID_ATTR_PERM_KEY:e=>`Invalid attribute permission key value '${e}'`,INVALID_ROLE_JSON_KEYS:e=>`Invalid ${e.length>1?"keys":"key"} in JSON body - '${e.join("', '")}'`,MISMATCHED_TABLE_ATTR_PERMS:e=>`You have a conflict with TABLE permissions for '${e}' being false and ATTRIBUTE permissions being true`,OUTDATED_PERMS_TRANSLATION_ERROR:"This instance was recently upgraded and uses our new role permissions structure. Please login to this instance in HarperDB Studio, go to 'Roles', and click 'Update Role Permission' for all standard roles to migrate them to the new structure.",ROLE_ALREADY_EXISTS:e=>`A role with name '${e}' already exists`,ROLE_NOT_FOUND:"Role not found",ROLE_PERMS_ERROR:"Errors in the role permissions JSON provided",SCHEMA_PERM_ERROR:e=>`Your role does not have permission to view database metadata for '${e}'`,SCHEMA_TABLE_PERM_ERROR:(e,t)=>`Your role does not have permission to view database.table metadata for '${e}.${t}'`,SU_ROLE_MISSING_ERROR:"Missing 'super_user' key/value in permission set",SU_CU_ROLE_BOOLEAN_ERROR:e=>`Value for '${e}' permission must be a boolean`,STRUCTURE_USER_ROLE_TYPE_ERROR:e=>`Value for '${e}' permission must be a boolean or Array`,SU_CU_ROLE_NO_PERMS_ALLOWED:e=>`Roles with '${e}' set to true cannot have other permissions set.`,SU_CU_ROLE_COMBINED_ERROR:"Roles cannot have both 'super_user' and 'cluster_user' values included in their permissions set.",TABLE_PERM_MISSING:e=>`Missing table ${e.toUpperCase()} permission`,TABLE_PERM_NOT_BOOLEAN:e=>`Table ${e.toUpperCase()} permission must be a boolean`},zk={ATTR_NOT_FOUND:(e,t,r)=>`Attribute '${r}' does not exist on '${e}.${t}'`,ATTR_EXISTS_ERR:(e,t,r)=>`Attribute '${r}' already exists in ${e}.${t}'`,DESCRIBE_ALL_ERR:"There was an error during describeAll. Please check the logs and try again.",INVALID_TABLE_ERR:e=>`Invalid table ${JSON.stringify(e)}`,SCHEMA_NOT_FOUND:e=>`database '${e}' does not exist`,SCHEMA_EXISTS_ERR:e=>`database '${e}' already exists`,TABLE_EXISTS_ERR:(e,t)=>`Table '${t}' already exists in '${e}'`,SCHEMA_REQUIRED_ERR:"database is required",TABLE_NOT_FOUND:(e,t)=>`Table '${e}.${t}' does not exist`,TABLE_REQUIRED_ERR:"table is required"},Jk={OUTER_JOIN_TRANSLATION_ERROR:"There was an error translating the final SQL outer join data."},Xk={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`},HO={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.`},xO={INVALID_ITC_DATA_TYPE:"Invalid ITC event data type, must be an object",MISSING_TYPE:"ITC event missing 'type'",MISSING_MSG:"ITC event missing 'message'",MISSING_ORIGIN:"ITC event message missing 'originator' property",INVALID_EVENT:e=>`ITC server received invalid event type: ${e}`},jk={FUNCTION_STATUS:"Error getting custom function status, check the log for more details",GET_FUNCTIONS:"Error getting custom functions, check the log for more details",GET_FUNCTION:"Error getting custom function, check the log for more details",SET_FUNCTION:"Error setting custom function, check the log for more details",NO_PROJECT:"Project does not exist. Create one using 'add_custom_function_project'",PROJECT_EXISTS:"Project already exists",VALIDATION_ERR:"Error validating request, check the log for more details",NO_FILE:"File does not exist",BAD_FILE_NAME:"File name can only contain alphanumeric, dash and underscore characters",BAD_PROJECT_NAME:"Project name can only contain alphanumeric, dash and underscores characters",BAD_PACKAGE:"Packaged project must be base64-encoded tar file of project directory",DROP_FUNCTION:"Error dropping custom function, check the log for more details",ADD_FUNCTION:"Error adding custom function project, check the log for more details",DROP_FUNCTION_PROJECT:"Error dropping custom function project, check the log for more details",BAD_FILE_PATH:"Filepath must be valid, and contain the name of the tarball you wish to write",NOT_ENABLED:"Custom functions is not enabled, to enable set fastifyRoutes enabled to true in hdb/harperdb-config.yaml file."},Zk={CLUSTERING_NOT_ENABLED:"Clustering must be enabled to perform this operation."},eV={...BO,...$k,...kk,...Wk,...Qk,...zk,...Jk,...Xk,...Kk,...HO,...xO,...jk,...Zk,...Vk};GO.exports={CHECK_LOGS_WRAPPER:UO,HDB_ERROR_MSGS:eV,DEFAULT_ERROR_MSGS:vO,DEFAULT_ERROR_RESP:qk,HTTP_STATUS_CODES:PO,LMDB_ERRORS_ENUM:Yk,AUTHENTICATION_ERROR_MSGS:BO,VALIDATION_ERROR_MSGS:HO,ITC_ERRORS:xO}});var se=g((Foe,kO)=>{"use strict";var qo=vr(),tV=K(),rV=P(),c_=class extends Error{static{a(this,"HdbError")}constructor(t,r,n,s,i){super(),Error.captureStackTrace(this,FO),this.statusCode=n||qo.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR,this.http_resp_msg=r||(qo.DEFAULT_ERROR_MSGS[n]?qo.DEFAULT_ERROR_MSGS[n]:qo.DEFAULT_ERROR_MSGS[qo.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR]),this.message=t.message?t.message:this.http_resp_msg,this.type=t.name,s&&(this.logLevel=s),typeof this.message!="string"&&(this.stack=t.stack),i&&tV[s](i)}},Uh=class extends Error{static{a(this,"ClientError")}constructor(t,r){if(t instanceof Error)return t.statusCode=r||400,t;super(t),this.statusCode=r||400}},vh=class extends Error{static{a(this,"ServerError")}constructor(t,r){super(t),this.statusCode=r||500}};function FO(e,t,r,n=rV.LOG_LEVELS.ERROR,s=null,i=!1){if(qO(e))return e;let o=new c_(e,t,r,n,s);return i&&delete o.stack,o}a(FO,"handleHDBError");function qO(e){return e.__proto__.constructor.name===c_.name}a(qO,"isHDBError");kO.exports={isHDBError:qO,handleHDBError:FO,ClientError:Uh,ServerError:vh,hdb_errors:qo}});var $O=g((koe,VO)=>{"use strict";var nV={key:"-----BEGIN RSA PRIVATE KEY-----\rMIIEowIBAAKCAQEArBFJQRfFiJku/KwhV1Ssp7cX61vvuKmd4Rp6A9jB2QLgx8nj\r/+Xhp2hPRkISnOA8BuAxr4dMD9syGJwX4kNy9mbZ5Q0fWZCiEGBpVcU1J+k+N5K4\rSuZ2SqgxeN2IN2RLzt3GyQY4imcdHgNv7aHoXUrEwBx0MeYEw3IIDXtrYKCR2D8I\rvWBfwMUgWa24G8lpWILWA5hd9srRz9NxlAiHSjhbgT7B0xruEpHRCHSyKjvaIJVt\rWBR+amejYsAKVrD/hgrqjsA1123Y6++YqvU6vwg64xhS2kz5r3dkNKhvwbWgpZdI\rIaRvsiB77f4kLGo0vi8RFgJ1ZRjGg3RRK2w1LQIDAQABAoIBAQCEOmh78EOpnGZC\rYBjjHrvrysVD5gvLcfVUtl8Ls7gMB60re1eOIF+PoZZCHKZnDd6zPfiQtj1adg0C\rYnnsM/8VoaZS4gm0b3RLd3ubIQifWhuo40RissY2yxfxlPSH9LhZCY8ojnJG0cTL\resK579E8WCfopjUY33XLqEbN7Ylv39J+DSqInjqV3efJZUa+HqUJ98VxxzodcKMD\rP3bwUU4gHoSSp4pAsOFH5sQhaIWH1IcNjrAwpee2cJQuh4G157RRIuuUpagtaEG/\rXJIiAyBguJyu3JQFnIBQF01N5+omJgXYJ1L0m54543/iIRThmF3zDCDgCyUzmOk+\rH6As9fv1AoGBANOpOtOZLSAScjGsgJamT3ceJ2wCa86g2j8Oxu8lJUmUp5s3tA0v\rBFW5O3S4KR1EXwkLMBUMrfFM8YvzHWxsXBI6XV8azGLvyqPHxr65OhmpGYkGZMXu\rn9okgjkqlewnY2I073gvyK7ppX51UL5y9fF1vlsk+UlW+Rgx/vMHbdcjAoGBANAc\rxRUsxs4QJpbS4zD3JOkHjr24a97TrS3kCybAHUMpR2NrEHPZw9zex0/aphOJUHfL\rIMkOZdpfDqMfxWy4FAEmqBEMkO2SB+h0Wp4P+qp81ax4vGFiB0cD3wtixr11U1tt\rlZ/ZTdv4VDpDFNK1KaplhTDeyuCjeYfS3/GJia9vAoGAcOsAgjBevZR5rXx84WH6\rVO8WUu37u7FenXNxt9VWTinrPMh72uixZFY8nOk+rely1e1NCn3IMko9Ns9NbDFm\r8SaH95vhXArXTYbfxZIlp9jp0YtCqcHDL+p4Oq04bFMbFyJseu7rHj1x18QYfnHw\rOY/6LL/N6k1m+Hx7qgXVmIcCgYB/w0nTCBw84XlvWqSTqQaF8VfWbWP79mP5KmkW\rLxdH5g2noVEGbohqDnK6OXd/wusdwByukiJBf94Skyy25AOT+VFwthA7aU1ljhkb\rtJ+lDuJ28eBkwLPLCzthWBC+u0qjdJFJAzVjd/7tjcU43nNn4s90AzL12iaAFhvZ\rwyA+DQKBgGc/4cdyGJ3YkcA8150gQBawgJZ7q8V1JND87ggWA8wnK3cHn7rMZQl2\r3emDp9HEFXFex5dbGDDqZFAoesZCDxjknIn9oNfW4PvaWS8q7b6ZKLZG1p03Pu7/\rtYaD0kPbo0kysfFT/co+NgHbdykvIyboomfGdNLTUjYuy6lpwpvs\r-----END RSA PRIVATE KEY-----\r".replace(/\r/g,`\r
7
7
  `),cert:"-----BEGIN CERTIFICATE-----\rMIIDXDCCAkSgAwIBAgIFNTE4MzQwDQYJKoZIhvcNAQELBQAwXTEXMBUGA1UEAxMO\rSGFycGVyREIsIEluYy4xCzAJBgNVBAYTAlVTMQswCQYDVQQIEwJDTzEPMA0GA1UE\rBxMGRGVudmVyMRcwFQYDVQQKEw5IYXJwZXJEQiwgSW5jLjAeFw0yMjAzMTEyMzAz\rNDlaFw0yNzAzMTAyMzAzNDlaMF0xFzAVBgNVBAMTDkhhcnBlckRCLCBJbmMuMQsw\rCQYDVQQGEwJVUzELMAkGA1UECBMCQ08xDzANBgNVBAcTBkRlbnZlcjEXMBUGA1UE\rChMOSGFycGVyREIsIEluYy4wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIB\rAQCsEUlBF8WImS78rCFXVKyntxfrW++4qZ3hGnoD2MHZAuDHyeP/5eGnaE9GQhKc\r4DwG4DGvh0wP2zIYnBfiQ3L2ZtnlDR9ZkKIQYGlVxTUn6T43krhK5nZKqDF43Yg3\rZEvO3cbJBjiKZx0eA2/toehdSsTAHHQx5gTDcggNe2tgoJHYPwi9YF/AxSBZrbgb\ryWlYgtYDmF32ytHP03GUCIdKOFuBPsHTGu4SkdEIdLIqO9oglW1YFH5qZ6NiwApW\rsP+GCuqOwDXXbdjr75iq9Tq/CDrjGFLaTPmvd2Q0qG/BtaCll0ghpG+yIHvt/iQs\rajS+LxEWAnVlGMaDdFErbDUtAgMBAAGjIzAhMA8GA1UdEwEB/wQFMAMBAf8wDgYD\rVR0PAQH/BAQDAgIEMA0GCSqGSIb3DQEBCwUAA4IBAQASR4YW/rPK7PNArHVe9zzM\rb0rKNX/2T9/0nybRhmE/+hdlSgliTAeebmwkUS2APckmekYt/q2ZY2NS65Fo/jjp\rG8TJrtcF4h+ylVqUp0ZXQLFtIsr7r2JZA7hJ6njW6G4DHSZ0gxtECLi4CBlTjzm5\rNmnmIDObvGRTuqmcdAZmXeObbta/He2XIzietukPAYX062pNM+G5XT5UM1eG/Vlp\rN86vjhpyI+ffKy+C60SJqxmKM3ydgN7oLscE7+2wLPN25XqN4W99OwGsp5dTdu/f\r5lPtFayXdJ55e/sNQKmGN+UGLrL05c2MWgjb8U/LFilnupUianceoeSERZmVjzKX\r-----END CERTIFICATE-----\r".replace(/\r/g,`\r
8
8
  `)},sV="certificate.pem",iV="privateKey.pem",oV="ca.pem";VO.exports={CERTIFICATE_VALUES:nV,CERTIFICATE_PEM_NAME:sV,PRIVATEKEY_PEM_NAME:iV,CA_PEM_NAME:oV}});var st=g((Voe,YO)=>{"use strict";var lr=require("validate.js");lr.validators.type=function(e,t,r,n){return e===null||typeof e>"u"||lr.validators.type.checks[t](e)?null:` must be a '${t}' value`};lr.validators.type.checks={Object:function(e){return lr.isObject(e)&&!lr.isArray(e)},Array:lr.isArray,Integer:lr.isInteger,Number:lr.isNumber,String:lr.isString,Date:lr.isDate,Boolean:function(e){return typeof e=="boolean"}};lr.validators.hasValidFileExt=function(e,t){return lr.isString(e)?e===""?"can't be blank":t.filter(r=>e.endsWith(r)).length>0?null:`must include one of the following valid file extensions - '${t.join("', '")}'`:null};YO.exports={validateObject:aV,validateObjectAsync:cV,validateBySchema:lV};function aV(e,t){if(!e||!t)return new Error("validateObject parameters were null");let r=lr(e,t,{format:"flat"});return r?new Error(r):null}a(aV,"validateObject");async function cV(e,t){if(!e||!t)return new Error("validateObject parameters were null");try{await lr.async(e,t,{format:"flat"})}catch(r){let n=r.join(",");return new Error(n)}return null}a(cV,"validateObjectAsync");function lV(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(lV,"validateBySchema")});var Bh=g((Koe,XO)=>{"use strict";var zO=require("fs-extra"),ae=require("joi"),uV=require("os"),{boolean:be,string:Zt,number:je,array:l_}=ae.types(),{totalmem:KO}=require("os"),Bi=require("path"),_V=K(),u_=z(),Yoe=$O(),WO=P(),dV=st(),QO="log",fV="components",EV="Invalid logging.rotation.maxSize unit. Available units are G, M or K",hV="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",mV="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",pV="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",SV="rootPath config parameter is undefined",TV="clustering.enabled config parameter is undefined",Hi=je.min(0).required(),__=l_.items({host:Zt.required(),port:Hi}).empty(null),Qn,JO=!1;XO.exports={configValidator:gV,routesValidator:NV,route_constraints:__};function gV(e,t=!1){if(JO=t,Qn=e.rootPath,u_.isEmpty(Qn))throw SV;let r=be.required(),n=je.min(0).max(1e3).empty(null).default(yV),s=Zt.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(pc),i=Zt.optional().empty(null),o=Zt.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null).required(),c=ae.string().empty(null).default(pc),l=ae.custom(AV).empty(null).default(pc),_=e.clustering?.enabled;if(u_.isEmpty(_))throw TV;let u=ae.object({certificate:i,certificateAuthority:i,privateKey:i}),d;return _===!0?d=ae.object({enabled:r,hubServer:ae.object({cluster:ae.object({name:ae.required().empty(null),network:ae.object({port:Hi,routes:__}).required()}).required(),leafNodes:ae.object({network:ae.object({port:Hi}).required()}).required(),network:ae.object({port:Hi}).required()}).required(),leafServer:ae.object({network:ae.object({port:Hi,routes:__}).required(),streams:ae.object({maxAge:je.min(120).allow(null).optional(),maxBytes:je.min(1).allow(null).optional(),maxMsgs:je.min(1).allow(null).optional(),path:c}).required()}).required(),logLevel:ae.valid("error","warn","info","debug","trace"),nodeName:o,republishMessages:be.optional(),databaseLevel:be.optional(),tls:ae.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:be.required(),verify:be.optional()}),user:Zt.optional().empty(null)}).required():d=ae.object({enabled:r,tls:ae.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:be.required()})}).required(),ae.object({authentication:ae.object({authorizeLocal:be,cacheTTL:je.required(),enableSessions:be}),analytics:ae.object({aggregatePeriod:je}),componentsRoot:s.optional(),clustering:d,localStudio:ae.object({enabled:r}).required(),logging:ae.object({auditAuthEvents:ae.object({logFailed:be,logSuccessful:be}),file:be.required(),level:ae.valid("notify","fatal","error","warn","info","debug","trace"),rotation:ae.object({enabled:be.optional(),compress:be.optional(),interval:Zt.custom(bV).optional().empty(null),maxSize:Zt.custom(OV).optional().empty(null),path:Zt.optional().empty(null).default(pc)}).required(),root:s,stdStreams:be.required(),auditLog:be.required()}).required(),operationsApi:ae.object({network:ae.object({cors:be.optional(),corsAccessList:l_.optional(),headersTimeout:je.min(1).optional(),keepAliveTimeout:je.min(1).optional(),port:je.optional().empty(null),domainSocket:ae.optional().empty("hdb/operations-server").default(pc),securePort:je.optional().empty(null),timeout:je.min(1).optional()}).optional(),tls:ae.alternatives([ae.array().items(u),u])}).required(),rootPath:Zt.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path").required(),mqtt:ae.object({network:ae.object({port:Hi,securePort:Hi,mtls:ae.alternatives([be.optional(),ae.object({user:Zt.optional(),certificateAuthority:i,required:be.optional()})])}).required(),webSocket:be.optional(),requireAuthentication:be.optional()}),http:ae.object({compressionThreshold:je.optional(),cors:be.optional(),corsAccessList:l_.optional(),headersTimeout:je.min(1).optional(),port:je.min(0).optional().empty(null),securePort:je.min(0).optional().empty(null),maxHeaderSize:je.optional(),mtls:ae.alternatives([be.optional(),ae.object({user:Zt.optional(),certificateAuthority:i,required:be.optional()})]),threadRange:ae.alternatives([l_.optional(),Zt.optional()])}).required(),threads:ae.alternatives(n.optional(),ae.object({count:n.optional(),debug:ae.alternatives(be.optional(),ae.object({startingPort:je.min(1).optional(),host:Zt.optional(),waitForDebugger:be.optional()})),maxHeapMemory:je.min(0).optional()})),storage:ae.object({writeAsync:be.required(),overlappingSync:be.optional(),caching:be.optional(),compression:ae.alternatives([be.optional(),ae.object({dictionary:Zt.optional(),threshold:je.optional()})]),compactOnStart:be.optional(),compactOnStartKeepBackup:be.optional(),noReadAhead:be.optional(),path:l,prefetchWrites:be.optional(),maxFreeSpaceToLoad:je.optional(),maxFreeSpaceToRetain:je.optional()}).required(),ignoreScripts:be.optional(),tls:ae.alternatives([ae.array().items(u),u])}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(gV,"configValidator");function RV(e){return JO||zO.existsSync(e)?null:`Specified path ${e} does not exist.`}a(RV,"doesPathExist");function AV(e,t){ae.assert(e,Zt.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=RV(e);if(r)return t.message(r)}a(AV,"validatePath");function OV(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(EV);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(mV):e}a(OV,"validateRotationMaxSize");function bV(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message(hV);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(pV):e}a(bV,"validateRotationInterval");function yV(e,t){let r=t.state.path.join("."),n=uV.cpus().length,s=n-1;s<=2&&(s=2);let i=process.constrainedMemory?.()||KO();return i=Math.round(Math.min(i,KO())/1e6),s=Math.max(Math.min(s,Math.round((i-750)/300)),1),_V.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}a(yV,"setDefaultThreads");function pc(e,t){let r=t.state.path.join(".");if(!u_.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if(u_.isEmpty(Qn))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return Bi.join(Qn,fV);case"logging.root":return Bi.join(Qn,QO);case"clustering.leafServer.streams.path":return Bi.join(Qn,"clustering","leaf");case"storage.path":let n=Bi.join(Qn,WO.LEGACY_DATABASES_DIR_NAME);return zO.existsSync(n)?n:Bi.join(Qn,WO.DATABASES_DIR_NAME);case"logging.rotation.path":return Bi.join(Qn,QO);case"operationsApi.network.domainSocket":return r==null?null:Bi.join(Qn,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(pc,"setDefaultRoot");function NV(e){let t=ae.object({routes:__});return dV.validateBySchema({routes:e},t)}a(NV,"routesValidator")});var xi={};qe(xi,{server:()=>it});var jO,it,ur=Re(()=>{jO=require("../../index"),it={};(0,jO._assignPackageExport)("server",it)});var dr=g((zoe,ab)=>{"use strict";var Hr=P(),vt=z(),Nt=K(),{configValidator:IV,routesValidator:ZO}=Bh(),_r=require("fs-extra"),wV=require("yaml"),Nn=require("path"),CV=require("is-number"),tb=require("properties-reader"),DV=require("lodash"),{handleHDBError:LV}=se(),{HTTP_STATUS_CODES:MV,HDB_ERROR_MSGS:d_}=vr(),Qoe=require("minimist"),{server:PV}=(ur(),ie(xi)),{DATABASES_PARAM_CONFIG:Sc,CONFIG_PARAMS:Br,CONFIG_PARAM_MAP:In}=Hr,UV="Unable to get config value because config is uninitialized",vV="Config successfully initialized",BV="Error backing up config file",HV="Empty parameter sent to getConfigValue",rb=Nn.join(Hr.PACKAGE_ROOT,"config","yaml",Hr.HDB_DEFAULT_CONFIG_FILE),xV="Configuration successfully set. You must restart HarperDB for new config settings to take effect.",eb={logging_rotation_retain:"logging.rotation.retain",logging_rotation_rotate:"logging.rotation.rotate",logging_rotation_rotateinterval:"logging.rotation.rotateInterval",logging_rotation_rotatemodule:"logging.rotation.rotateModule",logging_rotation_timezone:"logging.rotation.timezone",logging_rotation_workerinterval:"logging.rotation.workerInterval"},f_,It,E_;ab.exports={createConfigFile:GV,getDefaultConfig:FV,getConfigValue:sb,initConfig:xh,flattenConfig:ko,updateConfigValue:ib,updateConfigObject:kV,getConfiguration:YV,setConfiguration:KV,readConfigFile:Fh,getClusteringRoutes:WV,initOldConfig:ob,getConfigFromFile:QV,getConfigFilePath:Gi,addConfig:zV,deleteConfigFromFile:JV,getConfigObj:XV};function GV(e,t=!1){let r=Zs(rb);f_=ko(r.toJSON());let n;for(let c in e){let l=In[c.toLowerCase()];if(l===Br.DATABASES){Array.isArray(e[c])?n=e[c]:n=Object.keys(e[c]).map(_=>({[_]:e[c][_]}));continue}if(!l&&(c.endsWith("_package")||c.endsWith("_port"))&&(l=c),l!==void 0){let _=l.split("_"),u=Hh(l,e[c]);l==="rootPath"&&u?.endsWith("/")&&(u=u.slice(0,-1));try{r.setIn([..._],u)}catch(d){Nt.error(d)}}}n&&nb(r,n),Gh(r,t);let s=r.toJSON();It=ko(s);let i=r.getIn(["rootPath"]),o=Nn.join(i,Hr.HDB_CONFIG_FILE);_r.createFileSync(o),_r.writeFileSync(o,String(r)),Nt.trace(`Config file written to ${o}`)}a(GV,"createConfigFile");function nb(e,t){let r;try{try{r=JSON.parse(t)}catch(n){if(!vt.isObject(t))throw n;r=t}for(let n of r){let s=Object.keys(n)[0];if(n[s].hasOwnProperty(Sc.TABLES))for(let i in n[s][Sc.TABLES])for(let o in n[s][Sc.TABLES][i]){let c=n[s][Sc.TABLES][i][o],l=[Br.DATABASES,s,Sc.TABLES,i,o];e.hasIn(l)?e.setIn(l,c):e.addIn(l,c)}else for(let i in n[s]){let o=n[s][i],c=[Br.DATABASES,s,i];e.hasIn(c)?e.setIn(c,o):e.addIn(c,o)}}}catch(n){Nt.error("Error parsing schemas CLI/env config arguments",n)}}a(nb,"setSchemasConfig");function FV(e){if(f_===void 0){let r=Zs(rb);f_=ko(r.toJSON())}let t=In[e.toLowerCase()];if(t!==void 0)return f_[t.toLowerCase()]}a(FV,"getDefaultConfig");function sb(e){if(e==null){Nt.error(HV);return}if(It===void 0){Nt.trace(UV);return}let t=In[e.toLowerCase()];if(t!==void 0)return It[t.toLowerCase()]}a(sb,"getConfigValue");function Gi(e=vt.getPropsFilePath()){let t=vt.getEnvCliRootPath();return t?Nn.join(t,Hr.HDB_CONFIG_FILE):tb(e).get(Hr.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY)}a(Gi,"getConfigFilePath");function xh(e=!1){if(It===void 0||e){let t;if(!vt.noBootFile()){t=vt.getPropsFilePath();try{_r.accessSync(t,_r.constants.F_OK|_r.constants.R_OK)}catch(i){throw Nt.error(i),new Error(`HarperDB properties file at path ${t} does not exist`)}}let r=Gi(t),n;if(r.includes("config/settings.js"))try{ob(r);return}catch(i){if(i.code!==Hr.NODE_ERROR_CODES.ENOENT)throw i}try{n=Zs(r)}catch(i){if(i.code===Hr.NODE_ERROR_CODES.ENOENT){Nt.trace(`HarperDB config file not found at ${r}.
9
- This can occur during early stages of install where the config file has not yet been created`);return}else throw Nt.error(i),new Error(`Error reading HarperDB config file at ${r}`)}qV(n,r),Gh(n);let s=n.toJSON();if(PV.config=s,It=ko(s),It.logging_rotation_rotate)for(let i in eb)It[i]&&Nt.error(`Config ${eb[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);Nt.trace(vV)}}a(xh,"initConfig");function qV(e,t){let r=e.getIn(["rootPath"]),n=!1;e.hasIn(["storage","path"])||(e.setIn(["storage","path"],Nn.join(r,"database")),n=!0),e.hasIn(["clustering","leafServer","streams","path"])||(e.setIn(["clustering","leafServer","streams","path"],Nn.join(r,"clustering","leaf")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],Nn.join(r,"log")),n=!0),e.hasIn(["clustering","tls","verify"])||(e.setIn(["clustering","tls","verify"],!0),n=!0),e.hasIn(["authentication"])||(e.addIn(["authentication"],{cacheTTL:3e4,enableSessions:!0,operationTokenTimeout:e.getIn(["operationsApi","authentication","operationTokenTimeout"])??"1d",refreshTokenTimeout:e.getIn(["operationsApi","authentication","refreshTokenTimeout"])??"30d"}),n=!0),e.hasIn(["analytics"])||(e.addIn(["analytics"],{aggregatePeriod:60}),n=!0),n&&(Nt.trace("Updating config file with missing config params"),_r.writeFileSync(t,String(e)))}a(qV,"checkForUpdatedConfig");function Gh(e,t=!1){let r=e.toJSON();r.componentsRoot=r.componentsRoot??r?.customFunctions?.root,r?.http?.threads&&(r.threads=r?.http?.threads);let n=IV(r,t);if(n.error)throw d_.CONFIG_VALIDATION(n.error.message);typeof n.value.threads=="object"?e.setIn(["threads","count"],n.value.threads.count):e.setIn(["threads"],n.value.threads),e.setIn(["componentsRoot"],n.value.componentsRoot),e.setIn(["logging","root"],n.value.logging.root),e.setIn(["storage","path"],n.value.storage.path),e.setIn(["logging","rotation","path"],n.value.logging.rotation.path),e.setIn(["clustering","leafServer","streams","path"],n.value.clustering.leafServer.streams?.path),e.setIn(["operationsApi","network","domainSocket"],n.value?.operationsApi?.network?.domainSocket)}a(Gh,"validateConfig");function kV(e,t){It===void 0&&(It={});let r=In[e.toLowerCase()];if(r===void 0){Nt.trace(`Unable to update config object because config param '${e}' does not exist`);return}It[r.toLowerCase()]=t}a(kV,"updateConfigObject");function ib(e,t,r=void 0,n=!1,s=!1,i=!1){It===void 0&&xh();let o=sb(In.hdb_root),c=Nn.join(o,Hr.HDB_CONFIG_FILE),l=Zs(c),_;if(r===void 0&&e.toLowerCase()===Br.DATABASES)_=t;else if(r===void 0){let E;if(i)E=e;else if(E=In[e.toLowerCase()],E===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let f=E.split("_"),h=Hh(E,t);l.setIn([...f],h)}else for(let E in r){let f=In[E.toLowerCase()];if(f===Br.HTTP_SECUREPORT&&r[E]===It[Br.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),f===Br.OPERATIONSAPI_NETWORK_SECUREPORT&&r[E]===It[Br.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&l.setIn(["operationsApi","network","port"],null),f===Br.DATABASES){_=r[E];continue}if(f?.startsWith("threads_")){let h=l.getIn(["threads"]);h>=0&&(l.deleteIn(["threads"]),l.setIn(["threads","count"],h))}if(!f&&(E.endsWith("_package")||E.endsWith("_port"))&&(f=E),f!==void 0){let h=f.split("_"),p=Hr.LEGACY_CONFIG_PARAMS[E.toUpperCase()];p&&p.startsWith("customFunctions")&&l.hasIn(p.split("_"))&&(f=p,h=p.split("_"));let S=Hh(f,r[E]);f==="rootPath"&&S?.endsWith("/")&&(S=S.slice(0,-1));try{h.length>1&&typeof l.getIn(h.slice(0,-1))=="boolean"&&l.deleteIn(h.slice(0,-1)),l.setIn([...h],S)}catch(T){Nt.error(T)}}}_&&nb(l,_),Gh(l);let u=l.getIn(["rootPath"]),d=Nn.join(u,Hr.HDB_CONFIG_FILE);n===!0&&VV(c,u),_r.writeFileSync(d,String(l)),s&&(It=ko(l.toJSON())),Nt.trace(`Config parameter: ${e} updated with value: ${t}`)}a(ib,"updateConfigValue");function VV(e,t){try{let r=Nn.join(t,"backup",`${Hr.HDB_CONFIG_FILE}.bak`);_r.copySync(e,r),Nt.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){Nt.error(BV),Nt.error(r)}}a(VV,"backupConfigFile");var $V=["databases"];function ko(e){return e.http&&Object.assign(e.http,e?.customFunctions?.network),e?.operationsApi?.network&&(e.operationsApi.network=Object.assign({},e.http,e.operationsApi.network)),e?.operationsApi&&(e.operationsApi.tls=Object.assign({},e.tls,e.operationsApi.tls)),E_=e,r(e);function r(n){let s={};for(let i in n)if(n.hasOwnProperty(i)){if(typeof n[i]=="object"&&n[i]!==null&&!Array.isArray(n[i])&&!$V.includes(i)){let o=r(n[i]);for(let c in o){if(!o.hasOwnProperty(c))continue;c!=="package"&&(i=i.toLowerCase());let l=i+"_"+c;!Br[l.toUpperCase()]&&In[l]&&(s[In[l].toLowerCase()]=o[c]),s[l]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(ko,"flattenConfig");function Hh(e,t){if(e===Br.CLUSTERING_NODENAME||e===Br.CLUSTERING_USER){if(t==null)return t;if(!isNaN(t))return t.toString();if(typeof t=="string"&&t.toLowerCase()==="true"||typeof t=="string"&&t.toLowerCase()==="false")return t}else{if(CV(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||vt.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 vt.autoCast(t)}a(Hh,"castConfigValue");function YV(){let e=vt.getPropsFilePath(),t=Gi(e);return Zs(t).toJSON()}a(YV,"getConfiguration");async function KV(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return ib(void 0,void 0,s,!0),xV}catch(i){throw typeof i=="string"||i instanceof String?LV(i,i,MV.BAD_REQUEST,void 0,void 0,!0):i}}a(KV,"setConfiguration");function Fh(){let e=vt.getPropsFilePath();try{_r.accessSync(e,_r.constants.F_OK|_r.constants.R_OK)}catch(n){if(!vt.noBootFile())throw Nt.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=Gi(e);return Zs(t).toJSON()}a(Fh,"readConfigFile");function Zs(e){return wV.parseDocument(_r.readFileSync(e,"utf8"),{simpleKeys:!0})}a(Zs,"parseYamlDoc");function WV(){let e=Fh(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=vt.isEmptyOrZeroLength(t)?[]:t;let r=ZO(t);if(r)throw d_.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=vt.isEmptyOrZeroLength(n)?[]:n;let s=ZO(n);if(s)throw d_.CONFIG_VALIDATION(s.message);if(!vt.isEmptyOrZeroLength(n)&&!vt.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!vt.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw d_.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(WV,"getClusteringRoutes");function ob(e){let t=tb(e);It={};for(let r in In){let n=t.get(r.toUpperCase());if(vt.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=In[r].toLowerCase();s===Br.LOGGING_ROOT?It[s]=Nn.dirname(n):It[s]=n}return It}a(ob,"initOldConfig");function QV(e){let t=Fh();return DV.get(t,e.replaceAll("_","."))}a(QV,"getConfigFromFile");async function zV(e,t){let r=Zs(Gi());r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),await _r.writeFile(Gi(),String(r))}a(zV,"addConfig");function JV(e){let t=Gi(vt.getPropsFilePath()),r=Zs(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=Nn.join(n,Hr.HDB_CONFIG_FILE);_r.writeFileSync(s,String(r))}a(JV,"deleteConfigFromFile");function XV(){return E_||(xh(),E_)}a(XV,"getConfigObj")});var ne=g((Xoe,db)=>{"use strict";var qh=require("fs-extra"),Fi=require("path"),cb=require("os"),jV=require("properties-reader"),gc=K(),Tc=z(),de=P(),h_=dr(),ZV="Error initializing environment manager",m_="BOOT_PROPS_FILE_PATH",lb=!1,e$={[de.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[de.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[de.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},gs={};db.exports={BOOT_PROPS_FILE_PATH:m_,getHdbBasePath:t$,setHdbBasePath:r$,get:ub,initSync:s$,setProperty:Me,initTestEnvironment:o$,setCloneVar:i$};function t$(){return gs[de.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(t$,"getHdbBasePath");function r$(e){gs[de.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(r$,"setHdbBasePath");function ub(e){let t=h_.getConfigValue(e);return t===void 0?gs[e]:t}a(ub,"get");function Me(e,t){e$[e]&&(gs[e]=t),h_.updateConfigObject(e,t)}a(Me,"setProperty");function n$(){let e;try{e=Tc.getPropsFilePath(),qh.accessSync(e,qh.constants.F_OK|qh.constants.R_OK),lb=!0;let t=jV(e);return gs[de.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(de.HDB_SETTINGS_NAMES.INSTALL_USER),gs[de.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(de.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),gs[m_]=e,!0}catch{return gc.trace(`Environment manager found no properties file at ${e}`),!1}}a(n$,"doesPropFileExist");function s$(e=!1){try{(lb||n$()||Tc.noBootFile())&&!_b&&(h_.initConfig(e),gs[de.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=h_.getConfigValue(de.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){gc.error(ZV),gc.error(t),console.error(t),process.exit(1)}}a(s$,"initSync");var _b=!1;function i$(e){_b=e}a(i$,"setCloneVar");function o$(e={}){try{let{keep_alive_timeout:t,headers_timeout:r,server_timeout:n,https_enabled:s,cors_enabled:i,cors_accesslist:o,local_studio_on:c}=e,l=Fi.join(__dirname,"../../","unitTests");gs[m_]=Fi.join(l,"hdb_boot_properties.file"),Me(de.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,Fi.join(l,"settings.test")),Me(de.HDB_SETTINGS_NAMES.INSTALL_USER,cb.userInfo()?cb.userInfo().username:void 0),Me(de.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),Me(de.HDB_SETTINGS_NAMES.LOG_PATH_KEY,Fi.join(l,"envDir","log")),Me(de.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),Me(de.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),Me(de.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),Me(de.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,Fi.join(l,"envDir")),Me(de.CONFIG_PARAMS.STORAGE_PATH,Fi.join(l,"envDir")),s&&(Me(de.CONFIG_PARAMS.HTTP_SECUREPORT,ub(de.CONFIG_PARAMS.HTTP_PORT)),Me(de.CONFIG_PARAMS.HTTP_PORT,null)),Me(de.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,!!s),Me(de.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),Me(de.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,Tc.isEmpty(i)?!1:i),Me(de.CONFIG_PARAMS.HTTP_CORS,Tc.isEmpty(i)?!1:i),Me(de.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),Me(de.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),Me(de.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),Me(de.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),Me(de.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,Fi.resolve(__dirname,"../../unitTests/server/fastifyRoutes/custom_functions")),Me(de.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,Tc.isEmpty(c)?!1:c),o&&(Me("CORS_ACCESSLIST",o),Me(de.CONFIG_PARAMS.HTTP_CORSACCESSLIST,o)),n&&(Me(de.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,n),Me(de.CONFIG_PARAMS.HTTP_TIMEOUT,n)),t&&(Me(de.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),Me(de.CONFIG_PARAMS.HTTP_KEEPALIVETIMEOUT,t)),r&&(Me(de.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),Me(de.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${m_}. Please check your boot props and settings files`;gc.fatal(r),gc.error(t)}}a(o$,"initTestEnvironment")});var ze=g((Zoe,Tb)=>{"use strict";var yc=P(),a$=z(),fr=ne(),Nc=require("path"),c$=require("minimist"),fb=require("fs-extra"),Eb=require("lodash");fr.initSync();var{CONFIG_PARAMS:ei,DATABASES_PARAM_CONFIG:Rc,SYSTEM_SCHEMA_NAME:p_}=yc,Ac,Oc,bc;function hb(){if(Ac!==void 0)return Ac;if(fr.getHdbBasePath()!==void 0)return Ac=fr.get(ei.STORAGE_PATH)||Nc.join(fr.getHdbBasePath(),yc.DATABASES_DIR_NAME),Ac}a(hb,"getBaseSchemaPath");function mb(){if(Oc!==void 0)return Oc;if(fr.getHdbBasePath()!==void 0)return Oc=Sb(p_),Oc}a(mb,"getSystemSchemaPath");function pb(){if(bc!==void 0)return bc;if(fr.getHdbBasePath()!==void 0)return bc=fr.get(yc.CONFIG_PARAMS.STORAGE_AUDIT_PATH)||Nc.join(fr.getHdbBasePath(),yc.TRANSACTIONS_DIR_NAME),bc}a(pb,"getTransactionAuditStoreBasePath");function l$(e,t){let r=fr.get(ei.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||Nc.join(pb(),e.toString())}a(l$,"getTransactionAuditStorePath");function Sb(e,t){e=e.toString(),t=t&&t.toString();let r=fr.get(yc.CONFIG_PARAMS.DATABASES)?.[e];return t&&r?.tables?.[t]?.path||r?.path||Nc.join(hb(),e)}a(Sb,"getSchemaPath");function u$(e,t){e=e.toString(),t=t.toString();let r=process.env;Object.assign(r,c$(process.argv));let n=r[ei.DATABASES.toUpperCase()];if(n){let i;try{i=JSON.parse(n)}catch(o){if(!a$.isObject(n))throw o;i=n}for(let o of i){let c=o[p_];if(!c)continue;let l=fr.get(ei.DATABASES);l=l??{};let _=c?.tables?.[t]?.[Rc.PATH];if(_)return Eb.set(l,[p_,Rc.TABLES,t,Rc.PATH],_),fr.setProperty(ei.DATABASES,l),_;let u=c?.[Rc.PATH];if(u)return Eb.set(l,[p_,Rc.PATH],u),fr.setProperty(ei.DATABASES,l),u}}let s=r[ei.STORAGE_PATH.toUpperCase()];if(s){if(!fb.pathExistsSync(s))throw new Error(s+" does not exist");let i=Nc.join(s,e);return fb.mkdirsSync(i),fr.setProperty(ei.STORAGE_PATH,s),i}return mb()}a(u$,"initSystemSchemaPaths");function _$(){Ac=void 0,Oc=void 0,bc=void 0}a(_$,"resetPaths");Tb.exports={getBaseSchemaPath:hb,getSystemSchemaPath:mb,getTransactionAuditStorePath:l$,getTransactionAuditStoreBasePath:pb,getSchemaPath:Sb,initSystemSchemaPaths:u$,resetPaths:_$}});var xr=g((nae,bb)=>{"use strict";var d$=vr().LMDB_ERRORS_ENUM,tae=require("lmdb"),f$=dt(),rae=require("buffer").Buffer,{OVERFLOW_MARKER:gb,MAX_SEARCH_KEY_LENGTH:S_}=f$,Rb=["number","string","symbol","boolean","bigint"];function E$(e){if(e=e?.primaryStore||e,!e)throw new Error(d$.ENV_REQUIRED)}a(E$,"validateEnv");function h$(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(h$,"stringifyData");function m$(e){return e instanceof Date?e.valueOf():e}a(m$,"convertKeyValueToWrite");function p$(e,t){if(e===null)return t?[null]:void 0;if(e===void 0)return;if(Rb.includes(typeof e))return e.length>S_?[e.slice(0,S_)+gb]:[e];let r;if(Array.isArray(e)){r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n];if(Rb.includes(typeof i))i.length>S_?r.push(i.slice(0,S_)+gb):r.push(i);else{if(i===null&&t)return r.push(null);if(i instanceof Date)return r.push(i.getTime())}}}else if(e instanceof Date)return[e.getTime()];return r}a(p$,"getIndexedValues");var T_=0,Ab=0;function Ob(){Ab=Date.now()-performance.now()}a(Ob,"adjustStartTime");Ob();var S$=6e4;setInterval(Ob,S$).unref();function T$(){let e=performance.now()+Ab;return e>T_?(T_=e,e):(T_+=488e-6,T_)}a(T$,"getNextMonotonicTime");bb.exports={validateEnv:E$,stringifyData:h$,convertKeyValueToWrite:m$,getNextMonotonicTime:T$,getIndexedValues:p$}});var Ic=g((iae,yb)=>{"use strict";var g$=P().OPERATIONS_ENUM,kh=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i=void 0){this.operation=g$.INSERT,this.schema=t,this.table=r,this.hash_attribute=n,this.records=s,this.__origin=i}};yb.exports=kh});var wc=g((cae,Cb)=>{"use strict";var aae=Ic(),g_=P(),Vh=z(),Nb=K(),R$=require("uuid"),{handleHDBError:R_,hdb_errors:A$}=se(),{HDB_ERROR_MSGS:A_,HTTP_STATUS_CODES:O_}=A$;Cb.exports=Ib;function Ib(e,t,r){for(let s=0;s<t.length;s++)wb(t[s]);let{records:n}=e;for(let s=0;s<n.length;s++){let i=n[s];O$(i,r,e.operation)}}a(Ib,"processRows");Ib.validateAttribute=wb;function wb(e){if(Buffer.byteLength(String(e))>g_.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw R_(new Error,A_.ATTR_NAME_LENGTH_ERR(e),O_.BAD_REQUEST,void 0,void 0,!0);if(Vh.isEmptyOrZeroLength(e)||Vh.isEmpty(e.trim()))throw R_(new Error,A_.ATTR_NAME_NULLISH_ERR,O_.BAD_REQUEST,void 0,void 0,!0)}a(wb,"validateAttribute");function O$(e,t,r){if(!e.hasOwnProperty(t)||Vh.isEmptyOrZeroLength(e[t])){if(r===g_.OPERATIONS_ENUM.INSERT||r===g_.OPERATIONS_ENUM.UPSERT){e[t]=R$.v4();return}throw Nb.error("Update transaction aborted due to record with no hash value:",e),R_(new Error,A_.RECORD_MISSING_HASH_ERR,O_.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>g_.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw Nb.error(e),R_(new Error,A_.HASH_VAL_LENGTH_ERR,O_.BAD_REQUEST,void 0,void 0,!0)}a(O$,"validateHash")});var Db,wn,$h,Cc=Re(()=>{Db=require("events"),wn=class extends Db.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;drainCloseListener;currentDrainResolver;[Symbol.asyncIterator](){let t=new $h;return t.queue=this,t}push(t){this.send(t)}send(t){this.resolveNext?(this.resolveNext({value:t}),this.resolveNext=null):this.hasDataListeners?this.emit("data",t):(this.queue||(this.queue=[]),this.queue.push(t))}getNextMessage(){let t=this.queue?.shift();return t||this.emit("drained"),t}waitForDrain(){return new Promise(t=>{!this.queue||this.queue.length===0?t(!0):(this.once("drained",()=>t(!0)),this.currentDrainResolver=t,this.drainCloseListener||(this.drainCloseListener=!0,this.on("close",()=>{this.currentDrainResolver?.(!1)})))})}on(t,r){if(t==="data"&&!this.hasDataListeners)for(this.hasDataListeners=!0;this.queue?.length>0;)r(this.queue.shift());return super.on(t,r)}},$h=class{static{a(this,"EventQueueIterator")}queue;push(t){this.queue.send(t)}next(){let t=this.queue.getNextMessage();return t?{value:t}:new Promise(r=>this.queue.resolveNext=r)}return(t){return this.queue.emit("close"),{value:t,done:!0}}throw(t){return this.queue.emit("close",t),{done:!0}}}});var Wh={};qe(Wh,{loadGQLSchema:()=>N$,start:()=>Kh,startOnMainThread:()=>y$});function Kh({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r,n,s,i){let{parse:o,Source:c,Kind:l,NamedTypeNode:_,StringValueNode:u}=await import("graphql"),d=o(new c(r.toString(),s)),E=new Map,f=[],h;for(let S of d.definitions)switch(S.kind){case l.OBJECT_TYPE_DEFINITION:let B=function(U){if(U.kind==="NonNullType"){let Q=B(U.type);return Q.nullable=!1,Q}if(U.kind==="ListType")return{type:"array",elements:B(U.type)};let M={type:U.name?.value};return Object.defineProperty(M,"location",{value:U.loc.startToken}),M};a(B,"getProperty");let T=S.name.value,A=[],b={table:null,database:null,properties:A};E.set(T,b);for(let U of S.directives){if(U.name.value==="table"){for(let q of U.arguments)b[q.name.value]=q.value.value;b.schema&&(b.database=b.schema),b.table||(b.table=T),b.audit&&(b.audit=b.audit!=="false"),b.attributes=b.properties,f.push(b)}if(U.name.value==="sealed"&&(b.sealed=!0),U.name.value==="export"){b.export=!0;for(let q of U.arguments)q.name.value==="name"&&(b.export={name:q.value.value})}}let I=!1;for(let U of S.fields){let q=B(U.type);q.name=U.name.value,A.push(q);for(let M of U.directives)if(M.name.value==="primaryKey")I?console.warn("Can not define two attributes as a primary key"):(q.isPrimaryKey=!0,I=!0);else if(M.name.value==="indexed")q.indexed=!0;else if(M.name.value==="relationship"){let Q={};for(let J of M.arguments)Q[J.name.value]=J.value.value;q.relationship=Q}else if(M.name.value==="createdTime")q.assignCreatedTime=!0;else if(M.name.value==="updatedTime")q.assignUpdatedTime=!0;else if(M.name.value==="expiresAt")q.expiresAt=!0;else if(M.name.value==="allow"){let Q=q.authorizedRoles=[];for(let J of M.arguments)J.name.value==="role"&&Q.push(J.value.value)}}b.type=T,T==="Query"&&(h=b)}function p(S){let T=E.get(S.type);T?(Object.defineProperty(S,"properties",{value:T.properties}),Object.defineProperty(S,"definition",{value:T})):S.type==="array"?p(S.elements):b$.includes(S.type)||(0,Lb.getWorkerIndex)()===0&&console.error(`The type ${S.type} is unknown at line ${S.location.line}, column ${S.location.column}, in ${s}`)}a(p,"connectPropertyType");for(let S of E.values())for(let T of S.properties)p(T);for(let S of f)S.tableClass=e(S),S.export&&(S.export.name===""?i.set((0,Yh.dirname)(n),S.tableClass):i.set((0,Yh.dirname)(n)+"/"+(S.export.name||S.type),S.tableClass))}}var Yh,Lb,b$,y$,N$,Mb=Re(()=>{Yh=require("path");Ae();Lb=x(ot()),b$=["ID","Int","Float","Long","String","Boolean","Date","Bytes","Any","BigInt"];a(Kh,"start");y$=Kh,N$=Kh({ensureTable:ft}).handleFile});async function b_(e){let t=(0,vb.pathToFileURL)(e).toString();return I$?(Dc||(Dc=w$(D$)),(await(await Dc).import(t)).namespace):import(t)}async function w$(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),Dc=new Compartment({console,Math,Date,fetch:C$,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,Ub.extname)(r)||(r+=".js"),r)},importHook:async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){Object.assign(s,{Resource:$t,tables:Gr,databases:at})}};let n=await(0,Pb.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)}}),Dc}function C$(e,t){let r=typeof e=="string"||e.url;if(new URL(r).protocol!="https")throw new Error("Only https is allowed in fetch");return fetch(e,t)}function D$(){return{Resource:$t,tables:Gr}}var Pb,Ub,vb,I$,Dc,Qh=Re(()=>{an();Ae();Pb=require("fs/promises"),Ub=require("path"),vb=require("url"),I$=!1;a(b_,"secureImport");a(w$,"getCompartment");a(C$,"secureOnlyFetch");a(D$,"getGlobalVars")});var Jh={};qe(Jh,{handleFile:()=>L$});async function L$(e,t,r,n){let s=new Map,i=await b_(r);c(i.default)&&n.set((0,zh.dirname)(t),i.default),o(i,(0,zh.dirname)(t));function o(l,_){for(let u in l){let d=l[u];c(d)?n.set(_+"/"+u,d):typeof d=="object"&&o(d,_+"/"+u)}}a(o,"recurseForResources");function c(l){return typeof l=="function"&&(l.get||l.put||l.post||l.delete)}return a(c,"isResource"),s}var zh,Bb=Re(()=>{Qh();zh=require("path");a(L$,"handleFile")});var jh={};qe(jh,{start:()=>M$});function M$({resources:e}){e.set("login",Xh),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var Xh,Hb=Re(()=>{an();a(M$,"start");Xh=class extends $t{static{a(this,"Login")}static async get(t,r,n){}static async post(t,r,n){let{username:s,password:i,redirect:o}=r;return{data:await n.login(s,i)}}}});var $b={};qe($b,{parse:()=>em,streamAsJSON:()=>Lc,stringify:()=>qi});function Lc(e){return new Zh({value:e})}function xb(e){return console.error(e),JSON.stringify(e.toString())}function Gb(e,t,r){return e?.then?r?e.then(t,r):e.then(t):t(e)}function qi(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===kb)return Vb(e);if(t.resolution)return t.resolution.then(()=>qi(e));throw t}}function Vb(e){let t=typeof e;if(t==="object"){if(e===null)return"null";e.toJSON&&(e=e.toJSON());let r;if(Array.isArray(e)){r="[";for(let n=0;n<e.length;n++)n>0&&(r+=","),r+=Vb(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+qi(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function em(e){return v$.test(e)?P$.parse(e):JSON.parse(e)}var Fb,qb,P$,U$,kb,Zh,v$,tm=Re(()=>{Fb=require("stream"),qb=x(require("json-bigint-fixes")),P$=(0,qb.default)({useNativeBigInt:!0}),U$=1e4,kb={};BigInt.prototype.toJSON=function(){throw kb};a(Lc,"streamAsJSON");Zh=class extends Fb.Readable{static{a(this,"JSONStream")}constructor(t){super(t),this.buffer=[],this.bufferSize=0,this.iterator=this.serialize(t.value,!0),this.activeIterators=[]}*serialize(t){if(t&&typeof t=="object"){let r=t[Symbol.asyncIterator],n=t[Symbol.iterator];if((n||r)&&!t.then){yield"[";let s=!0;if((r||n)&&!(t instanceof Array)){let i=r?t[Symbol.asyncIterator]():t[Symbol.iterator]();this.activeIterators.push(i);let o;for(;;)if(o=i.next(),o.then&&(yield o.then(c=>(o=c,""))),o.done){this.activeIterators.splice(this.activeIterators.indexOf(i),1),yield"]";return}else s?s=!1:yield",",yield*this.serialize(o.value)}for(let i of t)s?s=!1:yield",",yield*this.serialize(i);yield"]";return}if(t.then)try{yield t.then(s=>this.serialize(s),xb)}catch(s){yield xb(s)}else yield qi(t)}else yield qi(t)}_read(){if(!this._amReading){if(this._amReading=!0,this.done)return this.push(null);Gb(this.readIterator(this.iterator),t=>{t?(this.done=!0,this.push(null)):this._amReading=!1},t=>{console.error(t),this.done=!0,this.push(t.toString()),this.push(null)})}}push(t){return t===null||t instanceof Buffer?(this.bufferSize>0&&this.flush(),super.push(t)):(this.bufferSize+=t.length||t.toString().length,this.buffer.push(t),this.bufferSize>U$?this.flush():!0)}flush(){let t=super.push(this.buffer.join(""));return this.buffer=[],this.bufferSize=0,t}readIterator(t){try{let r;if(t.childIterator)return Gb(this.readIterator(t.childIterator),n=>{if(n)return t.childIterator=null,this.readIterator(t)});do{let n=t.next();if(n.done)return!0;if(r=n.value,r==null)r="null";else{if(r.then)return this.flush(),Promise.resolve(r).then(s=>{if(s&&typeof s.return=="function")return t.childIterator=s,this.readIterator(t);if(this.push(s+""))return this.readIterator(t)});if(typeof r.return=="function")return t.childIterator=r,this.readIterator(t)}}while(this.push(r))}catch(r){return console.error(r),this.push(r.toString()),this.push(null),!0}}_destroy(t,r){for(let n of this.activeIterators)t?n.throw(t):n.return();r()}};a(xb,"handleError");a(Gb,"when");a(qi,"stringify");a(Vb,"jsStringify");v$=/[[,:]\s*-?\d{16,}/;a(em,"parse")});var ny=g((bae,ry)=>{"use strict";var rm=require("recursive-iterator"),B$=require("alasql"),nm=require("clone"),Yb=z(),{handleHDBError:Kb,hdb_errors:H$}=se(),{HDB_ERROR_MSGS:Wb,HTTP_STATUS_CODES:Qb}=H$,{getDatabases:x$}=(Ae(),ie(ke)),G$=["DISTINCT_ARRAY"],zb=Symbol("validateTables"),sm=Symbol("validateTable"),Oae=Symbol("getAllColumns"),Jb=Symbol("validateAllColumns"),y_=Symbol("findColumn"),Xb=Symbol("validateOrderBy"),Mc=Symbol("validateSegment"),im=Symbol("validateColumn"),jb=Symbol("setColumnsForTable"),Zb=Symbol("checkColumnsForAsterisk"),ey=Symbol("validateGroupBy"),ty=Symbol("hasColumns"),om=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[zb](),this[Zb](),this[Jb]()}[zb](){if(this[ty]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[sm](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[sm](t.table)})}}[ty](){let t=!1,r=new rm(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[sm](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=x$();if(!r[t.databaseid])throw Kb(new Error,Wb.SCHEMA_NOT_FOUND(t.databaseid),Qb.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw Kb(new Error,Wb.TABLE_NOT_FOUND(t.databaseid,t.tableid),Qb.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=nm(s);i.table=nm(t),this.attributes.push(i)})}[y_](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)}[Zb](){let t=new rm(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[jb](r.tableid)}[jb](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new B$.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[Jb](){this[Mc](this.statement.columns,!1),this[Mc](this.statement.joins,!1),this[Mc](this.statement.where,!1),this[ey](this.statement.group,!1),this[Mc](this.statement.order,!0)}[Mc](t,r){if(!t)return;let n=new rm(t),s=[];for(let{node:i,path:o}of n)!Yb.isEmpty(i)&&!Yb.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[Xb](i):s.push(this[im](i)));return s}[ey](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&G$.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=nm(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[y_](n)[0];s&&r.push(s)}}}),this.statement.group.forEach(n=>{let s=null;if(!n.columnid)r.forEach((i,o)=>{if(i.toString()===n.toString()){s=i,r.splice(o,1);return}});else{let i=this[y_](n);if(!i||i.length===0)throw`unknown column '${n.toString()}' in group by`;if(i.length>1)throw`ambiguously defined column '${n.toString()}' in group by`;r.forEach((o,c)=>{if(o.attribute===i[0].attribute&&o.table.tableid===i[0].table.tableid){s=o,r.splice(c,1);return}})}if(!s)throw`group by column '${n.toString()}' must be in select`}),r.length>0)throw`select column '${r[0].attribute?r[0].attribute:r[0].toString()}' must be in group by`}[Xb](t){let r=this.statement.columns.filter(n=>n.as===t.columnid);if(r.length>1)throw`ambiguous column reference ${(t.tableid?t.tableid+".":"")+t.columnid} in order by`;r.length===0&&this[im](t)}[im](t){let r=this[y_](t),n=(t.tableid?t.tableid+".":"")+t.columnid;if(r.length===0)throw`unknown column ${n}`;if(r.length>1)throw`ambiguous column reference ${n}`;return r[0]}};ry.exports=om});var iy=g((Nae,sy)=>{"use strict";var am=class{static{a(this,"BridgeMethods")}createSchema(){throw new Error("createSchema bridge method is not defined")}dropSchema(){throw new Error("dropSchema bridge method is not defined")}createTable(){throw new Error("createTable bridge method is not defined")}dropTable(){throw new Error("dropTable bridge method is not defined")}createRecords(){throw new Error("createRecords bridge method is not defined")}updateRecords(){throw new Error("updateRecords bridge method is not defined")}async upsertRecords(){throw new Error("upsertRecords bridge method is not defined")}deleteRecords(){throw new Error("deleteRecords bridge method is not defined")}createAttribute(){throw new Error("createAttribute bridge method is not defined")}dropAttribute(){throw new Error("dropAttribute bridge method is not defined")}searchByConditions(){throw new Error("searchByConditions bridge method is not defined")}searchByHash(){throw new Error("searchByHash bridge method is not defined")}searchByValue(){throw new Error("searchByValue bridge method is not defined")}getDataByHash(){throw new Error("getDataByHash bridge method is not defined")}getDataByValue(){throw new Error("getDataByValue bridge method is not defined")}deleteRecordsBefore(){throw new Error("deleteRecordsBefore bridge method is not defined")}deleteAuditLogsBefore(){throw new Error("deleteAuditLogsBefore bridge method is not defined")}async readAuditLog(){throw new Error("readAuditLog bridge method is not defined")}};sy.exports=am});var ay=g((wae,oy)=>{"use strict";var cm=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};oy.exports=cm});var _y={};qe(_y,{HAS_EXPIRATION:()=>hm,LAST_TIMESTAMP_PLACEHOLDER:()=>vc,LOCAL_TIMESTAMP:()=>F$,METADATA:()=>Pc,NO_TIMESTAMP:()=>um,PENDING_LOCAL_TIME:()=>mm,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>Em,RecordEncoder:()=>fm,TIMESTAMP_ASSIGN_LAST:()=>k$,TIMESTAMP_ASSIGN_NEW:()=>ly,TIMESTAMP_ASSIGN_PREVIOUS:()=>uy,TIMESTAMP_PLACEHOLDER:()=>N_,TIMESTAMP_RECORD_PREVIOUS:()=>_m,getUpdateRecord:()=>pm,handleLocalTimeForGets:()=>D_});function $$(){return Uc[0]=Uc[0]^64,q$.getFloat64(0)}function D_(e){let t=e.getEntry;e.readCount=0,e.cachePuts=!1,e.getEntry=function(i,o){e.readCount++;let c=t.call(this,i,o),l=c?.value,_=l?.[Pc];return _>=0&&(c.metadataFlags=_,c.localTime=l.localTime,c.value=l.value,l.expiresAt>0&&(c.expiresAt=l.expiresAt)),c&&(c.key=i),c};let r=e.get;e.get=function(i,o){let c=r.call(this,i,o);return c?.[Pc]>=0?c.value:c};let n=e.getRange;e.getRange=function(i){let o=n.call(this,i);return i.valuesForKey?o.map(c=>c?.value):i.values===!1||i.onlyCount?o:o.map(c=>{let l=c.value,_=l[Pc];return _>=0&&(c.metadataFlags=_,c.localTime=l.localTime,c.value=l.value,l.expiresAt>0&&(c.expiresAt=l.expiresAt)),c})};let s=e.useReadTransaction();if(s.done(),!s.done.isTracked){let i=s.constructor,o=s.use,c=s.done;i.prototype.use=function(){this.timerTracked||(this.timerTracked=!0,ki.push(new WeakRef(this))),o.call(this)},i.prototype.done=function(){if(c.call(this),this.isDone)for(let l=0;l<ki.length;l++){let _=ki[l].deref();(!_||_.isDone||_.isCommitted)&&ki.splice(l--,1)}},i.prototype.done.isTracked=!0}return e}function pm(e,t,r){return function(n,s,i,o,c=-1,l,_,u,d="put",E,f){if(E||l==null?Vo=i?.localTime?_m|uy:um:Vo=l?i?.localTime?_m|16384:ly|16384:um,u>0&&(c|=hm),w_=c,dm=u,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let h={version:o,instructedWrite:Vo>0},p;try{E&&(h.ifVersion=p=i?.version??null);let S=e.put(n,s,h);if(l){let T=_?.user?.username;if(f&&(I_=e.encoder.encode(f)),E&&i?.localTime){let A=i?.localTime,b=r.get(A);if(b){let I=Bt(b).previousLocalTime;return r.put(A,C_(o,t,n,I,T,d,I_),{ifVersion:p}),S}}r.put(vc,C_(o,t,n,i?.localTime?1:0,T,d,I_),{append:d!=="invalidate",instructedWrite:!0,ifVersion:p})}return S}catch(S){throw S.message+=" id: "+n+" options: "+h,S}}}var cy,lm,N_,vc,Em,F$,Pc,Uc,q$,um,ly,k$,uy,_m,hm,mm,V$,I_,Vo,w_,dm,fm,ki,Bc=Re(()=>{cy=require("msgpackr");ti();lm=x(K()),N_=new Uint8Array([1,1,1,1,4,64,0,0]),vc=new Uint8Array([1,1,1,1,1,0,0,0]),Em=new Uint8Array([1,1,1,1,3,64,0,0]),F$=Symbol("local-timestamp"),Pc=Symbol("metadata"),Uc=new Uint8Array(8),q$=new DataView(Uc.buffer,0,8),um=0,ly=0,k$=1,uy=3,_m=4,hm=16,mm=1,Vo=0,w_=-1,dm=0,fm=class extends cy.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(n,s){if(Vo||w_>=0){let i=0,o=Vo;o&&(i+=8,Vo=0);let c=w_,l=dm;c>=0&&(i+=2,w_=-1,l&&(i+=8,dm=0));let _=V$=r.call(this,n,s|2048|i);I_=_.subarray((_.start||0)+i,_.end);let u=_.start||0;return o&&(N_[4]=o,N_[5]=o>>8,_.set(N_,u),u+=8),c>=0&&(_[u++]=c,_[u++]=0,l&&(_.dataView||(_.dataView=new DataView(_.buffer,_.byteOffset,_.byteLength))).setFloat64(u,l)),_}else return r.call(this,n,s)}}decode(t,r){let n=r?.start||0,s=r>-1?r:r?.end||t.length,i=t[n],o=0;try{if(i<32&&s>2){let c=n,l;if(i===2){if(t.copy)t.copy(Uc,0,c),c+=8;else for(let d=0;d<8;d++)Uc[d]=t[c++];l=$$(),i=t[c]}let _;i<32&&(o=i,c+=2,o&hm&&(_=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8));let u=super.decode(t.subarray(c,s),s-c);return{localTime:l,value:u,[Pc]:o,expiresAt:_}}return super.decode(t,r)}catch(c){throw c.message+=", data: "+t.slice(0,40).toString("hex"),c}}};a($$,"getTimestamp");a(D_,"handleLocalTimeForGets");ki=[];setInterval(()=>{for(let e=0;e<ki.length;e++){let t=ki[e].deref();!t||t.isDone||t.isCommitted?ki.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(lm.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):lm.error("Read transaction detected that has been open too long (over one minute), make sure read transactions are quickly closed",t)),t.openTimer++):t.openTimer=1)}},15e3).unref();a(pm,"getUpdateRecord")});var Hc=g((Pae,fy)=>{"use strict";var dy=ne(),Y$=P(),{RecordEncoder:K$}=(Bc(),ie(_y)),Mae=require("fs");dy.initSync();var W$=dy.get(Y$.CONFIG_PARAMS.STORAGE_CACHING)!==!1,Sm=class{static{a(this,"OpenDBIObject")}constructor(t,r=!1){this.dupSort=t===!0,this.encoding=t?"ordered-binary":"msgpack",this.useVersions=r,this.sharedStructuresKey=Symbol.for("structures"),r&&(this.cache=W$&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:K$})}};fy.exports=Sm});var xc=g((vae,Ey)=>{"use strict";var Fr=ne(),cn=P();Fr.initSync();var L_=class{static{a(this,"OpenEnvironmentObject")}constructor(t,r=!1){this.path=t,this.mapSize=1073741824,this.maxDbs=1e4,this.maxReaders=2048,this.sharedStructuresKey=Symbol.for("structures"),this.readOnly=r,this.trackMetrics=!0,this.eventTurnBatching=!1,this.noSync=Fr.get(cn.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Fr.get(cn.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Fr.get(cn.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Fr.get(cn.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Fr.get(cn.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Fr.get(cn.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Fr.get(cn.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Fr.get(cn.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Fr.get(cn.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Fr.get(cn.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Fr.get(cn.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Fr.get(cn.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};Ey.exports=L_;L_.MAX_DBS=1e4});var We=g((Hae,by)=>{"use strict";var gm=require("lmdb"),Cn=require("fs-extra"),qr=require("path"),M_=xr(),py=K(),Er=vr().LMDB_ERRORS_ENUM,P_=ay(),Rm=Hc(),Sy=xc(),ri=dt(),hy=P(),{table:Q$,resetDatabases:z$}=(Ae(),ie(ke)),my=ne(),Dn=ri.INTERNAL_DBIS_NAME,Ty=ri.DBI_DEFINITION_NAME,J$="data.mdb",X$="lock.mdb",Gc=".mdb",j$="-lock",Tm=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=ln(t,r),this.key_type=this.dbi[ri.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[ri.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new gm.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function U_(e,t){if(e===void 0)throw new Error(Er.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(Er.ENV_NAME_REQUIRED)}a(U_,"pathEnvNameValidation");async function Am(e,t,r=!0){try{await Cn.access(e)}catch(n){throw n.code==="ENOENT"?new Error(Er.INVALID_BASE_PATH):n}try{let n=qr.join(e,t+Gc);return await Cn.access(n,Cn.constants.R_OK|Cn.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await Cn.access(qr.join(e,t,J$),Cn.constants.R_OK|Cn.constants.F_OK),qr.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(Er.INVALID_ENVIRONMENT)}else throw new Error(Er.INVALID_ENVIRONMENT);throw n}}a(Am,"validateEnvironmentPath");function v_(e,t){if(M_.validateEnv(e),t===void 0)throw new Error(Er.DBI_NAME_REQUIRED)}a(v_,"validateEnvDBIName");async function Z$(e,t,r=!1,n=!1){U_(e,t);let s=qr.basename(e);t=t.toString();let i=my.get(hy.CONFIG_PARAMS.DATABASES);i||my.setProperty(hy.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await Am(e,t,n),gy(e,t,r)}catch(o){if(o.message===Er.INVALID_ENVIRONMENT){let c=qr.join(e,t);await Cn.mkdirp(n?c:e);let l=new Sy(n?c:c+Gc,!1),_=gm.open(l);_.dbis=Object.create(null);let u=new Rm(!1);_.openDB(Dn,u),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let d=Om(e,t,r);return _[ri.ENVIRONMENT_NAME_KEY]=d,global.lmdb_map[d]=_,_}throw o}}a(Z$,"createEnvironment");async function e1(e,t,r,n=!0){U_(e,t),t=t.toString();let s=qr.join(e,t);return Q$({table:t,database:qr.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(e1,"copyEnvironment");async function gy(e,t,r=!1){U_(e,t),t=t.toString();let n=Om(e,t,r);if(global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null)),global.lmdb_map[n]!==void 0)return global.lmdb_map[n];let s=await Am(e,t),i=qr.join(e,t+Gc),o=s!=i,c=new Sy(s,o),l=gm.open(c);l.dbis=Object.create(null);let _=Ay(l);for(let u=0;u<_.length;u++)ln(l,_[u]);return l[ri.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(gy,"openEnvironment");async function t1(e,t,r=!1){U_(e,t),t=t.toString();let n=qr.join(e,t+Gc),s=await Am(e,t);if(global.lmdb_map!==void 0){let i=Om(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await Ry(o),delete global.lmdb_map[i]}}await Cn.remove(s),await Cn.remove(s===n?s+j$:qr.join(qr.dirname(s),X$))}a(t1,"deleteEnvironment");async function Ry(e){M_.validateEnv(e);let t=e[ri.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(Ry,"closeEnvironment");function Om(e,t,r=!1){let s=`${qr.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(Om,"getCachedEnvironmentName");function r1(e){M_.validateEnv(e);let t=Object.create(null),r=ln(e,Dn);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==Dn)try{t[n]=Object.assign(new P_,s)}catch{py.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(r1,"listDBIDefinitions");function Ay(e){M_.validateEnv(e);let t=[],r=ln(e,Dn);for(let{key:n}of r.getRange({start:!1}))n!==Dn&&t.push(n);return t}a(Ay,"listDBIs");function n1(e,t){let n=ln(e,Dn).getEntry(t),s=new P_;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{py.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(n1,"getDBIDefinition");function Oy(e,t,r,n=!r){if(v_(e,t),t=t.toString(),t===Dn)throw new Error(Er.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return ln(e,t)}catch(s){if(s.message===Er.DBI_DOES_NOT_EXIST){let i=new Rm(r,n===!0),o=e.openDB(t,i),c=new P_(r===!0,n);return o[Ty]=c,ln(e,Dn).putSync(t,c),e.dbis[t]=o,o}throw s}}a(Oy,"createDBI");function ln(e,t){if(v_(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==Dn?r=n1(e,t):r=new P_,r===void 0)throw new Error(Er.DBI_DOES_NOT_EXIST);let n;try{let s=new Rm(r.dup_sort,r.useVersions);if(n=e.openDB(t,s),n.db===void 0)throw new Error("MDB_NOTFOUND")}catch(s){throw s.message.includes("MDB_NOTFOUND")===!0?new Error(Er.DBI_DOES_NOT_EXIST):s}return n[Ty]=r,e.dbis[t]=n,n}a(ln,"openDBI");function s1(e,t){v_(e,t),t=t.toString();let r=ln(e,t),n=r.getStats();return r[ri.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(s1,"statDBI");async function i1(e,t){try{let r=qr.join(e,t+Gc);return(await Cn.stat(r)).size}catch{throw new Error(Er.INVALID_ENVIRONMENT)}}a(i1,"environmentDataSize");function o1(e,t){if(v_(e,t),t=t.toString(),t===Dn)throw new Error(Er.CANNOT_DROP_INTERNAL_DBIS_NAME);ln(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],ln(e,Dn).removeSync(t)}a(o1,"dropDBI");function a1(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{ln(e,i)}catch(o){if(o.message===Er.DBI_DOES_NOT_EXIST)Oy(e,i,i!==t,i===t),n=!0;else throw o}}n&&z$()}a(a1,"initializeDBIs");by.exports={openDBI:ln,openEnvironment:gy,createEnvironment:Z$,listDBIs:Ay,listDBIDefinitions:r1,createDBI:Oy,dropDBI:o1,statDBI:s1,deleteEnvironment:t1,initializeDBIs:a1,TransactionCursor:Tm,environmentDataSize:i1,copyEnvironment:e1,closeEnvironment:Ry}});var Ny=g((Gae,yy)=>{"use strict";var bm=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};yy.exports=bm});var wy=g((qae,Iy)=>{"use strict";var ym=class{static{a(this,"UpdateRecordsResponseObject")}constructor(t=[],r=[],n=void 0,s=[]){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n,this.original_records=s}};Iy.exports=ym});var Dy=g((Vae,Cy)=>{"use strict";var Nm=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};Cy.exports=Nm});var $o=g((Qae,Py)=>{"use strict";var c1=We(),l1=Ny(),u1=wy(),_1=Dy(),zn=xr(),Fc=vr().LMDB_ERRORS_ENUM,d1=dt(),Rs=P(),f1=z(),E1=require("uuid"),Yae=require("lmdb"),{handleHDBError:h1,hdb_errors:m1}=se(),{OVERFLOW_MARKER:Kae,MAX_SEARCH_KEY_LENGTH:Wae}=d1,Ly=ne();Ly.initSync();var B_=Ly.get(Rs.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),Im=Rs.TIME_STAMP_NAMES_ENUM.CREATED_TIME,Vi=Rs.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function p1(e,t,r,n,s=zn.getNextMonotonicTime()){Lm(e,t,r,n),wm(e,t,r);let i=new l1,o=[],c=[];for(let l=0;l<n.length;l++){let _=n[l];My(_,!0,s);let u=S1(e,t,r,_),d=_[t];o.push(u),c.push(d)}return Cm(o,c,n,i,s)}a(p1,"insertRecords");function S1(e,t,r,n){let s=n[t];return e.dbis[t].ifNoExists(s,()=>{for(let i=0;i<r.length;i++){let o=r[i];if(o===t||n.hasOwnProperty(o)===!1)continue;let c=n[o];if(typeof c=="function"){let u=c([[{}]]);Array.isArray(u)&&(c=u[0][Rs.FUNC_VAL],n[o]=c)}let l=zn.getIndexedValues(c),_=e.dbis[o];if(l){B_&&_.prefetch(l.map(u=>({key:u,value:s})),H_);for(let u=0,d=l.length;u<d;u++)_.put(l[u],s)}}B_&&e.dbis[t].prefetch([s],H_),e.dbis[t].put(s,n,n[Vi])})}a(S1,"insertRecord");function T1(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(T1,"removeSkippedRecords");function My(e,t,r){let n=r>0;(n||!Number.isInteger(e[Vi]))&&(e[Vi]=r||(r=zn.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[Im]))&&(e[Im]=r||zn.getNextMonotonicTime()):delete e[Im]}a(My,"setTimestamps");function wm(e,t,r){r.indexOf(Rs.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(Rs.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(Rs.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(Rs.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),c1.initializeDBIs(e,t,r)}a(wm,"initializeTransaction");async function g1(e,t,r,n,s=zn.getNextMonotonicTime()){Lm(e,t,r,n),wm(e,t,r);let i=new u1,o=[],c=[],l=[];for(let _=0;_<n.length;_++){let u=n[_],d=u[t],E;try{E=Dm(e,t,u,d,i,!0,s)}catch{i.skipped_hashes.push(d),o.push(_);continue}c.push(E),l.push(d)}return Cm(c,l,n,i,s,o)}a(g1,"updateRecords");async function R1(e,t,r,n,s=zn.getNextMonotonicTime()){try{Lm(e,t,r,n)}catch(l){throw h1(l,l.message,m1.HTTP_STATUS_CODES.BAD_REQUEST)}wm(e,t,r);let i=new _1,o=[],c=[];for(let l=0;l<n.length;l++){let _=n[l],u;f1.isEmpty(_[t])?(u=E1.v4(),_[t]=u):u=_[t];let d=Dm(e,t,_,u,i,!1,s);o.push(d),c.push(u)}return Cm(o,c,n,i,s)}a(R1,"upsertRecords");async function Cm(e,t,r,n,s,i=[]){let o=await Promise.all(e);for(let c=0,l=o.length;c<l;c++)o[c]===!0?n.written_hashes.push(t[c]):(n.skipped_hashes.push(t[c]),i.push(c));return n.txn_time=s||zn.getNextMonotonicTime(),T1(r,i),n}a(Cm,"finalizeWrite");function Dm(e,t,r,n,s,i=!1,o){let c=e.dbis[t],l=c.getEntry(n),_=l?.value,u=_;if(!_){if(i)return!1;_={}}if(My(r,!u,o),Number.isInteger(r[Vi])&&_[Vi]>r[Vi])return!1;u&&s.original_records.push(_);let d,E=a(()=>{for(let h in r){if(!r.hasOwnProperty(h)||h===t)continue;let p=r[h],S=e.dbis[h];if(S===void 0)continue;let T=_[h];if(typeof p=="function"){let b=p([[_]]);Array.isArray(b)&&(p=b[0][Rs.FUNC_VAL],r[h]=p)}if(p===T)continue;let A=zn.getIndexedValues(T);if(A){B_&&S.prefetch(A.map(b=>({key:b,value:n})),H_);for(let b=0,I=A.length;b<I;b++)S.remove(A[b],n)}if(A=zn.getIndexedValues(p),A){B_&&S.prefetch(A.map(b=>({key:b,value:n})),H_);for(let b=0,I=A.length;b<I;b++)S.put(A[b],n)}}let f=Object.assign({},_,r);c.put(n,f,f[Vi])},"do_put");return l?d=c.ifVersion(n,l.version,E):d=c.ifNoExists(n,E),d.then(f=>f?!0:Dm(e,t,r,n,s,i,o))}a(Dm,"updateUpsertRecord");function A1(e,t,r){if(zn.validateEnv(e),t===void 0)throw new Error(Fc.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(Fc.WRITE_ATTRIBUTES_REQUIRED):new Error(Fc.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(A1,"validateBasic");function Lm(e,t,r,n){if(A1(e,t,r),!Array.isArray(n))throw n===void 0?new Error(Fc.RECORDS_REQUIRED):new Error(Fc.RECORDS_MUST_BE_ARRAY)}a(Lm,"validateWrite");function H_(){}a(H_,"noop");Py.exports={insertRecords:p1,updateRecords:g1,upsertRecords:R1}});var $i=g((Jae,O1)=>{O1.exports={hdb_table:{hash_attribute:"id",name:"hdb_table",schema:"system",residence:["*"],attributes:[{attribute:"id"},{attribute:"name"},{attribute:"hash_attribute"},{attribute:"schema"},{attribute:"residence"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_attribute:{hash_attribute:"id",name:"hdb_attribute",schema:"system",residence:["*"],attributes:[{attribute:"id"},{attribute:"schema"},{attribute:"table"},{attribute:"attribute"},{attribute:"schema_table"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_schema:{hash_attribute:"name",name:"hdb_schema",schema:"system",residence:["*"],attributes:[{attribute:"name"},{attribute:"createddate"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_user:{hash_attribute:"username",name:"hdb_user",schema:"system",residence:["*"],attributes:[{attribute:"username"},{attribute:"password"},{attribute:"role"},{attribute:"active"},{attribute:"hash"},{attribute:"refresh_token"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_role:{hash_attribute:"id",name:"hdb_role",schema:"system",attributes:[{attribute:"id"},{attribute:"role"},{attribute:"permission"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}],residence:["*"]},hdb_job:{hash_attribute:"id",name:"hdb_job",schema:"system",attributes:[{attribute:"id"},{attribute:"user"},{attribute:"type"},{attribute:"status"},{attribute:"start_datetime"},{attribute:"end_datetime"},{attribute:"message"},{attribute:"created_datetime"},{attribute:"request"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_license:{hash_attribute:"license_key",name:"hdb_license",schema:"system",attributes:[{attribute:"license_key"},{attribute:"company"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_info:{hash_attribute:"info_id",name:"hdb_info",schema:"system",attributes:[{attribute:"info_id"},{attribute:"data_version_num"},{attribute:"hdb_version_num"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_nodes:{hash_attribute:"name",name:"hdb_nodes",schema:"system",attributes:[{attribute:"name"},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_analytics:{hash_attribute:"id",name:"hdb_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]},hdb_raw_analytics:{hash_attribute:"id",name:"hdb_raw_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{attribute:"time"},{attribute:"metrics"}]},hdb_temp:{hash_attribute:"id",name:"hdb_temp",schema:"system",attributes:[{attribute:"id"}]},hdb_durable_session:{hash_attribute:"id",name:"hdb_durable_session",schema:"system",attributes:[{attribute:"id"}]},hdb_session_will:{hash_attribute:"id",name:"hdb_session_will",schema:"system",attributes:[{attribute:"id"}]}}});var Xn=g((Xae,By)=>{"use strict";var vy=z(),Uy=P(),Yo=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Jn=require("joi"),ni={schema_format:{pattern:Yo,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},b1=Jn.alternatives(Jn.string().min(1).max(ni.schema_length.maximum).pattern(Yo).messages({"string.pattern.base":"{:#label} "+ni.schema_format.message}),Jn.number(),Jn.array()).required(),y1=Jn.alternatives(Jn.string().min(1).max(ni.schema_length.maximum).pattern(Yo).messages({"string.pattern.base":"{:#label} "+ni.schema_format.message}),Jn.number()),N1=Jn.alternatives(Jn.string().min(1).max(ni.schema_length.maximum).pattern(Yo).messages({"string.pattern.base":"{:#label} "+ni.schema_format.message}),Jn.number()).required();function I1(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>ni.schema_length.maximum?`'${e}' maximum of 250 characters`:Yo.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(I1,"checkValidTable");function w1(e,t){return vy.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(w1,"validateSchemaExists");function C1(e,t){let r=t.state.ancestors[0].schema;return vy.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(C1,"validateTableExists");function D1(e,t){return e.toLowerCase()===Uy.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${Uy.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(D1,"validateSchemaName");By.exports={common_validators:ni,schema_regex:Yo,hdb_schema_table:b1,validateSchemaExists:w1,validateTableExists:C1,validateSchemaName:D1,checkValidTable:I1,hdb_database:y1,hdb_table:N1}});var x_=g((Zae,Hy)=>{var{common_validators:jn}=Xn(),kc=st(),qc="is required",Tt={database:{presence:!1,format:jn.schema_format,length:jn.schema_length},schema:{presence:!1,format:jn.schema_format,length:jn.schema_length},table:{presence:!0,format:jn.schema_format,length:jn.schema_length},attribute:{presence:!0,format:jn.schema_format,length:jn.schema_length},hash_attribute:{presence:!0,format:jn.schema_format,length:jn.schema_length}};function Vc(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(Vc,"makeAttributesStrings");function L1(e){return e=Vc(e),Tt.table.presence=!1,Tt.attribute.presence=!1,Tt.hash_attribute.presence=!1,kc.validateObject(e,Tt)}a(L1,"schema_object");function M1(e){return e=Vc(e),Tt.table.presence={message:qc},Tt.attribute.presence=!1,Tt.hash_attribute.presence=!1,kc.validateObject(e,Tt)}a(M1,"table_object");function P1(e){return e=Vc(e),Tt.table.presence={message:qc},Tt.attribute.presence=!1,kc.validateObject(e,Tt)}a(P1,"create_table_object");function U1(e){return e=Vc(e),Tt.table.presence={message:qc},Tt.attribute.presence={message:qc},Tt.hash_attribute.presence=!1,kc.validateObject(e,Tt)}a(U1,"attribute_object");function v1(e){return e=Vc(e),Tt.table.presence={message:qc},Tt.attribute.presence=!1,Tt.hash_attribute.presence=!1,kc.validateObject(e,Tt)}a(v1,"describe_table");function B1(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(B1,"validateTableResidence");Hy.exports={schema_object:L1,create_table_object:P1,table_object:M1,attribute_object:U1,describe_table:v1,validateTableResidence:B1}});var Gy=g((tce,xy)=>{"use strict";var H1=require("uuid"),Mm=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||H1.v4(),this.schema_table=`${this.schema}.${this.table}`}};xy.exports=Mm});var G_=g((nce,Fy)=>{"use strict";var x1=Gy(),Pm=class extends x1{static{a(this,"LMDBCreateAttributeObject")}constructor(t,r,n,s,i=!0,o=!1){super(t,r,n,s),this.dup_sort=i,this.is_hash_attribute=o}};Fy.exports=Pm});var ky=g((ice,qy)=>{"use strict";qy.exports=F1;var G1="inserted";function F1(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===G1?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(F1,"returnObject")});var F_=g((ace,Wy)=>{"use strict";var q1=P(),Um=We(),k1=$o(),{getSystemSchemaPath:V1,getSchemaPath:$1}=ze(),Y1=$i(),K1=x_(),W1=G_(),Q1=ky(),{handleHDBError:Vy,hdb_errors:Yy}=se(),$y=z(),{HTTP_STATUS_CODES:z1}=Yy,vm=Y1.hdb_attribute,Ky=[];for(let e=0;e<vm.attributes.length;e++)Ky.push(vm.attributes[e].attribute);var J1="inserted";Wy.exports=X1;async function X1(e){let t=K1.attribute_object(e);if(t)throw Vy(new Error,t.message,Yy.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=!e.skip_table_check&&$y.checkGlobalSchemaTable(e.schema,e.table);if(r)throw Vy(new Error,r,z1.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=$y.isEmpty(e.dup_sort)||e.dup_sort=="true";let n=[];if(global.hdb_schema[e.schema]&&global.hdb_schema[e.schema][e.table]&&(n=global.hdb_schema[e.schema][e.table].attributes),Array.isArray(n)&&n.length>0){for(let i of n)if(i.attribute===e.attribute)throw new Error(`attribute '${i.attribute}' already exists in ${e.schema}.${e.table}`)}let s=new W1(e.schema,e.table,e.attribute,e.id);try{let i=await Um.openEnvironment($1(e.schema,e.table),e.table);if(i.dbis[e.attribute]!==void 0)throw new Error(`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`);Um.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await Um.openEnvironment(V1(),q1.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await k1.insertRecords(o,vm.hash_attribute,Ky,[s]);return Q1(J1,c,{records:[s]},l)}catch(i){throw i}}a(X1,"lmdbCreateAttribute")});var Hm=g((lce,zy)=>{var{hdb_table:j1,hdb_database:Qy}=Xn(),Z1=st(),Bm=require("joi"),eY={undefined:"undefined",null:"null"},tY=a((e,t)=>{let r=Object.keys(e),n=r.length,s;for(let i=0;i<n;i++){let o=r[i];(!o||o.length===0||eY[o]!==void 0)&&(s===void 0?s=`Invalid attribute name: '${o}'`:s+=`. Invalid attribute name: '${o}'`)}return s?t.message(s):e},"custom_records_val"),rY=Bm.object({database:Qy,schema:Qy,table:j1,records:Bm.array().items(Bm.object().custom(tY)).required()});zy.exports=function(e){return Z1.validateBySchema(e,rY)}});var $c=g((dce,Xy)=>{"use strict";var As=z(),Jy=K(),_ce=Hm(),{getDatabases:nY}=(Ae(),ie(ke)),{ClientError:Yi}=se();Xy.exports=sY;function sY(e){if(As.isEmpty(e))throw new Yi("invalid update parameters defined.");if(As.isEmptyOrZeroLength(e.schema))throw new Yi("invalid schema specified.");if(As.isEmptyOrZeroLength(e.table))throw new Yi("invalid table specified.");if(!Array.isArray(e.records))throw new Yi("records must be an array");let t=nY()[e.schema]?.[e.table];if(As.isEmpty(t))throw new Yi(`could not retrieve schema:${e.schema} and table ${e.table}`);let r=t.primaryKey,n=new Set,s={},i=!1;return e.operation==="update"&&(i=!0),e.records.forEach(o=>{if(i&&As.isEmptyOrZeroLength(o[r]))throw Jy.error("a valid hash attribute must be provided with update record:",o),new Yi("a valid hash attribute must be provided with update record, check log for more info");if(!As.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw Jy.error(`a valid hash value must be provided with ${e.operation} record:`,o),new Yi(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!As.isEmpty(o[r])&&o[r]!==""&&n.has(As.autoCast(o[r]))&&(o.skip=!0),n.add(As.autoCast(o[r]));for(let c in o)s[c]=1}),s[r]=1,{schema_table:t,hashes:Array.from(n),attributes:Object.keys(s)}}a(sY,"insertUpdateValidate")});var Zy=g((Ece,jy)=>{"use strict";var xm=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};jy.exports=xm});var rN=g((mce,tN)=>{"use strict";var Gm=We(),iY=K(),eN=vr().LMDB_ERRORS_ENUM;tN.exports=oY;async function oY(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 Gm.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==eN.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await Gm.closeEnvironment(global.lmdb_map[n]),await Gm.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==eN.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){iY.error(t)}}a(oY,"cleanLMDBMap")});var Os=g((Sce,oN)=>{"use strict";var Yc=require("crypto"),aY=ne(),{CONFIG_PARAMS:cY}=P(),sN="aes-256-cbc",lY=32,uY=16,Fm=64,iN=32,_Y=Fm+iN,nN=new Map;oN.exports={encrypt:dY,decrypt:fY,createNatsTableStreamName:EY};function dY(e){let t=Yc.randomBytes(lY),r=Yc.randomBytes(uY),n=Yc.createCipheriv(sN,Buffer.from(t),r),s=n.update(e);s=Buffer.concat([s,n.final()]);let i=t.toString("hex"),o=r.toString("hex"),c=s.toString("hex");return i+o+c}a(dY,"encrypt");function fY(e){let t=e.substr(0,Fm),r=e.substr(Fm,iN),n=e.substr(_Y,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=Yc.createDecipheriv(sN,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(fY,"decrypt");function EY(e,t){let r=aY.get(cY.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=nN.get(r);return n||(n=Yc.createHash("md5").update(r).digest("hex"),nN.set(r,n)),n}a(EY,"createNatsTableStreamName")});var si=g((Rce,cN)=>{"use strict";var gce=kr(),Kc=K(),aN=x_(),hY=Os(),q_=z(),{handleHDBError:k_,hdb_errors:mY}=se(),{HDB_ERROR_MSGS:V_,HTTP_STATUS_CODES:qm}=mY,pY=ne();pY.initSync();var{getDatabases:km}=(Ae(),ie(ke)),SY=require("fs-extra");cN.exports={describeAll:TY,describeTable:$_,describeSchema:gY};async function TY(e={}){try{let t=q_.isEmptyOrZeroLength(e),r=!!e.bypass_auth,n,s;!t&&!r&&(n=e.hdb_user?.role?.permission,s=n?.super_user||n?.cluster_user);let i=km(),o={},c={},l=[],_=e?.exact_count;for(let d in i){o[d]=!0,!t&&!s&&!r&&(c[d]=e.hdb_user?.role?.permission[d]?.describe);let E=i[d];for(let f in E)try{let h;if(t||s||r)h=await $_({schema:d,table:f,exact_count:_});else if(n&&n[d].describe&&n[d].tables[f].describe){let p=n[d].tables[f].attribute_permissions;h=await $_({schema:d,table:f,exact_count:_},p)}h&&l.push(h)}catch(h){Kc.error(h)}}let u={};for(let d in l)t||s||r?(u[l[d].schema]==null&&(u[l[d].schema]={}),u[l[d].schema][l[d].name]=l[d],o[l[d].schema]&&delete o[l[d].schema]):c[l[d].schema]&&(u[l[d].schema]==null&&(u[l[d].schema]={}),u[l[d].schema][l[d].name]=l[d],o[l[d].schema]&&delete o[l[d].schema]);for(let d in o)t||s||r?u[d]={}:c[d]&&(u[d]={});return u}catch(t){return Kc.error("Got an error in describeAll"),Kc.error(t),k_(new Error,V_.DESCRIBE_ALL_ERR)}}a(TY,"describeAll");async function $_(e,t){q_.transformReq(e);let{schema:r,table:n}=e;r=r?.toString(),n=n?.toString();let s=t;e.hdb_user&&!e.hdb_user?.role?.permission?.super_user&&(s=e.hdb_user?.role?.permission[r]?.tables[n]?.attribute_permissions);let i=aN.describe_table(e);if(i)throw i;let c=km()[r];if(!c)throw k_(new Error,V_.SCHEMA_NOT_FOUND(e.schema),qm.NOT_FOUND);let l=c[n];if(!l)throw k_(new Error,V_.TABLE_NOT_FOUND(e.schema,e.table),qm.NOT_FOUND);function _(f){u.push(Object.assign({},{attribute:f.attribute,type:f.type,elements:f.elements?.type,indexed:f.indexed,is_primary_key:f.isPrimaryKey,assigned_created_time:f.assignCreatedTime,assigned_updated_time:f.assignUpdatedTime,nullable:f.nullable,properties:f.properties?f.properties.map(h=>({type:h.type,name:h.name})):void 0}))}a(_,"pushAtt");let u=[];if(s){let f={};s.forEach(h=>{h.describe&&(f[h.attribute_name]=!0)}),l.attributes.forEach(h=>{f[h.name]&&_(h)})}else l.attributes?.forEach(f=>_(f));let d;try{d=(await SY.stat(l.primaryStore.env.path)).size}catch(f){Kc.warn("unable to get database size",f)}let E={schema:r,name:l.tableName,hash_attribute:l.attributes.find(f=>f.isPrimaryKey||f.is_hash_attribute)?.name,audit:l.audit,schema_defined:l.schemaDefined,attributes:u,db_size:d};E.clustering_stream_name=hY.createNatsTableStreamName(E.schema,E.name);try{let f=l.getRecordCount({exactCount:e.exact_count==="true"});E.record_count=f.recordCount,E.estimated_record_range=f.estimatedRange;let h=l.auditStore;if(h)for(let p of h.getKeys({reverse:!0,limit:1}))E.last_updated_record=p[0];if(!E.last_updated_record&&l.indices.__updatedtime__)for(let p of l.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))E.last_updated_record=p}catch(f){Kc.warn(`unable to stat table dbi due to ${f}`)}return E}a($_,"descTable");async function gY(e){q_.transformReq(e);let t=aN.schema_object(e);if(t)throw t;let r;e.hdb_user&&!e.hdb_user?.role?.permission?.super_user&&(r=e.hdb_user?.role?.permission[e.schema]);let n=e.schema.toString(),i=km()[n];if(!i)throw k_(new Error,V_.SCHEMA_NOT_FOUND(e.schema),qm.NOT_FOUND);let o={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),q_.isEmpty(l)||l.describe){let _=await $_({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);_&&(o[_.name]=_)}}return o}a(gY,"describeSchema")});var ii=g((yce,fN)=>{var RY=$i(),{callbackify:uN,promisify:AY}=require("util"),{getDatabases:_N}=(Ae(),ie(ke));fN.exports={setSchemaDataToGlobal:lN,getTableSchema:OY,getSystemSchema:bY,setSchemaDataToGlobalAsync:AY(lN)};var dN=si(),Oce=uN(dN.describeAll),bce=uN(dN.describeTable);function lN(e){global.hdb_schema=_N(),e&&e()}a(lN,"setSchemaDataToGlobal");function OY(e,t,r){let n=_N()[e];if(!n)return r(`schema ${e} does not exist`);let s=n[t];return s?r(null,{schema:e,name:t,hash_attribute:s.primaryKey}):r(`table ${e}.${t} does not exist`)}a(OY,"getTableSchema");function bY(){return RY}a(bY,"getSystemSchema")});var un=g((Ice,pN)=>{"use strict";var K_=Hm(),Yt=z(),yY=require("util"),W_=Ln(),NY=ii(),EN=K(),{handleHDBError:Ki,hdb_errors:IY}=se(),{HTTP_STATUS_CODES:Wi}=IY,wY=yY.promisify(NY.getTableSchema),CY="updated",hN="inserted",mN="upserted";pN.exports={insert:LY,update:MY,upsert:PY,validation:DY,flush:UY};async function DY(e){if(Yt.isEmpty(e))throw new Error("invalid update parameters defined.");if(Yt.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if(Yt.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await wY(e.schema,e.table),r=K_(e);if(r)throw r;if(!Array.isArray(e.records))throw new Error("records must be an array");let n=t.hash_attribute,s=new Set,i={},o=!1;return e.operation==="update"&&(o=!0),e.records.forEach(c=>{if(o&&Yt.isEmptyOrZeroLength(c[n]))throw EN.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(!Yt.isEmptyOrZeroLength(c[n])&&(c[n]==="null"||c[n]==="undefined"))throw EN.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[n]}" is not a valid hash attribute value`);!Yt.isEmpty(c[n])&&c[n]!==""&&s.has(Yt.autoCast(c[n]))&&(c.skip=!0),s.add(Yt.autoCast(c[n]));for(let l in c)i[l]=1}),i[n]=1,{schema_table:t,hashes:Array.from(s),attributes:Object.keys(i)}}a(DY,"validation");async function LY(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=K_(e);if(t)throw Ki(new Error,t.message,Wi.BAD_REQUEST);Yt.transformReq(e);let r=Yt.checkSchemaTableExist(e.schema,e.table);if(r)throw Ki(new Error,r,Wi.BAD_REQUEST);let n=await W_.createRecords(e);return Y_(hN,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(LY,"insertData");async function MY(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=K_(e);if(t)throw Ki(new Error,t.message,Wi.BAD_REQUEST);Yt.transformReq(e);let r=Yt.checkSchemaTableExist(e.schema,e.table);if(r)throw Ki(new Error,r,Wi.BAD_REQUEST);let n=await W_.updateRecords(e);return Yt.isEmpty(n.existing_rows)?Y_(CY,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):Y_(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(MY,"updateData");async function PY(e){if(e.operation!=="upsert")throw Ki(new Error,"invalid operation, must be upsert",Wi.INTERNAL_SERVER_ERROR);let t=K_(e);if(t)throw Ki(new Error,t.message,Wi.BAD_REQUEST);Yt.transformReq(e);let r=Yt.checkSchemaTableExist(e.schema,e.table);if(r)throw Ki(new Error,r,Wi.BAD_REQUEST);let n=await W_.upsertRecords(e);return Y_(mN,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(PY,"upsertData");function Y_(e,t,r,n,s,i){let o={message:`${e} ${t.length} of ${t.length+n.length} records`,new_attributes:s,txn_time:i};return e===hN?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===mN?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(Y_,"returnObject");function UY(e){return Yt.transformReq(e),W_.flush(e.schema,e.table)}a(UY,"flush")});var $m=g((Cce,gN)=>{var vY=st(),Vm=require("joi"),{hdb_table:BY,hdb_database:SN}=Xn(),TN={schema:SN,database:SN,table:BY},HY={date:Vm.date().iso().required()},xY={timestamp:Vm.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};gN.exports=function(e,t){let r=t==="timestamp"?{...TN,...xY}:{...TN,...HY},n=Vm.object(r);return vY.validateBySchema(e,n)}});var ON=g((Dce,AN)=>{var GY=st(),Ym=require("joi"),{hdb_table:FY,hdb_database:RN}=Xn(),qY=Ym.object({schema:RN,database:RN,table:FY,hash_values:Ym.array().required(),ids:Ym.array()});AN.exports=function(e){return GY.validateBySchema(e,qY)}});var yN=g((Lce,bN)=>{"use strict";var Km=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i){this.operation=t,this.schema=r,this.table=n,this.hash_attribute=s,this.records=i}},Wm=class{static{a(this,"NoSQLSeachObject")}constructor(t,r,n,s,i,o){this.schema=t,this.table=r,this.search_attribute=n,this.hash_attribute=s,this.get_attributes=i,this.search_value=o}},Qm=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};bN.exports={InsertObject:Km,NoSQLSeachObject:Wm,DeleteResponseObject:Qm}});var Ji=g((Pce,DN)=>{"use strict";var IN=$m(),kY=ON(),Qi=z(),NN=require("moment"),wN=K(),{promisify:VY,callbackify:$Y}=require("util"),zi=P(),YY=ii(),zm=VY(YY.getTableSchema),Jm=Ln(),{DeleteResponseObject:KY}=yN(),{handleHDBError:oi,hdb_errors:WY}=se(),{HDB_ERROR_MSGS:Q_,HTTP_STATUS_CODES:ai}=WY,QY="records successfully deleted",zY=$Y(CN);DN.exports={delete:zY,deleteRecord:CN,deleteFilesBefore:JY,deleteAuditLogsBefore:XY};async function JY(e){let t=IN(e,"date");if(t)throw oi(t,t.message,ai.BAD_REQUEST,void 0,void 0,!0);if(Qi.transformReq(e),!NN(e.date,NN.ISO_8601).isValid())throw oi(new Error,Q_.INVALID_DATE,ai.BAD_REQUEST,zi.LOG_LEVELS.ERROR,Q_.INVALID_DATE,!0);let n=Qi.checkSchemaTableExist(e.schema,e.table);if(n)throw oi(new Error,n,ai.NOT_FOUND,zi.LOG_LEVELS.ERROR,n,!0);let s=await Jm.deleteRecordsBefore(e);if(await zm(e.schema,e.table),wN.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(JY,"deleteFilesBefore");async function XY(e){let t=IN(e,"timestamp");if(t)throw oi(t,t.message,ai.BAD_REQUEST,void 0,void 0,!0);if(Qi.transformReq(e),isNaN(e.timestamp))throw oi(new Error,Q_.INVALID_VALUE("Timestamp"),ai.BAD_REQUEST,zi.LOG_LEVELS.ERROR,Q_.INVALID_VALUE("Timestamp"),!0);let r=Qi.checkSchemaTableExist(e.schema,e.table);if(r)throw oi(new Error,r,ai.NOT_FOUND,zi.LOG_LEVELS.ERROR,r,!0);let n=await Jm.deleteAuditLogsBefore(e);return await zm(e.schema,e.table),wN.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(XY,"deleteAuditLogsBefore");async function CN(e){e.ids&&(e.hash_values=e.ids);let t=kY(e);if(t)throw oi(t,t.message,ai.BAD_REQUEST,void 0,void 0,!0);Qi.transformReq(e);let r=Qi.checkSchemaTableExist(e.schema,e.table);if(r)throw oi(new Error,r,ai.NOT_FOUND,zi.LOG_LEVELS.ERROR,r,!0);try{await zm(e.schema,e.table);let n=await Jm.deleteRecords(e);return Qi.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${QY}`),n}catch(n){if(n.message===zi.SEARCH_NOT_FOUND_MESSAGE){let s=new KY;return s.message=zi.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(CN,"deleteRecord")});var z_=g((vce,PN)=>{var jY=require("crypto"),LN=9;function ZY(e){let t=tK(LN),r=MN(e+t);return t+r}a(ZY,"createHash");function eK(e,t){let r=e?.substr(0,LN),n=r+MN(t+r);return e===n}a(eK,"validateHash");function tK(e){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ",r=t.length,n="";for(let s=0;s<e;s++){let i=Math.floor(Math.random()*r);n+=t[i]}return n}a(tK,"generateSalt");function MN(e){return jY.createHash("md5").update(e).digest("hex")}a(MN,"md5");PN.exports={hash:ZY,validate:eK}});var vN=g((Hce,UN)=>{var Xm=st(),er={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 rK(e){return er.password.presence=!0,er.username.presence=!0,er.role.presence=!0,er.active.presence=!0,Xm.validateObject(e,er)}a(rK,"addUserValidation");function nK(e){return er.password.presence=!1,er.username.presence=!0,er.role.presence=!1,er.active.presence=!1,Xm.validateObject(e,er)}a(nK,"alterUserValidation");function sK(e){return er.password.presence=!1,er.username.presence=!0,er.role.presence=!1,er.active.presence=!1,Xm.validateObject(e,er)}a(sK,"dropUserValidation");UN.exports={addUserValidation:rK,alterUserValidation:nK,dropUserValidation:sK}});var ct=g((Fce,HN)=>{"use strict";var{platform:Gce}=require("os"),iK="nats-server.zip",jm="nats-server",oK=process.platform==="win32"?`${jm}.exe`:jm,aK=/^[^\s.,*>]+$/,BN="__request__",cK=a(e=>`${e}.${BN}`,"REQUEST_SUBJECT"),lK={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},uK={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},_K={HUB:"hub.pid",LEAF:"leaf.pid"},dK={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},fK={SUCCESS:"success",ERROR:"error"},EK={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},hK={TXN:"txn",MSGID:"msgid"},Ko={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},mK={[Ko.ERR]:1,[Ko.WRN]:2,[Ko.INF]:3,[Ko.DBG]:4,[Ko.TRC]:5},pK={debug:"-D",trace:"-DVV"};HN.exports={NATS_SERVER_ZIP:iK,NATS_SERVER_NAME:jm,NATS_BINARY_NAME:oK,PID_FILES:_K,NATS_CONFIG_FILES:uK,SERVER_SUFFIX:dK,NATS_TERM_CONSTRAINTS_RX:aK,REQUEST_SUFFIX:BN,UPDATE_REMOTE_RESPONSE_STATUSES:fK,CLUSTER_STATUS_STATUSES:EK,REQUEST_SUBJECT:cK,SUBJECT_PREFIXES:hK,MSG_HEADERS:lK,LOG_LEVELS:Ko,LOG_LEVEL_FLAGS:pK,LOG_LEVEL_HIERARCHY:mK}});var GN=g((kce,xN)=>{"use strict";var J_=P(),X_=class{static{a(this,"BaseLicense")}constructor(t=0,r=J_.RAM_ALLOCATION_ENUM.DEFAULT,n=J_.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},Zm=class extends X_{static{a(this,"ExtendedLicense")}constructor(t=0,r=J_.RAM_ALLOCATION_ENUM.DEFAULT,n=J_.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};xN.exports={BaseLicense:X_,ExtendedLicense:Zm}});var Xi=g(($ce,YN)=>{"use strict";var Qo=require("fs-extra"),qN=z_(),kN=require("crypto"),SK=require("moment"),TK=require("uuid").v4,tr=K(),tp=require("path"),gK=z(),ci=P(),{totalmem:FN}=require("os"),RK=GN().ExtendedLicense,Wo="invalid license key format",AK="061183",OK="mofi25",bK="aes-256-cbc",yK=16,NK=32,VN=ne();VN.initSync();var ep;YN.exports={validateLicense:$N,generateFingerPrint:wK,licenseSearch:sp,getLicense:LK,checkMemoryLimit:MK};function rp(){return tp.join(VN.getHdbBasePath(),ci.LICENSE_KEY_DIR_NAME,ci.LICENSE_FILE_NAME)}a(rp,"getLicenseDirPath");function IK(){let e=rp();return tp.join(e,ci.LICENSE_FILE_NAME)}a(IK,"getLicenseFilePath");function np(){let e=rp();return tp.join(e,ci.REG_KEY_FILE_NAME)}a(np,"getFingerPrintFilePath");async function wK(){let e=np();try{return await Qo.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await CK();throw tr.error(`Error writing fingerprint file to ${e}`),tr.error(t),new Error("There was an error generating the fingerprint")}}a(wK,"generateFingerPrint");async function CK(){let e=TK(),t=qN.hash(e),r=np();try{await Qo.mkdirp(rp()),await Qo.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw tr.error(`Error writing fingerprint file to ${r}`),tr.error(n),new Error("There was an error generating the fingerprint")}return t}a(CK,"writeFingerprint");function $N(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:ci.RAM_ALLOCATION_ENUM.DEFAULT,version:ci.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return tr.error("empty license key passed to validate."),r;let n=np(),s=!1;try{s=Qo.statSync(n)}catch(i){tr.error(i)}if(s){let i;try{i=Qo.readFileSync(n,"utf8")}catch{tr.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(OK),c=o[1];c=Buffer.concat([Buffer.from(c)],yK);let l=Buffer.concat([Buffer.from(i)],NK),_=kN.createDecipheriv(bK,l,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let u=null;try{u=_.update(o[0],"hex","utf8"),u.trim(),u+=_.final("utf8")}catch{let f=DK(o[0],i);if(f)u=f;else throw r.valid_license=!1,r.valid_machine=!1,console.error(Wo),tr.error(Wo),new Error(Wo)}let d;if(isNaN(u))try{d=JSON.parse(u),r.version=d.version,r.exp_date=d.exp_date,isNaN(r.exp_date)&&(r.exp_date=new Date(r.exp_date).getTime()),d.ram_allocation&&(r.ram_allocation=d.ram_allocation)}catch{throw console.error(Wo),tr.error(Wo),new Error(Wo)}else r.exp_date=u;r.exp_date<SK().valueOf()&&(r.valid_date=!1),qN.validate(o[1],`${AK}${i}${t}`)||(r.valid_license=!1)}else r.valid_license=!1,r.valid_machine=!1;return r.valid_license&&r.valid_machine&&r.valid_date||tr.error("Invalid licence"),r}a($N,"validateLicense");function DK(e,t){try{let r=kN.createDecipher("aes192",t),n=r.update(e,"hex","utf8");return n.trim(),n+=r.final("utf8"),n}catch{tr.warn("Check old license failed")}}a(DK,"checkOldLicense");function sp(){let e=new RK,t=[];try{t=Qo.readFileSync(IK(),"utf-8").split(ci.NEW_LINE)}catch(r){r.code==="ENOENT"?tr.info("no license file found"):tr.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if(gK.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=$N(s.license_key,s.company);i.valid_machine===!0&&i.valid_date===!0&&i.valid_machine===!0&&(e.exp_date=i.exp_date>e.exp_date?i.exp_date:e.exp_date,e.ram_allocation=i.ram_allocation,e.enterprise=!0)}catch(s){tr.error("There was an error parsing the license string."),tr.error(s),e.ram_allocation=ci.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return ep=e,e}a(sp,"licenseSearch");async function LK(){return ep||await sp(),ep}a(LK,"getLicense");function MK(){let e=sp().ram_allocation,t=process.constrainedMemory?.()||FN();if(t=Math.round(Math.min(t,FN())/2**20),t>e)return`This server has more memory (${t}MB) than HarperDB is licensed for (${e}MB), this should only be used for educational and development purposes.`}a(MK,"checkMemoryLimit")});var _n=g((zce,aI)=>{"use strict";var zN="username is required",JN="nothing to update, must supply active, role or password to update",XN="password cannot be an empty string",jN="If role is specified, it cannot be empty.",ZN="active must be true or false";aI.exports={addUser:qK,alterUser:kK,dropUser:$K,getSuperUser:QK,userInfo:YK,listUsers:Z_,listUsersExternal:KK,setUsersToGlobal:Jo,findAndValidateUser:iI,getClusterUser:zK,USERNAME_REQUIRED:zN,ALTERUSER_NOTHING_TO_UPDATE:JN,EMPTY_PASSWORD:XN,EMPTY_ROLE:jN,ACTIVE_BOOLEAN:ZN};var eI=un(),PK=Ji(),ap=z_(),tI=vN(),rI=kr(),cp=bs(),Vr=z(),nI=require("validate.js"),Oe=K(),{promisify:UK}=require("util"),lp=Os(),KN=P(),WN=ct(),vK=dr(),Kce=ne(),Wce=Xi(),BK=$i(),{table:Qce}=(Ae(),ie(ke)),{handleHDBError:Zn,hdb_errors:HK}=se(),{HTTP_STATUS_CODES:es,AUTHENTICATION_ERROR_MSGS:ip,HDB_ERROR_MSGS:zo}=HK,{UserEventMsg:up}=Mn(),op=require("lodash"),{server:_p}=(ur(),ie(xi)),xK=K();_p.getUser=(e,t)=>iI(e,t,t!=null);var sI={username:!0,active:!0,role:!0,password:!0},QN=new Map,j_=rI.searchByValue,GK=rI.searchByHash,FK=UK(PK.delete);async function qK(e){let t=nI.cleanAttributes(e,sI),r=tI.addUserValidation(t);if(r)throw Zn(new Error,r.message,es.BAD_REQUEST,void 0,void 0,!0);let n={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["id","permission","role"]},s;try{s=await j_(n),s=s&&Array.from(s)}catch(l){throw Oe.error("There was an error searching for a role in add user"),Oe.error(l),l}if(!s||s.length<1)throw Zn(new Error,zo.ROLE_NAME_NOT_FOUND(t.role),es.NOT_FOUND,void 0,void 0,!0);if(s.length>1)throw Zn(new Error,zo.DUP_ROLES_FOUND(t.role),es.CONFLICT,void 0,void 0,!0);s[0].permission.cluster_user===!0&&(t.hash=lp.encrypt(t.password)),t.password=ap.hash(t.password),t.role=s[0].id;let i={operation:"insert",schema:"system",table:"hdb_user",records:[t]},o;try{o=await eI.insert(i)}catch(l){throw Oe.error("There was an error searching for a user."),Oe.error(l),l}Oe.debug(o);try{await Jo()}catch(l){throw Oe.error("Got an error setting users to global"),Oe.error(l),l}if(o.skipped_hashes.length===1)throw Zn(new Error,zo.USER_ALREADY_EXISTS(t.username),es.CONFLICT,void 0,void 0,!0);let c=Object.assign({},t);return c.role=s[0],cp.signalUserChange(new up(process.pid)),`${c.username} successfully added`}a(qK,"addUser");async function kK(e){let t=nI.cleanAttributes(e,sI);if(Vr.isEmptyOrZeroLength(t.username))throw new Error(zN);if(Vr.isEmptyOrZeroLength(t.password)&&Vr.isEmptyOrZeroLength(t.role)&&Vr.isEmptyOrZeroLength(t.active))throw new Error(JN);if(!Vr.isEmpty(t.password)&&Vr.isEmptyOrZeroLength(t.password.trim()))throw new Error(XN);if(!Vr.isEmpty(t.active)&&!Vr.isBoolean(t.active))throw new Error(ZN);let r=VK(t.username);if(!Vr.isEmpty(t.password)&&!Vr.isEmptyOrZeroLength(t.password.trim())&&(r&&(t.hash=lp.encrypt(t.password)),t.password=ap.hash(t.password)),t.role==="")throw new Error(jN);if(t.role){let i={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]},o;try{o=Array.from(await j_(i)||[])}catch(c){throw Oe.error("Got an error searching for a role."),Oe.error(c),c}if(!o||o.length===0){let c=zo.ALTER_USER_ROLE_NOT_FOUND(t.role);throw Oe.error(c),Zn(new Error,c,es.NOT_FOUND,void 0,void 0,!0)}if(o.length>1){let c=zo.ALTER_USER_DUP_ROLES(t.role);throw Oe.error(c),Zn(new Error,c,es.CONFLICT,void 0,void 0,!0)}t.role=o[0].id}let n={operation:"update",schema:"system",table:"hdb_user",records:[t]},s;try{s=await eI.update(n)}catch(i){throw Oe.error("Error during update."),Oe.error(i),i}try{await Jo()}catch(i){throw Oe.error("Got an error setting users to global"),Oe.error(i),i}return cp.signalUserChange(new up(process.pid)),s}a(kK,"alterUser");function VK(e){let t=!1,r=global.hdb_users.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(VK,"isClusterUser");async function $K(e){try{let t=tI.dropUserValidation(e);if(t)throw new Error(t);let r={table:"hdb_user",schema:"system",hash_values:[e.username]};if(Vr.isEmpty(global.hdb_users.get(e.username)))throw Zn(new Error,zo.USER_NOT_EXIST(e.username),es.NOT_FOUND,void 0,void 0,!0);let n;try{n=await FK(r)}catch(s){throw Oe.error("Got an error deleting a user."),Oe.error(s),s}Oe.debug(n);try{await Jo()}catch(s){throw Oe.error("Got an error setting users to global."),Oe.error(s),s}return cp.signalUserChange(new up(process.pid)),`${e.username} successfully deleted`}catch(t){throw t}}a($K,"dropUser");async function YK(e){let t={};try{if(!e||!e.hdb_user)return"There was no user info in the body";t=op.cloneDeep(e.hdb_user);let r={schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]},n;try{n=await GK(r)}catch(s){throw Oe.error("Got an error searching for a role."),Oe.error(s),s}t.role=n[0],delete t.password,delete t.refresh_token,delete t.hash}catch(r){throw Oe.error(r),r}return t}a(YK,"userInfo");async function KK(){let e;try{e=await Z_()}catch(t){throw Oe.error("Got an error listing users."),Oe.error(t),t}try{e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token})}catch{throw new Error("there was an error massaging the user data")}return[...e.values()]}a(KK,"listUsersExternal");async function Z_(){try{let e={schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]},t;try{t=await j_(e)}catch(o){throw Oe.error("Got an error searching for roles."),Oe.error(o),o}let r={};for(let o of t)r[o.id]=op.cloneDeep(o);if(Object.keys(r).length===0)return null;let n={schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]},s;try{s=await j_(n)}catch(o){throw Oe.error("Got an error searching for users."),Oe.error(o),o}let i=new Map;for(let o of s)o=op.cloneDeep(o),o.role=r[o.role],WK(o.role),i.set(o.username,o);return i}catch(e){throw Oe.error("got an error listing users"),Oe.error(e),Vr.errorizeMessage(e)}return null}a(Z_,"listUsers");function WK(e){try{if(!e){Oe.error("invalid user role found.");return}e.permission.system||(e.permission.system={}),e.permission.system.tables||(e.permission.system.tables={});for(let t of Object.keys(BK)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}catch(t){Oe.error("Got an error trying to set system permissions."),Oe.error(t)}}a(WK,"appendSystemTablesToRole");async function Jo(){try{let e=await Z_();global.hdb_users=e}catch(e){throw Oe.error(e),e}}a(Jo,"setUsersToGlobal");async function iI(e,t,r=!0){global.hdb_users||await Jo();let n=global.hdb_users.get(e);if(!n){if(!r)return{username:e};throw Zn(new Error,ip.GENERIC_AUTH_FAIL,es.UNAUTHORIZED,void 0,void 0,!0)}if(n&&!n.active)throw Zn(new Error,ip.USER_INACTIVE,es.UNAUTHORIZED,void 0,void 0,!0);let s={active:n.active,username:n.username};if(n.refresh_token&&(s.refresh_token=n.refresh_token),n.role&&(s.role=n.role),r===!0){if(QN.get(t)===n.password)return s;if(ap.validate(n.password,t))QN.set(t,n.password);else throw Zn(new Error,ip.GENERIC_AUTH_FAIL,es.UNAUTHORIZED,void 0,void 0,!0)}return s}a(iI,"findAndValidateUser");async function QK(){global.hdb_users||await Jo();for(let[,e]of global.hdb_users)if(e.role.role==="super_user")return e}a(QK,"getSuperUser");async function zK(){let e=await Z_(),t=vK.getConfigFromFile(KN.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!Vr.isEmpty(r)&&r?.role?.role===KN.ROLE_TYPES_ENUM.CLUSTER_USER)return r.decrypt_hash=lp.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+WN.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+WN.SERVER_SUFFIX.ADMIN,r}a(zK,"getClusterUser");var oI=[];_p.invalidateUser=function(e){for(let t of oI)try{t(e)}catch(r){xK.error("Error invalidating user",r)}};_p.onInvalidatedUser=function(e){oI.push(e)}});var Qc=g((Zce,_I)=>{"use strict";var ji=K(),$r=P(),JK=rN(),Xce=ii(),jce=si(),XK=_n(),{validateEvent:cI}=Mn(),Wc=Ln(),jK=require("process"),{resetDatabases:ZK}=(Ae(),ie(ke)),eW={[$r.ITC_EVENT_TYPES.SCHEMA]:tW,[$r.ITC_EVENT_TYPES.USER]:uI};async function tW(e){let t=cI(e);if(t){ji.error(t);return}ji.trace("ITC schemaHandler received schema event:",e),await JK(e.message),await rW(e.message)}a(tW,"schemaHandler");async function rW(e){try{Wc.resetReadTxn($r.SYSTEM_SCHEMA_NAME,$r.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),Wc.resetReadTxn($r.SYSTEM_SCHEMA_NAME,$r.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),Wc.resetReadTxn($r.SYSTEM_SCHEMA_NAME,$r.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=ZK();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){ji.error(t)}}a(rW,"syncSchemaMetadata");var lI=[];async function uI(e){try{try{Wc.resetReadTxn($r.SYSTEM_SCHEMA_NAME,$r.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),Wc.resetReadTxn($r.SYSTEM_SCHEMA_NAME,$r.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){ji.warn(r)}let t=cI(e);if(t){ji.error(t);return}ji.trace(`ITC userHandler ${$r.HDB_ITC_CLIENT_PREFIX}${jK.pid} received user event:`,e),await XK.setUsersToGlobal();for(let r of lI)r()}catch(t){ji.error(t)}}a(uI,"userHandler");uI.addListener=function(e){lI.push(e)};_I.exports=eW});var Mn=g((ile,fI)=>{"use strict";var tle=K(),dp=z(),nW=P(),{ITC_ERRORS:zc}=vr(),{parentPort:rle,threadId:sW,isMainThread:iW,workerData:nle}=require("worker_threads"),{onMessageFromWorkers:oW,broadcast:sle,broadcastWithAcknowledgement:aW}=ot();fI.exports={sendItcEvent:cW,validateEvent:dI,SchemaEventMsg:lW,UserEventMsg:uW};var ed;oW(async(e,t)=>{ed=ed||Qc(),dI(e),ed[e.type]&&await ed[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function cW(e){return!iW&&e.message&&(e.message.originator=sW),aW(e)}a(cW,"sendItcEvent");function dI(e){if(typeof e!="object")return zc.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||dp.isEmpty(e.type))return zc.MISSING_TYPE;if(!e.hasOwnProperty("message")||dp.isEmpty(e.message))return zc.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||dp.isEmpty(e.message.originator))return zc.MISSING_ORIGIN;if(nW.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return zc.INVALID_EVENT(e.type)}a(dI,"validateEvent");function lW(e,t,r,n=void 0,s=void 0){this.originator=e,this.operation=t,this.schema=r,this.table=n,this.attribute=s}a(lW,"SchemaEventMsg");function uW(e){this.originator=e}a(uW,"UserEventMsg")});var bs=g((cle,pI)=>{"use strict";var EI=P(),ale=z(),td=K(),hI=Zy(),Xo,{sendItcEvent:mI}=Mn();function _W(e){try{td.trace("signalSchemaChange called with message:",e),Xo=Xo||Qc();let t=new hI(EI.ITC_EVENT_TYPES.SCHEMA,e);return Xo.schema(t),mI(t)}catch(t){td.error(t)}}a(_W,"signalSchemaChange");function dW(e){try{td.trace("signalUserChange called with message:",e),Xo=Xo||Qc();let t=new hI(EI.ITC_EVENT_TYPES.USER,e);return Xo.user(t),mI(t)}catch(t){td.error(t)}}a(dW,"signalUserChange");pI.exports={signalSchemaChange:_W,signalUserChange:dW}});var rd=g((ule,TI)=>{"use strict";var SI=z(),fW=P(),EW=K(),hW=F_(),mW=G_(),pW=bs(),{SchemaEventMsg:SW}=Mn(),TW="already exists in";TI.exports=gW;async function gW(e,t,r){if(SI.isEmptyOrZeroLength(r))return r;let n=[];SI.isEmptyOrZeroLength(t.attributes)||t.attributes.forEach(i=>{n.push(i.attribute)});let s=r.filter(i=>n.indexOf(i)<0);return s.length===0||await Promise.all(s.map(async i=>{await RW(e,t.schema,t.name,i)})),s}a(gW,"lmdbCheckForNewAttributes");async function RW(e,t,r,n){let s=new mW(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await AW(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(TW))EW.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(RW,"createNewAttribute");async function AW(e){let t;return t=await hW(e),pW.signalSchemaChange(new SW(process.pid,fW.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(AW,"createAttribute")});var jo=g((dle,gI)=>{"use strict";var fp=class{static{a(this,"LMDBTransactionObject")}constructor(t,r,n,s,i=void 0){this.operation=t,this.user_name=r,this.timestamp=n,this.hash_values=s,this.origin=i}};gI.exports=fp});var AI=g((Ele,RI)=>{"use strict";var OW=jo(),bW=P().OPERATIONS_ENUM,Ep=class extends OW{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(bW.INSERT,r,n,s,i),this.records=t}};RI.exports=Ep});var bI=g((mle,OI)=>{"use strict";var yW=jo(),NW=P().OPERATIONS_ENUM,hp=class extends yW{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(NW.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};OI.exports=hp});var NI=g((Sle,yI)=>{"use strict";var IW=jo(),wW=P().OPERATIONS_ENUM,mp=class extends IW{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(wW.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};yI.exports=mp});var wI=g((gle,II)=>{"use strict";var CW=jo(),DW=P().OPERATIONS_ENUM,pp=class extends CW{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(DW.DELETE,n,s,t,i),this.original_records=r}};II.exports=pp});var Jc=g((Ole,MI)=>{"use strict";var Ale=require("path"),CI=We(),LW=AI(),MW=bI(),PW=NI(),UW=wI(),Zo=dt(),DI=z(),{CONFIG_PARAMS:vW}=P(),LI=ne();LI.initSync();var nd=P().OPERATIONS_ENUM,{getTransactionAuditStorePath:BW}=ze();MI.exports=HW;async function HW(e,t){if(LI.get(vW.LOGGING_AUDITLOG)===!1)return;let r=BW(e.schema,e.table),n=await CI.openEnvironment(r,e.table,!0),s=xW(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){CI.initializeDBIs(n,Zo.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Zo.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[Zo.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[Zo.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),DI.isEmpty(s.user_name)||n.dbis[Zo.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[Zo.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(HW,"writeTransaction");function xW(e,t){let r=DI.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===nd.INSERT)return new LW(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===nd.UPDATE)return new MW(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===nd.UPSERT)return new PW(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===nd.DELETE)return new UW(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(xW,"createTransactionObject")});var Sp=g((Nle,PI)=>{"use strict";var GW=$c(),yle=Ic(),Xc=P(),FW=wc(),qW=$o().insertRecords,kW=We(),VW=K(),$W=rd(),{getSchemaPath:YW}=ze(),KW=Jc();PI.exports=WW;async function WW(e){try{let{schema_table:t,attributes:r}=GW(e);FW(e,r,t.hash_attribute),e.schema!==Xc.SYSTEM_SCHEMA_NAME&&(r.includes(Xc.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(Xc.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(Xc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(Xc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await $W(e.hdb_auth_header,t,r),s=YW(e.schema,e.table),i=await kW.openEnvironment(s,e.table),o=await qW(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await KW(e,o)}catch(c){VW.error(`unable to write transaction due to ${c.message}`)}return{written_hashes:o.written_hashes,skipped_hashes:o.skipped_hashes,schema_table:t,new_attributes:n,txn_time:o.txn_time}}catch(t){throw t}}a(WW,"lmdbCreateRecords")});var BI=g((wle,vI)=>{"use strict";var UI=P(),QW=Sp(),zW=Ic(),JW=require("fs-extra"),{getSchemaPath:XW}=ze();vI.exports=jW;async function jW(e){let t=[{name:e.schema,createddate:Date.now()}],r=new zW(UI.SYSTEM_SCHEMA_NAME,UI.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await QW(r),await JW.mkdirp(XW(e.schema))}a(jW,"lmdbCreateSchema")});var xI=g((Dle,HI)=>{"use strict";var Tp=class{static{a(this,"DeleteRecordsResponseObject")}constructor(t=[],r=[],n=void 0,s=[]){this.deleted=t,this.skipped=r,this.txn_time=n,this.original_records=s}};HI.exports=Tp});var kI=g((vle,qI)=>{"use strict";var GI=We(),gp=xr(),Rp=vr().LMDB_ERRORS_ENUM,ZW=dt(),FI=K(),Mle=z(),eQ=require("lmdb"),tQ=xI(),rQ=P(),{OVERFLOW_MARKER:Ple,MAX_SEARCH_KEY_LENGTH:Ule}=ZW,nQ=rQ.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function sQ(e,t,r,n){if(gp.validateEnv(e),t===void 0)throw new Error(Rp.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(Rp.IDS_REQUIRED):new Error(Rp.IDS_MUST_BE_ITERABLE);try{let s=GI.listDBIs(e);GI.initializeDBIs(e,t,s);let i=new tQ,o,c=[],l=[];for(let E=0,f=r.length;E<f;E++)try{o=r[E];let h=e.dbis[t].get(o);if(!h||n&&h[nQ]>n){i.skipped.push(o);continue}let p=e.dbis[t].ifVersion(o,eQ.IF_EXISTS,()=>{e.dbis[t].remove(o);for(let S=0;S<s.length;S++){let T=s[S];if(!h.hasOwnProperty(T)||T===t)continue;let A=e.dbis[T],b=h[T];if(b!=null)try{let I=gp.getIndexedValues(b);if(I)for(let B=0,U=I.length;B<U;B++)A.remove(I[B],o)}catch{FI.warn(`cannot delete from attribute: ${T}, ${b}:${o}`)}}});c.push(p),l.push(o),i.original_records.push(h)}catch(h){FI.warn(h),i.skipped.push(o)}let _=[],u=await Promise.all(c);for(let E=0,f=u.length;E<f;E++)u[E]===!0?i.deleted.push(l[E]):(i.skipped.push(l[E]),_.push(E));let d=0;for(let E=0;E<_.length;E++){let f=_[E];i.original_records.splice(f-d,1),d++}return i.txn_time=gp.getNextMonotonicTime(),i}catch(s){throw s}}a(sQ,"deleteRecords");qI.exports={deleteRecords:sQ}});var jc=g((Hle,$I)=>{"use strict";var ea=z(),iQ=kI(),oQ=We(),{getSchemaPath:aQ}=ze(),cQ=Jc(),lQ=K();$I.exports=uQ;async function uQ(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(ea.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(ea.isEmptyOrZeroLength(e.hash_values)&&!ea.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];ea.isEmpty(l)||e.hash_values.push(l)}}if(ea.isEmptyOrZeroLength(e.hash_values))return VI([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(ea.isEmptyOrZeroLength(e.records)){e.records=[];for(let c=0;c<e.hash_values.length;c++)e.records[c]={[n]:e.hash_values[c]}}let s=aQ(e.schema,e.table),i=await oQ.openEnvironment(s,e.table),o=await iQ.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await cQ(e,o)}catch(c){lQ.error(`unable to write transaction due to ${c.message}`)}return VI(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(uQ,"lmdbDeleteRecords");function VI(e,t,r){let n=e.length+t.length,s=n===1?"record":"records";return{message:`${e.length} of ${n} ${s} successfully deleted`,deleted_hashes:e,skipped_hashes:t,txn_time:r}}a(VI,"createDeleteResponse")});var Op=g((Fle,YI)=>{"use strict";var _Q=P(),Gle=xr();function Ap(e,t){let r=Object.create(null);if(t.length===1&&_Q.SEARCH_WILDCARDS.indexOf(t[0])>=0)Object.assign(r,e);else for(let n=0;n<t.length;n++){let s=t[n],i=e[s];r[s]=i===void 0?null:i}return r}a(Ap,"parseRow");function dQ(e,t,r,n){let s=Ap(r,e);n.push(s)}a(dQ,"searchAll");function fQ(e,t,r,n){let s=Ap(r,e);n[t]=s}a(fQ,"searchAllToMap");function EQ(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(EQ,"iterateDBI");function Zi(e,t,r,n,s){let i=Object.create(null);i[s]=e;let o;n===s?o=e:(o=t,n!==void 0&&(i[n]=o)),r[0].push(o),r[1].push(i)}a(Zi,"pushResults");function hQ(e,t,r,n,s,i){t.toString().endsWith(e)&&Zi(t,r,n,s,i)}a(hQ,"endsWith");function mQ(e,t,r,n,s,i){t.toString().includes(e)&&Zi(t,r,n,s,i)}a(mQ,"contains");function pQ(e,t,r,n,s,i){t>e&&Zi(t,r,n,s,i)}a(pQ,"greaterThanCompare");function SQ(e,t,r,n,s,i){t>=e&&Zi(t,r,n,s,i)}a(SQ,"greaterThanEqualCompare");function TQ(e,t,r,n,s,i){t<e&&Zi(t,r,n,s,i)}a(TQ,"lessThanCompare");function gQ(e,t,r,n,s,i){t<=e&&Zi(t,r,n,s,i)}a(gQ,"lessThanEqualCompare");YI.exports={parseRow:Ap,searchAll:dQ,searchAllToMap:fQ,iterateDBI:EQ,endsWith:hQ,contains:mQ,greaterThanCompare:pQ,greaterThanEqualCompare:SQ,lessThanCompare:TQ,lessThanEqualCompare:gQ,pushResults:Zi}});var ta=g((Yle,jI)=>{"use strict";var li=We(),kle=K(),Yr=xr(),sd=dt(),Et=vr().LMDB_ERRORS_ENUM,Vle=z(),RQ=P(),id=Op(),{parseRow:AQ}=id,$le=require("lmdb"),{OVERFLOW_MARKER:KI,MAX_SEARCH_KEY_LENGTH:OQ}=sd;function WI(e,t,r,n=!1,s=void 0,i=void 0){return eo(e,t,r,(o,c)=>c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}))}a(WI,"iterateFullIndex");function Zc(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,_=!1){return eo(e,t,r,(u,d,E,f)=>{let A={transaction:u,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!l:!_,exclusiveStart:i===!0?_:l};return f===r?(A.values=!1,d.getRange(A).map(b=>({value:b}))):d.getRange(A)})}a(Zc,"iterateRangeBetween");function eo(e,t,r,n){let s=e.database||e,i=li.openDBI(s,r);i[sd.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&li.openDBI(s,t);let o;e.database?o=e:(o=e.useReadTransaction(),o.database=e);let c=n(o,i,s,t);return c.transaction=o,e.database||(c.onDone=()=>{o.done()}),c}a(eo,"setupTransaction");function QI(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(KI)){if(!s)if(r)s=li.openDBI(e,r);else{let l=li.listDBIs(e);for(let _=0,u=l.length;_<u&&(s=li.openDBI(e,l[_]),!s[sd.DBI_DEFINITION_NAME].is_hash_attribute);_++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(QI,"getOverflowCheck");function bQ(e,t,r,n=!1,s=void 0,i=void 0){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);return eo(e,t,t,(o,c,l)=>(od(r),r=el(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(_=>AQ(_.value,r))))}a(bQ,"searchAll");function yQ(e,t,r,n=!1,s=void 0,i=void 0){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);od(r),r=el(e.database||e,r);let o=new Map;for(let{key:c,value:l}of WI(e,t,t,n,s,i))o.set(c,id.parseRow(l,r));return o}a(yQ,"searchAllToMap");function NQ(e,t,r=!1,n=void 0,s=void 0){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=WI(e,void 0,t,r,n,s),c=o.transaction,l=QI(c.database,c,void 0,t);for(let{key:_,value:u}of o){let d=l(_,u);i[d]===void 0&&(i[d]=[]),i[d].push(u)}return i}a(NQ,"iterateDBI");function IQ(e,t){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);return li.statDBI(e,t).entryCount}a(IQ,"countAll");function wQ(e,t,r,n,s=!1,i=void 0,o=void 0){return ui(e,r,n),eo(e,t,r,(c,l,_,u)=>(n=Yr.convertKeyValueToWrite(n),u===r?l.get(n,{transaction:c,lazy:!0})===void 0?[]:[{key:n,value:n}]:l.getValues(n,{transaction:c,reverse:s,limit:i,offset:o}).map(d=>({key:n,value:d}))))}a(wQ,"equals");function CQ(e,t,r){return ui(e,t,r),li.openDBI(e,t).getValuesCount(r)}a(CQ,"count");function DQ(e,t,r,n,s=!1,i=void 0,o=void 0){return ui(e,r,n),eo(e,null,r,(c,l)=>{n=Yr.convertKeyValueToWrite(n);let _=!0;typeof n=="number"&&(_=!1);let u;if(s===!0){let d;for(let E of l.getKeys({transaction:c,start:n}))if(!E.startsWith(n)){d=E;break}return d!==void 0&&(Number.isInteger(o)?o++:i++),u=l.getRange({transaction:c,start:d,end:void 0,reverse:s,limit:i,offset:o}).map(E=>{let{key:f}=E;if(f!==d){if(f.toString().startsWith(n))return E;if(_===!0)return u.DONE}}),u.filter(E=>E)}else return u=l.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(d=>{if(d.key.toString().startsWith(n))return d;if(_===!0)return u.DONE}),_?u:u.filter(d=>d)})}a(DQ,"startsWith");function LQ(e,t,r,n,s=!1,i=void 0,o=void 0){return zI(e,t,r,n,s,i,o,!0)}a(LQ,"endsWith");function zI(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return ui(e,r,n),eo(e,null,r,(l,_,u,d)=>{let E=QI(u,l,d,r);return o=Number.isInteger(o)?o:0,_.getKeys({transaction:l,end:s?!1:void 0,reverse:s}).flatMap(f=>{let h=f.toString();return h.endsWith(KI)?_.getValues(f,{transaction:l}).map(p=>{let S=E(f,p);if(c?S.endsWith(n):S.includes(n))return{key:S,value:p}}).filter(p=>p):(c?h.endsWith(n):h.includes(n))?_[sd.DBI_DEFINITION_NAME].is_hash_attribute?{key:f,value:f}:_.getValues(f,{transaction:l}).map(p=>({key:f,value:p})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a(zI,"contains");function MQ(e,t,r,n,s=!1,i=void 0,o=void 0){ui(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),Zc(e,t,r,n,l,s,i,o,!0,!1)}a(MQ,"greaterThan");function PQ(e,t,r,n,s=!1,i=void 0,o=void 0){ui(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),Zc(e,t,r,n,l,s,i,o,!1,!1)}a(PQ,"greaterThanEqual");function UQ(e,t,r,n,s=!1,i=void 0,o=void 0){ui(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),Zc(e,t,r,l,n,s,i,o,!1,!0)}a(UQ,"lessThan");function vQ(e,t,r,n,s=!1,i=void 0,o=void 0){ui(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),Zc(e,t,r,l,n,s,i,o,!1,!1)}a(vQ,"lessThanEqual");function BQ(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(Yr.validateEnv(e),r===void 0)throw new Error(Et.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(Et.START_VALUE_REQUIRED);if(s===void 0)throw new Error(Et.END_VALUE_REQUIRED);if(n=Yr.convertKeyValueToWrite(n),s=Yr.convertKeyValueToWrite(s),n>s)throw new Error(Et.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return Zc(e,t,r,n,s,i,o,c)}a(BQ,"between");function HQ(e,t,r,n){Yr.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);if(od(r),r=el(s,r),n===void 0)throw new Error(Et.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=id.parseRow(c,r)),o}a(HQ,"searchByHash");function xQ(e,t,r){Yr.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Et.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(xQ,"checkHashExists");function GQ(e,t,r,n,s=[]){return XI(e,t,r,n,s),JI(e,t,r,n,s).map(i=>i[1])}a(GQ,"batchSearchByHash");function FQ(e,t,r,n,s=[]){XI(e,t,r,n,s);let i=new Map;for(let[o,c]of JI(e,t,r,n,s))i.set(o,c);return i}a(FQ,"batchSearchByHashToMap");function JI(e,t,r,n,s=[]){return eo(e,t,t,(i,o,c)=>{r=el(c,r);let l=r.length<3;return n.map(_=>{let u=c.dbis[t].get(_,{transaction:i,lazy:l});if(u)return[_,id.parseRow(u,r)];s.push(_)}).filter(_=>_)})}a(JI,"batchHashSearch");function XI(e,t,r,n,s){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);if(od(r),n==null)throw new Error(Et.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(Et.IDS_MUST_BE_ITERABLE)}a(XI,"initializeBatchSearchByHash");function od(e){if(!Array.isArray(e))throw e===void 0?new Error(Et.FETCH_ATTRIBUTES_REQUIRED):new Error(Et.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(od,"validateFetchAttributes");function ui(e,t,r){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Et.SEARCH_VALUE_REQUIRED);if(r?.length>OQ)throw new Error(Et.SEARCH_VALUE_TOO_LARGE)}a(ui,"validateComparisonFunctions");function el(e,t){return t.length===1&&RQ.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=li.listDBIs(e)),t}a(el,"setGetWholeRowAttributes");jI.exports={searchAll:bQ,searchAllToMap:yQ,count:CQ,countAll:IQ,equals:wQ,startsWith:DQ,endsWith:LQ,contains:zI,searchByHash:HQ,setGetWholeRowAttributes:el,batchSearchByHash:GQ,batchSearchByHashToMap:FQ,checkHashExists:xQ,iterateDBI:NQ,greaterThan:MQ,greaterThanEqual:PQ,lessThan:UQ,lessThanEqual:vQ,between:BQ}});var ra=g((Wle,nw)=>{var ZI=require("lodash"),ew=st(),he=require("joi"),qQ=z(),{hdb_schema_table:tl,checkValidTable:tw,hdb_table:rw,hdb_database:ad}=Xn(),{handleHDBError:kQ,hdb_errors:VQ}=se(),{getDatabases:$Q}=(Ae(),ie(ke)),{HTTP_STATUS_CODES:YQ}=VQ,KQ=he.object({database:ad,schema:ad,table:rw,search_attribute:tl,search_value:he.any().required(),get_attributes:he.array().min(1).items(he.alternatives(tl,he.object())).optional(),desc:he.bool(),limit:he.number().integer().min(1),offset:he.number().integer().min(0)}),WQ=he.object({database:ad,schema:ad,table:rw,operator:he.string().valid("and","or").default("and").lowercase(),offset:he.number().integer().min(0),limit:he.number().integer().min(1),get_attributes:he.array().min(1).items(he.alternatives(tl,he.object())).optional(),sort:he.object({attribute:he.alternatives(tl,he.array().min(1)),descending:he.bool().optional()}).optional(),conditions:he.array().min(1).items(he.alternatives(he.object({operator:he.string().valid("and","or").default("and").lowercase(),conditions:he.array()}),he.object({search_attribute:he.alternatives(tl,he.array().min(1)),search_type:he.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:he.when("search_type",{switch:[{is:"equals",then:he.any()},{is:"between",then:he.array().items(he.alternatives([he.string(),he.number()])).length(2)}],otherwise:he.alternatives(he.string(),he.number())}).required()}))).required()});nw.exports=function(e,t){let r=null;switch(t){case"value":r=ew.validateBySchema(e,KQ);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(tw("database",e.schema)),i(tw("table",e.table)),e.hash_values?Array.isArray(e.hash_values)?e.hash_values.every(o=>typeof o=="string"||typeof o=="number")||i("'hash_values' must be strings or numbers"):i("'hash_values' must be an array"):i("'hash_values' is required"),e.get_attributes?Array.isArray(e.get_attributes)?e.get_attributes.length===0?i("'get_attributes' must contain at least 1 item"):e.get_attributes.every(o=>typeof o=="string"||typeof o=="number")||i("'get_attributes' must be strings or numbers"):i("'get_attributes' must be an array"):i("'get_attributes' is required"),s&&(r=new Error(s.trim()));break;case"conditions":r=ew.validateBySchema(e,WQ);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=qQ.checkGlobalSchemaTable(e.schema,e.table);if(s)return kQ(new Error,s,YQ.NOT_FOUND);let o=$Q()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let l=a(u=>{for(let d=0,E=u.conditions.length;d<E;d++){let f=u.conditions[d];f.conditions?l(f):c.push(f.search_attribute)}},"addConditions");t==="conditions"&&l(e);let _=ZI.filter(c,u=>u!=="*"&&!u.startsWith?.("$")&&u.attribute!=="*"&&!Array.isArray(u)&&!u.name&&!ZI.some(o,d=>d===u||d.attribute===u||d.attribute===u.attribute));if(_&&_.length>0){let u=_.join(", ");return u=u.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${u}'`)}}return r}});var bp=g((zle,sw)=>{"use strict";var QQ=We(),zQ=ra(),{getSchemaPath:JQ}=ze();sw.exports=XQ;function XQ(e){let t=zQ(e,"hashes");if(t)throw t;let r=JQ(e.schema,e.table);return QQ.openEnvironment(r,e.table)}a(XQ,"initialize")});var yp=g((Xle,iw)=>{"use strict";var jQ=ta(),ZQ=bp();iw.exports=ez;async function ez(e){let t=await ZQ(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return jQ.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(ez,"lmdbGetDataByHash")});var na=g((Zle,ow)=>{"use strict";var Np=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};ow.exports=Np});var cw=g((rue,aw)=>{"use strict";var tue=na(),tz=ta(),rz=bp();aw.exports=nz;async function nz(e){let t=await rz(e),r=global.hdb_schema[e.schema][e.table];return tz.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(nz,"lmdbSearchByHash")});var ts=g((sue,lw)=>{"use strict";var Ip=class{static{a(this,"SearchObject")}constructor(t,r,n,s,i,o,c,l=!1,_=void 0,u=void 0){this.schema=t,this.table=r,this.search_attribute=n,this.search_value=s,this.hash_attribute=i,this.get_attributes=o,this.end_value=c,this.reverse=l,this.limit=_,this.offset=u}};lw.exports=Ip});var cd=g((oue,hw)=>{"use strict";var rr=ta(),sz=We(),iz=z(),me=dt(),to=P(),oz=$i(),uw=vr().LMDB_ERRORS_ENUM,{getSchemaPath:az}=ze(),ys=to.SEARCH_WILDCARDS;async function cz(e,t,r){let n;e.schema===to.SYSTEM_SCHEMA_NAME?n=oz[e.table]:n=global.hdb_schema[e.schema][e.table];let s=Ew(e,n.hash_attribute,r,t);return dw(e,s,n.hash_attribute,r)}a(cz,"prepSearch");async function dw(e,t,r,n){let s=az(e.schema,e.table),i=await sz.openEnvironment(s,e.table),o=fw(i,e,t,r),c=o.transaction||i;if([me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,me.SEARCH_TYPES.SEARCH_ALL,me.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(lz(e,r)===!1){let u=e.search_attribute;if(u===r)return n?_w(o,()=>!0):o.map(E=>({[r]:E.key}));let d=a(E=>({[r]:E.value,[u]:E.key}),"toObject");return n?_w(o,d):o.map(d)}let _=e.search_attribute===r?o.map(u=>u.key):o.map(u=>u.value);return n===!0?rr.batchSearchByHashToMap(c,r,e.get_attributes,_):rr.batchSearchByHash(c,r,e.get_attributes,_)}a(dw,"executeSearch");function fw(e,t,r,n){let s,i=n;t.get_attributes.indexOf(n)<0&&(i=void 0);let{reverse:o,limit:c,offset:l}=t;switch(o=typeof o=="boolean"?o:!1,c=Number.isInteger(c)?c:void 0,l=Number.isInteger(l)?l:void 0,r){case me.SEARCH_TYPES.EQUALS:s=rr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.CONTAINS:s=rr.contains(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.ENDS_WITH:case me.SEARCH_TYPES._ENDS_WITH:s=rr.endsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.STARTS_WITH:case me.SEARCH_TYPES._STARTS_WITH:s=rr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return rr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return rr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case me.SEARCH_TYPES.SEARCH_ALL:return rr.searchAll(e,n,t.get_attributes,o,c,l);case me.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return rr.searchAllToMap(e,n,t.get_attributes,o,c,l);case me.SEARCH_TYPES.BETWEEN:s=rr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,l);break;case me.SEARCH_TYPES.GREATER_THAN:case me.SEARCH_TYPES._GREATER_THAN:s=rr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.GREATER_THAN_EQUAL:case me.SEARCH_TYPES._GREATER_THAN_EQUAL:s=rr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.LESS_THAN:case me.SEARCH_TYPES._LESS_THAN:s=rr.lessThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.LESS_THAN_EQUAL:case me.SEARCH_TYPES._LESS_THAN_EQUAL:s=rr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;default:return Object.create(null)}return s}a(fw,"searchByType");function _w(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(_w,"createMapFromIterable");function lz(e,t){if(e.get_attributes.length===1&&e.get_attributes[0]==="*")return!0;let r=[e.search_attribute];e.get_attributes.indexOf(t)>=0&&r.push(t);let n=!1;for(let s=0;s<e.get_attributes.length;s++)if(r.indexOf(e.get_attributes[s])<0){n=!0;break}return n}a(lz,"checkToFetchMore");function Ew(e,t,r,n){if(iz.isEmpty(n)){let s=e.search_value;typeof s=="object"?s=JSON.stringify(s):s=s.toString();let i=s.charAt(0),o=s.charAt(s.length-1),c=!1;if(e.search_attribute===t&&(c=!0),ys.indexOf(s)>-1)return r===!0?me.SEARCH_TYPES.SEARCH_ALL_TO_MAP:me.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(ys[0])<0&&s.indexOf(ys[1])<0)return c===!0?r===!0?me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:me.SEARCH_TYPES.EQUALS;if(ys.indexOf(i)>=0&&ys.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),me.SEARCH_TYPES.CONTAINS;if(ys.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),me.SEARCH_TYPES.ENDS_WITH;if(ys.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),me.SEARCH_TYPES.STARTS_WITH;if(s.includes(ys[0])||s.includes(ys[1]))return me.SEARCH_TYPES.EQUALS;throw new Error(uw.UNKNOWN_SEARCH_TYPE)}else switch(n){case to.VALUE_SEARCH_COMPARATORS.BETWEEN:return me.SEARCH_TYPES.BETWEEN;case to.VALUE_SEARCH_COMPARATORS.GREATER:return me.SEARCH_TYPES.GREATER_THAN;case to.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return me.SEARCH_TYPES.GREATER_THAN_EQUAL;case to.VALUE_SEARCH_COMPARATORS.LESS:return me.SEARCH_TYPES.LESS_THAN;case to.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return me.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(uw.UNKNOWN_SEARCH_TYPE)}}a(Ew,"createSearchTypeFromSearchObject");hw.exports={executeSearch:dw,createSearchTypeFromSearchObject:Ew,prepSearch:cz,searchByType:fw}});var pw=g((lue,mw)=>{"use strict";var cue=ts(),uz=ra(),_z=z(),dz=P(),fz=cd();mw.exports=Ez;function Ez(e,t){if(!_z.isEmpty(t)&&dz.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=uz(e,"value");if(n)throw n;return fz.prepSearch(e,t,!0)}a(Ez,"lmdbGetDataByValue")});var rl=g((due,Sw)=>{"use strict";var _ue=ts(),hz=ra(),mz=z(),pz=P(),Sz=cd();Sw.exports=Tz;async function Tz(e,t){if(!mz.isEmpty(t)&&pz.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=hz(e,"value");if(n)throw n;return Sz.prepSearch(e,t,!1)}a(Tz,"lmdbSearchByValue")});var gw=g((hue,Tw)=>{"use strict";var Eue=dt(),wp=class{static{a(this,"SearchByConditionsObject")}constructor(t,r,n,s,i=void 0,o=void 0,c="and"){this.schema=t,this.table=r,this.get_attributes=n,this.limit=i,this.offset=o,this.conditions=s,this.operator=c}},Cp=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},Dp=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};Tw.exports={SearchByConditionsObject:wp,SearchCondition:Cp,SortAttribute:Dp}});var yw=g((Tue,bw)=>{"use strict";var pue=gw().SearchByConditionsObject,gz=ts(),Rz=ra(),Lp=ta(),ld=dt(),{Resource:Sue}=(an(),ie(Mp)),Ow=cd(),Az=Op(),Oz=require("lodash"),{getSchemaPath:bz}=ze(),Rw=We(),{handleHDBError:yz,hdb_errors:Nz}=se(),{HTTP_STATUS_CODES:Iz}=Nz,wz=1e8;bw.exports=Cz;async function Cz(e){let t=Rz(e,"conditions");if(t)throw yz(t,t.message,Iz.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=bz(e.schema,e.table),n=await Rw.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let _ of e.conditions)Rw.openDBI(n,_.search_attribute);let i=Oz.sortBy(e.conditions,_=>{if(_.estimated_count===void 0){let u=_.search_type;u===ld.SEARCH_TYPES.EQUALS?_.estimated_count=Lp.count(n,_.search_attribute,_.search_value):u===ld.SEARCH_TYPES.CONTAINS||u===ld.SEARCH_TYPES.ENDS_WITH?_.estimated_count=1/0:_.estimated_count=wz}return _.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await Aw(o,e,i[0],s.hash_attribute),l;if(!e.operator||e.operator.toLowerCase()==="and"){let _=n.dbis[s.hash_attribute],u=i.slice(1).map(Ow.filterByType),d=u.length,E=Lp.setGetWholeRowAttributes(n,e.get_attributes);l=c.map(f=>_.get(f,{transaction:o,lazy:!0})),d>0&&(l=l.filter(f=>{for(let h=0;h<d;h++)if(!u[h](f))return!1;return!0})),(e.offset||e.limit!==void 0)&&(l=l.slice(e.offset,e.limit!==void 0?(e.offset||0)+e.limit:void 0)),l=l.map(f=>Az.parseRow(f,E))}else{for(let d=1;d<i.length;d++){let E=i[d],f=await Aw(o,e,E,s.hash_attribute);c=c.concat(f)}let _=new Set,u=e.offset||0;c=c.filter(d=>_.has(d)?!1:(_.add(d),!0)).slice(u,e.limit&&e.limit+u),l=Lp.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(Cz,"lmdbSearchByConditions");async function Aw(e,t,r,n){let s=new gz(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===ld.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,Ow.searchByType(e,s,i,n).map(o=>o.value)}a(Aw,"executeConditionSearch")});var nl=g((Rue,Nw)=>{"use strict";var Dz=P().OPERATIONS_ENUM,Pp=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=Dz.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};Nw.exports=Pp});var Up=g((Oue,Uw)=>{"use strict";var Dw=ts(),Lw=nl(),Mw=rl(),Pw=jc(),hr=P(),Iw=z(),ww=We(),{getTransactionAuditStorePath:Lz,getSchemaPath:Mz}=ze(),Cw=K();Uw.exports=Pz;async function Pz(e){try{if(Iw.isEmpty(global.hdb_schema[e.schema])||Iw.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await Uz(e),await vz(e);let t=Mz(e.schema,e.table);try{await ww.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")Cw.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=Lz(e.schema,e.table);await ww.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")Cw.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(Pz,"lmdbDropTable");async function Uz(e){let t=new Dw(hr.SYSTEM_SCHEMA_NAME,hr.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,hr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[hr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await Mw(t)),n=[];for(let i=0;i<r.length;i++){let o=r[i];n.push(o.id)}if(n.length===0)return;let s=new Lw(hr.SYSTEM_SCHEMA_NAME,hr.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await Pw(s)}a(Uz,"deleteAttributesFromSystem");async function vz(e){let t=new Dw(hr.SYSTEM_SCHEMA_NAME,hr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,hr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[hr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,hr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,hr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await Mw(t))}catch(i){throw i}for(let i=0;i<r.length;i++){let o=r[i];o.name===e.table&&o.schema===e.schema&&(n=o)}if(!n)throw new Error(`${e.schema}.${e.table} was not found`);let s=new Lw(hr.SYSTEM_SCHEMA_NAME,hr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await Pw(s)}catch(i){throw i}}a(vz,"dropTableFromSystem")});var Bw=g((yue,vw)=>{"use strict";var Bz=require("fs-extra"),Hz=ts(),xz=na(),Gz=nl(),Fz=Up(),qz=jc(),kz=yp(),Vz=rl(),Ns=P(),{getSchemaPath:$z}=ze(),{handleHDBError:Yz,hdb_errors:Kz}=se(),{HDB_ERROR_MSGS:Wz,HTTP_STATUS_CODES:Qz}=Kz;vw.exports=zz;async function zz(e){let t;try{t=await Jz(e.schema);let r=new Hz(Ns.SYSTEM_SCHEMA_NAME,Ns.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Ns.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[Ns.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await Vz(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await Fz(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new Gz(Ns.SYSTEM_SCHEMA_NAME,Ns.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await qz(s);let i=$z(t);await Bz.remove(i)}catch(r){throw r}}a(zz,"lmdbDropSchema");async function Jz(e){let t=new xz(Ns.SYSTEM_SCHEMA_NAME,Ns.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[Ns.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await kz(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw Yz(new Error,Wz.SCHEMA_NOT_FOUND(e),Qz.NOT_FOUND,void 0,void 0,!0);return n}a(Jz,"validateDropSchema")});var Bp=g((Iue,Hw)=>{"use strict";var vp=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};Hw.exports=vp});var Gw=g((Due,xw)=>{"use strict";var Xz=require("fs-extra"),ud=We(),{getTransactionAuditStorePath:jz}=ze(),Hp=dt(),Cue=Bp();xw.exports=Zz;async function Zz(e){let t;try{let r=jz(e.schema,e.table);await Xz.mkdirp(r),t=await ud.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{ud.createDBI(t,Hp.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),ud.createDBI(t,Hp.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),ud.createDBI(t,Hp.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(Zz,"createTransactionsAuditEnvironment")});var Vw=g((Mue,kw)=>{"use strict";var xp=P(),Fw=We(),e2=$o(),{getSystemSchemaPath:t2,getSchemaPath:r2}=ze(),n2=$i(),s2=F_(),Gp=G_(),i2=K(),o2=Gw(),qp=n2.hdb_table,qw=[];for(let e=0;e<qp.attributes.length;e++)qw.push(qp.attributes[e].attribute);kw.exports=a2;async function a2(e,t){let r=r2(t.schema,t.table),n=new Gp(t.schema,t.table,xp.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new Gp(t.schema,t.table,xp.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new Gp(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await Fw.createEnvironment(r,t.table),e!==void 0){let o=await Fw.openEnvironment(t2(),xp.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await e2.insertRecords(o,qp.hash_attribute,qw,[e]),n.skip_table_check=!0,s.skip_table_check=!0,i.skip_table_check=!0,await Fp(n),await Fp(s),await Fp(i)}await o2(t)}catch(o){throw o}}a(a2,"lmdbCreateTable");async function Fp(e){try{await s2(e)}catch(t){i2.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(Fp,"createAttribute")});var Yw=g((Uue,$w)=>{"use strict";var c2=$c(),l2=wc(),u2=rd(),sl=P(),_2=$o().updateRecords,d2=We(),{getSchemaPath:f2}=ze(),E2=Jc(),h2=K();$w.exports=m2;async function m2(e){try{let{schema_table:t,attributes:r}=c2(e);l2(e,r,t.hash_attribute),e.schema!==sl.SYSTEM_SCHEMA_NAME&&(r.includes(sl.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(sl.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(sl.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(sl.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await u2(e.hdb_auth_header,t,r),s=f2(e.schema,e.table),i=await d2.openEnvironment(s,e.table),o=await _2(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await E2(e,o)}catch(c){h2.error(`unable to write transaction due to ${c.message}`)}return{written_hashes:o.written_hashes,skipped_hashes:o.skipped_hashes,schema_table:t,new_attributes:n,txn_time:o.txn_time}}catch(t){throw t}}a(m2,"lmdbUpdateRecords")});var Ww=g((Bue,Kw)=>{"use strict";var p2=P().OPERATIONS_ENUM,kp=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=p2.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};Kw.exports=kp});var zw=g((Gue,Qw)=>{"use strict";var xue=Ww(),S2=$c(),T2=wc(),g2=rd(),il=P(),R2=$o().upsertRecords,A2=We(),{getSchemaPath:O2}=ze(),b2=Jc(),y2=K(),{handleHDBError:N2,hdb_errors:I2}=se();Qw.exports=w2;async function w2(e){let t;try{t=S2(e)}catch(l){throw N2(l,l.message,I2.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;T2(e,n,r.hash_attribute),e.schema!==il.SYSTEM_SCHEMA_NAME&&(n.includes(il.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(il.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(il.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(il.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await g2(e.hdb_auth_header,r,n),i=O2(e.schema,e.table),o=await A2.openEnvironment(i,e.table),c=await R2(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await b2(e,c)}catch(l){y2.error(`unable to write transaction due to ${l.message}`)}return{written_hashes:c.written_hashes,schema_table:r,new_attributes:s,txn_time:c.txn_time}}a(w2,"lmdbUpsertRecords")});var Xw=g((que,Jw)=>{"use strict";var Vp=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};Jw.exports=Vp});var Zw=g((Vue,jw)=>{"use strict";var $p=class{static{a(this,"DeleteAuditLogsBeforeResults")}constructor(t=void 0,r=void 0,n=0){this.start_timestamp=t,this.end_timestamp=r,this.transactions_deleted=n}};jw.exports=$p});var rC=g((Kue,tC)=>{"use strict";var Yp=We(),{getTransactionAuditStorePath:C2}=ze(),Yue=Xw(),ol=dt(),D2=z(),eC=Zw(),L2=require("util").promisify,M2=L2(setTimeout),P2=1e4,U2=100;tC.exports=v2;async function v2(e){let t=C2(e.schema,e.table),r=await Yp.openEnvironment(t,e.table,!0),n=Yp.listDBIs(r);Yp.initializeDBIs(r,ol.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new eC;do s=await B2(r,e.timestamp),i.start_timestamp===void 0&&(i.start_timestamp=s.start_timestamp),s.end_timestamp!==void 0&&(i.end_timestamp=s.end_timestamp),i.transactions_deleted+=s.transactions_deleted,await M2(U2);while(s.transactions_deleted>0);return i}a(v2,"deleteAuditLogsBefore");async function B2(e,t){let r=new eC;try{let n=e.dbis[ol.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],s;for(let{key:i,value:o}of n.getRange({start:!1})){if(i>=t)break;r.start_timestamp===void 0&&(r.start_timestamp=i),s=n.remove(i);let c=o[ol.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];D2.isEmpty(c)||(s=e.dbis[ol.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[ol.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>P2)break}return await s,r}catch(n){throw n}}a(B2,"deleteTransactions")});var sC=g((Que,nC)=>{"use strict";var Kp=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};nC.exports=Kp});var oC=g((Xue,iC)=>{"use strict";var H2=ts(),x2=nl(),Jue=sC(),rs=P(),G2=z(),Wp=We(),F2=$i(),q2=rl(),k2=jc(),{getSchemaPath:V2}=ze();iC.exports=$2;async function $2(e,t=!0){let r;e.schema===rs.SYSTEM_SCHEMA_NAME?r=F2[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await K2(e),s=V2(e.schema,e.table),i=await Wp.openEnvironment(s,e.table);return t===!0&&await Y2(e,i,r.hash_attribute),Wp.dropDBI(i,e.attribute),n}a($2,"lmdbDropAttribute");async function Y2(e,t,r){let n=Wp.openDBI(t,r),s,i=e.attribute;for(let{key:o,value:c,version:l}of n.getRange({start:!1,versions:!0})){let _={};for(let u in c)u!==i&&(_[u]=c[u]);s=t.dbis[r].put(o,_,l)}await s}a(Y2,"removeAttributeFromAllObjects");async function K2(e){let t=new H2(rs.SYSTEM_SCHEMA_NAME,rs.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,rs.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[rs.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,rs.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await q2(t)).filter(o=>o[rs.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(G2.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[rs.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new x2(rs.SYSTEM_SCHEMA_NAME,rs.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return k2(i)}a(K2,"dropAttributeFromSystem")});var dC=g((e_e,_C)=>{"use strict";var Qp=We(),sa=dt(),Zue=xr(),zp=P(),aC=z(),{getTransactionAuditStorePath:W2}=ze(),Q2=ta(),_d=jo(),z2=K();_C.exports=J2;async function J2(e){let t=W2(e.schema,e.table),r=await Qp.openEnvironment(t,e.table,!0),n=Qp.listDBIs(r);Qp.initializeDBIs(r,sa.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case zp.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return cC(r,e.search_values);case zp.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,j2(r,e.search_values,s);case zp.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return X2(r,e.search_values);default:return cC(r)}}a(J2,"readAuditLog");function cC(e,t=[0,Date.now()]){aC.isEmpty(t[0])&&(t[0]=0),aC.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[sa.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],n;for(let s of r.getKeys({start:t[1]}))if(s!==t[1]){n=s;break}return r.getRange({start:t[0],end:n}).map(({value:s})=>Object.assign(new _d,s))}a(cC,"searchTransactionsByTimestamp");function X2(e,t=[]){let r=new Map;for(let n=0;n<t.length;n++){let s=t[n],i=[];for(let o of e.dbis[sa.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,uC(e,i))}return Object.fromEntries(r)}a(X2,"searchTransactionsByUsername");function j2(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let _=t[c],u=Q2.equals(e,sa.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,sa.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,_);for(let{value:d}of u){let E=Number(d);n.has(E)?n.get(E).push(_.toString()):n.set(E,[_.toString()])}}let s=Array.from(n.keys()),i=uC(e,s),o=new Map;for(let c=0;c<i.length;c++){let l=i[c],_=l.timestamp,u=n.get(_);lC(l,"records",r,u,o),lC(l,"original_records",r,u,o)}return Object.fromEntries(o)}a(j2,"searchTransactionsByHashValues");function lC(e,t,r,n,s){let i=e.timestamp;if(e[t])for(let o=0;o<e[t].length;o++){let c=e[t][o],l=c[r].toString();if(n.indexOf(l)>=0)if(s.has(l)){let _=s.get(l),u=_[_.length-1];if(u.timestamp===i)u[t]=[c];else{let d=new _d(e.operation,e.user_name,i,void 0);d[t]=[c],_.push(d)}}else{let _=new _d(e.operation,e.user_name,i,void 0);_[t]=[c],s.set(l,[_])}}}a(lC,"loopRecords");function uC(e,t){let r=[];try{let n=e.dbis[sa.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP];for(let s=0;s<t.length;s++)try{let i=n.get(t[s]);if(i){let o=Object.assign(new _d,i);r.push(o)}}catch(i){z2.warn(i)}return r}catch(n){throw n}}a(uC,"batchSearchTransactions")});var EC=g((s_e,fC)=>{"use strict";var{getSchemaPath:r_e}=ze(),n_e=We(),{database:Z2}=(Ae(),ie(ke));fC.exports={writeTransaction:eJ};async function eJ(e,t,r){return Z2({database:e,table:t}).transaction(r)}a(eJ,"writeTransaction")});var SC=g((o_e,pC)=>{"use strict";var{getSchemaPath:hC}=ze(),mC=We();pC.exports={flush:tJ,resetReadTxn:rJ};async function tJ(e,t){return(await mC.openEnvironment(hC(e,t),t.toString())).flushed}a(tJ,"flush");async function rJ(e,t){try{(await mC.openEnvironment(hC(e,t),t.toString())).resetReadTxn()}catch{}}a(rJ,"resetReadTxn")});var AC=g((c_e,RC)=>{"use strict";var{Readable:nJ}=require("stream"),{getDatabases:sJ}=(Ae(),ie(ke)),{readSync:iJ,openSync:oJ,createReadStream:TC}=require("fs"),{open:aJ}=require("lmdb"),gC=Hc(),cJ=xc(),{AUDIT_STORE_OPTIONS:lJ}=(ti(),ie(OC)),{INTERNAL_DBIS_NAME:uJ,AUDIT_STORE_NAME:_J}=dt();RC.exports=fJ;var Jp=32768,dJ=100;async function fJ(e){let t=e.database||e.schema||"data",r=sJ()[t],n=new Date().toISOString(),s=e.tables||e.table&&[e.table];if(s){let _=r[s[0]];if(!_)throw new Error(`Can not find table ${s[0]}`);let u=_.dbisDB,d=aJ({noSync:!0,maxDbs:cJ.MAX_DBS}),E,f=d.openDB(uJ,new gC(!1)),h=u.useReadTransaction(),p=0,S=a(async function(A,b){b.encoding="binary",b.encoder=void 0;let I=d.openDB(A,b),B=u.openDB(A,b);for(let{key:U,version:q,value:M}of B.getRange({start:null,transaction:h,versions:B.useVersions}))E=I.put(U,M,q),p++%dJ===0&&(await new Promise(Q=>setTimeout(Q,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:A,value:b}of u.getRange({transaction:h,start:!1}))if(s.some(I=>A.startsWith?.(I+"/"))){f.put(A,b);let[,I]=A.split("/"),B=!I,U=new gC(!B,B);await S(A,U)}e.include_audit&&await S(_J,Object.assign({},lJ)),await E;let T=TC(d.path);return T.headers=l(),T.on("close",()=>{h.done(),d.close()}),T}let o=r[Object.keys(r)[0]].primaryStore,c=oJ(o.path);return o.transaction(()=>{let _=Buffer.alloc(Jp);iJ(c,_,0,Jp),o.resetReadTxn();let u=o.useReadTransaction();u.renew();let d=TC(null,{fd:c,start:Jp}),E=new nJ.from(async function*(){yield _;for await(let f of d)u.openTimer&&(u.openTimer=0),yield f;u.done()}());return E.headers=l(),E});function l(){let _=new Map;return _.set("content-type","application/octet-stream"),_.set("content-disposition",`attachment; filename="${t}"`),_.set("date",n),_}}a(fJ,"getBackup")});var NC=g((u_e,yC)=>{"use strict";var EJ=K(),{handleHDBError:hJ}=se(),mJ=iy(),pJ=F_(),SJ=Sp(),TJ=BI(),gJ=jc(),RJ=yp(),AJ=cw(),OJ=pw(),bJ=rl(),yJ=yw(),NJ=Bw(),IJ=Vw(),wJ=Yw(),CJ=zw(),DJ=rC(),LJ=Up(),MJ=oC(),PJ=dC(),UJ=EC(),bC=SC(),vJ=AC(),Xp=class extends mJ{static{a(this,"LMDBBridge")}async searchByConditions(t){return yJ(t)}async getDataByHash(t){return await RJ(t)}async searchByHash(t){return await AJ(t)}async getDataByValue(t,r){return await OJ(t,r)}async searchByValue(t){return await bJ(t)}async createSchema(t){return await TJ(t)}async dropSchema(t){return await NJ(t)}async createTable(t,r){return await IJ(t,r)}async dropTable(t){return await LJ(t)}async createAttribute(t){return await pJ(t)}async createRecords(t){return await SJ(t)}async updateRecords(t){return await wJ(t)}async upsertRecords(t){try{return await CJ(t)}catch(r){throw hJ(r,null,null,EJ.ERR,r)}}async deleteRecords(t){return await gJ(t)}async dropAttribute(t){return await MJ(t)}async deleteAuditLogsBefore(t){return await DJ(t)}async readAuditLog(t){return await PJ(t)}writeTransaction(t,r,n){return UJ.writeTransaction(t,r,n)}flush(t,r){return bC.flush(t,r)}resetReadTxn(t,r){return bC.resetReadTxn(t,r)}getBackup(t){return vJ(t)}};yC.exports=Xp});function GJ(){xJ=setInterval(function(){for(let e of jp)if(e.stale){let t=e[ye]?.url;DC.error(`Transaction was open too long and has been aborted, from table: ${e.lmdbDb?.name+(t?" path: "+t:"")}`),e.abort()}else e.stale=!0},HJ).unref()}var Zp,CC,DC,LC,MC,PC,IC,jp,BJ,al,wC,ro,dd,HJ,xJ,eS=Re(()=>{Zp=x(xr()),CC=x(se()),DC=x(K());an();LC=x(ne()),MC=x(P()),PC=x(z()),IC=100,jp=new Set,BJ=(0,PC.convertToMS)(LC.get(MC.CONFIG_PARAMS.STORAGE_MAXTRANSACTIONQUEUETIME))||45e3,ro=class e{static{a(this,"DatabaseTransaction")}writes=[];lmdbDb;readTxn;readTxnRefCount;readTxnsUsed;validated=0;timestamp=0;overloadChecked;open=1;getReadTxn(){if(this.readTxnRefCount=(this.readTxnRefCount||0)+1,this.stale&&(this.stale=!1),this.readTxn)return this.readTxn.openTimer&&(this.readTxn.openTimer=0),this.readTxn;if(this.open===1)return this.readTxn=this.lmdbDb.useReadTransaction(),this.readTxnsUsed=1,this.readTxn.openTimer&&(this.readTxn.openTimer=0),jp.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(jp.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(al&&!this.overloadChecked&&performance.now()-wC>BJ)throw new CC.ServerError("Outstanding write transactions have too long of queue, please try again later",503);this.overloadChecked=!0}addWrite(t){if(this.open===0)throw new Error("Can not use a transaction that is no longer open");if(this.open===2){let r=new e;return r.addWrite(t),r.commit({})}else this.writes.push(t)}removeWrite(t){let r=this.writes.indexOf(t);r>-1&&(this.writes[r]=null)}commit(t={}){let r=this.timestamp;r||(r=this.timestamp=t.timestamp=t.timestamp||(0,Zp.getNextMonotonicTime)());let n=t.retries||0;if(this.validated<this.writes.length)try{let d=this.validated;this.validated=this.writes.length;for(let f=d;f<this.validated;f++)this.writes[f]?.validate?.(this.timestamp);let E;for(let f=d;f<this.validated;f++){let h=this.writes[f];h&&(h.before||h.beforeIntermediate)&&(E=!0)}if(E)return(async()=>{try{for(let f=0;f<2;f++){let h;for(let p=d;p<this.validated;p++){let S=this.writes[p];if(!S)continue;let T=S[f===0?"before":"beforeIntermediate"];if(T){let A=T();h?h.push?h.push(A):h=[h,A]:h=A}}h&&await(h.push?Promise.all(h):h)}}catch(f){throw this.abort(),f}return this.commit(t)})()}catch(d){throw this.abort(),d}n||this.doneReadTxn(),this.open=t?.letItLinger?2:0;let s,i=[],o=0;this.writes=this.writes.filter(d=>d);let c=a(d=>{d.commit(r,d.entry,n)},"doWrite"),l=a(()=>{let d=this.writes[o++];if(d)if(d.key){n>0&&(d.entry=d.store.getEntry(d.key));let E=d.store.ifVersion(d.key,d.entry?.version??null,l);s=s||E}else l();else for(let E of this.writes)c(E)},"nextCondition"),_=this.lmdbDb;if(this.writes.length>0&&(_?.retryRisk&&(_.retryRisk*=.99),this.writes.length+(_?.retryRisk||0)<IC>>n?l():s=this.writes[0].store.transaction(()=>{for(let d of this.writes)d.entry=d.store.getEntry(d.key),c(d);return!0})),s)return al||(al=s,wC=performance.now(),al.then(()=>{al=null})),s.then(d=>d?(this.next&&i.push(this.next.commit(t)),t?.flush&&i.push(this.writes[0].store.flushed),this.writes=[],this.next=null,Promise.all(i).then(()=>({txnTime:r}))):(_&&(_.retryRisk=(_.retryRisk||0)+IC/2),t?t.retries=n+1:t={retries:1},this.commit(t)));let u={txnTime:r};if(this.next){let d=this.next?.commit(t);if(d?.then)return d?.then(E=>({txnTime:r,next:E}));u.next=d}return u}abort(){for(;this.readTxnsUsed>0;)this.doneReadTxn();this.open=0,this.writes=[]}},dd=class extends ro{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,Zp.getNextMonotonicTime)())}getReadTxn(){}},HJ=3e4;a(GJ,"startMonitoringTxns");GJ()});function Ze(e,t,r){if(!t)t=e,e={};else if(!e)e={};else if(e?.transaction?.open===1&&typeof t=="function")return t(e.transaction);if(typeof t!="function")throw new Error("Callback function must be provided to transaction");let n=e.transaction=new ro;e.timestamp&&(n.timestamp=e.timestamp),n[ye]=e,e.resourceCache||(e.resourceCache=[]);let s;try{if(s=t(n),s?.then)return s.then(i,o)}catch(c){o(c)}return i(s);function i(c){let l=n.commit({letItLinger:r?.letItLinger});return l.then?l.then(()=>c):c}function o(c){throw n.abort({}),c}}var UC,no=Re(()=>{UC=require("../../index");an();eS();a(Ze,"transaction");(0,UC._assignPackageExport)("transaction",Ze);Ze.commit=function(e){let t=(e[ye]||e)?.transaction;if(!t)throw new Error("No active transaction is available to commit");return t.commit()};Ze.abort=function(e){let t=(e[ye]||e)?.transaction;if(!t)throw new Error("No active transaction is available to abort");return t.abort()}});var kC={};qe(kC,{ResourceBridge:()=>nS});function sS({get_attributes:e},t){if(e){if(e[0]==="*"){if(t.schemaDefined)return;e=t.attributes.map(r=>r.name)}return e.forceNulls=!0,e}}function BC(e,t){let r=ns(e),n=sS(e,r);if(!r)throw new Pn.ClientError(`Table ${e.table} not found`);let s;n&&r.attributes.length-n.length>2&&n.length<5&&(s=!0);let i={user:e.hdb_user,onlyIfCached:e.onlyIfCached,noCacheStore:e.noCacheStore,noCache:e.noCache},o;Ze(i,()=>new Promise(_=>o=_));let c=e.ids||e.hash_values,l=0;return{[Symbol.asyncIterator](){return{async next(){if(l<c.length){let _=c[l++],u;try{u=await r.get({id:_,lazy:s,select:n},i),u=u&&Ed(u)}catch(d){u={message:d.toString()}}return t?{value:{key:_,value:u}}:{value:u}}else return o(),{done:!0}},return(_){return o(),{value:_,done:!0}},throw(_){return o(),{done:!0}}}}}}function ns(e){let t=e.database||e.schema||qJ,r=mr()[t];if(!r)throw(0,Pn.handleHDBError)(new Error,FJ.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function HC(e,t,r){let n=e.length+t.length,s=n===1?"record":"records";return{message:`${e.length} of ${n} ${s} successfully deleted`,deleted_hashes:e,skipped_hashes:t,txn_time:r}}async function*xC(e,t,r){let n;for await(let s of e.getHistory(t,r)){let i=s.type;i==="put"&&(i="upsert");let{id:o,version:c,value:l}=s;n?.timestamp===c?(n.hash_values.push(o),n.records.push(l)):(n&&(yield n),n={operation:i,user_name:s.user,timestamp:c,hash_values:[o],records:[l]})}n&&(yield n)}var GC,fd,Pn,FC,Un,tS,rS,qC,FJ,qJ,kJ,VJ,vC,nS,VC=Re(()=>{"use strict";GC=x(NC()),fd=x(ra()),Pn=x(se());Ae();FC=x($c()),Un=x(P()),tS=x(bs()),rS=x(Mn()),qC=x(z());no();hd();({HDB_ERROR_MSGS:FJ}=Pn.hdb_errors),qJ="data",kJ=1e4,VJ=10,nS=class extends GC.default{static{a(this,"ResourceBridge")}constructor(t){super(t),vC=this}async searchByConditions(t){t.select!==void 0&&(t.get_attributes=t.select);for(let o of t.conditions||[])o?.attribute!==void 0&&(o.search_attribute=o.attribute),o?.comparator!==void 0&&(o.search_type=o.comparator),o?.value!==void 0&&(o.search_value=o.value);let r=(0,fd.default)(t,"conditions");if(r)throw(0,Pn.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=ns(t);if(!n)throw new Pn.ClientError(`Table ${t.table} not found`);let s=t.conditions.map(i);function i(o){return o.conditions?(o.conditions=o.conditions.map(i),o):{attribute:o.search_attribute??o.attribute,comparator:o.search_type??o.comparator,value:o.search_value!==void 0?o.search_value:o.value}}return a(i,"mapCondition"),n.search({conditions:s,operator:t.operator?t.operator.toLowerCase():void 0,limit:t.limit,offset:t.offset,reverse:t.reverse,select:sS(t,n),sort:t.sort,allowFullScan:!0},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache})}async createTable(t,r){let n=r.attributes,s=!!n,i=r.primary_key||r.hash_attribute;if(n)for(let o of n)o.is_primary_key?(o.isPrimaryKey=!0,delete o.is_primary_key):o.name===i&&i&&(o.isPrimaryKey=!0);else{if(!i)throw new Pn.ClientError("A primary key must be specified with a `primary_key` property or with `attributes`");n=[{name:i,isPrimaryKey:!0},{name:"__createdtime__",indexed:!0},{name:"__updatedtime__",indexed:!0}]}ft({database:r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration})}async createAttribute(t){return await ns(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=ns(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=a((o,c,l)=>(c=Object.assign({},c),delete c[n],r.primaryStore.ifVersion(o,l,()=>r.primaryStore.put(o,c,l)).then(_=>{if(!_){let{value:u,version:d}=r.primaryStore.getEntry(o);return i(o,u,d)}})),"deleteRecord");for(let{key:o,value:c,version:l}of r.primaryStore.getRange({start:!0,versions:!0}))s=i(o,c,l),await new Promise(_=>setImmediate(_));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){ns(t).dropTable()}createSchema(t){return ia({database:t.schema,table:null}),tS.signalSchemaChange(new rS.SchemaEventMsg(process.pid,Un.OPERATIONS_ENUM.CREATE_SCHEMA,t.schema))}async dropSchema(t){await iS(t.schema),tS.signalSchemaChange(new rS.SchemaEventMsg(process.pid,Un.OPERATIONS_ENUM.DROP_SCHEMA,t.schema))}async updateRecords(t){return t.requires_existing=!0,this.upsertRecords(t)}async createRecords(t){return t.requires_no_existing=!0,vC.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,FC.default)(t),s,i=mr()[t.schema][t.table],o={user:t.hdb_user,expiresAt:t.expiresAt};return Ze(o,async c=>{if(!i.schemaDefined){s=[];for(let u of n)i.attributes.find(E=>E.name==u)||s.push(u);s.length>0&&await i.addAttributes(s.map(u=>({name:u,indexed:!0})))}let l=[],_=[];for(let u of t.records){let d=u[i.primaryKey],E=d!=null&&await i.get(d,o);if(t.requires_existing&&!E||t.requires_no_existing&&E){_.push(u[i.primaryKey]);continue}E&&(E=Ed(E));for(let f in u)if(Object.prototype.hasOwnProperty.call(u,f)){let h=u[f];if(typeof h=="function")try{let p=h([[E]]);Array.isArray(p)&&(h=p[0].func_val,u[f]=h)}catch(p){throw p.message+="Trying to set key "+f+" on object"+JSON.stringify(u),p}}if(E)for(let f in E)Object.prototype.hasOwnProperty.call(u,f)||(u[f]=E[f]);await(d==null?i.create(u,o):i.put(u,o)),l.push(u[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:l,new_attributes:s,skipped_hashes:_}})}async deleteRecords(t){let r=mr()[t.schema][t.table],n={user:t.hdb_user};return Ze(n,async s=>{let i=t.hash_values||t.records.map(l=>l[r.primaryKey]),o=[],c=[];for(let l of i)await r.delete(l,n)?o.push(l):c.push(l);return HC(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=mr()[t.schema][t.table];if(!r.createdTimeProperty)throw new Pn.ClientError("Table must have a '__createdtime__' attribute or @createdTime timestamp defined to perform this operation");let n=await r.search({conditions:[{attribute:r.createdTimeProperty.name,value:Date.parse(t.date),comparator:Un.VALUE_SEARCH_COMPARATORS.LESS}]}),s=!1,i=[],o=[],c=0,l=[],_=a(async()=>{let u=await this.deleteRecords({schema:t.schema,table:t.table,hash_values:l});i.push(...u.deleted_hashes),o.push(...u.skipped_hashes),await(0,qC.async_set_timeout)(VJ),l=[],s=!0},"chunkDelete");for await(let u of n)l.push(u[r.primaryKey]),c++,c%kJ===0&&await _();return l.length>0&&await _(),s?HC(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,fd.default)(t,"hashes");if(r)throw r;return BC(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of BC(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&Un.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r]===void 0)throw new Error(`Value search comparator - ${r} - is not valid`);t.select!==void 0&&(t.get_attributes=t.select),t.attribute!==void 0&&(t.search_attribute=condition.attribute),t.value!==void 0&&(t.search_value=condition.value);let n=(0,fd.default)(t,"value");if(n)throw n;let s=ns(t);if(!s)throw new Pn.ClientError(`Table ${t.table} not found`);let i=t.search_value;i.includes?.("*")&&(i.startsWith("*")?i.endsWith("*")?i!=="*"&&(r="contains",i=i.slice(1,-1)):(r="ends_with",i=i.slice(1)):i.endsWith("*")&&(r="starts_with",i=i.slice(0,-1))),r===Un.VALUE_SEARCH_COMPARATORS.BETWEEN&&(i=[i,t.end_value]);let o=i==="*"?[]:[{attribute:t.search_attribute,value:i,comparator:r}];return s.search({conditions:o,allowFullScan:!0,limit:t.limit,offset:t.offset,reverse:t.reverse,sort:t.sort,select:sS(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache})}async getDataByValue(t,r){let n=new Map,s=ns(t);t.get_attributes&&!t.get_attributes.includes(s.primaryKey)&&t.get_attributes[0]!=="*"&&t.get_attributes.push(s.primaryKey);for await(let i of this.searchByValue(t,r))n.set(i[s.primaryKey],i);return n}resetReadTxn(t,r){ns({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return ns(t).deleteHistory(t.timestamp)}async readAuditLog(t){let r=ns(t),n={};switch(t.search_type){case Un.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:for(let i of t.search_values)n[i]=(await r.getHistoryOfRecord(i)).map(o=>{let c=o.type;return c==="put"&&(c="upsert"),{operation:c,timestamp:o.version,user_name:o.user,hash_values:[i],records:[o.value]}});return n;case Un.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:let s=t.search_values;for await(let i of xC(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return xC(r,t.search_values?.[0],t.search_values?.[1])}}};a(sS,"getSelect");a(BC,"getRecords");a(ns,"getTable");a(HC,"createDeleteResponse");a(xC,"groupRecordsInHistory")});var Ln=g((y_e,$C)=>{"use strict";var{ResourceBridge:$J}=(VC(),ie(kC)),YJ=ne();YJ.initSync();var md;function KJ(){return md||(md=new $J,md)}a(KJ,"getBridge");$C.exports=KJ()});var QC=g((I_e,WC)=>{"use strict";var YC=require("lodash"),cl=require("mathjs"),WJ=require("jsonata"),KC=z();WC.exports={distinct_array:e=>Array.isArray(e)&&e.length>1?YC.uniqWith(e,YC.isEqual):e,searchJSON:QJ,mad:ll.bind(null,cl.mad),mean:ll.bind(null,cl.mean),mode:ll.bind(null,cl.mode),prod:ll.bind(null,cl.prod),median:ll.bind(null,cl.median)};function ll(e,t,r,n){return n===1?t==null?[]:[t]:n===2?(t!=null&&r.push(t),r):r!=null&&r.length>0?e(r):null}a(ll,"aggregateFunction");function QJ(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(KC.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),KC.isEmpty(this.__ala__.res[r])){let n=WJ(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(QJ,"searchJSON")});var JC=g((C_e,zC)=>{"use strict";var gt=require("moment"),oS="YYYY-MM-DDTHH:mm:ss.SSSZZ";gt.suppressDeprecationWarnings=!0;zC.exports={current_date:()=>gt().utc().format("YYYY-MM-DD"),current_time:()=>gt().utc().format("HH:mm:ss.SSS"),extract:(e,t)=>{switch(t.toLowerCase()){case"year":return gt(e).utc().format("YYYY");case"month":return gt(e).utc().format("MM");case"day":return gt(e).utc().format("DD");case"hour":return gt(e).utc().format("HH");case"minute":return gt(e).utc().format("mm");case"second":return gt(e).utc().format("ss");case"millisecond":return gt(e).utc().format("SSS");default:break}},date:e=>gt(e).utc().format(oS),date_format:(e,t)=>gt(e).utc().format(t),date_add:(e,t,r)=>gt(e).utc().add(t,r).valueOf(),date_sub:(e,t,r)=>gt(e).utc().subtract(t,r).valueOf(),date_diff:(e,t,r)=>{let n=gt(e).utc(),s=gt(t).utc();return r?n.diff(s,r,!0):n.diff(s)},now:()=>gt().utc().valueOf(),get_server_time:()=>gt().format(oS),offset_utc:(e,t)=>gt(e).utc().utcOffset(t).format(oS)}});var eD=g((D_e,ZC)=>{"use strict";var zJ=require("@turf/area"),JJ=require("@turf/length"),XJ=require("@turf/circle"),jJ=require("@turf/difference"),ZJ=require("@turf/distance"),e4=require("@turf/boolean-contains"),t4=require("@turf/boolean-equal"),r4=require("@turf/boolean-disjoint"),n4=require("@turf/helpers"),XC=P(),Te=z(),Is=K();ZC.exports={geoArea:s4,geoLength:i4,geoCircle:o4,geoDifference:a4,geoDistance:jC,geoNear:c4,geoContains:l4,geoEqual:u4,geoCrosses:_4,geoConvert:d4};function s4(e){if(Te.isEmpty(e))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e));try{return zJ.default(e)}catch(t){return Is.trace(t,e),NaN}}a(s4,"geoArea");function i4(e,t){if(Te.isEmpty(e))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e));try{return JJ.default(e,{units:t||"kilometers"})}catch(r){return Is.trace(r,e),NaN}}a(i4,"geoLength");function o4(e,t,r){if(Te.isEmpty(e))return NaN;if(Te.isEmpty(t))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e));try{return XJ.default(e,t,{units:r||"kilometers"})}catch(n){return Is.trace(n,e,t),NaN}}a(o4,"geoCircle");function a4(e,t){if(Te.isEmpty(e))return NaN;if(Te.isEmpty(t))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return jJ(e,t)}catch(r){return Is.trace(r,e,t),NaN}}a(a4,"geoDifference");function jC(e,t,r){if(Te.isEmpty(e))return NaN;if(Te.isEmpty(t))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return ZJ.default(e,t,{units:r||"kilometers"})}catch(n){return Is.trace(n,e,t),NaN}}a(jC,"geoDistance");function c4(e,t,r,n){if(Te.isEmpty(e)||Te.isEmpty(t))return!1;if(Te.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t)),isNaN(r))throw new Error("distance must be a number");try{return jC(e,t,n)<=r}catch(s){return Is.trace(s,e,t),!1}}a(c4,"geoNear");function l4(e,t){if(Te.isEmpty(e)||Te.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return e4.default(e,t)}catch(r){return Is.trace(r,e,t),!1}}a(l4,"geoContains");function u4(e,t){if(Te.isEmpty(e)||Te.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return t4.default(e,t)}catch(r){return Is.trace(r,e,t),!1}}a(u4,"geoEqual");function _4(e,t){if(Te.isEmpty(e)||Te.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return!r4.default(e,t)}catch(r){return Is.trace(r,e,t),!1}}a(_4,"geoCrosses");function d4(e,t,r){if(Te.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if(Te.isEmpty(t))throw new Error("geo_type is required");if(Te.isEmpty(XC.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(XC.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Te.autoCastJSON(e)),n4[t](e,r)}a(d4,"geoConvert")});var pd=g((M_e,tD)=>{var so=QC(),Kr=JC(),ss=eD();tD.exports=e=>{e.aggr.mad=e.aggr.MAD=so.mad,e.aggr.mean=e.aggr.MEAN=so.mean,e.aggr.mode=e.aggr.MODE=so.mode,e.aggr.prod=e.aggr.PROD=so.prod,e.aggr.median=e.aggr.MEDIAN=so.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=so.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=so.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=Kr.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Kr.current_time,e.fn.extract=e.fn.EXTRACT=Kr.extract,e.fn.date=e.fn.DATE=Kr.date,e.fn.date_format=e.fn.DATE_FORMAT=Kr.date_format,e.fn.date_add=e.fn.DATE_ADD=Kr.date_add,e.fn.date_sub=e.fn.DATE_SUB=Kr.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Kr.date_diff,e.fn.now=e.fn.NOW=Kr.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Kr.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Kr.get_server_time,e.fn.getdate=e.fn.GETDATE=Kr.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Kr.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=ss.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=ss.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=ss.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=ss.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=ss.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=ss.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=ss.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=ss.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=ss.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=ss.geoNear}});var iD=g((P_e,sD)=>{"use strict";var ul=require("lodash"),pr=require("alasql");pr.options.cache=!1;var f4=pd(),rD=require("clone"),Sd=require("recursive-iterator"),fe=K(),Le=z(),oa=Ln(),E4=P(),{hdb_errors:h4}=se(),{getDatabases:nD}=(Ae(),ie(ke)),m4="IS NULL",vn="There was a problem performing this search. Please check the logs and try again.";f4(pr);var aS=class{static{a(this,"SQLSearch")}constructor(t,r){if(Le.isEmpty(t))throw fe.error("AST statement for SQL select process cannot be empty"),"statement cannot be null";this.statement=t,this.columns={},this.all_table_attributes=r,this.fetch_attributes=[],this.exact_search_values={},this.comparator_search_values={},this.tables=[],this.data={},this.has_aggregator=!1,this.has_ordinal=!1,this.has_outer_join=!1,this._getColumns(),this._getTables(),this._conditionsToFetchAttributeValues(),this._setAliasesForColumns(),Le.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!Le.isEmptyOrZeroLength(n))return fe.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw fe.error("Error thrown from checkEmptySQL in SQLSearch class method search."),fe.error(n),new Error(vn)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw fe.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),fe.error(n),new Error(vn)}if(Object.keys(this.data).length===0)return fe.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw fe.error("Error thrown from processJoins in SQLSearch class method search."),fe.error(n),new Error(vn)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw fe.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),fe.error(n),new Error(vn)}try{return t=await this._finalSQL(),t}catch(n){throw fe.error("Error thrown from finalSQL in SQLSearch class method search."),fe.error(n),new Error(vn)}}_getColumns(){let t=new Sd(this.statement);for(let{node:r,path:n}of t)r&&r.columnid&&(this.columns[n[0]]||(this.columns[n[0]]=[]),this.columns[n[0]].push(rD(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=ul.uniqBy(t,r=>[r.databaseid,r.tableid,r.as].join()),this.tables.forEach(r=>{let n=`${r.databaseid}_${r.as?r.as:r.tableid}`;this.data[n]={},this.data[n].__hash_name=nD()[r.databaseid][r.tableid].primaryKey,this.data[n].__merged_data={},this.data[n].__merged_attributes=[],this.data[n].__merged_attr_map={}})}_conditionsToFetchAttributeValues(){if(Le.isEmpty(this.statement.where)){fe.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new Sd(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!Le.isEmpty(r)&&r.right)if(Le.isNotEmptyAndHasValue(r.right.value)){let n=Le.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new pr.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=Le.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new pr.yy.LogicValue({value:i}):n instanceof pr.yy.StringValue&&Le.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new pr.yy.NumValue({value:i}))});if(t){fe.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new Sd(this.statement.where))if(r&&r.left&&r.right&&(r.left.columnid||r.right.value)&&r.op){let n=new Set,s=r.left.columnid?r.left:r.right,i=this._findColumn(s);if(!i)continue;let o=[i.table.databaseid,i.table.tableid,i.attribute].join("/");if(!Le.isEmpty(E4.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(Le.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(Le.isEmptyOrZeroLength(r.left.columnid)||Le.isEmptyOrZeroLength(r.right.value)){this.comparator_search_values[o].ignore=!0,this.comparator_search_values[o].comparators=[];continue}this.comparator_search_values[o].comparators.push({attribute:r.left.columnid,operation:r.op,search_value:r.right.value})}continue}if(Le.isEmpty(this.exact_search_values[o])&&(this.exact_search_values[o]={ignore:!1,values:new Set}),!this.exact_search_values[o].ignore){let c=!1;switch(r.op){case"=":!Le.isEmpty(r.right.value)||!Le.isEmpty(r.left.value)?n.add(Le.isEmpty(r.right.value)?r.left.value:r.right.value):c=!0;break;case"IN":let l=Array.isArray(r.right)?r.right:r.left;for(let _=0;_<l.length;_++)if(l[_].value)n.add(l[_].value);else{c=!0;break}break;default:c=!0;break}this.exact_search_values[o].ignore=c,c?this.exact_search_values[o].values=new Set:this.exact_search_values[o].values=new Set([...this.exact_search_values[o].values,...n])}}}_setAliasesForColumns(){if(Le.isEmptyOrZeroLength(this.all_table_attributes)&&Le.isEmptyOrZeroLength(this.statement.from)&&Le.isEmptyOrZeroLength(this.columns.columns))return;let t=[],r={};this.statement.columns.forEach((n,s)=>{if(n.columnid==="*"){t.push(s);return}if(n.aggregatorid&&(this.has_aggregator=!0),!n.aggregatorid&&!n.funcid)if(n.as_orig=n.as?n.as:n.columnid,this.statement.joins)if(r[n.as_orig]>=0){let i=r[n.as_orig]+1;n.as=`[${n.as_orig+i}]`,r[n.as_orig]=i}else n.as=`[${n.as_orig}]`,r[n.as_orig]=0;else n.as=`[${n.as_orig}]`;!n.aggregatorid&&n.funcid&&n.args&&(n.as_orig=n.as?n.as:n.toString().replace(/'/g,'"'),n.as=`[${n.as_orig}]`),n.aggregatorid&&n.expression.columnid!=="*"&&(n.as_orig=n.as?n.as:n.expression.tableid?`${n.aggregatorid}(${n.expression.tableid}.${n.expression.columnid})`:`${n.aggregatorid}(${n.expression.columnid})`,n.as=`[${n.as_orig}]`)}),this.statement.columns.length>1&&t.length>0&&ul.pullAt(this.statement.columns,t)}_findColumn(t){let r=this.all_table_attributes.filter(n=>{if(t.columnid_orig&&t.tableid_orig)return(n.table.as===t.tableid_orig||n.table.tableid===t.tableid_orig)&&n.attribute===t.columnid_orig;if(t.tableid)return(n.table.as===t.tableid||n.table.tableid===t.tableid)&&n.attribute===t.columnid;let s=t.columnid_orig?t.columnid_orig:t.columnid;return n.attribute===s});if(Le.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);Le.isEmptyOrZeroLength(n)||(r=this.all_table_attributes.filter(s=>s.attribute===n[0].columnid&&n[0].tableid&&n[0].tableid===(s.table.as?s.table.as:s.table.tableid)))}return r[0]}async _checkEmptySQL(){let t=[];if(Le.isEmptyOrZeroLength(this.all_table_attributes)&&!Le.isEmptyOrZeroLength(this.columns.columns))return t;if(Le.isEmptyOrZeroLength(this.all_table_attributes)&&Le.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await pr.promise(r)}catch(r){throw fe.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),fe.error(r),new Error("There was a problem with the SQL statement")}return t}_addFetchColumns(t){t&&t.length>0&&t.forEach(r=>{let n=this._findColumn(r);n&&this.fetch_attributes.push(rD(n))})}_addColumnToMergedAttributes(t,r){this.data[t].__merged_attributes.push(r),this.data[t].__merged_attr_map[r]=this.data[t].__merged_attributes.length-1}_setMergedHashAttribute(t,r){this.data[t].__merged_data[r].splice(0,1,r)}_updateMergedAttribute(t,r,n,s){let i=this.data[t].__merged_attr_map[n];this.data[t].__merged_data[r].splice(i,1,s)}async _getFetchAttributeValues(){if(Le.isEmptyOrZeroLength(Object.keys(this.columns)))return[];this._addFetchColumns(this.columns.joins);let t=null;try{t=this.statement.where?this.statement.where.toString():""}catch{throw new Error("Could not generate proper where clause")}this.columns.where&&this._addFetchColumns(this.columns.where);let r=this._isSimpleSelect();if(r?this._addFetchColumns(this.columns.columns):(!this.columns.where&&this.fetch_attributes.length===0)|t.indexOf(m4)>-1&&this.tables.forEach(s=>{let i={columnid:nD()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=ul.uniqBy(this.fetch_attributes,s=>[s.table.databaseid,s.table.as?s.table.as:s.table.tableid,s.attribute].join()),r)return await this._simpleSQLQuery();let n=this.fetch_attributes.reduce((s,i)=>{let o=`${i.table.databaseid}_${i.table.as?i.table.as:i.table.tableid}`,c=this.data[o].__hash_name;return s[o]||(s[o]=[],s[o].push(null),this._addColumnToMergedAttributes(o,c)),i.attribute!==c&&(s[o].push(null),this._addColumnToMergedAttributes(o,i.attribute)),s},{});for(let s of this.fetch_attributes){let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`,o=this.data[i].__hash_name,c={schema:s.table.databaseid,table:s.table.tableid,get_attributes:[s.attribute]},l=!1,_=[s.table.databaseid,s.table.tableid,s.attribute].join("/");if(s.attribute===o&&(l=!0),!Le.isEmpty(this.exact_search_values[_])&&!this.exact_search_values[_].ignore&&!Le.isEmptyOrZeroLength(this.exact_search_values[_].values))if(l)try{c.hash_values=Array.from(this.exact_search_values[_].values);let u=await oa.getDataByHash(c);for(let d of c.hash_values)u.get(d)&&!this.data[i].__merged_data[d]&&(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d))}catch(u){throw fe.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),fe.error(u),new Error(vn)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[_].values).map(async u=>{let d=Object.assign({},c);d.search_value=u;let E=await oa.getDataByValue(d);for(let[f,h]of E)this.data[i].__merged_data[f]?this._updateMergedAttribute(i,f,s.attribute,h[s.attribute]):(this.data[i].__merged_data[f]=[...n[i]],this._updateMergedAttribute(i,f,s.attribute,h[s.attribute]),this._setMergedHashAttribute(i,f))}))}catch(u){throw fe.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),fe.error(u),new Error(vn)}else if(!Le.isEmpty(this.comparator_search_values[_])&&!this.comparator_search_values[_].ignore&&!Le.isEmptyOrZeroLength(this.comparator_search_values[_].comparators))try{let u=this.comparator_search_values[_].comparators;for(let d=0,E=u.length;d<E;d++){let f=u[d];c.search_attribute=f.attribute,c.search_value=f.search_value;let h=await oa.getDataByValue(c,f.operation);if(l)for(let[p]of h)this.data[i].__merged_data[p]||(this.data[i].__merged_data[p]=[...n[i]],this._setMergedHashAttribute(i,p));else for(let[p,S]of h)this.data[i].__merged_data[p]?this._updateMergedAttribute(i,p,s.attribute,S[s.attribute]):(this.data[i].__merged_data[p]=[...n[i]],this._updateMergedAttribute(i,p,s.attribute,S[s.attribute]),this._setMergedHashAttribute(i,p))}}catch(u){throw fe.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),fe.error(u),new Error(vn)}else try{c.search_attribute=s.attribute,c.search_value="*";let u=await oa.getDataByValue(c);if(l)for(let[d]of u)this.data[i].__merged_data[d]||(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d));else for(let[d,E]of u)this.data[i].__merged_data[d]?this._updateMergedAttribute(i,d,s.attribute,E[s.attribute]):(this.data[i].__merged_data[d]=[...n[i]],this._updateMergedAttribute(i,d,s.attribute,E[s.attribute]),this._setMergedHashAttribute(i,d))}catch(u){throw fe.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),fe.error(u),new Error(vn)}}}_isSimpleSelect(){let t=!0;return Object.keys(this.statement).length!==2||!this.statement.columns||!this.statement.from||this.statement.from.length!==1?(t=!1,t):(this.statement.columns.forEach(r=>{r instanceof pr.yy.Column||(t=!1)}),t)}_updateOrderByToAliases(){this.statement.order.forEach(t=>{if(t.expression.aggregatorid){t.is_aggregator=!0;return}if(t.expression.value){t.is_ordinal=!0,this.has_ordinal=!0;return}else t.is_ordinal=!1;let r=this.statement.columns.filter(s=>{let i=s.aggregatorid?s.expression:s,o=s.aggregatorid?s.as_orig:i.as_orig;return t.expression.tableid?i.columnid_orig===t.expression.columnid_orig&&i.tableid_orig===t.expression.tableid_orig:i.columnid_orig===t.expression.columnid_orig||t.expression.columnid_orig===o});r[0]||r.push(this._findColumn(t.expression));let n=r[0];if(t.is_func=!!n.funcid,t.is_aggregator=!!n.aggregatorid,n.as)if(n.as&&!t.expression.tableid)t.expression.columnid=n.as,t.expression.columnid_orig=n.as_orig;else{let s=new pr.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new pr.yy.Column,t.expression),t.initial_select_column.as=`[${t.expression.columnid_orig}]`,t.expression.columnid=t.initial_select_column.as;return}if(!t.is_aggregator){let s=t.is_func?new pr.yy.FuncValue:new pr.yy.Column;t.initial_select_column=Object.assign(s,n)}})}_addNonAggregatorsToFetchColumns(){let r=this.statement.order.filter(n=>!n.is_aggregator&&!n.is_ordinal).map(n=>n.is_func?{columnid:n.initial_select_column.args.filter(i=>!!i.columnid_orig)[0].columnid_orig}:{columnid:n.expression.columnid_orig});this._addFetchColumns(r)}async _processJoins(){let t=[],r=[],n=this.statement.from[0],s=[n],i=["? "+(n.as?" AS "+n.as:n.tableid)];t.push(Object.values(this.data[`${n.databaseid_orig}_${n.as?n.as_orig:n.tableid_orig}`].__merged_data)),this.statement.joins&&this.statement.joins.forEach(f=>{f.joinmode&&f.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(f.table);let h=f.joinmode+" JOIN ? AS "+(f.as?f.as:f.table.tableid);f.on&&(h+=" ON "+f.on.toString()),i.push(h),t.push(Object.values(this.data[`${f.table.databaseid_orig}_${f.table.as?f.table.as_orig:f.table.tableid_orig}`].__merged_data))});let o=[],c={};s.forEach(f=>{let h=this.data[`${f.databaseid_orig}_${f.as?f.as_orig:f.tableid_orig}`].__hash_name,p=f.as?f.as_orig:f.tableid_orig;o.push({key:`'${p}.${h}'`,schema:f.databaseid_orig,table:f.as?f.as_orig:f.tableid_orig,keys:new Set}),r.push(`${f.as?f.as:f.tableid}.\`${h}\` AS "${p}.${h}"`),c[f.as?f.as_orig:f.tableid_orig]=this.data[`${f.databaseid_orig}_${f.as?f.as_orig:f.tableid_orig}`].__merged_attributes});let l=this.statement.where?"WHERE "+this.statement.where:"";l=l.replace(/NOT\(NULL\)/g,"NOT NULL");let _="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(_="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(f=>{f.is_func?r.push(f.initial_select_column.toString()):f.initial_select_column.tableid?r.push(`${f.initial_select_column.tableid}.${f.initial_select_column.columnid} AS ${f.expression.columnid}`):r.push(`${f.initial_select_column.columnid} AS ${f.expression.columnid}`)}));let u="",d="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(u=this.statement.limit?"LIMIT "+this.statement.limit:"",d=this.statement.offset?"OFFSET "+this.statement.offset:"");let E=[];try{let f=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${l} ${_} ${u} ${d}`,h=this._convertColumnsToIndexes(f,s);E=await pr.promise(h,t),t=null}catch(f){throw fe.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),fe.error(f),new Error("There was a problem processing the data.")}if(E&&E.length>0){for(let f=0,h=E.length;f<h;f++){let p=E[f];o.forEach(S=>{p[S.key]!==null&&p[S.key]!==void 0&&S.keys.add(p[S.key])})}o.forEach(f=>{let h=Object.keys(this.data[`${f.schema}_${f.table}`].__merged_data),p=ul.difference(h,[...f.keys].map(S=>S.toString()));for(let S=0,T=p.length;S<T;S++){let A=p[S];delete this.data[`${f.schema}_${f.table}`].__merged_data[A]}})}return{existing_attributes:c,joined_length:E?E.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new Sd(this.columns);for(let{node:i}of s)if(i&&i.columnid){let o=this._findColumn(i);if(o){let c=o.table.as?o.table.as:o.table.tableid;(!t[c]||t[c].indexOf(o.attribute)<0)&&n.push(o)}}n=ul.uniqBy(n,i=>[i.table.databaseid,i.table.as?i.table.as:i.table.tableid,i.attribute].join());try{await this._getData(n)}catch(i){throw fe.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),fe.error(i),new Error(vn)}}async _getData(t){try{let r=t.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]?n[i].columns.push(s.attribute):n[i]={schema:s.table.databaseid,table:s.table.tableid,columns:[s.attribute]},n},{});for(let n in r){let s=r[n],i=this.data[n].__merged_data,o=[];for(let u in i)o.push(i[u][0]);this.data[n].__merged_attributes.push(...s.columns);let c={schema:s.schema,table:s.table,hash_values:o,get_attributes:s.columns},l=await oa.getDataByHash(c),_=s.columns.length;for(let u=0,d=o.length;u<d;u++){let E=o[u],f=l.get(E);for(let h=0;h<_;h++){let p=s.columns[h],S=f[p]===void 0?null:f[p];this.data[n].__merged_data[E].push(S)}}}}catch(r){throw fe.error("Error thrown from getDataByHash function in SQLSearch class method getData."),fe.error(r),r}}async _finalSQL(){let t=[],r=this.statement.from[0];t.push(Object.values(this.data[`${r.databaseid_orig}_${r.as?r.as_orig:r.tableid_orig}`].__merged_data)),r.as=r.as?r.as:r.tableid,r.databaseid="",r.tableid="?",this.statement.joins&&this.statement.joins.forEach(s=>{s.as=s.as?s.as:s.table.tableid,t.push(Object.values(this.data[`${s.table.databaseid_orig}_${s.table.as?s.table.as_orig:s.table.tableid_orig}`].__merged_data)),s.table.databaseid="",s.table.tableid="?"}),this.statement.order&&this.statement.order.forEach(s=>{if(s.is_ordinal)return;this.statement.columns.filter(o=>{let c=o.aggregatorid?o.expression:o,l=o.aggregatorid?o.as_orig:c.as_orig;return s.expression.tableid?c.columnid_orig===s.expression.columnid_orig&&c.tableid_orig===s.expression.tableid_orig:c.columnid_orig===s.expression.columnid_orig||s.expression.columnid_orig===l}).length===0&&(s.expression.columnid=s.initial_select_column.columnid)}),!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&this.statement.limit&&!this.statement.joins&&(delete this.statement.limit,delete this.statement.offset);let n;try{let s=this._buildSQL();fe.trace(`Final SQL: ${s}`),n=await pr.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),fe.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw fe.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),fe.error(s),new Error("There was a problem running the generated sql.")}return n}_translateUndefinedValues(t){try{let r=[];for(let n of t){let s=Object.create(null);Object.keys(n).forEach(i=>{n[i]===void 0?s[i]=null:s[i]=n[i]}),r.push(s)}return r}catch(r){return fe.error(h4.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),fe.trace(r.stack),t}}_buildSQL(t=!0){let r=this.statement.toString();return r=r.replace(/NOT\(NULL\)/g,"NOT NULL"),this.statement.columns.forEach(n=>{if(n.funcid&&n.as){let s=n.toString().replace(" AS "+n.as,"");r=r.replace(n.toString(),s)}}),t===!0?this._convertColumnsToIndexes(r,this.tables):r}_convertColumnsToIndexes(t,r){let n=t,s={};r.forEach(i=>{i.databaseid_orig?s[`${i.databaseid_orig}_${i.as?i.as_orig:i.tableid_orig}`]=i.as?i.as:i.tableid:s[`${i.databaseid}_${i.as?i.as:i.tableid}`]=`\`${i.as?i.as:i.tableid}\``});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=s[i],_=new RegExp(`${l}.\`${o}\``,"g"),u=`${l}.[${c}]`;n=n.replace(_,u)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=new RegExp(`\`${o}\``,"g"),_=`[${c}]`;n=n.replace(l,_)});return n}async _simpleSQLQuery(){let t=this.statement.columns.reduce((n,s)=>(s.as_orig&&s.as_orig!=s.columnid_orig?n[s.columnid_orig]=s.as_orig:n[s.columnid_orig]||(n[s.columnid_orig]=s.columnid_orig),n),{}),r=this.fetch_attributes.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]||(n[i]={}),n[i][t[s.attribute]]=null,n},{});for(let n of this.fetch_attributes){let s=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`,i={schema:n.table.databaseid,table:n.table.tableid,get_attributes:[n.attribute]};try{i.search_attribute=n.attribute,i.search_value="*";let o=await oa.getDataByValue(i);for(let[c,l]of o)this.data[s].__merged_data[c]||(l[n.attribute]===void 0&&(l[n.attribute]=null),this.data[s].__merged_data[c]=Object.assign({},r[s])),this.data[s].__merged_data[c][t[n.attribute]]=l[n.attribute]??null}catch(o){throw fe.error("There was an error when processing this SQL operation. Check your logs"),fe.error(o),new Error(vn)}}return Object.values(Object.values(this.data)[0].__merged_data)}};sD.exports=aS});var kr=g((v_e,oD)=>{"use strict";var p4=ny();oD.exports={searchByConditions:T4,searchByHash:g4,searchByValue:R4,search:A4};var cS=Ln(),{transformReq:lS}=z(),S4=iD();async function T4(e){return lS(e),cS.searchByConditions(e)}a(T4,"searchByConditions");async function g4(e){lS(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of cS.searchByHash(e))r&&t.push(r);return t}a(g4,"searchByHash");async function R4(e){lS(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of cS.searchByValue(e))t.push(r);return t}a(R4,"searchByValue");function A4(e,t){try{let r=new p4(e);r.validate(),new S4(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(A4,"search")});var Td=g((H_e,aD)=>{"use strict";var O4=Ln();aD.exports={writeTransaction:b4};function b4(e,t,r){return O4.writeTransaction(e,t,r)}a(b4,"writeTransaction")});var _D=g((F_e,uD)=>{"use strict";var y4=kr(),N4=ii(),cD=K(),I4=un(),G_e=Td(),w4=require("clone"),_S=require("alasql"),C4=pd(),lD=require("util"),D4=lD.promisify(N4.getTableSchema),L4=lD.promisify(y4.search),M4=P(),uS=z();C4(_S);uD.exports={update:U4};var P4="There was a problem performing this update. Please check the logs and try again.";async function U4({statement:e,hdb_user:t}){let r=await D4(e.table.databaseid,e.table.tableid),n=v4(e.columns);uS.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=w4(s),c=uS.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,_=_S.parse(l).statements[0],u=await L4(_),d=B4(n,u);return H4(o,d,t)}a(U4,"update");function v4(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=_S.compile(`SELECT ${r.expression.toString()} AS [${M4.FUNC_VAL}] FROM ?`)}),t}catch(t){throw cD.error(t),new Error(P4)}}a(v4,"createUpdateRecord");function B4(e,t){return uS.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(B4,"buildUpdateRecords");async function H4(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await I4.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){cD.error(`Error delete new_attributes from update response: ${i}`)}return s}a(H4,"updateRecords")});var fD=g(($_e,dD)=>{var x4=require("alasql"),G4=kr(),F4=K(),q4=Ln(),fS=require("util"),dS=z(),k4=P(),V4=ii(),k_e=Td(),V_e=un(),$4="record",Y4="successfully deleted",K4=fS.callbackify(J4),W4=fS.promisify(G4.search),Q4=fS.promisify(V4.getTableSchema);dD.exports={convertDelete:K4};function z4(e){return`${e.deleted_hashes.length} ${$4}${e.deleted_hashes.length===1?"":"s"} ${Y4}`}a(z4,"generateReturnMessage");async function J4({statement:e,hdb_user:t}){let r=await Q4(e.table.databaseid,e.table.tableid);dS.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=dS.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=x4.parse(o).statements[0],l={operation:k4.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await W4(c);let _=await q4.deleteRecords(l);return dS.isEmptyOrZeroLength(_.message)&&(_.message=z4(_)),delete _.txn_time,_}catch(_){throw F4.error(_),_.hdb_code?_.message:_}}a(J4,"convertDelete")});var SD=g((K_e,pD)=>{"use strict";var X4=si(),{hdb_errors:ED}=se(),{getDatabases:hD}=(Ae(),ie(ke));pD.exports={checkSchemaExists:mD,checkSchemaTableExists:j4,schema_describe:X4};async function mD(e){if(!hD()[e])return ED.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(mD,"checkSchemaExists");async function j4(e,t){let r=await mD(e);if(r)return r;if(!hD()[e][t])return ED.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(j4,"checkSchemaTableExists")});var _l=g((Q_e,Z4)=>{Z4.exports={name:"harperdb",version:"4.3.29",description:"HarperDB is a distributed database, caching service, streaming broker, and application development platform focused on performance and ease of use.",keywords:["database","nosql","api","distributed","broker","mqtt","real-time","enterprise","Fastify","NATS","HarperDB","Harper","clustering","replication","REST","WebSockets","decentralized","server-sent events","document store"],main:"harperdb.js",bin:{harperdb:"./bin/harperdb.js"},engines:{"minimum-node":"16.0.0","go-lang":"1.21.7","nats-server":"2.10.11"},exports:{".":"./index.js"},homepage:"https://www.harperdb.io/",bugs:"support@harperdb.io",author:{name:"HarperDB",email:"support@harperdb.io"},license:"SEE LICENSE IN LICENSE",scripts:{submodules:"git submodule update --init --recursive",build:"eslint -c ./.eslintbuild bin/ dataLayer/ security/ server/ sqlTranslator/ upgrade/ utility/ validation/",pretty:"eslint --fix bin/ dataLayer/ security/ server/ sqlTranslator/ upgrade/ utility/ validation/","cover:test":"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && nyc --no-clean --reporter=lcovonly npm run test:apitests && nyc --no-clean --reporter=lcovonly npm run test:resources && nyc --no-clean --reporter=lcovonly npm run test:logging && nyc --no-clean --reporter=lcovonly npm run test:upgrade && nyc --no-clean --reporter=lcovonly npm run test:nats && nyc --no-clean --reporter=lcovonly npm run test:cfserver && nyc --no-clean --reporter=lcovonly npm run test:hdbserver && nyc --no-clean --reporter=lcovonly npm run test:bin && nyc --no-clean --reporter=lcovonly npm run test:main && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license",test:"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && npm run test:apitests && npm run test:resources && npm run test:logging && npm run test:upgrade && npm run test:nats && npm run test:cfserver && npm run test:hdbserver && npm run test:bin && npm run test:main && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license","test:resources":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/resources/**/*.js' --config '../unitTests/.mocharc.json'","test:bin":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/bin/**/*.js' --config '../unitTests/.mocharc.json'","test:main":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --config '../unitTests/.mocharc-main.json'","test:lmdbbridge":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --config '../unitTests/.mocharc.json'","test:lmdbutility":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --config '../unitTests/.mocharc.json'","test:hdbserver":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --config '../unitTests/.mocharc.json'","test:cfserver":"npm run submodules && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/fastifyRoutes/customFunctionsServer-test.js' --config '../unitTests/.mocharc.json'","test:nats":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json'","test:upgrade":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --config '../unitTests/.mocharc.json'","test:apitests":"pm2 kill && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/apiTests/**/*-test.mjs' --config '../unitTests/.mocharc.json'","test:logging":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/logging/*.js' --config '../unitTests/.mocharc.json'","test:ci":" cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --retries 3 --config '../unitTests/.mocharc-main.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/customFunctions/customFunctionsServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter","hdb-check":"./utility/devops/hdb-check.sh","download-prebuilds":"node ./utility/devops/build/download-prebuilds.js",prebuild:"date",postinstall:"node ./launchServiceScripts/launchInstallNATSServer.js",build_nats_dependency:"node ./utility/devops/nats/builder.js",coverage:"nyc --reporter=lcov npm test"},dependencies:{"@aws-sdk/client-s3":"3.635.0","@aws-sdk/lib-storage":"3.635.0","@endo/static-module-record":"^1.0.4","@fastify/autoload":"5.7.1","@fastify/compress":"~6.5.0","@fastify/cors":"~8.5.0","@fastify/static":"~6.12.0","@turf/area":"6.5.0","@turf/boolean-contains":"6.5.0","@turf/boolean-disjoint":"6.5.0","@turf/boolean-equal":"6.5.0","@turf/circle":"6.5.0","@turf/difference":"6.5.0","@turf/distance":"6.5.0","@turf/helpers":"6.5.0","@turf/length":"6.5.0",alasql:"4.1.10","cbor-x":"1.5.8",chalk:"4.1.2","cli-progress":"3.12.0",clone:"2.1.2","fast-glob":"3.3.2",fastify:"~4.26.2","fastify-plugin":"~4.5.1","fs-extra":"11.2.0",graphql:"^16.8.1","human-readable-ids":"1.0.4",inquirer:"8.2.6","is-number":"7.0.0",joi:"17.12.2","json-bigint-fixes":"1.1.0",json2csv:"5.0.7",jsonata:"1.8.7",jsonwebtoken:"9.0.2",lmdb:"3.1.3",lodash:"4.17.21",mathjs:"11.12.0",minimist:"1.2.8",mkcert:"1.5.1",moment:"2.30.1","mqtt-packet":"~8.2.1",msgpackr:"1.10.1",nats:"2.19.0",needle:"3.3.1","node-stream-zip":"1.15.0","node-unix-socket":"0.2.5","normalize-path":"^3.0.0",ora:"5.4.1","ordered-binary":"1.5.1",papaparse:"5.4.1",passport:"0.6.0","passport-http":"0.3.0","passport-local":"1.0.0",pino:"8.16.0",pm2:"5.4.1",prompt:"1.3.0","properties-reader":"2.3.0","recursive-iterator":"3.3.0",semver:"7.5.4",send:"^0.18.0","serve-static":"1.15.0",ses:"1.1.0","stream-chain":"2.2.5","stream-json":"1.8.0",systeminformation:"5.22.9","tar-fs":"2.1.1",ulidx:"0.5.0",uuid:"9.0.1","validate.js":"0.13.1",ws:"8.17.1",yaml:"2.4.1"},devDependencies:{"@tsconfig/node16":"^1.0.3","@types/node":"latest","@typescript-eslint/eslint-plugin":"^5.55.0","@typescript-eslint/parser":"^5.55.0",axios:"1.6.8",chai:"4.4.1","chai-integer":"0.1.0",esbuild:"^0.20.2",eslint:"8.22.0","eslint-config-prettier":"8.3.0","eslint-plugin-prettier":"3.4.1","eslint-plugin-radar":"0.2.1",eventsource:"^2.0.2","hook-std":"3.0.0","intercept-stdout":"0.1.2",mocha:"^10.3.0","mocha-teamcity-reporter":"3.0.0","mock-require":"3.0.3","mock-stdin":"1.0.0",mqtt:"~4.3.8",newman:"5.3.2","newman-reporter-html":"1.0.5","newman-reporter-htmlextra":"1.22.11","newman-reporter-teamcity":"0.1.12","node-fetch":"2.6.7",nyc:"15.1.0",prettier:"2.8.4",rewire:"5.0.0",rimraf:"3.0.2",sinon:"10.0.0","sinon-chai":"3.7.0","source-map-support":"^0.5.21",typescript:"^5.4.2","why-is-node-still-running":"^1.0.0"},overrides:{"eslint-plugin-radar":{eslint:"8.22.0"},alasql:{xlsx:"0.18.5"}},optionalDependencies:{bufferutil:"^4.0.7","utf-8-validate":"^5.0.10"}}});var ml={};qe(ml,{addAnalyticsListener:()=>hl,recordAction:()=>Sr,recordActionBinary:()=>Wr,setAnalyticsEnabled:()=>e3});function e3(e){ID=e}function Sr(e,t,r,n,s){if(!ID)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=Ad.get(i);if(o)if(typeof e=="number"){let c=o.values,l=c.index++;if(l>=c.length){let _=c;o.values=c=new Float32Array(l*2),c.set(_),c.index=l+1}c[l]=e,o.total+=e}else if(typeof e=="boolean")e&&o.total++,o.count++;else if(typeof e=="function")o.count++;else throw new TypeError("Invalid metric value type "+typeof e);else{if(typeof e=="number")o={total:e,values:new Float32Array(4)},o.values.index=1,o.values[0]=e,o.total=e;else if(typeof e=="boolean")o={},o.total=e?1:0,o.count=1;else if(typeof e=="function")o={},o.count=1,o.callback=e;else throw new TypeError("Invalid metric value type "+typeof e);o.description={metric:t,path:r,method:n,type:s},Ad.set(i,o)}gd||t3()}function Wr(e,t,r,n,s){Sr(!!e,t,r,n,s)}function hl(e){DD.push(e)}function t3(){gd=performance.now(),setTimeout(async()=>{let e=performance.now()-gd;gd=0;let t=[],r={time:Date.now(),period:e,threadId:io.threadId,metrics:t};for(let[s,i]of Ad){if(i.values){let o=i.values.subarray(0,i.values.index);o.sort();let c=o.length,l=0,_=[],u;for(let d of LD){let E=Math.floor(c*d),f=o[E-1];if(E>l){let h=E-l;if(f===u){let p=_[_.length-1];typeof p=="number"?_[_.length-1]={value:p,count:1+h}:p.count+=h}else _.push(h>1?{value:f,count:h}:f),u=f;l=E}}t.push(Object.assign(i.description,{mean:i.total/c,distribution:_,count:c}))}else i.callback?t.push(Object.assign(i.description,i.callback(i))):t.push(Object.assign(i.description,{total:i.total,count:i.count}));await MD()}let n=process.memoryUsage();t.push({metric:"memory",threadId:io.threadId,byThread:!0,...n});for(let s of DD)s(t);Ad=new Map,io.parentPort?io.parentPort.postMessage({type:CD,report:r}):vD({report:r})},wD).unref()}async function r3(e,t=6e4){let r=mS(),n=PD(),s=new Promise(p=>{let S=performance.now();setImmediate(()=>{let T=performance.now();T-S>5e3&&(0,dl.warn)("Unusually high event queue latency on the main thread of "+Math.round(T-S)+"ms"),S=performance.now()}),n.primaryStore.prefetch([1],()=>{let T=performance.now();T-S>5e3&&(0,dl.warn)("Unusually high task queue latency on the main thread of "+Math.round(T-S)+"ms"),p(T-S)})}),i;for(let p of n.primaryStore.getRange({start:1/0,end:!1,reverse:!0}))if(p.value?.time){i=p.value.time;break}if(Date.now()-t<i)return;let o,c=new Map,l=new Map,_=[],u;for(let{key:p,value:S}of r.primaryStore.getRange({start:i||!1,exclusiveStart:!0,end:1/0})){if(!S)continue;if(o){if(p>o+t)break}else o=p;u=p;let{metrics:T,threadId:A}=S;for(let b of T||[]){let{path:I,method:B,type:U,metric:q,count:M,total:Q,distribution:J,threads:X,...oe}=b;M||(M=1);let le=q+(I?"-"+I:"");B!==void 0&&(le+="-"+B),U!==void 0&&(le+="-"+U);let ue=c.get(le);if(ue){if(ue.threads){let Ne=ue.threads[A];if(Ne)ue=Ne;else{ue.threads[A]=Object.assign({},oe);continue}}ue.count||(ue.count=1);let Be=ue.count;for(let Ne in oe){let He=oe[Ne];typeof He=="number"&&(ue[Ne]=(ue[Ne]*Be+He*M)/(Be+M))}ue.count+=M,Q>=0&&(ue.total+=Q,ue.ratio=ue.total/ue.count)}else ue=Object.assign({period:t},b),delete ue.distribution,c.set(le,ue),ue.byThread&&(ue.threads=[],ue.threads[A]=Object.assign({},oe),_.push(ue));if(J){J=J.map(Ne=>typeof Ne=="number"?{value:Ne,count:1}:Ne);let Be=l.get(le);Be?Be.push(...J):l.set(le,J)}}await MD()}for(let p of _){let{path:S,method:T,type:A,metric:b,count:I,total:B,distribution:U,threads:q,...M}=p;q=q.filter(Q=>Q);for(let Q in M){if(typeof p[Q]!="number")continue;let J=0;for(let X of q){let oe=X[Q];typeof oe=="number"&&(J+=oe)}p[Q]=J}p.count=q.length,delete p.threads,delete p.byThread}for(let[p,S]of l){let T=c.get(p);S.sort((Ne,He)=>Ne.value>He.value?1:-1);let A=T.count-1,b=[],I=0,B=0,U;for(let Ne of LD){let He=A*Ne;for(;I<He;)U=S[B++],I+=U.count,B===1&&I--;let zu=S[B>1?B-2:0];U||(U=S[0]),b.push(U.value-(U.value-zu.value)*(I-He)/U.count)}let[q,M,Q,J,X,oe,le,ue,Be]=b;Object.assign(T,{p1:q,p10:M,p25:Q,median:J,p75:X,p90:oe,p95:le,p99:ue,p999:Be})}let d;for(let[p,S]of c)S.id=(0,Rd.getNextMonotonicTime)(),S.time=u,n.primaryStore.put(S.id,S,{append:!0}).then(T=>{T||n.primaryStore.put(S.id,S)}),d=!0;let E=Date.now(),{idle:f,active:h}=performance.eventLoopUtilization();if(d||h*10>f){let p=(0,Rd.getNextMonotonicTime)(),S={id:p,metric:"main-thread-utilization",idle:f-TD,active:h-gD,taskQueueLatency:await s,time:E,...process.memoryUsage()};n.primaryStore.put(p,S,{append:!0}).then(T=>{T||n.primaryStore.put(p,S)})}TD=f,gD=h}async function RD(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function mS(){return AD||(AD=ft({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function PD(){return OD||(OD=ft({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function i3(){UD=!0;let e=(0,El.get)(hS.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await r3(wD,e),await RD(mS(),n3),await RD(PD(),s3)},Math.min(e/2,2147483647)).unref()}function vD(e,t){let r=e.report;r.threadId=t?.threadId||io.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(bD+=n.mean*n.count);r.totalBytesProcessed=bD,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(yD.get(t))}),yD.set(t,t.performance.eventLoopUtilization())),r.id=(0,Rd.getNextMonotonicTime)(),mS().primaryStore.put(r.id,r),UD||i3(),o3&&(BD=c3(r))}async function c3(e){if(await BD,!_i){let r=(0,fl.dirname)((0,dl.getLogFilePath)());try{_i=await(0,ES.open)((0,fl.join)(r,"analytics.log"),"r+")}catch{_i=await(0,ES.open)((0,fl.join)(r,"analytics.log"),"w+")}}let t=(await _i.stat()).size;if(t>a3){let r=Buffer.alloc(t);await _i.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await _i.write(r,{position:0}),await _i.truncate(r.length),t=r.length}await _i.write(JSON.stringify(e)+`
9
+ This can occur during early stages of install where the config file has not yet been created`);return}else throw Nt.error(i),new Error(`Error reading HarperDB config file at ${r}`)}qV(n,r),Gh(n);let s=n.toJSON();if(PV.config=s,It=ko(s),It.logging_rotation_rotate)for(let i in eb)It[i]&&Nt.error(`Config ${eb[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);Nt.trace(vV)}}a(xh,"initConfig");function qV(e,t){let r=e.getIn(["rootPath"]),n=!1;e.hasIn(["storage","path"])||(e.setIn(["storage","path"],Nn.join(r,"database")),n=!0),e.hasIn(["clustering","leafServer","streams","path"])||(e.setIn(["clustering","leafServer","streams","path"],Nn.join(r,"clustering","leaf")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],Nn.join(r,"log")),n=!0),e.hasIn(["clustering","tls","verify"])||(e.setIn(["clustering","tls","verify"],!0),n=!0),e.hasIn(["authentication"])||(e.addIn(["authentication"],{cacheTTL:3e4,enableSessions:!0,operationTokenTimeout:e.getIn(["operationsApi","authentication","operationTokenTimeout"])??"1d",refreshTokenTimeout:e.getIn(["operationsApi","authentication","refreshTokenTimeout"])??"30d"}),n=!0),e.hasIn(["analytics"])||(e.addIn(["analytics"],{aggregatePeriod:60}),n=!0),n&&(Nt.trace("Updating config file with missing config params"),_r.writeFileSync(t,String(e)))}a(qV,"checkForUpdatedConfig");function Gh(e,t=!1){let r=e.toJSON();r.componentsRoot=r.componentsRoot??r?.customFunctions?.root,r?.http?.threads&&(r.threads=r?.http?.threads);let n=IV(r,t);if(n.error)throw d_.CONFIG_VALIDATION(n.error.message);typeof n.value.threads=="object"?e.setIn(["threads","count"],n.value.threads.count):e.setIn(["threads"],n.value.threads),e.setIn(["componentsRoot"],n.value.componentsRoot),e.setIn(["logging","root"],n.value.logging.root),e.setIn(["storage","path"],n.value.storage.path),e.setIn(["logging","rotation","path"],n.value.logging.rotation.path),e.setIn(["clustering","leafServer","streams","path"],n.value.clustering.leafServer.streams?.path),e.setIn(["operationsApi","network","domainSocket"],n.value?.operationsApi?.network?.domainSocket)}a(Gh,"validateConfig");function kV(e,t){It===void 0&&(It={});let r=In[e.toLowerCase()];if(r===void 0){Nt.trace(`Unable to update config object because config param '${e}' does not exist`);return}It[r.toLowerCase()]=t}a(kV,"updateConfigObject");function ib(e,t,r=void 0,n=!1,s=!1,i=!1){It===void 0&&xh();let o=sb(In.hdb_root),c=Nn.join(o,Hr.HDB_CONFIG_FILE),l=Zs(c),_;if(r===void 0&&e.toLowerCase()===Br.DATABASES)_=t;else if(r===void 0){let E;if(i)E=e;else if(E=In[e.toLowerCase()],E===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let f=E.split("_"),h=Hh(E,t);l.setIn([...f],h)}else for(let E in r){let f=In[E.toLowerCase()];if(f===Br.HTTP_SECUREPORT&&r[E]===It[Br.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),f===Br.OPERATIONSAPI_NETWORK_SECUREPORT&&r[E]===It[Br.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&l.setIn(["operationsApi","network","port"],null),f===Br.DATABASES){_=r[E];continue}if(f?.startsWith("threads_")){let h=l.getIn(["threads"]);h>=0&&(l.deleteIn(["threads"]),l.setIn(["threads","count"],h))}if(!f&&(E.endsWith("_package")||E.endsWith("_port"))&&(f=E),f!==void 0){let h=f.split("_"),p=Hr.LEGACY_CONFIG_PARAMS[E.toUpperCase()];p&&p.startsWith("customFunctions")&&l.hasIn(p.split("_"))&&(f=p,h=p.split("_"));let S=Hh(f,r[E]);f==="rootPath"&&S?.endsWith("/")&&(S=S.slice(0,-1));try{h.length>1&&typeof l.getIn(h.slice(0,-1))=="boolean"&&l.deleteIn(h.slice(0,-1)),l.setIn([...h],S)}catch(T){Nt.error(T)}}}_&&nb(l,_),Gh(l);let u=l.getIn(["rootPath"]),d=Nn.join(u,Hr.HDB_CONFIG_FILE);n===!0&&VV(c,u),_r.writeFileSync(d,String(l)),s&&(It=ko(l.toJSON())),Nt.trace(`Config parameter: ${e} updated with value: ${t}`)}a(ib,"updateConfigValue");function VV(e,t){try{let r=Nn.join(t,"backup",`${Hr.HDB_CONFIG_FILE}.bak`);_r.copySync(e,r),Nt.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){Nt.error(BV),Nt.error(r)}}a(VV,"backupConfigFile");var $V=["databases"];function ko(e){return e.http&&Object.assign(e.http,e?.customFunctions?.network),e?.operationsApi?.network&&(e.operationsApi.network=Object.assign({},e.http,e.operationsApi.network)),e?.operationsApi&&(e.operationsApi.tls=Object.assign({},e.tls,e.operationsApi.tls)),E_=e,r(e);function r(n){let s={};for(let i in n)if(n.hasOwnProperty(i)){if(typeof n[i]=="object"&&n[i]!==null&&!Array.isArray(n[i])&&!$V.includes(i)){let o=r(n[i]);for(let c in o){if(!o.hasOwnProperty(c))continue;c!=="package"&&(i=i.toLowerCase());let l=i+"_"+c;!Br[l.toUpperCase()]&&In[l]&&(s[In[l].toLowerCase()]=o[c]),s[l]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(ko,"flattenConfig");function Hh(e,t){if(e===Br.CLUSTERING_NODENAME||e===Br.CLUSTERING_USER){if(t==null)return t;if(!isNaN(t))return t.toString();if(typeof t=="string"&&t.toLowerCase()==="true"||typeof t=="string"&&t.toLowerCase()==="false")return t}else{if(CV(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||vt.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 vt.autoCast(t)}a(Hh,"castConfigValue");function YV(){let e=vt.getPropsFilePath(),t=Gi(e);return Zs(t).toJSON()}a(YV,"getConfiguration");async function KV(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return ib(void 0,void 0,s,!0),xV}catch(i){throw typeof i=="string"||i instanceof String?LV(i,i,MV.BAD_REQUEST,void 0,void 0,!0):i}}a(KV,"setConfiguration");function Fh(){let e=vt.getPropsFilePath();try{_r.accessSync(e,_r.constants.F_OK|_r.constants.R_OK)}catch(n){if(!vt.noBootFile())throw Nt.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=Gi(e);return Zs(t).toJSON()}a(Fh,"readConfigFile");function Zs(e){return wV.parseDocument(_r.readFileSync(e,"utf8"),{simpleKeys:!0})}a(Zs,"parseYamlDoc");function WV(){let e=Fh(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=vt.isEmptyOrZeroLength(t)?[]:t;let r=ZO(t);if(r)throw d_.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=vt.isEmptyOrZeroLength(n)?[]:n;let s=ZO(n);if(s)throw d_.CONFIG_VALIDATION(s.message);if(!vt.isEmptyOrZeroLength(n)&&!vt.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!vt.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw d_.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(WV,"getClusteringRoutes");function ob(e){let t=tb(e);It={};for(let r in In){let n=t.get(r.toUpperCase());if(vt.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=In[r].toLowerCase();s===Br.LOGGING_ROOT?It[s]=Nn.dirname(n):It[s]=n}return It}a(ob,"initOldConfig");function QV(e){let t=Fh();return DV.get(t,e.replaceAll("_","."))}a(QV,"getConfigFromFile");async function zV(e,t){let r=Zs(Gi());r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),await _r.writeFile(Gi(),String(r))}a(zV,"addConfig");function JV(e){let t=Gi(vt.getPropsFilePath()),r=Zs(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=Nn.join(n,Hr.HDB_CONFIG_FILE);_r.writeFileSync(s,String(r))}a(JV,"deleteConfigFromFile");function XV(){return E_||(xh(),E_)}a(XV,"getConfigObj")});var ne=g((Xoe,db)=>{"use strict";var qh=require("fs-extra"),Fi=require("path"),cb=require("os"),jV=require("properties-reader"),gc=K(),Tc=z(),de=P(),h_=dr(),ZV="Error initializing environment manager",m_="BOOT_PROPS_FILE_PATH",lb=!1,e$={[de.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[de.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[de.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},gs={};db.exports={BOOT_PROPS_FILE_PATH:m_,getHdbBasePath:t$,setHdbBasePath:r$,get:ub,initSync:s$,setProperty:Me,initTestEnvironment:o$,setCloneVar:i$};function t$(){return gs[de.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(t$,"getHdbBasePath");function r$(e){gs[de.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(r$,"setHdbBasePath");function ub(e){let t=h_.getConfigValue(e);return t===void 0?gs[e]:t}a(ub,"get");function Me(e,t){e$[e]&&(gs[e]=t),h_.updateConfigObject(e,t)}a(Me,"setProperty");function n$(){let e;try{e=Tc.getPropsFilePath(),qh.accessSync(e,qh.constants.F_OK|qh.constants.R_OK),lb=!0;let t=jV(e);return gs[de.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(de.HDB_SETTINGS_NAMES.INSTALL_USER),gs[de.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(de.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),gs[m_]=e,!0}catch{return gc.trace(`Environment manager found no properties file at ${e}`),!1}}a(n$,"doesPropFileExist");function s$(e=!1){try{(lb||n$()||Tc.noBootFile())&&!_b&&(h_.initConfig(e),gs[de.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=h_.getConfigValue(de.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){gc.error(ZV),gc.error(t),console.error(t),process.exit(1)}}a(s$,"initSync");var _b=!1;function i$(e){_b=e}a(i$,"setCloneVar");function o$(e={}){try{let{keep_alive_timeout:t,headers_timeout:r,server_timeout:n,https_enabled:s,cors_enabled:i,cors_accesslist:o,local_studio_on:c}=e,l=Fi.join(__dirname,"../../","unitTests");gs[m_]=Fi.join(l,"hdb_boot_properties.file"),Me(de.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,Fi.join(l,"settings.test")),Me(de.HDB_SETTINGS_NAMES.INSTALL_USER,cb.userInfo()?cb.userInfo().username:void 0),Me(de.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),Me(de.HDB_SETTINGS_NAMES.LOG_PATH_KEY,Fi.join(l,"envDir","log")),Me(de.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),Me(de.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),Me(de.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),Me(de.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,Fi.join(l,"envDir")),Me(de.CONFIG_PARAMS.STORAGE_PATH,Fi.join(l,"envDir")),s&&(Me(de.CONFIG_PARAMS.HTTP_SECUREPORT,ub(de.CONFIG_PARAMS.HTTP_PORT)),Me(de.CONFIG_PARAMS.HTTP_PORT,null)),Me(de.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,!!s),Me(de.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),Me(de.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,Tc.isEmpty(i)?!1:i),Me(de.CONFIG_PARAMS.HTTP_CORS,Tc.isEmpty(i)?!1:i),Me(de.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),Me(de.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),Me(de.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),Me(de.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),Me(de.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,Fi.resolve(__dirname,"../../unitTests/server/fastifyRoutes/custom_functions")),Me(de.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,Tc.isEmpty(c)?!1:c),o&&(Me("CORS_ACCESSLIST",o),Me(de.CONFIG_PARAMS.HTTP_CORSACCESSLIST,o)),n&&(Me(de.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,n),Me(de.CONFIG_PARAMS.HTTP_TIMEOUT,n)),t&&(Me(de.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),Me(de.CONFIG_PARAMS.HTTP_KEEPALIVETIMEOUT,t)),r&&(Me(de.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),Me(de.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${m_}. Please check your boot props and settings files`;gc.fatal(r),gc.error(t)}}a(o$,"initTestEnvironment")});var ze=g((Zoe,Tb)=>{"use strict";var yc=P(),a$=z(),fr=ne(),Nc=require("path"),c$=require("minimist"),fb=require("fs-extra"),Eb=require("lodash");fr.initSync();var{CONFIG_PARAMS:ei,DATABASES_PARAM_CONFIG:Rc,SYSTEM_SCHEMA_NAME:p_}=yc,Ac,Oc,bc;function hb(){if(Ac!==void 0)return Ac;if(fr.getHdbBasePath()!==void 0)return Ac=fr.get(ei.STORAGE_PATH)||Nc.join(fr.getHdbBasePath(),yc.DATABASES_DIR_NAME),Ac}a(hb,"getBaseSchemaPath");function mb(){if(Oc!==void 0)return Oc;if(fr.getHdbBasePath()!==void 0)return Oc=Sb(p_),Oc}a(mb,"getSystemSchemaPath");function pb(){if(bc!==void 0)return bc;if(fr.getHdbBasePath()!==void 0)return bc=fr.get(yc.CONFIG_PARAMS.STORAGE_AUDIT_PATH)||Nc.join(fr.getHdbBasePath(),yc.TRANSACTIONS_DIR_NAME),bc}a(pb,"getTransactionAuditStoreBasePath");function l$(e,t){let r=fr.get(ei.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||Nc.join(pb(),e.toString())}a(l$,"getTransactionAuditStorePath");function Sb(e,t){e=e.toString(),t=t&&t.toString();let r=fr.get(yc.CONFIG_PARAMS.DATABASES)?.[e];return t&&r?.tables?.[t]?.path||r?.path||Nc.join(hb(),e)}a(Sb,"getSchemaPath");function u$(e,t){e=e.toString(),t=t.toString();let r=process.env;Object.assign(r,c$(process.argv));let n=r[ei.DATABASES.toUpperCase()];if(n){let i;try{i=JSON.parse(n)}catch(o){if(!a$.isObject(n))throw o;i=n}for(let o of i){let c=o[p_];if(!c)continue;let l=fr.get(ei.DATABASES);l=l??{};let _=c?.tables?.[t]?.[Rc.PATH];if(_)return Eb.set(l,[p_,Rc.TABLES,t,Rc.PATH],_),fr.setProperty(ei.DATABASES,l),_;let u=c?.[Rc.PATH];if(u)return Eb.set(l,[p_,Rc.PATH],u),fr.setProperty(ei.DATABASES,l),u}}let s=r[ei.STORAGE_PATH.toUpperCase()];if(s){if(!fb.pathExistsSync(s))throw new Error(s+" does not exist");let i=Nc.join(s,e);return fb.mkdirsSync(i),fr.setProperty(ei.STORAGE_PATH,s),i}return mb()}a(u$,"initSystemSchemaPaths");function _$(){Ac=void 0,Oc=void 0,bc=void 0}a(_$,"resetPaths");Tb.exports={getBaseSchemaPath:hb,getSystemSchemaPath:mb,getTransactionAuditStorePath:l$,getTransactionAuditStoreBasePath:pb,getSchemaPath:Sb,initSystemSchemaPaths:u$,resetPaths:_$}});var xr=g((nae,bb)=>{"use strict";var d$=vr().LMDB_ERRORS_ENUM,tae=require("lmdb"),f$=dt(),rae=require("buffer").Buffer,{OVERFLOW_MARKER:gb,MAX_SEARCH_KEY_LENGTH:S_}=f$,Rb=["number","string","symbol","boolean","bigint"];function E$(e){if(e=e?.primaryStore||e,!e)throw new Error(d$.ENV_REQUIRED)}a(E$,"validateEnv");function h$(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(h$,"stringifyData");function m$(e){return e instanceof Date?e.valueOf():e}a(m$,"convertKeyValueToWrite");function p$(e,t){if(e===null)return t?[null]:void 0;if(e===void 0)return;if(Rb.includes(typeof e))return e.length>S_?[e.slice(0,S_)+gb]:[e];let r;if(Array.isArray(e)){r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n];if(Rb.includes(typeof i))i.length>S_?r.push(i.slice(0,S_)+gb):r.push(i);else{if(i===null&&t)return r.push(null);if(i instanceof Date)return r.push(i.getTime())}}}else if(e instanceof Date)return[e.getTime()];return r}a(p$,"getIndexedValues");var T_=0,Ab=0;function Ob(){Ab=Date.now()-performance.now()}a(Ob,"adjustStartTime");Ob();var S$=6e4;setInterval(Ob,S$).unref();function T$(){let e=performance.now()+Ab;return e>T_?(T_=e,e):(T_+=488e-6,T_)}a(T$,"getNextMonotonicTime");bb.exports={validateEnv:E$,stringifyData:h$,convertKeyValueToWrite:m$,getNextMonotonicTime:T$,getIndexedValues:p$}});var Ic=g((iae,yb)=>{"use strict";var g$=P().OPERATIONS_ENUM,kh=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i=void 0){this.operation=g$.INSERT,this.schema=t,this.table=r,this.hash_attribute=n,this.records=s,this.__origin=i}};yb.exports=kh});var wc=g((cae,Cb)=>{"use strict";var aae=Ic(),g_=P(),Vh=z(),Nb=K(),R$=require("uuid"),{handleHDBError:R_,hdb_errors:A$}=se(),{HDB_ERROR_MSGS:A_,HTTP_STATUS_CODES:O_}=A$;Cb.exports=Ib;function Ib(e,t,r){for(let s=0;s<t.length;s++)wb(t[s]);let{records:n}=e;for(let s=0;s<n.length;s++){let i=n[s];O$(i,r,e.operation)}}a(Ib,"processRows");Ib.validateAttribute=wb;function wb(e){if(Buffer.byteLength(String(e))>g_.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw R_(new Error,A_.ATTR_NAME_LENGTH_ERR(e),O_.BAD_REQUEST,void 0,void 0,!0);if(Vh.isEmptyOrZeroLength(e)||Vh.isEmpty(e.trim()))throw R_(new Error,A_.ATTR_NAME_NULLISH_ERR,O_.BAD_REQUEST,void 0,void 0,!0)}a(wb,"validateAttribute");function O$(e,t,r){if(!e.hasOwnProperty(t)||Vh.isEmptyOrZeroLength(e[t])){if(r===g_.OPERATIONS_ENUM.INSERT||r===g_.OPERATIONS_ENUM.UPSERT){e[t]=R$.v4();return}throw Nb.error("Update transaction aborted due to record with no hash value:",e),R_(new Error,A_.RECORD_MISSING_HASH_ERR,O_.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>g_.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw Nb.error(e),R_(new Error,A_.HASH_VAL_LENGTH_ERR,O_.BAD_REQUEST,void 0,void 0,!0)}a(O$,"validateHash")});var Db,wn,$h,Cc=Re(()=>{Db=require("events"),wn=class extends Db.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;drainCloseListener;currentDrainResolver;[Symbol.asyncIterator](){let t=new $h;return t.queue=this,t}push(t){this.send(t)}send(t){this.resolveNext?(this.resolveNext({value:t}),this.resolveNext=null):this.hasDataListeners?this.emit("data",t):(this.queue||(this.queue=[]),this.queue.push(t))}getNextMessage(){let t=this.queue?.shift();return t||this.emit("drained"),t}waitForDrain(){return new Promise(t=>{!this.queue||this.queue.length===0?t(!0):(this.once("drained",()=>t(!0)),this.currentDrainResolver=t,this.drainCloseListener||(this.drainCloseListener=!0,this.on("close",()=>{this.currentDrainResolver?.(!1)})))})}on(t,r){if(t==="data"&&!this.hasDataListeners)for(this.hasDataListeners=!0;this.queue?.length>0;)r(this.queue.shift());return super.on(t,r)}},$h=class{static{a(this,"EventQueueIterator")}queue;push(t){this.queue.send(t)}next(){let t=this.queue.getNextMessage();return t?{value:t}:new Promise(r=>this.queue.resolveNext=r)}return(t){return this.queue.emit("close"),{value:t,done:!0}}throw(t){return this.queue.emit("close",t),{done:!0}}}});var Wh={};qe(Wh,{loadGQLSchema:()=>N$,start:()=>Kh,startOnMainThread:()=>y$});function Kh({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r,n,s,i){let{parse:o,Source:c,Kind:l,NamedTypeNode:_,StringValueNode:u}=await import("graphql"),d=o(new c(r.toString(),s)),E=new Map,f=[],h;for(let S of d.definitions)switch(S.kind){case l.OBJECT_TYPE_DEFINITION:let B=function(U){if(U.kind==="NonNullType"){let Q=B(U.type);return Q.nullable=!1,Q}if(U.kind==="ListType")return{type:"array",elements:B(U.type)};let M={type:U.name?.value};return Object.defineProperty(M,"location",{value:U.loc.startToken}),M};a(B,"getProperty");let T=S.name.value,A=[],b={table:null,database:null,properties:A};E.set(T,b);for(let U of S.directives){if(U.name.value==="table"){for(let q of U.arguments)b[q.name.value]=q.value.value;b.schema&&(b.database=b.schema),b.table||(b.table=T),b.audit&&(b.audit=b.audit!=="false"),b.attributes=b.properties,f.push(b)}if(U.name.value==="sealed"&&(b.sealed=!0),U.name.value==="export"){b.export=!0;for(let q of U.arguments)q.name.value==="name"&&(b.export={name:q.value.value})}}let I=!1;for(let U of S.fields){let q=B(U.type);q.name=U.name.value,A.push(q);for(let M of U.directives)if(M.name.value==="primaryKey")I?console.warn("Can not define two attributes as a primary key"):(q.isPrimaryKey=!0,I=!0);else if(M.name.value==="indexed")q.indexed=!0;else if(M.name.value==="relationship"){let Q={};for(let J of M.arguments)Q[J.name.value]=J.value.value;q.relationship=Q}else if(M.name.value==="createdTime")q.assignCreatedTime=!0;else if(M.name.value==="updatedTime")q.assignUpdatedTime=!0;else if(M.name.value==="expiresAt")q.expiresAt=!0;else if(M.name.value==="allow"){let Q=q.authorizedRoles=[];for(let J of M.arguments)J.name.value==="role"&&Q.push(J.value.value)}}b.type=T,T==="Query"&&(h=b)}function p(S){let T=E.get(S.type);T?(Object.defineProperty(S,"properties",{value:T.properties}),Object.defineProperty(S,"definition",{value:T})):S.type==="array"?p(S.elements):b$.includes(S.type)||(0,Lb.getWorkerIndex)()===0&&console.error(`The type ${S.type} is unknown at line ${S.location.line}, column ${S.location.column}, in ${s}`)}a(p,"connectPropertyType");for(let S of E.values())for(let T of S.properties)p(T);for(let S of f)S.tableClass=e(S),S.export&&(S.export.name===""?i.set((0,Yh.dirname)(n),S.tableClass):i.set((0,Yh.dirname)(n)+"/"+(S.export.name||S.type),S.tableClass))}}var Yh,Lb,b$,y$,N$,Mb=Re(()=>{Yh=require("path");Ae();Lb=x(ot()),b$=["ID","Int","Float","Long","String","Boolean","Date","Bytes","Any","BigInt"];a(Kh,"start");y$=Kh,N$=Kh({ensureTable:ft}).handleFile});async function b_(e){let t=(0,vb.pathToFileURL)(e).toString();return I$?(Dc||(Dc=w$(D$)),(await(await Dc).import(t)).namespace):import(t)}async function w$(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),Dc=new Compartment({console,Math,Date,fetch:C$,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,Ub.extname)(r)||(r+=".js"),r)},importHook:async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){Object.assign(s,{Resource:$t,tables:Gr,databases:at})}};let n=await(0,Pb.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)}}),Dc}function C$(e,t){let r=typeof e=="string"||e.url;if(new URL(r).protocol!="https")throw new Error("Only https is allowed in fetch");return fetch(e,t)}function D$(){return{Resource:$t,tables:Gr}}var Pb,Ub,vb,I$,Dc,Qh=Re(()=>{an();Ae();Pb=require("fs/promises"),Ub=require("path"),vb=require("url"),I$=!1;a(b_,"secureImport");a(w$,"getCompartment");a(C$,"secureOnlyFetch");a(D$,"getGlobalVars")});var Jh={};qe(Jh,{handleFile:()=>L$});async function L$(e,t,r,n){let s=new Map,i=await b_(r);c(i.default)&&n.set((0,zh.dirname)(t),i.default),o(i,(0,zh.dirname)(t));function o(l,_){for(let u in l){let d=l[u];c(d)?n.set(_+"/"+u,d):typeof d=="object"&&o(d,_+"/"+u)}}a(o,"recurseForResources");function c(l){return typeof l=="function"&&(l.get||l.put||l.post||l.delete)}return a(c,"isResource"),s}var zh,Bb=Re(()=>{Qh();zh=require("path");a(L$,"handleFile")});var jh={};qe(jh,{start:()=>M$});function M$({resources:e}){e.set("login",Xh),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var Xh,Hb=Re(()=>{an();a(M$,"start");Xh=class extends $t{static{a(this,"Login")}static async get(t,r,n){}static async post(t,r,n){let{username:s,password:i,redirect:o}=r;return{data:await n.login(s,i)}}}});var $b={};qe($b,{parse:()=>em,streamAsJSON:()=>Lc,stringify:()=>qi});function Lc(e){return new Zh({value:e})}function xb(e){return console.error(e),JSON.stringify(e.toString())}function Gb(e,t,r){return e?.then?r?e.then(t,r):e.then(t):t(e)}function qi(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===kb)return Vb(e);if(t.resolution)return t.resolution.then(()=>qi(e));throw t}}function Vb(e){let t=typeof e;if(t==="object"){if(e===null)return"null";e.toJSON&&(e=e.toJSON());let r;if(Array.isArray(e)){r="[";for(let n=0;n<e.length;n++)n>0&&(r+=","),r+=Vb(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+qi(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function em(e){return v$.test(e)?P$.parse(e):JSON.parse(e)}var Fb,qb,P$,U$,kb,Zh,v$,tm=Re(()=>{Fb=require("stream"),qb=x(require("json-bigint-fixes")),P$=(0,qb.default)({useNativeBigInt:!0}),U$=1e4,kb={};BigInt.prototype.toJSON=function(){throw kb};a(Lc,"streamAsJSON");Zh=class extends Fb.Readable{static{a(this,"JSONStream")}constructor(t){super(t),this.buffer=[],this.bufferSize=0,this.iterator=this.serialize(t.value,!0),this.activeIterators=[]}*serialize(t){if(t&&typeof t=="object"){let r=t[Symbol.asyncIterator],n=t[Symbol.iterator];if((n||r)&&!t.then){yield"[";let s=!0;if((r||n)&&!(t instanceof Array)){let i=r?t[Symbol.asyncIterator]():t[Symbol.iterator]();this.activeIterators.push(i);let o;for(;;)if(o=i.next(),o.then&&(yield o.then(c=>(o=c,""))),o.done){this.activeIterators.splice(this.activeIterators.indexOf(i),1),yield"]";return}else s?s=!1:yield",",yield*this.serialize(o.value)}for(let i of t)s?s=!1:yield",",yield*this.serialize(i);yield"]";return}if(t.then)try{yield t.then(s=>this.serialize(s),xb)}catch(s){yield xb(s)}else yield qi(t)}else yield qi(t)}_read(){if(!this._amReading){if(this._amReading=!0,this.done)return this.push(null);Gb(this.readIterator(this.iterator),t=>{t?(this.done=!0,this.push(null)):this._amReading=!1},t=>{console.error(t),this.done=!0,this.push(t.toString()),this.push(null)})}}push(t){return t===null||t instanceof Buffer?(this.bufferSize>0&&this.flush(),super.push(t)):(this.bufferSize+=t.length||t.toString().length,this.buffer.push(t),this.bufferSize>U$?this.flush():!0)}flush(){let t=super.push(this.buffer.join(""));return this.buffer=[],this.bufferSize=0,t}readIterator(t){try{let r;if(t.childIterator)return Gb(this.readIterator(t.childIterator),n=>{if(n)return t.childIterator=null,this.readIterator(t)});do{let n=t.next();if(n.done)return!0;if(r=n.value,r==null)r="null";else{if(r.then)return this.flush(),Promise.resolve(r).then(s=>{if(s&&typeof s.return=="function")return t.childIterator=s,this.readIterator(t);if(this.push(s+""))return this.readIterator(t)});if(typeof r.return=="function")return t.childIterator=r,this.readIterator(t)}}while(this.push(r))}catch(r){return console.error(r),this.push(r.toString()),this.push(null),!0}}_destroy(t,r){for(let n of this.activeIterators)t?n.throw(t):n.return();r()}};a(xb,"handleError");a(Gb,"when");a(qi,"stringify");a(Vb,"jsStringify");v$=/[[,:]\s*-?\d{16,}/;a(em,"parse")});var ny=g((bae,ry)=>{"use strict";var rm=require("recursive-iterator"),B$=require("alasql"),nm=require("clone"),Yb=z(),{handleHDBError:Kb,hdb_errors:H$}=se(),{HDB_ERROR_MSGS:Wb,HTTP_STATUS_CODES:Qb}=H$,{getDatabases:x$}=(Ae(),ie(ke)),G$=["DISTINCT_ARRAY"],zb=Symbol("validateTables"),sm=Symbol("validateTable"),Oae=Symbol("getAllColumns"),Jb=Symbol("validateAllColumns"),y_=Symbol("findColumn"),Xb=Symbol("validateOrderBy"),Mc=Symbol("validateSegment"),im=Symbol("validateColumn"),jb=Symbol("setColumnsForTable"),Zb=Symbol("checkColumnsForAsterisk"),ey=Symbol("validateGroupBy"),ty=Symbol("hasColumns"),om=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[zb](),this[Zb](),this[Jb]()}[zb](){if(this[ty]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[sm](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[sm](t.table)})}}[ty](){let t=!1,r=new rm(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[sm](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=x$();if(!r[t.databaseid])throw Kb(new Error,Wb.SCHEMA_NOT_FOUND(t.databaseid),Qb.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw Kb(new Error,Wb.TABLE_NOT_FOUND(t.databaseid,t.tableid),Qb.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=nm(s);i.table=nm(t),this.attributes.push(i)})}[y_](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)}[Zb](){let t=new rm(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[jb](r.tableid)}[jb](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new B$.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[Jb](){this[Mc](this.statement.columns,!1),this[Mc](this.statement.joins,!1),this[Mc](this.statement.where,!1),this[ey](this.statement.group,!1),this[Mc](this.statement.order,!0)}[Mc](t,r){if(!t)return;let n=new rm(t),s=[];for(let{node:i,path:o}of n)!Yb.isEmpty(i)&&!Yb.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[Xb](i):s.push(this[im](i)));return s}[ey](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&G$.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=nm(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[y_](n)[0];s&&r.push(s)}}}),this.statement.group.forEach(n=>{let s=null;if(!n.columnid)r.forEach((i,o)=>{if(i.toString()===n.toString()){s=i,r.splice(o,1);return}});else{let i=this[y_](n);if(!i||i.length===0)throw`unknown column '${n.toString()}' in group by`;if(i.length>1)throw`ambiguously defined column '${n.toString()}' in group by`;r.forEach((o,c)=>{if(o.attribute===i[0].attribute&&o.table.tableid===i[0].table.tableid){s=o,r.splice(c,1);return}})}if(!s)throw`group by column '${n.toString()}' must be in select`}),r.length>0)throw`select column '${r[0].attribute?r[0].attribute:r[0].toString()}' must be in group by`}[Xb](t){let r=this.statement.columns.filter(n=>n.as===t.columnid);if(r.length>1)throw`ambiguous column reference ${(t.tableid?t.tableid+".":"")+t.columnid} in order by`;r.length===0&&this[im](t)}[im](t){let r=this[y_](t),n=(t.tableid?t.tableid+".":"")+t.columnid;if(r.length===0)throw`unknown column ${n}`;if(r.length>1)throw`ambiguous column reference ${n}`;return r[0]}};ry.exports=om});var iy=g((Nae,sy)=>{"use strict";var am=class{static{a(this,"BridgeMethods")}createSchema(){throw new Error("createSchema bridge method is not defined")}dropSchema(){throw new Error("dropSchema bridge method is not defined")}createTable(){throw new Error("createTable bridge method is not defined")}dropTable(){throw new Error("dropTable bridge method is not defined")}createRecords(){throw new Error("createRecords bridge method is not defined")}updateRecords(){throw new Error("updateRecords bridge method is not defined")}async upsertRecords(){throw new Error("upsertRecords bridge method is not defined")}deleteRecords(){throw new Error("deleteRecords bridge method is not defined")}createAttribute(){throw new Error("createAttribute bridge method is not defined")}dropAttribute(){throw new Error("dropAttribute bridge method is not defined")}searchByConditions(){throw new Error("searchByConditions bridge method is not defined")}searchByHash(){throw new Error("searchByHash bridge method is not defined")}searchByValue(){throw new Error("searchByValue bridge method is not defined")}getDataByHash(){throw new Error("getDataByHash bridge method is not defined")}getDataByValue(){throw new Error("getDataByValue bridge method is not defined")}deleteRecordsBefore(){throw new Error("deleteRecordsBefore bridge method is not defined")}deleteAuditLogsBefore(){throw new Error("deleteAuditLogsBefore bridge method is not defined")}async readAuditLog(){throw new Error("readAuditLog bridge method is not defined")}};sy.exports=am});var ay=g((wae,oy)=>{"use strict";var cm=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};oy.exports=cm});var _y={};qe(_y,{HAS_EXPIRATION:()=>hm,LAST_TIMESTAMP_PLACEHOLDER:()=>vc,LOCAL_TIMESTAMP:()=>F$,METADATA:()=>Pc,NO_TIMESTAMP:()=>um,PENDING_LOCAL_TIME:()=>mm,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>Em,RecordEncoder:()=>fm,TIMESTAMP_ASSIGN_LAST:()=>k$,TIMESTAMP_ASSIGN_NEW:()=>ly,TIMESTAMP_ASSIGN_PREVIOUS:()=>uy,TIMESTAMP_PLACEHOLDER:()=>N_,TIMESTAMP_RECORD_PREVIOUS:()=>_m,getUpdateRecord:()=>pm,handleLocalTimeForGets:()=>D_});function $$(){return Uc[0]=Uc[0]^64,q$.getFloat64(0)}function D_(e){let t=e.getEntry;e.readCount=0,e.cachePuts=!1,e.getEntry=function(i,o){e.readCount++;let c=t.call(this,i,o),l=c?.value,_=l?.[Pc];return _>=0&&(c.metadataFlags=_,c.localTime=l.localTime,c.value=l.value,l.expiresAt>0&&(c.expiresAt=l.expiresAt)),c&&(c.key=i),c};let r=e.get;e.get=function(i,o){let c=r.call(this,i,o);return c?.[Pc]>=0?c.value:c};let n=e.getRange;e.getRange=function(i){let o=n.call(this,i);return i.valuesForKey?o.map(c=>c?.value):i.values===!1||i.onlyCount?o:o.map(c=>{let l=c.value,_=l[Pc];return _>=0&&(c.metadataFlags=_,c.localTime=l.localTime,c.value=l.value,l.expiresAt>0&&(c.expiresAt=l.expiresAt)),c})};let s=e.useReadTransaction();if(s.done(),!s.done.isTracked){let i=s.constructor,o=s.use,c=s.done;i.prototype.use=function(){this.timerTracked||(this.timerTracked=!0,ki.push(new WeakRef(this))),o.call(this)},i.prototype.done=function(){if(c.call(this),this.isDone)for(let l=0;l<ki.length;l++){let _=ki[l].deref();(!_||_.isDone||_.isCommitted)&&ki.splice(l--,1)}},i.prototype.done.isTracked=!0}return e}function pm(e,t,r){return function(n,s,i,o,c=-1,l,_,u,d="put",E,f){if(E||l==null?Vo=i?.localTime?_m|uy:um:Vo=l?i?.localTime?_m|16384:ly|16384:um,u>0&&(c|=hm),w_=c,dm=u,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let h={version:o,instructedWrite:Vo>0},p;try{E&&(h.ifVersion=p=i?.version??null);let S=e.put(n,s,h);if(l){let T=_?.user?.username;if(f&&(I_=e.encoder.encode(f)),E&&i?.localTime){let A=i?.localTime,b=r.get(A);if(b){let I=Bt(b).previousLocalTime;return r.put(A,C_(o,t,n,I,T,d,I_),{ifVersion:p}),S}}r.put(vc,C_(o,t,n,i?.localTime?1:0,T,d,I_),{append:d!=="invalidate",instructedWrite:!0,ifVersion:p})}return S}catch(S){throw S.message+=" id: "+n+" options: "+h,S}}}var cy,lm,N_,vc,Em,F$,Pc,Uc,q$,um,ly,k$,uy,_m,hm,mm,V$,I_,Vo,w_,dm,fm,ki,Bc=Re(()=>{cy=require("msgpackr");ti();lm=x(K()),N_=new Uint8Array([1,1,1,1,4,64,0,0]),vc=new Uint8Array([1,1,1,1,1,0,0,0]),Em=new Uint8Array([1,1,1,1,3,64,0,0]),F$=Symbol("local-timestamp"),Pc=Symbol("metadata"),Uc=new Uint8Array(8),q$=new DataView(Uc.buffer,0,8),um=0,ly=0,k$=1,uy=3,_m=4,hm=16,mm=1,Vo=0,w_=-1,dm=0,fm=class extends cy.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(n,s){if(Vo||w_>=0){let i=0,o=Vo;o&&(i+=8,Vo=0);let c=w_,l=dm;c>=0&&(i+=2,w_=-1,l&&(i+=8,dm=0));let _=V$=r.call(this,n,s|2048|i);I_=_.subarray((_.start||0)+i,_.end);let u=_.start||0;return o&&(N_[4]=o,N_[5]=o>>8,_.set(N_,u),u+=8),c>=0&&(_[u++]=c,_[u++]=0,l&&(_.dataView||(_.dataView=new DataView(_.buffer,_.byteOffset,_.byteLength))).setFloat64(u,l)),_}else return r.call(this,n,s)}}decode(t,r){let n=r?.start||0,s=r>-1?r:r?.end||t.length,i=t[n],o=0;try{if(i<32&&s>2){let c=n,l;if(i===2){if(t.copy)t.copy(Uc,0,c),c+=8;else for(let d=0;d<8;d++)Uc[d]=t[c++];l=$$(),i=t[c]}let _;i<32&&(o=i,c+=2,o&hm&&(_=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8));let u=super.decode(t.subarray(c,s),s-c);return{localTime:l,value:u,[Pc]:o,expiresAt:_}}return super.decode(t,r)}catch(c){throw c.message+=", data: "+t.slice(0,40).toString("hex"),c}}};a($$,"getTimestamp");a(D_,"handleLocalTimeForGets");ki=[];setInterval(()=>{for(let e=0;e<ki.length;e++){let t=ki[e].deref();!t||t.isDone||t.isCommitted?ki.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(lm.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):lm.error("Read transaction detected that has been open too long (over one minute), make sure read transactions are quickly closed",t)),t.openTimer++):t.openTimer=1)}},15e3).unref();a(pm,"getUpdateRecord")});var Hc=g((Pae,fy)=>{"use strict";var dy=ne(),Y$=P(),{RecordEncoder:K$}=(Bc(),ie(_y)),Mae=require("fs");dy.initSync();var W$=dy.get(Y$.CONFIG_PARAMS.STORAGE_CACHING)!==!1,Sm=class{static{a(this,"OpenDBIObject")}constructor(t,r=!1){this.dupSort=t===!0,this.encoding=t?"ordered-binary":"msgpack",this.useVersions=r,this.sharedStructuresKey=Symbol.for("structures"),r&&(this.cache=W$&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:K$})}};fy.exports=Sm});var xc=g((vae,Ey)=>{"use strict";var Fr=ne(),cn=P();Fr.initSync();var L_=class{static{a(this,"OpenEnvironmentObject")}constructor(t,r=!1){this.path=t,this.mapSize=1073741824,this.maxDbs=1e4,this.maxReaders=2048,this.sharedStructuresKey=Symbol.for("structures"),this.readOnly=r,this.trackMetrics=!0,this.eventTurnBatching=!1,this.noSync=Fr.get(cn.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Fr.get(cn.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Fr.get(cn.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Fr.get(cn.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Fr.get(cn.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Fr.get(cn.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Fr.get(cn.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Fr.get(cn.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Fr.get(cn.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Fr.get(cn.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Fr.get(cn.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Fr.get(cn.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};Ey.exports=L_;L_.MAX_DBS=1e4});var We=g((Hae,by)=>{"use strict";var gm=require("lmdb"),Cn=require("fs-extra"),qr=require("path"),M_=xr(),py=K(),Er=vr().LMDB_ERRORS_ENUM,P_=ay(),Rm=Hc(),Sy=xc(),ri=dt(),hy=P(),{table:Q$,resetDatabases:z$}=(Ae(),ie(ke)),my=ne(),Dn=ri.INTERNAL_DBIS_NAME,Ty=ri.DBI_DEFINITION_NAME,J$="data.mdb",X$="lock.mdb",Gc=".mdb",j$="-lock",Tm=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=ln(t,r),this.key_type=this.dbi[ri.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[ri.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new gm.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function U_(e,t){if(e===void 0)throw new Error(Er.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(Er.ENV_NAME_REQUIRED)}a(U_,"pathEnvNameValidation");async function Am(e,t,r=!0){try{await Cn.access(e)}catch(n){throw n.code==="ENOENT"?new Error(Er.INVALID_BASE_PATH):n}try{let n=qr.join(e,t+Gc);return await Cn.access(n,Cn.constants.R_OK|Cn.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await Cn.access(qr.join(e,t,J$),Cn.constants.R_OK|Cn.constants.F_OK),qr.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(Er.INVALID_ENVIRONMENT)}else throw new Error(Er.INVALID_ENVIRONMENT);throw n}}a(Am,"validateEnvironmentPath");function v_(e,t){if(M_.validateEnv(e),t===void 0)throw new Error(Er.DBI_NAME_REQUIRED)}a(v_,"validateEnvDBIName");async function Z$(e,t,r=!1,n=!1){U_(e,t);let s=qr.basename(e);t=t.toString();let i=my.get(hy.CONFIG_PARAMS.DATABASES);i||my.setProperty(hy.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await Am(e,t,n),gy(e,t,r)}catch(o){if(o.message===Er.INVALID_ENVIRONMENT){let c=qr.join(e,t);await Cn.mkdirp(n?c:e);let l=new Sy(n?c:c+Gc,!1),_=gm.open(l);_.dbis=Object.create(null);let u=new Rm(!1);_.openDB(Dn,u),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let d=Om(e,t,r);return _[ri.ENVIRONMENT_NAME_KEY]=d,global.lmdb_map[d]=_,_}throw o}}a(Z$,"createEnvironment");async function e1(e,t,r,n=!0){U_(e,t),t=t.toString();let s=qr.join(e,t);return Q$({table:t,database:qr.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(e1,"copyEnvironment");async function gy(e,t,r=!1){U_(e,t),t=t.toString();let n=Om(e,t,r);if(global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null)),global.lmdb_map[n]!==void 0)return global.lmdb_map[n];let s=await Am(e,t),i=qr.join(e,t+Gc),o=s!=i,c=new Sy(s,o),l=gm.open(c);l.dbis=Object.create(null);let _=Ay(l);for(let u=0;u<_.length;u++)ln(l,_[u]);return l[ri.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(gy,"openEnvironment");async function t1(e,t,r=!1){U_(e,t),t=t.toString();let n=qr.join(e,t+Gc),s=await Am(e,t);if(global.lmdb_map!==void 0){let i=Om(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await Ry(o),delete global.lmdb_map[i]}}await Cn.remove(s),await Cn.remove(s===n?s+j$:qr.join(qr.dirname(s),X$))}a(t1,"deleteEnvironment");async function Ry(e){M_.validateEnv(e);let t=e[ri.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(Ry,"closeEnvironment");function Om(e,t,r=!1){let s=`${qr.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(Om,"getCachedEnvironmentName");function r1(e){M_.validateEnv(e);let t=Object.create(null),r=ln(e,Dn);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==Dn)try{t[n]=Object.assign(new P_,s)}catch{py.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(r1,"listDBIDefinitions");function Ay(e){M_.validateEnv(e);let t=[],r=ln(e,Dn);for(let{key:n}of r.getRange({start:!1}))n!==Dn&&t.push(n);return t}a(Ay,"listDBIs");function n1(e,t){let n=ln(e,Dn).getEntry(t),s=new P_;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{py.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(n1,"getDBIDefinition");function Oy(e,t,r,n=!r){if(v_(e,t),t=t.toString(),t===Dn)throw new Error(Er.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return ln(e,t)}catch(s){if(s.message===Er.DBI_DOES_NOT_EXIST){let i=new Rm(r,n===!0),o=e.openDB(t,i),c=new P_(r===!0,n);return o[Ty]=c,ln(e,Dn).putSync(t,c),e.dbis[t]=o,o}throw s}}a(Oy,"createDBI");function ln(e,t){if(v_(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==Dn?r=n1(e,t):r=new P_,r===void 0)throw new Error(Er.DBI_DOES_NOT_EXIST);let n;try{let s=new Rm(r.dup_sort,r.useVersions);if(n=e.openDB(t,s),n.db===void 0)throw new Error("MDB_NOTFOUND")}catch(s){throw s.message.includes("MDB_NOTFOUND")===!0?new Error(Er.DBI_DOES_NOT_EXIST):s}return n[Ty]=r,e.dbis[t]=n,n}a(ln,"openDBI");function s1(e,t){v_(e,t),t=t.toString();let r=ln(e,t),n=r.getStats();return r[ri.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(s1,"statDBI");async function i1(e,t){try{let r=qr.join(e,t+Gc);return(await Cn.stat(r)).size}catch{throw new Error(Er.INVALID_ENVIRONMENT)}}a(i1,"environmentDataSize");function o1(e,t){if(v_(e,t),t=t.toString(),t===Dn)throw new Error(Er.CANNOT_DROP_INTERNAL_DBIS_NAME);ln(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],ln(e,Dn).removeSync(t)}a(o1,"dropDBI");function a1(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{ln(e,i)}catch(o){if(o.message===Er.DBI_DOES_NOT_EXIST)Oy(e,i,i!==t,i===t),n=!0;else throw o}}n&&z$()}a(a1,"initializeDBIs");by.exports={openDBI:ln,openEnvironment:gy,createEnvironment:Z$,listDBIs:Ay,listDBIDefinitions:r1,createDBI:Oy,dropDBI:o1,statDBI:s1,deleteEnvironment:t1,initializeDBIs:a1,TransactionCursor:Tm,environmentDataSize:i1,copyEnvironment:e1,closeEnvironment:Ry}});var Ny=g((Gae,yy)=>{"use strict";var bm=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};yy.exports=bm});var wy=g((qae,Iy)=>{"use strict";var ym=class{static{a(this,"UpdateRecordsResponseObject")}constructor(t=[],r=[],n=void 0,s=[]){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n,this.original_records=s}};Iy.exports=ym});var Dy=g((Vae,Cy)=>{"use strict";var Nm=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};Cy.exports=Nm});var $o=g((Qae,Py)=>{"use strict";var c1=We(),l1=Ny(),u1=wy(),_1=Dy(),zn=xr(),Fc=vr().LMDB_ERRORS_ENUM,d1=dt(),Rs=P(),f1=z(),E1=require("uuid"),Yae=require("lmdb"),{handleHDBError:h1,hdb_errors:m1}=se(),{OVERFLOW_MARKER:Kae,MAX_SEARCH_KEY_LENGTH:Wae}=d1,Ly=ne();Ly.initSync();var B_=Ly.get(Rs.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),Im=Rs.TIME_STAMP_NAMES_ENUM.CREATED_TIME,Vi=Rs.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function p1(e,t,r,n,s=zn.getNextMonotonicTime()){Lm(e,t,r,n),wm(e,t,r);let i=new l1,o=[],c=[];for(let l=0;l<n.length;l++){let _=n[l];My(_,!0,s);let u=S1(e,t,r,_),d=_[t];o.push(u),c.push(d)}return Cm(o,c,n,i,s)}a(p1,"insertRecords");function S1(e,t,r,n){let s=n[t];return e.dbis[t].ifNoExists(s,()=>{for(let i=0;i<r.length;i++){let o=r[i];if(o===t||n.hasOwnProperty(o)===!1)continue;let c=n[o];if(typeof c=="function"){let u=c([[{}]]);Array.isArray(u)&&(c=u[0][Rs.FUNC_VAL],n[o]=c)}let l=zn.getIndexedValues(c),_=e.dbis[o];if(l){B_&&_.prefetch(l.map(u=>({key:u,value:s})),H_);for(let u=0,d=l.length;u<d;u++)_.put(l[u],s)}}B_&&e.dbis[t].prefetch([s],H_),e.dbis[t].put(s,n,n[Vi])})}a(S1,"insertRecord");function T1(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(T1,"removeSkippedRecords");function My(e,t,r){let n=r>0;(n||!Number.isInteger(e[Vi]))&&(e[Vi]=r||(r=zn.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[Im]))&&(e[Im]=r||zn.getNextMonotonicTime()):delete e[Im]}a(My,"setTimestamps");function wm(e,t,r){r.indexOf(Rs.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(Rs.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(Rs.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(Rs.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),c1.initializeDBIs(e,t,r)}a(wm,"initializeTransaction");async function g1(e,t,r,n,s=zn.getNextMonotonicTime()){Lm(e,t,r,n),wm(e,t,r);let i=new u1,o=[],c=[],l=[];for(let _=0;_<n.length;_++){let u=n[_],d=u[t],E;try{E=Dm(e,t,u,d,i,!0,s)}catch{i.skipped_hashes.push(d),o.push(_);continue}c.push(E),l.push(d)}return Cm(c,l,n,i,s,o)}a(g1,"updateRecords");async function R1(e,t,r,n,s=zn.getNextMonotonicTime()){try{Lm(e,t,r,n)}catch(l){throw h1(l,l.message,m1.HTTP_STATUS_CODES.BAD_REQUEST)}wm(e,t,r);let i=new _1,o=[],c=[];for(let l=0;l<n.length;l++){let _=n[l],u;f1.isEmpty(_[t])?(u=E1.v4(),_[t]=u):u=_[t];let d=Dm(e,t,_,u,i,!1,s);o.push(d),c.push(u)}return Cm(o,c,n,i,s)}a(R1,"upsertRecords");async function Cm(e,t,r,n,s,i=[]){let o=await Promise.all(e);for(let c=0,l=o.length;c<l;c++)o[c]===!0?n.written_hashes.push(t[c]):(n.skipped_hashes.push(t[c]),i.push(c));return n.txn_time=s||zn.getNextMonotonicTime(),T1(r,i),n}a(Cm,"finalizeWrite");function Dm(e,t,r,n,s,i=!1,o){let c=e.dbis[t],l=c.getEntry(n),_=l?.value,u=_;if(!_){if(i)return!1;_={}}if(My(r,!u,o),Number.isInteger(r[Vi])&&_[Vi]>r[Vi])return!1;u&&s.original_records.push(_);let d,E=a(()=>{for(let h in r){if(!r.hasOwnProperty(h)||h===t)continue;let p=r[h],S=e.dbis[h];if(S===void 0)continue;let T=_[h];if(typeof p=="function"){let b=p([[_]]);Array.isArray(b)&&(p=b[0][Rs.FUNC_VAL],r[h]=p)}if(p===T)continue;let A=zn.getIndexedValues(T);if(A){B_&&S.prefetch(A.map(b=>({key:b,value:n})),H_);for(let b=0,I=A.length;b<I;b++)S.remove(A[b],n)}if(A=zn.getIndexedValues(p),A){B_&&S.prefetch(A.map(b=>({key:b,value:n})),H_);for(let b=0,I=A.length;b<I;b++)S.put(A[b],n)}}let f=Object.assign({},_,r);c.put(n,f,f[Vi])},"do_put");return l?d=c.ifVersion(n,l.version,E):d=c.ifNoExists(n,E),d.then(f=>f?!0:Dm(e,t,r,n,s,i,o))}a(Dm,"updateUpsertRecord");function A1(e,t,r){if(zn.validateEnv(e),t===void 0)throw new Error(Fc.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(Fc.WRITE_ATTRIBUTES_REQUIRED):new Error(Fc.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(A1,"validateBasic");function Lm(e,t,r,n){if(A1(e,t,r),!Array.isArray(n))throw n===void 0?new Error(Fc.RECORDS_REQUIRED):new Error(Fc.RECORDS_MUST_BE_ARRAY)}a(Lm,"validateWrite");function H_(){}a(H_,"noop");Py.exports={insertRecords:p1,updateRecords:g1,upsertRecords:R1}});var $i=g((Jae,O1)=>{O1.exports={hdb_table:{hash_attribute:"id",name:"hdb_table",schema:"system",residence:["*"],attributes:[{attribute:"id"},{attribute:"name"},{attribute:"hash_attribute"},{attribute:"schema"},{attribute:"residence"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_attribute:{hash_attribute:"id",name:"hdb_attribute",schema:"system",residence:["*"],attributes:[{attribute:"id"},{attribute:"schema"},{attribute:"table"},{attribute:"attribute"},{attribute:"schema_table"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_schema:{hash_attribute:"name",name:"hdb_schema",schema:"system",residence:["*"],attributes:[{attribute:"name"},{attribute:"createddate"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_user:{hash_attribute:"username",name:"hdb_user",schema:"system",residence:["*"],attributes:[{attribute:"username"},{attribute:"password"},{attribute:"role"},{attribute:"active"},{attribute:"hash"},{attribute:"refresh_token"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_role:{hash_attribute:"id",name:"hdb_role",schema:"system",attributes:[{attribute:"id"},{attribute:"role"},{attribute:"permission"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}],residence:["*"]},hdb_job:{hash_attribute:"id",name:"hdb_job",schema:"system",attributes:[{attribute:"id"},{attribute:"user"},{attribute:"type"},{attribute:"status"},{attribute:"start_datetime"},{attribute:"end_datetime"},{attribute:"message"},{attribute:"created_datetime"},{attribute:"request"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_license:{hash_attribute:"license_key",name:"hdb_license",schema:"system",attributes:[{attribute:"license_key"},{attribute:"company"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_info:{hash_attribute:"info_id",name:"hdb_info",schema:"system",attributes:[{attribute:"info_id"},{attribute:"data_version_num"},{attribute:"hdb_version_num"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_nodes:{hash_attribute:"name",name:"hdb_nodes",schema:"system",attributes:[{attribute:"name"},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_analytics:{hash_attribute:"id",name:"hdb_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]},hdb_raw_analytics:{hash_attribute:"id",name:"hdb_raw_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{attribute:"time"},{attribute:"metrics"}]},hdb_temp:{hash_attribute:"id",name:"hdb_temp",schema:"system",attributes:[{attribute:"id"}]},hdb_durable_session:{hash_attribute:"id",name:"hdb_durable_session",schema:"system",attributes:[{attribute:"id"}]},hdb_session_will:{hash_attribute:"id",name:"hdb_session_will",schema:"system",attributes:[{attribute:"id"}]}}});var Xn=g((Xae,By)=>{"use strict";var vy=z(),Uy=P(),Yo=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Jn=require("joi"),ni={schema_format:{pattern:Yo,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},b1=Jn.alternatives(Jn.string().min(1).max(ni.schema_length.maximum).pattern(Yo).messages({"string.pattern.base":"{:#label} "+ni.schema_format.message}),Jn.number(),Jn.array()).required(),y1=Jn.alternatives(Jn.string().min(1).max(ni.schema_length.maximum).pattern(Yo).messages({"string.pattern.base":"{:#label} "+ni.schema_format.message}),Jn.number()),N1=Jn.alternatives(Jn.string().min(1).max(ni.schema_length.maximum).pattern(Yo).messages({"string.pattern.base":"{:#label} "+ni.schema_format.message}),Jn.number()).required();function I1(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>ni.schema_length.maximum?`'${e}' maximum of 250 characters`:Yo.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(I1,"checkValidTable");function w1(e,t){return vy.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(w1,"validateSchemaExists");function C1(e,t){let r=t.state.ancestors[0].schema;return vy.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(C1,"validateTableExists");function D1(e,t){return e.toLowerCase()===Uy.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${Uy.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(D1,"validateSchemaName");By.exports={common_validators:ni,schema_regex:Yo,hdb_schema_table:b1,validateSchemaExists:w1,validateTableExists:C1,validateSchemaName:D1,checkValidTable:I1,hdb_database:y1,hdb_table:N1}});var x_=g((Zae,Hy)=>{var{common_validators:jn}=Xn(),kc=st(),qc="is required",Tt={database:{presence:!1,format:jn.schema_format,length:jn.schema_length},schema:{presence:!1,format:jn.schema_format,length:jn.schema_length},table:{presence:!0,format:jn.schema_format,length:jn.schema_length},attribute:{presence:!0,format:jn.schema_format,length:jn.schema_length},hash_attribute:{presence:!0,format:jn.schema_format,length:jn.schema_length}};function Vc(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(Vc,"makeAttributesStrings");function L1(e){return e=Vc(e),Tt.table.presence=!1,Tt.attribute.presence=!1,Tt.hash_attribute.presence=!1,kc.validateObject(e,Tt)}a(L1,"schema_object");function M1(e){return e=Vc(e),Tt.table.presence={message:qc},Tt.attribute.presence=!1,Tt.hash_attribute.presence=!1,kc.validateObject(e,Tt)}a(M1,"table_object");function P1(e){return e=Vc(e),Tt.table.presence={message:qc},Tt.attribute.presence=!1,kc.validateObject(e,Tt)}a(P1,"create_table_object");function U1(e){return e=Vc(e),Tt.table.presence={message:qc},Tt.attribute.presence={message:qc},Tt.hash_attribute.presence=!1,kc.validateObject(e,Tt)}a(U1,"attribute_object");function v1(e){return e=Vc(e),Tt.table.presence={message:qc},Tt.attribute.presence=!1,Tt.hash_attribute.presence=!1,kc.validateObject(e,Tt)}a(v1,"describe_table");function B1(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(B1,"validateTableResidence");Hy.exports={schema_object:L1,create_table_object:P1,table_object:M1,attribute_object:U1,describe_table:v1,validateTableResidence:B1}});var Gy=g((tce,xy)=>{"use strict";var H1=require("uuid"),Mm=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||H1.v4(),this.schema_table=`${this.schema}.${this.table}`}};xy.exports=Mm});var G_=g((nce,Fy)=>{"use strict";var x1=Gy(),Pm=class extends x1{static{a(this,"LMDBCreateAttributeObject")}constructor(t,r,n,s,i=!0,o=!1){super(t,r,n,s),this.dup_sort=i,this.is_hash_attribute=o}};Fy.exports=Pm});var ky=g((ice,qy)=>{"use strict";qy.exports=F1;var G1="inserted";function F1(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===G1?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(F1,"returnObject")});var F_=g((ace,Wy)=>{"use strict";var q1=P(),Um=We(),k1=$o(),{getSystemSchemaPath:V1,getSchemaPath:$1}=ze(),Y1=$i(),K1=x_(),W1=G_(),Q1=ky(),{handleHDBError:Vy,hdb_errors:Yy}=se(),$y=z(),{HTTP_STATUS_CODES:z1}=Yy,vm=Y1.hdb_attribute,Ky=[];for(let e=0;e<vm.attributes.length;e++)Ky.push(vm.attributes[e].attribute);var J1="inserted";Wy.exports=X1;async function X1(e){let t=K1.attribute_object(e);if(t)throw Vy(new Error,t.message,Yy.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=!e.skip_table_check&&$y.checkGlobalSchemaTable(e.schema,e.table);if(r)throw Vy(new Error,r,z1.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=$y.isEmpty(e.dup_sort)||e.dup_sort=="true";let n=[];if(global.hdb_schema[e.schema]&&global.hdb_schema[e.schema][e.table]&&(n=global.hdb_schema[e.schema][e.table].attributes),Array.isArray(n)&&n.length>0){for(let i of n)if(i.attribute===e.attribute)throw new Error(`attribute '${i.attribute}' already exists in ${e.schema}.${e.table}`)}let s=new W1(e.schema,e.table,e.attribute,e.id);try{let i=await Um.openEnvironment($1(e.schema,e.table),e.table);if(i.dbis[e.attribute]!==void 0)throw new Error(`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`);Um.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await Um.openEnvironment(V1(),q1.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await k1.insertRecords(o,vm.hash_attribute,Ky,[s]);return Q1(J1,c,{records:[s]},l)}catch(i){throw i}}a(X1,"lmdbCreateAttribute")});var Hm=g((lce,zy)=>{var{hdb_table:j1,hdb_database:Qy}=Xn(),Z1=st(),Bm=require("joi"),eY={undefined:"undefined",null:"null"},tY=a((e,t)=>{let r=Object.keys(e),n=r.length,s;for(let i=0;i<n;i++){let o=r[i];(!o||o.length===0||eY[o]!==void 0)&&(s===void 0?s=`Invalid attribute name: '${o}'`:s+=`. Invalid attribute name: '${o}'`)}return s?t.message(s):e},"custom_records_val"),rY=Bm.object({database:Qy,schema:Qy,table:j1,records:Bm.array().items(Bm.object().custom(tY)).required()});zy.exports=function(e){return Z1.validateBySchema(e,rY)}});var $c=g((dce,Xy)=>{"use strict";var As=z(),Jy=K(),_ce=Hm(),{getDatabases:nY}=(Ae(),ie(ke)),{ClientError:Yi}=se();Xy.exports=sY;function sY(e){if(As.isEmpty(e))throw new Yi("invalid update parameters defined.");if(As.isEmptyOrZeroLength(e.schema))throw new Yi("invalid schema specified.");if(As.isEmptyOrZeroLength(e.table))throw new Yi("invalid table specified.");if(!Array.isArray(e.records))throw new Yi("records must be an array");let t=nY()[e.schema]?.[e.table];if(As.isEmpty(t))throw new Yi(`could not retrieve schema:${e.schema} and table ${e.table}`);let r=t.primaryKey,n=new Set,s={},i=!1;return e.operation==="update"&&(i=!0),e.records.forEach(o=>{if(i&&As.isEmptyOrZeroLength(o[r]))throw Jy.error("a valid hash attribute must be provided with update record:",o),new Yi("a valid hash attribute must be provided with update record, check log for more info");if(!As.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw Jy.error(`a valid hash value must be provided with ${e.operation} record:`,o),new Yi(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!As.isEmpty(o[r])&&o[r]!==""&&n.has(As.autoCast(o[r]))&&(o.skip=!0),n.add(As.autoCast(o[r]));for(let c in o)s[c]=1}),s[r]=1,{schema_table:t,hashes:Array.from(n),attributes:Object.keys(s)}}a(sY,"insertUpdateValidate")});var Zy=g((Ece,jy)=>{"use strict";var xm=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};jy.exports=xm});var rN=g((mce,tN)=>{"use strict";var Gm=We(),iY=K(),eN=vr().LMDB_ERRORS_ENUM;tN.exports=oY;async function oY(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 Gm.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==eN.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await Gm.closeEnvironment(global.lmdb_map[n]),await Gm.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==eN.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){iY.error(t)}}a(oY,"cleanLMDBMap")});var Os=g((Sce,oN)=>{"use strict";var Yc=require("crypto"),aY=ne(),{CONFIG_PARAMS:cY}=P(),sN="aes-256-cbc",lY=32,uY=16,Fm=64,iN=32,_Y=Fm+iN,nN=new Map;oN.exports={encrypt:dY,decrypt:fY,createNatsTableStreamName:EY};function dY(e){let t=Yc.randomBytes(lY),r=Yc.randomBytes(uY),n=Yc.createCipheriv(sN,Buffer.from(t),r),s=n.update(e);s=Buffer.concat([s,n.final()]);let i=t.toString("hex"),o=r.toString("hex"),c=s.toString("hex");return i+o+c}a(dY,"encrypt");function fY(e){let t=e.substr(0,Fm),r=e.substr(Fm,iN),n=e.substr(_Y,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=Yc.createDecipheriv(sN,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(fY,"decrypt");function EY(e,t){let r=aY.get(cY.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=nN.get(r);return n||(n=Yc.createHash("md5").update(r).digest("hex"),nN.set(r,n)),n}a(EY,"createNatsTableStreamName")});var si=g((Rce,cN)=>{"use strict";var gce=kr(),Kc=K(),aN=x_(),hY=Os(),q_=z(),{handleHDBError:k_,hdb_errors:mY}=se(),{HDB_ERROR_MSGS:V_,HTTP_STATUS_CODES:qm}=mY,pY=ne();pY.initSync();var{getDatabases:km}=(Ae(),ie(ke)),SY=require("fs-extra");cN.exports={describeAll:TY,describeTable:$_,describeSchema:gY};async function TY(e={}){try{let t=q_.isEmptyOrZeroLength(e),r=!!e.bypass_auth,n,s;!t&&!r&&(n=e.hdb_user?.role?.permission,s=n?.super_user||n?.cluster_user);let i=km(),o={},c={},l=[],_=e?.exact_count;for(let d in i){o[d]=!0,!t&&!s&&!r&&(c[d]=e.hdb_user?.role?.permission[d]?.describe);let E=i[d];for(let f in E)try{let h;if(t||s||r)h=await $_({schema:d,table:f,exact_count:_});else if(n&&n[d].describe&&n[d].tables[f].describe){let p=n[d].tables[f].attribute_permissions;h=await $_({schema:d,table:f,exact_count:_},p)}h&&l.push(h)}catch(h){Kc.error(h)}}let u={};for(let d in l)t||s||r?(u[l[d].schema]==null&&(u[l[d].schema]={}),u[l[d].schema][l[d].name]=l[d],o[l[d].schema]&&delete o[l[d].schema]):c[l[d].schema]&&(u[l[d].schema]==null&&(u[l[d].schema]={}),u[l[d].schema][l[d].name]=l[d],o[l[d].schema]&&delete o[l[d].schema]);for(let d in o)t||s||r?u[d]={}:c[d]&&(u[d]={});return u}catch(t){return Kc.error("Got an error in describeAll"),Kc.error(t),k_(new Error,V_.DESCRIBE_ALL_ERR)}}a(TY,"describeAll");async function $_(e,t){q_.transformReq(e);let{schema:r,table:n}=e;r=r?.toString(),n=n?.toString();let s=t;e.hdb_user&&!e.hdb_user?.role?.permission?.super_user&&(s=e.hdb_user?.role?.permission[r]?.tables[n]?.attribute_permissions);let i=aN.describe_table(e);if(i)throw i;let c=km()[r];if(!c)throw k_(new Error,V_.SCHEMA_NOT_FOUND(e.schema),qm.NOT_FOUND);let l=c[n];if(!l)throw k_(new Error,V_.TABLE_NOT_FOUND(e.schema,e.table),qm.NOT_FOUND);function _(f){u.push(Object.assign({},{attribute:f.attribute,type:f.type,elements:f.elements?.type,indexed:f.indexed,is_primary_key:f.isPrimaryKey,assigned_created_time:f.assignCreatedTime,assigned_updated_time:f.assignUpdatedTime,nullable:f.nullable,properties:f.properties?f.properties.map(h=>({type:h.type,name:h.name})):void 0}))}a(_,"pushAtt");let u=[];if(s){let f={};s.forEach(h=>{h.describe&&(f[h.attribute_name]=!0)}),l.attributes.forEach(h=>{f[h.name]&&_(h)})}else l.attributes?.forEach(f=>_(f));let d;try{d=(await SY.stat(l.primaryStore.env.path)).size}catch(f){Kc.warn("unable to get database size",f)}let E={schema:r,name:l.tableName,hash_attribute:l.attributes.find(f=>f.isPrimaryKey||f.is_hash_attribute)?.name,audit:l.audit,schema_defined:l.schemaDefined,attributes:u,db_size:d};E.clustering_stream_name=hY.createNatsTableStreamName(E.schema,E.name);try{let f=l.getRecordCount({exactCount:e.exact_count==="true"});E.record_count=f.recordCount,E.estimated_record_range=f.estimatedRange;let h=l.auditStore;if(h)for(let p of h.getKeys({reverse:!0,limit:1}))E.last_updated_record=p[0];if(!E.last_updated_record&&l.indices.__updatedtime__)for(let p of l.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))E.last_updated_record=p}catch(f){Kc.warn(`unable to stat table dbi due to ${f}`)}return E}a($_,"descTable");async function gY(e){q_.transformReq(e);let t=aN.schema_object(e);if(t)throw t;let r;e.hdb_user&&!e.hdb_user?.role?.permission?.super_user&&(r=e.hdb_user?.role?.permission[e.schema]);let n=e.schema.toString(),i=km()[n];if(!i)throw k_(new Error,V_.SCHEMA_NOT_FOUND(e.schema),qm.NOT_FOUND);let o={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),q_.isEmpty(l)||l.describe){let _=await $_({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);_&&(o[_.name]=_)}}return o}a(gY,"describeSchema")});var ii=g((yce,fN)=>{var RY=$i(),{callbackify:uN,promisify:AY}=require("util"),{getDatabases:_N}=(Ae(),ie(ke));fN.exports={setSchemaDataToGlobal:lN,getTableSchema:OY,getSystemSchema:bY,setSchemaDataToGlobalAsync:AY(lN)};var dN=si(),Oce=uN(dN.describeAll),bce=uN(dN.describeTable);function lN(e){global.hdb_schema=_N(),e&&e()}a(lN,"setSchemaDataToGlobal");function OY(e,t,r){let n=_N()[e];if(!n)return r(`schema ${e} does not exist`);let s=n[t];return s?r(null,{schema:e,name:t,hash_attribute:s.primaryKey}):r(`table ${e}.${t} does not exist`)}a(OY,"getTableSchema");function bY(){return RY}a(bY,"getSystemSchema")});var un=g((Ice,pN)=>{"use strict";var K_=Hm(),Yt=z(),yY=require("util"),W_=Ln(),NY=ii(),EN=K(),{handleHDBError:Ki,hdb_errors:IY}=se(),{HTTP_STATUS_CODES:Wi}=IY,wY=yY.promisify(NY.getTableSchema),CY="updated",hN="inserted",mN="upserted";pN.exports={insert:LY,update:MY,upsert:PY,validation:DY,flush:UY};async function DY(e){if(Yt.isEmpty(e))throw new Error("invalid update parameters defined.");if(Yt.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if(Yt.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await wY(e.schema,e.table),r=K_(e);if(r)throw r;if(!Array.isArray(e.records))throw new Error("records must be an array");let n=t.hash_attribute,s=new Set,i={},o=!1;return e.operation==="update"&&(o=!0),e.records.forEach(c=>{if(o&&Yt.isEmptyOrZeroLength(c[n]))throw EN.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(!Yt.isEmptyOrZeroLength(c[n])&&(c[n]==="null"||c[n]==="undefined"))throw EN.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[n]}" is not a valid hash attribute value`);!Yt.isEmpty(c[n])&&c[n]!==""&&s.has(Yt.autoCast(c[n]))&&(c.skip=!0),s.add(Yt.autoCast(c[n]));for(let l in c)i[l]=1}),i[n]=1,{schema_table:t,hashes:Array.from(s),attributes:Object.keys(i)}}a(DY,"validation");async function LY(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=K_(e);if(t)throw Ki(new Error,t.message,Wi.BAD_REQUEST);Yt.transformReq(e);let r=Yt.checkSchemaTableExist(e.schema,e.table);if(r)throw Ki(new Error,r,Wi.BAD_REQUEST);let n=await W_.createRecords(e);return Y_(hN,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(LY,"insertData");async function MY(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=K_(e);if(t)throw Ki(new Error,t.message,Wi.BAD_REQUEST);Yt.transformReq(e);let r=Yt.checkSchemaTableExist(e.schema,e.table);if(r)throw Ki(new Error,r,Wi.BAD_REQUEST);let n=await W_.updateRecords(e);return Yt.isEmpty(n.existing_rows)?Y_(CY,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):Y_(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(MY,"updateData");async function PY(e){if(e.operation!=="upsert")throw Ki(new Error,"invalid operation, must be upsert",Wi.INTERNAL_SERVER_ERROR);let t=K_(e);if(t)throw Ki(new Error,t.message,Wi.BAD_REQUEST);Yt.transformReq(e);let r=Yt.checkSchemaTableExist(e.schema,e.table);if(r)throw Ki(new Error,r,Wi.BAD_REQUEST);let n=await W_.upsertRecords(e);return Y_(mN,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(PY,"upsertData");function Y_(e,t,r,n,s,i){let o={message:`${e} ${t.length} of ${t.length+n.length} records`,new_attributes:s,txn_time:i};return e===hN?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===mN?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(Y_,"returnObject");function UY(e){return Yt.transformReq(e),W_.flush(e.schema,e.table)}a(UY,"flush")});var $m=g((Cce,gN)=>{var vY=st(),Vm=require("joi"),{hdb_table:BY,hdb_database:SN}=Xn(),TN={schema:SN,database:SN,table:BY},HY={date:Vm.date().iso().required()},xY={timestamp:Vm.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};gN.exports=function(e,t){let r=t==="timestamp"?{...TN,...xY}:{...TN,...HY},n=Vm.object(r);return vY.validateBySchema(e,n)}});var ON=g((Dce,AN)=>{var GY=st(),Ym=require("joi"),{hdb_table:FY,hdb_database:RN}=Xn(),qY=Ym.object({schema:RN,database:RN,table:FY,hash_values:Ym.array().required(),ids:Ym.array()});AN.exports=function(e){return GY.validateBySchema(e,qY)}});var yN=g((Lce,bN)=>{"use strict";var Km=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i){this.operation=t,this.schema=r,this.table=n,this.hash_attribute=s,this.records=i}},Wm=class{static{a(this,"NoSQLSeachObject")}constructor(t,r,n,s,i,o){this.schema=t,this.table=r,this.search_attribute=n,this.hash_attribute=s,this.get_attributes=i,this.search_value=o}},Qm=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};bN.exports={InsertObject:Km,NoSQLSeachObject:Wm,DeleteResponseObject:Qm}});var Ji=g((Pce,DN)=>{"use strict";var IN=$m(),kY=ON(),Qi=z(),NN=require("moment"),wN=K(),{promisify:VY,callbackify:$Y}=require("util"),zi=P(),YY=ii(),zm=VY(YY.getTableSchema),Jm=Ln(),{DeleteResponseObject:KY}=yN(),{handleHDBError:oi,hdb_errors:WY}=se(),{HDB_ERROR_MSGS:Q_,HTTP_STATUS_CODES:ai}=WY,QY="records successfully deleted",zY=$Y(CN);DN.exports={delete:zY,deleteRecord:CN,deleteFilesBefore:JY,deleteAuditLogsBefore:XY};async function JY(e){let t=IN(e,"date");if(t)throw oi(t,t.message,ai.BAD_REQUEST,void 0,void 0,!0);if(Qi.transformReq(e),!NN(e.date,NN.ISO_8601).isValid())throw oi(new Error,Q_.INVALID_DATE,ai.BAD_REQUEST,zi.LOG_LEVELS.ERROR,Q_.INVALID_DATE,!0);let n=Qi.checkSchemaTableExist(e.schema,e.table);if(n)throw oi(new Error,n,ai.NOT_FOUND,zi.LOG_LEVELS.ERROR,n,!0);let s=await Jm.deleteRecordsBefore(e);if(await zm(e.schema,e.table),wN.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(JY,"deleteFilesBefore");async function XY(e){let t=IN(e,"timestamp");if(t)throw oi(t,t.message,ai.BAD_REQUEST,void 0,void 0,!0);if(Qi.transformReq(e),isNaN(e.timestamp))throw oi(new Error,Q_.INVALID_VALUE("Timestamp"),ai.BAD_REQUEST,zi.LOG_LEVELS.ERROR,Q_.INVALID_VALUE("Timestamp"),!0);let r=Qi.checkSchemaTableExist(e.schema,e.table);if(r)throw oi(new Error,r,ai.NOT_FOUND,zi.LOG_LEVELS.ERROR,r,!0);let n=await Jm.deleteAuditLogsBefore(e);return await zm(e.schema,e.table),wN.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(XY,"deleteAuditLogsBefore");async function CN(e){e.ids&&(e.hash_values=e.ids);let t=kY(e);if(t)throw oi(t,t.message,ai.BAD_REQUEST,void 0,void 0,!0);Qi.transformReq(e);let r=Qi.checkSchemaTableExist(e.schema,e.table);if(r)throw oi(new Error,r,ai.NOT_FOUND,zi.LOG_LEVELS.ERROR,r,!0);try{await zm(e.schema,e.table);let n=await Jm.deleteRecords(e);return Qi.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${QY}`),n}catch(n){if(n.message===zi.SEARCH_NOT_FOUND_MESSAGE){let s=new KY;return s.message=zi.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(CN,"deleteRecord")});var z_=g((vce,PN)=>{var jY=require("crypto"),LN=9;function ZY(e){let t=tK(LN),r=MN(e+t);return t+r}a(ZY,"createHash");function eK(e,t){let r=e?.substr(0,LN),n=r+MN(t+r);return e===n}a(eK,"validateHash");function tK(e){let t="0123456789abcdefghijklmnopqurstuvwxyzABCDEFGHIJKLMNOPQURSTUVWXYZ",r=t.length,n="";for(let s=0;s<e;s++){let i=Math.floor(Math.random()*r);n+=t[i]}return n}a(tK,"generateSalt");function MN(e){return jY.createHash("md5").update(e).digest("hex")}a(MN,"md5");PN.exports={hash:ZY,validate:eK}});var vN=g((Hce,UN)=>{var Xm=st(),er={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 rK(e){return er.password.presence=!0,er.username.presence=!0,er.role.presence=!0,er.active.presence=!0,Xm.validateObject(e,er)}a(rK,"addUserValidation");function nK(e){return er.password.presence=!1,er.username.presence=!0,er.role.presence=!1,er.active.presence=!1,Xm.validateObject(e,er)}a(nK,"alterUserValidation");function sK(e){return er.password.presence=!1,er.username.presence=!0,er.role.presence=!1,er.active.presence=!1,Xm.validateObject(e,er)}a(sK,"dropUserValidation");UN.exports={addUserValidation:rK,alterUserValidation:nK,dropUserValidation:sK}});var ct=g((Fce,HN)=>{"use strict";var{platform:Gce}=require("os"),iK="nats-server.zip",jm="nats-server",oK=process.platform==="win32"?`${jm}.exe`:jm,aK=/^[^\s.,*>]+$/,BN="__request__",cK=a(e=>`${e}.${BN}`,"REQUEST_SUBJECT"),lK={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},uK={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},_K={HUB:"hub.pid",LEAF:"leaf.pid"},dK={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},fK={SUCCESS:"success",ERROR:"error"},EK={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},hK={TXN:"txn",MSGID:"msgid"},Ko={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},mK={[Ko.ERR]:1,[Ko.WRN]:2,[Ko.INF]:3,[Ko.DBG]:4,[Ko.TRC]:5},pK={debug:"-D",trace:"-DVV"};HN.exports={NATS_SERVER_ZIP:iK,NATS_SERVER_NAME:jm,NATS_BINARY_NAME:oK,PID_FILES:_K,NATS_CONFIG_FILES:uK,SERVER_SUFFIX:dK,NATS_TERM_CONSTRAINTS_RX:aK,REQUEST_SUFFIX:BN,UPDATE_REMOTE_RESPONSE_STATUSES:fK,CLUSTER_STATUS_STATUSES:EK,REQUEST_SUBJECT:cK,SUBJECT_PREFIXES:hK,MSG_HEADERS:lK,LOG_LEVELS:Ko,LOG_LEVEL_FLAGS:pK,LOG_LEVEL_HIERARCHY:mK}});var GN=g((kce,xN)=>{"use strict";var J_=P(),X_=class{static{a(this,"BaseLicense")}constructor(t=0,r=J_.RAM_ALLOCATION_ENUM.DEFAULT,n=J_.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},Zm=class extends X_{static{a(this,"ExtendedLicense")}constructor(t=0,r=J_.RAM_ALLOCATION_ENUM.DEFAULT,n=J_.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};xN.exports={BaseLicense:X_,ExtendedLicense:Zm}});var Xi=g(($ce,YN)=>{"use strict";var Qo=require("fs-extra"),qN=z_(),kN=require("crypto"),SK=require("moment"),TK=require("uuid").v4,tr=K(),tp=require("path"),gK=z(),ci=P(),{totalmem:FN}=require("os"),RK=GN().ExtendedLicense,Wo="invalid license key format",AK="061183",OK="mofi25",bK="aes-256-cbc",yK=16,NK=32,VN=ne();VN.initSync();var ep;YN.exports={validateLicense:$N,generateFingerPrint:wK,licenseSearch:sp,getLicense:LK,checkMemoryLimit:MK};function rp(){return tp.join(VN.getHdbBasePath(),ci.LICENSE_KEY_DIR_NAME,ci.LICENSE_FILE_NAME)}a(rp,"getLicenseDirPath");function IK(){let e=rp();return tp.join(e,ci.LICENSE_FILE_NAME)}a(IK,"getLicenseFilePath");function np(){let e=rp();return tp.join(e,ci.REG_KEY_FILE_NAME)}a(np,"getFingerPrintFilePath");async function wK(){let e=np();try{return await Qo.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await CK();throw tr.error(`Error writing fingerprint file to ${e}`),tr.error(t),new Error("There was an error generating the fingerprint")}}a(wK,"generateFingerPrint");async function CK(){let e=TK(),t=qN.hash(e),r=np();try{await Qo.mkdirp(rp()),await Qo.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw tr.error(`Error writing fingerprint file to ${r}`),tr.error(n),new Error("There was an error generating the fingerprint")}return t}a(CK,"writeFingerprint");function $N(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:ci.RAM_ALLOCATION_ENUM.DEFAULT,version:ci.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return tr.error("empty license key passed to validate."),r;let n=np(),s=!1;try{s=Qo.statSync(n)}catch(i){tr.error(i)}if(s){let i;try{i=Qo.readFileSync(n,"utf8")}catch{tr.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(OK),c=o[1];c=Buffer.concat([Buffer.from(c)],yK);let l=Buffer.concat([Buffer.from(i)],NK),_=kN.createDecipheriv(bK,l,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let u=null;try{u=_.update(o[0],"hex","utf8"),u.trim(),u+=_.final("utf8")}catch{let f=DK(o[0],i);if(f)u=f;else throw r.valid_license=!1,r.valid_machine=!1,console.error(Wo),tr.error(Wo),new Error(Wo)}let d;if(isNaN(u))try{d=JSON.parse(u),r.version=d.version,r.exp_date=d.exp_date,isNaN(r.exp_date)&&(r.exp_date=new Date(r.exp_date).getTime()),d.ram_allocation&&(r.ram_allocation=d.ram_allocation)}catch{throw console.error(Wo),tr.error(Wo),new Error(Wo)}else r.exp_date=u;r.exp_date<SK().valueOf()&&(r.valid_date=!1),qN.validate(o[1],`${AK}${i}${t}`)||(r.valid_license=!1)}else r.valid_license=!1,r.valid_machine=!1;return r.valid_license&&r.valid_machine&&r.valid_date||tr.error("Invalid licence"),r}a($N,"validateLicense");function DK(e,t){try{let r=kN.createDecipher("aes192",t),n=r.update(e,"hex","utf8");return n.trim(),n+=r.final("utf8"),n}catch{tr.warn("Check old license failed")}}a(DK,"checkOldLicense");function sp(){let e=new RK,t=[];try{t=Qo.readFileSync(IK(),"utf-8").split(ci.NEW_LINE)}catch(r){r.code==="ENOENT"?tr.info("no license file found"):tr.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if(gK.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=$N(s.license_key,s.company);i.valid_machine===!0&&i.valid_date===!0&&i.valid_machine===!0&&(e.exp_date=i.exp_date>e.exp_date?i.exp_date:e.exp_date,e.ram_allocation=i.ram_allocation,e.enterprise=!0)}catch(s){tr.error("There was an error parsing the license string."),tr.error(s),e.ram_allocation=ci.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return ep=e,e}a(sp,"licenseSearch");async function LK(){return ep||await sp(),ep}a(LK,"getLicense");function MK(){let e=sp().ram_allocation,t=process.constrainedMemory?.()||FN();if(t=Math.round(Math.min(t,FN())/2**20),t>e)return`This server has more memory (${t}MB) than HarperDB is licensed for (${e}MB), this should only be used for educational and development purposes.`}a(MK,"checkMemoryLimit")});var _n=g((zce,aI)=>{"use strict";var zN="username is required",JN="nothing to update, must supply active, role or password to update",XN="password cannot be an empty string",jN="If role is specified, it cannot be empty.",ZN="active must be true or false";aI.exports={addUser:qK,alterUser:kK,dropUser:$K,getSuperUser:QK,userInfo:YK,listUsers:Z_,listUsersExternal:KK,setUsersToGlobal:Jo,findAndValidateUser:iI,getClusterUser:zK,USERNAME_REQUIRED:zN,ALTERUSER_NOTHING_TO_UPDATE:JN,EMPTY_PASSWORD:XN,EMPTY_ROLE:jN,ACTIVE_BOOLEAN:ZN};var eI=un(),PK=Ji(),ap=z_(),tI=vN(),rI=kr(),cp=bs(),Vr=z(),nI=require("validate.js"),Oe=K(),{promisify:UK}=require("util"),lp=Os(),KN=P(),WN=ct(),vK=dr(),Kce=ne(),Wce=Xi(),BK=$i(),{table:Qce}=(Ae(),ie(ke)),{handleHDBError:Zn,hdb_errors:HK}=se(),{HTTP_STATUS_CODES:es,AUTHENTICATION_ERROR_MSGS:ip,HDB_ERROR_MSGS:zo}=HK,{UserEventMsg:up}=Mn(),op=require("lodash"),{server:_p}=(ur(),ie(xi)),xK=K();_p.getUser=(e,t)=>iI(e,t,t!=null);var sI={username:!0,active:!0,role:!0,password:!0},QN=new Map,j_=rI.searchByValue,GK=rI.searchByHash,FK=UK(PK.delete);async function qK(e){let t=nI.cleanAttributes(e,sI),r=tI.addUserValidation(t);if(r)throw Zn(new Error,r.message,es.BAD_REQUEST,void 0,void 0,!0);let n={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["id","permission","role"]},s;try{s=await j_(n),s=s&&Array.from(s)}catch(l){throw Oe.error("There was an error searching for a role in add user"),Oe.error(l),l}if(!s||s.length<1)throw Zn(new Error,zo.ROLE_NAME_NOT_FOUND(t.role),es.NOT_FOUND,void 0,void 0,!0);if(s.length>1)throw Zn(new Error,zo.DUP_ROLES_FOUND(t.role),es.CONFLICT,void 0,void 0,!0);s[0].permission.cluster_user===!0&&(t.hash=lp.encrypt(t.password)),t.password=ap.hash(t.password),t.role=s[0].id;let i={operation:"insert",schema:"system",table:"hdb_user",records:[t]},o;try{o=await eI.insert(i)}catch(l){throw Oe.error("There was an error searching for a user."),Oe.error(l),l}Oe.debug(o);try{await Jo()}catch(l){throw Oe.error("Got an error setting users to global"),Oe.error(l),l}if(o.skipped_hashes.length===1)throw Zn(new Error,zo.USER_ALREADY_EXISTS(t.username),es.CONFLICT,void 0,void 0,!0);let c=Object.assign({},t);return c.role=s[0],cp.signalUserChange(new up(process.pid)),`${c.username} successfully added`}a(qK,"addUser");async function kK(e){let t=nI.cleanAttributes(e,sI);if(Vr.isEmptyOrZeroLength(t.username))throw new Error(zN);if(Vr.isEmptyOrZeroLength(t.password)&&Vr.isEmptyOrZeroLength(t.role)&&Vr.isEmptyOrZeroLength(t.active))throw new Error(JN);if(!Vr.isEmpty(t.password)&&Vr.isEmptyOrZeroLength(t.password.trim()))throw new Error(XN);if(!Vr.isEmpty(t.active)&&!Vr.isBoolean(t.active))throw new Error(ZN);let r=VK(t.username);if(!Vr.isEmpty(t.password)&&!Vr.isEmptyOrZeroLength(t.password.trim())&&(r&&(t.hash=lp.encrypt(t.password)),t.password=ap.hash(t.password)),t.role==="")throw new Error(jN);if(t.role){let i={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]},o;try{o=Array.from(await j_(i)||[])}catch(c){throw Oe.error("Got an error searching for a role."),Oe.error(c),c}if(!o||o.length===0){let c=zo.ALTER_USER_ROLE_NOT_FOUND(t.role);throw Oe.error(c),Zn(new Error,c,es.NOT_FOUND,void 0,void 0,!0)}if(o.length>1){let c=zo.ALTER_USER_DUP_ROLES(t.role);throw Oe.error(c),Zn(new Error,c,es.CONFLICT,void 0,void 0,!0)}t.role=o[0].id}let n={operation:"update",schema:"system",table:"hdb_user",records:[t]},s;try{s=await eI.update(n)}catch(i){throw Oe.error("Error during update."),Oe.error(i),i}try{await Jo()}catch(i){throw Oe.error("Got an error setting users to global"),Oe.error(i),i}return cp.signalUserChange(new up(process.pid)),s}a(kK,"alterUser");function VK(e){let t=!1,r=global.hdb_users.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(VK,"isClusterUser");async function $K(e){try{let t=tI.dropUserValidation(e);if(t)throw new Error(t);let r={table:"hdb_user",schema:"system",hash_values:[e.username]};if(Vr.isEmpty(global.hdb_users.get(e.username)))throw Zn(new Error,zo.USER_NOT_EXIST(e.username),es.NOT_FOUND,void 0,void 0,!0);let n;try{n=await FK(r)}catch(s){throw Oe.error("Got an error deleting a user."),Oe.error(s),s}Oe.debug(n);try{await Jo()}catch(s){throw Oe.error("Got an error setting users to global."),Oe.error(s),s}return cp.signalUserChange(new up(process.pid)),`${e.username} successfully deleted`}catch(t){throw t}}a($K,"dropUser");async function YK(e){let t={};try{if(!e||!e.hdb_user)return"There was no user info in the body";t=op.cloneDeep(e.hdb_user);let r={schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]},n;try{n=await GK(r)}catch(s){throw Oe.error("Got an error searching for a role."),Oe.error(s),s}t.role=n[0],delete t.password,delete t.refresh_token,delete t.hash}catch(r){throw Oe.error(r),r}return t}a(YK,"userInfo");async function KK(){let e;try{e=await Z_()}catch(t){throw Oe.error("Got an error listing users."),Oe.error(t),t}try{e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token})}catch{throw new Error("there was an error massaging the user data")}return[...e.values()]}a(KK,"listUsersExternal");async function Z_(){try{let e={schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]},t;try{t=await j_(e)}catch(o){throw Oe.error("Got an error searching for roles."),Oe.error(o),o}let r={};for(let o of t)r[o.id]=op.cloneDeep(o);if(Object.keys(r).length===0)return null;let n={schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]},s;try{s=await j_(n)}catch(o){throw Oe.error("Got an error searching for users."),Oe.error(o),o}let i=new Map;for(let o of s)o=op.cloneDeep(o),o.role=r[o.role],WK(o.role),i.set(o.username,o);return i}catch(e){throw Oe.error("got an error listing users"),Oe.error(e),Vr.errorizeMessage(e)}return null}a(Z_,"listUsers");function WK(e){try{if(!e){Oe.error("invalid user role found.");return}e.permission.system||(e.permission.system={}),e.permission.system.tables||(e.permission.system.tables={});for(let t of Object.keys(BK)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}catch(t){Oe.error("Got an error trying to set system permissions."),Oe.error(t)}}a(WK,"appendSystemTablesToRole");async function Jo(){try{let e=await Z_();global.hdb_users=e}catch(e){throw Oe.error(e),e}}a(Jo,"setUsersToGlobal");async function iI(e,t,r=!0){global.hdb_users||await Jo();let n=global.hdb_users.get(e);if(!n){if(!r)return{username:e};throw Zn(new Error,ip.GENERIC_AUTH_FAIL,es.UNAUTHORIZED,void 0,void 0,!0)}if(n&&!n.active)throw Zn(new Error,ip.USER_INACTIVE,es.UNAUTHORIZED,void 0,void 0,!0);let s={active:n.active,username:n.username};if(n.refresh_token&&(s.refresh_token=n.refresh_token),n.role&&(s.role=n.role),r===!0){if(QN.get(t)===n.password)return s;if(ap.validate(n.password,t))QN.set(t,n.password);else throw Zn(new Error,ip.GENERIC_AUTH_FAIL,es.UNAUTHORIZED,void 0,void 0,!0)}return s}a(iI,"findAndValidateUser");async function QK(){global.hdb_users||await Jo();for(let[,e]of global.hdb_users)if(e.role.role==="super_user")return e}a(QK,"getSuperUser");async function zK(){let e=await Z_(),t=vK.getConfigFromFile(KN.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!Vr.isEmpty(r)&&r?.role?.role===KN.ROLE_TYPES_ENUM.CLUSTER_USER)return r.decrypt_hash=lp.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+WN.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+WN.SERVER_SUFFIX.ADMIN,r}a(zK,"getClusterUser");var oI=[];_p.invalidateUser=function(e){for(let t of oI)try{t(e)}catch(r){xK.error("Error invalidating user",r)}};_p.onInvalidatedUser=function(e){oI.push(e)}});var Qc=g((Zce,_I)=>{"use strict";var ji=K(),$r=P(),JK=rN(),Xce=ii(),jce=si(),XK=_n(),{validateEvent:cI}=Mn(),Wc=Ln(),jK=require("process"),{resetDatabases:ZK}=(Ae(),ie(ke)),eW={[$r.ITC_EVENT_TYPES.SCHEMA]:tW,[$r.ITC_EVENT_TYPES.USER]:uI};async function tW(e){let t=cI(e);if(t){ji.error(t);return}ji.trace("ITC schemaHandler received schema event:",e),await JK(e.message),await rW(e.message)}a(tW,"schemaHandler");async function rW(e){try{Wc.resetReadTxn($r.SYSTEM_SCHEMA_NAME,$r.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),Wc.resetReadTxn($r.SYSTEM_SCHEMA_NAME,$r.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),Wc.resetReadTxn($r.SYSTEM_SCHEMA_NAME,$r.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=ZK();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){ji.error(t)}}a(rW,"syncSchemaMetadata");var lI=[];async function uI(e){try{try{Wc.resetReadTxn($r.SYSTEM_SCHEMA_NAME,$r.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),Wc.resetReadTxn($r.SYSTEM_SCHEMA_NAME,$r.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){ji.warn(r)}let t=cI(e);if(t){ji.error(t);return}ji.trace(`ITC userHandler ${$r.HDB_ITC_CLIENT_PREFIX}${jK.pid} received user event:`,e),await XK.setUsersToGlobal();for(let r of lI)r()}catch(t){ji.error(t)}}a(uI,"userHandler");uI.addListener=function(e){lI.push(e)};_I.exports=eW});var Mn=g((ile,fI)=>{"use strict";var tle=K(),dp=z(),nW=P(),{ITC_ERRORS:zc}=vr(),{parentPort:rle,threadId:sW,isMainThread:iW,workerData:nle}=require("worker_threads"),{onMessageFromWorkers:oW,broadcast:sle,broadcastWithAcknowledgement:aW}=ot();fI.exports={sendItcEvent:cW,validateEvent:dI,SchemaEventMsg:lW,UserEventMsg:uW};var ed;oW(async(e,t)=>{ed=ed||Qc(),dI(e),ed[e.type]&&await ed[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function cW(e){return!iW&&e.message&&(e.message.originator=sW),aW(e)}a(cW,"sendItcEvent");function dI(e){if(typeof e!="object")return zc.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||dp.isEmpty(e.type))return zc.MISSING_TYPE;if(!e.hasOwnProperty("message")||dp.isEmpty(e.message))return zc.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||dp.isEmpty(e.message.originator))return zc.MISSING_ORIGIN;if(nW.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return zc.INVALID_EVENT(e.type)}a(dI,"validateEvent");function lW(e,t,r,n=void 0,s=void 0){this.originator=e,this.operation=t,this.schema=r,this.table=n,this.attribute=s}a(lW,"SchemaEventMsg");function uW(e){this.originator=e}a(uW,"UserEventMsg")});var bs=g((cle,pI)=>{"use strict";var EI=P(),ale=z(),td=K(),hI=Zy(),Xo,{sendItcEvent:mI}=Mn();function _W(e){try{td.trace("signalSchemaChange called with message:",e),Xo=Xo||Qc();let t=new hI(EI.ITC_EVENT_TYPES.SCHEMA,e);return Xo.schema(t),mI(t)}catch(t){td.error(t)}}a(_W,"signalSchemaChange");function dW(e){try{td.trace("signalUserChange called with message:",e),Xo=Xo||Qc();let t=new hI(EI.ITC_EVENT_TYPES.USER,e);return Xo.user(t),mI(t)}catch(t){td.error(t)}}a(dW,"signalUserChange");pI.exports={signalSchemaChange:_W,signalUserChange:dW}});var rd=g((ule,TI)=>{"use strict";var SI=z(),fW=P(),EW=K(),hW=F_(),mW=G_(),pW=bs(),{SchemaEventMsg:SW}=Mn(),TW="already exists in";TI.exports=gW;async function gW(e,t,r){if(SI.isEmptyOrZeroLength(r))return r;let n=[];SI.isEmptyOrZeroLength(t.attributes)||t.attributes.forEach(i=>{n.push(i.attribute)});let s=r.filter(i=>n.indexOf(i)<0);return s.length===0||await Promise.all(s.map(async i=>{await RW(e,t.schema,t.name,i)})),s}a(gW,"lmdbCheckForNewAttributes");async function RW(e,t,r,n){let s=new mW(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await AW(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(TW))EW.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(RW,"createNewAttribute");async function AW(e){let t;return t=await hW(e),pW.signalSchemaChange(new SW(process.pid,fW.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(AW,"createAttribute")});var jo=g((dle,gI)=>{"use strict";var fp=class{static{a(this,"LMDBTransactionObject")}constructor(t,r,n,s,i=void 0){this.operation=t,this.user_name=r,this.timestamp=n,this.hash_values=s,this.origin=i}};gI.exports=fp});var AI=g((Ele,RI)=>{"use strict";var OW=jo(),bW=P().OPERATIONS_ENUM,Ep=class extends OW{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(bW.INSERT,r,n,s,i),this.records=t}};RI.exports=Ep});var bI=g((mle,OI)=>{"use strict";var yW=jo(),NW=P().OPERATIONS_ENUM,hp=class extends yW{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(NW.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};OI.exports=hp});var NI=g((Sle,yI)=>{"use strict";var IW=jo(),wW=P().OPERATIONS_ENUM,mp=class extends IW{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(wW.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};yI.exports=mp});var wI=g((gle,II)=>{"use strict";var CW=jo(),DW=P().OPERATIONS_ENUM,pp=class extends CW{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(DW.DELETE,n,s,t,i),this.original_records=r}};II.exports=pp});var Jc=g((Ole,MI)=>{"use strict";var Ale=require("path"),CI=We(),LW=AI(),MW=bI(),PW=NI(),UW=wI(),Zo=dt(),DI=z(),{CONFIG_PARAMS:vW}=P(),LI=ne();LI.initSync();var nd=P().OPERATIONS_ENUM,{getTransactionAuditStorePath:BW}=ze();MI.exports=HW;async function HW(e,t){if(LI.get(vW.LOGGING_AUDITLOG)===!1)return;let r=BW(e.schema,e.table),n=await CI.openEnvironment(r,e.table,!0),s=xW(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){CI.initializeDBIs(n,Zo.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Zo.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[Zo.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[Zo.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),DI.isEmpty(s.user_name)||n.dbis[Zo.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[Zo.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(HW,"writeTransaction");function xW(e,t){let r=DI.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===nd.INSERT)return new LW(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===nd.UPDATE)return new MW(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===nd.UPSERT)return new PW(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===nd.DELETE)return new UW(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(xW,"createTransactionObject")});var Sp=g((Nle,PI)=>{"use strict";var GW=$c(),yle=Ic(),Xc=P(),FW=wc(),qW=$o().insertRecords,kW=We(),VW=K(),$W=rd(),{getSchemaPath:YW}=ze(),KW=Jc();PI.exports=WW;async function WW(e){try{let{schema_table:t,attributes:r}=GW(e);FW(e,r,t.hash_attribute),e.schema!==Xc.SYSTEM_SCHEMA_NAME&&(r.includes(Xc.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(Xc.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(Xc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(Xc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await $W(e.hdb_auth_header,t,r),s=YW(e.schema,e.table),i=await kW.openEnvironment(s,e.table),o=await qW(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await KW(e,o)}catch(c){VW.error(`unable to write transaction due to ${c.message}`)}return{written_hashes:o.written_hashes,skipped_hashes:o.skipped_hashes,schema_table:t,new_attributes:n,txn_time:o.txn_time}}catch(t){throw t}}a(WW,"lmdbCreateRecords")});var BI=g((wle,vI)=>{"use strict";var UI=P(),QW=Sp(),zW=Ic(),JW=require("fs-extra"),{getSchemaPath:XW}=ze();vI.exports=jW;async function jW(e){let t=[{name:e.schema,createddate:Date.now()}],r=new zW(UI.SYSTEM_SCHEMA_NAME,UI.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await QW(r),await JW.mkdirp(XW(e.schema))}a(jW,"lmdbCreateSchema")});var xI=g((Dle,HI)=>{"use strict";var Tp=class{static{a(this,"DeleteRecordsResponseObject")}constructor(t=[],r=[],n=void 0,s=[]){this.deleted=t,this.skipped=r,this.txn_time=n,this.original_records=s}};HI.exports=Tp});var kI=g((vle,qI)=>{"use strict";var GI=We(),gp=xr(),Rp=vr().LMDB_ERRORS_ENUM,ZW=dt(),FI=K(),Mle=z(),eQ=require("lmdb"),tQ=xI(),rQ=P(),{OVERFLOW_MARKER:Ple,MAX_SEARCH_KEY_LENGTH:Ule}=ZW,nQ=rQ.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function sQ(e,t,r,n){if(gp.validateEnv(e),t===void 0)throw new Error(Rp.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(Rp.IDS_REQUIRED):new Error(Rp.IDS_MUST_BE_ITERABLE);try{let s=GI.listDBIs(e);GI.initializeDBIs(e,t,s);let i=new tQ,o,c=[],l=[];for(let E=0,f=r.length;E<f;E++)try{o=r[E];let h=e.dbis[t].get(o);if(!h||n&&h[nQ]>n){i.skipped.push(o);continue}let p=e.dbis[t].ifVersion(o,eQ.IF_EXISTS,()=>{e.dbis[t].remove(o);for(let S=0;S<s.length;S++){let T=s[S];if(!h.hasOwnProperty(T)||T===t)continue;let A=e.dbis[T],b=h[T];if(b!=null)try{let I=gp.getIndexedValues(b);if(I)for(let B=0,U=I.length;B<U;B++)A.remove(I[B],o)}catch{FI.warn(`cannot delete from attribute: ${T}, ${b}:${o}`)}}});c.push(p),l.push(o),i.original_records.push(h)}catch(h){FI.warn(h),i.skipped.push(o)}let _=[],u=await Promise.all(c);for(let E=0,f=u.length;E<f;E++)u[E]===!0?i.deleted.push(l[E]):(i.skipped.push(l[E]),_.push(E));let d=0;for(let E=0;E<_.length;E++){let f=_[E];i.original_records.splice(f-d,1),d++}return i.txn_time=gp.getNextMonotonicTime(),i}catch(s){throw s}}a(sQ,"deleteRecords");qI.exports={deleteRecords:sQ}});var jc=g((Hle,$I)=>{"use strict";var ea=z(),iQ=kI(),oQ=We(),{getSchemaPath:aQ}=ze(),cQ=Jc(),lQ=K();$I.exports=uQ;async function uQ(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(ea.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(ea.isEmptyOrZeroLength(e.hash_values)&&!ea.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];ea.isEmpty(l)||e.hash_values.push(l)}}if(ea.isEmptyOrZeroLength(e.hash_values))return VI([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(ea.isEmptyOrZeroLength(e.records)){e.records=[];for(let c=0;c<e.hash_values.length;c++)e.records[c]={[n]:e.hash_values[c]}}let s=aQ(e.schema,e.table),i=await oQ.openEnvironment(s,e.table),o=await iQ.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await cQ(e,o)}catch(c){lQ.error(`unable to write transaction due to ${c.message}`)}return VI(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(uQ,"lmdbDeleteRecords");function VI(e,t,r){let n=e.length+t.length,s=n===1?"record":"records";return{message:`${e.length} of ${n} ${s} successfully deleted`,deleted_hashes:e,skipped_hashes:t,txn_time:r}}a(VI,"createDeleteResponse")});var Op=g((Fle,YI)=>{"use strict";var _Q=P(),Gle=xr();function Ap(e,t){let r=Object.create(null);if(t.length===1&&_Q.SEARCH_WILDCARDS.indexOf(t[0])>=0)Object.assign(r,e);else for(let n=0;n<t.length;n++){let s=t[n],i=e[s];r[s]=i===void 0?null:i}return r}a(Ap,"parseRow");function dQ(e,t,r,n){let s=Ap(r,e);n.push(s)}a(dQ,"searchAll");function fQ(e,t,r,n){let s=Ap(r,e);n[t]=s}a(fQ,"searchAllToMap");function EQ(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(EQ,"iterateDBI");function Zi(e,t,r,n,s){let i=Object.create(null);i[s]=e;let o;n===s?o=e:(o=t,n!==void 0&&(i[n]=o)),r[0].push(o),r[1].push(i)}a(Zi,"pushResults");function hQ(e,t,r,n,s,i){t.toString().endsWith(e)&&Zi(t,r,n,s,i)}a(hQ,"endsWith");function mQ(e,t,r,n,s,i){t.toString().includes(e)&&Zi(t,r,n,s,i)}a(mQ,"contains");function pQ(e,t,r,n,s,i){t>e&&Zi(t,r,n,s,i)}a(pQ,"greaterThanCompare");function SQ(e,t,r,n,s,i){t>=e&&Zi(t,r,n,s,i)}a(SQ,"greaterThanEqualCompare");function TQ(e,t,r,n,s,i){t<e&&Zi(t,r,n,s,i)}a(TQ,"lessThanCompare");function gQ(e,t,r,n,s,i){t<=e&&Zi(t,r,n,s,i)}a(gQ,"lessThanEqualCompare");YI.exports={parseRow:Ap,searchAll:dQ,searchAllToMap:fQ,iterateDBI:EQ,endsWith:hQ,contains:mQ,greaterThanCompare:pQ,greaterThanEqualCompare:SQ,lessThanCompare:TQ,lessThanEqualCompare:gQ,pushResults:Zi}});var ta=g((Yle,jI)=>{"use strict";var li=We(),kle=K(),Yr=xr(),sd=dt(),Et=vr().LMDB_ERRORS_ENUM,Vle=z(),RQ=P(),id=Op(),{parseRow:AQ}=id,$le=require("lmdb"),{OVERFLOW_MARKER:KI,MAX_SEARCH_KEY_LENGTH:OQ}=sd;function WI(e,t,r,n=!1,s=void 0,i=void 0){return eo(e,t,r,(o,c)=>c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}))}a(WI,"iterateFullIndex");function Zc(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,_=!1){return eo(e,t,r,(u,d,E,f)=>{let A={transaction:u,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!l:!_,exclusiveStart:i===!0?_:l};return f===r?(A.values=!1,d.getRange(A).map(b=>({value:b}))):d.getRange(A)})}a(Zc,"iterateRangeBetween");function eo(e,t,r,n){let s=e.database||e,i=li.openDBI(s,r);i[sd.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&li.openDBI(s,t);let o;e.database?o=e:(o=e.useReadTransaction(),o.database=e);let c=n(o,i,s,t);return c.transaction=o,e.database||(c.onDone=()=>{o.done()}),c}a(eo,"setupTransaction");function QI(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(KI)){if(!s)if(r)s=li.openDBI(e,r);else{let l=li.listDBIs(e);for(let _=0,u=l.length;_<u&&(s=li.openDBI(e,l[_]),!s[sd.DBI_DEFINITION_NAME].is_hash_attribute);_++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(QI,"getOverflowCheck");function bQ(e,t,r,n=!1,s=void 0,i=void 0){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);return eo(e,t,t,(o,c,l)=>(od(r),r=el(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(_=>AQ(_.value,r))))}a(bQ,"searchAll");function yQ(e,t,r,n=!1,s=void 0,i=void 0){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);od(r),r=el(e.database||e,r);let o=new Map;for(let{key:c,value:l}of WI(e,t,t,n,s,i))o.set(c,id.parseRow(l,r));return o}a(yQ,"searchAllToMap");function NQ(e,t,r=!1,n=void 0,s=void 0){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=WI(e,void 0,t,r,n,s),c=o.transaction,l=QI(c.database,c,void 0,t);for(let{key:_,value:u}of o){let d=l(_,u);i[d]===void 0&&(i[d]=[]),i[d].push(u)}return i}a(NQ,"iterateDBI");function IQ(e,t){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);return li.statDBI(e,t).entryCount}a(IQ,"countAll");function wQ(e,t,r,n,s=!1,i=void 0,o=void 0){return ui(e,r,n),eo(e,t,r,(c,l,_,u)=>(n=Yr.convertKeyValueToWrite(n),u===r?l.get(n,{transaction:c,lazy:!0})===void 0?[]:[{key:n,value:n}]:l.getValues(n,{transaction:c,reverse:s,limit:i,offset:o}).map(d=>({key:n,value:d}))))}a(wQ,"equals");function CQ(e,t,r){return ui(e,t,r),li.openDBI(e,t).getValuesCount(r)}a(CQ,"count");function DQ(e,t,r,n,s=!1,i=void 0,o=void 0){return ui(e,r,n),eo(e,null,r,(c,l)=>{n=Yr.convertKeyValueToWrite(n);let _=!0;typeof n=="number"&&(_=!1);let u;if(s===!0){let d;for(let E of l.getKeys({transaction:c,start:n}))if(!E.startsWith(n)){d=E;break}return d!==void 0&&(Number.isInteger(o)?o++:i++),u=l.getRange({transaction:c,start:d,end:void 0,reverse:s,limit:i,offset:o}).map(E=>{let{key:f}=E;if(f!==d){if(f.toString().startsWith(n))return E;if(_===!0)return u.DONE}}),u.filter(E=>E)}else return u=l.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(d=>{if(d.key.toString().startsWith(n))return d;if(_===!0)return u.DONE}),_?u:u.filter(d=>d)})}a(DQ,"startsWith");function LQ(e,t,r,n,s=!1,i=void 0,o=void 0){return zI(e,t,r,n,s,i,o,!0)}a(LQ,"endsWith");function zI(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return ui(e,r,n),eo(e,null,r,(l,_,u,d)=>{let E=QI(u,l,d,r);return o=Number.isInteger(o)?o:0,_.getKeys({transaction:l,end:s?!1:void 0,reverse:s}).flatMap(f=>{let h=f.toString();return h.endsWith(KI)?_.getValues(f,{transaction:l}).map(p=>{let S=E(f,p);if(c?S.endsWith(n):S.includes(n))return{key:S,value:p}}).filter(p=>p):(c?h.endsWith(n):h.includes(n))?_[sd.DBI_DEFINITION_NAME].is_hash_attribute?{key:f,value:f}:_.getValues(f,{transaction:l}).map(p=>({key:f,value:p})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a(zI,"contains");function MQ(e,t,r,n,s=!1,i=void 0,o=void 0){ui(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),Zc(e,t,r,n,l,s,i,o,!0,!1)}a(MQ,"greaterThan");function PQ(e,t,r,n,s=!1,i=void 0,o=void 0){ui(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),Zc(e,t,r,n,l,s,i,o,!1,!1)}a(PQ,"greaterThanEqual");function UQ(e,t,r,n,s=!1,i=void 0,o=void 0){ui(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),Zc(e,t,r,l,n,s,i,o,!1,!0)}a(UQ,"lessThan");function vQ(e,t,r,n,s=!1,i=void 0,o=void 0){ui(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),Zc(e,t,r,l,n,s,i,o,!1,!1)}a(vQ,"lessThanEqual");function BQ(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(Yr.validateEnv(e),r===void 0)throw new Error(Et.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(Et.START_VALUE_REQUIRED);if(s===void 0)throw new Error(Et.END_VALUE_REQUIRED);if(n=Yr.convertKeyValueToWrite(n),s=Yr.convertKeyValueToWrite(s),n>s)throw new Error(Et.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return Zc(e,t,r,n,s,i,o,c)}a(BQ,"between");function HQ(e,t,r,n){Yr.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);if(od(r),r=el(s,r),n===void 0)throw new Error(Et.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=id.parseRow(c,r)),o}a(HQ,"searchByHash");function xQ(e,t,r){Yr.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Et.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(xQ,"checkHashExists");function GQ(e,t,r,n,s=[]){return XI(e,t,r,n,s),JI(e,t,r,n,s).map(i=>i[1])}a(GQ,"batchSearchByHash");function FQ(e,t,r,n,s=[]){XI(e,t,r,n,s);let i=new Map;for(let[o,c]of JI(e,t,r,n,s))i.set(o,c);return i}a(FQ,"batchSearchByHashToMap");function JI(e,t,r,n,s=[]){return eo(e,t,t,(i,o,c)=>{r=el(c,r);let l=r.length<3;return n.map(_=>{let u=c.dbis[t].get(_,{transaction:i,lazy:l});if(u)return[_,id.parseRow(u,r)];s.push(_)}).filter(_=>_)})}a(JI,"batchHashSearch");function XI(e,t,r,n,s){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);if(od(r),n==null)throw new Error(Et.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(Et.IDS_MUST_BE_ITERABLE)}a(XI,"initializeBatchSearchByHash");function od(e){if(!Array.isArray(e))throw e===void 0?new Error(Et.FETCH_ATTRIBUTES_REQUIRED):new Error(Et.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(od,"validateFetchAttributes");function ui(e,t,r){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Et.SEARCH_VALUE_REQUIRED);if(r?.length>OQ)throw new Error(Et.SEARCH_VALUE_TOO_LARGE)}a(ui,"validateComparisonFunctions");function el(e,t){return t.length===1&&RQ.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=li.listDBIs(e)),t}a(el,"setGetWholeRowAttributes");jI.exports={searchAll:bQ,searchAllToMap:yQ,count:CQ,countAll:IQ,equals:wQ,startsWith:DQ,endsWith:LQ,contains:zI,searchByHash:HQ,setGetWholeRowAttributes:el,batchSearchByHash:GQ,batchSearchByHashToMap:FQ,checkHashExists:xQ,iterateDBI:NQ,greaterThan:MQ,greaterThanEqual:PQ,lessThan:UQ,lessThanEqual:vQ,between:BQ}});var ra=g((Wle,nw)=>{var ZI=require("lodash"),ew=st(),he=require("joi"),qQ=z(),{hdb_schema_table:tl,checkValidTable:tw,hdb_table:rw,hdb_database:ad}=Xn(),{handleHDBError:kQ,hdb_errors:VQ}=se(),{getDatabases:$Q}=(Ae(),ie(ke)),{HTTP_STATUS_CODES:YQ}=VQ,KQ=he.object({database:ad,schema:ad,table:rw,search_attribute:tl,search_value:he.any().required(),get_attributes:he.array().min(1).items(he.alternatives(tl,he.object())).optional(),desc:he.bool(),limit:he.number().integer().min(1),offset:he.number().integer().min(0)}),WQ=he.object({database:ad,schema:ad,table:rw,operator:he.string().valid("and","or").default("and").lowercase(),offset:he.number().integer().min(0),limit:he.number().integer().min(1),get_attributes:he.array().min(1).items(he.alternatives(tl,he.object())).optional(),sort:he.object({attribute:he.alternatives(tl,he.array().min(1)),descending:he.bool().optional()}).optional(),conditions:he.array().min(1).items(he.alternatives(he.object({operator:he.string().valid("and","or").default("and").lowercase(),conditions:he.array()}),he.object({search_attribute:he.alternatives(tl,he.array().min(1)),search_type:he.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:he.when("search_type",{switch:[{is:"equals",then:he.any()},{is:"between",then:he.array().items(he.alternatives([he.string(),he.number()])).length(2)}],otherwise:he.alternatives(he.string(),he.number())}).required()}))).required()});nw.exports=function(e,t){let r=null;switch(t){case"value":r=ew.validateBySchema(e,KQ);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(tw("database",e.schema)),i(tw("table",e.table)),e.hash_values?Array.isArray(e.hash_values)?e.hash_values.every(o=>typeof o=="string"||typeof o=="number")||i("'hash_values' must be strings or numbers"):i("'hash_values' must be an array"):i("'hash_values' is required"),e.get_attributes?Array.isArray(e.get_attributes)?e.get_attributes.length===0?i("'get_attributes' must contain at least 1 item"):e.get_attributes.every(o=>typeof o=="string"||typeof o=="number")||i("'get_attributes' must be strings or numbers"):i("'get_attributes' must be an array"):i("'get_attributes' is required"),s&&(r=new Error(s.trim()));break;case"conditions":r=ew.validateBySchema(e,WQ);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=qQ.checkGlobalSchemaTable(e.schema,e.table);if(s)return kQ(new Error,s,YQ.NOT_FOUND);let o=$Q()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let l=a(u=>{for(let d=0,E=u.conditions.length;d<E;d++){let f=u.conditions[d];f.conditions?l(f):c.push(f.search_attribute)}},"addConditions");t==="conditions"&&l(e);let _=ZI.filter(c,u=>u!=="*"&&!u.startsWith?.("$")&&u.attribute!=="*"&&!Array.isArray(u)&&!u.name&&!ZI.some(o,d=>d===u||d.attribute===u||d.attribute===u.attribute));if(_&&_.length>0){let u=_.join(", ");return u=u.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${u}'`)}}return r}});var bp=g((zle,sw)=>{"use strict";var QQ=We(),zQ=ra(),{getSchemaPath:JQ}=ze();sw.exports=XQ;function XQ(e){let t=zQ(e,"hashes");if(t)throw t;let r=JQ(e.schema,e.table);return QQ.openEnvironment(r,e.table)}a(XQ,"initialize")});var yp=g((Xle,iw)=>{"use strict";var jQ=ta(),ZQ=bp();iw.exports=ez;async function ez(e){let t=await ZQ(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return jQ.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(ez,"lmdbGetDataByHash")});var na=g((Zle,ow)=>{"use strict";var Np=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};ow.exports=Np});var cw=g((rue,aw)=>{"use strict";var tue=na(),tz=ta(),rz=bp();aw.exports=nz;async function nz(e){let t=await rz(e),r=global.hdb_schema[e.schema][e.table];return tz.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(nz,"lmdbSearchByHash")});var ts=g((sue,lw)=>{"use strict";var Ip=class{static{a(this,"SearchObject")}constructor(t,r,n,s,i,o,c,l=!1,_=void 0,u=void 0){this.schema=t,this.table=r,this.search_attribute=n,this.search_value=s,this.hash_attribute=i,this.get_attributes=o,this.end_value=c,this.reverse=l,this.limit=_,this.offset=u}};lw.exports=Ip});var cd=g((oue,hw)=>{"use strict";var rr=ta(),sz=We(),iz=z(),me=dt(),to=P(),oz=$i(),uw=vr().LMDB_ERRORS_ENUM,{getSchemaPath:az}=ze(),ys=to.SEARCH_WILDCARDS;async function cz(e,t,r){let n;e.schema===to.SYSTEM_SCHEMA_NAME?n=oz[e.table]:n=global.hdb_schema[e.schema][e.table];let s=Ew(e,n.hash_attribute,r,t);return dw(e,s,n.hash_attribute,r)}a(cz,"prepSearch");async function dw(e,t,r,n){let s=az(e.schema,e.table),i=await sz.openEnvironment(s,e.table),o=fw(i,e,t,r),c=o.transaction||i;if([me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,me.SEARCH_TYPES.SEARCH_ALL,me.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(lz(e,r)===!1){let u=e.search_attribute;if(u===r)return n?_w(o,()=>!0):o.map(E=>({[r]:E.key}));let d=a(E=>({[r]:E.value,[u]:E.key}),"toObject");return n?_w(o,d):o.map(d)}let _=e.search_attribute===r?o.map(u=>u.key):o.map(u=>u.value);return n===!0?rr.batchSearchByHashToMap(c,r,e.get_attributes,_):rr.batchSearchByHash(c,r,e.get_attributes,_)}a(dw,"executeSearch");function fw(e,t,r,n){let s,i=n;t.get_attributes.indexOf(n)<0&&(i=void 0);let{reverse:o,limit:c,offset:l}=t;switch(o=typeof o=="boolean"?o:!1,c=Number.isInteger(c)?c:void 0,l=Number.isInteger(l)?l:void 0,r){case me.SEARCH_TYPES.EQUALS:s=rr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.CONTAINS:s=rr.contains(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.ENDS_WITH:case me.SEARCH_TYPES._ENDS_WITH:s=rr.endsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.STARTS_WITH:case me.SEARCH_TYPES._STARTS_WITH:s=rr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return rr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return rr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case me.SEARCH_TYPES.SEARCH_ALL:return rr.searchAll(e,n,t.get_attributes,o,c,l);case me.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return rr.searchAllToMap(e,n,t.get_attributes,o,c,l);case me.SEARCH_TYPES.BETWEEN:s=rr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,l);break;case me.SEARCH_TYPES.GREATER_THAN:case me.SEARCH_TYPES._GREATER_THAN:s=rr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.GREATER_THAN_EQUAL:case me.SEARCH_TYPES._GREATER_THAN_EQUAL:s=rr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.LESS_THAN:case me.SEARCH_TYPES._LESS_THAN:s=rr.lessThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.LESS_THAN_EQUAL:case me.SEARCH_TYPES._LESS_THAN_EQUAL:s=rr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;default:return Object.create(null)}return s}a(fw,"searchByType");function _w(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(_w,"createMapFromIterable");function lz(e,t){if(e.get_attributes.length===1&&e.get_attributes[0]==="*")return!0;let r=[e.search_attribute];e.get_attributes.indexOf(t)>=0&&r.push(t);let n=!1;for(let s=0;s<e.get_attributes.length;s++)if(r.indexOf(e.get_attributes[s])<0){n=!0;break}return n}a(lz,"checkToFetchMore");function Ew(e,t,r,n){if(iz.isEmpty(n)){let s=e.search_value;typeof s=="object"?s=JSON.stringify(s):s=s.toString();let i=s.charAt(0),o=s.charAt(s.length-1),c=!1;if(e.search_attribute===t&&(c=!0),ys.indexOf(s)>-1)return r===!0?me.SEARCH_TYPES.SEARCH_ALL_TO_MAP:me.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(ys[0])<0&&s.indexOf(ys[1])<0)return c===!0?r===!0?me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:me.SEARCH_TYPES.EQUALS;if(ys.indexOf(i)>=0&&ys.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),me.SEARCH_TYPES.CONTAINS;if(ys.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),me.SEARCH_TYPES.ENDS_WITH;if(ys.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),me.SEARCH_TYPES.STARTS_WITH;if(s.includes(ys[0])||s.includes(ys[1]))return me.SEARCH_TYPES.EQUALS;throw new Error(uw.UNKNOWN_SEARCH_TYPE)}else switch(n){case to.VALUE_SEARCH_COMPARATORS.BETWEEN:return me.SEARCH_TYPES.BETWEEN;case to.VALUE_SEARCH_COMPARATORS.GREATER:return me.SEARCH_TYPES.GREATER_THAN;case to.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return me.SEARCH_TYPES.GREATER_THAN_EQUAL;case to.VALUE_SEARCH_COMPARATORS.LESS:return me.SEARCH_TYPES.LESS_THAN;case to.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return me.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(uw.UNKNOWN_SEARCH_TYPE)}}a(Ew,"createSearchTypeFromSearchObject");hw.exports={executeSearch:dw,createSearchTypeFromSearchObject:Ew,prepSearch:cz,searchByType:fw}});var pw=g((lue,mw)=>{"use strict";var cue=ts(),uz=ra(),_z=z(),dz=P(),fz=cd();mw.exports=Ez;function Ez(e,t){if(!_z.isEmpty(t)&&dz.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=uz(e,"value");if(n)throw n;return fz.prepSearch(e,t,!0)}a(Ez,"lmdbGetDataByValue")});var rl=g((due,Sw)=>{"use strict";var _ue=ts(),hz=ra(),mz=z(),pz=P(),Sz=cd();Sw.exports=Tz;async function Tz(e,t){if(!mz.isEmpty(t)&&pz.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=hz(e,"value");if(n)throw n;return Sz.prepSearch(e,t,!1)}a(Tz,"lmdbSearchByValue")});var gw=g((hue,Tw)=>{"use strict";var Eue=dt(),wp=class{static{a(this,"SearchByConditionsObject")}constructor(t,r,n,s,i=void 0,o=void 0,c="and"){this.schema=t,this.table=r,this.get_attributes=n,this.limit=i,this.offset=o,this.conditions=s,this.operator=c}},Cp=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},Dp=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};Tw.exports={SearchByConditionsObject:wp,SearchCondition:Cp,SortAttribute:Dp}});var yw=g((Tue,bw)=>{"use strict";var pue=gw().SearchByConditionsObject,gz=ts(),Rz=ra(),Lp=ta(),ld=dt(),{Resource:Sue}=(an(),ie(Mp)),Ow=cd(),Az=Op(),Oz=require("lodash"),{getSchemaPath:bz}=ze(),Rw=We(),{handleHDBError:yz,hdb_errors:Nz}=se(),{HTTP_STATUS_CODES:Iz}=Nz,wz=1e8;bw.exports=Cz;async function Cz(e){let t=Rz(e,"conditions");if(t)throw yz(t,t.message,Iz.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=bz(e.schema,e.table),n=await Rw.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let _ of e.conditions)Rw.openDBI(n,_.search_attribute);let i=Oz.sortBy(e.conditions,_=>{if(_.estimated_count===void 0){let u=_.search_type;u===ld.SEARCH_TYPES.EQUALS?_.estimated_count=Lp.count(n,_.search_attribute,_.search_value):u===ld.SEARCH_TYPES.CONTAINS||u===ld.SEARCH_TYPES.ENDS_WITH?_.estimated_count=1/0:_.estimated_count=wz}return _.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await Aw(o,e,i[0],s.hash_attribute),l;if(!e.operator||e.operator.toLowerCase()==="and"){let _=n.dbis[s.hash_attribute],u=i.slice(1).map(Ow.filterByType),d=u.length,E=Lp.setGetWholeRowAttributes(n,e.get_attributes);l=c.map(f=>_.get(f,{transaction:o,lazy:!0})),d>0&&(l=l.filter(f=>{for(let h=0;h<d;h++)if(!u[h](f))return!1;return!0})),(e.offset||e.limit!==void 0)&&(l=l.slice(e.offset,e.limit!==void 0?(e.offset||0)+e.limit:void 0)),l=l.map(f=>Az.parseRow(f,E))}else{for(let d=1;d<i.length;d++){let E=i[d],f=await Aw(o,e,E,s.hash_attribute);c=c.concat(f)}let _=new Set,u=e.offset||0;c=c.filter(d=>_.has(d)?!1:(_.add(d),!0)).slice(u,e.limit&&e.limit+u),l=Lp.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(Cz,"lmdbSearchByConditions");async function Aw(e,t,r,n){let s=new gz(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===ld.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,Ow.searchByType(e,s,i,n).map(o=>o.value)}a(Aw,"executeConditionSearch")});var nl=g((Rue,Nw)=>{"use strict";var Dz=P().OPERATIONS_ENUM,Pp=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=Dz.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};Nw.exports=Pp});var Up=g((Oue,Uw)=>{"use strict";var Dw=ts(),Lw=nl(),Mw=rl(),Pw=jc(),hr=P(),Iw=z(),ww=We(),{getTransactionAuditStorePath:Lz,getSchemaPath:Mz}=ze(),Cw=K();Uw.exports=Pz;async function Pz(e){try{if(Iw.isEmpty(global.hdb_schema[e.schema])||Iw.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await Uz(e),await vz(e);let t=Mz(e.schema,e.table);try{await ww.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")Cw.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=Lz(e.schema,e.table);await ww.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")Cw.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(Pz,"lmdbDropTable");async function Uz(e){let t=new Dw(hr.SYSTEM_SCHEMA_NAME,hr.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,hr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[hr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await Mw(t)),n=[];for(let i=0;i<r.length;i++){let o=r[i];n.push(o.id)}if(n.length===0)return;let s=new Lw(hr.SYSTEM_SCHEMA_NAME,hr.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await Pw(s)}a(Uz,"deleteAttributesFromSystem");async function vz(e){let t=new Dw(hr.SYSTEM_SCHEMA_NAME,hr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,hr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[hr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,hr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,hr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await Mw(t))}catch(i){throw i}for(let i=0;i<r.length;i++){let o=r[i];o.name===e.table&&o.schema===e.schema&&(n=o)}if(!n)throw new Error(`${e.schema}.${e.table} was not found`);let s=new Lw(hr.SYSTEM_SCHEMA_NAME,hr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await Pw(s)}catch(i){throw i}}a(vz,"dropTableFromSystem")});var Bw=g((yue,vw)=>{"use strict";var Bz=require("fs-extra"),Hz=ts(),xz=na(),Gz=nl(),Fz=Up(),qz=jc(),kz=yp(),Vz=rl(),Ns=P(),{getSchemaPath:$z}=ze(),{handleHDBError:Yz,hdb_errors:Kz}=se(),{HDB_ERROR_MSGS:Wz,HTTP_STATUS_CODES:Qz}=Kz;vw.exports=zz;async function zz(e){let t;try{t=await Jz(e.schema);let r=new Hz(Ns.SYSTEM_SCHEMA_NAME,Ns.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Ns.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[Ns.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await Vz(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await Fz(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new Gz(Ns.SYSTEM_SCHEMA_NAME,Ns.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await qz(s);let i=$z(t);await Bz.remove(i)}catch(r){throw r}}a(zz,"lmdbDropSchema");async function Jz(e){let t=new xz(Ns.SYSTEM_SCHEMA_NAME,Ns.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[Ns.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await kz(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw Yz(new Error,Wz.SCHEMA_NOT_FOUND(e),Qz.NOT_FOUND,void 0,void 0,!0);return n}a(Jz,"validateDropSchema")});var Bp=g((Iue,Hw)=>{"use strict";var vp=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};Hw.exports=vp});var Gw=g((Due,xw)=>{"use strict";var Xz=require("fs-extra"),ud=We(),{getTransactionAuditStorePath:jz}=ze(),Hp=dt(),Cue=Bp();xw.exports=Zz;async function Zz(e){let t;try{let r=jz(e.schema,e.table);await Xz.mkdirp(r),t=await ud.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{ud.createDBI(t,Hp.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),ud.createDBI(t,Hp.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),ud.createDBI(t,Hp.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(Zz,"createTransactionsAuditEnvironment")});var Vw=g((Mue,kw)=>{"use strict";var xp=P(),Fw=We(),e2=$o(),{getSystemSchemaPath:t2,getSchemaPath:r2}=ze(),n2=$i(),s2=F_(),Gp=G_(),i2=K(),o2=Gw(),qp=n2.hdb_table,qw=[];for(let e=0;e<qp.attributes.length;e++)qw.push(qp.attributes[e].attribute);kw.exports=a2;async function a2(e,t){let r=r2(t.schema,t.table),n=new Gp(t.schema,t.table,xp.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new Gp(t.schema,t.table,xp.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new Gp(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await Fw.createEnvironment(r,t.table),e!==void 0){let o=await Fw.openEnvironment(t2(),xp.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await e2.insertRecords(o,qp.hash_attribute,qw,[e]),n.skip_table_check=!0,s.skip_table_check=!0,i.skip_table_check=!0,await Fp(n),await Fp(s),await Fp(i)}await o2(t)}catch(o){throw o}}a(a2,"lmdbCreateTable");async function Fp(e){try{await s2(e)}catch(t){i2.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(Fp,"createAttribute")});var Yw=g((Uue,$w)=>{"use strict";var c2=$c(),l2=wc(),u2=rd(),sl=P(),_2=$o().updateRecords,d2=We(),{getSchemaPath:f2}=ze(),E2=Jc(),h2=K();$w.exports=m2;async function m2(e){try{let{schema_table:t,attributes:r}=c2(e);l2(e,r,t.hash_attribute),e.schema!==sl.SYSTEM_SCHEMA_NAME&&(r.includes(sl.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(sl.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(sl.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(sl.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await u2(e.hdb_auth_header,t,r),s=f2(e.schema,e.table),i=await d2.openEnvironment(s,e.table),o=await _2(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await E2(e,o)}catch(c){h2.error(`unable to write transaction due to ${c.message}`)}return{written_hashes:o.written_hashes,skipped_hashes:o.skipped_hashes,schema_table:t,new_attributes:n,txn_time:o.txn_time}}catch(t){throw t}}a(m2,"lmdbUpdateRecords")});var Ww=g((Bue,Kw)=>{"use strict";var p2=P().OPERATIONS_ENUM,kp=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=p2.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};Kw.exports=kp});var zw=g((Gue,Qw)=>{"use strict";var xue=Ww(),S2=$c(),T2=wc(),g2=rd(),il=P(),R2=$o().upsertRecords,A2=We(),{getSchemaPath:O2}=ze(),b2=Jc(),y2=K(),{handleHDBError:N2,hdb_errors:I2}=se();Qw.exports=w2;async function w2(e){let t;try{t=S2(e)}catch(l){throw N2(l,l.message,I2.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;T2(e,n,r.hash_attribute),e.schema!==il.SYSTEM_SCHEMA_NAME&&(n.includes(il.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(il.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(il.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(il.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await g2(e.hdb_auth_header,r,n),i=O2(e.schema,e.table),o=await A2.openEnvironment(i,e.table),c=await R2(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await b2(e,c)}catch(l){y2.error(`unable to write transaction due to ${l.message}`)}return{written_hashes:c.written_hashes,schema_table:r,new_attributes:s,txn_time:c.txn_time}}a(w2,"lmdbUpsertRecords")});var Xw=g((que,Jw)=>{"use strict";var Vp=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};Jw.exports=Vp});var Zw=g((Vue,jw)=>{"use strict";var $p=class{static{a(this,"DeleteAuditLogsBeforeResults")}constructor(t=void 0,r=void 0,n=0){this.start_timestamp=t,this.end_timestamp=r,this.transactions_deleted=n}};jw.exports=$p});var rC=g((Kue,tC)=>{"use strict";var Yp=We(),{getTransactionAuditStorePath:C2}=ze(),Yue=Xw(),ol=dt(),D2=z(),eC=Zw(),L2=require("util").promisify,M2=L2(setTimeout),P2=1e4,U2=100;tC.exports=v2;async function v2(e){let t=C2(e.schema,e.table),r=await Yp.openEnvironment(t,e.table,!0),n=Yp.listDBIs(r);Yp.initializeDBIs(r,ol.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new eC;do s=await B2(r,e.timestamp),i.start_timestamp===void 0&&(i.start_timestamp=s.start_timestamp),s.end_timestamp!==void 0&&(i.end_timestamp=s.end_timestamp),i.transactions_deleted+=s.transactions_deleted,await M2(U2);while(s.transactions_deleted>0);return i}a(v2,"deleteAuditLogsBefore");async function B2(e,t){let r=new eC;try{let n=e.dbis[ol.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],s;for(let{key:i,value:o}of n.getRange({start:!1})){if(i>=t)break;r.start_timestamp===void 0&&(r.start_timestamp=i),s=n.remove(i);let c=o[ol.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];D2.isEmpty(c)||(s=e.dbis[ol.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[ol.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>P2)break}return await s,r}catch(n){throw n}}a(B2,"deleteTransactions")});var sC=g((Que,nC)=>{"use strict";var Kp=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};nC.exports=Kp});var oC=g((Xue,iC)=>{"use strict";var H2=ts(),x2=nl(),Jue=sC(),rs=P(),G2=z(),Wp=We(),F2=$i(),q2=rl(),k2=jc(),{getSchemaPath:V2}=ze();iC.exports=$2;async function $2(e,t=!0){let r;e.schema===rs.SYSTEM_SCHEMA_NAME?r=F2[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await K2(e),s=V2(e.schema,e.table),i=await Wp.openEnvironment(s,e.table);return t===!0&&await Y2(e,i,r.hash_attribute),Wp.dropDBI(i,e.attribute),n}a($2,"lmdbDropAttribute");async function Y2(e,t,r){let n=Wp.openDBI(t,r),s,i=e.attribute;for(let{key:o,value:c,version:l}of n.getRange({start:!1,versions:!0})){let _={};for(let u in c)u!==i&&(_[u]=c[u]);s=t.dbis[r].put(o,_,l)}await s}a(Y2,"removeAttributeFromAllObjects");async function K2(e){let t=new H2(rs.SYSTEM_SCHEMA_NAME,rs.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,rs.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[rs.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,rs.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await q2(t)).filter(o=>o[rs.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(G2.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[rs.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new x2(rs.SYSTEM_SCHEMA_NAME,rs.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return k2(i)}a(K2,"dropAttributeFromSystem")});var dC=g((e_e,_C)=>{"use strict";var Qp=We(),sa=dt(),Zue=xr(),zp=P(),aC=z(),{getTransactionAuditStorePath:W2}=ze(),Q2=ta(),_d=jo(),z2=K();_C.exports=J2;async function J2(e){let t=W2(e.schema,e.table),r=await Qp.openEnvironment(t,e.table,!0),n=Qp.listDBIs(r);Qp.initializeDBIs(r,sa.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case zp.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return cC(r,e.search_values);case zp.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,j2(r,e.search_values,s);case zp.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return X2(r,e.search_values);default:return cC(r)}}a(J2,"readAuditLog");function cC(e,t=[0,Date.now()]){aC.isEmpty(t[0])&&(t[0]=0),aC.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[sa.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],n;for(let s of r.getKeys({start:t[1]}))if(s!==t[1]){n=s;break}return r.getRange({start:t[0],end:n}).map(({value:s})=>Object.assign(new _d,s))}a(cC,"searchTransactionsByTimestamp");function X2(e,t=[]){let r=new Map;for(let n=0;n<t.length;n++){let s=t[n],i=[];for(let o of e.dbis[sa.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,uC(e,i))}return Object.fromEntries(r)}a(X2,"searchTransactionsByUsername");function j2(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let _=t[c],u=Q2.equals(e,sa.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,sa.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,_);for(let{value:d}of u){let E=Number(d);n.has(E)?n.get(E).push(_.toString()):n.set(E,[_.toString()])}}let s=Array.from(n.keys()),i=uC(e,s),o=new Map;for(let c=0;c<i.length;c++){let l=i[c],_=l.timestamp,u=n.get(_);lC(l,"records",r,u,o),lC(l,"original_records",r,u,o)}return Object.fromEntries(o)}a(j2,"searchTransactionsByHashValues");function lC(e,t,r,n,s){let i=e.timestamp;if(e[t])for(let o=0;o<e[t].length;o++){let c=e[t][o],l=c[r].toString();if(n.indexOf(l)>=0)if(s.has(l)){let _=s.get(l),u=_[_.length-1];if(u.timestamp===i)u[t]=[c];else{let d=new _d(e.operation,e.user_name,i,void 0);d[t]=[c],_.push(d)}}else{let _=new _d(e.operation,e.user_name,i,void 0);_[t]=[c],s.set(l,[_])}}}a(lC,"loopRecords");function uC(e,t){let r=[];try{let n=e.dbis[sa.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP];for(let s=0;s<t.length;s++)try{let i=n.get(t[s]);if(i){let o=Object.assign(new _d,i);r.push(o)}}catch(i){z2.warn(i)}return r}catch(n){throw n}}a(uC,"batchSearchTransactions")});var EC=g((s_e,fC)=>{"use strict";var{getSchemaPath:r_e}=ze(),n_e=We(),{database:Z2}=(Ae(),ie(ke));fC.exports={writeTransaction:eJ};async function eJ(e,t,r){return Z2({database:e,table:t}).transaction(r)}a(eJ,"writeTransaction")});var SC=g((o_e,pC)=>{"use strict";var{getSchemaPath:hC}=ze(),mC=We();pC.exports={flush:tJ,resetReadTxn:rJ};async function tJ(e,t){return(await mC.openEnvironment(hC(e,t),t.toString())).flushed}a(tJ,"flush");async function rJ(e,t){try{(await mC.openEnvironment(hC(e,t),t.toString())).resetReadTxn()}catch{}}a(rJ,"resetReadTxn")});var AC=g((c_e,RC)=>{"use strict";var{Readable:nJ}=require("stream"),{getDatabases:sJ}=(Ae(),ie(ke)),{readSync:iJ,openSync:oJ,createReadStream:TC}=require("fs"),{open:aJ}=require("lmdb"),gC=Hc(),cJ=xc(),{AUDIT_STORE_OPTIONS:lJ}=(ti(),ie(OC)),{INTERNAL_DBIS_NAME:uJ,AUDIT_STORE_NAME:_J}=dt();RC.exports=fJ;var Jp=32768,dJ=100;async function fJ(e){let t=e.database||e.schema||"data",r=sJ()[t],n=new Date().toISOString(),s=e.tables||e.table&&[e.table];if(s){let _=r[s[0]];if(!_)throw new Error(`Can not find table ${s[0]}`);let u=_.dbisDB,d=aJ({noSync:!0,maxDbs:cJ.MAX_DBS}),E,f=d.openDB(uJ,new gC(!1)),h=u.useReadTransaction(),p=0,S=a(async function(A,b){b.encoding="binary",b.encoder=void 0;let I=d.openDB(A,b),B=u.openDB(A,b);for(let{key:U,version:q,value:M}of B.getRange({start:null,transaction:h,versions:B.useVersions}))E=I.put(U,M,q),p++%dJ===0&&(await new Promise(Q=>setTimeout(Q,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:A,value:b}of u.getRange({transaction:h,start:!1}))if(s.some(I=>A.startsWith?.(I+"/"))){f.put(A,b);let[,I]=A.split("/"),B=!I,U=new gC(!B,B);await S(A,U)}e.include_audit&&await S(_J,Object.assign({},lJ)),await E;let T=TC(d.path);return T.headers=l(),T.on("close",()=>{h.done(),d.close()}),T}let o=r[Object.keys(r)[0]].primaryStore,c=oJ(o.path);return o.transaction(()=>{let _=Buffer.alloc(Jp);iJ(c,_,0,Jp),o.resetReadTxn();let u=o.useReadTransaction();u.renew();let d=TC(null,{fd:c,start:Jp}),E=new nJ.from(async function*(){yield _;for await(let f of d)u.openTimer&&(u.openTimer=0),yield f;u.done()}());return E.headers=l(),E});function l(){let _=new Map;return _.set("content-type","application/octet-stream"),_.set("content-disposition",`attachment; filename="${t}"`),_.set("date",n),_}}a(fJ,"getBackup")});var NC=g((u_e,yC)=>{"use strict";var EJ=K(),{handleHDBError:hJ}=se(),mJ=iy(),pJ=F_(),SJ=Sp(),TJ=BI(),gJ=jc(),RJ=yp(),AJ=cw(),OJ=pw(),bJ=rl(),yJ=yw(),NJ=Bw(),IJ=Vw(),wJ=Yw(),CJ=zw(),DJ=rC(),LJ=Up(),MJ=oC(),PJ=dC(),UJ=EC(),bC=SC(),vJ=AC(),Xp=class extends mJ{static{a(this,"LMDBBridge")}async searchByConditions(t){return yJ(t)}async getDataByHash(t){return await RJ(t)}async searchByHash(t){return await AJ(t)}async getDataByValue(t,r){return await OJ(t,r)}async searchByValue(t){return await bJ(t)}async createSchema(t){return await TJ(t)}async dropSchema(t){return await NJ(t)}async createTable(t,r){return await IJ(t,r)}async dropTable(t){return await LJ(t)}async createAttribute(t){return await pJ(t)}async createRecords(t){return await SJ(t)}async updateRecords(t){return await wJ(t)}async upsertRecords(t){try{return await CJ(t)}catch(r){throw hJ(r,null,null,EJ.ERR,r)}}async deleteRecords(t){return await gJ(t)}async dropAttribute(t){return await MJ(t)}async deleteAuditLogsBefore(t){return await DJ(t)}async readAuditLog(t){return await PJ(t)}writeTransaction(t,r,n){return UJ.writeTransaction(t,r,n)}flush(t,r){return bC.flush(t,r)}resetReadTxn(t,r){return bC.resetReadTxn(t,r)}getBackup(t){return vJ(t)}};yC.exports=Xp});function GJ(){xJ=setInterval(function(){for(let e of jp)if(e.stale){let t=e[ye]?.url;DC.error(`Transaction was open too long and has been aborted, from table: ${e.lmdbDb?.name+(t?" path: "+t:"")}`),e.abort()}else e.stale=!0},HJ).unref()}var Zp,CC,DC,LC,MC,PC,IC,jp,BJ,al,wC,ro,dd,HJ,xJ,eS=Re(()=>{Zp=x(xr()),CC=x(se()),DC=x(K());an();LC=x(ne()),MC=x(P()),PC=x(z()),IC=100,jp=new Set,BJ=(0,PC.convertToMS)(LC.get(MC.CONFIG_PARAMS.STORAGE_MAXTRANSACTIONQUEUETIME))||45e3,ro=class e{static{a(this,"DatabaseTransaction")}writes=[];lmdbDb;readTxn;readTxnRefCount;readTxnsUsed;validated=0;timestamp=0;overloadChecked;open=1;getReadTxn(){if(this.readTxnRefCount=(this.readTxnRefCount||0)+1,this.stale&&(this.stale=!1),this.readTxn)return this.readTxn.openTimer&&(this.readTxn.openTimer=0),this.readTxn;if(this.open===1)return this.readTxn=this.lmdbDb.useReadTransaction(),this.readTxnsUsed=1,this.readTxn.openTimer&&(this.readTxn.openTimer=0),jp.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(jp.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(al&&!this.overloadChecked&&performance.now()-wC>BJ)throw new CC.ServerError("Outstanding write transactions have too long of queue, please try again later",503);this.overloadChecked=!0}addWrite(t){if(this.open===0)throw new Error("Can not use a transaction that is no longer open");if(this.open===2){let r=new e;return r.addWrite(t),r.commit({})}else this.writes.push(t)}removeWrite(t){let r=this.writes.indexOf(t);r>-1&&(this.writes[r]=null)}commit(t={}){let r=this.timestamp;r||(r=this.timestamp=t.timestamp||(0,Zp.getNextMonotonicTime)()),t.timestamp||(t.timestamp=r);let n=t.retries||0;if(this.validated<this.writes.length)try{let d=this.validated;this.validated=this.writes.length;for(let f=d;f<this.validated;f++)this.writes[f]?.validate?.(this.timestamp);let E;for(let f=d;f<this.validated;f++){let h=this.writes[f];h&&(h.before||h.beforeIntermediate)&&(E=!0)}if(E)return(async()=>{try{for(let f=0;f<2;f++){let h;for(let p=d;p<this.validated;p++){let S=this.writes[p];if(!S)continue;let T=S[f===0?"before":"beforeIntermediate"];if(T){let A=T();h?h.push?h.push(A):h=[h,A]:h=A}}h&&await(h.push?Promise.all(h):h)}}catch(f){throw this.abort(),f}return this.commit(t)})()}catch(d){throw this.abort(),d}n||this.doneReadTxn(),this.open=t?.letItLinger?2:0;let s,i=[],o=0;this.writes=this.writes.filter(d=>d);let c=a(d=>{d.commit(r,d.entry,n)},"doWrite"),l=a(()=>{let d=this.writes[o++];if(d)if(d.key){n>0&&(d.entry=d.store.getEntry(d.key));let E=d.store.ifVersion(d.key,d.entry?.version??null,l);s=s||E}else l();else for(let E of this.writes)c(E)},"nextCondition"),_=this.lmdbDb;if(this.writes.length>0&&(_?.retryRisk&&(_.retryRisk*=.99),this.writes.length+(_?.retryRisk||0)<IC>>n?l():s=this.writes[0].store.transaction(()=>{for(let d of this.writes)d.entry=d.store.getEntry(d.key),c(d);return!0})),s)return al||(al=s,wC=performance.now(),al.then(()=>{al=null})),s.then(d=>d?(this.next&&i.push(this.next.commit(t)),t?.flush&&i.push(this.writes[0].store.flushed),this.writes=[],this.next=null,Promise.all(i).then(()=>({txnTime:r}))):(_&&(_.retryRisk=(_.retryRisk||0)+IC/2),t?t.retries=n+1:t={retries:1},this.commit(t)));let u={txnTime:r};if(this.next){let d=this.next?.commit(t);if(d?.then)return d?.then(E=>({txnTime:r,next:E}));u.next=d}return u}abort(){for(;this.readTxnsUsed>0;)this.doneReadTxn();this.open=0,this.writes=[]}},dd=class extends ro{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,Zp.getNextMonotonicTime)())}getReadTxn(){}},HJ=3e4;a(GJ,"startMonitoringTxns");GJ()});function Ze(e,t,r){if(!t)t=e,e={};else if(!e)e={};else if(e?.transaction?.open===1&&typeof t=="function")return t(e.transaction);if(typeof t!="function")throw new Error("Callback function must be provided to transaction");let n=e.transaction=new ro;e.timestamp&&(n.timestamp=e.timestamp),n[ye]=e,e.resourceCache||(e.resourceCache=[]);let s;try{if(s=t(n),s?.then)return s.then(i,o)}catch(c){o(c)}return i(s);function i(c){let l=n.commit({letItLinger:r?.letItLinger});return l.then?l.then(()=>c):c}function o(c){throw n.abort({}),c}}var UC,no=Re(()=>{UC=require("../../index");an();eS();a(Ze,"transaction");(0,UC._assignPackageExport)("transaction",Ze);Ze.commit=function(e){let t=(e[ye]||e)?.transaction;if(!t)throw new Error("No active transaction is available to commit");return t.commit()};Ze.abort=function(e){let t=(e[ye]||e)?.transaction;if(!t)throw new Error("No active transaction is available to abort");return t.abort()}});var kC={};qe(kC,{ResourceBridge:()=>nS});function sS({get_attributes:e},t){if(e){if(e[0]==="*"){if(t.schemaDefined)return;e=t.attributes.map(r=>r.name)}return e.forceNulls=!0,e}}function BC(e,t){let r=ns(e),n=sS(e,r);if(!r)throw new Pn.ClientError(`Table ${e.table} not found`);let s;n&&r.attributes.length-n.length>2&&n.length<5&&(s=!0);let i={user:e.hdb_user,onlyIfCached:e.onlyIfCached,noCacheStore:e.noCacheStore,noCache:e.noCache},o;Ze(i,()=>new Promise(_=>o=_));let c=e.ids||e.hash_values,l=0;return{[Symbol.asyncIterator](){return{async next(){if(l<c.length){let _=c[l++],u;try{u=await r.get({id:_,lazy:s,select:n},i),u=u&&Ed(u)}catch(d){u={message:d.toString()}}return t?{value:{key:_,value:u}}:{value:u}}else return o(),{done:!0}},return(_){return o(),{value:_,done:!0}},throw(_){return o(),{done:!0}}}}}}function ns(e){let t=e.database||e.schema||qJ,r=mr()[t];if(!r)throw(0,Pn.handleHDBError)(new Error,FJ.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function HC(e,t,r){let n=e.length+t.length,s=n===1?"record":"records";return{message:`${e.length} of ${n} ${s} successfully deleted`,deleted_hashes:e,skipped_hashes:t,txn_time:r}}async function*xC(e,t,r){let n;for await(let s of e.getHistory(t,r)){let i=s.type;i==="put"&&(i="upsert");let{id:o,version:c,value:l}=s;n?.timestamp===c?(n.hash_values.push(o),n.records.push(l)):(n&&(yield n),n={operation:i,user_name:s.user,timestamp:c,hash_values:[o],records:[l]})}n&&(yield n)}var GC,fd,Pn,FC,Un,tS,rS,qC,FJ,qJ,kJ,VJ,vC,nS,VC=Re(()=>{"use strict";GC=x(NC()),fd=x(ra()),Pn=x(se());Ae();FC=x($c()),Un=x(P()),tS=x(bs()),rS=x(Mn()),qC=x(z());no();hd();({HDB_ERROR_MSGS:FJ}=Pn.hdb_errors),qJ="data",kJ=1e4,VJ=10,nS=class extends GC.default{static{a(this,"ResourceBridge")}constructor(t){super(t),vC=this}async searchByConditions(t){t.select!==void 0&&(t.get_attributes=t.select);for(let o of t.conditions||[])o?.attribute!==void 0&&(o.search_attribute=o.attribute),o?.comparator!==void 0&&(o.search_type=o.comparator),o?.value!==void 0&&(o.search_value=o.value);let r=(0,fd.default)(t,"conditions");if(r)throw(0,Pn.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=ns(t);if(!n)throw new Pn.ClientError(`Table ${t.table} not found`);let s=t.conditions.map(i);function i(o){return o.conditions?(o.conditions=o.conditions.map(i),o):{attribute:o.search_attribute??o.attribute,comparator:o.search_type??o.comparator,value:o.search_value!==void 0?o.search_value:o.value}}return a(i,"mapCondition"),n.search({conditions:s,operator:t.operator?t.operator.toLowerCase():void 0,limit:t.limit,offset:t.offset,reverse:t.reverse,select:sS(t,n),sort:t.sort,allowFullScan:!0},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache})}async createTable(t,r){let n=r.attributes,s=!!n,i=r.primary_key||r.hash_attribute;if(n)for(let o of n)o.is_primary_key?(o.isPrimaryKey=!0,delete o.is_primary_key):o.name===i&&i&&(o.isPrimaryKey=!0);else{if(!i)throw new Pn.ClientError("A primary key must be specified with a `primary_key` property or with `attributes`");n=[{name:i,isPrimaryKey:!0},{name:"__createdtime__",indexed:!0},{name:"__updatedtime__",indexed:!0}]}ft({database:r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration})}async createAttribute(t){return await ns(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=ns(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=a((o,c,l)=>(c=Object.assign({},c),delete c[n],r.primaryStore.ifVersion(o,l,()=>r.primaryStore.put(o,c,l)).then(_=>{if(!_){let{value:u,version:d}=r.primaryStore.getEntry(o);return i(o,u,d)}})),"deleteRecord");for(let{key:o,value:c,version:l}of r.primaryStore.getRange({start:!0,versions:!0}))s=i(o,c,l),await new Promise(_=>setImmediate(_));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){ns(t).dropTable()}createSchema(t){return ia({database:t.schema,table:null}),tS.signalSchemaChange(new rS.SchemaEventMsg(process.pid,Un.OPERATIONS_ENUM.CREATE_SCHEMA,t.schema))}async dropSchema(t){await iS(t.schema),tS.signalSchemaChange(new rS.SchemaEventMsg(process.pid,Un.OPERATIONS_ENUM.DROP_SCHEMA,t.schema))}async updateRecords(t){return t.requires_existing=!0,this.upsertRecords(t)}async createRecords(t){return t.requires_no_existing=!0,vC.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,FC.default)(t),s,i=mr()[t.schema][t.table],o={user:t.hdb_user,expiresAt:t.expiresAt};return Ze(o,async c=>{if(!i.schemaDefined){s=[];for(let u of n)i.attributes.find(E=>E.name==u)||s.push(u);s.length>0&&await i.addAttributes(s.map(u=>({name:u,indexed:!0})))}let l=[],_=[];for(let u of t.records){let d=u[i.primaryKey],E=d!=null&&await i.get(d,o);if(t.requires_existing&&!E||t.requires_no_existing&&E){_.push(u[i.primaryKey]);continue}E&&(E=Ed(E));for(let f in u)if(Object.prototype.hasOwnProperty.call(u,f)){let h=u[f];if(typeof h=="function")try{let p=h([[E]]);Array.isArray(p)&&(h=p[0].func_val,u[f]=h)}catch(p){throw p.message+="Trying to set key "+f+" on object"+JSON.stringify(u),p}}if(E)for(let f in E)Object.prototype.hasOwnProperty.call(u,f)||(u[f]=E[f]);await(d==null?i.create(u,o):i.put(u,o)),l.push(u[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:l,new_attributes:s,skipped_hashes:_}})}async deleteRecords(t){let r=mr()[t.schema][t.table],n={user:t.hdb_user};return Ze(n,async s=>{let i=t.hash_values||t.records.map(l=>l[r.primaryKey]),o=[],c=[];for(let l of i)await r.delete(l,n)?o.push(l):c.push(l);return HC(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=mr()[t.schema][t.table];if(!r.createdTimeProperty)throw new Pn.ClientError("Table must have a '__createdtime__' attribute or @createdTime timestamp defined to perform this operation");let n=await r.search({conditions:[{attribute:r.createdTimeProperty.name,value:Date.parse(t.date),comparator:Un.VALUE_SEARCH_COMPARATORS.LESS}]}),s=!1,i=[],o=[],c=0,l=[],_=a(async()=>{let u=await this.deleteRecords({schema:t.schema,table:t.table,hash_values:l});i.push(...u.deleted_hashes),o.push(...u.skipped_hashes),await(0,qC.async_set_timeout)(VJ),l=[],s=!0},"chunkDelete");for await(let u of n)l.push(u[r.primaryKey]),c++,c%kJ===0&&await _();return l.length>0&&await _(),s?HC(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,fd.default)(t,"hashes");if(r)throw r;return BC(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of BC(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&Un.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r]===void 0)throw new Error(`Value search comparator - ${r} - is not valid`);t.select!==void 0&&(t.get_attributes=t.select),t.attribute!==void 0&&(t.search_attribute=condition.attribute),t.value!==void 0&&(t.search_value=condition.value);let n=(0,fd.default)(t,"value");if(n)throw n;let s=ns(t);if(!s)throw new Pn.ClientError(`Table ${t.table} not found`);let i=t.search_value;i.includes?.("*")&&(i.startsWith("*")?i.endsWith("*")?i!=="*"&&(r="contains",i=i.slice(1,-1)):(r="ends_with",i=i.slice(1)):i.endsWith("*")&&(r="starts_with",i=i.slice(0,-1))),r===Un.VALUE_SEARCH_COMPARATORS.BETWEEN&&(i=[i,t.end_value]);let o=i==="*"?[]:[{attribute:t.search_attribute,value:i,comparator:r}];return s.search({conditions:o,allowFullScan:!0,limit:t.limit,offset:t.offset,reverse:t.reverse,sort:t.sort,select:sS(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache})}async getDataByValue(t,r){let n=new Map,s=ns(t);t.get_attributes&&!t.get_attributes.includes(s.primaryKey)&&t.get_attributes[0]!=="*"&&t.get_attributes.push(s.primaryKey);for await(let i of this.searchByValue(t,r))n.set(i[s.primaryKey],i);return n}resetReadTxn(t,r){ns({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return ns(t).deleteHistory(t.timestamp)}async readAuditLog(t){let r=ns(t),n={};switch(t.search_type){case Un.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:for(let i of t.search_values)n[i]=(await r.getHistoryOfRecord(i)).map(o=>{let c=o.type;return c==="put"&&(c="upsert"),{operation:c,timestamp:o.version,user_name:o.user,hash_values:[i],records:[o.value]}});return n;case Un.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:let s=t.search_values;for await(let i of xC(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return xC(r,t.search_values?.[0],t.search_values?.[1])}}};a(sS,"getSelect");a(BC,"getRecords");a(ns,"getTable");a(HC,"createDeleteResponse");a(xC,"groupRecordsInHistory")});var Ln=g((y_e,$C)=>{"use strict";var{ResourceBridge:$J}=(VC(),ie(kC)),YJ=ne();YJ.initSync();var md;function KJ(){return md||(md=new $J,md)}a(KJ,"getBridge");$C.exports=KJ()});var QC=g((I_e,WC)=>{"use strict";var YC=require("lodash"),cl=require("mathjs"),WJ=require("jsonata"),KC=z();WC.exports={distinct_array:e=>Array.isArray(e)&&e.length>1?YC.uniqWith(e,YC.isEqual):e,searchJSON:QJ,mad:ll.bind(null,cl.mad),mean:ll.bind(null,cl.mean),mode:ll.bind(null,cl.mode),prod:ll.bind(null,cl.prod),median:ll.bind(null,cl.median)};function ll(e,t,r,n){return n===1?t==null?[]:[t]:n===2?(t!=null&&r.push(t),r):r!=null&&r.length>0?e(r):null}a(ll,"aggregateFunction");function QJ(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(KC.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),KC.isEmpty(this.__ala__.res[r])){let n=WJ(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(QJ,"searchJSON")});var JC=g((C_e,zC)=>{"use strict";var gt=require("moment"),oS="YYYY-MM-DDTHH:mm:ss.SSSZZ";gt.suppressDeprecationWarnings=!0;zC.exports={current_date:()=>gt().utc().format("YYYY-MM-DD"),current_time:()=>gt().utc().format("HH:mm:ss.SSS"),extract:(e,t)=>{switch(t.toLowerCase()){case"year":return gt(e).utc().format("YYYY");case"month":return gt(e).utc().format("MM");case"day":return gt(e).utc().format("DD");case"hour":return gt(e).utc().format("HH");case"minute":return gt(e).utc().format("mm");case"second":return gt(e).utc().format("ss");case"millisecond":return gt(e).utc().format("SSS");default:break}},date:e=>gt(e).utc().format(oS),date_format:(e,t)=>gt(e).utc().format(t),date_add:(e,t,r)=>gt(e).utc().add(t,r).valueOf(),date_sub:(e,t,r)=>gt(e).utc().subtract(t,r).valueOf(),date_diff:(e,t,r)=>{let n=gt(e).utc(),s=gt(t).utc();return r?n.diff(s,r,!0):n.diff(s)},now:()=>gt().utc().valueOf(),get_server_time:()=>gt().format(oS),offset_utc:(e,t)=>gt(e).utc().utcOffset(t).format(oS)}});var eD=g((D_e,ZC)=>{"use strict";var zJ=require("@turf/area"),JJ=require("@turf/length"),XJ=require("@turf/circle"),jJ=require("@turf/difference"),ZJ=require("@turf/distance"),e4=require("@turf/boolean-contains"),t4=require("@turf/boolean-equal"),r4=require("@turf/boolean-disjoint"),n4=require("@turf/helpers"),XC=P(),Te=z(),Is=K();ZC.exports={geoArea:s4,geoLength:i4,geoCircle:o4,geoDifference:a4,geoDistance:jC,geoNear:c4,geoContains:l4,geoEqual:u4,geoCrosses:_4,geoConvert:d4};function s4(e){if(Te.isEmpty(e))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e));try{return zJ.default(e)}catch(t){return Is.trace(t,e),NaN}}a(s4,"geoArea");function i4(e,t){if(Te.isEmpty(e))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e));try{return JJ.default(e,{units:t||"kilometers"})}catch(r){return Is.trace(r,e),NaN}}a(i4,"geoLength");function o4(e,t,r){if(Te.isEmpty(e))return NaN;if(Te.isEmpty(t))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e));try{return XJ.default(e,t,{units:r||"kilometers"})}catch(n){return Is.trace(n,e,t),NaN}}a(o4,"geoCircle");function a4(e,t){if(Te.isEmpty(e))return NaN;if(Te.isEmpty(t))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return jJ(e,t)}catch(r){return Is.trace(r,e,t),NaN}}a(a4,"geoDifference");function jC(e,t,r){if(Te.isEmpty(e))return NaN;if(Te.isEmpty(t))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return ZJ.default(e,t,{units:r||"kilometers"})}catch(n){return Is.trace(n,e,t),NaN}}a(jC,"geoDistance");function c4(e,t,r,n){if(Te.isEmpty(e)||Te.isEmpty(t))return!1;if(Te.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t)),isNaN(r))throw new Error("distance must be a number");try{return jC(e,t,n)<=r}catch(s){return Is.trace(s,e,t),!1}}a(c4,"geoNear");function l4(e,t){if(Te.isEmpty(e)||Te.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return e4.default(e,t)}catch(r){return Is.trace(r,e,t),!1}}a(l4,"geoContains");function u4(e,t){if(Te.isEmpty(e)||Te.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return t4.default(e,t)}catch(r){return Is.trace(r,e,t),!1}}a(u4,"geoEqual");function _4(e,t){if(Te.isEmpty(e)||Te.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return!r4.default(e,t)}catch(r){return Is.trace(r,e,t),!1}}a(_4,"geoCrosses");function d4(e,t,r){if(Te.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if(Te.isEmpty(t))throw new Error("geo_type is required");if(Te.isEmpty(XC.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(XC.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Te.autoCastJSON(e)),n4[t](e,r)}a(d4,"geoConvert")});var pd=g((M_e,tD)=>{var so=QC(),Kr=JC(),ss=eD();tD.exports=e=>{e.aggr.mad=e.aggr.MAD=so.mad,e.aggr.mean=e.aggr.MEAN=so.mean,e.aggr.mode=e.aggr.MODE=so.mode,e.aggr.prod=e.aggr.PROD=so.prod,e.aggr.median=e.aggr.MEDIAN=so.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=so.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=so.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=Kr.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Kr.current_time,e.fn.extract=e.fn.EXTRACT=Kr.extract,e.fn.date=e.fn.DATE=Kr.date,e.fn.date_format=e.fn.DATE_FORMAT=Kr.date_format,e.fn.date_add=e.fn.DATE_ADD=Kr.date_add,e.fn.date_sub=e.fn.DATE_SUB=Kr.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Kr.date_diff,e.fn.now=e.fn.NOW=Kr.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Kr.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Kr.get_server_time,e.fn.getdate=e.fn.GETDATE=Kr.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Kr.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=ss.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=ss.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=ss.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=ss.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=ss.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=ss.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=ss.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=ss.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=ss.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=ss.geoNear}});var iD=g((P_e,sD)=>{"use strict";var ul=require("lodash"),pr=require("alasql");pr.options.cache=!1;var f4=pd(),rD=require("clone"),Sd=require("recursive-iterator"),fe=K(),Le=z(),oa=Ln(),E4=P(),{hdb_errors:h4}=se(),{getDatabases:nD}=(Ae(),ie(ke)),m4="IS NULL",vn="There was a problem performing this search. Please check the logs and try again.";f4(pr);var aS=class{static{a(this,"SQLSearch")}constructor(t,r){if(Le.isEmpty(t))throw fe.error("AST statement for SQL select process cannot be empty"),"statement cannot be null";this.statement=t,this.columns={},this.all_table_attributes=r,this.fetch_attributes=[],this.exact_search_values={},this.comparator_search_values={},this.tables=[],this.data={},this.has_aggregator=!1,this.has_ordinal=!1,this.has_outer_join=!1,this._getColumns(),this._getTables(),this._conditionsToFetchAttributeValues(),this._setAliasesForColumns(),Le.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!Le.isEmptyOrZeroLength(n))return fe.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw fe.error("Error thrown from checkEmptySQL in SQLSearch class method search."),fe.error(n),new Error(vn)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw fe.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),fe.error(n),new Error(vn)}if(Object.keys(this.data).length===0)return fe.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw fe.error("Error thrown from processJoins in SQLSearch class method search."),fe.error(n),new Error(vn)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw fe.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),fe.error(n),new Error(vn)}try{return t=await this._finalSQL(),t}catch(n){throw fe.error("Error thrown from finalSQL in SQLSearch class method search."),fe.error(n),new Error(vn)}}_getColumns(){let t=new Sd(this.statement);for(let{node:r,path:n}of t)r&&r.columnid&&(this.columns[n[0]]||(this.columns[n[0]]=[]),this.columns[n[0]].push(rD(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=ul.uniqBy(t,r=>[r.databaseid,r.tableid,r.as].join()),this.tables.forEach(r=>{let n=`${r.databaseid}_${r.as?r.as:r.tableid}`;this.data[n]={},this.data[n].__hash_name=nD()[r.databaseid][r.tableid].primaryKey,this.data[n].__merged_data={},this.data[n].__merged_attributes=[],this.data[n].__merged_attr_map={}})}_conditionsToFetchAttributeValues(){if(Le.isEmpty(this.statement.where)){fe.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new Sd(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!Le.isEmpty(r)&&r.right)if(Le.isNotEmptyAndHasValue(r.right.value)){let n=Le.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new pr.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=Le.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new pr.yy.LogicValue({value:i}):n instanceof pr.yy.StringValue&&Le.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new pr.yy.NumValue({value:i}))});if(t){fe.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new Sd(this.statement.where))if(r&&r.left&&r.right&&(r.left.columnid||r.right.value)&&r.op){let n=new Set,s=r.left.columnid?r.left:r.right,i=this._findColumn(s);if(!i)continue;let o=[i.table.databaseid,i.table.tableid,i.attribute].join("/");if(!Le.isEmpty(E4.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(Le.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(Le.isEmptyOrZeroLength(r.left.columnid)||Le.isEmptyOrZeroLength(r.right.value)){this.comparator_search_values[o].ignore=!0,this.comparator_search_values[o].comparators=[];continue}this.comparator_search_values[o].comparators.push({attribute:r.left.columnid,operation:r.op,search_value:r.right.value})}continue}if(Le.isEmpty(this.exact_search_values[o])&&(this.exact_search_values[o]={ignore:!1,values:new Set}),!this.exact_search_values[o].ignore){let c=!1;switch(r.op){case"=":!Le.isEmpty(r.right.value)||!Le.isEmpty(r.left.value)?n.add(Le.isEmpty(r.right.value)?r.left.value:r.right.value):c=!0;break;case"IN":let l=Array.isArray(r.right)?r.right:r.left;for(let _=0;_<l.length;_++)if(l[_].value)n.add(l[_].value);else{c=!0;break}break;default:c=!0;break}this.exact_search_values[o].ignore=c,c?this.exact_search_values[o].values=new Set:this.exact_search_values[o].values=new Set([...this.exact_search_values[o].values,...n])}}}_setAliasesForColumns(){if(Le.isEmptyOrZeroLength(this.all_table_attributes)&&Le.isEmptyOrZeroLength(this.statement.from)&&Le.isEmptyOrZeroLength(this.columns.columns))return;let t=[],r={};this.statement.columns.forEach((n,s)=>{if(n.columnid==="*"){t.push(s);return}if(n.aggregatorid&&(this.has_aggregator=!0),!n.aggregatorid&&!n.funcid)if(n.as_orig=n.as?n.as:n.columnid,this.statement.joins)if(r[n.as_orig]>=0){let i=r[n.as_orig]+1;n.as=`[${n.as_orig+i}]`,r[n.as_orig]=i}else n.as=`[${n.as_orig}]`,r[n.as_orig]=0;else n.as=`[${n.as_orig}]`;!n.aggregatorid&&n.funcid&&n.args&&(n.as_orig=n.as?n.as:n.toString().replace(/'/g,'"'),n.as=`[${n.as_orig}]`),n.aggregatorid&&n.expression.columnid!=="*"&&(n.as_orig=n.as?n.as:n.expression.tableid?`${n.aggregatorid}(${n.expression.tableid}.${n.expression.columnid})`:`${n.aggregatorid}(${n.expression.columnid})`,n.as=`[${n.as_orig}]`)}),this.statement.columns.length>1&&t.length>0&&ul.pullAt(this.statement.columns,t)}_findColumn(t){let r=this.all_table_attributes.filter(n=>{if(t.columnid_orig&&t.tableid_orig)return(n.table.as===t.tableid_orig||n.table.tableid===t.tableid_orig)&&n.attribute===t.columnid_orig;if(t.tableid)return(n.table.as===t.tableid||n.table.tableid===t.tableid)&&n.attribute===t.columnid;let s=t.columnid_orig?t.columnid_orig:t.columnid;return n.attribute===s});if(Le.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);Le.isEmptyOrZeroLength(n)||(r=this.all_table_attributes.filter(s=>s.attribute===n[0].columnid&&n[0].tableid&&n[0].tableid===(s.table.as?s.table.as:s.table.tableid)))}return r[0]}async _checkEmptySQL(){let t=[];if(Le.isEmptyOrZeroLength(this.all_table_attributes)&&!Le.isEmptyOrZeroLength(this.columns.columns))return t;if(Le.isEmptyOrZeroLength(this.all_table_attributes)&&Le.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await pr.promise(r)}catch(r){throw fe.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),fe.error(r),new Error("There was a problem with the SQL statement")}return t}_addFetchColumns(t){t&&t.length>0&&t.forEach(r=>{let n=this._findColumn(r);n&&this.fetch_attributes.push(rD(n))})}_addColumnToMergedAttributes(t,r){this.data[t].__merged_attributes.push(r),this.data[t].__merged_attr_map[r]=this.data[t].__merged_attributes.length-1}_setMergedHashAttribute(t,r){this.data[t].__merged_data[r].splice(0,1,r)}_updateMergedAttribute(t,r,n,s){let i=this.data[t].__merged_attr_map[n];this.data[t].__merged_data[r].splice(i,1,s)}async _getFetchAttributeValues(){if(Le.isEmptyOrZeroLength(Object.keys(this.columns)))return[];this._addFetchColumns(this.columns.joins);let t=null;try{t=this.statement.where?this.statement.where.toString():""}catch{throw new Error("Could not generate proper where clause")}this.columns.where&&this._addFetchColumns(this.columns.where);let r=this._isSimpleSelect();if(r?this._addFetchColumns(this.columns.columns):(!this.columns.where&&this.fetch_attributes.length===0)|t.indexOf(m4)>-1&&this.tables.forEach(s=>{let i={columnid:nD()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=ul.uniqBy(this.fetch_attributes,s=>[s.table.databaseid,s.table.as?s.table.as:s.table.tableid,s.attribute].join()),r)return await this._simpleSQLQuery();let n=this.fetch_attributes.reduce((s,i)=>{let o=`${i.table.databaseid}_${i.table.as?i.table.as:i.table.tableid}`,c=this.data[o].__hash_name;return s[o]||(s[o]=[],s[o].push(null),this._addColumnToMergedAttributes(o,c)),i.attribute!==c&&(s[o].push(null),this._addColumnToMergedAttributes(o,i.attribute)),s},{});for(let s of this.fetch_attributes){let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`,o=this.data[i].__hash_name,c={schema:s.table.databaseid,table:s.table.tableid,get_attributes:[s.attribute]},l=!1,_=[s.table.databaseid,s.table.tableid,s.attribute].join("/");if(s.attribute===o&&(l=!0),!Le.isEmpty(this.exact_search_values[_])&&!this.exact_search_values[_].ignore&&!Le.isEmptyOrZeroLength(this.exact_search_values[_].values))if(l)try{c.hash_values=Array.from(this.exact_search_values[_].values);let u=await oa.getDataByHash(c);for(let d of c.hash_values)u.get(d)&&!this.data[i].__merged_data[d]&&(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d))}catch(u){throw fe.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),fe.error(u),new Error(vn)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[_].values).map(async u=>{let d=Object.assign({},c);d.search_value=u;let E=await oa.getDataByValue(d);for(let[f,h]of E)this.data[i].__merged_data[f]?this._updateMergedAttribute(i,f,s.attribute,h[s.attribute]):(this.data[i].__merged_data[f]=[...n[i]],this._updateMergedAttribute(i,f,s.attribute,h[s.attribute]),this._setMergedHashAttribute(i,f))}))}catch(u){throw fe.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),fe.error(u),new Error(vn)}else if(!Le.isEmpty(this.comparator_search_values[_])&&!this.comparator_search_values[_].ignore&&!Le.isEmptyOrZeroLength(this.comparator_search_values[_].comparators))try{let u=this.comparator_search_values[_].comparators;for(let d=0,E=u.length;d<E;d++){let f=u[d];c.search_attribute=f.attribute,c.search_value=f.search_value;let h=await oa.getDataByValue(c,f.operation);if(l)for(let[p]of h)this.data[i].__merged_data[p]||(this.data[i].__merged_data[p]=[...n[i]],this._setMergedHashAttribute(i,p));else for(let[p,S]of h)this.data[i].__merged_data[p]?this._updateMergedAttribute(i,p,s.attribute,S[s.attribute]):(this.data[i].__merged_data[p]=[...n[i]],this._updateMergedAttribute(i,p,s.attribute,S[s.attribute]),this._setMergedHashAttribute(i,p))}}catch(u){throw fe.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),fe.error(u),new Error(vn)}else try{c.search_attribute=s.attribute,c.search_value="*";let u=await oa.getDataByValue(c);if(l)for(let[d]of u)this.data[i].__merged_data[d]||(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d));else for(let[d,E]of u)this.data[i].__merged_data[d]?this._updateMergedAttribute(i,d,s.attribute,E[s.attribute]):(this.data[i].__merged_data[d]=[...n[i]],this._updateMergedAttribute(i,d,s.attribute,E[s.attribute]),this._setMergedHashAttribute(i,d))}catch(u){throw fe.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),fe.error(u),new Error(vn)}}}_isSimpleSelect(){let t=!0;return Object.keys(this.statement).length!==2||!this.statement.columns||!this.statement.from||this.statement.from.length!==1?(t=!1,t):(this.statement.columns.forEach(r=>{r instanceof pr.yy.Column||(t=!1)}),t)}_updateOrderByToAliases(){this.statement.order.forEach(t=>{if(t.expression.aggregatorid){t.is_aggregator=!0;return}if(t.expression.value){t.is_ordinal=!0,this.has_ordinal=!0;return}else t.is_ordinal=!1;let r=this.statement.columns.filter(s=>{let i=s.aggregatorid?s.expression:s,o=s.aggregatorid?s.as_orig:i.as_orig;return t.expression.tableid?i.columnid_orig===t.expression.columnid_orig&&i.tableid_orig===t.expression.tableid_orig:i.columnid_orig===t.expression.columnid_orig||t.expression.columnid_orig===o});r[0]||r.push(this._findColumn(t.expression));let n=r[0];if(t.is_func=!!n.funcid,t.is_aggregator=!!n.aggregatorid,n.as)if(n.as&&!t.expression.tableid)t.expression.columnid=n.as,t.expression.columnid_orig=n.as_orig;else{let s=new pr.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new pr.yy.Column,t.expression),t.initial_select_column.as=`[${t.expression.columnid_orig}]`,t.expression.columnid=t.initial_select_column.as;return}if(!t.is_aggregator){let s=t.is_func?new pr.yy.FuncValue:new pr.yy.Column;t.initial_select_column=Object.assign(s,n)}})}_addNonAggregatorsToFetchColumns(){let r=this.statement.order.filter(n=>!n.is_aggregator&&!n.is_ordinal).map(n=>n.is_func?{columnid:n.initial_select_column.args.filter(i=>!!i.columnid_orig)[0].columnid_orig}:{columnid:n.expression.columnid_orig});this._addFetchColumns(r)}async _processJoins(){let t=[],r=[],n=this.statement.from[0],s=[n],i=["? "+(n.as?" AS "+n.as:n.tableid)];t.push(Object.values(this.data[`${n.databaseid_orig}_${n.as?n.as_orig:n.tableid_orig}`].__merged_data)),this.statement.joins&&this.statement.joins.forEach(f=>{f.joinmode&&f.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(f.table);let h=f.joinmode+" JOIN ? AS "+(f.as?f.as:f.table.tableid);f.on&&(h+=" ON "+f.on.toString()),i.push(h),t.push(Object.values(this.data[`${f.table.databaseid_orig}_${f.table.as?f.table.as_orig:f.table.tableid_orig}`].__merged_data))});let o=[],c={};s.forEach(f=>{let h=this.data[`${f.databaseid_orig}_${f.as?f.as_orig:f.tableid_orig}`].__hash_name,p=f.as?f.as_orig:f.tableid_orig;o.push({key:`'${p}.${h}'`,schema:f.databaseid_orig,table:f.as?f.as_orig:f.tableid_orig,keys:new Set}),r.push(`${f.as?f.as:f.tableid}.\`${h}\` AS "${p}.${h}"`),c[f.as?f.as_orig:f.tableid_orig]=this.data[`${f.databaseid_orig}_${f.as?f.as_orig:f.tableid_orig}`].__merged_attributes});let l=this.statement.where?"WHERE "+this.statement.where:"";l=l.replace(/NOT\(NULL\)/g,"NOT NULL");let _="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(_="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(f=>{f.is_func?r.push(f.initial_select_column.toString()):f.initial_select_column.tableid?r.push(`${f.initial_select_column.tableid}.${f.initial_select_column.columnid} AS ${f.expression.columnid}`):r.push(`${f.initial_select_column.columnid} AS ${f.expression.columnid}`)}));let u="",d="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(u=this.statement.limit?"LIMIT "+this.statement.limit:"",d=this.statement.offset?"OFFSET "+this.statement.offset:"");let E=[];try{let f=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${l} ${_} ${u} ${d}`,h=this._convertColumnsToIndexes(f,s);E=await pr.promise(h,t),t=null}catch(f){throw fe.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),fe.error(f),new Error("There was a problem processing the data.")}if(E&&E.length>0){for(let f=0,h=E.length;f<h;f++){let p=E[f];o.forEach(S=>{p[S.key]!==null&&p[S.key]!==void 0&&S.keys.add(p[S.key])})}o.forEach(f=>{let h=Object.keys(this.data[`${f.schema}_${f.table}`].__merged_data),p=ul.difference(h,[...f.keys].map(S=>S.toString()));for(let S=0,T=p.length;S<T;S++){let A=p[S];delete this.data[`${f.schema}_${f.table}`].__merged_data[A]}})}return{existing_attributes:c,joined_length:E?E.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new Sd(this.columns);for(let{node:i}of s)if(i&&i.columnid){let o=this._findColumn(i);if(o){let c=o.table.as?o.table.as:o.table.tableid;(!t[c]||t[c].indexOf(o.attribute)<0)&&n.push(o)}}n=ul.uniqBy(n,i=>[i.table.databaseid,i.table.as?i.table.as:i.table.tableid,i.attribute].join());try{await this._getData(n)}catch(i){throw fe.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),fe.error(i),new Error(vn)}}async _getData(t){try{let r=t.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]?n[i].columns.push(s.attribute):n[i]={schema:s.table.databaseid,table:s.table.tableid,columns:[s.attribute]},n},{});for(let n in r){let s=r[n],i=this.data[n].__merged_data,o=[];for(let u in i)o.push(i[u][0]);this.data[n].__merged_attributes.push(...s.columns);let c={schema:s.schema,table:s.table,hash_values:o,get_attributes:s.columns},l=await oa.getDataByHash(c),_=s.columns.length;for(let u=0,d=o.length;u<d;u++){let E=o[u],f=l.get(E);for(let h=0;h<_;h++){let p=s.columns[h],S=f[p]===void 0?null:f[p];this.data[n].__merged_data[E].push(S)}}}}catch(r){throw fe.error("Error thrown from getDataByHash function in SQLSearch class method getData."),fe.error(r),r}}async _finalSQL(){let t=[],r=this.statement.from[0];t.push(Object.values(this.data[`${r.databaseid_orig}_${r.as?r.as_orig:r.tableid_orig}`].__merged_data)),r.as=r.as?r.as:r.tableid,r.databaseid="",r.tableid="?",this.statement.joins&&this.statement.joins.forEach(s=>{s.as=s.as?s.as:s.table.tableid,t.push(Object.values(this.data[`${s.table.databaseid_orig}_${s.table.as?s.table.as_orig:s.table.tableid_orig}`].__merged_data)),s.table.databaseid="",s.table.tableid="?"}),this.statement.order&&this.statement.order.forEach(s=>{if(s.is_ordinal)return;this.statement.columns.filter(o=>{let c=o.aggregatorid?o.expression:o,l=o.aggregatorid?o.as_orig:c.as_orig;return s.expression.tableid?c.columnid_orig===s.expression.columnid_orig&&c.tableid_orig===s.expression.tableid_orig:c.columnid_orig===s.expression.columnid_orig||s.expression.columnid_orig===l}).length===0&&(s.expression.columnid=s.initial_select_column.columnid)}),!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&this.statement.limit&&!this.statement.joins&&(delete this.statement.limit,delete this.statement.offset);let n;try{let s=this._buildSQL();fe.trace(`Final SQL: ${s}`),n=await pr.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),fe.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw fe.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),fe.error(s),new Error("There was a problem running the generated sql.")}return n}_translateUndefinedValues(t){try{let r=[];for(let n of t){let s=Object.create(null);Object.keys(n).forEach(i=>{n[i]===void 0?s[i]=null:s[i]=n[i]}),r.push(s)}return r}catch(r){return fe.error(h4.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),fe.trace(r.stack),t}}_buildSQL(t=!0){let r=this.statement.toString();return r=r.replace(/NOT\(NULL\)/g,"NOT NULL"),this.statement.columns.forEach(n=>{if(n.funcid&&n.as){let s=n.toString().replace(" AS "+n.as,"");r=r.replace(n.toString(),s)}}),t===!0?this._convertColumnsToIndexes(r,this.tables):r}_convertColumnsToIndexes(t,r){let n=t,s={};r.forEach(i=>{i.databaseid_orig?s[`${i.databaseid_orig}_${i.as?i.as_orig:i.tableid_orig}`]=i.as?i.as:i.tableid:s[`${i.databaseid}_${i.as?i.as:i.tableid}`]=`\`${i.as?i.as:i.tableid}\``});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=s[i],_=new RegExp(`${l}.\`${o}\``,"g"),u=`${l}.[${c}]`;n=n.replace(_,u)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=new RegExp(`\`${o}\``,"g"),_=`[${c}]`;n=n.replace(l,_)});return n}async _simpleSQLQuery(){let t=this.statement.columns.reduce((n,s)=>(s.as_orig&&s.as_orig!=s.columnid_orig?n[s.columnid_orig]=s.as_orig:n[s.columnid_orig]||(n[s.columnid_orig]=s.columnid_orig),n),{}),r=this.fetch_attributes.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]||(n[i]={}),n[i][t[s.attribute]]=null,n},{});for(let n of this.fetch_attributes){let s=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`,i={schema:n.table.databaseid,table:n.table.tableid,get_attributes:[n.attribute]};try{i.search_attribute=n.attribute,i.search_value="*";let o=await oa.getDataByValue(i);for(let[c,l]of o)this.data[s].__merged_data[c]||(l[n.attribute]===void 0&&(l[n.attribute]=null),this.data[s].__merged_data[c]=Object.assign({},r[s])),this.data[s].__merged_data[c][t[n.attribute]]=l[n.attribute]??null}catch(o){throw fe.error("There was an error when processing this SQL operation. Check your logs"),fe.error(o),new Error(vn)}}return Object.values(Object.values(this.data)[0].__merged_data)}};sD.exports=aS});var kr=g((v_e,oD)=>{"use strict";var p4=ny();oD.exports={searchByConditions:T4,searchByHash:g4,searchByValue:R4,search:A4};var cS=Ln(),{transformReq:lS}=z(),S4=iD();async function T4(e){return lS(e),cS.searchByConditions(e)}a(T4,"searchByConditions");async function g4(e){lS(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of cS.searchByHash(e))r&&t.push(r);return t}a(g4,"searchByHash");async function R4(e){lS(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of cS.searchByValue(e))t.push(r);return t}a(R4,"searchByValue");function A4(e,t){try{let r=new p4(e);r.validate(),new S4(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(A4,"search")});var Td=g((H_e,aD)=>{"use strict";var O4=Ln();aD.exports={writeTransaction:b4};function b4(e,t,r){return O4.writeTransaction(e,t,r)}a(b4,"writeTransaction")});var _D=g((F_e,uD)=>{"use strict";var y4=kr(),N4=ii(),cD=K(),I4=un(),G_e=Td(),w4=require("clone"),_S=require("alasql"),C4=pd(),lD=require("util"),D4=lD.promisify(N4.getTableSchema),L4=lD.promisify(y4.search),M4=P(),uS=z();C4(_S);uD.exports={update:U4};var P4="There was a problem performing this update. Please check the logs and try again.";async function U4({statement:e,hdb_user:t}){let r=await D4(e.table.databaseid,e.table.tableid),n=v4(e.columns);uS.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=w4(s),c=uS.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,_=_S.parse(l).statements[0],u=await L4(_),d=B4(n,u);return H4(o,d,t)}a(U4,"update");function v4(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=_S.compile(`SELECT ${r.expression.toString()} AS [${M4.FUNC_VAL}] FROM ?`)}),t}catch(t){throw cD.error(t),new Error(P4)}}a(v4,"createUpdateRecord");function B4(e,t){return uS.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(B4,"buildUpdateRecords");async function H4(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await I4.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){cD.error(`Error delete new_attributes from update response: ${i}`)}return s}a(H4,"updateRecords")});var fD=g(($_e,dD)=>{var x4=require("alasql"),G4=kr(),F4=K(),q4=Ln(),fS=require("util"),dS=z(),k4=P(),V4=ii(),k_e=Td(),V_e=un(),$4="record",Y4="successfully deleted",K4=fS.callbackify(J4),W4=fS.promisify(G4.search),Q4=fS.promisify(V4.getTableSchema);dD.exports={convertDelete:K4};function z4(e){return`${e.deleted_hashes.length} ${$4}${e.deleted_hashes.length===1?"":"s"} ${Y4}`}a(z4,"generateReturnMessage");async function J4({statement:e,hdb_user:t}){let r=await Q4(e.table.databaseid,e.table.tableid);dS.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=dS.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=x4.parse(o).statements[0],l={operation:k4.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await W4(c);let _=await q4.deleteRecords(l);return dS.isEmptyOrZeroLength(_.message)&&(_.message=z4(_)),delete _.txn_time,_}catch(_){throw F4.error(_),_.hdb_code?_.message:_}}a(J4,"convertDelete")});var SD=g((K_e,pD)=>{"use strict";var X4=si(),{hdb_errors:ED}=se(),{getDatabases:hD}=(Ae(),ie(ke));pD.exports={checkSchemaExists:mD,checkSchemaTableExists:j4,schema_describe:X4};async function mD(e){if(!hD()[e])return ED.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(mD,"checkSchemaExists");async function j4(e,t){let r=await mD(e);if(r)return r;if(!hD()[e][t])return ED.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(j4,"checkSchemaTableExists")});var _l=g((Q_e,Z4)=>{Z4.exports={name:"harperdb",version:"4.3.30",description:"HarperDB is a distributed database, caching service, streaming broker, and application development platform focused on performance and ease of use.",keywords:["database","nosql","api","distributed","broker","mqtt","real-time","enterprise","Fastify","NATS","HarperDB","Harper","clustering","replication","REST","WebSockets","decentralized","server-sent events","document store"],main:"harperdb.js",bin:{harperdb:"./bin/harperdb.js"},engines:{"minimum-node":"16.0.0","go-lang":"1.21.7","nats-server":"2.10.11"},exports:{".":"./index.js"},homepage:"https://www.harperdb.io/",bugs:"support@harperdb.io",author:{name:"HarperDB",email:"support@harperdb.io"},license:"SEE LICENSE IN LICENSE",scripts:{submodules:"git submodule update --init --recursive",build:"eslint -c ./.eslintbuild bin/ dataLayer/ security/ server/ sqlTranslator/ upgrade/ utility/ validation/",pretty:"eslint --fix bin/ dataLayer/ security/ server/ sqlTranslator/ upgrade/ utility/ validation/","cover:test":"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && nyc --no-clean --reporter=lcovonly npm run test:apitests && nyc --no-clean --reporter=lcovonly npm run test:resources && nyc --no-clean --reporter=lcovonly npm run test:logging && nyc --no-clean --reporter=lcovonly npm run test:upgrade && nyc --no-clean --reporter=lcovonly npm run test:nats && nyc --no-clean --reporter=lcovonly npm run test:cfserver && nyc --no-clean --reporter=lcovonly npm run test:hdbserver && nyc --no-clean --reporter=lcovonly npm run test:bin && nyc --no-clean --reporter=lcovonly npm run test:main && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license",test:"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && npm run test:apitests && npm run test:resources && npm run test:logging && npm run test:upgrade && npm run test:nats && npm run test:cfserver && npm run test:hdbserver && npm run test:bin && npm run test:main && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license","test:resources":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/resources/**/*.js' --config '../unitTests/.mocharc.json'","test:bin":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/bin/**/*.js' --config '../unitTests/.mocharc.json'","test:main":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --config '../unitTests/.mocharc-main.json'","test:lmdbbridge":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --config '../unitTests/.mocharc.json'","test:lmdbutility":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --config '../unitTests/.mocharc.json'","test:hdbserver":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --config '../unitTests/.mocharc.json'","test:cfserver":"npm run submodules && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/fastifyRoutes/customFunctionsServer-test.js' --config '../unitTests/.mocharc.json'","test:nats":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json'","test:upgrade":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --config '../unitTests/.mocharc.json'","test:apitests":"pm2 kill && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/apiTests/**/*-test.mjs' --config '../unitTests/.mocharc.json'","test:logging":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/logging/*.js' --config '../unitTests/.mocharc.json'","test:ci":" cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --retries 3 --config '../unitTests/.mocharc-main.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/customFunctions/customFunctionsServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter","hdb-check":"./utility/devops/hdb-check.sh","download-prebuilds":"node ./utility/devops/build/download-prebuilds.js",prebuild:"date",postinstall:"node ./launchServiceScripts/launchInstallNATSServer.js",build_nats_dependency:"node ./utility/devops/nats/builder.js",coverage:"nyc --reporter=lcov npm test"},dependencies:{"@aws-sdk/client-s3":"3.635.0","@aws-sdk/lib-storage":"3.635.0","@endo/static-module-record":"^1.0.4","@fastify/autoload":"5.7.1","@fastify/compress":"~6.5.0","@fastify/cors":"~8.5.0","@fastify/static":"~6.12.0","@turf/area":"6.5.0","@turf/boolean-contains":"6.5.0","@turf/boolean-disjoint":"6.5.0","@turf/boolean-equal":"6.5.0","@turf/circle":"6.5.0","@turf/difference":"6.5.0","@turf/distance":"6.5.0","@turf/helpers":"6.5.0","@turf/length":"6.5.0",alasql:"4.1.10","cbor-x":"1.5.8",chalk:"4.1.2","cli-progress":"3.12.0",clone:"2.1.2","fast-glob":"3.3.2",fastify:"~4.26.2","fastify-plugin":"~4.5.1","fs-extra":"11.2.0",graphql:"^16.8.1","human-readable-ids":"1.0.4",inquirer:"8.2.6","is-number":"7.0.0",joi:"17.12.2","json-bigint-fixes":"1.1.0",json2csv:"5.0.7",jsonata:"1.8.7",jsonwebtoken:"9.0.2",lmdb:"3.1.3",lodash:"4.17.21",mathjs:"11.12.0",minimist:"1.2.8",mkcert:"1.5.1",moment:"2.30.1","mqtt-packet":"~8.2.1",msgpackr:"1.10.1",nats:"2.19.0",needle:"3.3.1","node-stream-zip":"1.15.0","node-unix-socket":"0.2.5","normalize-path":"^3.0.0",ora:"5.4.1","ordered-binary":"1.5.1",papaparse:"5.4.1",passport:"0.6.0","passport-http":"0.3.0","passport-local":"1.0.0",pino:"8.16.0",pm2:"5.4.1",prompt:"1.3.0","properties-reader":"2.3.0","recursive-iterator":"3.3.0",semver:"7.5.4",send:"^0.18.0","serve-static":"1.15.0",ses:"1.1.0","stream-chain":"2.2.5","stream-json":"1.8.0",systeminformation:"5.22.9","tar-fs":"2.1.1",ulidx:"0.5.0",uuid:"9.0.1","validate.js":"0.13.1",ws:"8.17.1",yaml:"2.4.1"},devDependencies:{"@tsconfig/node16":"^1.0.3","@types/node":"latest","@typescript-eslint/eslint-plugin":"^5.55.0","@typescript-eslint/parser":"^5.55.0",axios:"1.6.8",chai:"4.4.1","chai-integer":"0.1.0",esbuild:"^0.20.2",eslint:"8.22.0","eslint-config-prettier":"8.3.0","eslint-plugin-prettier":"3.4.1","eslint-plugin-radar":"0.2.1",eventsource:"^2.0.2","hook-std":"3.0.0","intercept-stdout":"0.1.2",mocha:"^10.3.0","mocha-teamcity-reporter":"3.0.0","mock-require":"3.0.3","mock-stdin":"1.0.0",mqtt:"~4.3.8",newman:"5.3.2","newman-reporter-html":"1.0.5","newman-reporter-htmlextra":"1.22.11","newman-reporter-teamcity":"0.1.12","node-fetch":"2.6.7",nyc:"15.1.0",prettier:"2.8.4",rewire:"5.0.0",rimraf:"3.0.2",sinon:"10.0.0","sinon-chai":"3.7.0","source-map-support":"^0.5.21",typescript:"^5.4.2","why-is-node-still-running":"^1.0.0"},overrides:{"eslint-plugin-radar":{eslint:"8.22.0"},alasql:{xlsx:"0.18.5"}},optionalDependencies:{bufferutil:"^4.0.7","utf-8-validate":"^5.0.10"}}});var ml={};qe(ml,{addAnalyticsListener:()=>hl,recordAction:()=>Sr,recordActionBinary:()=>Wr,setAnalyticsEnabled:()=>e3});function e3(e){ID=e}function Sr(e,t,r,n,s){if(!ID)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=Ad.get(i);if(o)if(typeof e=="number"){let c=o.values,l=c.index++;if(l>=c.length){let _=c;o.values=c=new Float32Array(l*2),c.set(_),c.index=l+1}c[l]=e,o.total+=e}else if(typeof e=="boolean")e&&o.total++,o.count++;else if(typeof e=="function")o.count++;else throw new TypeError("Invalid metric value type "+typeof e);else{if(typeof e=="number")o={total:e,values:new Float32Array(4)},o.values.index=1,o.values[0]=e,o.total=e;else if(typeof e=="boolean")o={},o.total=e?1:0,o.count=1;else if(typeof e=="function")o={},o.count=1,o.callback=e;else throw new TypeError("Invalid metric value type "+typeof e);o.description={metric:t,path:r,method:n,type:s},Ad.set(i,o)}gd||t3()}function Wr(e,t,r,n,s){Sr(!!e,t,r,n,s)}function hl(e){DD.push(e)}function t3(){gd=performance.now(),setTimeout(async()=>{let e=performance.now()-gd;gd=0;let t=[],r={time:Date.now(),period:e,threadId:io.threadId,metrics:t};for(let[s,i]of Ad){if(i.values){let o=i.values.subarray(0,i.values.index);o.sort();let c=o.length,l=0,_=[],u;for(let d of LD){let E=Math.floor(c*d),f=o[E-1];if(E>l){let h=E-l;if(f===u){let p=_[_.length-1];typeof p=="number"?_[_.length-1]={value:p,count:1+h}:p.count+=h}else _.push(h>1?{value:f,count:h}:f),u=f;l=E}}t.push(Object.assign(i.description,{mean:i.total/c,distribution:_,count:c}))}else i.callback?t.push(Object.assign(i.description,i.callback(i))):t.push(Object.assign(i.description,{total:i.total,count:i.count}));await MD()}let n=process.memoryUsage();t.push({metric:"memory",threadId:io.threadId,byThread:!0,...n});for(let s of DD)s(t);Ad=new Map,io.parentPort?io.parentPort.postMessage({type:CD,report:r}):vD({report:r})},wD).unref()}async function r3(e,t=6e4){let r=mS(),n=PD(),s=new Promise(p=>{let S=performance.now();setImmediate(()=>{let T=performance.now();T-S>5e3&&(0,dl.warn)("Unusually high event queue latency on the main thread of "+Math.round(T-S)+"ms"),S=performance.now()}),n.primaryStore.prefetch([1],()=>{let T=performance.now();T-S>5e3&&(0,dl.warn)("Unusually high task queue latency on the main thread of "+Math.round(T-S)+"ms"),p(T-S)})}),i;for(let p of n.primaryStore.getRange({start:1/0,end:!1,reverse:!0}))if(p.value?.time){i=p.value.time;break}if(Date.now()-t<i)return;let o,c=new Map,l=new Map,_=[],u;for(let{key:p,value:S}of r.primaryStore.getRange({start:i||!1,exclusiveStart:!0,end:1/0})){if(!S)continue;if(o){if(p>o+t)break}else o=p;u=p;let{metrics:T,threadId:A}=S;for(let b of T||[]){let{path:I,method:B,type:U,metric:q,count:M,total:Q,distribution:J,threads:X,...oe}=b;M||(M=1);let le=q+(I?"-"+I:"");B!==void 0&&(le+="-"+B),U!==void 0&&(le+="-"+U);let ue=c.get(le);if(ue){if(ue.threads){let Ne=ue.threads[A];if(Ne)ue=Ne;else{ue.threads[A]=Object.assign({},oe);continue}}ue.count||(ue.count=1);let Be=ue.count;for(let Ne in oe){let He=oe[Ne];typeof He=="number"&&(ue[Ne]=(ue[Ne]*Be+He*M)/(Be+M))}ue.count+=M,Q>=0&&(ue.total+=Q,ue.ratio=ue.total/ue.count)}else ue=Object.assign({period:t},b),delete ue.distribution,c.set(le,ue),ue.byThread&&(ue.threads=[],ue.threads[A]=Object.assign({},oe),_.push(ue));if(J){J=J.map(Ne=>typeof Ne=="number"?{value:Ne,count:1}:Ne);let Be=l.get(le);Be?Be.push(...J):l.set(le,J)}}await MD()}for(let p of _){let{path:S,method:T,type:A,metric:b,count:I,total:B,distribution:U,threads:q,...M}=p;q=q.filter(Q=>Q);for(let Q in M){if(typeof p[Q]!="number")continue;let J=0;for(let X of q){let oe=X[Q];typeof oe=="number"&&(J+=oe)}p[Q]=J}p.count=q.length,delete p.threads,delete p.byThread}for(let[p,S]of l){let T=c.get(p);S.sort((Ne,He)=>Ne.value>He.value?1:-1);let A=T.count-1,b=[],I=0,B=0,U;for(let Ne of LD){let He=A*Ne;for(;I<He;)U=S[B++],I+=U.count,B===1&&I--;let zu=S[B>1?B-2:0];U||(U=S[0]),b.push(U.value-(U.value-zu.value)*(I-He)/U.count)}let[q,M,Q,J,X,oe,le,ue,Be]=b;Object.assign(T,{p1:q,p10:M,p25:Q,median:J,p75:X,p90:oe,p95:le,p99:ue,p999:Be})}let d;for(let[p,S]of c)S.id=(0,Rd.getNextMonotonicTime)(),S.time=u,n.primaryStore.put(S.id,S,{append:!0}).then(T=>{T||n.primaryStore.put(S.id,S)}),d=!0;let E=Date.now(),{idle:f,active:h}=performance.eventLoopUtilization();if(d||h*10>f){let p=(0,Rd.getNextMonotonicTime)(),S={id:p,metric:"main-thread-utilization",idle:f-TD,active:h-gD,taskQueueLatency:await s,time:E,...process.memoryUsage()};n.primaryStore.put(p,S,{append:!0}).then(T=>{T||n.primaryStore.put(p,S)})}TD=f,gD=h}async function RD(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function mS(){return AD||(AD=ft({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function PD(){return OD||(OD=ft({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function i3(){UD=!0;let e=(0,El.get)(hS.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await r3(wD,e),await RD(mS(),n3),await RD(PD(),s3)},Math.min(e/2,2147483647)).unref()}function vD(e,t){let r=e.report;r.threadId=t?.threadId||io.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(bD+=n.mean*n.count);r.totalBytesProcessed=bD,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(yD.get(t))}),yD.set(t,t.performance.eventLoopUtilization())),r.id=(0,Rd.getNextMonotonicTime)(),mS().primaryStore.put(r.id,r),UD||i3(),o3&&(BD=c3(r))}async function c3(e){if(await BD,!_i){let r=(0,fl.dirname)((0,dl.getLogFilePath)());try{_i=await(0,ES.open)((0,fl.join)(r,"analytics.log"),"r+")}catch{_i=await(0,ES.open)((0,fl.join)(r,"analytics.log"),"w+")}}let t=(await _i.stat()).size;if(t>a3){let r=Buffer.alloc(t);await _i.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await _i.write(r,{position:0}),await _i.truncate(r.length),t=r.length}await _i.write(JSON.stringify(e)+`
10
10
  `,t)}var io,ND,dl,fl,ES,Rd,El,hS,Ad,ID,gd,wD,CD,DD,LD,TD,gD,MD,n3,s3,AD,OD,UD,bD,yD,o3,BD,_i,a3,ws=Re(()=>{io=require("worker_threads"),ND=x(ot());Ae();dl=x(K()),fl=require("path"),ES=require("fs/promises"),Rd=x(xr()),El=x(ne()),hS=x(P());ur();(0,El.initSync)();Ad=new Map,ID=(0,El.get)(hS.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)>-1;a(e3,"setAnalyticsEnabled");a(Sr,"recordAction");it.recordAnalytics=Sr;a(Wr,"recordActionBinary");gd=0,wD=1e3,CD="analytics-report",DD=[];a(hl,"addAnalyticsListener");LD=[.01,.1,.25,.5,.75,.9,.95,.99,.999,1];a(t3,"sendAnalytics");a(r3,"aggregation");TD=0,gD=0,MD=a(()=>new Promise(setImmediate),"rest");a(RD,"cleanup");n3=36e5,s3=31536e6;a(mS,"getRawAnalyticsTable");a(PD,"getAnalyticsTable");(0,ND.setChildListenerByType)(CD,vD);a(i3,"startScheduledTasks");bD=0,yD=new Map,o3=!1;a(vD,"recordAnalytics");a3=1e6;a(c3,"logAnalytics")});var RS=g((ade,QD)=>{"use strict";var{decode:l3}=require("msgpackr"),{isMainThread:sde,parentPort:ide,threadId:ode}=require("worker_threads"),yd=wt(),aa=ct(),TS=P(),nr=K(),SS=ne(),u3=P(),{onMessageByType:_3}=ot(),FD=Os(),{recordAction:HD,recordActionBinary:d3}=(ws(),ie(ml)),{publishToStream:f3}=yd,{ConsumerEvents:xD}=require("nats"),E3=kr(),{promisify:h3}=require("util"),qD=h3(setTimeout),Nd=1e4,Id,bd,m3,p3,kD,pl=new Map,ca=new Map;QD.exports={initialize:VD,ingestConsumer:gS,setSubscription:S3,setIgnoreOrigin:R3,getDatabaseSubscriptions:g3,updateConsumer:$D};async function VD(){_3(TS.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,async n=>{await $D(n)}),kD=!0,nr.notify("Initializing clustering ingest service.");let{connection:e,jsm:t,js:r}=await yd.getNATSReferences();Id=e,bd=e.info.server_name,m3=t,p3=r}a(VD,"initialize");async function $D(e){if(e.status==="start"){let{js:t,jsm:r}=await YD(e.node_domain_name);gS(e.stream_name,t,r,e.node_domain_name)}else if(e.status==="stop"){let t=pl.get(e.stream_name+e.node_domain_name);t&&(nr.notify("Closing ingest consumer for node:",e.node_domain_name,"stream:",e.stream_name),await t.close?.(),pl.set(e.stream_name+e.node_domain_name,"close")),ca.get(e.node_domain_name)==="failed"&&ca.set(e.node_domain_name,"close")}}a($D,"updateConsumer");var wd=new Map;function S3(e,t,r){let n=wd.get(e);n||wd.set(e,n=new Map),n.set(t,r),kD||VD().then(T3)}a(S3,"setSubscription");async function T3(){let e=await E3.searchByValue({database:"system",table:"hdb_nodes",search_attribute:"name",search_value:"*"});for await(let t of e){let r=t.name+aa.SERVER_SUFFIX.LEAF,n,s;for(let i of t.subscriptions)if(i.subscribe===!0){if(!n&&({js:n,jsm:s}=await YD(r),!n))break;let{schema:o,table:c}=i,l=FD.createNatsTableStreamName(o,c);gS(l,n,s,r)}}}a(T3,"accessConsumers");async function YD(e){let t,r,n=1;for(;!r;)try{t=await Id.jetstream({domain:e}),r=await Id.jetstreamManager({domain:e,checkAPI:!1})}catch(s){if(ca.get(e)==="close")break;ca.set(e,"failed"),n%10===1&&nr.warn("Nats ingest attempting to connect to:",e,"Nats error:",s.message);let i=n++*100<Nd?n++*100:Nd;await qD(i)}return{js:t,jsm:r}}a(YD,"connectToRemoteJS");function g3(){return wd}a(g3,"getDatabaseSubscriptions");var KD;function R3(e){KD=e}a(R3,"setIgnoreOrigin");var WD=100,GD=new Array(WD),Od=0;async function gS(e,t,r,n){let{connection:s}=await yd.getNATSReferences();Id=s,bd=s.info.server_name;let i,o=1;for(;!i;)try{i=await t.consumers.get(e,bd),nr.notify("Initializing ingest consumer for node:",n,"stream:",e)}catch(_){if(ca.get(n)==="close")break;o%10===1&&nr.warn("Nats ingest error getting consumer:",n,"stream:",e,"Nats error:",_.message),_.code==="404"&&(nr.notify("Nats ingest creating consumer for node:",n,"stream:",e),i=await yd.createConsumer(r,e,bd,new Date(Date.now()).toISOString()));let u=o++*100<Nd?o++*100:Nd;await qD(u)}let c=!1,l;for(;!c;){if(pl.get(e+n)==="close"||ca.get(n)==="close"){pl.delete(e+n),c=!0;continue}l=await i.consume({max_messages:SS.get(TS.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS)??100,bind:!0}),pl.set(e+n,l);let _=!1;(async()=>{for await(let u of await l.status())if(u.type===xD.ConsumerDeleted&&(await l.close(),c=!0),u.type===xD.HeartbeatsMissed){let d=u.data;nr.trace(`${d} clustering ingest consumer heartbeats missed, node: ${n} stream: ${l.consumer.stream}`),d===100&&(nr.warn(`Restarting clustering ingest consumer due to missed heartbeat threshold being met, node: ${n} stream: ${l.consumer.stream}`),l.stop(),_=!0)}})();try{for await(let u of l)await GD[Od],GD[Od]=A3(u).catch(d=>{nr.error(d)}),++Od>=WD&&(Od=0)}catch(u){u.message==="consumer deleted"?(nr.notify("Nats consumer deleted, closing messages for node:",n,"stream:",l.consumer.stream),await l.close(),c=!0):nr.error("Error consuming clustering ingest, restarting consumer",u)}}}a(gS,"ingestConsumer");async function A3(e){let t=l3(e.data);HD(e.data.length,"bytes-received",e.subject,t.operation,"ingest"),nr.trace("Nats message processor message size:",e?.msg?._msg?.size,"bytes");let r=e.headers,n=!1,s=SS.get(TS.CONFIG_PARAMS.CLUSTERING_NODENAME);r.has(aa.MSG_HEADERS.TRANSACTED_NODES)&&r.values(aa.MSG_HEADERS.TRANSACTED_NODES).indexOf(s)>-1&&(n=!0);let i=r.get(aa.MSG_HEADERS.ORIGIN);if(n||(n=i===s&&!KD),d3(n,"echo",e.subject,t.operation,"ingest"),n){e.ack();return}r.append(aa.MSG_HEADERS.TRANSACTED_NODES,s);try{let{operation:o,schema:c,next:l,table:_,records:u,hash_values:d,__origin:E,expiresAt:f}=t;nr.trace("processing message:",o,c,_,(u?"records: "+u.map(B=>B?.id):"")+(d?"ids: "+d:""),"with sequence:",e.seq),nr.trace(`messageProcessor nats msg id: ${e.headers.get(aa.MSG_HEADERS.NATS_MSG_ID)}`);let h;u||(u=d);let p=new Promise(B=>h=B),{timestamp:S,user:T,node_name:A}=E||{},b=wd.get(c)?.get(_);if(!b)throw new Error(`Missing table for replication message: ${_}`);if(o==="define_schema")t.type=o,t.onCommit=h,b.send(t);else if(u.length===1&&!l)b.send({type:pS(o),value:u[0],id:d?.[0],expiresAt:f,timestamp:S,table:_,onCommit:h,user:T,nodeName:A});else{let B=u.map((U,q)=>({type:pS(o),value:U,expiresAt:f,id:d?.[q],table:_}));for(;l;)B.push({type:pS(l.operation),value:l.record,expiresAt:l.expiresAt,id:l.id,table:l.table}),l=l.next;b.send({type:"transaction",writes:B,table:_,timestamp:S,onCommit:h,user:T,nodeName:A})}SS.get(u3.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&f3(e.subject.split(".").slice(0,-1).join("."),FD.createNatsTableStreamName(c,_),e.headers,e.data),await p;let I=Date.now()-S;S&&HD(I,"replication-latency",e.subject,o,"ingest")}catch(o){nr.error(o)}e.ack()}a(A3,"messageProcessor");function pS(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}a(pS,"convertOperation")});var wt=g((Ede,_L)=>{"use strict";var Ht=ne();Ht.initSync();var O3=require("fs-extra"),b3=require("semver"),gl=require("path"),{monotonicFactory:y3}=require("ulidx"),JD=y3(),N3=require("util"),XD=require("child_process"),I3=N3.promisify(XD.exec),w3=XD.spawn,Kt=ct(),Ie=P(),Cd=z(),Bn=K(),Dd=Os(),C3=Td(),Sl=dr(),{broadcast:D3,onMessageByType:L3,getWorkerIndex:M3}=ot(),{isMainThread:jD}=require("worker_threads"),{Encoder:P3,decode:yS}=require("msgpackr"),ZD=new P3,{isEmpty:lo}=Cd,eL=_n(),lde=48*36e11;jD&&L3(Ie.ITC_EVENT_TYPES.RESTART,()=>{Tr=void 0,co=void 0});var{connect:U3,StorageType:v3,RetentionPolicy:B3,AckPolicy:NS,DeliverPolicy:IS,DiscardPolicy:H3,NatsConnection:ude,JetStreamManager:_de,JetStreamClient:dde,StringCodec:fde,JSONCodec:x3,createInbox:wS,headers:G3,ErrorCode:zD}=require("nats"),{PACKAGE_ROOT:F3}=P(),q3=_l(),{recordAction:k3}=(ws(),ie(ml)),tL=x3(),V3="clustering",$3=q3.engines[Kt.NATS_SERVER_NAME],Y3=gl.join(F3,"dependencies"),bS=gl.join(Y3,`${process.platform}-${process.arch}`,Kt.NATS_BINARY_NAME),AS,OS,Tl,oo,ao;_L.exports={runCommand:rL,checkNATSServerInstalled:K3,createConnection:CS,getConnection:Rl,getJetStreamManager:Al,getJetStream:sL,getNATSReferences:is,getServerList:Q3,createLocalStream:DS,listStreams:iL,deleteLocalStream:z3,getServerConfig:la,listRemoteStreams:J3,viewStream:X3,viewStreamIterator:j3,publishToStream:Z3,request:rX,reloadNATS:LS,reloadNATSHub:nX,reloadNATSLeaf:sX,extractServerName:tX,requestErrorHandler:iX,createLocalTableStream:lL,createTableStreams:cX,purgeTableStream:uL,purgeSchemaTableStreams:lX,getStreamInfo:uX,updateLocalStreams:dX,closeConnection:W3,getJsmServerName:Ld,addNatsMsgHeader:oL,clearClientCache:nL,updateRemoteConsumer:oX,createConsumer:aL,updateConsumerIterator:aX};async function rL(e,t=void 0){let{stdout:r,stderr:n}=await I3(e,{cwd:t});if(n)throw new Error(n.replace(`
11
11
  `,""));return r.replace(`
12
12
  `,"")}a(rL,"runCommand");async function K3(){try{await O3.access(bS)}catch{return!1}let e=await rL(`${bS} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return b3.eq(t,$3)}a(K3,"checkNATSServerInstalled");async function CS(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let o=await eL.getClusterUser();if(lo(o))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=o.username,r=o.decrypt_hash}Bn.trace("create nats connection called");let i=await U3({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),Bn.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(o=>{o&&Bn.error("Error with Nats client connection, connection closed",o),nL()}),i}a(CS,"createConnection");function nL(){Tr=void 0,oo=void 0,ao=void 0,co=void 0}a(nL,"clearClientCache");async function W3(){Tr&&(await Tr.drain(),Tr=void 0,oo=void 0,ao=void 0,co=void 0)}a(W3,"closeConnection");var Tr,co;async function Rl(){return co||(co=CS(Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),Tr=await co),Tr||co}a(Rl,"getConnection");async function Al(){if(oo)return oo;lo(Tr)&&await Rl();let{domain:e}=la(Ie.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(lo(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return oo=await Tr.jetstreamManager({domain:e,timeout:6e4}),oo}a(Al,"getJetStreamManager");async function sL(){if(ao)return ao;lo(Tr)&&await Rl();let{domain:e}=la(Ie.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(lo(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return ao=Tr.jetstream({domain:e,timeout:6e4}),ao}a(sL,"getJetStream");async function is(){let e=Tr||await Rl(),t=oo||await Al(),r=ao||await sL();return{connection:e,jsm:t,js:r}}a(is,"getNATSReferences");async function Q3(e){let t=Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await eL.getClusterUser(),s=await CS(t,r,n),i=wS(),o=s.subscribe(i),c=[],l,_=(async()=>{for await(let u of o){let d=tL.decode(u.data);d.response_time=Date.now()-l,c.push(d)}})();return l=Date.now(),await s.publish("$SYS.REQ.SERVER.PING.VARZ",void 0,{reply:i}),await s.publish("$SYS.REQ.SERVER.PING",void 0,{reply:i}),await s.flush(),await Cd.async_set_timeout(e),await o.drain(),await s.close(),await _,c}a(Q3,"getServerList");async function DS(e,t){let{jsm:r}=await is(),n=Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:v3.File,retention:B3.Limits,subjects:t,discard:H3.Old,max_msgs:s,max_bytes:i,max_age:n})}a(DS,"createLocalStream");async function iL(){let{jsm:e}=await is(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}a(iL,"listStreams");async function z3(e){let{jsm:t}=await is();await t.streams.delete(e)}a(z3,"deleteLocalStream");async function J3(e){let{connection:t}=await is(),r=[],n=wS(),s=t.subscribe(n),i=(async()=>{for await(let o of s)r.push(tL.decode(o.data))})();return await t.publish(`$JS.${e}.API.STREAM.LIST`,void 0,{reply:n}),await t.flush(),await s.drain(),await i,r}a(J3,"listRemoteStreams");async function X3(e,t=void 0,r=void 0){let{jsm:n,js:s}=await is(),i=JD(),o={durable_name:i,ack_policy:NS.Explicit};t&&(o.deliver_policy=IS.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];let _=[];for await(let u of l){let d=yS(u.data),E={nats_timestamp:u.info.timestampNanos,nats_sequence:u.info.streamSequence,entry:d};if(u.headers&&(E.origin=u.headers.get(Kt.MSG_HEADERS.ORIGIN)),_.push(E),u.ack(),u.info.pending===0)break}return await c.delete(),_}a(X3,"viewStream");async function*j3(e,t=void 0,r=void 0){let{jsm:n,js:s}=await is(),i=JD(),o={durable_name:i,ack_policy:NS.Explicit};t&&(o.deliver_policy=IS.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];for await(let _ of l){let u=yS(_.data);u[0]||(u=[u]);for(let d of u){let E={nats_timestamp:_.info.timestampNanos,nats_sequence:_.info.streamSequence,entry:d};_.headers&&(E.origin=_.headers.get(Kt.MSG_HEADERS.ORIGIN)),yield E}if(_.ack(),_.info.pending===0)break}await c.delete()}a(j3,"viewStreamIterator");async function Z3(e,t,r,n){Bn.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=oL(n,r);let{js:s}=await is(),i=await Ld(),o=`${e}.${i}`,c=n instanceof Uint8Array?n:ZD.encode(n);try{Bn.trace(`publishToStream publishing to subject: ${o}`),k3(c.length,"bytes-sent",e,n.operation,"replication"),await s.publish(o,c,{headers:r})}catch(l){if(l.code&&l.code.toString()==="503")return cL(async()=>{try{await s.publish(o,c,{headers:r})}catch{if(l.code&&l.code.toString()==="503"){Bn.trace(`publishToStream creating stream: ${t}`);let u=o.split(".");u[2]="*",await DS(t,[o]),await s.publish(o,c,{headers:r})}else throw l}});throw l}}a(Z3,"publishToStream");function oL(e,t){t===void 0&&(t=G3());let r=Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(Kt.MSG_HEADERS.ORIGIN)&&r&&t.append(Kt.MSG_HEADERS.ORIGIN,r),t}a(oL,"addNatsMsgHeader");function la(e){e=e.toLowerCase();let t=gl.join(Ht.get(Ie.CONFIG_PARAMS.ROOTPATH),V3);if(e===Ie.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return lo(OS)&&(OS={port:Sl.getConfigFromFile(Ie.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:Sl.getConfigFromFile(Ie.CONFIG_PARAMS.CLUSTERING_NODENAME)+Kt.SERVER_SUFFIX.HUB,config_file:Kt.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:gl.join(t,Kt.PID_FILES.HUB),hdb_nats_path:t}),OS;if(e===Ie.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return lo(AS)&&(AS={port:Sl.getConfigFromFile(Ie.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:Sl.getConfigFromFile(Ie.CONFIG_PARAMS.CLUSTERING_NODENAME)+Kt.SERVER_SUFFIX.LEAF,config_file:Kt.NATS_CONFIG_FILES.LEAF_SERVER,domain:Sl.getConfigFromFile(Ie.CONFIG_PARAMS.CLUSTERING_NODENAME)+Kt.SERVER_SUFFIX.LEAF,pid_file_path:gl.join(t,Kt.PID_FILES.LEAF),hdb_nats_path:t}),AS;Bn.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(la,"getServerConfig");async function aL(e,t,r,n){try{await e.consumers.add(t,{ack_policy:NS.Explicit,durable_name:r,deliver_policy:IS.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}a(aL,"createConsumer");async function eX(e,t,r){await e.consumers.delete(t,r)}a(eX,"removeConsumer");function tX(e){return e.split(".")[1]}a(tX,"extractServerName");async function rX(e,t,r=6e4,n=wS()){if(!Cd.isObject(t))throw new Error("data param must be an object");let s=ZD.encode(t),{connection:i}=await is(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return yS(c.data)}a(rX,"request");function LS(e){return new Promise(async(t,r)=>{let n=w3(bS,["--signal",`reload=${e}`],{cwd:__dirname}),s,i;n.on("error",o=>{r(o)}),n.stdout.on("data",o=>{i+=o.toString()}),n.stderr.on("data",o=>{s+=o.toString()}),n.stderr.on("close",o=>{s&&r(s),t(i)})})}a(LS,"reloadNATS");async function nX(){let{pid_file_path:e}=la(Ie.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await LS(e)}a(nX,"reloadNATSHub");async function sX(){let{pid_file_path:e}=la(Ie.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await LS(e)}a(sX,"reloadNATSLeaf");function iX(e,t,r){let n;switch(e.code){case zD.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case zD.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}a(iX,"requestErrorHandler");async function oX(e,t){let r=t+Kt.SERVER_SUFFIX.LEAF,{connection:n}=await is(),{jsm:s}=await EX(r),{schema:i,table:o}=e,c=Dd.createNatsTableStreamName(i,o),l=e.start_time?e.start_time:new Date(Date.now()).toISOString();await cL(async()=>{if(e.subscribe===!0)await aL(s,c,n.info.server_name,l);else try{await eX(s,c,n.info.server_name)}catch(_){Bn.trace(_)}})}a(oX,"updateRemoteConsumer");async function aX(e,t,r,n){let s=Dd.createNatsTableStreamName(e,t),i=r+Kt.SERVER_SUFFIX.LEAF,o={type:Ie.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!jD&&M3()<Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=RS();await c(o)}await D3(o),n==="stop"&&await Cd.async_set_timeout(1e3)}a(aX,"updateConsumerIterator");function cL(e){return C3.writeTransaction(Ie.SYSTEM_SCHEMA_NAME,Ie.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(cL,"exclusiveLock");async function lL(e,t){let r=Dd.createNatsTableStreamName(e,t),n=await Ld(),s=_X(e,t,n);await DS(r,[s])}a(lL,"createLocalTableStream");async function cX(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await lL(n,s)}}a(cX,"createTableStreams");async function uL(e,t,r=void 0){if(Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=Dd.createNatsTableStreamName(e,t),{domain:s}=la(Ie.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await Rl()).jetstreamManager({domain:s,timeout:24e4})).streams.purge(n,r)}catch(n){if(n.message==="stream not found")Bn.warn(n);else throw n}}a(uL,"purgeTableStream");async function lX(e,t){if(Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await uL(e,t[r])}a(lX,"purgeSchemaTableStreams");async function uX(e){return(await Al()).streams.info(e)}a(uX,"getStreamInfo");function _X(e,t,r){return`${Kt.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}a(_X,"createSubjectName");async function Ld(){if(Tl)return Tl;if(Tl=(await Al())?.nc?.info?.server_name,Tl===void 0)throw new Error("Unable to get jetstream manager server name");return Tl}a(Ld,"getJsmServerName");async function dX(){let e=await Al(),t=await Ld(),r=await iL();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let o=fX(n),c=i.split(".");if(c[c.length-1]===t&&!o||s.name==="__HARPERDB_WORK_QUEUE__")continue;let _=i.split(".");_[_.length-1]=t;let u=_.join(".");Bn.trace(`Updating stream subject name from: ${i} to: ${u}`),s.subjects[0]=u,await e.streams.update(s.name,s)}}a(dX,"updateLocalStreams");function fX(e){let{config:t}=e,r=!1,n=Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=Ht.get(Ie.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);return i=i===null?-1:i,n!==t.max_age&&(t.max_age=n,r=!0),s!==t.max_bytes&&(t.max_bytes=s,r=!0),i!==t.max_msgs&&(t.max_msgs=i,r=!0),r}a(fX,"updateStreamLimits");async function EX(e){let t,r;try{t=await Tr.jetstream({domain:e}),r=await Tr.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw Bn.error("Unable to connect to:",e),n}return{js:t,jsm:r}}a(EX,"connectToRemoteJS")});var vd=g((pde,hL)=>{"use strict";var ua=x_(),_a=SD(),hX=K(),mX=require("uuid").v4,mde=require("clone"),Pd=bs(),da=P(),pX=require("util"),di=Ln(),{handleHDBError:gr,hdb_errors:SX}=se(),{HDB_ERROR_MSGS:Md,HTTP_STATUS_CODES:Rr}=SX,{SchemaEventMsg:Ud}=Mn(),dL=wt(),{getDatabases:TX}=(Ae(),ie(ke)),{transformReq:fa}=z();hL.exports={createSchema:gX,createSchemaStructure:fL,createTable:RX,createTableStructure:EL,createAttribute:NX,dropSchema:AX,dropTable:OX,dropAttribute:bX,getBackup:IX};async function gX(e){let t=await fL(e);return Pd.signalSchemaChange(new Ud(process.pid,e.operation,e.schema)),t}a(gX,"createSchema");async function fL(e){let t=ua.schema_object(e);if(t)throw gr(t,t.message,Rr.BAD_REQUEST,void 0,void 0,!0);if(fa(e),!await _a.checkSchemaExists(e.schema))throw gr(new Error,Md.SCHEMA_EXISTS_ERR(e.schema),Rr.BAD_REQUEST,da.LOG_LEVELS.ERROR,Md.SCHEMA_EXISTS_ERR(e.schema),!0);return await di.createSchema(e),`database '${e.schema}' successfully created`}a(fL,"createSchemaStructure");async function RX(e){return fa(e),e.hash_attribute=e.primary_key??e.hash_attribute,await EL(e)}a(RX,"createTable");async function EL(e){let t=ua.create_table_object(e);if(t)throw gr(t,t.message,Rr.BAD_REQUEST,void 0,void 0,!0);if(ua.validateTableResidence(e.residence),!await _a.checkSchemaTableExists(e.schema,e.table))throw gr(new Error,Md.TABLE_EXISTS_ERR(e.schema,e.table),Rr.BAD_REQUEST,da.LOG_LEVELS.ERROR,Md.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:mX(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await di.createTable(n,e);else throw gr(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",Rr.BAD_REQUEST);else await di.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}a(EL,"createTableStructure");async function AX(e){let t=!e.schema&&!e.database?new Error("database is required"):void 0,r=ua.schema_object(e),n=t??r;if(n)throw gr(n,n.message,Rr.BAD_REQUEST,void 0,void 0,!0);fa(e);let s=await _a.checkSchemaExists(e.schema);if(s)throw gr(new Error,s,Rr.NOT_FOUND,da.LOG_LEVELS.ERROR,s,!0);let i=await _a.schema_describe.describeSchema({schema:e.schema}),o=Object.keys(global.hdb_schema[e.schema]);return await di.dropSchema(e),Pd.signalSchemaChange(new Ud(process.pid,e.operation,e.schema)),await dL.purgeSchemaTableStreams(e.schema,o),`successfully deleted '${e.schema}'`}a(AX,"dropSchema");async function OX(e){let t=ua.table_object(e);if(t)throw gr(t,t.message,Rr.BAD_REQUEST,void 0,void 0,!0);fa(e);let r=await _a.checkSchemaTableExists(e.schema,e.table);if(r)throw gr(new Error,r,Rr.NOT_FOUND,da.LOG_LEVELS.ERROR,r,!0);return await di.dropTable(e),await dL.purgeTableStream(e.schema,e.table),`successfully deleted table '${e.schema}.${e.table}'`}a(OX,"dropTable");async function bX(e){let t=ua.attribute_object(e);if(t)throw gr(t,t.message,Rr.BAD_REQUEST,void 0,void 0,!0);fa(e);let r=await _a.checkSchemaTableExists(e.schema,e.table);if(r)throw gr(new Error,r,Rr.NOT_FOUND,da.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw gr(new Error,"You cannot drop a hash attribute",Rr.BAD_REQUEST,void 0,void 0,!0);if(da.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw gr(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,Rr.BAD_REQUEST,void 0,void 0,!0);try{return await di.dropAttribute(e),yX(e),Pd.signalSchemaChange(new Ud(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw hX.error(`Got an error deleting attribute ${pX.inspect(e)}.`),n}}a(bX,"dropAttribute");function yX(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(yX,"dropAttributeFromGlobal");async function NX(e){fa(e);let t=TX()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw gr(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,Rr.BAD_REQUEST,void 0,void 0,!0);return await di.createAttribute(e),Pd.signalSchemaChange(new Ud(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}a(NX,"createAttribute");function IX(e){return di.getBackup(e)}a(IX,"getBackup")});var pL=g((Tde,mL)=>{"use strict";var{OPERATIONS_ENUM:wX}=P(),MS=class{static{a(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=wX.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};mL.exports=MS});var PS=g((Ade,AL)=>{"use strict";var CX=Ln(),Rde=pL(),Bd=z(),Hd=P(),DX=ne(),{handleHDBError:SL,hdb_errors:LX}=se(),{HDB_ERROR_MSGS:TL,HTTP_STATUS_CODES:gL}=LX,MX=Object.values(Hd.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),RL="To use this operation audit log must be enabled in harperdb-config.yaml";AL.exports=PX;async function PX(e){if(Bd.isEmpty(e.schema))throw new Error(TL.SCHEMA_REQUIRED_ERR);if(Bd.isEmpty(e.table))throw new Error(TL.TABLE_REQUIRED_ERR);if(!DX.get(Hd.CONFIG_PARAMS.LOGGING_AUDITLOG))throw SL(new Error,RL,gL.BAD_REQUEST,Hd.LOG_LEVELS.ERROR,RL,!0);let t=Bd.checkSchemaTableExist(e.schema,e.table);if(t)throw SL(new Error,t,gL.NOT_FOUND,Hd.LOG_LEVELS.ERROR,t,!0);if(!Bd.isEmpty(e.search_type)&&MX.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await CX.readAuditLog(e)}a(PX,"readAuditLog")});var bL=g((bde,OL)=>{"use strict";var{OPERATIONS_ENUM:UX}=P(),US=class{static{a(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=UX.GET_BACKUP,this.schema=t,this.table=r}};OL.exports=US});var IL=g((wde,NL)=>{"use strict";var vX=Ln(),Nde=bL(),vS=z(),BX=P(),Ide=ne(),{handleHDBError:HX,hdb_errors:xX}=se(),{HDB_ERROR_MSGS:yL,HTTP_STATUS_CODES:GX}=xX;NL.exports=FX;async function FX(e){if(vS.isEmpty(e.schema))throw new Error(yL.SCHEMA_REQUIRED_ERR);if(vS.isEmpty(e.table))throw new Error(yL.TABLE_REQUIRED_ERR);let t=vS.checkSchemaTableExist(e.schema,e.table);if(t)throw HX(new Error,t,GX.NOT_FOUND,BX.LOG_LEVELS.ERROR,t,!0);return await vX.getBackup(read_audit_log_object)}a(FX,"getBackup")});var PL=g((Dde,ML)=>{var fi=require("validate.js"),CL=st(),Ea=P(),{handleHDBError:qX,hdb_errors:kX}=se(),{HDB_ERROR_MSGS:ht,HTTP_STATUS_CODES:VX}=kX,BS=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),$X={STRUCTURE_USER:"structure_user"},wL=Object.values(Ea.ROLE_TYPES_ENUM),YX="attribute_permissions",KX="attribute_name",{PERMS_CRUD_ENUM:ha}=Ea,WX=[YX,...Object.values(ha)],DL=[ha.READ,ha.INSERT,ha.UPDATE],QX=[KX,...DL];function zX(e){let t=BS();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,LL(e,t)}a(zX,"addRoleValidation");function JX(e){let t=BS();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,LL(e,t)}a(JX,"alterRoleValidation");function XX(e){let t=BS();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,CL.validateObject(e,t)}a(XX,"dropRoleValidation");var jX=["operation","role","id","permission","hdb_user","hdb_auth_header"];function LL(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)jX.includes(n[o])||s.push(n[o]);s.length>0&&Rt(ht.INVALID_ROLE_JSON_KEYS(s),r);let i=CL.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{Rt(o,r)}),e.permission){let o=ZX(e);o&&Rt(o,r),wL.forEach(c=>{e.permission[c]&&!fi.isBoolean(e.permission[c])&&Rt(ht.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(wL.indexOf(o)<0){if(o===$X.STRUCTURE_USER){let l=e.permission[o];if(typeof l=="boolean")continue;if(Array.isArray(l)){for(let _=0,u=l.length;_<u;_++){let d=l[_];global.hdb_schema[d]||Rt(ht.SCHEMA_NOT_FOUND(d),r)}continue}Rt(ht.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){Rt(ht.SCHEMA_NOT_FOUND(o),r);continue}if(c.tables)for(let l in c.tables){let _=c.tables[l];if(!l||!global.hdb_schema[o][l]){Rt(ht.TABLE_NOT_FOUND(o,l),r);continue}if(Object.keys(_).forEach(u=>{WX.includes(u)||Rt(ht.INVALID_PERM_KEY(u),r,o,l)}),Object.values(ha).forEach(u=>{fi.isDefined(_[u])?fi.isBoolean(_[u])||Rt(ht.TABLE_PERM_NOT_BOOLEAN(u),r,o,l):Rt(ht.TABLE_PERM_MISSING(u),r,o,l)}),fi.isDefined(_.attribute_permissions)){if(!fi.isArray(_.attribute_permissions)){Rt(ht.ATTR_PERMS_NOT_ARRAY,r,o,l);continue}}else{Rt(ht.ATTR_PERMS_ARRAY_MISSING,r,o,l);continue}if(_.attribute_permissions){let u=global.hdb_schema[o][l].attributes.map(({attribute:E})=>E),d={read:!1,insert:!1,update:!1};for(let E in _.attribute_permissions){let f=_.attribute_permissions[E];if(Object.keys(f).forEach(p=>{!QX.includes(p)&&p!==ha.DELETE&&Rt(ht.INVALID_ATTR_PERM_KEY(p),r,o,l)}),!fi.isDefined(f.attribute_name)){Rt(ht.ATTR_PERM_MISSING_NAME,r,o,l);continue}let h=f.attribute_name;if(!u.includes(h)){Rt(ht.INVALID_ATTRIBUTE_IN_PERMS(h),r,o,l);continue}DL.forEach(p=>{fi.isDefined(f[p])?fi.isBoolean(f[p])||Rt(ht.ATTR_PERM_NOT_BOOLEAN(p,h),r,o,l):Rt(ht.ATTR_PERM_MISSING(p,h),r,o,l)}),!d.read&&f.read===!0&&(d.read=!0),!d.insert&&f.insert===!0&&(d.insert=!0),!d.update&&f.update===!0&&(d.update=!0)}if(_.read===!1&&d.read===!0||_.insert===!1&&d.insert===!0||_.update===!1&&d.update===!0){let E=`${o}.${l}`;Rt(ht.MISMATCHED_TABLE_ATTR_PERMS(E),r,o,l)}}}}return ej(r)}a(LL,"customValidate");ML.exports={addRoleValidation:zX,alterRoleValidation:JX,dropRoleValidation:XX};function ZX(e){let{operation:t,permission:r}=e;if(t===Ea.OPERATIONS_ENUM.ADD_ROLE||t===Ea.OPERATIONS_ENUM.ALTER_ROLE){let n=r.super_user===!0,s=r.cluster_user===!0;if(Object.keys(r).length>1&&(n||s)){if(s&&n)return ht.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?Ea.ROLE_TYPES_ENUM.SUPER_USER:Ea.ROLE_TYPES_ENUM.CLUSTER_USER;return ht.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(ZX,"validateNoSUPerms");function ej(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:ht.ROLE_PERMS_ERROR,...e};return qX(new Error,n,VX.BAD_REQUEST)}else return null}a(ej,"generateRolePermResponse");function Rt(e,t,r,n){if(!r)t.main_permissions.push(e);else{let s=n?r+"_"+n:r;t.schema_permissions[s]?t.schema_permissions[s].push(e):t.schema_permissions[s]=[e]}}a(Rt,"addPermError")});var kS=g((Mde,HL)=>{"use strict";var UL=un(),vL=kr(),tj=Ji(),xS=PL(),GS=bs(),rj=require("uuid").v4,nj=require("util"),xd=P(),sj=z(),FS=vL.searchByValue,ij=vL.searchByHash,oj=nj.promisify(tj.delete),aj=ts(),cj=na(),{hdb_errors:lj,handleHDBError:uo}=se(),{HDB_ERROR_MSGS:BL,HTTP_STATUS_CODES:Ol}=lj,{UserEventMsg:qS}=Mn();HL.exports={addRole:uj,alterRole:_j,dropRole:dj,listRoles:fj};function HS(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(HS,"scrubRoleDetails");async function uj(e){let t=xS.addRoleValidation(e);if(t)throw t;e=HS(e);let r={schema:"system",table:"hdb_role",search_attribute:"role",search_value:e.role,hash_attribute:"id",get_attributes:["*"]},n;try{n=Array.from(await FS(r)||[])}catch(i){throw uo(i)}if(n&&n.length>0)throw uo(new Error,BL.ROLE_ALREADY_EXISTS(e.role),Ol.CONFLICT,void 0,void 0,!0);e.id||(e.id=rj());let s={operation:"insert",schema:"system",table:"hdb_role",hash_attribute:"id",records:[e]};return await UL.insert(s),GS.signalUserChange(new qS(process.pid)),e=HS(e),e}a(uj,"addRole");async function _j(e){let t=xS.alterRoleValidation(e);if(t)throw t;e=HS(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await UL.update(r)}catch(s){throw uo(s)}if(n&&n?.message==="updated 0 of 1 records")throw uo(new Error,"Invalid role id",Ol.BAD_REQUEST,void 0,void 0,!0);return await GS.signalUserChange(new qS(process.pid)),e}a(_j,"alterRole");async function dj(e){let t=xS.dropRoleValidation(e);if(t)throw uo(new Error,t,Ol.BAD_REQUEST,void 0,void 0,!0);let r=new cj(xd.SYSTEM_SCHEMA_NAME,xd.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await ij(r));if(n.length===0)throw uo(new Error,BL.ROLE_NOT_FOUND,Ol.NOT_FOUND,void 0,void 0,!0);let s=new aj(xd.SYSTEM_SCHEMA_NAME,xd.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await FS(s)),o=!1;if(sj.isEmptyOrZeroLength(i)===!1){for(let l=0;l<i.length;l++)if(i[l].active===!0){o=!0;break}}if(o===!0)throw uo(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,Ol.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await oj(c),GS.signalUserChange(new qS(process.pid)),`${n[0].role} successfully deleted`}a(dj,"dropRole");async function fj(){return FS({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(fj,"listRoles")});var qL=g((Ude,FL)=>{"use strict";var Ej=ne(),Ei=require("joi"),hj=st(),xL=require("moment"),mj=require("fs-extra"),VS=require("path"),pj=require("lodash"),bl=P(),{LOG_LEVELS:_o}=P(),Sj="YYYY-MM-DD hh:mm:ss",Tj=VS.resolve(__dirname,"../logs");FL.exports=function(e){return hj.validateBySchema(e,gj)};var gj=Ei.object({from:Ei.custom(GL),until:Ei.custom(GL),level:Ei.valid(_o.NOTIFY,_o.FATAL,_o.ERROR,_o.WARN,_o.INFO,_o.DEBUG,_o.TRACE),order:Ei.valid("asc","desc"),limit:Ei.number().min(1),start:Ei.number().min(0),log_name:Ei.custom(Rj)});function GL(e,t){if(xL(e,xL.ISO_8601).format(Sj)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(GL,"validateDatetime");function Rj(e,t){if(pj.invert(bl.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=Ej.get(bl.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?bl.LOG_NAMES.HDB:e,i=s===bl.LOG_NAMES.INSTALL?VS.join(Tj,bl.LOG_NAMES.INSTALL):VS.join(n,s);return mj.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(Rj,"validateReadLogPath")});var YS=g((Bde,VL)=>{"use strict";var Gd=P(),Aj=K(),Oj=ne(),bj=qL(),$S=require("path"),kL=require("fs-extra"),{once:yj}=require("events"),{handleHDBError:Nj,hdb_errors:Ij}=se(),{PACKAGE_ROOT:wj}=P(),Cj=$S.join(wj,"logs"),Dj=1e3,Lj=200;VL.exports=Mj;async function Mj(e){let t=bj(e);if(t)throw Nj(t,t.message,Ij.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=Oj.get(Gd.HDB_SETTINGS_NAMES.LOG_PATH_KEY),n=e.log_name===void 0?Gd.LOG_NAMES.HDB:e.log_name,s=n===Gd.LOG_NAMES.INSTALL?$S.join(Cj,Gd.LOG_NAMES.INSTALL):$S.join(r,n),i=e.level!==void 0,o=i?e.level:void 0,c=e.from!==void 0,l=c?new Date(e.from):void 0,_=e.until!==void 0,u=_?new Date(e.until):void 0,d=e.limit===void 0?Dj:e.limit,E=e.order===void 0?void 0:e.order,f=e.start===void 0?0:e.start,h=f+d,p=0;E==="desc"&&!l&&!u&&(p=Math.max(kL.statSync(s).size-(h+5)*Lj,0));let S=kL.createReadStream(s,{start:p});S.on("error",U=>{Aj.error(U)});let T=0,A=[],b="",I;S.on("data",U=>{let q=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;U=b+U;let M=0,Q;for(;(Q=q.exec(U))&&!S.destroyed;){I&&(I.message=U.slice(M,Q.index),B(I));let[J,X,oe]=Q,le=oe.split("] ["),ue=le[0],Be=le[1];le.splice(0,2),I={timestamp:X,thread:ue,level:Be,tags:le,message:""},M=Q.index+J.length}b=U.slice(M)}),S.on("end",U=>{S.destroyed||I&&(I.message=b.trim(),B(I))}),S.resume();function B(U){let q,M,Q;switch(!0){case(i&&c&&_):q=new Date(U.timestamp),M=new Date(l),Q=new Date(u),U.level===o&&q>=M&&q<=Q&&T<f?T++:U.level===o&&q>=M&&q<=Q&&(hi(U,E,A),T++,T===h&&S.destroy());break;case(i&&c):q=new Date(U.timestamp),M=new Date(l),U.level===o&&q>=M&&T<f?T++:U.level===o&&q>=M&&(hi(U,E,A),T++,T===h&&S.destroy());break;case(i&&_):q=new Date(U.timestamp),Q=new Date(u),U.level===o&&q<=Q&&T<f?T++:U.level===o&&q<=Q&&(hi(U,E,A),T++,T===h&&S.destroy());break;case(c&&_):q=new Date(U.timestamp),M=new Date(l),Q=new Date(u),q>=M&&q<=Q&&T<f?T++:q>=M&&q<=Q&&(hi(U,E,A),T++,T===h&&S.destroy());break;case i:U.level===o&&T<f?T++:U.level===o&&(hi(U,E,A),T++,T===h&&S.destroy());break;case c:q=new Date(U.timestamp),M=new Date(l),q>=M&&T<f?T++:q>=M&&T>=f&&(hi(U,E,A),T++,T===h&&S.destroy());break;case _:q=new Date(U.timestamp),Q=new Date(u),q<=Q&&T<f?T++:q<=Q&&T>=f&&(hi(U,E,A),T++,T===h&&S.destroy());break;default:T<f?T++:(hi(U,E,A),T++,T===h&&S.destroy())}}return a(B,"onLogMessage"),await yj(S,"close"),A}a(Mj,"readLog");function hi(e,t,r){t==="desc"?Pj(e,r):t==="asc"?Uj(e,r):r.push(e)}a(hi,"pushLineToResult");function Pj(e,t){let r=new Date(e.timestamp),n=0,s=t.length;for(;n<s;){let i=n+s>>>1;new Date(t[i].timestamp)>r?n=i+1:s=i}t.splice(n,0,e)}a(Pj,"insertDescending");function Uj(e,t){let r=new Date(e.timestamp),n=0,s=t.length;for(;n<s;){let i=n+s>>>1;new Date(t[i].timestamp)<r?n=i+1:s=i}t.splice(n,0,e)}a(Uj,"insertAscending")});var Fd=g((qde,WL)=>{"use strict";var KS=require("joi"),{string:yl,boolean:$L,date:vj}=KS.types(),Bj=st(),{validateSchemaExists:xde,validateTableExists:Gde,validateSchemaName:Fde}=Xn(),Hj=P(),xj=ct(),YL=ne();YL.initSync();var Gj=yl.invalid(YL.get(Hj.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(xj.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(),KL={operation:yl.valid("add_node","update_node","set_node_replication"),node_name:Gj,subscriptions:KS.array().items({table:yl.optional(),schema:yl.optional(),database:yl.optional(),subscribe:$L.required(),publish:$L.required().custom(qj),start_time:vj.iso()}).min(1).required()};function Fj(e){return Bj.validateBySchema(e,KS.object(KL))}a(Fj,"addUpdateNodeValidator");function qj(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(qj,"checkForFalsy");WL.exports={addUpdateNodeValidator:Fj,validation_schema:KL}});var zL=g((Vde,QL)=>{var kj=st(),Vj={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};QL.exports=function(e){return kj.validateObject(e,Vj)}});var QS=g(($de,JL)=>{"use strict";var $j=P().OPERATIONS_ENUM,WS=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=$j.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};JL.exports=WS});var jL=g((Kde,XL)=>{"use strict";var Yj={OPERATION:"operation",REFRESH:"refresh"},zS=class{static{a(this,"JWTTokens")}constructor(t,r){this.operation_token=t,this.refresh_token=r}},JS=class{static{a(this,"JWTRSAKeys")}constructor(t,r,n){this.public_key=t,this.private_key=r,this.passphrase=n}};XL.exports={JWTTokens:zS,TOKEN_TYPE_ENUM:Yj,JWTRSAKeys:JS}});var wl=g((Qde,rM)=>{"use strict";var Il=require("jsonwebtoken"),XS=require("fs-extra"),jS=z(),dn=P(),{handleHDBError:Ar,hdb_errors:Kj}=se(),{HTTP_STATUS_CODES:Or,AUTHENTICATION_ERROR_MSGS:br}=Kj,Nl=K(),ZL=z_(),tT=_n(),Wj=un().update,Qj=QS(),zj=bs(),{UserEventMsg:Jj}=Mn(),mi=ne();mi.initSync();var ZS=require("path"),{JWTTokens:Xj,JWTRSAKeys:jj,TOKEN_TYPE_ENUM:qd}=jL(),Zj=mi.get(dn.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY)?mi.get(dn.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY):"1d",eZ=mi.get(dn.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY)?mi.get(dn.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY):"30d",kd="RS256",eT;rM.exports={createTokens:tZ,validateOperationToken:nZ,refreshOperationToken:rZ,validateRefreshToken:tM};async function tZ(e){if(jS.isEmpty(e)||typeof e!="object")throw Ar(new Error,br.INVALID_AUTH_OBJECT,Or.BAD_REQUEST,void 0,void 0,!0);if(jS.isEmpty(e.username))throw Ar(new Error,br.USERNAME_REQUIRED,Or.BAD_REQUEST,void 0,void 0,!0);if(jS.isEmpty(e.password))throw Ar(new Error,br.PASSWORD_REQUIRED,Or.BAD_REQUEST,void 0,void 0,!0);let t;try{if(t=await tT.findAndValidateUser(e.username,e.password),!t)throw Ar(new Error,br.INVALID_CREDENTIALS,Or.UNAUTHORIZED,void 0,void 0,!0)}catch(E){throw Nl.error(E),Ar(new Error,br.INVALID_CREDENTIALS,Or.UNAUTHORIZED,void 0,void 0,!0)}let r=await Vd(),n=!1,s=!1;t.role&&t.role.permission&&(n=t.role.permission.super_user===!0,s=t.role.permission.cluster_user===!0);let i={username:e.username,super_user:n,cluster_user:s},o=await eM(i,r.private_key,r.passphrase),c=await Il.sign(i,{key:r.private_key,passphrase:r.passphrase},{expiresIn:eZ,algorithm:kd,subject:qd.REFRESH}),l=ZL.hash(c),_=new Qj(dn.SYSTEM_SCHEMA_NAME,dn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,[{username:e.username,refresh_token:l}]),u,d;try{u=await Wj(_)}catch(E){Nl.error(E),d=E}if(d!==void 0||u.skipped_hashes.length>0)throw Ar(new Error,br.REFRESH_TOKEN_SAVE_FAILED,Or.INTERNAL_SERVER_ERROR);return zj.signalUserChange(new Jj(process.pid)),new Xj(o,c)}a(tZ,"createTokens");async function eM(e,t,r){return await Il.sign(e,{key:t,passphrase:r},{expiresIn:Zj,algorithm:kd,subject:qd.OPERATION})}a(eM,"signOperationToken");async function Vd(){if(eT===void 0)try{let e=ZS.join(mi.getHdbBasePath(),dn.LICENSE_KEY_DIR_NAME,dn.JWT_ENUM.JWT_PASSPHRASE_NAME),t=ZS.join(mi.getHdbBasePath(),dn.LICENSE_KEY_DIR_NAME,dn.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r=ZS.join(mi.getHdbBasePath(),dn.LICENSE_KEY_DIR_NAME,dn.JWT_ENUM.JWT_PUBLIC_KEY_NAME),n=(await XS.readFile(e)).toString(),s=(await XS.readFile(t)).toString(),i=(await XS.readFile(r)).toString();eT=new jj(i,s,n)}catch(e){throw Nl.error(e),Ar(new Error,br.NO_ENCRYPTION_KEYS,Or.INTERNAL_SERVER_ERROR)}return eT}a(Vd,"getJWTRSAKeys");async function rZ(e){if(!e)throw Ar(new Error,br.INVALID_BODY,Or.BAD_REQUEST,void 0,void 0,!0);if(!e.refresh_token)throw Ar(new Error,br.REFRESH_TOKEN_REQUIRED,Or.BAD_REQUEST,void 0,void 0,!0);await tM(e.refresh_token);let t=await Vd(),r=await Il.decode(e.refresh_token);return{operation_token:await eM({username:r.username,super_user:r.super_user,cluster_user:r.cluster_user},t.private_key,t.passphrase)}}a(rZ,"refreshOperationToken");async function nZ(e){try{let t=await Vd(),r=await Il.verify(e,t.public_key,{algorithms:kd,subject:qd.OPERATION});return await tT.findAndValidateUser(r.username,void 0,!1)}catch(t){throw Nl.warn(t),t.name&&t.name==="TokenExpiredError"?Ar(new Error,br.TOKEN_EXPIRED,Or.FORBIDDEN):Ar(new Error,br.INVALID_TOKEN,Or.UNAUTHORIZED)}}a(nZ,"validateOperationToken");async function tM(e){let t;try{let r=await Vd(),n=await Il.verify(e,r.public_key,{algorithms:kd,subject:qd.REFRESH});t=await tT.findAndValidateUser(n.username,void 0,!1)}catch(r){throw Nl.warn(r),r.name&&r.name==="TokenExpiredError"?Ar(new Error,br.TOKEN_EXPIRED,Or.FORBIDDEN):Ar(new Error,br.INVALID_TOKEN,Or.UNAUTHORIZED)}if(!ZL.validate(t.refresh_token,e))throw Ar(new Error,br.INVALID_TOKEN,Or.UNAUTHORIZED);return t}a(tM,"validateRefreshToken")});var rT=g((Xde,iM)=>{"use strict";var sZ=zL(),ma=require("passport"),iZ=require("passport-local").Strategy,oZ=require("passport-http").BasicStrategy,aZ=require("util"),cZ=_n(),sM=aZ.callbackify(cZ.findAndValidateUser),Jde=vr(),lZ=P(),nM=wl();ma.use(new iZ(function(e,t,r){sM(e,t,r)}));ma.use(new oZ(function(e,t,r){sM(e,t,r)}));ma.serializeUser(function(e,t){t(null,e)});ma.deserializeUser(function(e,t){t(null,e)});function uZ(e,t,r){if(e.raw?.user!==void 0)return r(null,e.raw.user);let n,s;if(e.headers?.authorization){let o=e.headers.authorization.split(" ");n=o[0],s=o[1]}function i(o,c){return o?r(o):c?r(null,c):r("Must login")}switch(a(i,"handleResponse"),n){case"Basic":ma.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===lZ.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?nM.validateRefreshToken(s).then(o=>{e.body.refresh_token=s,r(null,o)}).catch(o=>{r(o)}):nM.validateOperationToken(s).then(o=>{r(null,o)}).catch(o=>{r(o)});break;default:ma.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(uZ,"authorize");function _Z(e,t){let r=sZ(e);if(r){t(r);return}let n={authorized:!0,messages:[]},s=e.user.role;if(!s?.permission)return t("Invalid role");let i=JSON.parse(s.permission);if(i.super_user)return t(null,n);if(!i[e.schema])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.schema} schema`),t(null,n);if(!i[e.schema].tables[e.table])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.table} table`),t(null,n);if(!i[e.schema].tables[e.table][e.operation])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.operation} on ${e.table} table`),t(null,n);if(i[e.schema].tables[e.table].attribute_permissions&&!e.attributes)return n.authorized=!1,n.messages.push(`${e.schema}.${e.table} has attribute permissions. Missing attributes to validate`),t(null,n);if(i[e.schema].tables[e.table].attribute_permissions&&e.attributes){let o=i[e.schema].tables[e.table].attribute_permissions;for(let c in o)e.attributes.indexOf(o[c].attribute_name)>-1&&!o[c][e.operation]&&(n.authorized=!1,n.messages.push(`Not authorized to ${e.operation} ${o[c].attribute_name} `))}return t(null,n)}a(_Z,"checkPermissions");iM.exports={authorize:uZ,checkPermissions:_Z}});var pa=g((Zde,oM)=>{"use strict";var nT=class{static{a(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},sT=class{static{a(this,"NodeSubscription")}constructor(t,r,n,s){this.schema=t,this.table=r,this.publish=n,this.subscribe=s}};oM.exports={Node:nT,NodeSubscription:sT}});var cM=g((tfe,aM)=>{"use strict";var dZ=P().OPERATIONS_ENUM,iT=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=dZ.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};aM.exports=iT});var Cl=g((nfe,lM)=>{"use strict";var oT=class{static{a(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},aT=class{static{a(this,"RemotePayloadSubscription")}constructor(t,r,n,s,i,o,c){this.schema=t,this.table=r,this.hash_attribute=n,this.publish=s,this.subscribe=i,this.start_time=o,c!==void 0&&(this.attributes=c)}};lM.exports={RemotePayloadObject:oT,RemotePayloadSubscription:aT}});var _M=g((ife,uM)=>{"use strict";var cT=class{static{a(this,"TableSizeObject")}constructor(t,r,n=0,s=0,i=0,o=0){this.schema=t,this.table=r,this.table_size=n,this.record_count=s,this.transaction_log_size=i,this.transaction_log_record_count=o}};uM.exports=cT});var EM=g((ufe,fM)=>{"use strict";var fZ=_M(),afe=dt(),dM=We(),EZ=K(),{getSchemaPath:cfe,getTransactionAuditStorePath:lfe}=ze(),{getDatabases:hZ}=(Ae(),ie(ke));fM.exports=mZ;async function mZ(e){let t=new fZ;try{let r=hZ()[e.schema]?.[e.name],n=r.primaryStore.getStats(),s=r.auditStore?.getStats(),i=await dM.environmentDataSize(schema_path,e.name),o=await dM.environmentDataSize(txn_path,e.name);t.schema=e.schema,t.table=e.name,t.table_size=i,t.record_count=n.entryCount,t.transaction_log_size=o,t.transaction_log_record_count=s.entryCount}catch(r){EZ.warn(`unable to stat table dbi due to ${r}`)}return t}a(mZ,"lmdbGetTableSize")});var mM=g((dfe,hM)=>{"use strict";var lT=class{static{a(this,"SystemInformationObject")}constructor(t,r,n,s,i,o,c){this.system=t,this.time=r,this.cpu=n,this.memory=s,this.disk=i,this.network=o,this.harperdb_processes=c}};hM.exports=lT});var Sa=g((Sfe,gM)=>{"use strict";var pZ=require("fs-extra"),SZ=require("path"),sr=require("systeminformation"),pi=K(),pM=wt(),Efe=ct(),Yd=P(),TZ=EM(),gZ=si(),{getThreadInfo:SM}=ot(),gT=ne();gT.initSync();var RZ=mM(),{openEnvironment:hfe}=We(),{getSchemaPath:mfe}=ze(),{database:pfe,databases:uT}=(Ae(),ie(ke)),$d;gM.exports={getHDBProcessInfo:ET,getNetworkInfo:mT,getDiskInfo:hT,getMemoryInfo:fT,getCPUInfo:dT,getTimeInfo:_T,getSystemInformation:pT,systemInformation:AZ,getTableSize:ST,getMetrics:TT};function _T(){return sr.time()}a(_T,"getTimeInfo");async function dT(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:o,governor:c,socket:l,cache:_,...u}=await sr.cpu();u.cpu_speed=await sr.cpuCurrentSpeed();let{raw_currentload:d,raw_currentload_idle:E,raw_currentload_irq:f,raw_currentload_nice:h,raw_currentload_system:p,raw_currentload_user:S,cpus:T,...A}=await sr.currentLoad();return A.cpus=[],T.forEach(b=>{let{raw_load:I,raw_load_idle:B,raw_load_irq:U,raw_load_nice:q,raw_load_system:M,raw_load_user:Q,...J}=b;A.cpus.push(J)}),u.current_load=A,u}catch(e){return pi.error(`error in getCPUInfo: ${e}`),{}}}a(dT,"getCPUInfo");async function fT(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await sr.mem();return Object.assign(s,process.memoryUsage())}catch(e){return pi.error(`error in getMemoryInfo: ${e}`),{}}}a(fT,"getMemoryInfo");async function ET(){let e={core:[],clustering:[]};try{let t=await sr.processes(),r;try{r=Number.parseInt(await pZ.readFile(SZ.join(gT.get(Yd.CONFIG_PARAMS.ROOTPATH),Yd.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===Yd.NODE_ERROR_CODES.ENOENT)pi.warn("Unable to locate 'hdb.pid' file, try stopping and starting HarperDB. This could be because HarperDB is not running.");else throw n}t.list.forEach(n=>{n.pid===r?e.core.push(n):n.name==="nats-server"&&e.clustering.push(n)});for(let n of e.core)for(let s of t.list)s.pid===n.parentPid&&(s.name==="PM2"||s.command==="PM2")&&(n.parent="PM2");return e}catch(t){return pi.error(`error in getHDBProcessInfo: ${t}`),e}}a(ET,"getHDBProcessInfo");async function hT(){let e={};try{let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await sr.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:l,..._}=await sr.fsStats();return e.read_write=_,e.size=await sr.fsSize(),e}catch(t){return pi.error(`error in getDiskInfo: ${t}`),e}}a(hT,"getDiskInfo");async function mT(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return e.default_interface=await sr.networkInterfaceDefault(),e.latency=await sr.inetChecksite("google.com"),(await sr.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:o,dhcp:c,dnsSuffix:l,ieee8021xAuth:_,ieee8021xState:u,carrier_changes:d,...E}=n;e.interfaces.push(E)}),(await sr.networkStats()).forEach(n=>{let{rx_sec:s,tx_sec:i,ms:o,...c}=n;e.stats.push(c)}),e}catch(t){return pi.error(`error in getNetworkInfo: ${t}`),e}}a(mT,"getNetworkInfo");async function pT(){if($d!==void 0)return $d;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:o,...c}=await sr.osInfo();e=c;let l=await sr.versions("node, npm");return e.node_version=l.node,e.npm_version=l.npm,$d=e,$d}catch(t){return pi.error(`error in getSystemInformation: ${t}`),e}}a(pT,"getSystemInformation");async function ST(){let e=[],t=await gZ.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await TZ(n));return e}a(ST,"getTableSize");async function TT(){let e={};for(let t in uT){let r=e[t]={},n=r.tables={};for(let s in uT[t])try{let i=uT[t][s];r.readers||(Object.assign(r,i.primaryStore.rootStore.getStats()),delete r.root,r.readers=i.primaryStore.rootStore.readerList().split(/\n\s+/).slice(1).map(l=>{let[_,u,d]=l.trim().split(" ");return{pid:_,thread:u,txnid:d}}),i.primaryStore.auditStore&&(r.audit=i.auditStore.getStats()));let o=i.primaryStore.getStats(),c={};for(let l of["treeDepth","treeBranchPageCount","treeLeafPageCount","entryCount","overflowPages"])c[l]=o[l];n[s]=c}catch(i){pi.notify(`Error getting stats for table ${s}: ${i}`)}}return e}a(TT,"getMetrics");async function TM(){if(gT.get(Yd.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{jsm:e}=await pM.getNATSReferences(),t=await pM.listStreams(),r=[];for(let n of t){let s=[],i=await e.consumers.list(n.config.name);for await(let c of i)s.push({name:c.name,created:c.created,num_ack_pending:c.num_ack_pending,num_redelivered:c.num_redelivered,num_waiting:c.num_waiting,num_pending:c.num_pending});let o={stream_name:n.config.name,database:n.config.subjects[0].split(".")[1],table:n.config.subjects[0].split(".")[2],state:n.state,consumers:s};r.push(o)}return r}}a(TM,"getNatsStreamInfo");async function AZ(e){let t=new RZ;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await pT(),t.time=_T(),t.cpu=await dT(),t.memory=await fT(),t.disk=await hT(),t.network=await mT(),t.harperdb_processes=await ET(),t.table_size=await ST(),t.metrics=await TT(),t.threads=await SM(),t.replication=await TM(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await pT();break;case"time":t.time=_T();break;case"cpu":t.cpu=await dT();break;case"memory":t.memory=await fT();break;case"disk":t.disk=await hT();break;case"network":t.network=await mT();break;case"harperdb_processes":t.harperdb_processes=await ET();break;case"table_size":t.table_size=await ST();break;case"database_metrics":case"metrics":t.metrics=await TT();break;case"threads":t.threads=await SM();break;case"replication":t.replication=await TM();break;default:break}return t}a(AZ,"systemInformation")});var Wd=g((gfe,RM)=>{"use strict";RM.exports={version:OZ,printVersion:bZ};var Kd=_l();function OZ(){if(Kd)return Kd.version}a(OZ,"version");function bZ(){Kd&&console.log(`HarperDB Version ${Kd.version}`)}a(bZ,"printVersion")});var Cs=g((bfe,yM)=>{"use strict";var yZ=un(),RT=z(),NZ=require("util"),fo=P(),AM=ne();AM.initSync();var IZ=rT(),OM=kr(),{Node:Afe,NodeSubscription:Ofe}=pa(),wZ=na(),CZ=cM(),{RemotePayloadObject:DZ,RemotePayloadSubscription:LZ}=Cl(),{handleHDBError:MZ,hdb_errors:PZ}=se(),{HTTP_STATUS_CODES:UZ,HDB_ERROR_MSGS:vZ}=PZ,BZ=ts(),HZ=Sa(),xZ=Wd(),{getDatabases:GZ}=(Ae(),ie(ke)),FZ=NZ.promisify(IZ.authorize),qZ=OM.searchByHash,kZ=OM.searchByValue;yM.exports={authHeaderToUser:VZ,isEmpty:$Z,getNodeRecord:YZ,upsertNodeRecord:KZ,buildNodePayloads:WZ,checkClusteringEnabled:QZ,getAllNodeRecords:zZ,getSystemInfo:JZ,reverseSubscription:bM};async function VZ(e){let t={headers:{authorization:e.hdb_auth_header}};return e.hdb_user=await FZ(t,null),e}a(VZ,"authHeaderToUser");function $Z(e){return e==null}a($Z,"isEmpty");async function YZ(e){let t=new wZ(fo.SYSTEM_SCHEMA_NAME,fo.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return qZ(t)}a(YZ,"getNodeRecord");async function KZ(e){let t=new CZ(fo.SYSTEM_SCHEMA_NAME,fo.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return yZ.upsert(t)}a(KZ,"upsertNodeRecord");function bM(e){if(RT.isEmpty(e.subscribe)||RT.isEmpty(e.publish))throw new Error("Received invalid subscription object");let{schema:t,table:r,hash_attribute:n}=e,s={schema:t,table:r,hash_attribute:n};return e.subscribe===!0&&e.publish===!1?(s.subscribe=!1,s.publish=!0):e.subscribe===!1&&e.publish===!0?(s.subscribe=!0,s.publish=!1):(s.subscribe=e.subscribe,s.publish=e.publish),s}a(bM,"reverseSubscription");function WZ(e,t,r,n){let s=[];for(let i=0,o=e.length;i<o;i++){let c=e[i],{schema:l,table:_}=c,u=RT.getTableHashAttribute(l,_),{subscribe:d,publish:E}=bM(c),f=GZ()[l]?.[_],h=new LZ(l,_,u,E,d,c.start_time,f.schemaDefined?f.attributes:void 0);s.push(h)}return new DZ(r,t,s,n)}a(WZ,"buildNodePayloads");function QZ(){if(!AM.get(fo.CONFIG_PARAMS.CLUSTERING_ENABLED))throw MZ(new Error,vZ.CLUSTERING_NOT_ENABLED,UZ.BAD_REQUEST,void 0,void 0,!0)}a(QZ,"checkClusteringEnabled");async function zZ(){let e=new BZ(fo.SYSTEM_SCHEMA_NAME,fo.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await kZ(e))}a(zZ,"getAllNodeRecords");async function JZ(){let e=await HZ.getSystemInformation();return{hdb_version:xZ.version(),node_version:e.node_version,platform:e.platform}}a(JZ,"getSystemInfo")});var AT=g((Nfe,PM)=>{"use strict";var Qd=wt(),NM=z(),IM=ct(),wM=P(),zd=K(),CM=vd(),XZ=Bp(),{RemotePayloadObject:jZ}=Cl(),{handleHDBError:DM,hdb_errors:ZZ}=se(),{HTTP_STATUS_CODES:LM}=ZZ,{NodeSubscription:MM}=pa();PM.exports=e5;async function e5(e,t){let r;try{r=await Qd.request(`${t}.${IM.REQUEST_SUFFIX}`,new jZ(wM.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),zd.trace("Response from remote describe all request:",r)}catch(o){zd.error(`addNode received error from describe all request to remote node: ${o}`);let c=Qd.requestErrorHandler(o,"add_node",t);throw DM(new Error,c,LM.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===IM.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let o=`Error returned from remote node ${t}: ${r.message}`;throw DM(new Error,o,LM.INTERNAL_SERVER_ERROR,"error",o)}let n=r.message,s=[],i=[];for(let o of e){let{table:c}=o,l=o.database??o.schema??"data";if(l===wM.SYSTEM_SCHEMA_NAME){await Qd.createLocalTableStream(l,c);let h=new MM(l,c,o.publish,o.subscribe);h.start_time=o.start_time,i.push(h);continue}let _=NM.doesSchemaExist(l),u=n[l]!==void 0,d=c?NM.doesTableExist(l,c):!0,E=c?n?.[l]?.[c]!==void 0:!0;if(!_&&!u||!d&&!E){s.push(o);continue}if(!_&&u&&(zd.trace(`addNode creating schema: ${l}`),await CM.createSchema({operation:"create_schema",schema:l})),!d&&E){zd.trace(`addNode creating table: ${c} in schema: ${l} with attributes ${JSON.stringify(n[l][c].attributes)}`);let h=new XZ(l,c,n[l][c].hash_attribute);n[l][c].attributes&&(h.attributes=n[l][c].attributes),await CM.createTable(h)}await Qd.createLocalTableStream(l,c);let f=new MM(l,c,o.publish,o.subscribe);f.start_time=o.start_time,i.push(f)}return{added:i,skipped:s}}a(e5,"reviewSubscriptions")});var Zd=g((wfe,BM)=>{"use strict";var{handleHDBError:Jd,hdb_errors:t5}=se(),{HTTP_STATUS_CODES:Xd}=t5,{addUpdateNodeValidator:r5}=Fd(),jd=K(),vM=P(),UM=ct(),n5=z(),Dl=wt(),Ll=Cs(),s5=ne(),i5=AT(),{Node:o5,NodeSubscription:a5}=pa(),{broadcast:c5}=ot(),l5="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",u5="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",_5=s5.get(vM.CONFIG_PARAMS.CLUSTERING_NODENAME);BM.exports=d5;async function d5(e,t=!1){jd.trace("addNode called with:",e),Ll.checkClusteringEnabled();let r=r5(e);if(r)throw Jd(r,r.message,Xd.BAD_REQUEST,void 0,void 0,!0);let n=e.node_name;if(!t){let d=await Ll.getNodeRecord(n);if(!n5.isEmptyOrZeroLength(d))throw Jd(new Error,`Node '${n}' has already been added, perform update_node to proceed.`,Xd.BAD_REQUEST,void 0,void 0,!0)}let{added:s,skipped:i}=await i5(e.subscriptions,n),o={message:void 0,added:s,skipped:i};if(s.length===0)return o.message=l5,o;let c=Ll.buildNodePayloads(s,_5,vM.OPERATIONS_ENUM.ADD_NODE,await Ll.getSystemInfo()),l=[];for(let d=0,E=s.length;d<E;d++){let f=s[d];s[d].start_time===void 0&&delete s[d].start_time,l.push(new a5(f.schema,f.table,f.publish,f.subscribe))}jd.trace("addNode sending remote payload:",c);let _;try{_=await Dl.request(`${n}.${UM.REQUEST_SUFFIX}`,c)}catch(d){jd.error(`addNode received error from request: ${d}`);for(let f=0,h=s.length;f<h;f++){let p=s[f];p.publish=!1,p.subscribe=!1,await Dl.updateRemoteConsumer(p,n)}let E=Dl.requestErrorHandler(d,"add_node",n);throw Jd(new Error,E,Xd.INTERNAL_SERVER_ERROR,"error",E)}if(_.status===UM.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let d=`Error returned from remote node ${n}: ${_.message}`;throw Jd(new Error,d,Xd.INTERNAL_SERVER_ERROR,"error",d)}jd.trace(_);for(let d=0,E=s.length;d<E;d++){let f=s[d];await Dl.updateRemoteConsumer(f,n),f.subscribe===!0&&await Dl.updateConsumerIterator(f.schema,f.table,n,"start")}let u=new o5(n,l,_.system_info);return await Ll.upsertNodeRecord(u),c5({type:"nats_update"}),i.length>0?o.message=u5:o.message=`Successfully added '${n}' to manifest`,o}a(d5,"addNode")});var yT=g((Lfe,GM)=>{"use strict";var{handleHDBError:OT,hdb_errors:f5}=se(),{HTTP_STATUS_CODES:bT}=f5,{addUpdateNodeValidator:E5}=Fd(),Ml=K(),xM=P(),HM=ct(),Dfe=z(),Pl=wt(),Ul=Cs(),h5=ne(),{cloneDeep:m5}=require("lodash"),p5=AT(),{Node:S5,NodeSubscription:T5}=pa(),{broadcast:g5}=ot(),R5="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",A5="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",O5=h5.get(xM.CONFIG_PARAMS.CLUSTERING_NODENAME);GM.exports=b5;async function b5(e){Ml.trace("updateNode called with:",e),Ul.checkClusteringEnabled();let t=E5(e);if(t)throw OT(t,t.message,bT.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await Ul.getNodeRecord(r);s.length>0&&(n=m5(s));let{added:i,skipped:o}=await p5(e.subscriptions,r),c={message:void 0,updated:i,skipped:o};if(i.length===0)return c.message=R5,c;let l=Ul.buildNodePayloads(i,O5,xM.OPERATIONS_ENUM.UPDATE_NODE,await Ul.getSystemInfo());for(let u=0,d=i.length;u<d;u++){let E=i[u];Ml.trace(`updateNode updating work stream for node: ${r} subscription:`,E),i[u].start_time===void 0&&delete i[u].start_time}Ml.trace("updateNode sending remote payload:",l);let _;try{_=await Pl.request(`${r}.${HM.REQUEST_SUFFIX}`,l)}catch(u){Ml.error(`updateNode received error from request: ${u}`);let d=Pl.requestErrorHandler(u,"update_node",r);throw OT(new Error,d,bT.INTERNAL_SERVER_ERROR,"error",d)}if(_.status===HM.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let u=`Error returned from remote node ${r}: ${_.message}`;throw OT(new Error,u,bT.INTERNAL_SERVER_ERROR,"error",u)}Ml.trace(_);for(let u=0,d=i.length;u<d;u++){let E=i[u];await Pl.updateRemoteConsumer(E,r),E.subscribe===!0?await Pl.updateConsumerIterator(E.schema,E.table,r,"start"):await Pl.updateConsumerIterator(E.schema,E.table,r,"stop")}return n||(n=[new S5(r,[],_.system_info)]),await y5(n[0],i,_.system_info),o.length>0?c.message=A5:c.message=`Successfully updated '${r}'`,c}a(b5,"updateNode");async function y5(e,t,r){let n=e;for(let s=0,i=t.length;s<i;s++){let o=t[s],c=!1;for(let l=0,_=e.subscriptions.length;l<_;l++){let u=n.subscriptions[l];if(u.schema===o.schema&&u.table===o.table){u.publish=o.publish,u.subscribe=o.subscribe,c=!0;break}}c||n.subscriptions.push(new T5(o.schema,o.table,o.publish,o.subscribe))}n.system_info=r,await Ul.upsertNodeRecord(n),g5({type:"nats_update"})}a(y5,"updateNodeTable")});var $M=g((Pfe,VM)=>{"use strict";var kM=require("joi"),{string:FM}=kM.types(),N5=st(),qM=P(),I5=ne(),w5=ct();VM.exports=C5;function C5(e){let t=FM.invalid(I5.get(qM.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(w5.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=kM.object({operation:FM.valid(qM.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return N5.validateBySchema(e,r)}a(C5,"removeNodeValidator")});var tf=g((vfe,zM)=>{"use strict";var{handleHDBError:YM,hdb_errors:D5}=se(),{HTTP_STATUS_CODES:KM}=D5,L5=$M(),vl=K(),WM=Cs(),M5=z(),ef=P(),QM=ct(),NT=wt(),P5=ne(),{RemotePayloadObject:U5}=Cl(),{NodeSubscription:v5}=pa(),B5=nl(),H5=Ji(),{broadcast:x5}=ot(),G5=P5.get(ef.CONFIG_PARAMS.CLUSTERING_NODENAME);zM.exports=F5;async function F5(e){vl.trace("removeNode called with:",e),WM.checkClusteringEnabled();let t=L5(e);if(t)throw YM(t,t.message,KM.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await WM.getNodeRecord(r);if(M5.isEmptyOrZeroLength(n))throw YM(new Error,`Node '${r}' was not found.`,KM.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new U5(ef.OPERATIONS_ENUM.REMOVE_NODE,G5,[]),i,o=!1;for(let l=0,_=n.subscriptions.length;l<_;l++){let u=n.subscriptions[l];u.subscribe===!0&&await NT.updateConsumerIterator(u.schema,u.table,r,"stop");try{await NT.updateRemoteConsumer(new v5(u.schema,u.table,!1,!1),r)}catch(d){vl.error(d)}}try{i=await NT.request(`${r}.${QM.REQUEST_SUFFIX}`,s),vl.trace("Remove node reply from remote node:",r,i)}catch(l){vl.error("removeNode received error from request:",l),o=!0}let c=new B5(ef.SYSTEM_SCHEMA_NAME,ef.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await H5.deleteRecord(c),x5({type:"nats_update"}),i?.status===QM.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||o?(vl.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(F5,"removeNode")});var jM=g((Hfe,XM)=>{"use strict";var JM=require("joi"),{string:q5,array:k5}=JM.types(),V5=st(),$5=Fd();XM.exports=Y5;function Y5(e){let t=JM.object({operation:q5.valid("configure_cluster").required(),connections:k5.items($5.validation_schema).required()});return V5.validateBySchema(e,t)}a(Y5,"configureClusterValidator")});var IT=g((Gfe,nP)=>{"use strict";var K5=P(),rf=K(),W5=z(),Q5=tf(),z5=Zd(),ZM=Cs(),J5=jM(),{handleHDBError:eP,hdb_errors:X5}=se(),{HTTP_STATUS_CODES:tP}=X5,j5="Configure cluster complete.",Z5="Failed to configure the cluster. Check the logs for more details.",e8="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";nP.exports=t8;async function t8(e){rf.trace("configure cluster called with:",e),ZM.checkClusteringEnabled();let t=J5(e);if(t)throw eP(t,t.message,tP.BAD_REQUEST,void 0,void 0,!0);let r=await ZM.getAllNodeRecords(),n=[];for(let u=0,d=r.length;u<d;u++){let E=await rP(Q5,{operation:K5.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[u].name},r[u].name);n.push(E)}rf.trace("All results from configure_cluster remove node:",n);let s=[],i=e.connections.length;for(let u=0;u<i;u++){let d=e.connections[u],E=await rP(z5,d,d.node_name);s.push(E)}rf.trace("All results from configure_cluster add node:",s);let o=[],c=[],l=!1,_=n.concat(s);for(let u=0,d=_.length;u<d;u++){let E=_[u];E.status==="rejected"&&(rf.error(E),o.includes(E.node_name)||o.push(E.node_name)),(E?.result?.message?.includes?.("Successfully")||E?.result?.includes?.("Successfully"))&&(l=!0),!(typeof E.result=="string"&&E.result.includes("Successfully removed")||E.status==="rejected")&&c.push({node_name:E?.node_name,subscriptions:E?.result})}if(W5.isEmptyOrZeroLength(o))return{message:j5,connections:c};if(l)return{message:e8,failed_nodes:o,connections:c};throw eP(new Error,Z5,tP.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(t8,"configureCluster");async function rP(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){return{node_name:r,error:n,status:"rejected"}}}a(rP,"functionWrapper")});var aP=g((qfe,oP)=>{"use strict";var Bl=require("joi"),r8=st(),{validateSchemaExists:sP,validateTableExists:n8,validateSchemaName:iP}=Xn(),s8=Bl.object({operation:Bl.string().valid("purge_stream"),schema:Bl.string().custom(sP).custom(iP).optional(),database:Bl.string().custom(sP).custom(iP).optional(),table:Bl.string().custom(n8).required()});function i8(e){return r8.validateBySchema(e,s8)}a(i8,"purgeStreamValidator");oP.exports=i8});var wT=g((Vfe,cP)=>{"use strict";var{handleHDBError:o8,hdb_errors:a8}=se(),{HTTP_STATUS_CODES:c8}=a8,l8=aP(),u8=wt(),_8=Cs();cP.exports=d8;async function d8(e){e.schema=e.schema??e.database;let t=l8(e);if(t)throw o8(t,t.message,c8.BAD_REQUEST,void 0,void 0,!0);_8.checkClusteringEnabled();let{schema:r,table:n,options:s}=e;return await u8.purgeTableStream(r,n,s),`Successfully purged table '${r}.${n}'`}a(d8,"purgeStream")});var LT=g((Yfe,EP)=>{"use strict";var DT=Cs(),f8=wt(),_P=ne(),nf=P(),Eo=ct(),E8=z(),CT=K(),{RemotePayloadObject:h8}=Cl(),{ErrorCode:lP}=require("nats"),uP=_P.get(nf.CONFIG_PARAMS.CLUSTERING_ENABLED),dP=_P.get(nf.CONFIG_PARAMS.CLUSTERING_NODENAME);EP.exports={clusterStatus:m8,buildNodeStatus:fP};async function m8(){let e={node_name:dP,is_enabled:uP,connections:[]};if(!uP)return e;let t=await DT.getAllNodeRecords();if(E8.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(fP(t[n],e.connections));return await Promise.allSettled(r),e}a(m8,"clusterStatus");async function fP(e,t){let r=e.name,n=new h8(nf.OPERATIONS_ENUM.CLUSTER_STATUS,dP,void 0,await DT.getSystemInfo()),s,i,o=Eo.CLUSTER_STATUS_STATUSES.OPEN;try{let l=Date.now();s=await f8.request(Eo.REQUEST_SUBJECT(r),n),i=Date.now()-l,s.status===Eo.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=Eo.CLUSTER_STATUS_STATUSES.CLOSED,CT.error(`Error getting node status from ${r} `,s))}catch(l){CT.warn(`Error getting node status from ${r}`,l),l.code===lP.NoResponders?o=Eo.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:l.code===lP.Timeout?o=Eo.CLUSTER_STATUS_STATUSES.TIMEOUT:o=Eo.CLUSTER_STATUS_STATUSES.CLOSED}let c=new p8(r,o,s?.message?.ports?.clustering,s?.message?.ports?.operations_api,i,s?.message?.uptime,e.subscriptions,s?.message?.system_info);try{let l={name:r,system_info:s?.message?.system_info};e.system_info?.hdb_version!==nf.PRE_4_0_0_VERSION&&await DT.upsertNodeRecord(l)}catch(l){CT.error("Cluster status encountered an error updating system info for node:",r,l)}t.push(c)}a(fP,"buildNodeStatus");function p8(e,t,r,n,s,i,o,c){this.node_name=e,this.status=t,this.ports={clustering:r,operations_api:n},this.latency_ms=s,this.uptime=i,this.subscriptions=o,this.system_info=c}a(p8,"NodeStatusObject")});var PT=g((Wfe,hP)=>{"use strict";var{handleHDBError:S8,hdb_errors:T8}=se(),{HTTP_STATUS_CODES:g8}=T8,R8=wt(),A8=Cs(),MT=z(),sf=require("joi"),O8=st(),b8=2e3,y8=sf.object({timeout:sf.number().min(1),connected_nodes:sf.boolean(),routes:sf.boolean()});hP.exports=N8;async function N8(e){A8.checkClusteringEnabled();let t=O8.validateBySchema(e,y8);if(t)throw S8(t,t.message,g8.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||MT.autoCastBoolean(n),o=s===void 0||MT.autoCastBoolean(s),c={nodes:[]},l=await R8.getServerList(r??b8),_={};if(i)for(let u=0,d=l.length;u<d;u++){let E=l[u].statsz;E&&(_[l[u].server.name]=E.routes)}for(let u=0,d=l.length;u<d;u++){if(l[u].statsz)continue;let E=l[u].server,f=l[u].data;if(E.name.endsWith("-hub")){let h={name:E.name.slice(0,-4),response_time:l[u].response_time};i&&(h.connected_nodes=[],_[E.name]&&_[E.name].forEach(p=>{h.connected_nodes.includes(p.name.slice(0,-4))||h.connected_nodes.push(p.name.slice(0,-4))})),o&&(h.routes=f.cluster?.urls?f.cluster?.urls.map(p=>({host:p.split(":")[0],port:MT.autoCast(p.split(":")[1])})):[]),c.nodes.push(h)}}return c}a(N8,"clusterNetwork")});var TP=g((zfe,SP)=>{"use strict";var UT=require("joi"),mP=st(),{route_constraints:pP}=Bh();SP.exports={setRoutesValidator:I8,deleteRoutesValidator:w8};function I8(e){let t=UT.object({server:UT.valid("hub","leaf").required(),routes:pP.required()});return mP.validateBySchema(e,t)}a(I8,"setRoutesValidator");function w8(e){let t=UT.object({routes:pP.required()});return mP.validateBySchema(e,t)}a(w8,"deleteRoutesValidator")});var BT=g((Xfe,OP)=>{"use strict";var ho=dr(),vT=z(),of=P(),gP=TP(),{handleHDBError:RP,hdb_errors:C8}=se(),{HTTP_STATUS_CODES:AP}=C8,D8="cluster routes successfully set",L8="cluster routes successfully deleted";OP.exports={setRoutes:M8,getRoutes:P8,deleteRoutes:U8};function M8(e){let t=gP.setRoutesValidator(e);if(t)throw RP(t,t.message,AP.BAD_REQUEST,void 0,void 0,!0);let r=ho.getClusteringRoutes(),n=e.server==="hub"?r.hub_routes:r.leaf_routes,s=e.server==="hub"?r.leaf_routes:r.hub_routes,i=[],o=[];for(let c=0,l=e.routes.length;c<l;c++){let _=e.routes[c];_.port=vT.autoCast(_.port);let u=n.some(E=>E.host===_.host&&E.port===_.port),d=s.some(E=>E.host===_.host&&E.port===_.port);u||d?i.push(_):(n.push(_),o.push(_))}return e.server==="hub"?ho.updateConfigValue(of.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,n):ho.updateConfigValue(of.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n),{message:D8,set:o,skipped:i}}a(M8,"setRoutes");function P8(){let e=ho.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}a(P8,"getRoutes");function U8(e){let t=gP.deleteRoutesValidator(e);if(t)throw RP(t,t.message,AP.BAD_REQUEST,void 0,void 0,!0);let r=ho.getClusteringRoutes(),n=r.hub_routes,s=r.leaf_routes,i=[],o=[],c=!1,l=!1;for(let _=0,u=e.routes.length;_<u;_++){let d=e.routes[_],E=!1;for(let f=0,h=n.length;f<h;f++){let p=n[f];if(d.host===p.host&&d.port===p.port){n.splice(f,1),E=!0,c=!0,i.push(d);break}}if(!E){let f=!0;for(let h=0,p=s.length;h<p;h++){let S=s[h];if(d.host===S.host&&d.port===S.port){s.splice(h,1),l=!0,f=!1,i.push(d);break}}f&&o.push(d)}}return c&&(n=vT.isEmptyOrZeroLength(n)?null:n,ho.updateConfigValue(of.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,n)),l&&(s=vT.isEmptyOrZeroLength(s)?null:s,ho.updateConfigValue(of.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,s)),{message:L8,deleted:i,skipped:o}}a(U8,"deleteRoutes")});var yP=g((Zfe,bP)=>{"use strict";var Hl=require("alasql"),mo=require("recursive-iterator"),Hn=K(),v8=z(),xl=P(),HT=class{static{a(this,"sql_statement_bucket")}constructor(t){this.ast=t,this.affected_attributes=new Map,this.table_lookup=new Map,this.schema_lookup=new Map,this.table_to_schema_lookup=new Map,H8(this.ast,this.affected_attributes,this.table_lookup,this.schema_lookup,this.table_to_schema_lookup)}getAttributesBySchemaTableName(t,r){if(!t||!r||!this.affected_attributes)return[];if(this.affected_attributes.has(t))return!this.affected_attributes.get(t).has(r)&&(r=this.table_lookup.get(r),!r)?[]:this.affected_attributes.get(t).get(r)}getAllTables(){let t=[];if(!this.affected_attributes)return t;for(let r of this.affected_attributes.keys())t.push(Array.from(this.affected_attributes.get(r).keys()));return t}getTablesBySchemaName(t){return!t||!this.affected_attributes?[]:Array.from(this.affected_attributes.get(t).keys())}getSchemas(){return this.affected_attributes?Array.from(this.affected_attributes.keys()):[]}getAst(){return this.ast}updateAttributeWildcardsForRolePerms(t){let r=this.ast.columns.filter(s=>xl.SEARCH_WILDCARDS.includes(s.columnid));if(r.length===0)return this.ast;let n=this.ast.from[0].databaseid;return this.ast.columns=this.ast.columns.filter(s=>!xl.SEARCH_WILDCARDS.includes(s.columnid)),r.forEach(s=>{let i=this.table_to_schema_lookup.has(s.tableid)?this.table_to_schema_lookup.get(s.tableid):n,o=this.table_lookup.has(s.tableid)?this.table_lookup.get(s.tableid):this.ast.from[0].tableid;if(t[i]&&t[i].tables[o]&&t[i].tables[o][xl.PERMS_CRUD_ENUM.READ]){let c;t[i].tables[o].attribute_permissions.length>0?c=B8(t[i].tables[o].attribute_permissions):c=global.hdb_schema[i][o].attributes.map(_=>({attribute_name:_.attribute}));let l=this.affected_attributes.get(i).get(o).filter(_=>!xl.SEARCH_WILDCARDS.includes(_));c.forEach(({attribute_name:_})=>{let u=new Hl.yy.Column({columnid:_});s.tableid&&(u.tableid=s.tableid),this.ast.columns.push(u),l.includes(_)||l.push(_)}),this.affected_attributes.get(i).set(o,l)}}),this.ast}};function B8(e){return e.filter(t=>t[xl.PERMS_CRUD_ENUM.READ])}a(B8,"filterReadRestrictedAttrs");function H8(e,t,r,n,s){x8(e,t,r,n,s)}a(H8,"interpretAST");function Gl(e,t,r,n,s){if(!(!e||!e.databaseid)&&(t.has(e.databaseid)||t.set(e.databaseid,new Map),t.get(e.databaseid).has(e.tableid)||t.get(e.databaseid).set(e.tableid,[]),e.as&&(r.has(e.as)||r.set(e.as,e.tableid),n&&!n.has(e.as)&&n.set(e.as,e.databaseid)),s)){let i=e.databaseid,o=e.tableid;e.as&&(o=e.as),s.set(o,i)}}a(Gl,"addSchemaTableToMap");function x8(e,t,r,n,s){if(!e){Hn.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof Hl.yy.Insert?k8(e,t,r):e instanceof Hl.yy.Select?G8(e,t,r,n,s):e instanceof Hl.yy.Update?F8(e,t,r):e instanceof Hl.yy.Delete?q8(e,t,r):Hn.error("AST in getRecordAttributesAST() is not a valid SQL type.")}a(x8,"getRecordAttributesAST");function G8(e,t,r,n,s){if(!e){Hn.info("getSelectAttributes: invalid SQL syntax tree");return}if(!e.from||e.from[0]===void 0)return;let i=e.from[0].databaseid;if(v8.isEmptyOrZeroLength(i)){Hn.error("No schema specified");return}e.from.forEach(c=>{Gl(c,t,r,n,s)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),Gl(c.table,t,r,n,s)});let o=new mo(e.columns);for(let{node:c}of o)if(c&&c.columnid){let l=c.tableid,_=n.has(l)?n.get(l):i;if(l||(l=e.from[0].tableid),!t.get(_).has(l))if(r.has(l))l=r.get(l);else{Hn.info(`table specified as ${l} not found.`);return}t.get(_).get(l).indexOf(c.columnid)<0&&t.get(_).get(l).push(c.columnid)}if(e.where){let c=new mo(e.where),l=e.from[0].tableid;for(let{node:_}of c)if(_&&_.columnid){let u=_.tableid?_.tableid:l;if(!t.get(i).has(u))if(r.has(u))u=r.get(u);else{Hn.info(`table specified as ${u} not found.`);continue}t.get(i).get(u).indexOf(_.columnid)<0&&t.get(i).get(u).push(_.columnid)}}if(e.joins&&e.joins.forEach(c=>{let l=new mo(c.on);for(let{node:_}of l)if(_&&_.columnid){let u=_.tableid,d=s.get(u);if(!t.get(d).has(u))if(r.has(u))u=r.get(u);else{Hn.info(`table specified as ${u} not found.`);continue}t.get(d).get(u).indexOf(_.columnid)<0&&t.get(d).get(u).push(_.columnid)}}),e.order){let c=new mo(e.order);for(let{node:l}of c)if(l&&l.columnid){let _=l.tableid,u=n.has(_)?n.get(_):i;if(_||(_=e.from[0].tableid),!t.get(u).has(_))if(r.has(_))_=r.get(_);else{Hn.info(`table specified as ${_} not found.`);return}t.get(u).get(_).indexOf(l.columnid)<0&&t.get(u).get(_).push(l.columnid)}}}a(G8,"getSelectAttributes");function F8(e,t,r){if(!e){Hn.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new mo(e.columns),s=e.table.databaseid;Gl(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&xT(e.table.tableid,s,i.columnid,t,r)}a(F8,"getUpdateAttributes");function q8(e,t,r){if(!e){Hn.info("getDeleteAttributes: invalid SQL syntax tree");return}let n=new mo(e.where),s=e.table.databaseid;Gl(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&xT(e.table.tableid,s,i.columnid,t,r)}a(q8,"getDeleteAttributes");function k8(e,t,r){if(!e){Hn.info("getInsertAttributes: invalid SQL syntax tree");return}let n=new mo(e.columns),s=e.into.databaseid;Gl(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&xT(e.into.tableid,s,i.columnid,t,r)}a(k8,"getInsertAttributes");function xT(e,t,r,n,s){if(!n.get(t))return;let i=e;n.get(t).has(i)||(i=s.get(i)),n.get(t).get(i).push(r)}a(xT,"pushAttribute");bP.exports=HT});var qT=g((tEe,CP)=>{var af=Xi(),NP=require("chalk"),Qr=K(),IP=require("prompt"),{promisify:V8}=require("util"),GT=P(),$8=require("fs-extra"),Y8=require("path"),K8=z(),W8=Wd(),wP=ne();wP.initSync();var Q8=require("moment"),z8=V8(IP.get),J8=Y8.join(wP.getHdbBasePath(),GT.LICENSE_KEY_DIR_NAME,GT.LICENSE_FILE_NAME,GT.LICENSE_FILE_NAME);CP.exports={getFingerprint:j8,setLicense:X8,parseLicense:FT,register:Z8,getRegistrationInfo:t6};async function X8(e){if(e&&e.key&&e.company){try{Qr.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await FT(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw Qr.error(r),Qr.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}a(X8,"setLicense");async function j8(){let e={};try{e=await af.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw Qr.error(r),Qr.error(t),new Error(r)}return e}a(j8,"getFingerprint");async function FT(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");Qr.info("Validating license input...");let r=af.validateLicense(e,t);if(Qr.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(Qr.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(Qr.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{Qr.info("writing license to disk"),await $8.writeFile(J8,JSON.stringify({license_key:e,company:t}))}catch(n){throw Qr.error("Failed to write License"),n}return"Registration successful."}a(FT,"parseLicense");async function Z8(){let e=await e6();return FT(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(Z8,"register");async function e6(){let e=await af.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:NP.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:NP.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{IP.start()}catch(n){Qr.error(n)}let r;try{r=await z8(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}a(e6,"promptForRegistration");async function t6(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await af.getLicense()}catch(r){throw Qr.error(`There was an error when searching licenses due to: ${r.message}`),r}if(K8.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=W8.version(),e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=Q8.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(t6,"getRegistrationInfo")});var LP=g((nEe,DP)=>{"use strict";var r6=ct(),kT=class{static{a(this,"HubConfigObject")}constructor(t,r,n,s,i,o,c,l,_,u,d,E,f,h){this.port=t,o===null&&(o=void 0),this.server_name=r+r6.SERVER_SUFFIX.HUB,this.pid_file=n,this.max_payload=67108864,this.reconnect_error_reports=100,this.jetstream={enabled:!1},this.tls={cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l},this.leafnodes={port:_,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c}},this.cluster={name:u,port:d,routes:E,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l}},this.accounts={SYS:{users:f},HDB:{users:h}},this.system_account="SYS"}};DP.exports=kT});var UP=g((iEe,PP)=>{"use strict";var MP=ct(),VT=class{static{a(this,"LeafConfigObject")}constructor(t,r,n,s,i,o,c,l,_,u,d){this.port=t,d===null&&(d=void 0),this.server_name=r+MP.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+MP.SERVER_SUFFIX.LEAF},this.tls={cert_file:_,key_file:u,ca_file:d,insecure:!0},this.leafnodes={remotes:[{tls:{ca_file:d,insecure:!0},urls:i,account:"SYS"},{tls:{ca_file:d,insecure:!0},urls:o,account:"HDB"}]},this.accounts={SYS:{users:c},HDB:{users:l,jetstream:"enabled"}},this.system_account="SYS"}};PP.exports=VT});var BP=g((aEe,vP)=>{"use strict";var $T=class{static{a(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};vP.exports=$T});var xP=g((lEe,HP)=>{"use strict";var n6=ct(),YT=class{static{a(this,"SysUserObject")}constructor(t,r){this.user=t+n6.SERVER_SUFFIX.ADMIN,this.password=r}};HP.exports=YT});var QT=g((_Ee,qP)=>{"use strict";var Ta=require("path"),uf=require("fs-extra"),s6=LP(),i6=UP(),o6=BP(),a6=xP(),KT=_n(),Ra=z(),yr=dr(),lf=P(),Fl=ct(),{CONFIG_PARAMS:mt}=lf,Aa=K(),ql=ne(),GP=Os(),WT=wt(),ga="clustering",c6=1e4,FP=50;qP.exports={generateNatsConfig:u6,removeNatsConfig:_6,getHubConfigPath:l6};function l6(){let e=ql.get(mt.ROOTPATH);return Ta.join(e,ga,Fl.NATS_CONFIG_FILES.HUB_SERVER)}a(l6,"getHubConfigPath");async function u6(e=!1,t=void 0){ql.initSync();let r=ql.get(mt.ROOTPATH),n=Ta.join(r,ga,Fl.PID_FILES.HUB),s=Ta.join(r,ga,Fl.PID_FILES.LEAF),i=yr.getConfigFromFile(mt.CLUSTERING_LEAFSERVER_STREAMS_PATH),o=Ta.join(r,ga,Fl.NATS_CONFIG_FILES.HUB_SERVER),c=Ta.join(r,ga,Fl.NATS_CONFIG_FILES.LEAF_SERVER),l=yr.getConfigFromFile(mt.CLUSTERING_TLS_CERTIFICATE),_=yr.getConfigFromFile(mt.CLUSTERING_TLS_PRIVATEKEY),u=yr.getConfigFromFile(mt.CLUSTERING_TLS_CERT_AUTH),d=yr.getConfigFromFile(mt.CLUSTERING_TLS_INSECURE),E=yr.getConfigFromFile(mt.CLUSTERING_TLS_VERIFY),f=yr.getConfigFromFile(mt.CLUSTERING_NODENAME),h=yr.getConfigFromFile(mt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await WT.checkNATSServerInstalled()||_f("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let p=await KT.listUsers(),S=yr.getConfigFromFile(mt.CLUSTERING_USER),T=await KT.getClusterUser();(Ra.isEmpty(T)||T.active!==!0)&&_f(`Invalid cluster user '${S}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await cf(mt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await cf(mt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await cf(mt.CLUSTERING_HUBSERVER_NETWORK_PORT),await cf(mt.CLUSTERING_LEAFSERVER_NETWORK_PORT));let A=[],b=[];for(let[J,X]of p.entries())X.role?.role===lf.ROLE_TYPES_ENUM.CLUSTER_USER&&X.active&&(A.push(new a6(X.username,GP.decrypt(X.hash))),b.push(new o6(X.username,GP.decrypt(X.hash))));let I=[],{hub_routes:B}=yr.getClusteringRoutes();if(!Ra.isEmptyOrZeroLength(B))for(let J of B)I.push(`tls://${T.sys_name_encoded}:${T.uri_encoded_d_hash}@${J.host}:${J.port}`);let U=new s6(yr.getConfigFromFile(mt.CLUSTERING_HUBSERVER_NETWORK_PORT),f,n,l,_,u,d,E,h,yr.getConfigFromFile(mt.CLUSTERING_HUBSERVER_CLUSTER_NAME),yr.getConfigFromFile(mt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),I,A,b);u==null&&(delete U.tls.ca_file,delete U.leafnodes.tls.ca_file),t=Ra.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===lf.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await uf.writeJson(o,U),Aa.trace(`Hub server config written to ${o}`));let q=`tls://${T.sys_name_encoded}:${T.uri_encoded_d_hash}@0.0.0.0:${h}`,M=`tls://${T.uri_encoded_name}:${T.uri_encoded_d_hash}@0.0.0.0:${h}`,Q=new i6(yr.getConfigFromFile(mt.CLUSTERING_LEAFSERVER_NETWORK_PORT),f,s,i,[q],[M],A,b,l,_,u,d);u==null&&delete Q.tls.ca_file,(t===void 0||t===lf.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await uf.writeJson(c,Q),Aa.trace(`Leaf server config written to ${c}`))}a(u6,"generateNatsConfig");async function cf(e){let t=ql.get(e);return Ra.isEmpty(t)&&_f(`port undefined for '${e}'`),await Ra.isPortTaken(t)&&_f(`'${e}' port '${t}' is is in use by another process, check to see if HarperDB is already running or another process is using this port.`),!0}a(cf,"isPortAvailable");function _f(e){let t=`Error generating clustering config: ${e}`;Aa.error(t),console.error(t),process.exit(1)}a(_f,"generateNatsConfigError");async function _6(e){let{port:t,config_file:r}=WT.getServerConfig(e),{username:n,decrypt_hash:s}=await KT.getClusterUser(),i=0,o=2e3;for(;i<FP;){try{let u=await WT.createConnection(t,n,s,!1);if(u.protocol.connected===!0){u.close();break}}catch(u){Aa.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${u}`)}if(i++,i>=FP)throw new Error(`Operations API timed out attempting to connect to ${e}. This is commonly caused by incorrect clustering config. Check hdb.log for further details.`);let _=o*(i*2);_>3e4&&Aa.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await Ra.async_set_timeout(_)}let c="0".repeat(c6),l=Ta.join(ql.get(mt.ROOTPATH),ga,r);await uf.writeFile(l,c),await uf.remove(l),Aa.notify(e,"started.")}a(_6,"removeNatsConfig")});var QP={};qe(QP,{compactOnStart:()=>d6,copyDb:()=>WP});async function d6(){Vl.notify("Running compact on start"),console.log("Running compact on start");let e=(0,zT.get)(Si.CONFIG_PARAMS.ROOTPATH),t=new Map,r=mr();try{for(let n in r){if(n==="system")continue;let s;for(let l in r[n]){s=r[n][l].primaryStore.path;break}if(!s){console.log("Couldn't find any tables in database",n);continue}let i=(0,df.join)(e,"backup",n+".mdb"),o=(0,df.join)(e,Si.DATABASES_DIR_NAME,n+"-copy.mdb"),c=await kP(n);console.log("Database",n,"before compact has a total record count of",c),t.set(n,{db_path:s,copy_dest:o,backup_dest:i,record_count:c}),await WP(n,o),console.log("Backing up",n,"to",i),await(0,po.move)(s,i,{overwrite:!0})}kl();for(let[n,{db_path:s,copy_dest:i}]of t)console.log("Moving copy compacted",n,"to",s),await(0,po.move)(i,s,{overwrite:!0}),await(0,po.remove)((0,df.join)(e,Si.DATABASES_DIR_NAME,`${n}-copy.mdb-lock`));kl()}catch(n){Vl.error("Error compacting database, rolling back operation",n),console.error("Error compacting database, rolling back operation",n),(0,JT.updateConfigValue)(Si.CONFIG_PARAMS.STORAGE_COMPACTONSTART,!1);for(let[s,{db_path:i,backup_dest:o}]of t){console.error("Moving backup database",o,"back to",i);try{await(0,po.move)(o,i,{overwrite:!0})}catch(c){console.error(c)}}throw kl(),n}for(let[n,{backup_dest:s,record_count:i}]of t){let o=!0,c=await kP(n);if(console.log("Database",n,"after compact has a total record count of",c),i!==c){o=!1;let l=`There is a discrepancy between pre and post compact record count for database ${n}.