harperdb 4.4.26 → 4.4.27

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.
@@ -8,7 +8,7 @@ Caused by:`));else if(typeof u=="object")try{n+=JSON.stringify(u)}catch{n+="Obje
8
8
  `).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:MQ.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(HQ,"findPs")});var Ht=N((Tge,RC)=>{"use strict";var xQ="__dbis__",kQ="__txns__",FQ="__environment_name__",GQ="__dbi_defintion__",qQ={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"},$Q=["__createdtime__","__updatedtime__"],VQ="\uFFFF",AC={TIMESTAMP:"timestamp",HASH_VALUE:"hash_value",USER_NAME:"user_name"},KQ=Object.values(AC);RC.exports={AUDIT_STORE_NAME:kQ,INTERNAL_DBIS_NAME:xQ,DBI_DEFINITION_NAME:GQ,SEARCH_TYPES:qQ,TIMESTAMP_NAMES:$Q,MAX_SEARCH_KEY_LENGTH:256,ENVIRONMENT_NAME_KEY:FQ,TRANSACTIONS_DBI_NAMES_ENUM:AC,TRANSACTIONS_DBIS:KQ,OVERFLOW_MARKER:VQ}});var Pn=N((gge,DC)=>{"use strict";var yC=M(),bC=Ht(),OC={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},NC=a(e=>`${e} Check logs and try again.`,"CHECK_LOGS_WRAPPER"),IC={500:NC("There was an error processing your request."),400:"Invalid request"},YQ=IC[OC.INTERNAL_SERVER_ERROR],WQ={OP_NOT_SUPPORTED_FOR_FS:a(e=>`${e} is not available for this instance because it uses the File System data store.`,"OP_NOT_SUPPORTED_FOR_FS"),MISSING_VALUE:a(e=>`${e} is missing.`,"MISSING_VALUE"),INVALID_VALUE:a(e=>`${e} is invalid.`,"INVALID_VALUE"),NOT_FOUND:a(e=>`${e} not found.`,"NOT_FOUND")},jQ={CONFIG_VALIDATION:a(e=>`HarperDB config file validation error: ${e}`,"CONFIG_VALIDATION")},zQ={DEFAULT_BULK_LOAD_ERR:"There was an error during your bulk load into HarperDB.",DOWNLOAD_FILE_ERR:a(e=>`There was an error downloading '${e}'.`,"DOWNLOAD_FILE_ERR"),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:a(e=>`Bulk load operation failed - ${e} is not a valid 'action' parameter`,"INVALID_ACTION_PARAM_ERR"),INVALID_FILE_EXT_ERR:a(e=>`Error selecting correct parser - valid file type not found in json - ${e}`,"INVALID_FILE_EXT_ERR"),MAX_FILE_SIZE_ERR:a((e,t)=>`File size is ${e} bytes, which exceeded the maximum size allowed of: ${t} bytes`,"MAX_FILE_SIZE_ERR"),PAPA_PARSE_ERR:"There was an error parsing the downloaded CSV data.",S3_DOWNLOAD_ERR:a(e=>`There was an error downloading '${e}' from AWS.`,"S3_DOWNLOAD_ERR"),WRITE_TEMP_FILE_ERR:"Error writing temporary file to storage"},QQ={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 ${bC.INTERNAL_DBIS_NAME}`,CANNOT_DROP_INTERNAL_DBIS_NAME:`cannot drop a dbi named ${bC.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"},JQ={ATTR_NAME_LENGTH_ERR:a(e=>`transaction aborted due to attribute name ${e} being too long. Attribute names cannot be longer than ${yC.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE} bytes.`,"ATTR_NAME_LENGTH_ERR"),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 ${yC.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"},wC={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"},XQ={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:a(e=>`Operation '${e}' is restricted to 'super_user' roles`,"OP_IS_SU_ONLY"),OP_NOT_FOUND:a(e=>`Operation '${e}' not found`,"OP_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:a((e,t,r)=>`There was an error authorizing ${e} op on table '${t}.${r}'`,"UNKNOWN_OP_AUTH_ERROR"),USER_HAS_NO_PERMS:a(e=>`User ${e} has no role or permissions. Please assign the user a valid role.`,"USER_HAS_NO_PERMS"),DROP_SYSTEM:"The 'system' database, tables and records are used internally by HarperDB and cannot be updated or removed."},ZQ={ATTR_PERM_MISSING:a((e,t)=>`${e.toUpperCase()} attribute permission missing for '${t}'`,"ATTR_PERM_MISSING"),ATTR_PERM_MISSING_NAME:"Permission object in 'attribute_permission' missing an 'attribute_name'",ATTR_PERM_NOT_BOOLEAN:a((e,t)=>`${e.toUpperCase()} attribute permission for '${t}' must be a boolean`,"ATTR_PERM_NOT_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:a(e=>`Invalid attribute '${e}' in 'attribute_permissions'`,"INVALID_ATTRIBUTE_IN_PERMS"),INVALID_PERM_KEY:a(e=>`Invalid table permission key value '${e}'`,"INVALID_PERM_KEY"),INVALID_ATTR_PERM_KEY:a(e=>`Invalid attribute permission key value '${e}'`,"INVALID_ATTR_PERM_KEY"),INVALID_ROLE_JSON_KEYS:a(e=>`Invalid ${e.length>1?"keys":"key"} in JSON body - '${e.join("', '")}'`,"INVALID_ROLE_JSON_KEYS"),MISMATCHED_TABLE_ATTR_PERMS:a(e=>`You have a conflict with TABLE permissions for '${e}' being false and ATTRIBUTE permissions being true`,"MISMATCHED_TABLE_ATTR_PERMS"),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:a(e=>`A role with name '${e}' already exists`,"ROLE_ALREADY_EXISTS"),ROLE_NOT_FOUND:"Role not found",ROLE_PERMS_ERROR:"Errors in the role permissions JSON provided",SCHEMA_PERM_ERROR:a(e=>`Your role does not have permission to view database metadata for '${e}'`,"SCHEMA_PERM_ERROR"),SCHEMA_TABLE_PERM_ERROR:a((e,t)=>`Your role does not have permission to view database.table metadata for '${e}.${t}'`,"SCHEMA_TABLE_PERM_ERROR"),SU_ROLE_MISSING_ERROR:"Missing 'super_user' key/value in permission set",SU_CU_ROLE_BOOLEAN_ERROR:a(e=>`Value for '${e}' permission must be a boolean`,"SU_CU_ROLE_BOOLEAN_ERROR"),STRUCTURE_USER_ROLE_TYPE_ERROR:a(e=>`Value for '${e}' permission must be a boolean or Array`,"STRUCTURE_USER_ROLE_TYPE_ERROR"),SU_CU_ROLE_NO_PERMS_ALLOWED:a(e=>`Roles with '${e}' set to true cannot have other permissions set.`,"SU_CU_ROLE_NO_PERMS_ALLOWED"),SU_CU_ROLE_COMBINED_ERROR:"Roles cannot have both 'super_user' and 'cluster_user' values included in their permissions set.",TABLE_PERM_MISSING:a(e=>`Missing table ${e.toUpperCase()} permission`,"TABLE_PERM_MISSING"),TABLE_PERM_NOT_BOOLEAN:a(e=>`Table ${e.toUpperCase()} permission must be a boolean`,"TABLE_PERM_NOT_BOOLEAN")},e2={ATTR_NOT_FOUND:a((e,t,r)=>`Attribute '${r}' does not exist on '${e}.${t}'`,"ATTR_NOT_FOUND"),ATTR_EXISTS_ERR:a((e,t,r)=>`Attribute '${r}' already exists in ${e}.${t}'`,"ATTR_EXISTS_ERR"),DESCRIBE_ALL_ERR:"There was an error during describeAll. Please check the logs and try again.",INVALID_TABLE_ERR:a(e=>`Invalid table ${JSON.stringify(e)}`,"INVALID_TABLE_ERR"),SCHEMA_NOT_FOUND:a(e=>`database '${e}' does not exist`,"SCHEMA_NOT_FOUND"),SCHEMA_EXISTS_ERR:a(e=>`database '${e}' already exists`,"SCHEMA_EXISTS_ERR"),TABLE_EXISTS_ERR:a((e,t)=>`Table '${t}' already exists in '${e}'`,"TABLE_EXISTS_ERR"),SCHEMA_REQUIRED_ERR:"database is required",TABLE_NOT_FOUND:a((e,t)=>`Table '${e}.${t}' does not exist`,"TABLE_NOT_FOUND"),TABLE_REQUIRED_ERR:"table is required"},t2={OUTER_JOIN_TRANSLATION_ERROR:"There was an error translating the final SQL outer join data."},r2={ALTER_USER_DUP_ROLES:a(e=>`Update failed. There are duplicates for the '${e}' role which is not allowed. Update your roles and try again.`,"ALTER_USER_DUP_ROLES"),ALTER_USER_ROLE_NOT_FOUND:a(e=>`Update failed. Requested '${e}' role not found.`,"ALTER_USER_ROLE_NOT_FOUND"),DUP_ROLES_FOUND:a(e=>`Multiple ${e} roles found. Roles must have unique 'role' value. Please update and try again.`,"DUP_ROLES_FOUND"),ROLE_NAME_NOT_FOUND:a(e=>`${e} role not found`,"ROLE_NAME_NOT_FOUND"),USER_ALREADY_EXISTS:a(e=>`User ${e} already exists`,"USER_ALREADY_EXISTS"),USER_NOT_EXIST:a(e=>`User ${e} does not exist`,"USER_NOT_EXIST")},CC={INVALID_DATE:"Invalid date, must be in ISO-8601 format (YYYY-MM-DD).",SEARCH_CONDITIONS_INVALID_SORT_ATTRIBUTE:a(e=>`invalid sort attribute '${e}', the attribute must either be the table's hash attribute or an attribute used in conditions.`,"SEARCH_CONDITIONS_INVALID_SORT_ATTRIBUTE")},PC={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:a(e=>`ITC server received invalid event type: ${e}`,"INVALID_EVENT")},n2={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.",BAD_SSH_KEY_NAME:"SSH key name can only contain alphanumeric, dash and underscore characters"},s2={CLUSTERING_NOT_ENABLED:"Clustering must be enabled to perform this operation."},i2={...wC,...zQ,...WQ,...XQ,...ZQ,...e2,...t2,...r2,...JQ,...CC,...PC,...n2,...s2,...jQ};DC.exports={CHECK_LOGS_WRAPPER:NC,HDB_ERROR_MSGS:i2,DEFAULT_ERROR_MSGS:IC,DEFAULT_ERROR_RESP:YQ,HTTP_STATUS_CODES:OC,LMDB_ERRORS_ENUM:QQ,AUTHENTICATION_ERROR_MSGS:wC,VALIDATION_ERROR_MSGS:CC,ITC_ERRORS:PC}});var _e=N((Rge,UC)=>{"use strict";var wl=Pn(),o2=j(),a2=M(),sh=class extends Error{static{a(this,"HdbError")}constructor(t,r,n,s,i){super(),Error.captureStackTrace(this,LC),this.statusCode=n||wl.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR,this.http_resp_msg=r||(wl.DEFAULT_ERROR_MSGS[n]?wl.DEFAULT_ERROR_MSGS[n]:wl.DEFAULT_ERROR_MSGS[wl.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&&o2[s](i)}},Eg=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}},hg=class extends Error{static{a(this,"ServerError")}constructor(t,r){super(t),this.statusCode=r||500}};function LC(e,t,r,n=a2.LOG_LEVELS.ERROR,s=null,i=!1){if(MC(e))return e;let o=new sh(e,t,r,n,s);return i&&delete o.stack,o}a(LC,"handleHDBError");function MC(e){return e.__proto__.constructor.name===sh.name}a(MC,"isHDBError");UC.exports={isHDBError:MC,handleHDBError:LC,ClientError:Eg,ServerError:hg,hdb_errors:wl}});var pg=N(vC=>{"use strict";var c2={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
9
9
  `),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
10
10
  `)},l2="certificate.pem",u2="privateKey.pem",d2="caCertificate.pem",_2="natsCertificate.pem",f2="natsCaCertificate.pem",Rt={DEFAULT:"default","DEFAULT-CA":"default-ca",SERVER:"server",CA:"ca","OPERATIONS-API":"operations-api","OPERATIONS-CA":"operations-ca"},E2={tls_certificate:Rt.SERVER,tls_certificateAuthority:Rt.CA,customFunctions_tls_certificate:Rt.SERVER,customFunctions_tls_certificateAuthority:Rt.CA,operationsApi_tls_certificate:Rt["OPERATIONS-API"],operationsApi_tls_certificateAuthority:Rt["OPERATIONS-CA"]},h2={[Rt.SERVER]:2,[Rt.DEFAULT]:1},p2={[Rt["OPERATIONS-API"]]:3,[Rt.SERVER]:2,[Rt.DEFAULT]:1},m2={[Rt["OPERATIONS-API"]]:3,[Rt.SERVER]:2,[Rt.DEFAULT]:1},S2={[Rt["OPERATIONS-CA"]]:3,[Rt.CA]:2,[Rt["DEFAULT-CA"]]:1},T2={[Rt["OPERATIONS-CA"]]:3,[Rt.CA]:2,[Rt["DEFAULT-CA"]]:1},g2={[Rt.CA]:2,[Rt["DEFAULT-CA"]]:1};Object.assign(vC,{CERTIFICATE_PEM_NAME:l2,PRIVATEKEY_PEM_NAME:u2,CA_PEM_NAME:d2,CERT_NAME:Rt,CERT_CONFIG_NAME_MAP:E2,CERT_PREFERENCE_APP:h2,CERT_PREFERENCE_OPS:p2,CERT_PREFERENCE_REP:m2,CA_CERT_PREFERENCE_REP:S2,CA_CERT_PREFERENCE_OPS:T2,CA_CERT_PREFERENCE_APP:g2,CERTIFICATE_VALUES:c2,NATS_CERTIFICATE_PEM_NAME:_2,NATS_CA_PEM_NAME:f2})});var Tt=N((Oge,BC)=>{"use strict";var nn=require("validate.js");nn.validators.type=function(e,t,r,n){return e===null||typeof e>"u"||nn.validators.type.checks[t](e)?null:` must be a '${t}' value`};nn.validators.type.checks={Object:a(function(e){return nn.isObject(e)&&!nn.isArray(e)},"Object"),Array:nn.isArray,Integer:nn.isInteger,Number:nn.isNumber,String:nn.isString,Date:nn.isDate,Boolean:a(function(e){return typeof e=="boolean"},"Boolean")};nn.validators.hasValidFileExt=function(e,t){return nn.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};BC.exports={validateObject:A2,validateObjectAsync:R2,validateBySchema:y2};function A2(e,t){if(!e||!t)return new Error("validateObject parameters were null");let r=nn(e,t,{format:"flat"});return r?new Error(r):null}a(A2,"validateObject");async function R2(e,t){if(!e||!t)return new Error("validateObject parameters were null");try{await nn.async(e,t,{format:"flat"})}catch(r){let n=r.join(",");return new Error(n)}return null}a(R2,"validateObjectAsync");function y2(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(y2,"validateBySchema")});var Sg=N((wge,qC)=>{"use strict";var FC=require("fs-extra"),me=require("joi"),b2=require("os"),{boolean:He,string:It,number:tr,array:za}=me.types(),{totalmem:HC}=require("os"),ja=require("path"),O2=j(),mg=re(),Ige=pg(),xC=M(),N2=Tt(),kC="log",I2="components",w2="Invalid logging.rotation.maxSize unit. Available units are G, M or K",C2="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",P2="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",D2="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",L2="rootPath config parameter is undefined",sn=me.alternatives([tr.min(0),It]).optional().empty(null),ih=me.alternatives([za.items(It,{host:It.required(),port:sn},{hostname:It.required(),port:sn}).empty(null),za.items(It)]),pi,GC=!1;qC.exports={configValidator:M2,routesValidator:k2,route_constraints:ih};function M2(e,t=!1){if(GC=t,pi=e.rootPath,mg.isEmpty(pi))throw L2;let r=He.optional(),n=tr.min(0).max(1e3).empty(null).default(x2),s=It.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(Fd),i=It.optional().empty(null),o=It.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null).required(),c=me.string().empty(null).default(Fd),l=me.custom(v2).empty(null).default(Fd),u=e.clustering?.enabled,d=me.object({certificate:i,certificateAuthority:i,privateKey:i}),_;return u===!0?_=me.object({enabled:r,hubServer:me.object({cluster:me.object({name:me.required().empty(null),network:me.object({port:sn,routes:ih}).required()}).required(),leafNodes:me.object({network:me.object({port:sn}).required()}).required(),network:me.object({port:sn}).required()}).required(),leafServer:me.object({network:me.object({port:sn,routes:ih}).required(),streams:me.object({maxAge:tr.min(120).allow(null).optional(),maxBytes:tr.min(1).allow(null).optional(),maxMsgs:tr.min(1).allow(null).optional(),path:c}).required()}).required(),logLevel:me.valid("error","warn","info","debug","trace"),nodeName:o,republishMessages:He.optional(),databaseLevel:He.optional(),tls:me.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:He.required(),verify:He.optional()}),user:It.optional().empty(null)}).optional():_=me.object({enabled:r,tls:me.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:He.optional()})}).optional(),me.object({authentication:me.alternatives(me.object({authorizeLocal:He,cacheTTL:tr.required(),enableSessions:He}),He).optional(),analytics:me.object({aggregatePeriod:tr}),replication:me.object({hostname:me.alternatives(It,tr).optional().empty(null),url:It.optional().empty(null),port:sn,securePort:sn,routes:za.optional().empty(null),databases:me.alternatives(It,za),enableRootCAs:He.optional(),copyTablesToCatchUp:He.optional()}).optional(),componentsRoot:s.optional(),clustering:_,localStudio:me.object({enabled:r}).required(),logging:me.object({auditAuthEvents:me.object({logFailed:He,logSuccessful:He}),file:He.required(),level:me.valid("notify","fatal","error","warn","info","debug","trace"),rotation:me.object({enabled:He.optional(),compress:He.optional(),interval:It.custom(H2).optional().empty(null),maxSize:It.custom(B2).optional().empty(null),path:It.optional().empty(null).default(Fd)}).required(),root:s,stdStreams:He.required(),auditLog:He.required()}).required(),operationsApi:me.object({network:me.object({cors:He.optional(),corsAccessList:za.optional(),headersTimeout:tr.min(1).optional(),keepAliveTimeout:tr.min(1).optional(),port:sn,domainSocket:me.optional().empty("hdb/operations-server").default(Fd),securePort:sn,timeout:tr.min(1).optional()}).optional(),tls:me.alternatives([me.array().items(d),d])}).required(),rootPath:It.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").required(),mqtt:me.object({network:me.object({port:sn,securePort:sn,mtls:me.alternatives([He.optional(),me.object({user:It.optional(),certificateAuthority:i,required:He.optional()})])}).required(),webSocket:He.optional(),requireAuthentication:He.optional()}),http:me.object({compressionThreshold:tr.optional(),cors:He.optional(),corsAccessList:za.optional(),headersTimeout:tr.min(1).optional(),port:sn,securePort:sn,maxHeaderSize:tr.optional(),mtls:me.alternatives([He.optional(),me.object({user:It.optional(),certificateAuthority:i,required:He.optional()})]),threadRange:me.alternatives([za.optional(),It.optional()])}).required(),threads:me.alternatives(n.optional(),me.object({count:n.optional(),debug:me.alternatives(He.optional(),me.object({startingPort:tr.min(1).optional(),host:It.optional(),waitForDebugger:He.optional()})),maxHeapMemory:tr.min(0).optional()})),storage:me.object({writeAsync:He.required(),overlappingSync:He.optional(),caching:He.optional(),compression:me.alternatives([He.optional(),me.object({dictionary:It.optional(),threshold:tr.optional()})]),compactOnStart:He.optional(),compactOnStartKeepBackup:He.optional(),noReadAhead:He.optional(),path:l,prefetchWrites:He.optional(),maxFreeSpaceToLoad:tr.optional(),maxFreeSpaceToRetain:tr.optional()}).required(),ignoreScripts:He.optional(),tls:me.alternatives([me.array().items(d),d])}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(M2,"configValidator");function U2(e){return GC||FC.existsSync(e)?null:`Specified path ${e} does not exist.`}a(U2,"doesPathExist");function v2(e,t){me.assert(e,It.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=U2(e);if(r)return t.message(r)}a(v2,"validatePath");function B2(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(w2);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(P2):e}a(B2,"validateRotationMaxSize");function H2(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message(C2);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(D2):e}a(H2,"validateRotationInterval");function x2(e,t){let r=t.state.path.join("."),n=b2.cpus().length,s=n-1;s<=2&&(s=2);let i=process.constrainedMemory?.()||HC();return i=Math.round(Math.min(i,HC())/1e6),s=Math.max(Math.min(s,Math.round((i-750)/300)),1),O2.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}a(x2,"setDefaultThreads");function Fd(e,t){let r=t.state.path.join(".");if(!mg.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if(mg.isEmpty(pi))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return ja.join(pi,I2);case"logging.root":return ja.join(pi,kC);case"clustering.leafServer.streams.path":return ja.join(pi,"clustering","leaf");case"storage.path":let n=ja.join(pi,xC.LEGACY_DATABASES_DIR_NAME);return FC.existsSync(n)?n:ja.join(pi,xC.DATABASES_DIR_NAME);case"logging.rotation.path":return ja.join(pi,kC);case"operationsApi.network.domainSocket":return r==null?null:ja.join(pi,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(Fd,"setDefaultRoot");function k2(e){let t=me.object({routes:ih});return N2.validateBySchema({routes:e},t)}a(k2,"routesValidator")});var Qa={};je(Qa,{server:()=>it});var $C,it,qr=Ie(()=>{$C=L(fi()),it={};(0,$C._assignPackageExport)("server",it)});var wt=N(ZC=>{"use strict";var on=M(),Er=re(),hr=j(),{configValidator:F2,routesValidator:VC}=Sg(),$r=require("fs-extra"),YC=require("yaml"),Ln=require("path"),G2=require("is-number"),WC=require("properties-reader"),q2=require("lodash"),{handleHDBError:$2}=_e(),{HTTP_STATUS_CODES:V2,HDB_ERROR_MSGS:Cl}=Pn(),{server:K2}=(qr(),oe(Qa)),{DATABASES_PARAM_CONFIG:Gd,CONFIG_PARAMS:Dn,CONFIG_PARAM_MAP:xs}=on,Y2="Unable to get config value because config is uninitialized",W2="Config successfully initialized",j2="Error backing up config file",z2="Empty parameter sent to getConfigValue",jC=Ln.join(on.PACKAGE_ROOT,"config","yaml",on.HDB_DEFAULT_CONFIG_FILE),Q2=Ln.join(on.PACKAGE_ROOT,"config","yaml","defaultNatsConfig.yaml"),J2="Configuration successfully set. You must restart HarperDB for new config settings to take effect.",KC={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"},oh,jt,ah;Object.assign(ZC,{createConfigFile:X2,getDefaultConfig:Z2,getConfigValue:QC,initConfig:ch,flattenConfig:Pl,updateConfigValue:JC,updateConfigObject:t4,getConfiguration:s4,setConfiguration:i4,readConfigFile:Rg,getClusteringRoutes:o4,initOldConfig:XC,getConfigFromFile:a4,getConfigFilePath:Ja,addConfig:c4,deleteConfigFromFile:l4,getConfigObj:u4,resolvePath:Tg,getFlatConfigObj:d4});function Tg(e){if(e?.startsWith("~/"))return Ln.join(Er.getHomeDir(),e.slice(1));let t=se();return Ln.resolve(t.getHdbBasePath(),e)}a(Tg,"resolvePath");function X2(e,t=!1){let r=$o(jC);if(e.clustering_enabled||e.CLUSTERING_ENABLED||e.clustering){let c=YC.parseDocument($r.readFileSync(Q2,"utf8"),{simpleKeys:!0});r.addIn(["clustering"],c.toJSON().clustering)}oh=Pl(r.toJSON());let n;for(let c in e){let l=xs[c.toLowerCase()];if(l===Dn.DATABASES){Array.isArray(e[c])?n=e[c]:n=Object.keys(e[c]).map(u=>({[u]:e[c][u]}));continue}if(!l&&(c.endsWith("_package")||c.endsWith("_port"))&&(l=c),l!==void 0){let u=l.split("_"),d=gg(l,e[c]);l==="rootPath"&&d?.endsWith("/")&&(d=d.slice(0,-1));try{r.setIn([...u],d)}catch(_){hr.error(_)}}}n&&zC(r,n),Ag(r,t);let s=r.toJSON();jt=Pl(s);let i=r.getIn(["rootPath"]),o=Ln.join(i,on.HDB_CONFIG_FILE);$r.createFileSync(o),$r.writeFileSync(o,String(r)),hr.trace(`Config file written to ${o}`)}a(X2,"createConfigFile");function zC(e,t){let r;try{try{r=JSON.parse(t)}catch(n){if(!Er.isObject(t))throw n;r=t}for(let n of r){let s=Object.keys(n)[0];if(n[s].hasOwnProperty(Gd.TABLES))for(let i in n[s][Gd.TABLES])for(let o in n[s][Gd.TABLES][i]){let c=n[s][Gd.TABLES][i][o],l=[Dn.DATABASES,s,Gd.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=[Dn.DATABASES,s,i];e.hasIn(c)?e.setIn(c,o):e.addIn(c,o)}}}catch(n){hr.error("Error parsing schemas CLI/env config arguments",n)}}a(zC,"setSchemasConfig");function Z2(e){if(oh===void 0){let r=$o(jC);oh=Pl(r.toJSON())}let t=xs[e.toLowerCase()];if(t!==void 0)return oh[t.toLowerCase()]}a(Z2,"getDefaultConfig");function QC(e){if(e==null){hr.info(z2);return}if(jt===void 0){hr.trace(Y2);return}let t=xs[e.toLowerCase()];if(t!==void 0)return jt[t.toLowerCase()]}a(QC,"getConfigValue");function Ja(e=Er.getPropsFilePath()){let t=Er.getEnvCliRootPath();if(t)return Tg(Ln.join(t,on.HDB_CONFIG_FILE));let r=WC(e);return Tg(r.get(on.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}a(Ja,"getConfigFilePath");function ch(e=!1){if(jt===void 0||e){let t;if(!Er.noBootFile()){t=Er.getPropsFilePath();try{$r.accessSync(t,$r.constants.F_OK|$r.constants.R_OK)}catch(i){throw hr.error(i),new Error(`HarperDB properties file at path ${t} does not exist`)}}let r=Ja(t),n;if(r.includes("config/settings.js"))try{XC(r);return}catch(i){if(i.code!==on.NODE_ERROR_CODES.ENOENT)throw i}try{n=$o(r)}catch(i){if(i.code===on.NODE_ERROR_CODES.ENOENT){hr.trace(`HarperDB config file not found at ${r}.
11
- This can occur during early stages of install where the config file has not yet been created`);return}else throw hr.error(i),new Error(`Error reading HarperDB config file at ${r}`)}e4(n,r),Ag(n);let s=n.toJSON();if(K2.config=s,jt=Pl(s),jt.logging_rotation_rotate)for(let i in KC)jt[i]&&hr.error(`Config ${KC[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);hr.trace(W2)}}a(ch,"initConfig");function e4(e,t){let r=e.getIn(["rootPath"]),n=!1;e.hasIn(["storage","path"])||(e.setIn(["storage","path"],Ln.join(r,"database")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],Ln.join(r,"log")),n=!0),e.hasIn(["authentication"])||(e.addIn(["authentication"],{cacheTTL:3e4,enableSessions:!0,operationTokenTimeout:e.getIn(["operationsApi","authentication","operationTokenTimeout"])??"1d",refreshTokenTimeout:e.getIn(["operationsApi","authentication","refreshTokenTimeout"])??"30d"}),n=!0),e.hasIn(["analytics"])||(e.addIn(["analytics"],{aggregatePeriod:60}),n=!0),n&&(hr.trace("Updating config file with missing config params"),$r.writeFileSync(t,String(e)))}a(e4,"checkForUpdatedConfig");function Ag(e,t=!1){let r=e.toJSON();if(r.componentsRoot=r.componentsRoot??r?.customFunctions?.root,r?.http?.threads&&(r.threads=r?.http?.threads),r.http?.port&&r.http?.port===r.http?.securePort)throw Cl.CONFIG_VALIDATION("http.port and http.securePort cannot be the same value");if(r.operationsApi?.network?.port&&r.operationsApi?.network?.port===r.operationsApi?.network?.securePort)throw Cl.CONFIG_VALIDATION("operationsApi.network.port and operationsApi.network.securePort cannot be the same value");let n=F2(r,t);if(n.error)throw Cl.CONFIG_VALIDATION(n.error.message);typeof n.value.threads=="object"?e.setIn(["threads","count"],n.value.threads.count):e.setIn(["threads"],n.value.threads),e.setIn(["componentsRoot"],n.value.componentsRoot),e.setIn(["logging","root"],n.value.logging.root),e.setIn(["storage","path"],n.value.storage.path),e.setIn(["logging","rotation","path"],n.value.logging.rotation.path),e.setIn(["operationsApi","network","domainSocket"],n.value?.operationsApi?.network?.domainSocket),r?.clustering?.enabled&&e.setIn(["clustering","leafServer","streams","path"],n.value.clustering.leafServer.streams?.path)}a(Ag,"validateConfig");function t4(e,t){jt===void 0&&(jt={});let r=xs[e.toLowerCase()];if(r===void 0){hr.trace(`Unable to update config object because config param '${e}' does not exist`);return}jt[r.toLowerCase()]=t}a(t4,"updateConfigObject");function JC(e,t,r=void 0,n=!1,s=!1,i=!1){jt===void 0&&ch();let o=QC(xs.hdb_root),c=Ln.join(o,on.HDB_CONFIG_FILE),l=$o(c),u;if(r===void 0&&e.toLowerCase()===Dn.DATABASES)u=t;else if(r===void 0){let E;if(i)E=e;else if(E=xs[e.toLowerCase()],E===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let f=E.split("_"),h=gg(E,t);l.setIn([...f],h)}else for(let E in r){let f=xs[E.toLowerCase()];if(f===Dn.HTTP_SECUREPORT&&r[E]===jt[Dn.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),f===Dn.OPERATIONSAPI_NETWORK_SECUREPORT&&r[E]===jt[Dn.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&l.setIn(["operationsApi","network","port"],null),f===Dn.DATABASES){u=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("_"),T=on.LEGACY_CONFIG_PARAMS[E.toUpperCase()];T&&T.startsWith("customFunctions")&&l.hasIn(T.split("_"))&&(f=T,h=T.split("_"));let m=gg(f,r[E]);f==="rootPath"&&m?.endsWith("/")&&(m=m.slice(0,-1));try{h.length>1&&typeof l.getIn(h.slice(0,-1))=="boolean"&&l.deleteIn(h.slice(0,-1)),l.setIn([...h],m)}catch(g){hr.error(g)}}}u&&zC(l,u),Ag(l);let d=l.getIn(["rootPath"]),_=Ln.join(d,on.HDB_CONFIG_FILE);n===!0&&r4(c,d),$r.writeFileSync(_,String(l)),s&&(jt=Pl(l.toJSON())),hr.trace(`Config parameter: ${e} updated with value: ${t}`)}a(JC,"updateConfigValue");function r4(e,t){try{let r=Ln.join(t,"backup",`${new Date(Date.now()).toISOString().replaceAll(":","-")}-${on.HDB_CONFIG_FILE}.bak`);$r.copySync(e,r),hr.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){hr.error(j2),hr.error(r)}}a(r4,"backupConfigFile");var n4=["databases"];function Pl(e){return e.http&&Object.assign(e.http,e?.customFunctions?.network),e?.operationsApi?.network&&(e.operationsApi.network={...e.http,...e.operationsApi.network}),e?.operationsApi&&(e.operationsApi.tls={...e.tls,...e.operationsApi.tls}),ah=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])&&!n4.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;!Dn[l.toUpperCase()]&&xs[l]&&(s[xs[l].toLowerCase()]=o[c]),s[l]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(Pl,"flattenConfig");function gg(e,t){if(e===Dn.CLUSTERING_NODENAME||e===Dn.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(G2(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||Er.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 Er.autoCast(t)}a(gg,"castConfigValue");function s4(){let e=Er.getPropsFilePath(),t=Ja(e);return $o(t).toJSON()}a(s4,"getConfiguration");async function i4(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return JC(void 0,void 0,s,!0),J2}catch(i){throw typeof i=="string"||i instanceof String?$2(i,i,V2.BAD_REQUEST,void 0,void 0,!0):i}}a(i4,"setConfiguration");function Rg(){let e=Er.getPropsFilePath();try{$r.accessSync(e,$r.constants.F_OK|$r.constants.R_OK)}catch(n){if(!Er.noBootFile())throw hr.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=Ja(e);return $o(t).toJSON()}a(Rg,"readConfigFile");function $o(e){return YC.parseDocument($r.readFileSync(e,"utf8"),{simpleKeys:!0})}a($o,"parseYamlDoc");function o4(){let e=Rg(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=Er.isEmptyOrZeroLength(t)?[]:t;let r=VC(t);if(r)throw Cl.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=Er.isEmptyOrZeroLength(n)?[]:n;let s=VC(n);if(s)throw Cl.CONFIG_VALIDATION(s.message);if(!Er.isEmptyOrZeroLength(n)&&!Er.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!Er.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw Cl.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(o4,"getClusteringRoutes");function XC(e){let t=WC(e);jt={};for(let r in xs){let n=t.get(r.toUpperCase());if(Er.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=xs[r].toLowerCase();s===Dn.LOGGING_ROOT?jt[s]=Ln.dirname(n):jt[s]=n}return jt}a(XC,"initOldConfig");function a4(e){let t=Rg();return q2.get(t,e.replaceAll("_","."))}a(a4,"getConfigFromFile");async function c4(e,t){let r=$o(Ja());r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),await $r.writeFile(Ja(),String(r))}a(c4,"addConfig");function l4(e){let t=Ja(Er.getPropsFilePath()),r=$o(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=Ln.join(n,on.HDB_CONFIG_FILE);$r.writeFileSync(s,String(r))}a(l4,"deleteConfigFromFile");function u4(){return ah||(ch(),ah)}a(u4,"getConfigObj");function d4(){return jt||ch(),jt}a(d4,"getFlatConfigObj")});var se=N((sP,iP)=>{"use strict";var yg=require("fs-extra"),Xa=require("path"),eP=require("os"),_4=require("properties-reader"),$d=j(),qd=re(),Pe=M(),lh=wt(),f4="Error initializing environment manager",uh="BOOT_PROPS_FILE_PATH",tP=!1,E4={[Pe.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[Pe.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[Pe.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},ji={};Object.assign(sP,iP.exports={BOOT_PROPS_FILE_PATH:uh,getHdbBasePath:h4,setHdbBasePath:p4,get:rP,initSync:S4,setProperty:Qe,initTestEnvironment:g4,setCloneVar:T4});function h4(){return ji[Pe.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(h4,"getHdbBasePath");function p4(e){ji[Pe.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(p4,"setHdbBasePath");function rP(e){let t=lh.getConfigValue(e);return t===void 0?ji[e]:t}a(rP,"get");function Qe(e,t){E4[e]&&(ji[e]=t),lh.updateConfigObject(e,t)}a(Qe,"setProperty");function m4(){let e;try{e=qd.getPropsFilePath(),yg.accessSync(e,yg.constants.F_OK|yg.constants.R_OK),tP=!0;let t=_4(e);return ji[Pe.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(Pe.HDB_SETTINGS_NAMES.INSTALL_USER),ji[Pe.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(Pe.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),ji[uh]=e,!0}catch{return $d.trace(`Environment manager found no properties file at ${e}`),!1}}a(m4,"doesPropFileExist");function S4(e=!1){try{((tP||m4()||qd.noBootFile())&&!nP||e)&&(lh.initConfig(e),ji[Pe.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=lh.getConfigValue(Pe.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){$d.error(f4),$d.error(t),console.error(t),process.exit(1)}}a(S4,"initSync");var nP=!1;function T4(e){nP=e}a(T4,"setCloneVar");function g4(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=Xa.join(__dirname,"../../","unitTests");ji[uh]=Xa.join(l,"hdb_boot_properties.file"),Qe(Pe.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,Xa.join(l,"settings.test")),Qe(Pe.HDB_SETTINGS_NAMES.INSTALL_USER,eP.userInfo()?eP.userInfo().username:void 0),Qe(Pe.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),Qe(Pe.HDB_SETTINGS_NAMES.LOG_PATH_KEY,Xa.join(l,"envDir","log")),Qe(Pe.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),Qe(Pe.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),Qe(Pe.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),Qe(Pe.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,Xa.join(l,"envDir")),Qe(Pe.CONFIG_PARAMS.STORAGE_PATH,Xa.join(l,"envDir")),s&&(Qe(Pe.CONFIG_PARAMS.HTTP_SECUREPORT,rP(Pe.CONFIG_PARAMS.HTTP_PORT)),Qe(Pe.CONFIG_PARAMS.HTTP_PORT,null)),Qe(Pe.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,!!s),Qe(Pe.CONFIG_PARAMS.HTTP_PORT,9926),Qe(Pe.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),Qe(Pe.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT,9925),Qe(Pe.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,qd.isEmpty(i)?!1:i),Qe(Pe.CONFIG_PARAMS.HTTP_CORS,qd.isEmpty(i)?!1:i),Qe(Pe.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),Qe(Pe.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),Qe(Pe.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),Qe(Pe.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),Qe(Pe.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,Xa.resolve(__dirname,"../../unitTests/server/fastifyRoutes/custom_functions")),Qe(Pe.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,qd.isEmpty(c)?!1:c),o&&(Qe("CORS_ACCESSLIST",o),Qe(Pe.CONFIG_PARAMS.HTTP_CORSACCESSLIST,o)),n&&(Qe(Pe.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,n),Qe(Pe.CONFIG_PARAMS.HTTP_TIMEOUT,n)),t&&(Qe(Pe.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),Qe(Pe.CONFIG_PARAMS.HTTP_KEEPALIVETIMEOUT,t)),r&&(Qe(Pe.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),Qe(Pe.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${uh}. Please check your boot props and settings files`;$d.fatal(r),$d.error(t)}}a(g4,"initTestEnvironment")});var gt=N((Mge,_P)=>{"use strict";var jd=M(),A4=re(),an=se(),zd=require("path"),R4=require("minimist"),oP=require("fs-extra"),aP=require("lodash");an.initSync();var{CONFIG_PARAMS:Vo,DATABASES_PARAM_CONFIG:Vd,SYSTEM_SCHEMA_NAME:dh}=jd,Kd,Yd,Wd;function cP(){if(Kd!==void 0)return Kd;if(an.getHdbBasePath()!==void 0)return Kd=an.get(Vo.STORAGE_PATH)||zd.join(an.getHdbBasePath(),jd.DATABASES_DIR_NAME),Kd}a(cP,"getBaseSchemaPath");function lP(){if(Yd!==void 0)return Yd;if(an.getHdbBasePath()!==void 0)return Yd=dP(dh),Yd}a(lP,"getSystemSchemaPath");function uP(){if(Wd!==void 0)return Wd;if(an.getHdbBasePath()!==void 0)return Wd=an.get(jd.CONFIG_PARAMS.STORAGE_AUDIT_PATH)||zd.join(an.getHdbBasePath(),jd.TRANSACTIONS_DIR_NAME),Wd}a(uP,"getTransactionAuditStoreBasePath");function y4(e,t){let r=an.get(Vo.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||zd.join(uP(),e.toString())}a(y4,"getTransactionAuditStorePath");function dP(e,t){e=e.toString(),t=t&&t.toString();let r=an.get(jd.CONFIG_PARAMS.DATABASES)?.[e];return t&&r?.tables?.[t]?.path||r?.path||zd.join(cP(),e)}a(dP,"getSchemaPath");function b4(e,t){e=e.toString(),t=t.toString();let r=process.env;Object.assign(r,R4(process.argv));let n=r[Vo.DATABASES.toUpperCase()];if(n){let i;try{i=JSON.parse(n)}catch(o){if(!A4.isObject(n))throw o;i=n}for(let o of i){let c=o[dh];if(!c)continue;let l=an.get(Vo.DATABASES);l=l??{};let u=c?.tables?.[t]?.[Vd.PATH];if(u)return aP.set(l,[dh,Vd.TABLES,t,Vd.PATH],u),an.setProperty(Vo.DATABASES,l),u;let d=c?.[Vd.PATH];if(d)return aP.set(l,[dh,Vd.PATH],d),an.setProperty(Vo.DATABASES,l),d}}let s=r[Vo.STORAGE_PATH.toUpperCase()];if(s){if(!oP.pathExistsSync(s))throw new Error(s+" does not exist");let i=zd.join(s,e);return oP.mkdirsSync(i),an.setProperty(Vo.STORAGE_PATH,s),i}return lP()}a(b4,"initSystemSchemaPaths");function O4(){Kd=void 0,Yd=void 0,Wd=void 0}a(O4,"resetPaths");_P.exports={getBaseSchemaPath:cP,getSystemSchemaPath:lP,getTransactionAuditStorePath:y4,getTransactionAuditStoreBasePath:uP,getSchemaPath:dP,initSystemSchemaPaths:b4,resetPaths:O4}});var cn=N((Hge,mP)=>{"use strict";var N4=Pn().LMDB_ERRORS_ENUM,vge=require("lmdb"),I4=Ht(),Bge=require("buffer").Buffer,{OVERFLOW_MARKER:fP,MAX_SEARCH_KEY_LENGTH:_h}=I4,EP=["number","string","symbol","boolean","bigint"];function w4(e){if(e=e?.primaryStore||e,!e)throw new Error(N4.ENV_REQUIRED)}a(w4,"validateEnv");function C4(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(C4,"stringifyData");function P4(e){return e instanceof Date?e.valueOf():e}a(P4,"convertKeyValueToWrite");function D4(e,t){if(e===null)return t?[null]:void 0;if(e===void 0)return;if(EP.includes(typeof e))return e.length>_h?[e.slice(0,_h)+fP]:[e];let r;if(Array.isArray(e)){r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n];if(EP.includes(typeof i))i.length>_h?r.push(i.slice(0,_h)+fP):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(D4,"getIndexedValues");var fh=0,hP=0;function pP(){hP=Date.now()-performance.now()}a(pP,"adjustStartTime");pP();var L4=6e4;setInterval(pP,L4).unref();function M4(){let e=performance.now()+hP;return e>fh?(fh=e,e):(fh+=488e-6,fh)}a(M4,"getNextMonotonicTime");mP.exports={validateEnv:w4,stringifyData:C4,convertKeyValueToWrite:P4,getNextMonotonicTime:M4,getIndexedValues:D4}});var Qd=N((kge,SP)=>{"use strict";var U4=M().OPERATIONS_ENUM,bg=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i=void 0){this.operation=U4.INSERT,this.schema=t,this.table=r,this.hash_attribute=n,this.records=s,this.__origin=i}};SP.exports=bg});var Jd=N((qge,RP)=>{"use strict";var Gge=Qd(),Eh=M(),Og=re(),TP=j(),v4=require("uuid"),{handleHDBError:hh,hdb_errors:B4}=_e(),{HDB_ERROR_MSGS:ph,HTTP_STATUS_CODES:mh}=B4;RP.exports=gP;function gP(e,t,r){for(let s=0;s<t.length;s++)AP(t[s]);let{records:n}=e;for(let s=0;s<n.length;s++){let i=n[s];H4(i,r,e.operation)}}a(gP,"processRows");gP.validateAttribute=AP;function AP(e){if(Buffer.byteLength(String(e))>Eh.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw hh(new Error,ph.ATTR_NAME_LENGTH_ERR(e),mh.BAD_REQUEST,void 0,void 0,!0);if(Og.isEmptyOrZeroLength(e)||Og.isEmpty(e.trim()))throw hh(new Error,ph.ATTR_NAME_NULLISH_ERR,mh.BAD_REQUEST,void 0,void 0,!0)}a(AP,"validateAttribute");function H4(e,t,r){if(!e.hasOwnProperty(t)||Og.isEmptyOrZeroLength(e[t])){if(r===Eh.OPERATIONS_ENUM.INSERT||r===Eh.OPERATIONS_ENUM.UPSERT){e[t]=v4.v4();return}throw TP.error("Update transaction aborted due to record with no hash value:",e),hh(new Error,ph.RECORD_MISSING_HASH_ERR,mh.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>Eh.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw TP.error(e),hh(new Error,ph.HASH_VAL_LENGTH_ERR,mh.BAD_REQUEST,void 0,void 0,!0)}a(H4,"validateHash")});var yP,Mn,Ng,Dl=Ie(()=>{yP=require("events"),Mn=class extends yP.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;drainCloseListener;currentDrainResolver;[Symbol.asyncIterator](){let t=new Ng;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)}},Ng=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 Cg={};je(Cg,{loadGQLSchema:()=>F4,start:()=>wg,startOnMainThread:()=>k4});function wg({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r,n,s,i){let{parse:o,Source:c,Kind:l,NamedTypeNode:u,StringValueNode:d}=await import("graphql"),_=o(new c(r.toString(),s)),E=new Map,f=[],h;for(let g of _.definitions)switch(g.kind){case l.OBJECT_TYPE_DEFINITION:let H=function(Y){if(Y.kind==="NonNullType"){let Q=H(Y.type);return Q.nullable=!1,Q}if(Y.kind==="ListType")return{type:"array",elements:H(Y.type)};let ne={type:Y.name?.value};return Object.defineProperty(ne,"location",{value:Y.loc.startToken}),ne};a(H,"getProperty");let S=g.name.value,y=[],I={table:null,database:null,properties:y};E.set(S,I);for(let Y of g.directives){if(Y.name.value==="table"){for(let ne of Y.arguments)I[ne.name.value]=ne.value.value;I.schema&&(I.database=I.schema),I.table||(I.table=S),I.audit&&(I.audit=I.audit!=="false"),I.attributes=I.properties,f.push(I)}if(Y.name.value==="sealed"&&(I.sealed=!0),Y.name.value==="splitSegments"&&(I.splitSegments=!0),Y.name.value==="replicate"&&(I.replicate=!0),Y.name.value==="export"){I.export=!0;for(let ne of Y.arguments)typeof I.export!="object"&&(I.export={}),I.export[ne.name.value]=ne.value.value}}let U=!1,X={};for(let Y of g.fields){let V=H(Y.type);V.name=Y.name.value,y.push(V),X[V.name]=void 0;for(let ne of Y.directives){let Q=ne.name.value;if(Q==="primaryKey")U?console.warn("Can not define two attributes as a primary key at",ne.loc):(V.isPrimaryKey=!0,U=!0);else if(Q==="indexed")V.indexed=!0;else if(Q==="computed"){for(let de of ne.arguments||[])if(de.name.value==="from"){let W=de.value.value;V.computed={from:m(W,de,X)},V.version==null&&(V.version=W)}else de.name.value==="version"&&(V.version=de.value.value);V.computed=V.computed||!0}else if(Q==="relationship"){let de={};for(let W of ne.arguments)de[W.name.value]=W.value.value;V.relationship=de}else if(Q==="createdTime")V.assignCreatedTime=!0;else if(Q==="updatedTime")V.assignUpdatedTime=!0;else if(Q==="expiresAt")V.expiresAt=!0;else if(Q==="allow"){let de=V.authorizedRoles=[];for(let W of ne.arguments)W.name.value==="role"&&de.push(W.value.value)}else server.knownGraphQLDirectives.includes(Q)&&console.warn(`@${Q} is an unknown directive, at`,ne.loc)}}I.type=S,S==="Query"&&(h=I)}function T(g){let S=E.get(g.type);S?(Object.defineProperty(g,"properties",{value:S.properties}),Object.defineProperty(g,"definition",{value:S})):g.type==="array"?T(g.elements):x4.includes(g.type)||(0,OP.getWorkerIndex)()===0&&console.error(`The type ${g.type} is unknown at line ${g.location.line}, column ${g.location.column}, in ${s}`)}a(T,"connectPropertyType");for(let g of E.values())for(let S of g.properties)T(S);for(let g of f)g.tableClass=e(g),g.export&&(g.export.name===""?i.set((0,Ig.dirname)(n),g.tableClass):i.set((0,Ig.dirname)(n)+"/"+(g.export.name||g.type),g.tableClass,g.export));function m(g,S,y){return new bP.Script(`function computed(attributes) { return function(record) { with(attributes) { with (record) { return ${g}; } } } } computed;`,{filename:s,lineOffset:S.loc.startToken.line-1,columnOffset:S.loc.startToken.column}).runInThisContext()(y)}a(m,"createComputedFrom")}}var Ig,bP,OP,x4,k4,F4,NP=Ie(()=>{Ig=require("path"),bP=require("node:vm");De();OP=L(dt()),x4=["ID","Int","Float","Long","String","Boolean","Date","Bytes","Any","BigInt"];server.knownGraphQLDirectives&&(server.knownGraphQLDirectives=["table","sealed","export","primaryKey","indexed","computed","relationship","createdTime","updatedTime","expiresAt","allow"]);a(wg,"start");k4=wg,F4=wg({ensureTable:Et}).handleFile});var MP={};je(MP,{parse:()=>Dg,streamAsJSON:()=>Xd,stringify:()=>Za});function Xd(e){return new Pg({value:e})}function IP(e){return console.error(e),JSON.stringify(e.toString())}function wP(e,t,r){return e?.then?r?e.then(t,r):e.then(t):t(e)}function Za(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===DP)return LP(e);if(t.resolution)return t.resolution.then(()=>Za(e));throw t}}function LP(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+=LP(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+Za(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function Dg(e){return e?.length>0?(typeof e!="string"&&(e=e.toString()),$4.test(e)?G4.parse(e):JSON.parse(e)):null}var CP,PP,G4,q4,DP,Pg,$4,Lg=Ie(()=>{CP=require("stream"),PP=L(require("json-bigint-fixes")),G4=(0,PP.default)({useNativeBigInt:!0}),q4=1e4,DP={message:"Cannot serialize BigInt to JSON"};BigInt.prototype.toJSON=function(){throw DP};a(Xd,"streamAsJSON");Pg=class extends CP.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(;;){try{o=i.next(),o.then&&(yield o.then(c=>(o=c,""),c=>(o={done:!1,value:{error:c.toString()}},i={next:a(()=>({done:!0}),"next")},"")))}catch(c){o={done:!1,value:{error:c.toString()}},i={next:a(()=>({done:!0}),"next")}}if(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),IP)}catch(s){yield IP(s)}else yield Za(t)}else yield Za(t)}_read(){if(!this._amReading){if(this._amReading=!0,this.done)return this.push(null);wP(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>q4?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 wP(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(IP,"handleError");a(wP,"when");a(Za,"stringify");a(LP,"jsStringify");$4=/[[,:]\s*-?\d{16,}/;a(Dg,"parse")});var YP=N((Qge,KP)=>{"use strict";var Mg=require("recursive-iterator"),V4=require("alasql"),Ug=require("clone"),UP=re(),{handleHDBError:vP,hdb_errors:K4}=_e(),{HDB_ERROR_MSGS:BP,HTTP_STATUS_CODES:HP}=K4,{getDatabases:Y4}=(De(),oe(lt)),W4=["DISTINCT_ARRAY"],xP=Symbol("validateTables"),vg=Symbol("validateTable"),zge=Symbol("getAllColumns"),kP=Symbol("validateAllColumns"),Sh=Symbol("findColumn"),FP=Symbol("validateOrderBy"),Zd=Symbol("validateSegment"),Bg=Symbol("validateColumn"),GP=Symbol("setColumnsForTable"),qP=Symbol("checkColumnsForAsterisk"),$P=Symbol("validateGroupBy"),VP=Symbol("hasColumns"),Hg=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[xP](),this[qP](),this[kP]()}[xP](){if(this[VP]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[vg](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[vg](t.table)})}}[VP](){let t=!1,r=new Mg(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[vg](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=Y4();if(!r[t.databaseid])throw vP(new Error,BP.SCHEMA_NOT_FOUND(t.databaseid),HP.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw vP(new Error,BP.TABLE_NOT_FOUND(t.databaseid,t.tableid),HP.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=Ug(s);i.table=Ug(t),this.attributes.push(i)})}[Sh](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)}[qP](){let t=new Mg(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[GP](r.tableid)}[GP](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new V4.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[kP](){this[Zd](this.statement.columns,!1),this[Zd](this.statement.joins,!1),this[Zd](this.statement.where,!1),this[$P](this.statement.group,!1),this[Zd](this.statement.order,!0)}[Zd](t,r){if(!t)return;let n=new Mg(t),s=[];for(let{node:i,path:o}of n)!UP.isEmpty(i)&&!UP.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[FP](i):s.push(this[Bg](i)));return s}[$P](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&W4.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=Ug(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[Sh](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[Sh](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`}[FP](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[Bg](t)}[Bg](t){let r=this[Sh](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]}};KP.exports=Hg});var jP=N((Xge,WP)=>{"use strict";var xg=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")}};WP.exports=xg});var QP=N((eAe,zP)=>{"use strict";var kg=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};zP.exports=kg});var eD={};je(eD,{HAS_EXPIRATION:()=>Ah,HAS_RESIDENCY_ID:()=>Wg,HAS_STRUCTURE_UPDATE:()=>Rh,LAST_TIMESTAMP_PLACEHOLDER:()=>n_,LOCAL_TIMESTAMP:()=>j4,METADATA:()=>e_,NO_TIMESTAMP:()=>Gg,PENDING_LOCAL_TIME:()=>jg,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>Yg,RecordEncoder:()=>Kg,TIMESTAMP_ASSIGN_LAST:()=>Q4,TIMESTAMP_ASSIGN_NEW:()=>XP,TIMESTAMP_ASSIGN_PREVIOUS:()=>ZP,TIMESTAMP_PLACEHOLDER:()=>Th,TIMESTAMP_RECORD_PREVIOUS:()=>qg,getUpdateRecord:()=>zg,handleLocalTimeForGets:()=>yh});function X4(){return r_[0]=r_[0]^64,z4.getFloat64(0)}function yh(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,u=l?.[e_];return u>=0&&(c.metadataFlags=u,c.localTime=l.localTime,c.value=l.value,c.residencyId=l.residencyId,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?.[e_]>=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,u=l[e_];return u>=0&&(c.metadataFlags=u,c.localTime=l.localTime,c.value=l.value,c.residencyId=l.residencyId,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,ec.push(new WeakRef(this))),o.call(this)},i.prototype.done=function(){if(c.call(this),this.isDone)for(let l=0;l<ec.length;l++){let u=ec[l].deref();(!u||u.isDone||u.isCommitted)&&ec.splice(l--,1)}},i.prototype.done.isTracked=!0}return e}function zg(e,t,r){return function(n,s,i,o,c=-1,l,u,d="put",_,E){_||l==null?Ll=i?.localTime?qg|ZP:Gg:Ll=l?i?.localTime?qg|16384:XP|16384:Gg;let f=u?.expiresAt;if(f>=0&&(c|=Ah),t_=c,$g=f,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let h={version:o,instructedWrite:Ll>0},T,m=0;try{let g=i?.residencyId,S=u?.residencyId;S&&(Vg=S,t_|=Wg,m|=tc),g!==S&&(m|=rc,g||(g=0)),c&Ah&&(m|=i_),u?.originatingOperation&&(m|=s_),_&&(h.ifVersion=T=i?.version??null);let y=e.put(n,s,h);if(l){let I=u?.user?.username;if(E&&(gh=e.encoder.encode(E)),e.encoder.hasStructureUpdate&&(m|=Rh,e.encoder.hasStructureUpdate=!1),_&&i?.localTime){let U=i?.localTime,H=r.get(U);if(H){let X=xt(H).previousLocalTime;return r.put(U,Ml(o,t,n,X,u?.nodeId??server.replication.getThisNodeId(r)??0,I,d,gh,m,S,g,f),{ifVersion:T}),y}}r.put(n_,Ml(o,t,n,i?.localTime?1:0,u?.nodeId??server.replication?.getThisNodeId(r)??0,I,d,gh,m,S,g,f,u?.originatingOperation),{append:d!=="invalidate",instructedWrite:!0,ifVersion:T})}return y}catch(g){throw g.message+=" id: "+n+" options: "+h,g}}}var JP,Fg,Th,n_,Yg,j4,e_,r_,z4,Gg,XP,Q4,ZP,qg,Ah,Wg,jg,Rh,J4,gh,Ll,t_,$g,Vg,Kg,ec,Ul=Ie(()=>{JP=require("msgpackr");zi();Fg=L(j()),Th=new Uint8Array([1,1,1,1,4,64,0,0]),n_=new Uint8Array([1,1,1,1,1,0,0,0]),Yg=new Uint8Array([1,1,1,1,3,64,0,0]),j4=Symbol("local-timestamp"),e_=Symbol("metadata"),r_=new Uint8Array(8),z4=new DataView(r_.buffer,0,8),Gg=0,XP=0,Q4=1,ZP=3,qg=4,Ah=16,Wg=32,jg=1,Rh=256,Ll=0,t_=-1,$g=-1,Vg=0,Kg=class extends JP.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(s,i){if(Ll||t_>=0){let o=0,c=Ll;c&&(o+=8,Ll=0);let l=t_,u=$g,d=Vg;l>=0&&(o+=2,t_=-1,u>=0&&(o+=8,$g=-1),d&&(o+=4,Vg=0));let _=J4=r.call(this,s,i|2048|o);gh=_.subarray((_.start||0)+o,_.end);let E=_.start||0;return c&&(Th[4]=c,Th[5]=c>>8,_.set(Th,E),E+=8),l>=0&&(_[E++]=l&31,_[E++]=l>>5,u>=0&&((_.dataView||(_.dataView=new DataView(_.buffer,_.byteOffset,_.byteLength))).setFloat64(E,u),E+=8),d&&(_.dataView||(_.dataView=new DataView(_.buffer,_.byteOffset,_.byteLength))).setUint32(E,d)),_}else return r.call(this,s,i)};let n=this.saveStructures;this.saveStructures=function(s,i){let o=n.call(this,s,i);return this.hasStructureUpdate=!0,o}}decode(t,r){let n=r?.start||0,s=r>-1?r:r?.end||t.length,i=t[n],o=0;try{if(i<32&&s>2){let c=n,l;if(i===2){if(t.copy)t.copy(r_,0,c),c+=8;else for(let E=0;E<8;E++)r_[E]=t[c++];l=X4(),i=t[c]}let u,d;i<32&&(o=i|t[c+1]<<5,c+=2,o&Ah&&(u=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8),o&Wg&&(d=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4));let _=r?.valueAsBuffer?t.subarray(c,s):super.decode(t.subarray(c,s),s-c);return{localTime:l,value:_,[e_]:o,expiresAt:u,residencyId:d}}return r?.valueAsBuffer?t:super.decode(t,r)}catch(c){throw c.message+=", data: "+t.slice(0,40).toString("hex"),c}}};a(X4,"getTimestamp");a(yh,"handleLocalTimeForGets");ec=[];setInterval(()=>{for(let e=0;e<ec.length;e++){let t=ec[e].deref();!t||t.isDone||t.isCommitted?ec.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(Fg.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):Fg.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(zg,"getUpdateRecord")});var o_=N((iAe,rD)=>{"use strict";var tD=se(),Z4=M(),{RecordEncoder:eJ}=(Ul(),oe(eD)),sAe=require("fs");tD.initSync();var tJ=tD.get(Z4.CONFIG_PARAMS.STORAGE_CACHING)!==!1,Qg=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=tJ&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:eJ})}};rD.exports=Qg});var a_=N((aAe,nD)=>{"use strict";var Un=se(),cs=M();Un.initSync();var bh=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=Un.get(cs.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Un.get(cs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Un.get(cs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Un.get(cs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Un.get(cs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Un.get(cs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Un.get(cs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Un.get(cs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Un.get(cs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Un.get(cs.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Un.get(cs.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Un.get(cs.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};nD.exports=bh;bh.MAX_DBS=1e4});var ht=N((lAe,fD)=>{"use strict";var Xg=require("lmdb"),ks=require("fs-extra"),vn=require("path"),Oh=cn(),oD=j(),ln=Pn().LMDB_ERRORS_ENUM,Nh=QP(),Zg=o_(),aD=a_(),Ko=Ht(),sD=M(),{table:rJ,resetDatabases:nJ}=(De(),oe(lt)),iD=se(),Fs=Ko.INTERNAL_DBIS_NAME,cD=Ko.DBI_DEFINITION_NAME,sJ="data.mdb",iJ="lock.mdb",c_=".mdb",oJ="-lock",Jg=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=ls(t,r),this.key_type=this.dbi[Ko.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[Ko.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new Xg.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function Ih(e,t){if(e===void 0)throw new Error(ln.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(ln.ENV_NAME_REQUIRED)}a(Ih,"pathEnvNameValidation");async function eA(e,t,r=!0){try{await ks.access(e)}catch(n){throw n.code==="ENOENT"?new Error(ln.INVALID_BASE_PATH):n}try{let n=vn.join(e,t+c_);return await ks.access(n,ks.constants.R_OK|ks.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await ks.access(vn.join(e,t,sJ),ks.constants.R_OK|ks.constants.F_OK),vn.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(ln.INVALID_ENVIRONMENT)}else throw new Error(ln.INVALID_ENVIRONMENT);throw n}}a(eA,"validateEnvironmentPath");function wh(e,t){if(Oh.validateEnv(e),t===void 0)throw new Error(ln.DBI_NAME_REQUIRED)}a(wh,"validateEnvDBIName");async function aJ(e,t,r=!1,n=!1){Ih(e,t);let s=vn.basename(e);t=t.toString();let i=iD.get(sD.CONFIG_PARAMS.DATABASES);i||iD.setProperty(sD.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await eA(e,t,n),lD(e,t,r)}catch(o){if(o.message===ln.INVALID_ENVIRONMENT){let c=vn.join(e,t);await ks.mkdirp(n?c:e);let l=new aD(n?c:c+c_,!1),u=Xg.open(l);u.dbis=Object.create(null);let d=new Zg(!1);u.openDB(Fs,d),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let _=tA(e,t,r);return u[Ko.ENVIRONMENT_NAME_KEY]=_,global.lmdb_map[_]=u,u}throw o}}a(aJ,"createEnvironment");async function cJ(e,t,r,n=!0){Ih(e,t),t=t.toString();let s=vn.join(e,t);return rJ({table:t,database:vn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(cJ,"copyEnvironment");async function lD(e,t,r=!1){Ih(e,t),t=t.toString();let n=tA(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 eA(e,t),i=vn.join(e,t+c_),o=s!=i,c=new aD(s,o),l=Xg.open(c);l.dbis=Object.create(null);let u=dD(l);for(let d=0;d<u.length;d++)ls(l,u[d]);return l[Ko.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(lD,"openEnvironment");async function lJ(e,t,r=!1){Ih(e,t),t=t.toString();let n=vn.join(e,t+c_),s=await eA(e,t);if(global.lmdb_map!==void 0){let i=tA(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await uD(o),delete global.lmdb_map[i]}}await ks.remove(s),await ks.remove(s===n?s+oJ:vn.join(vn.dirname(s),iJ))}a(lJ,"deleteEnvironment");async function uD(e){Oh.validateEnv(e);let t=e[Ko.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(uD,"closeEnvironment");function tA(e,t,r=!1){let s=`${vn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(tA,"getCachedEnvironmentName");function uJ(e){Oh.validateEnv(e);let t=Object.create(null),r=ls(e,Fs);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==Fs)try{t[n]=Object.assign(new Nh,s)}catch{oD.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(uJ,"listDBIDefinitions");function dD(e){Oh.validateEnv(e);let t=[],r=ls(e,Fs);for(let{key:n}of r.getRange({start:!1}))n!==Fs&&t.push(n);return t}a(dD,"listDBIs");function dJ(e,t){let n=ls(e,Fs).getEntry(t),s=new Nh;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{oD.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(dJ,"getDBIDefinition");function _D(e,t,r,n=!r){if(wh(e,t),t=t.toString(),t===Fs)throw new Error(ln.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return ls(e,t)}catch(s){if(s.message===ln.DBI_DOES_NOT_EXIST){let i=new Zg(r,n===!0),o=e.openDB(t,i),c=new Nh(r===!0,n);return o[cD]=c,ls(e,Fs).putSync(t,c),e.dbis[t]=o,o}throw s}}a(_D,"createDBI");function ls(e,t){if(wh(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==Fs?r=dJ(e,t):r=new Nh,r===void 0)throw new Error(ln.DBI_DOES_NOT_EXIST);let n;try{let s=new Zg(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(ln.DBI_DOES_NOT_EXIST):s}return n[cD]=r,e.dbis[t]=n,n}a(ls,"openDBI");function _J(e,t){wh(e,t),t=t.toString();let r=ls(e,t),n=r.getStats();return r[Ko.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(_J,"statDBI");async function fJ(e,t){try{let r=vn.join(e,t+c_);return(await ks.stat(r)).size}catch{throw new Error(ln.INVALID_ENVIRONMENT)}}a(fJ,"environmentDataSize");function EJ(e,t){if(wh(e,t),t=t.toString(),t===Fs)throw new Error(ln.CANNOT_DROP_INTERNAL_DBIS_NAME);ls(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],ls(e,Fs).removeSync(t)}a(EJ,"dropDBI");function hJ(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{ls(e,i)}catch(o){if(o.message===ln.DBI_DOES_NOT_EXIST)_D(e,i,i!==t,i===t),n=!0;else throw o}}n&&nJ()}a(hJ,"initializeDBIs");fD.exports={openDBI:ls,openEnvironment:lD,createEnvironment:aJ,listDBIs:dD,listDBIDefinitions:uJ,createDBI:_D,dropDBI:EJ,statDBI:_J,deleteEnvironment:lJ,initializeDBIs:hJ,TransactionCursor:Jg,environmentDataSize:fJ,copyEnvironment:cJ,closeEnvironment:uD}});var hD=N((dAe,ED)=>{"use strict";var rA=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};ED.exports=rA});var mD=N((fAe,pD)=>{"use strict";var nA=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}};pD.exports=nA});var TD=N((hAe,SD)=>{"use strict";var sA=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};SD.exports=sA});var sc=N((gAe,RD)=>{"use strict";var pJ=ht(),mJ=hD(),SJ=mD(),TJ=TD(),mi=cn(),l_=Pn().LMDB_ERRORS_ENUM,gJ=Ht(),Qi=M(),AJ=re(),RJ=require("uuid"),mAe=require("lmdb"),{handleHDBError:yJ,hdb_errors:bJ}=_e(),{OVERFLOW_MARKER:SAe,MAX_SEARCH_KEY_LENGTH:TAe}=gJ,gD=se();gD.initSync();var Ch=gD.get(Qi.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),iA=Qi.TIME_STAMP_NAMES_ENUM.CREATED_TIME,nc=Qi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function OJ(e,t,r,n,s=mi.getNextMonotonicTime()){lA(e,t,r,n),oA(e,t,r);let i=new mJ,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l];AD(u,!0,s);let d=NJ(e,t,r,u),_=u[t];o.push(d),c.push(_)}return aA(o,c,n,i,s)}a(OJ,"insertRecords");function NJ(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 d=c([[{}]]);Array.isArray(d)&&(c=d[0][Qi.FUNC_VAL],n[o]=c)}let l=mi.getIndexedValues(c),u=e.dbis[o];if(l){Ch&&u.prefetch(l.map(d=>({key:d,value:s})),Ph);for(let d=0,_=l.length;d<_;d++)u.put(l[d],s)}}Ch&&e.dbis[t].prefetch([s],Ph),e.dbis[t].put(s,n,n[nc])})}a(NJ,"insertRecord");function IJ(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(IJ,"removeSkippedRecords");function AD(e,t,r){let n=r>0;(n||!Number.isInteger(e[nc]))&&(e[nc]=r||(r=mi.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[iA]))&&(e[iA]=r||mi.getNextMonotonicTime()):delete e[iA]}a(AD,"setTimestamps");function oA(e,t,r){r.indexOf(Qi.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(Qi.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(Qi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(Qi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),pJ.initializeDBIs(e,t,r)}a(oA,"initializeTransaction");async function wJ(e,t,r,n,s=mi.getNextMonotonicTime()){lA(e,t,r,n),oA(e,t,r);let i=new SJ,o=[],c=[],l=[];for(let u=0;u<n.length;u++){let d=n[u],_=d[t],E;try{E=cA(e,t,d,_,i,!0,s)}catch{i.skipped_hashes.push(_),o.push(u);continue}c.push(E),l.push(_)}return aA(c,l,n,i,s,o)}a(wJ,"updateRecords");async function CJ(e,t,r,n,s=mi.getNextMonotonicTime()){try{lA(e,t,r,n)}catch(l){throw yJ(l,l.message,bJ.HTTP_STATUS_CODES.BAD_REQUEST)}oA(e,t,r);let i=new TJ,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l],d;AJ.isEmpty(u[t])?(d=RJ.v4(),u[t]=d):d=u[t];let _=cA(e,t,u,d,i,!1,s);o.push(_),c.push(d)}return aA(o,c,n,i,s)}a(CJ,"upsertRecords");async function aA(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||mi.getNextMonotonicTime(),IJ(r,i),n}a(aA,"finalizeWrite");function cA(e,t,r,n,s,i=!1,o){let c=e.dbis[t],l=c.getEntry(n),u=l?.value,d=u;if(!u){if(i)return!1;u={}}if(AD(r,!d,o),Number.isInteger(r[nc])&&u[nc]>r[nc])return!1;d&&s.original_records.push(u);let _,E=a(()=>{for(let h in r){if(!r.hasOwnProperty(h)||h===t)continue;let T=r[h],m=e.dbis[h];if(m===void 0)continue;let g=u[h];if(typeof T=="function"){let y=T([[u]]);Array.isArray(y)&&(T=y[0][Qi.FUNC_VAL],r[h]=T)}if(T===g)continue;let S=mi.getIndexedValues(g);if(S){Ch&&m.prefetch(S.map(y=>({key:y,value:n})),Ph);for(let y=0,I=S.length;y<I;y++)m.remove(S[y],n)}if(S=mi.getIndexedValues(T),S){Ch&&m.prefetch(S.map(y=>({key:y,value:n})),Ph);for(let y=0,I=S.length;y<I;y++)m.put(S[y],n)}}let f={...u,...r};c.put(n,f,f[nc])},"do_put");return l?_=c.ifVersion(n,l.version,E):_=c.ifNoExists(n,E),_.then(f=>f?!0:cA(e,t,r,n,s,i,o))}a(cA,"updateUpsertRecord");function PJ(e,t,r){if(mi.validateEnv(e),t===void 0)throw new Error(l_.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(l_.WRITE_ATTRIBUTES_REQUIRED):new Error(l_.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(PJ,"validateBasic");function lA(e,t,r,n){if(PJ(e,t,r),!Array.isArray(n))throw n===void 0?new Error(l_.RECORDS_REQUIRED):new Error(l_.RECORDS_MUST_BE_ARRAY)}a(lA,"validateWrite");function Ph(){}a(Ph,"noop");RD.exports={insertRecords:OJ,updateRecords:wJ,upsertRecords:CJ}});var Ji=N((RAe,DJ)=>{DJ.exports={hdb_user:{hash_attribute:"username",name:"hdb_user",schema:"system",residence:["*"],attributes:[{attribute:"username"},{attribute:"password"},{attribute:"role"},{attribute:"active"},{attribute:"hash"},{attribute:"refresh_token"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_role:{hash_attribute:"id",name:"hdb_role",schema:"system",attributes:[{attribute:"id"},{attribute:"role"},{attribute:"permission"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}],residence:["*"]},hdb_job:{hash_attribute:"id",name:"hdb_job",schema:"system",attributes:[{attribute:"id"},{attribute:"user"},{attribute:"type"},{attribute:"status"},{attribute:"start_datetime"},{attribute:"end_datetime"},{attribute:"message"},{attribute:"created_datetime"},{attribute:"request"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_license:{hash_attribute:"license_key",name:"hdb_license",schema:"system",attributes:[{attribute:"license_key"},{attribute:"company"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_info:{hash_attribute:"info_id",name:"hdb_info",schema:"system",attributes:[{attribute:"info_id"},{attribute:"data_version_num"},{attribute:"hdb_version_num"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_nodes:{hash_attribute:"name",name:"hdb_nodes",schema:"system",attributes:[{attribute:"name"},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"}]},hdb_certificate:{hash_attribute:"name",name:"hdb_certificate",schema:"system",attributes:[{attribute:"name"},{attribute:"uses"},{attribute:"certificate"},{attribute:"is_authority"},{attribute:"private_key_name"},{attribute:"details"},{attribute:"is_self_signed"},{attribute:"__updatedtime__"}]},hdb_analytics:{hash_attribute:"id",name:"hdb_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]},hdb_raw_analytics:{hash_attribute:"id",name:"hdb_raw_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{attribute:"time"},{attribute:"metrics"}]},hdb_temp:{hash_attribute:"id",name:"hdb_temp",schema:"system",attributes:[{attribute:"id"}]},hdb_durable_session:{hash_attribute:"id",name:"hdb_durable_session",schema:"system",attributes:[{attribute:"id"}]},hdb_session_will:{hash_attribute:"id",name:"hdb_session_will",schema:"system",attributes:[{attribute:"id"}]}}});var Ti=N((yAe,OD)=>{"use strict";var bD=re(),yD=M(),vl=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Si=require("joi"),Yo={schema_format:{pattern:vl,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},LJ=Si.alternatives(Si.string().min(1).max(Yo.schema_length.maximum).pattern(vl).messages({"string.pattern.base":"{:#label} "+Yo.schema_format.message}),Si.number(),Si.array()).required(),MJ=Si.alternatives(Si.string().min(1).max(Yo.schema_length.maximum).pattern(vl).messages({"string.pattern.base":"{:#label} "+Yo.schema_format.message}),Si.number()),UJ=Si.alternatives(Si.string().min(1).max(Yo.schema_length.maximum).pattern(vl).messages({"string.pattern.base":"{:#label} "+Yo.schema_format.message}),Si.number()).required();function vJ(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>Yo.schema_length.maximum?`'${e}' maximum of 250 characters`:vl.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(vJ,"checkValidTable");function BJ(e,t){return bD.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(BJ,"validateSchemaExists");function HJ(e,t){let r=t.state.ancestors[0].schema;return bD.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(HJ,"validateTableExists");function xJ(e,t){return e.toLowerCase()===yD.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${yD.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(xJ,"validateSchemaName");OD.exports={common_validators:Yo,schema_regex:vl,hdb_schema_table:LJ,validateSchemaExists:BJ,validateTableExists:HJ,validateSchemaName:xJ,checkValidTable:vJ,hdb_database:MJ,hdb_table:UJ}});var Dh=N((OAe,ND)=>{var{common_validators:gi}=Ti(),d_=Tt(),u_="is required",rr={database:{presence:!1,format:gi.schema_format,length:gi.schema_length},schema:{presence:!1,format:gi.schema_format,length:gi.schema_length},table:{presence:!0,format:gi.schema_format,length:gi.schema_length},attribute:{presence:!0,format:gi.schema_format,length:gi.schema_length},hash_attribute:{presence:!0,format:gi.schema_format,length:gi.schema_length}};function __(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(__,"makeAttributesStrings");function kJ(e){return e=__(e),rr.table.presence=!1,rr.attribute.presence=!1,rr.hash_attribute.presence=!1,d_.validateObject(e,rr)}a(kJ,"schema_object");function FJ(e){return e=__(e),rr.table.presence={message:u_},rr.attribute.presence=!1,rr.hash_attribute.presence=!1,d_.validateObject(e,rr)}a(FJ,"table_object");function GJ(e){return e=__(e),rr.table.presence={message:u_},rr.attribute.presence=!1,d_.validateObject(e,rr)}a(GJ,"create_table_object");function qJ(e){return e=__(e),rr.table.presence={message:u_},rr.attribute.presence={message:u_},rr.hash_attribute.presence=!1,d_.validateObject(e,rr)}a(qJ,"attribute_object");function $J(e){return e=__(e),rr.table.presence={message:u_},rr.attribute.presence=!1,rr.hash_attribute.presence=!1,d_.validateObject(e,rr)}a($J,"describe_table");function VJ(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(VJ,"validateTableResidence");ND.exports={schema_object:kJ,create_table_object:GJ,table_object:FJ,attribute_object:qJ,describe_table:$J,validateTableResidence:VJ}});var wD=N((IAe,ID)=>{"use strict";var KJ=require("uuid"),uA=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||KJ.v4(),this.schema_table=`${this.schema}.${this.table}`}};ID.exports=uA});var Lh=N((CAe,CD)=>{"use strict";var YJ=wD(),dA=class extends YJ{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}};CD.exports=dA});var DD=N((DAe,PD)=>{"use strict";PD.exports=jJ;var WJ="inserted";function jJ(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===WJ?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(jJ,"returnObject")});var Mh=N((UAe,vD)=>{"use strict";var zJ=M(),_A=ht(),QJ=sc(),{getSystemSchemaPath:JJ,getSchemaPath:XJ}=gt(),MAe=Ji(),ZJ=Dh(),e3=Lh(),t3=DD(),{handleHDBError:LD,hdb_errors:UD}=_e(),MD=re(),{HTTP_STATUS_CODES:r3}=UD,n3="inserted";vD.exports=s3;async function s3(e){let t=ZJ.attribute_object(e);if(t)throw LD(new Error,t.message,UD.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=!e.skip_table_check&&MD.checkGlobalSchemaTable(e.schema,e.table);if(r)throw LD(new Error,r,r3.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=MD.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 e3(e.schema,e.table,e.attribute,e.id);try{let i=await _A.openEnvironment(XJ(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}`);_A.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await _A.openEnvironment(JJ(),zJ.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await QJ.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_attribute_attributes,[s]);return t3(n3,c,{records:[s]},l)}catch(i){throw i}}a(s3,"lmdbCreateAttribute")});var EA=N((BAe,HD)=>{var{hdb_table:i3,hdb_database:BD}=Ti(),o3=Tt(),fA=require("joi"),a3={undefined:"undefined",null:"null"},c3=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||a3[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"),l3=fA.object({database:BD,schema:BD,table:i3,records:fA.array().items(fA.object().custom(c3)).required()});HD.exports=function(e){return o3.validateBySchema(e,l3)}});var f_=N((kAe,kD)=>{"use strict";var Xi=re(),xD=j(),xAe=EA(),{getDatabases:u3}=(De(),oe(lt)),{ClientError:ic}=_e();kD.exports=d3;function d3(e){if(Xi.isEmpty(e))throw new ic("invalid update parameters defined.");if(Xi.isEmptyOrZeroLength(e.schema))throw new ic("invalid schema specified.");if(Xi.isEmptyOrZeroLength(e.table))throw new ic("invalid table specified.");if(!Array.isArray(e.records))throw new ic("records must be an array");let t=u3()[e.schema]?.[e.table];if(Xi.isEmpty(t))throw new ic(`could not retrieve schema:${e.schema} and table ${e.table}`);let r=t.primaryKey,n=new Set,s={},i=!1;return e.operation==="update"&&(i=!0),e.records.forEach(o=>{if(i&&Xi.isEmptyOrZeroLength(o[r]))throw xD.error("a valid hash attribute must be provided with update record:",o),new ic("a valid hash attribute must be provided with update record, check log for more info");if(!Xi.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw xD.error(`a valid hash value must be provided with ${e.operation} record:`,o),new ic(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!Xi.isEmpty(o[r])&&o[r]!==""&&n.has(Xi.autoCast(o[r]))&&(o.skip=!0),n.add(Xi.autoCast(o[r]));for(let c in o)s[c]=1}),s[r]=1,{schema_table:t,hashes:Array.from(n),attributes:Object.keys(s)}}a(d3,"insertUpdateValidate")});var GD=N((GAe,FD)=>{"use strict";var hA=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};FD.exports=hA});var VD=N(($Ae,$D)=>{"use strict";var pA=ht(),_3=j(),qD=Pn().LMDB_ERRORS_ENUM;$D.exports=f3;async function f3(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 pA.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==qD.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await pA.closeEnvironment(global.lmdb_map[n]),await pA.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==qD.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){_3.error(t)}}a(f3,"cleanLMDBMap")});var Zi=N((KAe,jD)=>{"use strict";var E_=require("crypto"),E3=se(),{CONFIG_PARAMS:h3}=M(),YD="aes-256-cbc",p3=32,m3=16,mA=64,WD=32,S3=mA+WD,KD=new Map;jD.exports={encrypt:T3,decrypt:g3,createNatsTableStreamName:A3};function T3(e){let t=E_.randomBytes(p3),r=E_.randomBytes(m3),n=E_.createCipheriv(YD,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(T3,"encrypt");function g3(e){let t=e.substr(0,mA),r=e.substr(mA,WD),n=e.substr(S3,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=E_.createDecipheriv(YD,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(g3,"decrypt");function A3(e,t){let r=E3.get(h3.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=KD.get(r);return n||(n=E_.createHash("md5").update(r).digest("hex"),KD.set(r,n)),n}a(A3,"createNatsTableStreamName")});var eo=N((jAe,JD)=>{"use strict";var WAe=Vr(),h_=j(),zD=Dh(),R3=Zi(),Uh=re(),{handleHDBError:vh,hdb_errors:y3}=_e(),{HDB_ERROR_MSGS:Bh,HTTP_STATUS_CODES:SA}=y3,QD=se();QD.initSync();var{getDatabases:TA}=(De(),oe(lt)),b3=require("fs-extra"),O3=M();JD.exports={describeAll:N3,describeTable:Hh,describeSchema:I3};async function N3(e={}){try{let t=Uh.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=TA(),o={},c={},l=[],u=e?.exact_count;for(let _ in i){o[_]=!0,!t&&!s&&!r&&(c[_]=e.hdb_user?.role?.permission[_]?.describe);let E=i[_];for(let f in E)try{let h;if(t||s||r)h=await Hh({schema:_,table:f,exact_count:u});else if(n&&n[_].describe&&n[_].tables[f].describe){let T=n[_].tables[f].attribute_permissions;h=await Hh({schema:_,table:f,exact_count:u},T)}h&&l.push(h)}catch(h){h_.error(h)}}let d={};for(let _ in l)t||s||r?(d[l[_].schema]==null&&(d[l[_].schema]={}),d[l[_].schema][l[_].name]=l[_],o[l[_].schema]&&delete o[l[_].schema]):c[l[_].schema]&&(d[l[_].schema]==null&&(d[l[_].schema]={}),d[l[_].schema][l[_].name]=l[_],o[l[_].schema]&&delete o[l[_].schema]);for(let _ in o)t||s||r?d[_]={}:c[_]&&(d[_]={});return d}catch(t){return h_.error("Got an error in describeAll"),h_.error(t),vh(new Error,Bh.DESCRIBE_ALL_ERR)}}a(N3,"describeAll");async function Hh(e,t){Uh.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=zD.describe_table(e);if(i)throw i;let c=TA()[r];if(!c)throw vh(new Error,Bh.SCHEMA_NOT_FOUND(e.schema),SA.NOT_FOUND);let l=c[n];if(!l)throw vh(new Error,Bh.TABLE_NOT_FOUND(e.schema,e.table),SA.NOT_FOUND);function u(f){d.push({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(u,"pushAtt");let d=[];if(s){let f={};s.forEach(h=>{h.describe&&(f[h.attribute_name]=!0)}),l.attributes.forEach(h=>{f[h.name]&&u(h)})}else l.attributes?.forEach(f=>u(f));let _;try{_=(await b3.stat(l.primaryStore.env.path)).size}catch(f){h_.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:d,db_size:_};l.replicate!==void 0&&(E.replicate=l.replicate),l.expirationMS!==void 0&&(E.expiration=l.expirationMS/1e3+"s"),l.sealed!==void 0&&(E.sealed=l.sealed),l.sources?.length>0&&(E.sources=l.sources.map(f=>f.name).filter(f=>f&&f!=="NATSReplicator"&&f!=="Replicator")),QD.get(O3.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(E.clustering_stream_name=R3.createNatsTableStreamName(E.schema,E.name));try{let f=l.getRecordCount({exactCount:e.exact_count==="true"});E.record_count=f.recordCount,E.table_size=l.getSize(),E.db_audit_size=l.getAuditSize(),E.estimated_record_range=f.estimatedRange;let h=l.auditStore;if(h)for(let T of h.getKeys({reverse:!0,limit:1}))E.last_updated_record=T[0];if(!E.last_updated_record&&l.indices.__updatedtime__)for(let T of l.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))E.last_updated_record=T}catch(f){h_.warn(`unable to stat table dbi due to ${f}`)}return E}a(Hh,"descTable");async function I3(e){Uh.transformReq(e);let t=zD.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=TA()[n];if(!i)throw vh(new Error,Bh.SCHEMA_NOT_FOUND(e.schema),SA.NOT_FOUND);let o={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),Uh.isEmpty(l)||l.describe){let u=await Hh({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);u&&(o[u.name]=u)}}return o}a(I3,"describeSchema")});var Gs=N((XAe,rL)=>{var w3=Ji(),{callbackify:ZD,promisify:C3}=require("util"),{getDatabases:eL}=(De(),oe(lt));rL.exports={setSchemaDataToGlobal:XD,getTableSchema:P3,getSystemSchema:D3,setSchemaDataToGlobalAsync:C3(XD)};var tL=eo(),QAe=ZD(tL.describeAll),JAe=ZD(tL.describeTable);function XD(e){global.hdb_schema=eL(),e&&e()}a(XD,"setSchemaDataToGlobal");function P3(e,t,r){let n=eL()[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(P3,"getTableSchema");function D3(){return w3}a(D3,"getSystemSchema")});var un=N((eRe,oL)=>{"use strict";var kh=EA(),Cr=re(),L3=require("util"),Fh=Bn(),M3=Gs(),nL=j(),{handleHDBError:oc,hdb_errors:U3}=_e(),{HTTP_STATUS_CODES:ac}=U3,v3=L3.promisify(M3.getTableSchema),B3="updated",sL="inserted",iL="upserted";oL.exports={insert:x3,update:k3,upsert:F3,validation:H3,flush:G3};async function H3(e){if(Cr.isEmpty(e))throw new Error("invalid update parameters defined.");if(Cr.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if(Cr.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await v3(e.schema,e.table),r=kh(e);if(r)throw r;if(!Array.isArray(e.records))throw new Error("records must be an array");let n=t.hash_attribute,s=new Set,i={},o=!1;return e.operation==="update"&&(o=!0),e.records.forEach(c=>{if(o&&Cr.isEmptyOrZeroLength(c[n]))throw nL.error("a valid hash attribute must be provided with update record:",c),new Error("a valid hash attribute must be provided with update record");if(!Cr.isEmptyOrZeroLength(c[n])&&(c[n]==="null"||c[n]==="undefined"))throw nL.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[n]}" is not a valid hash attribute value`);!Cr.isEmpty(c[n])&&c[n]!==""&&s.has(Cr.autoCast(c[n]))&&(c.skip=!0),s.add(Cr.autoCast(c[n]));for(let l in c)i[l]=1}),i[n]=1,{schema_table:t,hashes:Array.from(s),attributes:Object.keys(i)}}a(H3,"validation");async function x3(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=kh(e);if(t)throw oc(new Error,t.message,ac.BAD_REQUEST);Cr.transformReq(e);let r=Cr.checkSchemaTableExist(e.schema,e.table);if(r)throw oc(new Error,r,ac.BAD_REQUEST);let n=await Fh.createRecords(e);return xh(sL,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(x3,"insertData");async function k3(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=kh(e);if(t)throw oc(new Error,t.message,ac.BAD_REQUEST);Cr.transformReq(e);let r=Cr.checkSchemaTableExist(e.schema,e.table);if(r)throw oc(new Error,r,ac.BAD_REQUEST);let n=await Fh.updateRecords(e);return Cr.isEmpty(n.existing_rows)?xh(B3,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):xh(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(k3,"updateData");async function F3(e){if(e.operation!=="upsert")throw oc(new Error,"invalid operation, must be upsert",ac.INTERNAL_SERVER_ERROR);let t=kh(e);if(t)throw oc(new Error,t.message,ac.BAD_REQUEST);Cr.transformReq(e);let r=Cr.checkSchemaTableExist(e.schema,e.table);if(r)throw oc(new Error,r,ac.BAD_REQUEST);let n=await Fh.upsertRecords(e);return xh(iL,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(F3,"upsertData");function xh(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===sL?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===iL?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(xh,"returnObject");function G3(e){return Cr.transformReq(e),Fh.flush(e.schema,e.table)}a(G3,"flush")});var AA=N((rRe,lL)=>{var q3=Tt(),gA=require("joi"),{hdb_table:$3,hdb_database:aL}=Ti(),cL={schema:aL,database:aL,table:$3},V3={date:gA.date().iso().required()},K3={timestamp:gA.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};lL.exports=function(e,t){let r=t==="timestamp"?{...cL,...K3}:{...cL,...V3},n=gA.object(r);return q3.validateBySchema(e,n)}});var _L=N((nRe,dL)=>{var Y3=Tt(),RA=require("joi"),{hdb_table:W3,hdb_database:uL}=Ti(),j3=RA.object({schema:uL,database:uL,table:W3,hash_values:RA.array().required(),ids:RA.array()});dL.exports=function(e){return Y3.validateBySchema(e,j3)}});var NA=N((sRe,fL)=>{"use strict";var yA=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}},bA=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}},OA=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};fL.exports={InsertObject:yA,NoSQLSeachObject:bA,DeleteResponseObject:OA}});var uc=N((oRe,SL)=>{"use strict";var hL=AA(),z3=_L(),cc=re(),EL=require("moment"),pL=j(),{promisify:Q3,callbackify:J3}=require("util"),lc=M(),X3=Gs(),IA=Q3(X3.getTableSchema),wA=Bn(),{DeleteResponseObject:Z3}=NA(),{handleHDBError:Wo,hdb_errors:eX}=_e(),{HDB_ERROR_MSGS:Gh,HTTP_STATUS_CODES:jo}=eX,tX="records successfully deleted",rX=J3(mL);SL.exports={delete:rX,deleteRecord:mL,deleteFilesBefore:nX,deleteAuditLogsBefore:sX};async function nX(e){let t=hL(e,"date");if(t)throw Wo(t,t.message,jo.BAD_REQUEST,void 0,void 0,!0);if(cc.transformReq(e),!EL(e.date,EL.ISO_8601).isValid())throw Wo(new Error,Gh.INVALID_DATE,jo.BAD_REQUEST,lc.LOG_LEVELS.ERROR,Gh.INVALID_DATE,!0);let n=cc.checkSchemaTableExist(e.schema,e.table);if(n)throw Wo(new Error,n,jo.NOT_FOUND,lc.LOG_LEVELS.ERROR,n,!0);let s=await wA.deleteRecordsBefore(e);if(await IA(e.schema,e.table),pL.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(nX,"deleteFilesBefore");async function sX(e){let t=hL(e,"timestamp");if(t)throw Wo(t,t.message,jo.BAD_REQUEST,void 0,void 0,!0);if(cc.transformReq(e),isNaN(e.timestamp))throw Wo(new Error,Gh.INVALID_VALUE("Timestamp"),jo.BAD_REQUEST,lc.LOG_LEVELS.ERROR,Gh.INVALID_VALUE("Timestamp"),!0);let r=cc.checkSchemaTableExist(e.schema,e.table);if(r)throw Wo(new Error,r,jo.NOT_FOUND,lc.LOG_LEVELS.ERROR,r,!0);let n=await wA.deleteAuditLogsBefore(e);return await IA(e.schema,e.table),pL.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(sX,"deleteAuditLogsBefore");async function mL(e){e.ids&&(e.hash_values=e.ids);let t=z3(e);if(t)throw Wo(t,t.message,jo.BAD_REQUEST,void 0,void 0,!0);cc.transformReq(e);let r=cc.checkSchemaTableExist(e.schema,e.table);if(r)throw Wo(new Error,r,jo.NOT_FOUND,lc.LOG_LEVELS.ERROR,r,!0);try{await IA(e.schema,e.table);let n=await wA.deleteRecords(e);return cc.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${tX}`),n}catch(n){if(n.message===lc.SEARCH_NOT_FOUND_MESSAGE){let s=new Z3;return s.message=lc.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(mL,"deleteRecord")});var qh=N((cRe,AL)=>{var iX=require("crypto"),TL=9;function oX(e){let t=cX(TL),r=gL(e+t);return t+r}a(oX,"createHash");function aX(e,t){let r=e?.substr(0,TL),n=r+gL(t+r);return e===n}a(aX,"validateHash");function cX(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(cX,"generateSalt");function gL(e){return iX.createHash("md5").update(e).digest("hex")}a(gL,"md5");AL.exports={hash:oX,validate:aX}});var yL=N((uRe,RL)=>{var CA=Tt(),Kr={username:{presence:!0,exclusion:{within:["system"],message:"You cannot create tables within the system schema"}},password:{presence:!0},role:{presence:!0,format:"[\\w\\-\\_]+"},active:{presence:!0,inclusion:{within:[!0,!1],message:"must be a boolean"}}};function lX(e){return Kr.password.presence=!0,Kr.username.presence=!0,Kr.role.presence=!0,Kr.active.presence=!0,CA.validateObject(e,Kr)}a(lX,"addUserValidation");function uX(e){return Kr.password.presence=!1,Kr.username.presence=!0,Kr.role.presence=!1,Kr.active.presence=!1,CA.validateObject(e,Kr)}a(uX,"alterUserValidation");function dX(e){return Kr.password.presence=!1,Kr.username.presence=!0,Kr.role.presence=!1,Kr.active.presence=!1,CA.validateObject(e,Kr)}a(dX,"dropUserValidation");RL.exports={addUserValidation:lX,alterUserValidation:uX,dropUserValidation:dX}});var Ct=N((fRe,OL)=>{"use strict";var{platform:_Re}=require("os"),_X="nats-server.zip",PA="nats-server",fX=process.platform==="win32"?`${PA}.exe`:PA,EX=/^[^\s.,*>]+$/,bL="__request__",hX=a(e=>`${e}.${bL}`,"REQUEST_SUBJECT"),pX={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},mX={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},SX={HUB:"hub.pid",LEAF:"leaf.pid"},TX={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},gX={SUCCESS:"success",ERROR:"error"},AX={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},RX={TXN:"txn",MSGID:"msgid"},Bl={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},yX={[Bl.ERR]:1,[Bl.WRN]:2,[Bl.INF]:3,[Bl.DBG]:4,[Bl.TRC]:5},bX={debug:"-D",trace:"-DVV"};OL.exports={NATS_SERVER_ZIP:_X,NATS_SERVER_NAME:PA,NATS_BINARY_NAME:fX,PID_FILES:SX,NATS_CONFIG_FILES:mX,SERVER_SUFFIX:TX,NATS_TERM_CONSTRAINTS_RX:EX,REQUEST_SUFFIX:bL,UPDATE_REMOTE_RESPONSE_STATUSES:gX,CLUSTER_STATUS_STATUSES:AX,REQUEST_SUBJECT:hX,SUBJECT_PREFIXES:RX,MSG_HEADERS:pX,LOG_LEVELS:Bl,LOG_LEVEL_FLAGS:bX,LOG_LEVEL_HIERARCHY:yX}});var IL=N((hRe,NL)=>{"use strict";var $h=M(),Vh=class{static{a(this,"BaseLicense")}constructor(t=0,r=$h.RAM_ALLOCATION_ENUM.DEFAULT,n=$h.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},DA=class extends Vh{static{a(this,"ExtendedLicense")}constructor(t=0,r=$h.RAM_ALLOCATION_ENUM.DEFAULT,n=$h.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};NL.exports={BaseLicense:Vh,ExtendedLicense:DA}});var dc=N((mRe,UL)=>{"use strict";var xl=require("fs-extra"),CL=qh(),PL=require("crypto"),OX=require("moment"),NX=require("uuid").v4,Yr=j(),MA=require("path"),IX=re(),zo=M(),{totalmem:wL}=require("os"),wX=IL().ExtendedLicense,Hl="invalid license key format",CX="061183",PX="mofi25",DX="aes-256-cbc",LX=16,MX=32,DL=se(),{resolvePath:LL}=wt();DL.initSync();var LA;UL.exports={validateLicense:ML,generateFingerPrint:vX,licenseSearch:BA,getLicense:xX,checkMemoryLimit:kX};function UA(){return MA.join(DL.getHdbBasePath(),zo.LICENSE_KEY_DIR_NAME,zo.LICENSE_FILE_NAME)}a(UA,"getLicenseDirPath");function UX(){let e=UA();return LL(MA.join(e,zo.LICENSE_FILE_NAME))}a(UX,"getLicenseFilePath");function vA(){let e=UA();return LL(MA.join(e,zo.REG_KEY_FILE_NAME))}a(vA,"getFingerPrintFilePath");async function vX(){let e=vA();try{return await xl.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await BX();throw Yr.error(`Error writing fingerprint file to ${e}`),Yr.error(t),new Error("There was an error generating the fingerprint")}}a(vX,"generateFingerPrint");async function BX(){let e=NX(),t=CL.hash(e),r=vA();try{await xl.mkdirp(UA()),await xl.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw Yr.error(`Error writing fingerprint file to ${r}`),Yr.error(n),new Error("There was an error generating the fingerprint")}return t}a(BX,"writeFingerprint");function ML(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:zo.RAM_ALLOCATION_ENUM.DEFAULT,version:zo.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return Yr.error("empty license key passed to validate."),r;let n=vA(),s=!1;try{s=xl.statSync(n)}catch(i){Yr.error(i)}if(s){let i;try{i=xl.readFileSync(n,"utf8")}catch{Yr.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(PX),c=o[1];c=Buffer.concat([Buffer.from(c)],LX);let l=Buffer.concat([Buffer.from(i)],MX),u=PL.createDecipheriv(DX,l,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let d=null;try{d=u.update(o[0],"hex","utf8"),d.trim(),d+=u.final("utf8")}catch{let f=HX(o[0],i);if(f)d=f;else throw r.valid_license=!1,r.valid_machine=!1,console.error(Hl),Yr.error(Hl),new Error(Hl)}let _;if(isNaN(d))try{_=JSON.parse(d),r.version=_.version,r.exp_date=_.exp_date,isNaN(r.exp_date)&&(r.exp_date=new Date(r.exp_date).getTime()),_.ram_allocation&&(r.ram_allocation=_.ram_allocation)}catch{throw console.error(Hl),Yr.error(Hl),new Error(Hl)}else r.exp_date=d;r.exp_date<OX().valueOf()&&(r.valid_date=!1),CL.validate(o[1],`${CX}${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||Yr.error("Invalid licence"),r}a(ML,"validateLicense");function HX(e,t){try{let r=PL.createDecipher("aes192",t),n=r.update(e,"hex","utf8");return n.trim(),n+=r.final("utf8"),n}catch{Yr.warn("Check old license failed")}}a(HX,"checkOldLicense");function BA(){let e=new wX,t=[];try{t=xl.readFileSync(UX(),"utf-8").split(zo.NEW_LINE)}catch(r){r.code==="ENOENT"?Yr.debug("no license file found"):Yr.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if(IX.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=ML(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){Yr.error("There was an error parsing the license string."),Yr.error(s),e.ram_allocation=zo.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return LA=e,e}a(BA,"licenseSearch");async function xX(){return LA||await BA(),LA}a(xX,"getLicense");function kX(){let e=BA().ram_allocation,t=process.constrainedMemory?.()||wL();if(t=Math.round(Math.min(t,wL())/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(kX,"checkMemoryLimit")});var xn=N((RRe,QL)=>{"use strict";var xL="username is required",kL="nothing to update, must supply active, role or password to update",FL="password cannot be an empty string",GL="If role is specified, it cannot be empty.",qL="active must be true or false";QL.exports={addUser:jX,alterUser:zX,dropUser:JX,getSuperUser:tZ,userInfo:XX,listUsers:Yh,listUsersExternal:ZX,setUsersToGlobal:Fl,findAndValidateUser:jL,getClusterUser:rZ,USERNAME_REQUIRED:xL,ALTERUSER_NOTHING_TO_UPDATE:kL,EMPTY_PASSWORD:FL,EMPTY_ROLE:GL,ACTIVE_BOOLEAN:qL};var $L=un(),FX=uc(),kA=qh(),VL=yL(),KL=Vr(),FA=to(),Hn=re(),YL=require("validate.js"),Ke=j(),{promisify:GX}=require("util"),GA=Zi(),vL=M(),BL=Ct(),qX=wt(),TRe=se(),gRe=dc(),$X=Ji(),{table:ARe}=(De(),oe(lt)),{handleHDBError:Ai,hdb_errors:VX}=_e(),{HTTP_STATUS_CODES:Ri,AUTHENTICATION_ERROR_MSGS:HA,HDB_ERROR_MSGS:kl}=VX,{UserEventMsg:qA}=qs(),xA=require("lodash"),{server:$A}=(qr(),oe(Qa)),KX=j();$A.getUser=(e,t)=>jL(e,t,t!=null);var WL={username:!0,active:!0,role:!0,password:!0},HL=new Map,Kh=KL.searchByValue,YX=KL.searchByHash,WX=GX(FX.delete);async function jX(e){let t=YL.cleanAttributes(e,WL),r=VL.addUserValidation(t);if(r)throw Ai(new Error,r.message,Ri.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 Kh(n),s=s&&Array.from(s)}catch(l){throw Ke.error("There was an error searching for a role in add user"),Ke.error(l),l}if(!s||s.length<1)throw Ai(new Error,kl.ROLE_NAME_NOT_FOUND(t.role),Ri.NOT_FOUND,void 0,void 0,!0);if(s.length>1)throw Ai(new Error,kl.DUP_ROLES_FOUND(t.role),Ri.CONFLICT,void 0,void 0,!0);s[0].permission.cluster_user===!0&&(t.hash=GA.encrypt(t.password)),t.password=kA.hash(t.password),t.role=s[0].id;let i={operation:"insert",schema:"system",table:"hdb_user",records:[t]},o;try{o=await $L.insert(i)}catch(l){throw Ke.error("There was an error searching for a user."),Ke.error(l),l}Ke.debug(o);try{await Fl()}catch(l){throw Ke.error("Got an error setting users to global"),Ke.error(l),l}if(o.skipped_hashes.length===1)throw Ai(new Error,kl.USER_ALREADY_EXISTS(t.username),Ri.CONFLICT,void 0,void 0,!0);let c={...t};return c.role=s[0],FA.signalUserChange(new qA(process.pid)),`${c.username} successfully added`}a(jX,"addUser");async function zX(e){let t=YL.cleanAttributes(e,WL);if(Hn.isEmptyOrZeroLength(t.username))throw new Error(xL);if(Hn.isEmptyOrZeroLength(t.password)&&Hn.isEmptyOrZeroLength(t.role)&&Hn.isEmptyOrZeroLength(t.active))throw new Error(kL);if(!Hn.isEmpty(t.password)&&Hn.isEmptyOrZeroLength(t.password.trim()))throw new Error(FL);if(!Hn.isEmpty(t.active)&&!Hn.isBoolean(t.active))throw new Error(qL);let r=QX(t.username);if(!Hn.isEmpty(t.password)&&!Hn.isEmptyOrZeroLength(t.password.trim())&&(r&&(t.hash=GA.encrypt(t.password)),t.password=kA.hash(t.password)),t.role==="")throw new Error(GL);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 Kh(i)||[])}catch(c){throw Ke.error("Got an error searching for a role."),Ke.error(c),c}if(!o||o.length===0){let c=kl.ALTER_USER_ROLE_NOT_FOUND(t.role);throw Ke.error(c),Ai(new Error,c,Ri.NOT_FOUND,void 0,void 0,!0)}if(o.length>1){let c=kl.ALTER_USER_DUP_ROLES(t.role);throw Ke.error(c),Ai(new Error,c,Ri.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 $L.update(n)}catch(i){throw Ke.error("Error during update."),Ke.error(i),i}try{await Fl()}catch(i){throw Ke.error("Got an error setting users to global"),Ke.error(i),i}return FA.signalUserChange(new qA(process.pid)),s}a(zX,"alterUser");function QX(e){let t=!1,r=global.hdb_users.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(QX,"isClusterUser");async function JX(e){try{let t=VL.dropUserValidation(e);if(t)throw new Error(t);let r={table:"hdb_user",schema:"system",hash_values:[e.username]};if(Hn.isEmpty(global.hdb_users.get(e.username)))throw Ai(new Error,kl.USER_NOT_EXIST(e.username),Ri.NOT_FOUND,void 0,void 0,!0);let n;try{n=await WX(r)}catch(s){throw Ke.error("Got an error deleting a user."),Ke.error(s),s}Ke.debug(n);try{await Fl()}catch(s){throw Ke.error("Got an error setting users to global."),Ke.error(s),s}return FA.signalUserChange(new qA(process.pid)),`${e.username} successfully deleted`}catch(t){throw t}}a(JX,"dropUser");async function XX(e){let t={};try{if(!e||!e.hdb_user)return"There was no user info in the body";t=xA.cloneDeep(e.hdb_user);let r={schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]},n;try{n=await YX(r)}catch(s){throw Ke.error("Got an error searching for a role."),Ke.error(s),s}t.role=n[0],delete t.password,delete t.refresh_token,delete t.hash}catch(r){throw Ke.error(r),r}return t}a(XX,"userInfo");async function ZX(){let e;try{e=await Yh()}catch(t){throw Ke.error("Got an error listing users."),Ke.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(ZX,"listUsersExternal");async function Yh(){try{let e={schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]},t;try{t=await Kh(e)}catch(o){throw Ke.error("Got an error searching for roles."),Ke.error(o),o}let r={};for(let o of t)r[o.id]=xA.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 Kh(n)}catch(o){throw Ke.error("Got an error searching for users."),Ke.error(o),o}let i=new Map;for(let o of s)o=xA.cloneDeep(o),o.role=r[o.role],eZ(o.role),i.set(o.username,o);return i}catch(e){throw Ke.error("got an error listing users"),Ke.error(e),Hn.errorizeMessage(e)}return null}a(Yh,"listUsers");function eZ(e){try{if(!e){Ke.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($X)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}catch(t){Ke.error("Got an error trying to set system permissions."),Ke.error(t)}}a(eZ,"appendSystemTablesToRole");async function Fl(){try{let e=await Yh();global.hdb_users=e}catch(e){throw Ke.error(e),e}}a(Fl,"setUsersToGlobal");async function jL(e,t,r=!0){global.hdb_users||await Fl();let n=global.hdb_users.get(e);if(!n){if(!r)return{username:e};throw Ai(new Error,HA.GENERIC_AUTH_FAIL,Ri.UNAUTHORIZED,void 0,void 0,!0)}if(n&&!n.active)throw Ai(new Error,HA.USER_INACTIVE,Ri.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(HL.get(t)===n.password)return s;if(kA.validate(n.password,t))HL.set(t,n.password);else throw Ai(new Error,HA.GENERIC_AUTH_FAIL,Ri.UNAUTHORIZED,void 0,void 0,!0)}return s}a(jL,"findAndValidateUser");async function tZ(){global.hdb_users||await Fl();for(let[,e]of global.hdb_users)if(e.role.role==="super_user")return e}a(tZ,"getSuperUser");async function rZ(){let e=await Yh(),t=qX.getConfigFromFile(vL.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!Hn.isEmpty(r)&&r?.role?.role===vL.ROLE_TYPES_ENUM.CLUSTER_USER)return r.decrypt_hash=GA.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+BL.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+BL.SERVER_SUFFIX.ADMIN,r}a(rZ,"getClusterUser");var zL=[];$A.invalidateUser=function(e){for(let t of zL)try{t(e)}catch(r){KX.error("Error invalidating user",r)}};$A.onInvalidatedUser=function(e){zL.push(e)}});var m_=N((NRe,eM)=>{"use strict";var _c=j(),kn=M(),nZ=VD(),bRe=Gs(),ORe=eo(),sZ=xn(),{validateEvent:JL}=qs(),p_=Bn(),iZ=require("process"),{resetDatabases:oZ}=(De(),oe(lt)),aZ={[kn.ITC_EVENT_TYPES.SCHEMA]:cZ,[kn.ITC_EVENT_TYPES.USER]:ZL};async function cZ(e){let t=JL(e);if(t){_c.error(t);return}_c.trace("ITC schemaHandler received schema event:",e),await nZ(e.message),await lZ(e.message)}a(cZ,"schemaHandler");async function lZ(e){try{p_.resetReadTxn(kn.SYSTEM_SCHEMA_NAME,kn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),p_.resetReadTxn(kn.SYSTEM_SCHEMA_NAME,kn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),p_.resetReadTxn(kn.SYSTEM_SCHEMA_NAME,kn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=oZ();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){_c.error(t)}}a(lZ,"syncSchemaMetadata");var XL=[];async function ZL(e){try{try{p_.resetReadTxn(kn.SYSTEM_SCHEMA_NAME,kn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),p_.resetReadTxn(kn.SYSTEM_SCHEMA_NAME,kn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){_c.warn(r)}let t=JL(e);if(t){_c.error(t);return}_c.trace(`ITC userHandler ${kn.HDB_ITC_CLIENT_PREFIX}${iZ.pid} received user event:`,e),await sZ.setUsersToGlobal();for(let r of XL)r()}catch(t){_c.error(t)}}a(ZL,"userHandler");ZL.addListener=function(e){XL.push(e)};eM.exports=aZ});var qs=N((LRe,rM)=>{"use strict";var wRe=j(),VA=re(),uZ=M(),{ITC_ERRORS:S_}=Pn(),{parentPort:CRe,threadId:dZ,isMainThread:_Z,workerData:PRe}=require("worker_threads"),{onMessageFromWorkers:fZ,broadcast:DRe,broadcastWithAcknowledgement:EZ}=dt();rM.exports={sendItcEvent:hZ,validateEvent:tM,SchemaEventMsg:pZ,UserEventMsg:mZ};var Wh;fZ(async(e,t)=>{Wh=Wh||m_(),tM(e),Wh[e.type]&&await Wh[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function hZ(e){return!_Z&&e.message&&(e.message.originator=dZ),EZ(e)}a(hZ,"sendItcEvent");function tM(e){if(typeof e!="object")return S_.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||VA.isEmpty(e.type))return S_.MISSING_TYPE;if(!e.hasOwnProperty("message")||VA.isEmpty(e.message))return S_.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||VA.isEmpty(e.message.originator))return S_.MISSING_ORIGIN;if(uZ.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return S_.INVALID_EVENT(e.type)}a(tM,"validateEvent");function pZ(e,t,r,n=void 0,s=void 0){this.originator=e,this.operation=t,this.schema=r,this.table=n,this.attribute=s}a(pZ,"SchemaEventMsg");function mZ(e){this.originator=e}a(mZ,"UserEventMsg")});var to=N((vRe,oM)=>{"use strict";var nM=M(),URe=re(),jh=j(),sM=GD(),Gl,{sendItcEvent:iM}=qs();function SZ(e){try{jh.info("signalSchemaChange called with message:",e),Gl=Gl||m_();let t=new sM(nM.ITC_EVENT_TYPES.SCHEMA,e);return Gl.schema(t),iM(t)}catch(t){jh.error(t)}}a(SZ,"signalSchemaChange");function TZ(e){try{jh.trace("signalUserChange called with message:",e),Gl=Gl||m_();let t=new sM(nM.ITC_EVENT_TYPES.USER,e);return Gl.user(t),iM(t)}catch(t){jh.error(t)}}a(TZ,"signalUserChange");oM.exports={signalSchemaChange:SZ,signalUserChange:TZ}});var zh=N((HRe,cM)=>{"use strict";var aM=re(),gZ=M(),AZ=j(),RZ=Mh(),yZ=Lh(),bZ=to(),{SchemaEventMsg:OZ}=qs(),NZ="already exists in";cM.exports=IZ;async function IZ(e,t,r){if(aM.isEmptyOrZeroLength(r))return r;let n=[];aM.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 wZ(e,t.schema,t.name,i)})),s}a(IZ,"lmdbCheckForNewAttributes");async function wZ(e,t,r,n){let s=new yZ(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await CZ(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(NZ))AZ.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(wZ,"createNewAttribute");async function CZ(e){let t;return t=await RZ(e),bZ.signalSchemaChange(new OZ(process.pid,gZ.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(CZ,"createAttribute")});var ql=N((kRe,lM)=>{"use strict";var KA=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}};lM.exports=KA});var dM=N((GRe,uM)=>{"use strict";var PZ=ql(),DZ=M().OPERATIONS_ENUM,YA=class extends PZ{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(DZ.INSERT,r,n,s,i),this.records=t}};uM.exports=YA});var fM=N(($Re,_M)=>{"use strict";var LZ=ql(),MZ=M().OPERATIONS_ENUM,WA=class extends LZ{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(MZ.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};_M.exports=WA});var hM=N((KRe,EM)=>{"use strict";var UZ=ql(),vZ=M().OPERATIONS_ENUM,jA=class extends UZ{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(vZ.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};EM.exports=jA});var mM=N((WRe,pM)=>{"use strict";var BZ=ql(),HZ=M().OPERATIONS_ENUM,zA=class extends BZ{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(HZ.DELETE,n,s,t,i),this.original_records=r}};pM.exports=zA});var T_=N((QRe,AM)=>{"use strict";var zRe=require("path"),SM=ht(),xZ=dM(),kZ=fM(),FZ=hM(),GZ=mM(),$l=Ht(),TM=re(),{CONFIG_PARAMS:qZ}=M(),gM=se();gM.initSync();var Qh=M().OPERATIONS_ENUM,{getTransactionAuditStorePath:$Z}=gt();AM.exports=VZ;async function VZ(e,t){if(gM.get(qZ.LOGGING_AUDITLOG)===!1)return;let r=$Z(e.schema,e.table),n=await SM.openEnvironment(r,e.table,!0),s=KZ(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){SM.initializeDBIs(n,$l.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,$l.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[$l.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[$l.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),TM.isEmpty(s.user_name)||n.dbis[$l.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[$l.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(VZ,"writeTransaction");function KZ(e,t){let r=TM.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===Qh.INSERT)return new xZ(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Qh.UPDATE)return new kZ(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Qh.UPSERT)return new FZ(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Qh.DELETE)return new GZ(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(KZ,"createTransactionObject")});var QA=N((ZRe,RM)=>{"use strict";var YZ=f_(),XRe=Qd(),g_=M(),WZ=Jd(),jZ=sc().insertRecords,zZ=ht(),QZ=j(),JZ=zh(),{getSchemaPath:XZ}=gt(),ZZ=T_();RM.exports=e5;async function e5(e){try{let{schema_table:t,attributes:r}=YZ(e);WZ(e,r,t.hash_attribute),e.schema!==g_.SYSTEM_SCHEMA_NAME&&(r.includes(g_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(g_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(g_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(g_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await JZ(e.hdb_auth_header,t,r),s=XZ(e.schema,e.table),i=await zZ.openEnvironment(s,e.table),o=await jZ(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await ZZ(e,o)}catch(c){QZ.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(e5,"lmdbCreateRecords")});var OM=N((tye,bM)=>{"use strict";var yM=M(),t5=QA(),r5=Qd(),n5=require("fs-extra"),{getSchemaPath:s5}=gt();bM.exports=i5;async function i5(e){let t=[{name:e.schema,createddate:Date.now()}],r=new r5(yM.SYSTEM_SCHEMA_NAME,yM.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await t5(r),await n5.mkdirp(s5(e.schema))}a(i5,"lmdbCreateSchema")});var IM=N((nye,NM)=>{"use strict";var JA=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}};NM.exports=JA});var DM=N((cye,PM)=>{"use strict";var wM=ht(),XA=cn(),ZA=Pn().LMDB_ERRORS_ENUM,o5=Ht(),CM=j(),iye=re(),a5=require("lmdb"),c5=IM(),l5=M(),{OVERFLOW_MARKER:oye,MAX_SEARCH_KEY_LENGTH:aye}=o5,u5=l5.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function d5(e,t,r,n){if(XA.validateEnv(e),t===void 0)throw new Error(ZA.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(ZA.IDS_REQUIRED):new Error(ZA.IDS_MUST_BE_ITERABLE);try{let s=wM.listDBIs(e);wM.initializeDBIs(e,t,s);let i=new c5,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[u5]>n){i.skipped.push(o);continue}let T=e.dbis[t].ifVersion(o,a5.IF_EXISTS,()=>{e.dbis[t].remove(o);for(let m=0;m<s.length;m++){let g=s[m];if(!h.hasOwnProperty(g)||g===t)continue;let S=e.dbis[g],y=h[g];if(y!=null)try{let I=XA.getIndexedValues(y);if(I)for(let U=0,H=I.length;U<H;U++)S.remove(I[U],o)}catch{CM.warn(`cannot delete from attribute: ${g}, ${y}:${o}`)}}});c.push(T),l.push(o),i.original_records.push(h)}catch(h){CM.warn(h),i.skipped.push(o)}let u=[],d=await Promise.all(c);for(let E=0,f=d.length;E<f;E++)d[E]===!0?i.deleted.push(l[E]):(i.skipped.push(l[E]),u.push(E));let _=0;for(let E=0;E<u.length;E++){let f=u[E];i.original_records.splice(f-_,1),_++}return i.txn_time=XA.getNextMonotonicTime(),i}catch(s){throw s}}a(d5,"deleteRecords");PM.exports={deleteRecords:d5}});var A_=N((uye,MM)=>{"use strict";var Vl=re(),_5=DM(),f5=ht(),{getSchemaPath:E5}=gt(),h5=T_(),p5=j();MM.exports=m5;async function m5(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(Vl.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(Vl.isEmptyOrZeroLength(e.hash_values)&&!Vl.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];Vl.isEmpty(l)||e.hash_values.push(l)}}if(Vl.isEmptyOrZeroLength(e.hash_values))return LM([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(Vl.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=E5(e.schema,e.table),i=await f5.openEnvironment(s,e.table),o=await _5.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await h5(e,o)}catch(c){p5.error(`unable to write transaction due to ${c.message}`)}return LM(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(m5,"lmdbDeleteRecords");function LM(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(LM,"createDeleteResponse")});var tR=N((fye,UM)=>{"use strict";var S5=M(),_ye=cn();function eR(e,t){let r=Object.create(null);if(t.length===1&&S5.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(eR,"parseRow");function T5(e,t,r,n){let s=eR(r,e);n.push(s)}a(T5,"searchAll");function g5(e,t,r,n){let s=eR(r,e);n[t]=s}a(g5,"searchAllToMap");function A5(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(A5,"iterateDBI");function fc(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(fc,"pushResults");function R5(e,t,r,n,s,i){t.toString().endsWith(e)&&fc(t,r,n,s,i)}a(R5,"endsWith");function y5(e,t,r,n,s,i){t.toString().includes(e)&&fc(t,r,n,s,i)}a(y5,"contains");function b5(e,t,r,n,s,i){t>e&&fc(t,r,n,s,i)}a(b5,"greaterThanCompare");function O5(e,t,r,n,s,i){t>=e&&fc(t,r,n,s,i)}a(O5,"greaterThanEqualCompare");function N5(e,t,r,n,s,i){t<e&&fc(t,r,n,s,i)}a(N5,"lessThanCompare");function I5(e,t,r,n,s,i){t<=e&&fc(t,r,n,s,i)}a(I5,"lessThanEqualCompare");UM.exports={parseRow:eR,searchAll:T5,searchAllToMap:g5,iterateDBI:A5,endsWith:R5,contains:y5,greaterThanCompare:b5,greaterThanEqualCompare:O5,lessThanCompare:N5,lessThanEqualCompare:I5,pushResults:fc}});var Kl=N((Sye,GM)=>{"use strict";var Qo=ht(),hye=j(),Fn=cn(),Jh=Ht(),zt=Pn().LMDB_ERRORS_ENUM,pye=re(),w5=M(),Xh=tR(),{parseRow:C5}=Xh,mye=require("lmdb"),{OVERFLOW_MARKER:vM,MAX_SEARCH_KEY_LENGTH:P5}=Jh;function BM(e,t,r,n=!1,s=void 0,i=void 0){return Ec(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(BM,"iterateFullIndex");function R_(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,u=!1){return Ec(e,t,r,(d,_,E,f)=>{let S={transaction:d,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!l:!u,exclusiveStart:i===!0?u:l};return f===r?(S.values=!1,_.getRange(S).map(y=>({value:y}))):_.getRange(S)})}a(R_,"iterateRangeBetween");function Ec(e,t,r,n){let s=e.database||e,i=Qo.openDBI(s,r);i[Jh.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&Qo.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(Ec,"setupTransaction");function HM(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(vM)){if(!s)if(r)s=Qo.openDBI(e,r);else{let l=Qo.listDBIs(e);for(let u=0,d=l.length;u<d&&(s=Qo.openDBI(e,l[u]),!s[Jh.DBI_DEFINITION_NAME].is_hash_attribute);u++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(HM,"getOverflowCheck");function D5(e,t,r,n=!1,s=void 0,i=void 0){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);return Ec(e,t,t,(o,c,l)=>(Zh(r),r=y_(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(u=>C5(u.value,r))))}a(D5,"searchAll");function L5(e,t,r,n=!1,s=void 0,i=void 0){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);Zh(r),r=y_(e.database||e,r);let o=new Map;for(let{key:c,value:l}of BM(e,t,t,n,s,i))o.set(c,Xh.parseRow(l,r));return o}a(L5,"searchAllToMap");function M5(e,t,r=!1,n=void 0,s=void 0){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=BM(e,void 0,t,r,n,s),c=o.transaction,l=HM(c.database,c,void 0,t);for(let{key:u,value:d}of o){let _=l(u,d);i[_]===void 0&&(i[_]=[]),i[_].push(d)}return i}a(M5,"iterateDBI");function U5(e,t){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);return Qo.statDBI(e,t).entryCount}a(U5,"countAll");function v5(e,t,r,n,s=!1,i=void 0,o=void 0){return Jo(e,r,n),Ec(e,t,r,(c,l,u,d)=>(n=Fn.convertKeyValueToWrite(n),d===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(_=>({key:n,value:_}))))}a(v5,"equals");function B5(e,t,r){return Jo(e,t,r),Qo.openDBI(e,t).getValuesCount(r)}a(B5,"count");function H5(e,t,r,n,s=!1,i=void 0,o=void 0){return Jo(e,r,n),Ec(e,null,r,(c,l)=>{n=Fn.convertKeyValueToWrite(n);let u=!0;typeof n=="number"&&(u=!1);let d;if(s===!0){let _;for(let E of l.getKeys({transaction:c,start:n}))if(!E.startsWith(n)){_=E;break}return _!==void 0&&(Number.isInteger(o)?o++:i++),d=l.getRange({transaction:c,start:_,end:void 0,reverse:s,limit:i,offset:o}).map(E=>{let{key:f}=E;if(f!==_){if(f.toString().startsWith(n))return E;if(u===!0)return d.DONE}}),d.filter(E=>E)}else return d=l.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(_=>{if(_.key.toString().startsWith(n))return _;if(u===!0)return d.DONE}),u?d:d.filter(_=>_)})}a(H5,"startsWith");function x5(e,t,r,n,s=!1,i=void 0,o=void 0){return xM(e,t,r,n,s,i,o,!0)}a(x5,"endsWith");function xM(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return Jo(e,r,n),Ec(e,null,r,(l,u,d,_)=>{let E=HM(d,l,_,r);return o=Number.isInteger(o)?o:0,u.getKeys({transaction:l,end:s?!1:void 0,reverse:s}).flatMap(f=>{let h=f.toString();return h.endsWith(vM)?u.getValues(f,{transaction:l}).map(T=>{let m=E(f,T);if(c?m.endsWith(n):m.includes(n))return{key:m,value:T}}).filter(T=>T):(c?h.endsWith(n):h.includes(n))?u[Jh.DBI_DEFINITION_NAME].is_hash_attribute?{key:f,value:f}:u.getValues(f,{transaction:l}).map(T=>({key:f,value:T})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a(xM,"contains");function k5(e,t,r,n,s=!1,i=void 0,o=void 0){Jo(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),R_(e,t,r,n,l,s,i,o,!0,!1)}a(k5,"greaterThan");function F5(e,t,r,n,s=!1,i=void 0,o=void 0){Jo(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),R_(e,t,r,n,l,s,i,o,!1,!1)}a(F5,"greaterThanEqual");function G5(e,t,r,n,s=!1,i=void 0,o=void 0){Jo(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),R_(e,t,r,l,n,s,i,o,!1,!0)}a(G5,"lessThan");function q5(e,t,r,n,s=!1,i=void 0,o=void 0){Jo(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),R_(e,t,r,l,n,s,i,o,!1,!1)}a(q5,"lessThanEqual");function $5(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(Fn.validateEnv(e),r===void 0)throw new Error(zt.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(zt.START_VALUE_REQUIRED);if(s===void 0)throw new Error(zt.END_VALUE_REQUIRED);if(n=Fn.convertKeyValueToWrite(n),s=Fn.convertKeyValueToWrite(s),n>s)throw new Error(zt.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return R_(e,t,r,n,s,i,o,c)}a($5,"between");function V5(e,t,r,n){Fn.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);if(Zh(r),r=y_(s,r),n===void 0)throw new Error(zt.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=Xh.parseRow(c,r)),o}a(V5,"searchByHash");function K5(e,t,r){Fn.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(zt.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(K5,"checkHashExists");function Y5(e,t,r,n,s=[]){return FM(e,t,r,n,s),kM(e,t,r,n,s).map(i=>i[1])}a(Y5,"batchSearchByHash");function W5(e,t,r,n,s=[]){FM(e,t,r,n,s);let i=new Map;for(let[o,c]of kM(e,t,r,n,s))i.set(o,c);return i}a(W5,"batchSearchByHashToMap");function kM(e,t,r,n,s=[]){return Ec(e,t,t,(i,o,c)=>{r=y_(c,r);let l=r.length<3;return n.map(u=>{let d=c.dbis[t].get(u,{transaction:i,lazy:l});if(d)return[u,Xh.parseRow(d,r)];s.push(u)}).filter(u=>u)})}a(kM,"batchHashSearch");function FM(e,t,r,n,s){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);if(Zh(r),n==null)throw new Error(zt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(zt.IDS_MUST_BE_ITERABLE)}a(FM,"initializeBatchSearchByHash");function Zh(e){if(!Array.isArray(e))throw e===void 0?new Error(zt.FETCH_ATTRIBUTES_REQUIRED):new Error(zt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(Zh,"validateFetchAttributes");function Jo(e,t,r){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(zt.SEARCH_VALUE_REQUIRED);if(r?.length>P5)throw new Error(zt.SEARCH_VALUE_TOO_LARGE)}a(Jo,"validateComparisonFunctions");function y_(e,t){return t.length===1&&w5.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=Qo.listDBIs(e)),t}a(y_,"setGetWholeRowAttributes");GM.exports={searchAll:D5,searchAllToMap:L5,count:B5,countAll:U5,equals:v5,startsWith:H5,endsWith:x5,contains:xM,searchByHash:V5,setGetWholeRowAttributes:y_,batchSearchByHash:Y5,batchSearchByHashToMap:W5,checkHashExists:K5,iterateDBI:M5,greaterThan:k5,greaterThanEqual:F5,lessThan:G5,lessThanEqual:q5,between:$5}});var Yl=N((gye,YM)=>{var qM=require("lodash"),$M=Tt(),xe=require("joi"),j5=re(),{hdb_schema_table:b_,checkValidTable:VM,hdb_table:KM,hdb_database:ep}=Ti(),{handleHDBError:z5,hdb_errors:Q5}=_e(),{getDatabases:J5}=(De(),oe(lt)),{HTTP_STATUS_CODES:X5}=Q5,Z5=xe.object({database:ep,schema:ep,table:KM,search_attribute:b_,search_value:xe.any().required(),get_attributes:xe.array().min(1).items(xe.alternatives(b_,xe.object())).optional(),desc:xe.bool(),limit:xe.number().integer().min(1),offset:xe.number().integer().min(0)}),e6=xe.object({database:ep,schema:ep,table:KM,operator:xe.string().valid("and","or").default("and").lowercase(),offset:xe.number().integer().min(0),limit:xe.number().integer().min(1),get_attributes:xe.array().min(1).items(xe.alternatives(b_,xe.object())).optional(),sort:xe.object({attribute:xe.alternatives(b_,xe.array().min(1)),descending:xe.bool().optional()}).optional(),conditions:xe.array().min(1).items(xe.alternatives(xe.object({operator:xe.string().valid("and","or").default("and").lowercase(),conditions:xe.array()}),xe.object({search_attribute:xe.alternatives(b_,xe.array().min(1)),search_type:xe.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:xe.when("search_type",{switch:[{is:"equals",then:xe.any()},{is:"between",then:xe.array().items(xe.alternatives([xe.string(),xe.number()])).length(2)}],otherwise:xe.alternatives(xe.string(),xe.number())}).required()}))).required()});YM.exports=function(e,t){let r=null;switch(t){case"value":r=$M.validateBySchema(e,Z5);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(VM("database",e.schema)),i(VM("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=$M.validateBySchema(e,e6);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=j5.checkGlobalSchemaTable(e.schema,e.table);if(s)return z5(new Error,s,X5.NOT_FOUND);let o=J5()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let l=a(d=>{for(let _=0,E=d.conditions.length;_<E;_++){let f=d.conditions[_];f.conditions?l(f):c.push(f.search_attribute)}},"addConditions");t==="conditions"&&l(e);let u=qM.filter(c,d=>d!=="*"&&!d.startsWith?.("$")&&d.attribute!=="*"&&!Array.isArray(d)&&!d.name&&!qM.some(o,_=>_===d||_.attribute===d||_.attribute===d.attribute));if(u&&u.length>0){let d=u.join(", ");return d=d.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${d}'`)}}return r}});var rR=N((Rye,WM)=>{"use strict";var t6=ht(),r6=Yl(),{getSchemaPath:n6}=gt();WM.exports=s6;function s6(e){let t=r6(e,"hashes");if(t)throw t;let r=n6(e.schema,e.table);return t6.openEnvironment(r,e.table)}a(s6,"initialize")});var nR=N((bye,jM)=>{"use strict";var i6=Kl(),o6=rR();jM.exports=a6;async function a6(e){let t=await o6(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return i6.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(a6,"lmdbGetDataByHash")});var Wl=N((Nye,zM)=>{"use strict";var sR=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};zM.exports=sR});var JM=N((Cye,QM)=>{"use strict";var wye=Wl(),c6=Kl(),l6=rR();QM.exports=u6;async function u6(e){let t=await l6(e),r=global.hdb_schema[e.schema][e.table];return c6.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(u6,"lmdbSearchByHash")});var $s=N((Dye,XM)=>{"use strict";var iR=class{static{a(this,"SearchObject")}constructor(t,r,n,s,i,o,c,l=!1,u=void 0,d=void 0){this.schema=t,this.table=r,this.search_attribute=n,this.search_value=s,this.hash_attribute=i,this.get_attributes=o,this.end_value=c,this.reverse=l,this.limit=u,this.offset=d}};XM.exports=iR});var tp=N((Mye,sU)=>{"use strict";var Wr=Kl(),d6=ht(),_6=re(),ke=Ht(),hc=M(),f6=Ji(),ZM=Pn().LMDB_ERRORS_ENUM,{getSchemaPath:E6}=gt(),ro=hc.SEARCH_WILDCARDS;async function h6(e,t,r){let n;e.schema===hc.SYSTEM_SCHEMA_NAME?n=f6[e.table]:n=global.hdb_schema[e.schema][e.table];let s=nU(e,n.hash_attribute,r,t);return tU(e,s,n.hash_attribute,r)}a(h6,"prepSearch");async function tU(e,t,r,n){let s=E6(e.schema,e.table),i=await d6.openEnvironment(s,e.table),o=rU(i,e,t,r),c=o.transaction||i;if([ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,ke.SEARCH_TYPES.SEARCH_ALL,ke.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(p6(e,r)===!1){let d=e.search_attribute;if(d===r)return n?eU(o,()=>!0):o.map(E=>({[r]:E.key}));let _=a(E=>({[r]:E.value,[d]:E.key}),"toObject");return n?eU(o,_):o.map(_)}let u=e.search_attribute===r?o.map(d=>d.key):o.map(d=>d.value);return n===!0?Wr.batchSearchByHashToMap(c,r,e.get_attributes,u):Wr.batchSearchByHash(c,r,e.get_attributes,u)}a(tU,"executeSearch");function rU(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 ke.SEARCH_TYPES.EQUALS:s=Wr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.CONTAINS:s=Wr.contains(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.ENDS_WITH:case ke.SEARCH_TYPES._ENDS_WITH:s=Wr.endsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.STARTS_WITH:case ke.SEARCH_TYPES._STARTS_WITH:s=Wr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return Wr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return Wr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case ke.SEARCH_TYPES.SEARCH_ALL:return Wr.searchAll(e,n,t.get_attributes,o,c,l);case ke.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return Wr.searchAllToMap(e,n,t.get_attributes,o,c,l);case ke.SEARCH_TYPES.BETWEEN:s=Wr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,l);break;case ke.SEARCH_TYPES.GREATER_THAN:case ke.SEARCH_TYPES._GREATER_THAN:s=Wr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.GREATER_THAN_EQUAL:case ke.SEARCH_TYPES._GREATER_THAN_EQUAL:s=Wr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.LESS_THAN:case ke.SEARCH_TYPES._LESS_THAN:s=Wr.lessThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.LESS_THAN_EQUAL:case ke.SEARCH_TYPES._LESS_THAN_EQUAL:s=Wr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;default:return Object.create(null)}return s}a(rU,"searchByType");function eU(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(eU,"createMapFromIterable");function p6(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(p6,"checkToFetchMore");function nU(e,t,r,n){if(_6.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),ro.indexOf(s)>-1)return r===!0?ke.SEARCH_TYPES.SEARCH_ALL_TO_MAP:ke.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(ro[0])<0&&s.indexOf(ro[1])<0)return c===!0?r===!0?ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:ke.SEARCH_TYPES.EQUALS;if(ro.indexOf(i)>=0&&ro.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),ke.SEARCH_TYPES.CONTAINS;if(ro.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),ke.SEARCH_TYPES.ENDS_WITH;if(ro.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),ke.SEARCH_TYPES.STARTS_WITH;if(s.includes(ro[0])||s.includes(ro[1]))return ke.SEARCH_TYPES.EQUALS;throw new Error(ZM.UNKNOWN_SEARCH_TYPE)}else switch(n){case hc.VALUE_SEARCH_COMPARATORS.BETWEEN:return ke.SEARCH_TYPES.BETWEEN;case hc.VALUE_SEARCH_COMPARATORS.GREATER:return ke.SEARCH_TYPES.GREATER_THAN;case hc.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return ke.SEARCH_TYPES.GREATER_THAN_EQUAL;case hc.VALUE_SEARCH_COMPARATORS.LESS:return ke.SEARCH_TYPES.LESS_THAN;case hc.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return ke.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(ZM.UNKNOWN_SEARCH_TYPE)}}a(nU,"createSearchTypeFromSearchObject");sU.exports={executeSearch:tU,createSearchTypeFromSearchObject:nU,prepSearch:h6,searchByType:rU}});var oU=N((Bye,iU)=>{"use strict";var vye=$s(),m6=Yl(),S6=re(),T6=M(),g6=tp();iU.exports=A6;function A6(e,t){if(!S6.isEmpty(t)&&T6.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=m6(e,"value");if(n)throw n;return g6.prepSearch(e,t,!0)}a(A6,"lmdbGetDataByValue")});var O_=N((kye,aU)=>{"use strict";var xye=$s(),R6=Yl(),y6=re(),b6=M(),O6=tp();aU.exports=N6;async function N6(e,t){if(!y6.isEmpty(t)&&b6.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=R6(e,"value");if(n)throw n;return O6.prepSearch(e,t,!1)}a(N6,"lmdbSearchByValue")});var lU=N((qye,cU)=>{"use strict";var Gye=Ht(),oR=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}},aR=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},cR=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};cU.exports={SearchByConditionsObject:oR,SearchCondition:aR,SortAttribute:cR}});var EU=N((Yye,fU)=>{"use strict";var Vye=lU().SearchByConditionsObject,I6=$s(),w6=Yl(),lR=Kl(),rp=Ht(),{Resource:Kye}=(Vs(),oe(uR)),_U=tp(),C6=tR(),P6=require("lodash"),{getSchemaPath:D6}=gt(),uU=ht(),{handleHDBError:L6,hdb_errors:M6}=_e(),{HTTP_STATUS_CODES:U6}=M6,v6=1e8;fU.exports=B6;async function B6(e){let t=w6(e,"conditions");if(t)throw L6(t,t.message,U6.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=D6(e.schema,e.table),n=await uU.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let u of e.conditions)uU.openDBI(n,u.search_attribute);let i=P6.sortBy(e.conditions,u=>{if(u.estimated_count===void 0){let d=u.search_type;d===rp.SEARCH_TYPES.EQUALS?u.estimated_count=lR.count(n,u.search_attribute,u.search_value):d===rp.SEARCH_TYPES.CONTAINS||d===rp.SEARCH_TYPES.ENDS_WITH?u.estimated_count=1/0:u.estimated_count=v6}return u.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await dU(o,e,i[0],s.hash_attribute),l;if(!e.operator||e.operator.toLowerCase()==="and"){let u=n.dbis[s.hash_attribute],d=i.slice(1).map(_U.filterByType),_=d.length,E=lR.setGetWholeRowAttributes(n,e.get_attributes);l=c.map(f=>u.get(f,{transaction:o,lazy:!0})),_>0&&(l=l.filter(f=>{for(let h=0;h<_;h++)if(!d[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=>C6.parseRow(f,E))}else{for(let _=1;_<i.length;_++){let E=i[_],f=await dU(o,e,E,s.hash_attribute);c=c.concat(f)}let u=new Set,d=e.offset||0;c=c.filter(_=>u.has(_)?!1:(u.add(_),!0)).slice(d,e.limit&&e.limit+d),l=lR.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(B6,"lmdbSearchByConditions");async function dU(e,t,r,n){let s=new I6(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===rp.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,_U.searchByType(e,s,i,n).map(o=>o.value)}a(dU,"executeConditionSearch")});var N_=N((jye,hU)=>{"use strict";var H6=M().OPERATIONS_ENUM,dR=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=H6.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};hU.exports=dR});var _R=N((Qye,yU)=>{"use strict";var TU=$s(),gU=N_(),AU=O_(),RU=A_(),dn=M(),pU=re(),mU=ht(),{getTransactionAuditStorePath:x6,getSchemaPath:k6}=gt(),SU=j();yU.exports=F6;async function F6(e){try{if(pU.isEmpty(global.hdb_schema[e.schema])||pU.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await G6(e),await q6(e);let t=k6(e.schema,e.table);try{await mU.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")SU.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=x6(e.schema,e.table);await mU.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")SU.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(F6,"lmdbDropTable");async function G6(e){let t=new TU(dn.SYSTEM_SCHEMA_NAME,dn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,dn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[dn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await AU(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 gU(dn.SYSTEM_SCHEMA_NAME,dn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await RU(s)}a(G6,"deleteAttributesFromSystem");async function q6(e){let t=new TU(dn.SYSTEM_SCHEMA_NAME,dn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,dn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[dn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,dn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,dn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await AU(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 gU(dn.SYSTEM_SCHEMA_NAME,dn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await RU(s)}catch(i){throw i}}a(q6,"dropTableFromSystem")});var OU=N((Xye,bU)=>{"use strict";var $6=require("fs-extra"),V6=$s(),K6=Wl(),Y6=N_(),W6=_R(),j6=A_(),z6=nR(),Q6=O_(),no=M(),{getSchemaPath:J6}=gt(),{handleHDBError:X6,hdb_errors:Z6}=_e(),{HDB_ERROR_MSGS:e8,HTTP_STATUS_CODES:t8}=Z6;bU.exports=r8;async function r8(e){let t;try{t=await n8(e.schema);let r=new V6(no.SYSTEM_SCHEMA_NAME,no.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,no.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[no.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await Q6(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await W6(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new Y6(no.SYSTEM_SCHEMA_NAME,no.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await j6(s);let i=J6(t);await $6.remove(i)}catch(r){throw r}}a(r8,"lmdbDropSchema");async function n8(e){let t=new K6(no.SYSTEM_SCHEMA_NAME,no.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[no.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await z6(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw X6(new Error,e8.SCHEMA_NOT_FOUND(e),t8.NOT_FOUND,void 0,void 0,!0);return n}a(n8,"validateDropSchema")});var I_=N((ebe,NU)=>{"use strict";var fR=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};NU.exports=fR});var hR=N((nbe,IU)=>{"use strict";var s8=require("fs-extra"),np=ht(),{getTransactionAuditStorePath:i8}=gt(),ER=Ht(),rbe=I_();IU.exports=o8;async function o8(e){let t;try{let r=i8(e.schema,e.table);await s8.mkdirp(r),t=await np.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{np.createDBI(t,ER.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),np.createDBI(t,ER.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),np.createDBI(t,ER.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(o8,"createTransactionsAuditEnvironment")});var PU=N((obe,CU)=>{"use strict";var pR=M(),wU=ht(),a8=sc(),{getSystemSchemaPath:c8,getSchemaPath:l8}=gt(),ibe=Ji(),u8=Mh(),mR=Lh(),d8=j(),_8=hR();CU.exports=f8;async function f8(e,t){let r=l8(t.schema,t.table),n=new mR(t.schema,t.table,pR.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new mR(t.schema,t.table,pR.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new mR(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await wU.createEnvironment(r,t.table),e!==void 0){let o=await wU.openEnvironment(c8(),pR.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await a8.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_table_attributes,[e]),n.skip_table_check=!0,s.skip_table_check=!0,i.skip_table_check=!0,await SR(n),await SR(s),await SR(i)}await _8(t)}catch(o){throw o}}a(f8,"lmdbCreateTable");async function SR(e){try{await u8(e)}catch(t){d8.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(SR,"createAttribute")});var LU=N((cbe,DU)=>{"use strict";var E8=f_(),h8=Jd(),p8=zh(),w_=M(),m8=sc().updateRecords,S8=ht(),{getSchemaPath:T8}=gt(),g8=T_(),A8=j();DU.exports=R8;async function R8(e){try{let{schema_table:t,attributes:r}=E8(e);h8(e,r,t.hash_attribute),e.schema!==w_.SYSTEM_SCHEMA_NAME&&(r.includes(w_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(w_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(w_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(w_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await p8(e.hdb_auth_header,t,r),s=T8(e.schema,e.table),i=await S8.openEnvironment(s,e.table),o=await m8(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await g8(e,o)}catch(c){A8.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(R8,"lmdbUpdateRecords")});var UU=N((ube,MU)=>{"use strict";var y8=M().OPERATIONS_ENUM,TR=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=y8.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};MU.exports=TR});var BU=N((fbe,vU)=>{"use strict";var _be=UU(),b8=f_(),O8=Jd(),N8=zh(),C_=M(),I8=sc().upsertRecords,w8=ht(),{getSchemaPath:C8}=gt(),P8=T_(),D8=j(),{handleHDBError:L8,hdb_errors:M8}=_e();vU.exports=U8;async function U8(e){let t;try{t=b8(e)}catch(l){throw L8(l,l.message,M8.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;O8(e,n,r.hash_attribute),e.schema!==C_.SYSTEM_SCHEMA_NAME&&(n.includes(C_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(C_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(C_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(C_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await N8(e.hdb_auth_header,r,n),i=C8(e.schema,e.table),o=await w8.openEnvironment(i,e.table),c=await I8(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await P8(e,c)}catch(l){D8.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(U8,"lmdbUpsertRecords")});var xU=N((hbe,HU)=>{"use strict";var gR=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};HU.exports=gR});var FU=N((mbe,kU)=>{"use strict";var AR=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}};kU.exports=AR});var $U=N((gbe,qU)=>{"use strict";var RR=ht(),{getTransactionAuditStorePath:v8}=gt(),Tbe=xU(),P_=Ht(),B8=re(),GU=FU(),H8=require("util").promisify,x8=H8(setTimeout),k8=1e4,F8=100;qU.exports=G8;async function G8(e){let t=v8(e.schema,e.table),r=await RR.openEnvironment(t,e.table,!0),n=RR.listDBIs(r);RR.initializeDBIs(r,P_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new GU;do s=await q8(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 x8(F8);while(s.transactions_deleted>0);return i}a(G8,"deleteAuditLogsBefore");async function q8(e,t){let r=new GU;try{let n=e.dbis[P_.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[P_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];B8.isEmpty(c)||(s=e.dbis[P_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[P_.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>k8)break}return await s,r}catch(n){throw n}}a(q8,"deleteTransactions")});var KU=N((Rbe,VU)=>{"use strict";var yR=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};VU.exports=yR});var WU=N((Obe,YU)=>{"use strict";var $8=$s(),V8=N_(),bbe=KU(),yi=M(),K8=re(),bR=ht(),Y8=Ji(),W8=O_(),j8=A_(),{getSchemaPath:z8}=gt();YU.exports=Q8;async function Q8(e,t=!0){let r;e.schema===yi.SYSTEM_SCHEMA_NAME?r=Y8[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await X8(e),s=z8(e.schema,e.table),i=await bR.openEnvironment(s,e.table);return t===!0&&await J8(e,i,r.hash_attribute),bR.dropDBI(i,e.attribute),n}a(Q8,"lmdbDropAttribute");async function J8(e,t,r){let n=bR.openDBI(t,r),s,i=e.attribute;for(let{key:o,value:c,version:l}of n.getRange({start:!1,versions:!0})){let u={};for(let d in c)d!==i&&(u[d]=c[d]);s=t.dbis[r].put(o,u,l)}await s}a(J8,"removeAttributeFromAllObjects");async function X8(e){let t=new $8(yi.SYSTEM_SCHEMA_NAME,yi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,yi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[yi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,yi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await W8(t)).filter(o=>o[yi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(K8.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[yi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new V8(yi.SYSTEM_SCHEMA_NAME,yi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return j8(i)}a(X8,"dropAttributeFromSystem")});var ZU=N((wbe,XU)=>{"use strict";var OR=ht(),jl=Ht(),Ibe=cn(),NR=M(),jU=re(),{getTransactionAuditStorePath:Z8}=gt(),e9=Kl(),sp=ql(),t9=j();XU.exports=r9;async function r9(e){let t=Z8(e.schema,e.table),r=await OR.openEnvironment(t,e.table,!0),n=OR.listDBIs(r);OR.initializeDBIs(r,jl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case NR.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return zU(r,e.search_values);case NR.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,s9(r,e.search_values,s);case NR.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return n9(r,e.search_values);default:return zU(r)}}a(r9,"readAuditLog");function zU(e,t=[0,Date.now()]){jU.isEmpty(t[0])&&(t[0]=0),jU.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[jl.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 sp,s))}a(zU,"searchTransactionsByTimestamp");function n9(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[jl.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,JU(e,i))}return Object.fromEntries(r)}a(n9,"searchTransactionsByUsername");function s9(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let u=t[c],d=e9.equals(e,jl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,jl.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,u);for(let{value:_}of d){let E=Number(_);n.has(E)?n.get(E).push(u.toString()):n.set(E,[u.toString()])}}let s=Array.from(n.keys()),i=JU(e,s),o=new Map;for(let c=0;c<i.length;c++){let l=i[c],u=l.timestamp,d=n.get(u);QU(l,"records",r,d,o),QU(l,"original_records",r,d,o)}return Object.fromEntries(o)}a(s9,"searchTransactionsByHashValues");function QU(e,t,r,n,s){let i=e.timestamp;if(e[t])for(let o=0;o<e[t].length;o++){let c=e[t][o],l=c[r].toString();if(n.indexOf(l)>=0)if(s.has(l)){let u=s.get(l),d=u[u.length-1];if(d.timestamp===i)d[t]=[c];else{let _=new sp(e.operation,e.user_name,i,void 0);_[t]=[c],u.push(_)}}else{let u=new sp(e.operation,e.user_name,i,void 0);u[t]=[c],s.set(l,[u])}}}a(QU,"loopRecords");function JU(e,t){let r=[];try{let n=e.dbis[jl.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 sp,i);r.push(o)}}catch(i){t9.warn(i)}return r}catch(n){throw n}}a(JU,"batchSearchTransactions")});var tv=N((Lbe,ev)=>{"use strict";var{getSchemaPath:Pbe}=gt(),Dbe=ht(),{database:i9}=(De(),oe(lt));ev.exports={writeTransaction:o9};async function o9(e,t,r){return i9({database:e,table:t}).transaction(r)}a(o9,"writeTransaction")});var iv=N((Ube,sv)=>{"use strict";var{getSchemaPath:rv}=gt(),nv=ht();sv.exports={flush:a9,resetReadTxn:c9};async function a9(e,t){return(await nv.openEnvironment(rv(e,t),t.toString())).flushed}a(a9,"flush");async function c9(e,t){try{(await nv.openEnvironment(rv(e,t),t.toString())).resetReadTxn()}catch{}}a(c9,"resetReadTxn")});var lv=N((Bbe,cv)=>{"use strict";var{Readable:l9}=require("stream"),{getDatabases:u9}=(De(),oe(lt)),{readSync:d9,openSync:_9,createReadStream:ov}=require("fs"),{open:f9}=require("lmdb"),av=o_(),E9=a_(),{AUDIT_STORE_OPTIONS:h9}=(zi(),oe(uv)),{INTERNAL_DBIS_NAME:p9,AUDIT_STORE_NAME:m9}=Ht();cv.exports=T9;var IR=32768,S9=100;async function T9(e){let t=e.database||e.schema||"data",r=u9()[t],n=new Date().toISOString(),s=e.tables||e.table&&[e.table];if(s){let u=r[s[0]];if(!u)throw new Error(`Can not find table ${s[0]}`);let d=u.dbisDB,_=f9({noSync:!0,maxDbs:E9.MAX_DBS}),E,f=_.openDB(p9,new av(!1)),h=d.useReadTransaction(),T=0,m=a(async function(S,y){y.encoding="binary",y.encoder=void 0;let I=_.openDB(S,y),U=d.openDB(S,y);for(let{key:H,version:X,value:Y}of U.getRange({start:null,transaction:h,versions:U.useVersions}))E=I.put(H,Y,X),T++%S9===0&&(await new Promise(V=>setTimeout(V,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:S,value:y}of d.getRange({transaction:h,start:!1}))if(s.some(I=>S.startsWith?.(I+"/"))){f.put(S,y);let[,I]=S.split("/"),U=!I,H=new av(!U,U);await m(S,H)}e.include_audit&&await m(m9,{...h9}),await E;let g=ov(_.path);return g.headers=l(),g.on("close",()=>{h.done(),_.close()}),g}let o=r[Object.keys(r)[0]].primaryStore,c=_9(o.path);return o.transaction(()=>{let u=Buffer.alloc(IR);d9(c,u,0,IR),o.resetReadTxn();let d=o.useReadTransaction();d.renew();let _=ov(null,{fd:c,start:IR}),E=new l9.from(async function*(){yield u;for await(let f of _)d.openTimer&&(d.openTimer=0),yield f;d.done()}());return E.headers=l(),E});function l(){let u=new Map;return u.set("content-type","application/octet-stream"),u.set("content-disposition",`attachment; filename="${t}"`),u.set("date",n),u}}a(T9,"getBackup")});var fv=N((xbe,_v)=>{"use strict";var g9=j(),{handleHDBError:A9}=_e(),R9=jP(),y9=Mh(),b9=QA(),O9=OM(),N9=A_(),I9=nR(),w9=JM(),C9=oU(),P9=O_(),D9=EU(),L9=OU(),M9=PU(),U9=LU(),v9=BU(),B9=$U(),H9=_R(),x9=WU(),k9=ZU(),F9=tv(),dv=iv(),G9=lv(),wR=class extends R9{static{a(this,"LMDBBridge")}async searchByConditions(t){return D9(t)}async getDataByHash(t){return await I9(t)}async searchByHash(t){return await w9(t)}async getDataByValue(t,r){return await C9(t,r)}async searchByValue(t){return await P9(t)}async createSchema(t){return await O9(t)}async dropSchema(t){return await L9(t)}async createTable(t,r){return await M9(t,r)}async dropTable(t){return await H9(t)}async createAttribute(t){return await y9(t)}async createRecords(t){return await b9(t)}async updateRecords(t){return await U9(t)}async upsertRecords(t){try{return await v9(t)}catch(r){throw A9(r,null,null,g9.ERR,r)}}async deleteRecords(t){return await N9(t)}async dropAttribute(t){return await x9(t)}async deleteAuditLogsBefore(t){return await B9(t)}async readAuditLog(t){return await k9(t)}writeTransaction(t,r,n){return F9.writeTransaction(t,r,n)}flush(t,r){return dv.flush(t,r)}resetReadTxn(t,r){return dv.resetReadTxn(t,r)}getBackup(t){return G9(t)}};_v.exports=wR});function Av(e){PR=e}function K9(){V9=setInterval(function(){for(let e of CR)if(e.stale){let t=e[Fe]?.url;mv.error(`Transaction was open too long and has been aborted, from table: ${e.lmdbDb?.name+(t?" path: "+t:"")}`),e.abort()}else e.stale=!0},$9).unref()}var DR,pv,mv,Sv,Tv,gv,Ev,CR,q9,D_,hv,PR,pc,ip,$9,V9,op=Ie(()=>{DR=L(cn()),pv=L(_e()),mv=L(j());Vs();Sv=L(se()),Tv=L(M()),gv=L(re()),Ev=100,CR=new Set,q9=(0,gv.convertToMS)(Sv.get(Tv.CONFIG_PARAMS.STORAGE_MAXTRANSACTIONQUEUETIME))||45e3;a(Av,"replicationConfirmation");pc=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),CR.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(CR.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(D_&&!this.overloadChecked&&performance.now()-hv>q9)throw new pv.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,DR.getNextMonotonicTime)()),t.timestamp||(t.timestamp=r);let n=t.retries||0;if(this.validated<this.writes.length)try{let _=this.validated;this.validated=this.writes.length;for(let f=_;f<this.validated;f++)this.writes[f]?.validate?.(this.timestamp);let E;for(let f=_;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 T=_;T<this.validated;T++){let m=this.writes[T];if(!m)continue;let g=m[f===0?"before":"beforeIntermediate"];if(g){let S=g();h?h.push?h.push(S):h=[h,S]:h=S}}h&&await(h.push?Promise.all(h):h)}}catch(f){throw this.abort(),f}return this.commit(t)})()}catch(_){throw this.abort(),_}n||this.doneReadTxn(),this.open=t?.letItLinger?2:0;let s,i=[],o=0;this.writes=this.writes.filter(_=>_);let c=a(_=>{_.commit(r,_.entry,n)},"doWrite"),l=a(()=>{let _=this.writes[o++];if(_)if(_.key){n>0&&(_.entry=_.store.getEntry(_.key));let E=_.store.ifVersion(_.key,_.entry?.version??null,l);s=s||E}else l();else for(let E of this.writes)c(E)},"nextCondition"),u=this.lmdbDb;if(this.writes.length>0&&(u?.retryRisk&&(u.retryRisk*=.99),this.writes.length+(u?.retryRisk||0)<Ev>>n?l():s=this.writes[0].store.transaction(()=>{for(let _ of this.writes)_.entry=_.store.getEntry(_.key),c(_);return!0})),s)return D_||(D_=s,hv=performance.now(),D_.then(()=>{D_=null})),s.then(_=>{if(_){if(this.next&&i.push(this.next.commit(t)),t?.flush&&i.push(this.writes[0].store.flushed),this.replicatedConfirmation){let E=this.writes[0].store.rootStore.databaseName,f=this.writes[this.writes.length-1];PR&&f&&i.push(PR(E,f.store.getEntry(f.key).localTime,this.replicatedConfirmation))}return this.writes=[],this.next=null,Promise.all(i).then(()=>({txnTime:r}))}else return u&&(u.retryRisk=(u.retryRisk||0)+Ev/2),t?t.retries=n+1:t={retries:1},this.commit(t)});let d={txnTime:r};if(this.next){let _=this.next?.commit(t);if(_?.then)return _?.then(E=>({txnTime:r,next:E}));d.next=_}return d}abort(){for(;this.readTxnsUsed>0;)this.doneReadTxn();this.open=0,this.writes=[]}},ip=class extends pc{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,DR.getNextMonotonicTime)())}getReadTxn(){}},$9=3e4;a(K9,"startMonitoringTxns");K9()});function Pt(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 pc;e.timestamp&&(n.timestamp=e.timestamp),e.replicatedConfirmation&&(n.replicatedConfirmation=e.replicatedConfirmation),n[Fe]=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 Rv,mc=Ie(()=>{Rv=L(fi());Vs();op();a(Pt,"transaction");(0,Rv._assignPackageExport)("transaction",Pt);Pt.commit=function(e){let t=(e[Fe]||e)?.transaction;if(!t)throw new Error("No active transaction is available to commit");return t.commit()};Pt.abort=function(e){let t=(e[Fe]||e)?.transaction;if(!t)throw new Error("No active transaction is available to abort");return t.abort()}});var Pv={};je(Pv,{ResourceBridge:()=>UR});function vR({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 bv(e,t){let r=bi(e),n=vR(e,r);if(!r)throw new Ks.ClientError(`Table ${e.table} not found`);let s;n&&r.attributes.length-n.length>2&&n.length<5&&(s=!0);let i={user:e.hdb_user,onlyIfCached:e.onlyIfCached,noCacheStore:e.noCacheStore,noCache:e.noCache,replicateFrom:e.replicateFrom},o;Pt(i,()=>new Promise(u=>o=u));let c=e.ids||e.hash_values,l=0;return{[Symbol.asyncIterator](){return{async next(){if(l<c.length){let u=c[l++],d;try{d=await r.get({id:u,lazy:s,select:n},i),d=d&&cp(d)}catch(_){d={message:_.toString()}}return t?{value:{key:u,value:d}}:{value:d}}else return o(),{done:!0}},return(u){return o(),{value:u,done:!0}},throw(u){return o(),{done:!0}}}}}}function bi(e){let t=e.database||e.schema||W9,r=ut()[t];if(!r)throw(0,Ks.handleHDBError)(new Error,Y9.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function Ov(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*Nv(e,t,r,n){let s,i=0;for await(let o of e.getHistory(t,r)){let c=o.operation??o.type;c==="put"&&(c="upsert");let{id:l,version:u,value:d}=o;if(s?.timestamp===u)s.hash_values.push(l),s.records.push(d);else{if(s&&(yield s,i++,n&&n<=i)){s=void 0;break}s={operation:c,user_name:o.user,timestamp:u,hash_values:[l],records:[d]}}}s&&(yield s)}var Iv,ap,Ks,wv,Ys,LR,MR,Cv,Y9,W9,j9,z9,yv,UR,Dv=Ie(()=>{"use strict";Iv=L(fv()),ap=L(Yl()),Ks=L(_e());De();wv=L(f_()),Ys=L(M()),LR=L(to()),MR=L(qs()),Cv=L(re());mc();lp();({HDB_ERROR_MSGS:Y9}=Ks.hdb_errors),W9="data",j9=1e4,z9=10,UR=class extends Iv.default{static{a(this,"ResourceBridge")}constructor(t){super(t),yv=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,ap.default)(t,"conditions");if(r)throw(0,Ks.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=bi(t);if(!n)throw new Ks.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:vR(t,n),sort:t.sort,allowFullScan:!0},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async createTable(t,r){let n=r.attributes,s=!!n,i=r.primary_key||r.hash_attribute;if(n)for(let o of n)o.is_primary_key?(o.isPrimaryKey=!0,delete o.is_primary_key):o.name===i&&i&&(o.isPrimaryKey=!0);else{if(!i)throw new Ks.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}]}Et({database:r.database??r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration,audit:r.audit})}async createAttribute(t){return await bi(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=bi(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=a((o,c,l)=>(c={...c},delete c[n],r.primaryStore.ifVersion(o,l,()=>r.primaryStore.put(o,c,l)).then(u=>{if(!u){let{value:d,version:_}=r.primaryStore.getEntry(o);return i(o,d,_)}})),"deleteRecord");for(let{key:o,value:c,version:l}of r.primaryStore.getRange({start:!0,versions:!0}))s=i(o,c,l),await new Promise(u=>setImmediate(u));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){bi(t).dropTable()}createSchema(t){return zl({database:t.schema,table:null}),LR.signalSchemaChange(new MR.SchemaEventMsg(process.pid,Ys.OPERATIONS_ENUM.CREATE_SCHEMA,t.schema))}async dropSchema(t){await BR(t.schema),LR.signalSchemaChange(new MR.SchemaEventMsg(process.pid,Ys.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,yv.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,wv.default)(t),s,i=ut()[t.schema][t.table],o={user:t.hdb_user,expiresAt:t.expiresAt,originatingOperation:t.operation};return t.replicateTo&&(o.replicateTo=t.replicateTo),t.replicatedConfirmation&&(o.replicatedConfirmation=t.replicatedConfirmation),Pt(o,async c=>{if(!i.schemaDefined){s=[];for(let d of n)i.attributes.find(E=>E.name==d)||s.push(d);s.length>0&&await i.addAttributes(s.map(d=>({name:d,indexed:!0})))}let l=[],u=[];for(let d of t.records){let _=d[i.primaryKey],E=_!=null&&await i.get(_,o);if(t.requires_existing&&!E||t.requires_no_existing&&E){u.push(d[i.primaryKey]);continue}E&&(E=cp(E));for(let f in d)if(Object.prototype.hasOwnProperty.call(d,f)){let h=d[f];if(typeof h=="function")try{let T=h([[E]]);Array.isArray(T)&&(h=T[0].func_val,d[f]=h)}catch(T){throw T.message+="Trying to set key "+f+" on object"+JSON.stringify(d),T}}if(E)for(let f in E)Object.prototype.hasOwnProperty.call(d,f)||(d[f]=E[f]);await(_==null?i.create(d,o):i.put(d,o)),l.push(d[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:l,new_attributes:s,skipped_hashes:u}})}async deleteRecords(t){let r=ut()[t.schema][t.table],n={user:t.hdb_user};return t.replicateTo&&(n.replicateTo=t.replicateTo),t.replicatedConfirmation&&(n.replicatedConfirmation=t.replicatedConfirmation),Pt(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 Ov(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=ut()[t.schema][t.table];if(!r.createdTimeProperty)throw new Ks.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:Ys.VALUE_SEARCH_COMPARATORS.LESS}]}),s=!1,i=[],o=[],c=0,l=[],u=a(async()=>{let d=await this.deleteRecords({schema:t.schema,table:t.table,hash_values:l});i.push(...d.deleted_hashes),o.push(...d.skipped_hashes),await(0,Cv.async_set_timeout)(z9),l=[],s=!0},"chunkDelete");for await(let d of n)l.push(d[r.primaryKey]),c++,c%j9===0&&await u();return l.length>0&&await u(),s?Ov(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,ap.default)(t,"hashes");if(r)throw r;return bv(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of bv(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&Ys.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,ap.default)(t,"value");if(n)throw n;let s=bi(t);if(!s)throw new Ks.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===Ys.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:vR(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async getDataByValue(t,r){let n=new Map,s=bi(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){bi({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return bi(t).deleteHistory(t.timestamp,t.cleanup_deleted_records)}async readAuditLog(t){let r=bi(t),n={};switch(t.search_type){case Ys.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.operation??o.type;return c==="put"&&(c="upsert"),{operation:c,timestamp:o.version,user_name:o.user,hash_values:[i],records:[o.value]}});return n;case Ys.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:let s=t.search_values;for await(let i of Nv(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return Nv(r,t.search_values?.[0],t.search_values?.[1],t.limit)}}};a(vR,"getSelect");a(bv,"getRecords");a(bi,"getTable");a(Ov,"createDeleteResponse");a(Nv,"groupRecordsInHistory")});var Bn=N((Zbe,Lv)=>{"use strict";var{ResourceBridge:Q9}=(Dv(),oe(Pv)),J9=se();J9.initSync();var up;function X9(){return up||(up=new Q9,up)}a(X9,"getBridge");Lv.exports=X9()});var Bv=N((tOe,vv)=>{"use strict";var Mv=require("lodash"),L_=require("mathjs"),Z9=require("jsonata"),Uv=re();vv.exports={distinct_array:a(e=>Array.isArray(e)&&e.length>1?Mv.uniqWith(e,Mv.isEqual):e,"distinct_array"),searchJSON:e7,mad:M_.bind(null,L_.mad),mean:M_.bind(null,L_.mean),mode:M_.bind(null,L_.mode),prod:M_.bind(null,L_.prod),median:M_.bind(null,L_.median)};function M_(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(M_,"aggregateFunction");function e7(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(Uv.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),Uv.isEmpty(this.__ala__.res[r])){let n=Z9(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(e7,"searchJSON")});var xv=N((nOe,Hv)=>{"use strict";var nr=require("moment"),HR="YYYY-MM-DDTHH:mm:ss.SSSZZ";nr.suppressDeprecationWarnings=!0;Hv.exports={current_date:a(()=>nr().utc().format("YYYY-MM-DD"),"current_date"),current_time:a(()=>nr().utc().format("HH:mm:ss.SSS"),"current_time"),extract:a((e,t)=>{switch(t.toLowerCase()){case"year":return nr(e).utc().format("YYYY");case"month":return nr(e).utc().format("MM");case"day":return nr(e).utc().format("DD");case"hour":return nr(e).utc().format("HH");case"minute":return nr(e).utc().format("mm");case"second":return nr(e).utc().format("ss");case"millisecond":return nr(e).utc().format("SSS");default:break}},"extract"),date:a(e=>nr(e).utc().format(HR),"date"),date_format:a((e,t)=>nr(e).utc().format(t),"date_format"),date_add:a((e,t,r)=>nr(e).utc().add(t,r).valueOf(),"date_add"),date_sub:a((e,t,r)=>nr(e).utc().subtract(t,r).valueOf(),"date_sub"),date_diff:a((e,t,r)=>{let n=nr(e).utc(),s=nr(t).utc();return r?n.diff(s,r,!0):n.diff(s)},"date_diff"),now:a(()=>nr().utc().valueOf(),"now"),get_server_time:a(()=>nr().format(HR),"get_server_time"),offset_utc:a((e,t)=>nr(e).utc().utcOffset(t).format(HR),"offset_utc")}});var qv=N((iOe,Gv)=>{"use strict";var t7=require("@turf/area"),r7=require("@turf/length"),n7=require("@turf/circle"),s7=require("@turf/difference"),i7=require("@turf/distance"),o7=require("@turf/boolean-contains"),a7=require("@turf/boolean-equal"),c7=require("@turf/boolean-disjoint"),l7=require("@turf/helpers"),kv=M(),$e=re(),so=j();Gv.exports={geoArea:u7,geoLength:d7,geoCircle:_7,geoDifference:f7,geoDistance:Fv,geoNear:E7,geoContains:h7,geoEqual:p7,geoCrosses:m7,geoConvert:S7};function u7(e){if($e.isEmpty(e))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e));try{return t7.default(e)}catch(t){return so.trace(t,e),NaN}}a(u7,"geoArea");function d7(e,t){if($e.isEmpty(e))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e));try{return r7.default(e,{units:t||"kilometers"})}catch(r){return so.trace(r,e),NaN}}a(d7,"geoLength");function _7(e,t,r){if($e.isEmpty(e))return NaN;if($e.isEmpty(t))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e));try{return n7.default(e,t,{units:r||"kilometers"})}catch(n){return so.trace(n,e,t),NaN}}a(_7,"geoCircle");function f7(e,t){if($e.isEmpty(e))return NaN;if($e.isEmpty(t))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t));try{return s7(e,t)}catch(r){return so.trace(r,e,t),NaN}}a(f7,"geoDifference");function Fv(e,t,r){if($e.isEmpty(e))return NaN;if($e.isEmpty(t))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t));try{return i7.default(e,t,{units:r||"kilometers"})}catch(n){return so.trace(n,e,t),NaN}}a(Fv,"geoDistance");function E7(e,t,r,n){if($e.isEmpty(e)||$e.isEmpty(t))return!1;if($e.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t)),isNaN(r))throw new Error("distance must be a number");try{return Fv(e,t,n)<=r}catch(s){return so.trace(s,e,t),!1}}a(E7,"geoNear");function h7(e,t){if($e.isEmpty(e)||$e.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t));try{return o7.default(e,t)}catch(r){return so.trace(r,e,t),!1}}a(h7,"geoContains");function p7(e,t){if($e.isEmpty(e)||$e.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t));try{return a7.default(e,t)}catch(r){return so.trace(r,e,t),!1}}a(p7,"geoEqual");function m7(e,t){if($e.isEmpty(e)||$e.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t));try{return!c7.default(e,t)}catch(r){return so.trace(r,e,t),!1}}a(m7,"geoCrosses");function S7(e,t,r){if($e.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if($e.isEmpty(t))throw new Error("geo_type is required");if($e.isEmpty(kv.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(kv.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=$e.autoCastJSON(e)),l7[t](e,r)}a(S7,"geoConvert")});var dp=N((aOe,$v)=>{var Sc=Bv(),Gn=xv(),Oi=qv();$v.exports=e=>{e.aggr.mad=e.aggr.MAD=Sc.mad,e.aggr.mean=e.aggr.MEAN=Sc.mean,e.aggr.mode=e.aggr.MODE=Sc.mode,e.aggr.prod=e.aggr.PROD=Sc.prod,e.aggr.median=e.aggr.MEDIAN=Sc.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=Sc.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=Sc.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=Gn.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Gn.current_time,e.fn.extract=e.fn.EXTRACT=Gn.extract,e.fn.date=e.fn.DATE=Gn.date,e.fn.date_format=e.fn.DATE_FORMAT=Gn.date_format,e.fn.date_add=e.fn.DATE_ADD=Gn.date_add,e.fn.date_sub=e.fn.DATE_SUB=Gn.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Gn.date_diff,e.fn.now=e.fn.NOW=Gn.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Gn.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Gn.get_server_time,e.fn.getdate=e.fn.GETDATE=Gn.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Gn.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=Oi.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=Oi.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=Oi.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=Oi.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=Oi.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=Oi.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=Oi.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=Oi.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=Oi.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=Oi.geoNear}});var Wv=N((cOe,Yv)=>{"use strict";var U_=require("lodash"),_n=require("alasql");_n.options.cache=!1;var T7=dp(),Vv=require("clone"),_p=require("recursive-iterator"),Ue=j(),et=re(),Ql=Bn(),g7=M(),{hdb_errors:A7}=_e(),{getDatabases:Kv}=(De(),oe(lt)),R7="IS NULL",Ws="There was a problem performing this search. Please check the logs and try again.";T7(_n);var xR=class{static{a(this,"SQLSearch")}constructor(t,r){if(et.isEmpty(t))throw Ue.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(),et.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!et.isEmptyOrZeroLength(n))return Ue.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw Ue.error("Error thrown from checkEmptySQL in SQLSearch class method search."),Ue.error(n),new Error(Ws)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw Ue.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),Ue.error(n),new Error(Ws)}if(Object.keys(this.data).length===0)return Ue.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw Ue.error("Error thrown from processJoins in SQLSearch class method search."),Ue.error(n),new Error(Ws)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw Ue.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),Ue.error(n),new Error(Ws)}try{return t=await this._finalSQL(),t}catch(n){throw Ue.error("Error thrown from finalSQL in SQLSearch class method search."),Ue.error(n),new Error(Ws)}}_getColumns(){let t=new _p(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(Vv(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=U_.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=Kv()[r.databaseid][r.tableid].primaryKey,this.data[n].__merged_data={},this.data[n].__merged_attributes=[],this.data[n].__merged_attr_map={}})}_conditionsToFetchAttributeValues(){if(et.isEmpty(this.statement.where)){Ue.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new _p(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!et.isEmpty(r)&&r.right)if(et.isNotEmptyAndHasValue(r.right.value)){let n=et.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new _n.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=et.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new _n.yy.LogicValue({value:i}):n instanceof _n.yy.StringValue&&et.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new _n.yy.NumValue({value:i}))});if(t){Ue.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new _p(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(!et.isEmpty(g7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(et.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(et.isEmptyOrZeroLength(r.left.columnid)||et.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(et.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"=":!et.isEmpty(r.right.value)||!et.isEmpty(r.left.value)?n.add(et.isEmpty(r.right.value)?r.left.value:r.right.value):c=!0;break;case"IN":let l=Array.isArray(r.right)?r.right:r.left;for(let u=0;u<l.length;u++)if(l[u].value)n.add(l[u].value);else{c=!0;break}break;default:c=!0;break}this.exact_search_values[o].ignore=c,c?this.exact_search_values[o].values=new Set:this.exact_search_values[o].values=new Set([...this.exact_search_values[o].values,...n])}}}_setAliasesForColumns(){if(et.isEmptyOrZeroLength(this.all_table_attributes)&&et.isEmptyOrZeroLength(this.statement.from)&&et.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&&U_.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(et.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);et.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(et.isEmptyOrZeroLength(this.all_table_attributes)&&!et.isEmptyOrZeroLength(this.columns.columns))return t;if(et.isEmptyOrZeroLength(this.all_table_attributes)&&et.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await _n.promise(r)}catch(r){throw Ue.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),Ue.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(Vv(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(et.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(R7)>-1&&this.tables.forEach(s=>{let i={columnid:Kv()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=U_.uniqBy(this.fetch_attributes,s=>[s.table.databaseid,s.table.as?s.table.as:s.table.tableid,s.attribute].join()),r)return await this._simpleSQLQuery();let n=this.fetch_attributes.reduce((s,i)=>{let o=`${i.table.databaseid}_${i.table.as?i.table.as:i.table.tableid}`,c=this.data[o].__hash_name;return s[o]||(s[o]=[],s[o].push(null),this._addColumnToMergedAttributes(o,c)),i.attribute!==c&&(s[o].push(null),this._addColumnToMergedAttributes(o,i.attribute)),s},{});for(let s of this.fetch_attributes){let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`,o=this.data[i].__hash_name,c={schema:s.table.databaseid,table:s.table.tableid,get_attributes:[s.attribute]},l=!1,u=[s.table.databaseid,s.table.tableid,s.attribute].join("/");if(s.attribute===o&&(l=!0),!et.isEmpty(this.exact_search_values[u])&&!this.exact_search_values[u].ignore&&!et.isEmptyOrZeroLength(this.exact_search_values[u].values))if(l)try{c.hash_values=Array.from(this.exact_search_values[u].values);let d=await Ql.getDataByHash(c);for(let _ of c.hash_values)d.get(_)&&!this.data[i].__merged_data[_]&&(this.data[i].__merged_data[_]=[...n[i]],this._setMergedHashAttribute(i,_))}catch(d){throw Ue.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),Ue.error(d),new Error(Ws)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[u].values).map(async d=>{let _={...c};_.search_value=d;let E=await Ql.getDataByValue(_);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(d){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),Ue.error(d),new Error(Ws)}else if(!et.isEmpty(this.comparator_search_values[u])&&!this.comparator_search_values[u].ignore&&!et.isEmptyOrZeroLength(this.comparator_search_values[u].comparators))try{let d=this.comparator_search_values[u].comparators;for(let _=0,E=d.length;_<E;_++){let f=d[_];c.search_attribute=f.attribute,c.search_value=f.search_value;let h=await Ql.getDataByValue(c,f.operation);if(l)for(let[T]of h)this.data[i].__merged_data[T]||(this.data[i].__merged_data[T]=[...n[i]],this._setMergedHashAttribute(i,T));else for(let[T,m]of h)this.data[i].__merged_data[T]?this._updateMergedAttribute(i,T,s.attribute,m[s.attribute]):(this.data[i].__merged_data[T]=[...n[i]],this._updateMergedAttribute(i,T,s.attribute,m[s.attribute]),this._setMergedHashAttribute(i,T))}}catch(d){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),Ue.error(d),new Error(Ws)}else try{c.search_attribute=s.attribute,c.search_value="*";let d=await Ql.getDataByValue(c);if(l)for(let[_]of d)this.data[i].__merged_data[_]||(this.data[i].__merged_data[_]=[...n[i]],this._setMergedHashAttribute(i,_));else for(let[_,E]of d)this.data[i].__merged_data[_]?this._updateMergedAttribute(i,_,s.attribute,E[s.attribute]):(this.data[i].__merged_data[_]=[...n[i]],this._updateMergedAttribute(i,_,s.attribute,E[s.attribute]),this._setMergedHashAttribute(i,_))}catch(d){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),Ue.error(d),new Error(Ws)}}}_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 _n.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 _n.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new _n.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 _n.yy.FuncValue:new _n.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,T=f.as?f.as_orig:f.tableid_orig;o.push({key:`'${T}.${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 "${T}.${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 u="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(u="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(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 d="",_="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(d=this.statement.limit?"LIMIT "+this.statement.limit:"",_=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 _n.promise(h,t),t=null}catch(f){throw Ue.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),Ue.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 T=E[f];o.forEach(m=>{T[m.key]!==null&&T[m.key]!==void 0&&m.keys.add(T[m.key])})}o.forEach(f=>{let h=Object.keys(this.data[`${f.schema}_${f.table}`].__merged_data),T=U_.difference(h,[...f.keys].map(m=>m.toString()));for(let m=0,g=T.length;m<g;m++){let S=T[m];delete this.data[`${f.schema}_${f.table}`].__merged_data[S]}})}return{existing_attributes:c,joined_length:E?E.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new _p(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=U_.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 Ue.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),Ue.error(i),new Error(Ws)}}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 d in i)o.push(i[d][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 Ql.getDataByHash(c),u=s.columns.length;for(let d=0,_=o.length;d<_;d++){let E=o[d],f=l.get(E);for(let h=0;h<u;h++){let T=s.columns[h],m=f[T]===void 0?null:f[T];this.data[n].__merged_data[E].push(m)}}}}catch(r){throw Ue.error("Error thrown from getDataByHash function in SQLSearch class method getData."),Ue.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();Ue.trace(`Final SQL: ${s}`),n=await _n.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),Ue.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw Ue.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),Ue.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 Ue.error(A7.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),Ue.trace(r.stack),t}}_buildSQL(t=!0){let r=this.statement.toString();return r=r.replace(/NOT\(NULL\)/g,"NOT NULL"),this.statement.columns.forEach(n=>{if(n.funcid&&n.as){let s=n.toString().replace(" AS "+n.as,"");r=r.replace(n.toString(),s)}}),t===!0?this._convertColumnsToIndexes(r,this.tables):r}_convertColumnsToIndexes(t,r){let n=t,s={};r.forEach(i=>{i.databaseid_orig?s[`${i.databaseid_orig}_${i.as?i.as_orig:i.tableid_orig}`]=i.as?i.as:i.tableid:s[`${i.databaseid}_${i.as?i.as:i.tableid}`]=`\`${i.as?i.as:i.tableid}\``});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=s[i],u=new RegExp(`${l}.\`${o}\``,"g"),d=`${l}.[${c}]`;n=n.replace(u,d)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=new RegExp(`\`${o}\``,"g"),u=`[${c}]`;n=n.replace(l,u)});return n}async _simpleSQLQuery(){let t=this.statement.columns.reduce((n,s)=>(s.as_orig&&s.as_orig!=s.columnid_orig?n[s.columnid_orig]=s.as_orig:n[s.columnid_orig]||(n[s.columnid_orig]=s.columnid_orig),n),{}),r=this.fetch_attributes.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]||(n[i]={}),n[i][t[s.attribute]]=null,n},{});for(let n of this.fetch_attributes){let s=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`,i={schema:n.table.databaseid,table:n.table.tableid,get_attributes:[n.attribute]};try{i.search_attribute=n.attribute,i.search_value="*";let o=await Ql.getDataByValue(i);for(let[c,l]of o)this.data[s].__merged_data[c]||(l[n.attribute]===void 0&&(l[n.attribute]=null),this.data[s].__merged_data[c]={...r[s]}),this.data[s].__merged_data[c][t[n.attribute]]=l[n.attribute]??null}catch(o){throw Ue.error("There was an error when processing this SQL operation. Check your logs"),Ue.error(o),new Error(Ws)}}return Object.values(Object.values(this.data)[0].__merged_data)}};Yv.exports=xR});var Vr=N((uOe,jv)=>{"use strict";var y7=YP();jv.exports={searchByConditions:O7,searchByHash:N7,searchByValue:I7,search:w7};var kR=Bn(),{transformReq:FR}=re(),b7=Wv();async function O7(e){return FR(e),kR.searchByConditions(e)}a(O7,"searchByConditions");async function N7(e){FR(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of kR.searchByHash(e))r&&t.push(r);return t}a(N7,"searchByHash");async function I7(e){FR(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of kR.searchByValue(e))t.push(r);return t}a(I7,"searchByValue");function w7(e,t){try{let r=new y7(e);r.validate(),new b7(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(w7,"search")});var fp=N((_Oe,zv)=>{"use strict";var C7=Bn();zv.exports={writeTransaction:P7};function P7(e,t,r){return C7.writeTransaction(e,t,r)}a(P7,"writeTransaction")});var Zv=N((hOe,Xv)=>{"use strict";var D7=Vr(),L7=Gs(),Qv=j(),M7=un(),EOe=fp(),U7=require("clone"),qR=require("alasql"),v7=dp(),Jv=require("util"),B7=Jv.promisify(L7.getTableSchema),H7=Jv.promisify(D7.search),x7=M(),GR=re();v7(qR);Xv.exports={update:F7};var k7="There was a problem performing this update. Please check the logs and try again.";async function F7({statement:e,hdb_user:t}){let r=await B7(e.table.databaseid,e.table.tableid),n=G7(e.columns);GR.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=U7(s),c=GR.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,u=qR.parse(l).statements[0],d=await H7(u),_=q7(n,d);return $7(o,_,t)}a(F7,"update");function G7(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=qR.compile(`SELECT ${r.expression.toString()} AS [${x7.FUNC_VAL}] FROM ?`)}),t}catch(t){throw Qv.error(t),new Error(k7)}}a(G7,"createUpdateRecord");function q7(e,t){return GR.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(q7,"buildUpdateRecords");async function $7(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await M7.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){Qv.error(`Error delete new_attributes from update response: ${i}`)}return s}a($7,"updateRecords")});var t0=N((TOe,e0)=>{var V7=require("alasql"),K7=Vr(),Y7=j(),W7=Bn(),VR=require("util"),$R=re(),j7=M(),z7=Gs(),mOe=fp(),SOe=un(),Q7="record",J7="successfully deleted",X7=VR.callbackify(ree),Z7=VR.promisify(K7.search),eee=VR.promisify(z7.getTableSchema);e0.exports={convertDelete:X7};function tee(e){return`${e.deleted_hashes.length} ${Q7}${e.deleted_hashes.length===1?"":"s"} ${J7}`}a(tee,"generateReturnMessage");async function ree({statement:e,hdb_user:t}){let r=await eee(e.table.databaseid,e.table.tableid);$R.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=$R.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=V7.parse(o).statements[0],l={operation:j7.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await Z7(c);let u=await W7.deleteRecords(l);return $R.isEmptyOrZeroLength(u.message)&&(u.message=tee(u)),delete u.txn_time,u}catch(u){throw Y7.error(u),u.hdb_code?u.message:u}}a(ree,"convertDelete")});var o0=N((AOe,i0)=>{"use strict";var nee=eo(),{hdb_errors:r0}=_e(),{getDatabases:n0}=(De(),oe(lt));i0.exports={checkSchemaExists:s0,checkSchemaTableExists:see,schema_describe:nee};async function s0(e){if(!n0()[e])return r0.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(s0,"checkSchemaExists");async function see(e,t){let r=await s0(e);if(r)return r;if(!n0()[e][t])return r0.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(see,"checkSchemaTableExists")});var Jl=N((yOe,iee)=>{iee.exports={name:"harperdb",version:"4.4.26",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","cover:test":"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && nyc --no-clean --reporter=lcovonly npm run test:replication && 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 --no-clean --reporter=lcovonly npm run test:security && 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:replication && 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 && npm run test:security && 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","test:security":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/security/**/*.js' --config '../unitTests/.mocharc.json'","test:replication":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/replication/**/*.js' --config '../unitTests/.mocharc.json'","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",format:"prettier .","format:fix":"npm run format -- --write",lint:"eslint .","lint:fix":"npm run lint -- --fix"},dependencies:{"@aws-sdk/client-s3":"3.717.0","@aws-sdk/lib-storage":"3.717.0","@endo/static-module-record":"^1.0.4","@fastify/autoload":"5.10.0","@fastify/compress":"~6.5.0","@fastify/cors":"~9.0.1","@fastify/static":"~7.0.4","@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.6.0",chalk:"4.1.2",chokidar:"^4.0.3","cli-progress":"3.12.0",clone:"2.1.2","fast-glob":"3.3.2",fastify:"~4.29.0","fastify-plugin":"~4.5.1","fs-extra":"11.2.0",graphql:"^16.10.0","gunzip-maybe":"1.4.2","human-readable-ids":"1.0.4",inquirer:"8.2.6","is-number":"7.0.0",joi:"17.12.2","json-bigint-fixes":"1.1.0",json2csv:"5.0.7",jsonata:"1.8.7",jsonwebtoken:"9.0.2",lmdb:"3.2.6",lodash:"4.17.21",mathjs:"11.12.0",minimist:"1.2.8",moment:"2.30.1","mqtt-packet":"~9.0.0",msgpackr:"1.11.2",nats:"2.19.0",needle:"3.3.1","node-forge":"^1.3.1","node-stream-zip":"1.15.0","node-unix-socket":"0.2.5","normalize-path":"^3.0.0",ora:"5.4.1","ordered-binary":"1.5.3",papaparse:"5.4.1",passport:"0.6.0","passport-http":"0.3.0","passport-local":"1.0.0",pino:"8.16.0",pm2:"5.4.1",prompt:"1.3.0","properties-reader":"2.3.0","recursive-iterator":"3.3.0",semver:"7.5.4",send:"^1.1.0","serve-static":"2.1.0",ses:"1.1.0","stream-chain":"2.2.5","stream-json":"1.8.0",systeminformation:"5.24.5","tar-fs":"3.0.6",ulidx:"0.5.0",uuid:"10.0.0","validate.js":"0.13.1",ws:"8.18.0",yaml:"2.7.0"},devDependencies:{"@tsconfig/node16":"^1.0.3","@types/node":"20.14.8","@typescript-eslint/eslint-plugin":"^7.18.0","@typescript-eslint/parser":"^7.18.0",axios:"1.7.5",chai:"4.4.1","chai-integer":"0.1.0",esbuild:"^0.24.2",eslint:"^8.57.1","eslint-config-prettier":"^9.1.0","eslint-plugin-sonarjs":"^3.0.1",eventsource:"^2.0.2","graphql-http":"^1.22.3","hook-std":"3.0.0","intercept-stdout":"0.1.2",mkcert:"1.5.1",mocha:"^11.0.1","mocha-teamcity-reporter":"^4.2.0","mock-require":"3.0.3","mock-stdin":"1.0.0",mqtt:"~4.3.8",newman:"6.1.3","node-fetch":"2.6.7",nyc:"15.1.0",prettier:"3.3.3",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.7.2",undici:"^6.19.8","why-is-node-still-running":"^1.0.0"},overrides:{alasql:{xlsx:"0.18.5"}},optionalDependencies:{bufferutil:"^4.0.7","segfault-handler":"^1.3.0","utf-8-validate":"^5.0.10"}}});var k_={};je(k_,{addAnalyticsListener:()=>x_,recordAction:()=>pr,recordActionBinary:()=>qn,setAnalyticsEnabled:()=>oee});function oee(e){h0=e}function pr(e,t,r,n,s){if(!h0)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=pp.get(i);if(o)if(typeof e=="number"){let c=o.values,l=c.index++;if(l>=c.length){let u=c;o.values=c=new Float32Array(l*2),c.set(u),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},pp.set(i,o)}Ep||aee()}function qn(e,t,r,n,s){pr(!!e,t,r,n,s)}function x_(e){S0.push(e)}function aee(){Ep=performance.now(),setTimeout(async()=>{let e=performance.now()-Ep;Ep=0;let t=[],r={time:Date.now(),period:e,threadId:Tc.threadId,metrics:t};for(let[s,i]of pp){if(i.values){let o=i.values.subarray(0,i.values.index);o.sort();let c=o.length,l=0,u=[],d;for(let _ of T0){let E=Math.floor(c*_),f=o[E-1];if(E>l){let h=E-l;if(f===d){let T=u[u.length-1];typeof T=="number"?u[u.length-1]={value:T,count:1+h}:T.count+=h}else u.push(h>1?{value:f,count:h}:f),d=f;l=E}}t.push(Object.assign(i.description,{mean:i.total/c,distribution:u,count:c}))}else i.callback?t.push(Object.assign(i.description,i.callback(i))):t.push(Object.assign(i.description,{total:i.total,count:i.count}));await g0()}let n=process.memoryUsage();t.push({metric:"memory",threadId:Tc.threadId,byThread:!0,...n});for(let s of S0)s(t);pp=new Map,Tc.parentPort?Tc.parentPort.postMessage({type:m0,report:r}):y0({report:r})},p0).unref()}async function cee(e,t=6e4){let r=WR(),n=A0(),s=new Promise(T=>{let m=performance.now();setImmediate(()=>{let g=performance.now();g-m>5e3&&(0,v_.warn)("Unusually high event queue latency on the main thread of "+Math.round(g-m)+"ms"),m=performance.now()}),n.primaryStore.prefetch([1],()=>{let g=performance.now();g-m>5e3&&(0,v_.warn)("Unusually high task queue latency on the main thread of "+Math.round(g-m)+"ms"),T(g-m)})}),i;for(let T of n.primaryStore.getRange({start:1/0,end:!1,reverse:!0}))if(T.value?.time){i=T.value.time;break}if(Date.now()-t<i)return;let o,c=new Map,l=new Map,u=[],d;for(let{key:T,value:m}of r.primaryStore.getRange({start:i||!1,exclusiveStart:!0,end:1/0})){if(!m)continue;if(o){if(T>o+t)break}else o=T;d=T;let{metrics:g,threadId:S}=m;for(let y of g||[]){let{path:I,method:U,type:H,metric:X,count:Y,total:V,distribution:ne,threads:Q,...de}=y;Y||(Y=1);let W=X+(I?"-"+I:"");U!==void 0&&(W+="-"+U),H!==void 0&&(W+="-"+H);let ae=c.get(W);if(ae){if(ae.threads){let Ne=ae.threads[S];if(Ne)ae=Ne;else{ae.threads[S]={...de};continue}}ae.count||(ae.count=1);let Oe=ae.count;for(let Ne in de){let Me=de[Ne];typeof Me=="number"&&(ae[Ne]=(ae[Ne]*Oe+Me*Y)/(Oe+Y))}ae.count+=Y,V>=0&&(ae.total+=V,ae.ratio=ae.total/ae.count)}else ae={period:t,...y},delete ae.distribution,c.set(W,ae),ae.byThread&&(ae.threads=[],ae.threads[S]={...de},u.push(ae));if(ne){ne=ne.map(Ne=>typeof Ne=="number"?{value:Ne,count:1}:Ne);let Oe=l.get(W);Oe?Oe.push(...ne):l.set(W,ne)}}await g0()}for(let T of u){let{path:m,method:g,type:S,metric:y,count:I,total:U,distribution:H,threads:X,...Y}=T;X=X.filter(V=>V);for(let V in Y){if(typeof T[V]!="number")continue;let ne=0;for(let Q of X){let de=Q[V];typeof de=="number"&&(ne+=de)}T[V]=ne}T.count=X.length,delete T.threads,delete T.byThread}for(let[T,m]of l){let g=c.get(T);m.sort((Ne,Me)=>Ne.value>Me.value?1:-1);let S=g.count-1,y=[],I=0,U=0,H;for(let Ne of T0){let Me=S*Ne;for(;I<Me;)H=m[U++],I+=H.count,U===1&&I--;let Gr=m[U>1?U-2:0];H||(H=m[0]),y.push(H.value-(H.value-Gr.value)*(I-Me)/H.count)}let[X,Y,V,ne,Q,de,W,ae,Oe]=y;Object.assign(g,{p1:X,p10:Y,p25:V,median:ne,p75:Q,p90:de,p95:W,p99:ae,p999:Oe})}let _;for(let[T,m]of c)m.id=(0,hp.getNextMonotonicTime)(),m.time=d,n.primaryStore.put(m.id,m,{append:!0}).then(g=>{g||n.primaryStore.put(m.id,m)}),_=!0;let E=Date.now(),{idle:f,active:h}=performance.eventLoopUtilization();if(_||h*10>f){let T=(0,hp.getNextMonotonicTime)(),m={id:T,metric:"main-thread-utilization",idle:f-a0,active:h-c0,taskQueueLatency:await s,time:E,...process.memoryUsage()};n.primaryStore.put(T,m,{append:!0}).then(g=>{g||n.primaryStore.put(T,m)})}a0=f,c0=h}async function l0(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function WR(){return u0||(u0=Et({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function A0(){return d0||(d0=Et({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function dee(){R0=!0;let e=(0,H_.get)(YR.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await cee(p0,e),await l0(WR(),lee),await l0(A0(),uee)},Math.min(e/2,2147483647)).unref()}function y0(e,t){let r=e.report;r.threadId=t?.threadId||Tc.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(_0+=n.mean*n.count);r.totalBytesProcessed=_0,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(f0.get(t))}),f0.set(t,t.performance.eventLoopUtilization())),r.id=(0,hp.getNextMonotonicTime)(),WR().primaryStore.put(r.id,r),R0||dee(),_ee&&(b0=Eee(r))}async function Eee(e){if(await b0,!Xo){let r=(0,B_.dirname)((0,v_.getLogFilePath)());try{Xo=await(0,KR.open)((0,B_.join)(r,"analytics.log"),"r+")}catch{Xo=await(0,KR.open)((0,B_.join)(r,"analytics.log"),"w+")}}let t=(await Xo.stat()).size;if(t>fee){let r=Buffer.alloc(t);await Xo.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await Xo.write(r,{position:0}),await Xo.truncate(r.length),t=r.length}await Xo.write(JSON.stringify(e)+`
11
+ This can occur during early stages of install where the config file has not yet been created`);return}else throw hr.error(i),new Error(`Error reading HarperDB config file at ${r}`)}e4(n,r),Ag(n);let s=n.toJSON();if(K2.config=s,jt=Pl(s),jt.logging_rotation_rotate)for(let i in KC)jt[i]&&hr.error(`Config ${KC[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);hr.trace(W2)}}a(ch,"initConfig");function e4(e,t){let r=e.getIn(["rootPath"]),n=!1;e.hasIn(["storage","path"])||(e.setIn(["storage","path"],Ln.join(r,"database")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],Ln.join(r,"log")),n=!0),e.hasIn(["authentication"])||(e.addIn(["authentication"],{cacheTTL:3e4,enableSessions:!0,operationTokenTimeout:e.getIn(["operationsApi","authentication","operationTokenTimeout"])??"1d",refreshTokenTimeout:e.getIn(["operationsApi","authentication","refreshTokenTimeout"])??"30d"}),n=!0),e.hasIn(["analytics"])||(e.addIn(["analytics"],{aggregatePeriod:60}),n=!0),n&&(hr.trace("Updating config file with missing config params"),$r.writeFileSync(t,String(e)))}a(e4,"checkForUpdatedConfig");function Ag(e,t=!1){let r=e.toJSON();if(r.componentsRoot=r.componentsRoot??r?.customFunctions?.root,r?.http?.threads&&(r.threads=r?.http?.threads),r.http?.port&&r.http?.port===r.http?.securePort)throw Cl.CONFIG_VALIDATION("http.port and http.securePort cannot be the same value");if(r.operationsApi?.network?.port&&r.operationsApi?.network?.port===r.operationsApi?.network?.securePort)throw Cl.CONFIG_VALIDATION("operationsApi.network.port and operationsApi.network.securePort cannot be the same value");let n=F2(r,t);if(n.error)throw Cl.CONFIG_VALIDATION(n.error.message);typeof n.value.threads=="object"?e.setIn(["threads","count"],n.value.threads.count):e.setIn(["threads"],n.value.threads),e.setIn(["componentsRoot"],n.value.componentsRoot),e.setIn(["logging","root"],n.value.logging.root),e.setIn(["storage","path"],n.value.storage.path),e.setIn(["logging","rotation","path"],n.value.logging.rotation.path),e.setIn(["operationsApi","network","domainSocket"],n.value?.operationsApi?.network?.domainSocket),r?.clustering?.enabled&&e.setIn(["clustering","leafServer","streams","path"],n.value.clustering.leafServer.streams?.path)}a(Ag,"validateConfig");function t4(e,t){jt===void 0&&(jt={});let r=xs[e.toLowerCase()];if(r===void 0){hr.trace(`Unable to update config object because config param '${e}' does not exist`);return}jt[r.toLowerCase()]=t}a(t4,"updateConfigObject");function JC(e,t,r=void 0,n=!1,s=!1,i=!1){jt===void 0&&ch();let o=QC(xs.hdb_root),c=Ln.join(o,on.HDB_CONFIG_FILE),l=$o(c),u;if(r===void 0&&e.toLowerCase()===Dn.DATABASES)u=t;else if(r===void 0){let E;if(i)E=e;else if(E=xs[e.toLowerCase()],E===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let f=E.split("_"),h=gg(E,t);l.setIn([...f],h)}else for(let E in r){let f=xs[E.toLowerCase()];if(f===Dn.HTTP_SECUREPORT&&r[E]===jt[Dn.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),f===Dn.OPERATIONSAPI_NETWORK_SECUREPORT&&r[E]===jt[Dn.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&l.setIn(["operationsApi","network","port"],null),f===Dn.DATABASES){u=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("_"),T=on.LEGACY_CONFIG_PARAMS[E.toUpperCase()];T&&T.startsWith("customFunctions")&&l.hasIn(T.split("_"))&&(f=T,h=T.split("_"));let m=gg(f,r[E]);f==="rootPath"&&m?.endsWith("/")&&(m=m.slice(0,-1));try{h.length>1&&typeof l.getIn(h.slice(0,-1))=="boolean"&&l.deleteIn(h.slice(0,-1)),l.setIn([...h],m)}catch(g){hr.error(g)}}}u&&zC(l,u),Ag(l);let d=l.getIn(["rootPath"]),_=Ln.join(d,on.HDB_CONFIG_FILE);n===!0&&r4(c,d),$r.writeFileSync(_,String(l)),s&&(jt=Pl(l.toJSON())),hr.trace(`Config parameter: ${e} updated with value: ${t}`)}a(JC,"updateConfigValue");function r4(e,t){try{let r=Ln.join(t,"backup",`${new Date(Date.now()).toISOString().replaceAll(":","-")}-${on.HDB_CONFIG_FILE}.bak`);$r.copySync(e,r),hr.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){hr.error(j2),hr.error(r)}}a(r4,"backupConfigFile");var n4=["databases"];function Pl(e){return e.http&&Object.assign(e.http,e?.customFunctions?.network),e?.operationsApi?.network&&(e.operationsApi.network={...e.http,...e.operationsApi.network}),e?.operationsApi&&(e.operationsApi.tls={...e.tls,...e.operationsApi.tls}),ah=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])&&!n4.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;!Dn[l.toUpperCase()]&&xs[l]&&(s[xs[l].toLowerCase()]=o[c]),s[l]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(Pl,"flattenConfig");function gg(e,t){if(e===Dn.CLUSTERING_NODENAME||e===Dn.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(G2(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||Er.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 Er.autoCast(t)}a(gg,"castConfigValue");function s4(){let e=Er.getPropsFilePath(),t=Ja(e);return $o(t).toJSON()}a(s4,"getConfiguration");async function i4(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return JC(void 0,void 0,s,!0),J2}catch(i){throw typeof i=="string"||i instanceof String?$2(i,i,V2.BAD_REQUEST,void 0,void 0,!0):i}}a(i4,"setConfiguration");function Rg(){let e=Er.getPropsFilePath();try{$r.accessSync(e,$r.constants.F_OK|$r.constants.R_OK)}catch(n){if(!Er.noBootFile())throw hr.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=Ja(e);return $o(t).toJSON()}a(Rg,"readConfigFile");function $o(e){return YC.parseDocument($r.readFileSync(e,"utf8"),{simpleKeys:!0})}a($o,"parseYamlDoc");function o4(){let e=Rg(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=Er.isEmptyOrZeroLength(t)?[]:t;let r=VC(t);if(r)throw Cl.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=Er.isEmptyOrZeroLength(n)?[]:n;let s=VC(n);if(s)throw Cl.CONFIG_VALIDATION(s.message);if(!Er.isEmptyOrZeroLength(n)&&!Er.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!Er.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw Cl.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(o4,"getClusteringRoutes");function XC(e){let t=WC(e);jt={};for(let r in xs){let n=t.get(r.toUpperCase());if(Er.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=xs[r].toLowerCase();s===Dn.LOGGING_ROOT?jt[s]=Ln.dirname(n):jt[s]=n}return jt}a(XC,"initOldConfig");function a4(e){let t=Rg();return q2.get(t,e.replaceAll("_","."))}a(a4,"getConfigFromFile");async function c4(e,t){let r=$o(Ja());r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),await $r.writeFile(Ja(),String(r))}a(c4,"addConfig");function l4(e){let t=Ja(Er.getPropsFilePath()),r=$o(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=Ln.join(n,on.HDB_CONFIG_FILE);$r.writeFileSync(s,String(r))}a(l4,"deleteConfigFromFile");function u4(){return ah||(ch(),ah)}a(u4,"getConfigObj");function d4(){return jt||ch(),jt}a(d4,"getFlatConfigObj")});var se=N((sP,iP)=>{"use strict";var yg=require("fs-extra"),Xa=require("path"),eP=require("os"),_4=require("properties-reader"),$d=j(),qd=re(),Pe=M(),lh=wt(),f4="Error initializing environment manager",uh="BOOT_PROPS_FILE_PATH",tP=!1,E4={[Pe.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[Pe.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[Pe.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},ji={};Object.assign(sP,iP.exports={BOOT_PROPS_FILE_PATH:uh,getHdbBasePath:h4,setHdbBasePath:p4,get:rP,initSync:S4,setProperty:Qe,initTestEnvironment:g4,setCloneVar:T4});function h4(){return ji[Pe.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(h4,"getHdbBasePath");function p4(e){ji[Pe.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(p4,"setHdbBasePath");function rP(e){let t=lh.getConfigValue(e);return t===void 0?ji[e]:t}a(rP,"get");function Qe(e,t){E4[e]&&(ji[e]=t),lh.updateConfigObject(e,t)}a(Qe,"setProperty");function m4(){let e;try{e=qd.getPropsFilePath(),yg.accessSync(e,yg.constants.F_OK|yg.constants.R_OK),tP=!0;let t=_4(e);return ji[Pe.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(Pe.HDB_SETTINGS_NAMES.INSTALL_USER),ji[Pe.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(Pe.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),ji[uh]=e,!0}catch{return $d.trace(`Environment manager found no properties file at ${e}`),!1}}a(m4,"doesPropFileExist");function S4(e=!1){try{((tP||m4()||qd.noBootFile())&&!nP||e)&&(lh.initConfig(e),ji[Pe.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=lh.getConfigValue(Pe.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){$d.error(f4),$d.error(t),console.error(t),process.exit(1)}}a(S4,"initSync");var nP=!1;function T4(e){nP=e}a(T4,"setCloneVar");function g4(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=Xa.join(__dirname,"../../","unitTests");ji[uh]=Xa.join(l,"hdb_boot_properties.file"),Qe(Pe.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,Xa.join(l,"settings.test")),Qe(Pe.HDB_SETTINGS_NAMES.INSTALL_USER,eP.userInfo()?eP.userInfo().username:void 0),Qe(Pe.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),Qe(Pe.HDB_SETTINGS_NAMES.LOG_PATH_KEY,Xa.join(l,"envDir","log")),Qe(Pe.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),Qe(Pe.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),Qe(Pe.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),Qe(Pe.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,Xa.join(l,"envDir")),Qe(Pe.CONFIG_PARAMS.STORAGE_PATH,Xa.join(l,"envDir")),s&&(Qe(Pe.CONFIG_PARAMS.HTTP_SECUREPORT,rP(Pe.CONFIG_PARAMS.HTTP_PORT)),Qe(Pe.CONFIG_PARAMS.HTTP_PORT,null)),Qe(Pe.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,!!s),Qe(Pe.CONFIG_PARAMS.HTTP_PORT,9926),Qe(Pe.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),Qe(Pe.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT,9925),Qe(Pe.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,qd.isEmpty(i)?!1:i),Qe(Pe.CONFIG_PARAMS.HTTP_CORS,qd.isEmpty(i)?!1:i),Qe(Pe.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),Qe(Pe.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),Qe(Pe.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),Qe(Pe.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),Qe(Pe.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,Xa.resolve(__dirname,"../../unitTests/server/fastifyRoutes/custom_functions")),Qe(Pe.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,qd.isEmpty(c)?!1:c),o&&(Qe("CORS_ACCESSLIST",o),Qe(Pe.CONFIG_PARAMS.HTTP_CORSACCESSLIST,o)),n&&(Qe(Pe.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,n),Qe(Pe.CONFIG_PARAMS.HTTP_TIMEOUT,n)),t&&(Qe(Pe.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),Qe(Pe.CONFIG_PARAMS.HTTP_KEEPALIVETIMEOUT,t)),r&&(Qe(Pe.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),Qe(Pe.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${uh}. Please check your boot props and settings files`;$d.fatal(r),$d.error(t)}}a(g4,"initTestEnvironment")});var gt=N((Mge,_P)=>{"use strict";var jd=M(),A4=re(),an=se(),zd=require("path"),R4=require("minimist"),oP=require("fs-extra"),aP=require("lodash");an.initSync();var{CONFIG_PARAMS:Vo,DATABASES_PARAM_CONFIG:Vd,SYSTEM_SCHEMA_NAME:dh}=jd,Kd,Yd,Wd;function cP(){if(Kd!==void 0)return Kd;if(an.getHdbBasePath()!==void 0)return Kd=an.get(Vo.STORAGE_PATH)||zd.join(an.getHdbBasePath(),jd.DATABASES_DIR_NAME),Kd}a(cP,"getBaseSchemaPath");function lP(){if(Yd!==void 0)return Yd;if(an.getHdbBasePath()!==void 0)return Yd=dP(dh),Yd}a(lP,"getSystemSchemaPath");function uP(){if(Wd!==void 0)return Wd;if(an.getHdbBasePath()!==void 0)return Wd=an.get(jd.CONFIG_PARAMS.STORAGE_AUDIT_PATH)||zd.join(an.getHdbBasePath(),jd.TRANSACTIONS_DIR_NAME),Wd}a(uP,"getTransactionAuditStoreBasePath");function y4(e,t){let r=an.get(Vo.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||zd.join(uP(),e.toString())}a(y4,"getTransactionAuditStorePath");function dP(e,t){e=e.toString(),t=t&&t.toString();let r=an.get(jd.CONFIG_PARAMS.DATABASES)?.[e];return t&&r?.tables?.[t]?.path||r?.path||zd.join(cP(),e)}a(dP,"getSchemaPath");function b4(e,t){e=e.toString(),t=t.toString();let r=process.env;Object.assign(r,R4(process.argv));let n=r[Vo.DATABASES.toUpperCase()];if(n){let i;try{i=JSON.parse(n)}catch(o){if(!A4.isObject(n))throw o;i=n}for(let o of i){let c=o[dh];if(!c)continue;let l=an.get(Vo.DATABASES);l=l??{};let u=c?.tables?.[t]?.[Vd.PATH];if(u)return aP.set(l,[dh,Vd.TABLES,t,Vd.PATH],u),an.setProperty(Vo.DATABASES,l),u;let d=c?.[Vd.PATH];if(d)return aP.set(l,[dh,Vd.PATH],d),an.setProperty(Vo.DATABASES,l),d}}let s=r[Vo.STORAGE_PATH.toUpperCase()];if(s){if(!oP.pathExistsSync(s))throw new Error(s+" does not exist");let i=zd.join(s,e);return oP.mkdirsSync(i),an.setProperty(Vo.STORAGE_PATH,s),i}return lP()}a(b4,"initSystemSchemaPaths");function O4(){Kd=void 0,Yd=void 0,Wd=void 0}a(O4,"resetPaths");_P.exports={getBaseSchemaPath:cP,getSystemSchemaPath:lP,getTransactionAuditStorePath:y4,getTransactionAuditStoreBasePath:uP,getSchemaPath:dP,initSystemSchemaPaths:b4,resetPaths:O4}});var cn=N((Hge,mP)=>{"use strict";var N4=Pn().LMDB_ERRORS_ENUM,vge=require("lmdb"),I4=Ht(),Bge=require("buffer").Buffer,{OVERFLOW_MARKER:fP,MAX_SEARCH_KEY_LENGTH:_h}=I4,EP=["number","string","symbol","boolean","bigint"];function w4(e){if(e=e?.primaryStore||e,!e)throw new Error(N4.ENV_REQUIRED)}a(w4,"validateEnv");function C4(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(C4,"stringifyData");function P4(e){return e instanceof Date?e.valueOf():e}a(P4,"convertKeyValueToWrite");function D4(e,t){if(e===null)return t?[null]:void 0;if(e===void 0)return;if(EP.includes(typeof e))return e.length>_h?[e.slice(0,_h)+fP]:[e];let r;if(Array.isArray(e)){r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n];if(EP.includes(typeof i))i.length>_h?r.push(i.slice(0,_h)+fP):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(D4,"getIndexedValues");var fh=0,hP=0;function pP(){hP=Date.now()-performance.now()}a(pP,"adjustStartTime");pP();var L4=6e4;setInterval(pP,L4).unref();function M4(){let e=performance.now()+hP;return e>fh?(fh=e,e):(fh+=488e-6,fh)}a(M4,"getNextMonotonicTime");mP.exports={validateEnv:w4,stringifyData:C4,convertKeyValueToWrite:P4,getNextMonotonicTime:M4,getIndexedValues:D4}});var Qd=N((kge,SP)=>{"use strict";var U4=M().OPERATIONS_ENUM,bg=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i=void 0){this.operation=U4.INSERT,this.schema=t,this.table=r,this.hash_attribute=n,this.records=s,this.__origin=i}};SP.exports=bg});var Jd=N((qge,RP)=>{"use strict";var Gge=Qd(),Eh=M(),Og=re(),TP=j(),v4=require("uuid"),{handleHDBError:hh,hdb_errors:B4}=_e(),{HDB_ERROR_MSGS:ph,HTTP_STATUS_CODES:mh}=B4;RP.exports=gP;function gP(e,t,r){for(let s=0;s<t.length;s++)AP(t[s]);let{records:n}=e;for(let s=0;s<n.length;s++){let i=n[s];H4(i,r,e.operation)}}a(gP,"processRows");gP.validateAttribute=AP;function AP(e){if(Buffer.byteLength(String(e))>Eh.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw hh(new Error,ph.ATTR_NAME_LENGTH_ERR(e),mh.BAD_REQUEST,void 0,void 0,!0);if(Og.isEmptyOrZeroLength(e)||Og.isEmpty(e.trim()))throw hh(new Error,ph.ATTR_NAME_NULLISH_ERR,mh.BAD_REQUEST,void 0,void 0,!0)}a(AP,"validateAttribute");function H4(e,t,r){if(!e.hasOwnProperty(t)||Og.isEmptyOrZeroLength(e[t])){if(r===Eh.OPERATIONS_ENUM.INSERT||r===Eh.OPERATIONS_ENUM.UPSERT){e[t]=v4.v4();return}throw TP.error("Update transaction aborted due to record with no hash value:",e),hh(new Error,ph.RECORD_MISSING_HASH_ERR,mh.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>Eh.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw TP.error(e),hh(new Error,ph.HASH_VAL_LENGTH_ERR,mh.BAD_REQUEST,void 0,void 0,!0)}a(H4,"validateHash")});var yP,Mn,Ng,Dl=Ie(()=>{yP=require("events"),Mn=class extends yP.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;drainCloseListener;currentDrainResolver;[Symbol.asyncIterator](){let t=new Ng;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)}},Ng=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 Cg={};je(Cg,{loadGQLSchema:()=>F4,start:()=>wg,startOnMainThread:()=>k4});function wg({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r,n,s,i){let{parse:o,Source:c,Kind:l,NamedTypeNode:u,StringValueNode:d}=await import("graphql"),_=o(new c(r.toString(),s)),E=new Map,f=[],h;for(let g of _.definitions)switch(g.kind){case l.OBJECT_TYPE_DEFINITION:let H=function(Y){if(Y.kind==="NonNullType"){let Q=H(Y.type);return Q.nullable=!1,Q}if(Y.kind==="ListType")return{type:"array",elements:H(Y.type)};let ne={type:Y.name?.value};return Object.defineProperty(ne,"location",{value:Y.loc.startToken}),ne};a(H,"getProperty");let S=g.name.value,y=[],I={table:null,database:null,properties:y};E.set(S,I);for(let Y of g.directives){if(Y.name.value==="table"){for(let ne of Y.arguments)I[ne.name.value]=ne.value.value;I.schema&&(I.database=I.schema),I.table||(I.table=S),I.audit&&(I.audit=I.audit!=="false"),I.attributes=I.properties,f.push(I)}if(Y.name.value==="sealed"&&(I.sealed=!0),Y.name.value==="splitSegments"&&(I.splitSegments=!0),Y.name.value==="replicate"&&(I.replicate=!0),Y.name.value==="export"){I.export=!0;for(let ne of Y.arguments)typeof I.export!="object"&&(I.export={}),I.export[ne.name.value]=ne.value.value}}let U=!1,X={};for(let Y of g.fields){let V=H(Y.type);V.name=Y.name.value,y.push(V),X[V.name]=void 0;for(let ne of Y.directives){let Q=ne.name.value;if(Q==="primaryKey")U?console.warn("Can not define two attributes as a primary key at",ne.loc):(V.isPrimaryKey=!0,U=!0);else if(Q==="indexed")V.indexed=!0;else if(Q==="computed"){for(let de of ne.arguments||[])if(de.name.value==="from"){let W=de.value.value;V.computed={from:m(W,de,X)},V.version==null&&(V.version=W)}else de.name.value==="version"&&(V.version=de.value.value);V.computed=V.computed||!0}else if(Q==="relationship"){let de={};for(let W of ne.arguments)de[W.name.value]=W.value.value;V.relationship=de}else if(Q==="createdTime")V.assignCreatedTime=!0;else if(Q==="updatedTime")V.assignUpdatedTime=!0;else if(Q==="expiresAt")V.expiresAt=!0;else if(Q==="allow"){let de=V.authorizedRoles=[];for(let W of ne.arguments)W.name.value==="role"&&de.push(W.value.value)}else server.knownGraphQLDirectives.includes(Q)&&console.warn(`@${Q} is an unknown directive, at`,ne.loc)}}I.type=S,S==="Query"&&(h=I)}function T(g){let S=E.get(g.type);S?(Object.defineProperty(g,"properties",{value:S.properties}),Object.defineProperty(g,"definition",{value:S})):g.type==="array"?T(g.elements):x4.includes(g.type)||(0,OP.getWorkerIndex)()===0&&console.error(`The type ${g.type} is unknown at line ${g.location.line}, column ${g.location.column}, in ${s}`)}a(T,"connectPropertyType");for(let g of E.values())for(let S of g.properties)T(S);for(let g of f)g.tableClass=e(g),g.export&&(g.export.name===""?i.set((0,Ig.dirname)(n),g.tableClass):i.set((0,Ig.dirname)(n)+"/"+(g.export.name||g.type),g.tableClass,g.export));function m(g,S,y){return new bP.Script(`function computed(attributes) { return function(record) { with(attributes) { with (record) { return ${g}; } } } } computed;`,{filename:s,lineOffset:S.loc.startToken.line-1,columnOffset:S.loc.startToken.column}).runInThisContext()(y)}a(m,"createComputedFrom")}}var Ig,bP,OP,x4,k4,F4,NP=Ie(()=>{Ig=require("path"),bP=require("node:vm");De();OP=L(dt()),x4=["ID","Int","Float","Long","String","Boolean","Date","Bytes","Any","BigInt"];server.knownGraphQLDirectives&&(server.knownGraphQLDirectives=["table","sealed","export","primaryKey","indexed","computed","relationship","createdTime","updatedTime","expiresAt","allow"]);a(wg,"start");k4=wg,F4=wg({ensureTable:Et}).handleFile});var MP={};je(MP,{parse:()=>Dg,streamAsJSON:()=>Xd,stringify:()=>Za});function Xd(e){return new Pg({value:e})}function IP(e){return console.error(e),JSON.stringify(e.toString())}function wP(e,t,r){return e?.then?r?e.then(t,r):e.then(t):t(e)}function Za(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===DP)return LP(e);if(t.resolution)return t.resolution.then(()=>Za(e));throw t}}function LP(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+=LP(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+Za(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function Dg(e){return e?.length>0?(typeof e!="string"&&(e=e.toString()),$4.test(e)?G4.parse(e):JSON.parse(e)):null}var CP,PP,G4,q4,DP,Pg,$4,Lg=Ie(()=>{CP=require("stream"),PP=L(require("json-bigint-fixes")),G4=(0,PP.default)({useNativeBigInt:!0}),q4=1e4,DP={message:"Cannot serialize BigInt to JSON"};BigInt.prototype.toJSON=function(){throw DP};a(Xd,"streamAsJSON");Pg=class extends CP.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(;;){try{o=i.next(),o.then&&(yield o.then(c=>(o=c,""),c=>(o={done:!1,value:{error:c.toString()}},i={next:a(()=>({done:!0}),"next")},"")))}catch(c){o={done:!1,value:{error:c.toString()}},i={next:a(()=>({done:!0}),"next")}}if(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),IP)}catch(s){yield IP(s)}else yield Za(t)}else yield Za(t)}_read(){if(!this._amReading){if(this._amReading=!0,this.done)return this.push(null);wP(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>q4?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 wP(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(IP,"handleError");a(wP,"when");a(Za,"stringify");a(LP,"jsStringify");$4=/[[,:]\s*-?\d{16,}/;a(Dg,"parse")});var YP=N((Qge,KP)=>{"use strict";var Mg=require("recursive-iterator"),V4=require("alasql"),Ug=require("clone"),UP=re(),{handleHDBError:vP,hdb_errors:K4}=_e(),{HDB_ERROR_MSGS:BP,HTTP_STATUS_CODES:HP}=K4,{getDatabases:Y4}=(De(),oe(lt)),W4=["DISTINCT_ARRAY"],xP=Symbol("validateTables"),vg=Symbol("validateTable"),zge=Symbol("getAllColumns"),kP=Symbol("validateAllColumns"),Sh=Symbol("findColumn"),FP=Symbol("validateOrderBy"),Zd=Symbol("validateSegment"),Bg=Symbol("validateColumn"),GP=Symbol("setColumnsForTable"),qP=Symbol("checkColumnsForAsterisk"),$P=Symbol("validateGroupBy"),VP=Symbol("hasColumns"),Hg=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[xP](),this[qP](),this[kP]()}[xP](){if(this[VP]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[vg](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[vg](t.table)})}}[VP](){let t=!1,r=new Mg(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[vg](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=Y4();if(!r[t.databaseid])throw vP(new Error,BP.SCHEMA_NOT_FOUND(t.databaseid),HP.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw vP(new Error,BP.TABLE_NOT_FOUND(t.databaseid,t.tableid),HP.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=Ug(s);i.table=Ug(t),this.attributes.push(i)})}[Sh](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)}[qP](){let t=new Mg(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[GP](r.tableid)}[GP](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new V4.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[kP](){this[Zd](this.statement.columns,!1),this[Zd](this.statement.joins,!1),this[Zd](this.statement.where,!1),this[$P](this.statement.group,!1),this[Zd](this.statement.order,!0)}[Zd](t,r){if(!t)return;let n=new Mg(t),s=[];for(let{node:i,path:o}of n)!UP.isEmpty(i)&&!UP.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[FP](i):s.push(this[Bg](i)));return s}[$P](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&W4.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=Ug(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[Sh](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[Sh](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`}[FP](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[Bg](t)}[Bg](t){let r=this[Sh](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]}};KP.exports=Hg});var jP=N((Xge,WP)=>{"use strict";var xg=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")}};WP.exports=xg});var QP=N((eAe,zP)=>{"use strict";var kg=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};zP.exports=kg});var eD={};je(eD,{HAS_EXPIRATION:()=>Ah,HAS_RESIDENCY_ID:()=>Wg,HAS_STRUCTURE_UPDATE:()=>Rh,LAST_TIMESTAMP_PLACEHOLDER:()=>n_,LOCAL_TIMESTAMP:()=>j4,METADATA:()=>e_,NO_TIMESTAMP:()=>Gg,PENDING_LOCAL_TIME:()=>jg,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>Yg,RecordEncoder:()=>Kg,TIMESTAMP_ASSIGN_LAST:()=>Q4,TIMESTAMP_ASSIGN_NEW:()=>XP,TIMESTAMP_ASSIGN_PREVIOUS:()=>ZP,TIMESTAMP_PLACEHOLDER:()=>Th,TIMESTAMP_RECORD_PREVIOUS:()=>qg,getUpdateRecord:()=>zg,handleLocalTimeForGets:()=>yh});function X4(){return r_[0]=r_[0]^64,z4.getFloat64(0)}function yh(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,u=l?.[e_];return u>=0&&(c.metadataFlags=u,c.localTime=l.localTime,c.value=l.value,c.residencyId=l.residencyId,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?.[e_]>=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,u=l[e_];return u>=0&&(c.metadataFlags=u,c.localTime=l.localTime,c.value=l.value,c.residencyId=l.residencyId,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,ec.push(new WeakRef(this))),o.call(this)},i.prototype.done=function(){if(c.call(this),this.isDone)for(let l=0;l<ec.length;l++){let u=ec[l].deref();(!u||u.isDone||u.isCommitted)&&ec.splice(l--,1)}},i.prototype.done.isTracked=!0}return e}function zg(e,t,r){return function(n,s,i,o,c=-1,l,u,d="put",_,E){_||l==null?Ll=i?.localTime?qg|ZP:Gg:Ll=l?i?.localTime?qg|16384:XP|16384:Gg;let f=u?.expiresAt;if(f>=0&&(c|=Ah),t_=c,$g=f,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let h={version:o,instructedWrite:Ll>0},T,m=0;try{let g=i?.residencyId,S=u?.residencyId;S&&(Vg=S,t_|=Wg,m|=tc),g!==S&&(m|=rc,g||(g=0)),c&Ah&&(m|=i_),u?.originatingOperation&&(m|=s_),_&&(h.ifVersion=T=i?.version??null);let y=e.put(n,s,h);if(l){let I=u?.user?.username;if(E&&(gh=e.encoder.encode(E)),e.encoder.hasStructureUpdate&&(m|=Rh,e.encoder.hasStructureUpdate=!1),_&&i?.localTime){let U=i?.localTime,H=r.get(U);if(H){let X=xt(H).previousLocalTime;return r.put(U,Ml(o,t,n,X,u?.nodeId??server.replication.getThisNodeId(r)??0,I,d,gh,m,S,g,f),{ifVersion:T}),y}}r.put(n_,Ml(o,t,n,i?.localTime?1:0,u?.nodeId??server.replication?.getThisNodeId(r)??0,I,d,gh,m,S,g,f,u?.originatingOperation),{append:d!=="invalidate",instructedWrite:!0,ifVersion:T})}return y}catch(g){throw g.message+=" id: "+n+" options: "+h,g}}}var JP,Fg,Th,n_,Yg,j4,e_,r_,z4,Gg,XP,Q4,ZP,qg,Ah,Wg,jg,Rh,J4,gh,Ll,t_,$g,Vg,Kg,ec,Ul=Ie(()=>{JP=require("msgpackr");zi();Fg=L(j()),Th=new Uint8Array([1,1,1,1,4,64,0,0]),n_=new Uint8Array([1,1,1,1,1,0,0,0]),Yg=new Uint8Array([1,1,1,1,3,64,0,0]),j4=Symbol("local-timestamp"),e_=Symbol("metadata"),r_=new Uint8Array(8),z4=new DataView(r_.buffer,0,8),Gg=0,XP=0,Q4=1,ZP=3,qg=4,Ah=16,Wg=32,jg=1,Rh=256,Ll=0,t_=-1,$g=-1,Vg=0,Kg=class extends JP.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(s,i){if(Ll||t_>=0){let o=0,c=Ll;c&&(o+=8,Ll=0);let l=t_,u=$g,d=Vg;l>=0&&(o+=2,t_=-1,u>=0&&(o+=8,$g=-1),d&&(o+=4,Vg=0));let _=J4=r.call(this,s,i|2048|o);gh=_.subarray((_.start||0)+o,_.end);let E=_.start||0;return c&&(Th[4]=c,Th[5]=c>>8,_.set(Th,E),E+=8),l>=0&&(_[E++]=l&31,_[E++]=l>>5,u>=0&&((_.dataView||(_.dataView=new DataView(_.buffer,_.byteOffset,_.byteLength))).setFloat64(E,u),E+=8),d&&(_.dataView||(_.dataView=new DataView(_.buffer,_.byteOffset,_.byteLength))).setUint32(E,d)),_}else return r.call(this,s,i)};let n=this.saveStructures;this.saveStructures=function(s,i){let o=n.call(this,s,i);return this.hasStructureUpdate=!0,o}}decode(t,r){let n=r?.start||0,s=r>-1?r:r?.end||t.length,i=t[n],o=0;try{if(i<32&&s>2){let c=n,l;if(i===2){if(t.copy)t.copy(r_,0,c),c+=8;else for(let E=0;E<8;E++)r_[E]=t[c++];l=X4(),i=t[c]}let u,d;i<32&&(o=i|t[c+1]<<5,c+=2,o&Ah&&(u=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8),o&Wg&&(d=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getUint32(c),c+=4));let _=r?.valueAsBuffer?t.subarray(c,s):super.decode(t.subarray(c,s),s-c);return{localTime:l,value:_,[e_]:o,expiresAt:u,residencyId:d}}return r?.valueAsBuffer?t:super.decode(t,r)}catch(c){throw c.message+=", data: "+t.slice(0,40).toString("hex"),c}}};a(X4,"getTimestamp");a(yh,"handleLocalTimeForGets");ec=[];setInterval(()=>{for(let e=0;e<ec.length;e++){let t=ec[e].deref();!t||t.isDone||t.isCommitted?ec.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(Fg.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):Fg.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(zg,"getUpdateRecord")});var o_=N((iAe,rD)=>{"use strict";var tD=se(),Z4=M(),{RecordEncoder:eJ}=(Ul(),oe(eD)),sAe=require("fs");tD.initSync();var tJ=tD.get(Z4.CONFIG_PARAMS.STORAGE_CACHING)!==!1,Qg=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=tJ&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:eJ})}};rD.exports=Qg});var a_=N((aAe,nD)=>{"use strict";var Un=se(),cs=M();Un.initSync();var bh=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=Un.get(cs.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Un.get(cs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Un.get(cs.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Un.get(cs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Un.get(cs.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Un.get(cs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Un.get(cs.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Un.get(cs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Un.get(cs.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Un.get(cs.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Un.get(cs.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Un.get(cs.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};nD.exports=bh;bh.MAX_DBS=1e4});var ht=N((lAe,fD)=>{"use strict";var Xg=require("lmdb"),ks=require("fs-extra"),vn=require("path"),Oh=cn(),oD=j(),ln=Pn().LMDB_ERRORS_ENUM,Nh=QP(),Zg=o_(),aD=a_(),Ko=Ht(),sD=M(),{table:rJ,resetDatabases:nJ}=(De(),oe(lt)),iD=se(),Fs=Ko.INTERNAL_DBIS_NAME,cD=Ko.DBI_DEFINITION_NAME,sJ="data.mdb",iJ="lock.mdb",c_=".mdb",oJ="-lock",Jg=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=ls(t,r),this.key_type=this.dbi[Ko.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[Ko.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new Xg.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function Ih(e,t){if(e===void 0)throw new Error(ln.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(ln.ENV_NAME_REQUIRED)}a(Ih,"pathEnvNameValidation");async function eA(e,t,r=!0){try{await ks.access(e)}catch(n){throw n.code==="ENOENT"?new Error(ln.INVALID_BASE_PATH):n}try{let n=vn.join(e,t+c_);return await ks.access(n,ks.constants.R_OK|ks.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await ks.access(vn.join(e,t,sJ),ks.constants.R_OK|ks.constants.F_OK),vn.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(ln.INVALID_ENVIRONMENT)}else throw new Error(ln.INVALID_ENVIRONMENT);throw n}}a(eA,"validateEnvironmentPath");function wh(e,t){if(Oh.validateEnv(e),t===void 0)throw new Error(ln.DBI_NAME_REQUIRED)}a(wh,"validateEnvDBIName");async function aJ(e,t,r=!1,n=!1){Ih(e,t);let s=vn.basename(e);t=t.toString();let i=iD.get(sD.CONFIG_PARAMS.DATABASES);i||iD.setProperty(sD.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await eA(e,t,n),lD(e,t,r)}catch(o){if(o.message===ln.INVALID_ENVIRONMENT){let c=vn.join(e,t);await ks.mkdirp(n?c:e);let l=new aD(n?c:c+c_,!1),u=Xg.open(l);u.dbis=Object.create(null);let d=new Zg(!1);u.openDB(Fs,d),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let _=tA(e,t,r);return u[Ko.ENVIRONMENT_NAME_KEY]=_,global.lmdb_map[_]=u,u}throw o}}a(aJ,"createEnvironment");async function cJ(e,t,r,n=!0){Ih(e,t),t=t.toString();let s=vn.join(e,t);return rJ({table:t,database:vn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(cJ,"copyEnvironment");async function lD(e,t,r=!1){Ih(e,t),t=t.toString();let n=tA(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 eA(e,t),i=vn.join(e,t+c_),o=s!=i,c=new aD(s,o),l=Xg.open(c);l.dbis=Object.create(null);let u=dD(l);for(let d=0;d<u.length;d++)ls(l,u[d]);return l[Ko.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(lD,"openEnvironment");async function lJ(e,t,r=!1){Ih(e,t),t=t.toString();let n=vn.join(e,t+c_),s=await eA(e,t);if(global.lmdb_map!==void 0){let i=tA(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await uD(o),delete global.lmdb_map[i]}}await ks.remove(s),await ks.remove(s===n?s+oJ:vn.join(vn.dirname(s),iJ))}a(lJ,"deleteEnvironment");async function uD(e){Oh.validateEnv(e);let t=e[Ko.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(uD,"closeEnvironment");function tA(e,t,r=!1){let s=`${vn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(tA,"getCachedEnvironmentName");function uJ(e){Oh.validateEnv(e);let t=Object.create(null),r=ls(e,Fs);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==Fs)try{t[n]=Object.assign(new Nh,s)}catch{oD.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(uJ,"listDBIDefinitions");function dD(e){Oh.validateEnv(e);let t=[],r=ls(e,Fs);for(let{key:n}of r.getRange({start:!1}))n!==Fs&&t.push(n);return t}a(dD,"listDBIs");function dJ(e,t){let n=ls(e,Fs).getEntry(t),s=new Nh;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{oD.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(dJ,"getDBIDefinition");function _D(e,t,r,n=!r){if(wh(e,t),t=t.toString(),t===Fs)throw new Error(ln.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return ls(e,t)}catch(s){if(s.message===ln.DBI_DOES_NOT_EXIST){let i=new Zg(r,n===!0),o=e.openDB(t,i),c=new Nh(r===!0,n);return o[cD]=c,ls(e,Fs).putSync(t,c),e.dbis[t]=o,o}throw s}}a(_D,"createDBI");function ls(e,t){if(wh(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==Fs?r=dJ(e,t):r=new Nh,r===void 0)throw new Error(ln.DBI_DOES_NOT_EXIST);let n;try{let s=new Zg(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(ln.DBI_DOES_NOT_EXIST):s}return n[cD]=r,e.dbis[t]=n,n}a(ls,"openDBI");function _J(e,t){wh(e,t),t=t.toString();let r=ls(e,t),n=r.getStats();return r[Ko.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(_J,"statDBI");async function fJ(e,t){try{let r=vn.join(e,t+c_);return(await ks.stat(r)).size}catch{throw new Error(ln.INVALID_ENVIRONMENT)}}a(fJ,"environmentDataSize");function EJ(e,t){if(wh(e,t),t=t.toString(),t===Fs)throw new Error(ln.CANNOT_DROP_INTERNAL_DBIS_NAME);ls(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],ls(e,Fs).removeSync(t)}a(EJ,"dropDBI");function hJ(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{ls(e,i)}catch(o){if(o.message===ln.DBI_DOES_NOT_EXIST)_D(e,i,i!==t,i===t),n=!0;else throw o}}n&&nJ()}a(hJ,"initializeDBIs");fD.exports={openDBI:ls,openEnvironment:lD,createEnvironment:aJ,listDBIs:dD,listDBIDefinitions:uJ,createDBI:_D,dropDBI:EJ,statDBI:_J,deleteEnvironment:lJ,initializeDBIs:hJ,TransactionCursor:Jg,environmentDataSize:fJ,copyEnvironment:cJ,closeEnvironment:uD}});var hD=N((dAe,ED)=>{"use strict";var rA=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};ED.exports=rA});var mD=N((fAe,pD)=>{"use strict";var nA=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}};pD.exports=nA});var TD=N((hAe,SD)=>{"use strict";var sA=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};SD.exports=sA});var sc=N((gAe,RD)=>{"use strict";var pJ=ht(),mJ=hD(),SJ=mD(),TJ=TD(),mi=cn(),l_=Pn().LMDB_ERRORS_ENUM,gJ=Ht(),Qi=M(),AJ=re(),RJ=require("uuid"),mAe=require("lmdb"),{handleHDBError:yJ,hdb_errors:bJ}=_e(),{OVERFLOW_MARKER:SAe,MAX_SEARCH_KEY_LENGTH:TAe}=gJ,gD=se();gD.initSync();var Ch=gD.get(Qi.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),iA=Qi.TIME_STAMP_NAMES_ENUM.CREATED_TIME,nc=Qi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function OJ(e,t,r,n,s=mi.getNextMonotonicTime()){lA(e,t,r,n),oA(e,t,r);let i=new mJ,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l];AD(u,!0,s);let d=NJ(e,t,r,u),_=u[t];o.push(d),c.push(_)}return aA(o,c,n,i,s)}a(OJ,"insertRecords");function NJ(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 d=c([[{}]]);Array.isArray(d)&&(c=d[0][Qi.FUNC_VAL],n[o]=c)}let l=mi.getIndexedValues(c),u=e.dbis[o];if(l){Ch&&u.prefetch(l.map(d=>({key:d,value:s})),Ph);for(let d=0,_=l.length;d<_;d++)u.put(l[d],s)}}Ch&&e.dbis[t].prefetch([s],Ph),e.dbis[t].put(s,n,n[nc])})}a(NJ,"insertRecord");function IJ(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(IJ,"removeSkippedRecords");function AD(e,t,r){let n=r>0;(n||!Number.isInteger(e[nc]))&&(e[nc]=r||(r=mi.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[iA]))&&(e[iA]=r||mi.getNextMonotonicTime()):delete e[iA]}a(AD,"setTimestamps");function oA(e,t,r){r.indexOf(Qi.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(Qi.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(Qi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(Qi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),pJ.initializeDBIs(e,t,r)}a(oA,"initializeTransaction");async function wJ(e,t,r,n,s=mi.getNextMonotonicTime()){lA(e,t,r,n),oA(e,t,r);let i=new SJ,o=[],c=[],l=[];for(let u=0;u<n.length;u++){let d=n[u],_=d[t],E;try{E=cA(e,t,d,_,i,!0,s)}catch{i.skipped_hashes.push(_),o.push(u);continue}c.push(E),l.push(_)}return aA(c,l,n,i,s,o)}a(wJ,"updateRecords");async function CJ(e,t,r,n,s=mi.getNextMonotonicTime()){try{lA(e,t,r,n)}catch(l){throw yJ(l,l.message,bJ.HTTP_STATUS_CODES.BAD_REQUEST)}oA(e,t,r);let i=new TJ,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l],d;AJ.isEmpty(u[t])?(d=RJ.v4(),u[t]=d):d=u[t];let _=cA(e,t,u,d,i,!1,s);o.push(_),c.push(d)}return aA(o,c,n,i,s)}a(CJ,"upsertRecords");async function aA(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||mi.getNextMonotonicTime(),IJ(r,i),n}a(aA,"finalizeWrite");function cA(e,t,r,n,s,i=!1,o){let c=e.dbis[t],l=c.getEntry(n),u=l?.value,d=u;if(!u){if(i)return!1;u={}}if(AD(r,!d,o),Number.isInteger(r[nc])&&u[nc]>r[nc])return!1;d&&s.original_records.push(u);let _,E=a(()=>{for(let h in r){if(!r.hasOwnProperty(h)||h===t)continue;let T=r[h],m=e.dbis[h];if(m===void 0)continue;let g=u[h];if(typeof T=="function"){let y=T([[u]]);Array.isArray(y)&&(T=y[0][Qi.FUNC_VAL],r[h]=T)}if(T===g)continue;let S=mi.getIndexedValues(g);if(S){Ch&&m.prefetch(S.map(y=>({key:y,value:n})),Ph);for(let y=0,I=S.length;y<I;y++)m.remove(S[y],n)}if(S=mi.getIndexedValues(T),S){Ch&&m.prefetch(S.map(y=>({key:y,value:n})),Ph);for(let y=0,I=S.length;y<I;y++)m.put(S[y],n)}}let f={...u,...r};c.put(n,f,f[nc])},"do_put");return l?_=c.ifVersion(n,l.version,E):_=c.ifNoExists(n,E),_.then(f=>f?!0:cA(e,t,r,n,s,i,o))}a(cA,"updateUpsertRecord");function PJ(e,t,r){if(mi.validateEnv(e),t===void 0)throw new Error(l_.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(l_.WRITE_ATTRIBUTES_REQUIRED):new Error(l_.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(PJ,"validateBasic");function lA(e,t,r,n){if(PJ(e,t,r),!Array.isArray(n))throw n===void 0?new Error(l_.RECORDS_REQUIRED):new Error(l_.RECORDS_MUST_BE_ARRAY)}a(lA,"validateWrite");function Ph(){}a(Ph,"noop");RD.exports={insertRecords:OJ,updateRecords:wJ,upsertRecords:CJ}});var Ji=N((RAe,DJ)=>{DJ.exports={hdb_user:{hash_attribute:"username",name:"hdb_user",schema:"system",residence:["*"],attributes:[{attribute:"username"},{attribute:"password"},{attribute:"role"},{attribute:"active"},{attribute:"hash"},{attribute:"refresh_token"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_role:{hash_attribute:"id",name:"hdb_role",schema:"system",attributes:[{attribute:"id"},{attribute:"role"},{attribute:"permission"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}],residence:["*"]},hdb_job:{hash_attribute:"id",name:"hdb_job",schema:"system",attributes:[{attribute:"id"},{attribute:"user"},{attribute:"type"},{attribute:"status"},{attribute:"start_datetime"},{attribute:"end_datetime"},{attribute:"message"},{attribute:"created_datetime"},{attribute:"request"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_license:{hash_attribute:"license_key",name:"hdb_license",schema:"system",attributes:[{attribute:"license_key"},{attribute:"company"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_info:{hash_attribute:"info_id",name:"hdb_info",schema:"system",attributes:[{attribute:"info_id"},{attribute:"data_version_num"},{attribute:"hdb_version_num"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_nodes:{hash_attribute:"name",name:"hdb_nodes",schema:"system",attributes:[{attribute:"name"},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"}]},hdb_certificate:{hash_attribute:"name",name:"hdb_certificate",schema:"system",attributes:[{attribute:"name"},{attribute:"uses"},{attribute:"certificate"},{attribute:"is_authority"},{attribute:"private_key_name"},{attribute:"details"},{attribute:"is_self_signed"},{attribute:"__updatedtime__"}]},hdb_analytics:{hash_attribute:"id",name:"hdb_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]},hdb_raw_analytics:{hash_attribute:"id",name:"hdb_raw_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{attribute:"time"},{attribute:"metrics"}]},hdb_temp:{hash_attribute:"id",name:"hdb_temp",schema:"system",attributes:[{attribute:"id"}]},hdb_durable_session:{hash_attribute:"id",name:"hdb_durable_session",schema:"system",attributes:[{attribute:"id"}]},hdb_session_will:{hash_attribute:"id",name:"hdb_session_will",schema:"system",attributes:[{attribute:"id"}]}}});var Ti=N((yAe,OD)=>{"use strict";var bD=re(),yD=M(),vl=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Si=require("joi"),Yo={schema_format:{pattern:vl,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},LJ=Si.alternatives(Si.string().min(1).max(Yo.schema_length.maximum).pattern(vl).messages({"string.pattern.base":"{:#label} "+Yo.schema_format.message}),Si.number(),Si.array()).required(),MJ=Si.alternatives(Si.string().min(1).max(Yo.schema_length.maximum).pattern(vl).messages({"string.pattern.base":"{:#label} "+Yo.schema_format.message}),Si.number()),UJ=Si.alternatives(Si.string().min(1).max(Yo.schema_length.maximum).pattern(vl).messages({"string.pattern.base":"{:#label} "+Yo.schema_format.message}),Si.number()).required();function vJ(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>Yo.schema_length.maximum?`'${e}' maximum of 250 characters`:vl.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(vJ,"checkValidTable");function BJ(e,t){return bD.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(BJ,"validateSchemaExists");function HJ(e,t){let r=t.state.ancestors[0].schema;return bD.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(HJ,"validateTableExists");function xJ(e,t){return e.toLowerCase()===yD.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${yD.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(xJ,"validateSchemaName");OD.exports={common_validators:Yo,schema_regex:vl,hdb_schema_table:LJ,validateSchemaExists:BJ,validateTableExists:HJ,validateSchemaName:xJ,checkValidTable:vJ,hdb_database:MJ,hdb_table:UJ}});var Dh=N((OAe,ND)=>{var{common_validators:gi}=Ti(),d_=Tt(),u_="is required",rr={database:{presence:!1,format:gi.schema_format,length:gi.schema_length},schema:{presence:!1,format:gi.schema_format,length:gi.schema_length},table:{presence:!0,format:gi.schema_format,length:gi.schema_length},attribute:{presence:!0,format:gi.schema_format,length:gi.schema_length},hash_attribute:{presence:!0,format:gi.schema_format,length:gi.schema_length}};function __(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(__,"makeAttributesStrings");function kJ(e){return e=__(e),rr.table.presence=!1,rr.attribute.presence=!1,rr.hash_attribute.presence=!1,d_.validateObject(e,rr)}a(kJ,"schema_object");function FJ(e){return e=__(e),rr.table.presence={message:u_},rr.attribute.presence=!1,rr.hash_attribute.presence=!1,d_.validateObject(e,rr)}a(FJ,"table_object");function GJ(e){return e=__(e),rr.table.presence={message:u_},rr.attribute.presence=!1,d_.validateObject(e,rr)}a(GJ,"create_table_object");function qJ(e){return e=__(e),rr.table.presence={message:u_},rr.attribute.presence={message:u_},rr.hash_attribute.presence=!1,d_.validateObject(e,rr)}a(qJ,"attribute_object");function $J(e){return e=__(e),rr.table.presence={message:u_},rr.attribute.presence=!1,rr.hash_attribute.presence=!1,d_.validateObject(e,rr)}a($J,"describe_table");function VJ(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(VJ,"validateTableResidence");ND.exports={schema_object:kJ,create_table_object:GJ,table_object:FJ,attribute_object:qJ,describe_table:$J,validateTableResidence:VJ}});var wD=N((IAe,ID)=>{"use strict";var KJ=require("uuid"),uA=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||KJ.v4(),this.schema_table=`${this.schema}.${this.table}`}};ID.exports=uA});var Lh=N((CAe,CD)=>{"use strict";var YJ=wD(),dA=class extends YJ{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}};CD.exports=dA});var DD=N((DAe,PD)=>{"use strict";PD.exports=jJ;var WJ="inserted";function jJ(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===WJ?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(jJ,"returnObject")});var Mh=N((UAe,vD)=>{"use strict";var zJ=M(),_A=ht(),QJ=sc(),{getSystemSchemaPath:JJ,getSchemaPath:XJ}=gt(),MAe=Ji(),ZJ=Dh(),e3=Lh(),t3=DD(),{handleHDBError:LD,hdb_errors:UD}=_e(),MD=re(),{HTTP_STATUS_CODES:r3}=UD,n3="inserted";vD.exports=s3;async function s3(e){let t=ZJ.attribute_object(e);if(t)throw LD(new Error,t.message,UD.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=!e.skip_table_check&&MD.checkGlobalSchemaTable(e.schema,e.table);if(r)throw LD(new Error,r,r3.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=MD.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 e3(e.schema,e.table,e.attribute,e.id);try{let i=await _A.openEnvironment(XJ(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}`);_A.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await _A.openEnvironment(JJ(),zJ.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await QJ.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_attribute_attributes,[s]);return t3(n3,c,{records:[s]},l)}catch(i){throw i}}a(s3,"lmdbCreateAttribute")});var EA=N((BAe,HD)=>{var{hdb_table:i3,hdb_database:BD}=Ti(),o3=Tt(),fA=require("joi"),a3={undefined:"undefined",null:"null"},c3=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||a3[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"),l3=fA.object({database:BD,schema:BD,table:i3,records:fA.array().items(fA.object().custom(c3)).required()});HD.exports=function(e){return o3.validateBySchema(e,l3)}});var f_=N((kAe,kD)=>{"use strict";var Xi=re(),xD=j(),xAe=EA(),{getDatabases:u3}=(De(),oe(lt)),{ClientError:ic}=_e();kD.exports=d3;function d3(e){if(Xi.isEmpty(e))throw new ic("invalid update parameters defined.");if(Xi.isEmptyOrZeroLength(e.schema))throw new ic("invalid schema specified.");if(Xi.isEmptyOrZeroLength(e.table))throw new ic("invalid table specified.");if(!Array.isArray(e.records))throw new ic("records must be an array");let t=u3()[e.schema]?.[e.table];if(Xi.isEmpty(t))throw new ic(`could not retrieve schema:${e.schema} and table ${e.table}`);let r=t.primaryKey,n=new Set,s={},i=!1;return e.operation==="update"&&(i=!0),e.records.forEach(o=>{if(i&&Xi.isEmptyOrZeroLength(o[r]))throw xD.error("a valid hash attribute must be provided with update record:",o),new ic("a valid hash attribute must be provided with update record, check log for more info");if(!Xi.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw xD.error(`a valid hash value must be provided with ${e.operation} record:`,o),new ic(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!Xi.isEmpty(o[r])&&o[r]!==""&&n.has(Xi.autoCast(o[r]))&&(o.skip=!0),n.add(Xi.autoCast(o[r]));for(let c in o)s[c]=1}),s[r]=1,{schema_table:t,hashes:Array.from(n),attributes:Object.keys(s)}}a(d3,"insertUpdateValidate")});var GD=N((GAe,FD)=>{"use strict";var hA=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};FD.exports=hA});var VD=N(($Ae,$D)=>{"use strict";var pA=ht(),_3=j(),qD=Pn().LMDB_ERRORS_ENUM;$D.exports=f3;async function f3(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 pA.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==qD.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await pA.closeEnvironment(global.lmdb_map[n]),await pA.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==qD.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){_3.error(t)}}a(f3,"cleanLMDBMap")});var Zi=N((KAe,jD)=>{"use strict";var E_=require("crypto"),E3=se(),{CONFIG_PARAMS:h3}=M(),YD="aes-256-cbc",p3=32,m3=16,mA=64,WD=32,S3=mA+WD,KD=new Map;jD.exports={encrypt:T3,decrypt:g3,createNatsTableStreamName:A3};function T3(e){let t=E_.randomBytes(p3),r=E_.randomBytes(m3),n=E_.createCipheriv(YD,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(T3,"encrypt");function g3(e){let t=e.substr(0,mA),r=e.substr(mA,WD),n=e.substr(S3,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=E_.createDecipheriv(YD,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(g3,"decrypt");function A3(e,t){let r=E3.get(h3.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=KD.get(r);return n||(n=E_.createHash("md5").update(r).digest("hex"),KD.set(r,n)),n}a(A3,"createNatsTableStreamName")});var eo=N((jAe,JD)=>{"use strict";var WAe=Vr(),h_=j(),zD=Dh(),R3=Zi(),Uh=re(),{handleHDBError:vh,hdb_errors:y3}=_e(),{HDB_ERROR_MSGS:Bh,HTTP_STATUS_CODES:SA}=y3,QD=se();QD.initSync();var{getDatabases:TA}=(De(),oe(lt)),b3=require("fs-extra"),O3=M();JD.exports={describeAll:N3,describeTable:Hh,describeSchema:I3};async function N3(e={}){try{let t=Uh.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=TA(),o={},c={},l=[],u=e?.exact_count;for(let _ in i){o[_]=!0,!t&&!s&&!r&&(c[_]=e.hdb_user?.role?.permission[_]?.describe);let E=i[_];for(let f in E)try{let h;if(t||s||r)h=await Hh({schema:_,table:f,exact_count:u});else if(n&&n[_].describe&&n[_].tables[f].describe){let T=n[_].tables[f].attribute_permissions;h=await Hh({schema:_,table:f,exact_count:u},T)}h&&l.push(h)}catch(h){h_.error(h)}}let d={};for(let _ in l)t||s||r?(d[l[_].schema]==null&&(d[l[_].schema]={}),d[l[_].schema][l[_].name]=l[_],o[l[_].schema]&&delete o[l[_].schema]):c[l[_].schema]&&(d[l[_].schema]==null&&(d[l[_].schema]={}),d[l[_].schema][l[_].name]=l[_],o[l[_].schema]&&delete o[l[_].schema]);for(let _ in o)t||s||r?d[_]={}:c[_]&&(d[_]={});return d}catch(t){return h_.error("Got an error in describeAll"),h_.error(t),vh(new Error,Bh.DESCRIBE_ALL_ERR)}}a(N3,"describeAll");async function Hh(e,t){Uh.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=zD.describe_table(e);if(i)throw i;let c=TA()[r];if(!c)throw vh(new Error,Bh.SCHEMA_NOT_FOUND(e.schema),SA.NOT_FOUND);let l=c[n];if(!l)throw vh(new Error,Bh.TABLE_NOT_FOUND(e.schema,e.table),SA.NOT_FOUND);function u(f){d.push({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(u,"pushAtt");let d=[];if(s){let f={};s.forEach(h=>{h.describe&&(f[h.attribute_name]=!0)}),l.attributes.forEach(h=>{f[h.name]&&u(h)})}else l.attributes?.forEach(f=>u(f));let _;try{_=(await b3.stat(l.primaryStore.env.path)).size}catch(f){h_.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:d,db_size:_};l.replicate!==void 0&&(E.replicate=l.replicate),l.expirationMS!==void 0&&(E.expiration=l.expirationMS/1e3+"s"),l.sealed!==void 0&&(E.sealed=l.sealed),l.sources?.length>0&&(E.sources=l.sources.map(f=>f.name).filter(f=>f&&f!=="NATSReplicator"&&f!=="Replicator")),QD.get(O3.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(E.clustering_stream_name=R3.createNatsTableStreamName(E.schema,E.name));try{let f=l.getRecordCount({exactCount:e.exact_count==="true"});E.record_count=f.recordCount,E.table_size=l.getSize(),E.db_audit_size=l.getAuditSize(),E.estimated_record_range=f.estimatedRange;let h=l.auditStore;if(h)for(let T of h.getKeys({reverse:!0,limit:1}))E.last_updated_record=T[0];if(!E.last_updated_record&&l.indices.__updatedtime__)for(let T of l.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))E.last_updated_record=T}catch(f){h_.warn(`unable to stat table dbi due to ${f}`)}return E}a(Hh,"descTable");async function I3(e){Uh.transformReq(e);let t=zD.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=TA()[n];if(!i)throw vh(new Error,Bh.SCHEMA_NOT_FOUND(e.schema),SA.NOT_FOUND);let o={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),Uh.isEmpty(l)||l.describe){let u=await Hh({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);u&&(o[u.name]=u)}}return o}a(I3,"describeSchema")});var Gs=N((XAe,rL)=>{var w3=Ji(),{callbackify:ZD,promisify:C3}=require("util"),{getDatabases:eL}=(De(),oe(lt));rL.exports={setSchemaDataToGlobal:XD,getTableSchema:P3,getSystemSchema:D3,setSchemaDataToGlobalAsync:C3(XD)};var tL=eo(),QAe=ZD(tL.describeAll),JAe=ZD(tL.describeTable);function XD(e){global.hdb_schema=eL(),e&&e()}a(XD,"setSchemaDataToGlobal");function P3(e,t,r){let n=eL()[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(P3,"getTableSchema");function D3(){return w3}a(D3,"getSystemSchema")});var un=N((eRe,oL)=>{"use strict";var kh=EA(),Cr=re(),L3=require("util"),Fh=Bn(),M3=Gs(),nL=j(),{handleHDBError:oc,hdb_errors:U3}=_e(),{HTTP_STATUS_CODES:ac}=U3,v3=L3.promisify(M3.getTableSchema),B3="updated",sL="inserted",iL="upserted";oL.exports={insert:x3,update:k3,upsert:F3,validation:H3,flush:G3};async function H3(e){if(Cr.isEmpty(e))throw new Error("invalid update parameters defined.");if(Cr.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if(Cr.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await v3(e.schema,e.table),r=kh(e);if(r)throw r;if(!Array.isArray(e.records))throw new Error("records must be an array");let n=t.hash_attribute,s=new Set,i={},o=!1;return e.operation==="update"&&(o=!0),e.records.forEach(c=>{if(o&&Cr.isEmptyOrZeroLength(c[n]))throw nL.error("a valid hash attribute must be provided with update record:",c),new Error("a valid hash attribute must be provided with update record");if(!Cr.isEmptyOrZeroLength(c[n])&&(c[n]==="null"||c[n]==="undefined"))throw nL.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[n]}" is not a valid hash attribute value`);!Cr.isEmpty(c[n])&&c[n]!==""&&s.has(Cr.autoCast(c[n]))&&(c.skip=!0),s.add(Cr.autoCast(c[n]));for(let l in c)i[l]=1}),i[n]=1,{schema_table:t,hashes:Array.from(s),attributes:Object.keys(i)}}a(H3,"validation");async function x3(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=kh(e);if(t)throw oc(new Error,t.message,ac.BAD_REQUEST);Cr.transformReq(e);let r=Cr.checkSchemaTableExist(e.schema,e.table);if(r)throw oc(new Error,r,ac.BAD_REQUEST);let n=await Fh.createRecords(e);return xh(sL,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(x3,"insertData");async function k3(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=kh(e);if(t)throw oc(new Error,t.message,ac.BAD_REQUEST);Cr.transformReq(e);let r=Cr.checkSchemaTableExist(e.schema,e.table);if(r)throw oc(new Error,r,ac.BAD_REQUEST);let n=await Fh.updateRecords(e);return Cr.isEmpty(n.existing_rows)?xh(B3,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):xh(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(k3,"updateData");async function F3(e){if(e.operation!=="upsert")throw oc(new Error,"invalid operation, must be upsert",ac.INTERNAL_SERVER_ERROR);let t=kh(e);if(t)throw oc(new Error,t.message,ac.BAD_REQUEST);Cr.transformReq(e);let r=Cr.checkSchemaTableExist(e.schema,e.table);if(r)throw oc(new Error,r,ac.BAD_REQUEST);let n=await Fh.upsertRecords(e);return xh(iL,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(F3,"upsertData");function xh(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===sL?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===iL?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(xh,"returnObject");function G3(e){return Cr.transformReq(e),Fh.flush(e.schema,e.table)}a(G3,"flush")});var AA=N((rRe,lL)=>{var q3=Tt(),gA=require("joi"),{hdb_table:$3,hdb_database:aL}=Ti(),cL={schema:aL,database:aL,table:$3},V3={date:gA.date().iso().required()},K3={timestamp:gA.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};lL.exports=function(e,t){let r=t==="timestamp"?{...cL,...K3}:{...cL,...V3},n=gA.object(r);return q3.validateBySchema(e,n)}});var _L=N((nRe,dL)=>{var Y3=Tt(),RA=require("joi"),{hdb_table:W3,hdb_database:uL}=Ti(),j3=RA.object({schema:uL,database:uL,table:W3,hash_values:RA.array().required(),ids:RA.array()});dL.exports=function(e){return Y3.validateBySchema(e,j3)}});var NA=N((sRe,fL)=>{"use strict";var yA=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}},bA=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}},OA=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};fL.exports={InsertObject:yA,NoSQLSeachObject:bA,DeleteResponseObject:OA}});var uc=N((oRe,SL)=>{"use strict";var hL=AA(),z3=_L(),cc=re(),EL=require("moment"),pL=j(),{promisify:Q3,callbackify:J3}=require("util"),lc=M(),X3=Gs(),IA=Q3(X3.getTableSchema),wA=Bn(),{DeleteResponseObject:Z3}=NA(),{handleHDBError:Wo,hdb_errors:eX}=_e(),{HDB_ERROR_MSGS:Gh,HTTP_STATUS_CODES:jo}=eX,tX="records successfully deleted",rX=J3(mL);SL.exports={delete:rX,deleteRecord:mL,deleteFilesBefore:nX,deleteAuditLogsBefore:sX};async function nX(e){let t=hL(e,"date");if(t)throw Wo(t,t.message,jo.BAD_REQUEST,void 0,void 0,!0);if(cc.transformReq(e),!EL(e.date,EL.ISO_8601).isValid())throw Wo(new Error,Gh.INVALID_DATE,jo.BAD_REQUEST,lc.LOG_LEVELS.ERROR,Gh.INVALID_DATE,!0);let n=cc.checkSchemaTableExist(e.schema,e.table);if(n)throw Wo(new Error,n,jo.NOT_FOUND,lc.LOG_LEVELS.ERROR,n,!0);let s=await wA.deleteRecordsBefore(e);if(await IA(e.schema,e.table),pL.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(nX,"deleteFilesBefore");async function sX(e){let t=hL(e,"timestamp");if(t)throw Wo(t,t.message,jo.BAD_REQUEST,void 0,void 0,!0);if(cc.transformReq(e),isNaN(e.timestamp))throw Wo(new Error,Gh.INVALID_VALUE("Timestamp"),jo.BAD_REQUEST,lc.LOG_LEVELS.ERROR,Gh.INVALID_VALUE("Timestamp"),!0);let r=cc.checkSchemaTableExist(e.schema,e.table);if(r)throw Wo(new Error,r,jo.NOT_FOUND,lc.LOG_LEVELS.ERROR,r,!0);let n=await wA.deleteAuditLogsBefore(e);return await IA(e.schema,e.table),pL.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(sX,"deleteAuditLogsBefore");async function mL(e){e.ids&&(e.hash_values=e.ids);let t=z3(e);if(t)throw Wo(t,t.message,jo.BAD_REQUEST,void 0,void 0,!0);cc.transformReq(e);let r=cc.checkSchemaTableExist(e.schema,e.table);if(r)throw Wo(new Error,r,jo.NOT_FOUND,lc.LOG_LEVELS.ERROR,r,!0);try{await IA(e.schema,e.table);let n=await wA.deleteRecords(e);return cc.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${tX}`),n}catch(n){if(n.message===lc.SEARCH_NOT_FOUND_MESSAGE){let s=new Z3;return s.message=lc.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(mL,"deleteRecord")});var qh=N((cRe,AL)=>{var iX=require("crypto"),TL=9;function oX(e){let t=cX(TL),r=gL(e+t);return t+r}a(oX,"createHash");function aX(e,t){let r=e?.substr(0,TL),n=r+gL(t+r);return e===n}a(aX,"validateHash");function cX(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(cX,"generateSalt");function gL(e){return iX.createHash("md5").update(e).digest("hex")}a(gL,"md5");AL.exports={hash:oX,validate:aX}});var yL=N((uRe,RL)=>{var CA=Tt(),Kr={username:{presence:!0,exclusion:{within:["system"],message:"You cannot create tables within the system schema"}},password:{presence:!0},role:{presence:!0,format:"[\\w\\-\\_]+"},active:{presence:!0,inclusion:{within:[!0,!1],message:"must be a boolean"}}};function lX(e){return Kr.password.presence=!0,Kr.username.presence=!0,Kr.role.presence=!0,Kr.active.presence=!0,CA.validateObject(e,Kr)}a(lX,"addUserValidation");function uX(e){return Kr.password.presence=!1,Kr.username.presence=!0,Kr.role.presence=!1,Kr.active.presence=!1,CA.validateObject(e,Kr)}a(uX,"alterUserValidation");function dX(e){return Kr.password.presence=!1,Kr.username.presence=!0,Kr.role.presence=!1,Kr.active.presence=!1,CA.validateObject(e,Kr)}a(dX,"dropUserValidation");RL.exports={addUserValidation:lX,alterUserValidation:uX,dropUserValidation:dX}});var Ct=N((fRe,OL)=>{"use strict";var{platform:_Re}=require("os"),_X="nats-server.zip",PA="nats-server",fX=process.platform==="win32"?`${PA}.exe`:PA,EX=/^[^\s.,*>]+$/,bL="__request__",hX=a(e=>`${e}.${bL}`,"REQUEST_SUBJECT"),pX={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},mX={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},SX={HUB:"hub.pid",LEAF:"leaf.pid"},TX={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},gX={SUCCESS:"success",ERROR:"error"},AX={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},RX={TXN:"txn",MSGID:"msgid"},Bl={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},yX={[Bl.ERR]:1,[Bl.WRN]:2,[Bl.INF]:3,[Bl.DBG]:4,[Bl.TRC]:5},bX={debug:"-D",trace:"-DVV"};OL.exports={NATS_SERVER_ZIP:_X,NATS_SERVER_NAME:PA,NATS_BINARY_NAME:fX,PID_FILES:SX,NATS_CONFIG_FILES:mX,SERVER_SUFFIX:TX,NATS_TERM_CONSTRAINTS_RX:EX,REQUEST_SUFFIX:bL,UPDATE_REMOTE_RESPONSE_STATUSES:gX,CLUSTER_STATUS_STATUSES:AX,REQUEST_SUBJECT:hX,SUBJECT_PREFIXES:RX,MSG_HEADERS:pX,LOG_LEVELS:Bl,LOG_LEVEL_FLAGS:bX,LOG_LEVEL_HIERARCHY:yX}});var IL=N((hRe,NL)=>{"use strict";var $h=M(),Vh=class{static{a(this,"BaseLicense")}constructor(t=0,r=$h.RAM_ALLOCATION_ENUM.DEFAULT,n=$h.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},DA=class extends Vh{static{a(this,"ExtendedLicense")}constructor(t=0,r=$h.RAM_ALLOCATION_ENUM.DEFAULT,n=$h.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};NL.exports={BaseLicense:Vh,ExtendedLicense:DA}});var dc=N((mRe,UL)=>{"use strict";var xl=require("fs-extra"),CL=qh(),PL=require("crypto"),OX=require("moment"),NX=require("uuid").v4,Yr=j(),MA=require("path"),IX=re(),zo=M(),{totalmem:wL}=require("os"),wX=IL().ExtendedLicense,Hl="invalid license key format",CX="061183",PX="mofi25",DX="aes-256-cbc",LX=16,MX=32,DL=se(),{resolvePath:LL}=wt();DL.initSync();var LA;UL.exports={validateLicense:ML,generateFingerPrint:vX,licenseSearch:BA,getLicense:xX,checkMemoryLimit:kX};function UA(){return MA.join(DL.getHdbBasePath(),zo.LICENSE_KEY_DIR_NAME,zo.LICENSE_FILE_NAME)}a(UA,"getLicenseDirPath");function UX(){let e=UA();return LL(MA.join(e,zo.LICENSE_FILE_NAME))}a(UX,"getLicenseFilePath");function vA(){let e=UA();return LL(MA.join(e,zo.REG_KEY_FILE_NAME))}a(vA,"getFingerPrintFilePath");async function vX(){let e=vA();try{return await xl.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await BX();throw Yr.error(`Error writing fingerprint file to ${e}`),Yr.error(t),new Error("There was an error generating the fingerprint")}}a(vX,"generateFingerPrint");async function BX(){let e=NX(),t=CL.hash(e),r=vA();try{await xl.mkdirp(UA()),await xl.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw Yr.error(`Error writing fingerprint file to ${r}`),Yr.error(n),new Error("There was an error generating the fingerprint")}return t}a(BX,"writeFingerprint");function ML(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:zo.RAM_ALLOCATION_ENUM.DEFAULT,version:zo.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return Yr.error("empty license key passed to validate."),r;let n=vA(),s=!1;try{s=xl.statSync(n)}catch(i){Yr.error(i)}if(s){let i;try{i=xl.readFileSync(n,"utf8")}catch{Yr.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(PX),c=o[1];c=Buffer.concat([Buffer.from(c)],LX);let l=Buffer.concat([Buffer.from(i)],MX),u=PL.createDecipheriv(DX,l,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let d=null;try{d=u.update(o[0],"hex","utf8"),d.trim(),d+=u.final("utf8")}catch{let f=HX(o[0],i);if(f)d=f;else throw r.valid_license=!1,r.valid_machine=!1,console.error(Hl),Yr.error(Hl),new Error(Hl)}let _;if(isNaN(d))try{_=JSON.parse(d),r.version=_.version,r.exp_date=_.exp_date,isNaN(r.exp_date)&&(r.exp_date=new Date(r.exp_date).getTime()),_.ram_allocation&&(r.ram_allocation=_.ram_allocation)}catch{throw console.error(Hl),Yr.error(Hl),new Error(Hl)}else r.exp_date=d;r.exp_date<OX().valueOf()&&(r.valid_date=!1),CL.validate(o[1],`${CX}${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||Yr.error("Invalid licence"),r}a(ML,"validateLicense");function HX(e,t){try{let r=PL.createDecipher("aes192",t),n=r.update(e,"hex","utf8");return n.trim(),n+=r.final("utf8"),n}catch{Yr.warn("Check old license failed")}}a(HX,"checkOldLicense");function BA(){let e=new wX,t=[];try{t=xl.readFileSync(UX(),"utf-8").split(zo.NEW_LINE)}catch(r){r.code==="ENOENT"?Yr.debug("no license file found"):Yr.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if(IX.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=ML(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){Yr.error("There was an error parsing the license string."),Yr.error(s),e.ram_allocation=zo.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return LA=e,e}a(BA,"licenseSearch");async function xX(){return LA||await BA(),LA}a(xX,"getLicense");function kX(){let e=BA().ram_allocation,t=process.constrainedMemory?.()||wL();if(t=Math.round(Math.min(t,wL())/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(kX,"checkMemoryLimit")});var xn=N((RRe,QL)=>{"use strict";var xL="username is required",kL="nothing to update, must supply active, role or password to update",FL="password cannot be an empty string",GL="If role is specified, it cannot be empty.",qL="active must be true or false";QL.exports={addUser:jX,alterUser:zX,dropUser:JX,getSuperUser:tZ,userInfo:XX,listUsers:Yh,listUsersExternal:ZX,setUsersToGlobal:Fl,findAndValidateUser:jL,getClusterUser:rZ,USERNAME_REQUIRED:xL,ALTERUSER_NOTHING_TO_UPDATE:kL,EMPTY_PASSWORD:FL,EMPTY_ROLE:GL,ACTIVE_BOOLEAN:qL};var $L=un(),FX=uc(),kA=qh(),VL=yL(),KL=Vr(),FA=to(),Hn=re(),YL=require("validate.js"),Ke=j(),{promisify:GX}=require("util"),GA=Zi(),vL=M(),BL=Ct(),qX=wt(),TRe=se(),gRe=dc(),$X=Ji(),{table:ARe}=(De(),oe(lt)),{handleHDBError:Ai,hdb_errors:VX}=_e(),{HTTP_STATUS_CODES:Ri,AUTHENTICATION_ERROR_MSGS:HA,HDB_ERROR_MSGS:kl}=VX,{UserEventMsg:qA}=qs(),xA=require("lodash"),{server:$A}=(qr(),oe(Qa)),KX=j();$A.getUser=(e,t)=>jL(e,t,t!=null);var WL={username:!0,active:!0,role:!0,password:!0},HL=new Map,Kh=KL.searchByValue,YX=KL.searchByHash,WX=GX(FX.delete);async function jX(e){let t=YL.cleanAttributes(e,WL),r=VL.addUserValidation(t);if(r)throw Ai(new Error,r.message,Ri.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 Kh(n),s=s&&Array.from(s)}catch(l){throw Ke.error("There was an error searching for a role in add user"),Ke.error(l),l}if(!s||s.length<1)throw Ai(new Error,kl.ROLE_NAME_NOT_FOUND(t.role),Ri.NOT_FOUND,void 0,void 0,!0);if(s.length>1)throw Ai(new Error,kl.DUP_ROLES_FOUND(t.role),Ri.CONFLICT,void 0,void 0,!0);s[0].permission.cluster_user===!0&&(t.hash=GA.encrypt(t.password)),t.password=kA.hash(t.password),t.role=s[0].id;let i={operation:"insert",schema:"system",table:"hdb_user",records:[t]},o;try{o=await $L.insert(i)}catch(l){throw Ke.error("There was an error searching for a user."),Ke.error(l),l}Ke.debug(o);try{await Fl()}catch(l){throw Ke.error("Got an error setting users to global"),Ke.error(l),l}if(o.skipped_hashes.length===1)throw Ai(new Error,kl.USER_ALREADY_EXISTS(t.username),Ri.CONFLICT,void 0,void 0,!0);let c={...t};return c.role=s[0],FA.signalUserChange(new qA(process.pid)),`${c.username} successfully added`}a(jX,"addUser");async function zX(e){let t=YL.cleanAttributes(e,WL);if(Hn.isEmptyOrZeroLength(t.username))throw new Error(xL);if(Hn.isEmptyOrZeroLength(t.password)&&Hn.isEmptyOrZeroLength(t.role)&&Hn.isEmptyOrZeroLength(t.active))throw new Error(kL);if(!Hn.isEmpty(t.password)&&Hn.isEmptyOrZeroLength(t.password.trim()))throw new Error(FL);if(!Hn.isEmpty(t.active)&&!Hn.isBoolean(t.active))throw new Error(qL);let r=QX(t.username);if(!Hn.isEmpty(t.password)&&!Hn.isEmptyOrZeroLength(t.password.trim())&&(r&&(t.hash=GA.encrypt(t.password)),t.password=kA.hash(t.password)),t.role==="")throw new Error(GL);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 Kh(i)||[])}catch(c){throw Ke.error("Got an error searching for a role."),Ke.error(c),c}if(!o||o.length===0){let c=kl.ALTER_USER_ROLE_NOT_FOUND(t.role);throw Ke.error(c),Ai(new Error,c,Ri.NOT_FOUND,void 0,void 0,!0)}if(o.length>1){let c=kl.ALTER_USER_DUP_ROLES(t.role);throw Ke.error(c),Ai(new Error,c,Ri.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 $L.update(n)}catch(i){throw Ke.error("Error during update."),Ke.error(i),i}try{await Fl()}catch(i){throw Ke.error("Got an error setting users to global"),Ke.error(i),i}return FA.signalUserChange(new qA(process.pid)),s}a(zX,"alterUser");function QX(e){let t=!1,r=global.hdb_users.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(QX,"isClusterUser");async function JX(e){try{let t=VL.dropUserValidation(e);if(t)throw new Error(t);let r={table:"hdb_user",schema:"system",hash_values:[e.username]};if(Hn.isEmpty(global.hdb_users.get(e.username)))throw Ai(new Error,kl.USER_NOT_EXIST(e.username),Ri.NOT_FOUND,void 0,void 0,!0);let n;try{n=await WX(r)}catch(s){throw Ke.error("Got an error deleting a user."),Ke.error(s),s}Ke.debug(n);try{await Fl()}catch(s){throw Ke.error("Got an error setting users to global."),Ke.error(s),s}return FA.signalUserChange(new qA(process.pid)),`${e.username} successfully deleted`}catch(t){throw t}}a(JX,"dropUser");async function XX(e){let t={};try{if(!e||!e.hdb_user)return"There was no user info in the body";t=xA.cloneDeep(e.hdb_user);let r={schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]},n;try{n=await YX(r)}catch(s){throw Ke.error("Got an error searching for a role."),Ke.error(s),s}t.role=n[0],delete t.password,delete t.refresh_token,delete t.hash}catch(r){throw Ke.error(r),r}return t}a(XX,"userInfo");async function ZX(){let e;try{e=await Yh()}catch(t){throw Ke.error("Got an error listing users."),Ke.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(ZX,"listUsersExternal");async function Yh(){try{let e={schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]},t;try{t=await Kh(e)}catch(o){throw Ke.error("Got an error searching for roles."),Ke.error(o),o}let r={};for(let o of t)r[o.id]=xA.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 Kh(n)}catch(o){throw Ke.error("Got an error searching for users."),Ke.error(o),o}let i=new Map;for(let o of s)o=xA.cloneDeep(o),o.role=r[o.role],eZ(o.role),i.set(o.username,o);return i}catch(e){throw Ke.error("got an error listing users"),Ke.error(e),Hn.errorizeMessage(e)}return null}a(Yh,"listUsers");function eZ(e){try{if(!e){Ke.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($X)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}catch(t){Ke.error("Got an error trying to set system permissions."),Ke.error(t)}}a(eZ,"appendSystemTablesToRole");async function Fl(){try{let e=await Yh();global.hdb_users=e}catch(e){throw Ke.error(e),e}}a(Fl,"setUsersToGlobal");async function jL(e,t,r=!0){global.hdb_users||await Fl();let n=global.hdb_users.get(e);if(!n){if(!r)return{username:e};throw Ai(new Error,HA.GENERIC_AUTH_FAIL,Ri.UNAUTHORIZED,void 0,void 0,!0)}if(n&&!n.active)throw Ai(new Error,HA.USER_INACTIVE,Ri.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(HL.get(t)===n.password)return s;if(kA.validate(n.password,t))HL.set(t,n.password);else throw Ai(new Error,HA.GENERIC_AUTH_FAIL,Ri.UNAUTHORIZED,void 0,void 0,!0)}return s}a(jL,"findAndValidateUser");async function tZ(){global.hdb_users||await Fl();for(let[,e]of global.hdb_users)if(e.role.role==="super_user")return e}a(tZ,"getSuperUser");async function rZ(){let e=await Yh(),t=qX.getConfigFromFile(vL.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!Hn.isEmpty(r)&&r?.role?.role===vL.ROLE_TYPES_ENUM.CLUSTER_USER)return r.decrypt_hash=GA.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+BL.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+BL.SERVER_SUFFIX.ADMIN,r}a(rZ,"getClusterUser");var zL=[];$A.invalidateUser=function(e){for(let t of zL)try{t(e)}catch(r){KX.error("Error invalidating user",r)}};$A.onInvalidatedUser=function(e){zL.push(e)}});var m_=N((NRe,eM)=>{"use strict";var _c=j(),kn=M(),nZ=VD(),bRe=Gs(),ORe=eo(),sZ=xn(),{validateEvent:JL}=qs(),p_=Bn(),iZ=require("process"),{resetDatabases:oZ}=(De(),oe(lt)),aZ={[kn.ITC_EVENT_TYPES.SCHEMA]:cZ,[kn.ITC_EVENT_TYPES.USER]:ZL};async function cZ(e){let t=JL(e);if(t){_c.error(t);return}_c.trace("ITC schemaHandler received schema event:",e),await nZ(e.message),await lZ(e.message)}a(cZ,"schemaHandler");async function lZ(e){try{p_.resetReadTxn(kn.SYSTEM_SCHEMA_NAME,kn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),p_.resetReadTxn(kn.SYSTEM_SCHEMA_NAME,kn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),p_.resetReadTxn(kn.SYSTEM_SCHEMA_NAME,kn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=oZ();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){_c.error(t)}}a(lZ,"syncSchemaMetadata");var XL=[];async function ZL(e){try{try{p_.resetReadTxn(kn.SYSTEM_SCHEMA_NAME,kn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),p_.resetReadTxn(kn.SYSTEM_SCHEMA_NAME,kn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){_c.warn(r)}let t=JL(e);if(t){_c.error(t);return}_c.trace(`ITC userHandler ${kn.HDB_ITC_CLIENT_PREFIX}${iZ.pid} received user event:`,e),await sZ.setUsersToGlobal();for(let r of XL)r()}catch(t){_c.error(t)}}a(ZL,"userHandler");ZL.addListener=function(e){XL.push(e)};eM.exports=aZ});var qs=N((LRe,rM)=>{"use strict";var wRe=j(),VA=re(),uZ=M(),{ITC_ERRORS:S_}=Pn(),{parentPort:CRe,threadId:dZ,isMainThread:_Z,workerData:PRe}=require("worker_threads"),{onMessageFromWorkers:fZ,broadcast:DRe,broadcastWithAcknowledgement:EZ}=dt();rM.exports={sendItcEvent:hZ,validateEvent:tM,SchemaEventMsg:pZ,UserEventMsg:mZ};var Wh;fZ(async(e,t)=>{Wh=Wh||m_(),tM(e),Wh[e.type]&&await Wh[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function hZ(e){return!_Z&&e.message&&(e.message.originator=dZ),EZ(e)}a(hZ,"sendItcEvent");function tM(e){if(typeof e!="object")return S_.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||VA.isEmpty(e.type))return S_.MISSING_TYPE;if(!e.hasOwnProperty("message")||VA.isEmpty(e.message))return S_.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||VA.isEmpty(e.message.originator))return S_.MISSING_ORIGIN;if(uZ.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return S_.INVALID_EVENT(e.type)}a(tM,"validateEvent");function pZ(e,t,r,n=void 0,s=void 0){this.originator=e,this.operation=t,this.schema=r,this.table=n,this.attribute=s}a(pZ,"SchemaEventMsg");function mZ(e){this.originator=e}a(mZ,"UserEventMsg")});var to=N((vRe,oM)=>{"use strict";var nM=M(),URe=re(),jh=j(),sM=GD(),Gl,{sendItcEvent:iM}=qs();function SZ(e){try{jh.info("signalSchemaChange called with message:",e),Gl=Gl||m_();let t=new sM(nM.ITC_EVENT_TYPES.SCHEMA,e);return Gl.schema(t),iM(t)}catch(t){jh.error(t)}}a(SZ,"signalSchemaChange");function TZ(e){try{jh.trace("signalUserChange called with message:",e),Gl=Gl||m_();let t=new sM(nM.ITC_EVENT_TYPES.USER,e);return Gl.user(t),iM(t)}catch(t){jh.error(t)}}a(TZ,"signalUserChange");oM.exports={signalSchemaChange:SZ,signalUserChange:TZ}});var zh=N((HRe,cM)=>{"use strict";var aM=re(),gZ=M(),AZ=j(),RZ=Mh(),yZ=Lh(),bZ=to(),{SchemaEventMsg:OZ}=qs(),NZ="already exists in";cM.exports=IZ;async function IZ(e,t,r){if(aM.isEmptyOrZeroLength(r))return r;let n=[];aM.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 wZ(e,t.schema,t.name,i)})),s}a(IZ,"lmdbCheckForNewAttributes");async function wZ(e,t,r,n){let s=new yZ(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await CZ(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(NZ))AZ.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(wZ,"createNewAttribute");async function CZ(e){let t;return t=await RZ(e),bZ.signalSchemaChange(new OZ(process.pid,gZ.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(CZ,"createAttribute")});var ql=N((kRe,lM)=>{"use strict";var KA=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}};lM.exports=KA});var dM=N((GRe,uM)=>{"use strict";var PZ=ql(),DZ=M().OPERATIONS_ENUM,YA=class extends PZ{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(DZ.INSERT,r,n,s,i),this.records=t}};uM.exports=YA});var fM=N(($Re,_M)=>{"use strict";var LZ=ql(),MZ=M().OPERATIONS_ENUM,WA=class extends LZ{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(MZ.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};_M.exports=WA});var hM=N((KRe,EM)=>{"use strict";var UZ=ql(),vZ=M().OPERATIONS_ENUM,jA=class extends UZ{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(vZ.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};EM.exports=jA});var mM=N((WRe,pM)=>{"use strict";var BZ=ql(),HZ=M().OPERATIONS_ENUM,zA=class extends BZ{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(HZ.DELETE,n,s,t,i),this.original_records=r}};pM.exports=zA});var T_=N((QRe,AM)=>{"use strict";var zRe=require("path"),SM=ht(),xZ=dM(),kZ=fM(),FZ=hM(),GZ=mM(),$l=Ht(),TM=re(),{CONFIG_PARAMS:qZ}=M(),gM=se();gM.initSync();var Qh=M().OPERATIONS_ENUM,{getTransactionAuditStorePath:$Z}=gt();AM.exports=VZ;async function VZ(e,t){if(gM.get(qZ.LOGGING_AUDITLOG)===!1)return;let r=$Z(e.schema,e.table),n=await SM.openEnvironment(r,e.table,!0),s=KZ(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){SM.initializeDBIs(n,$l.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,$l.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[$l.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[$l.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),TM.isEmpty(s.user_name)||n.dbis[$l.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[$l.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(VZ,"writeTransaction");function KZ(e,t){let r=TM.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===Qh.INSERT)return new xZ(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Qh.UPDATE)return new kZ(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Qh.UPSERT)return new FZ(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Qh.DELETE)return new GZ(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(KZ,"createTransactionObject")});var QA=N((ZRe,RM)=>{"use strict";var YZ=f_(),XRe=Qd(),g_=M(),WZ=Jd(),jZ=sc().insertRecords,zZ=ht(),QZ=j(),JZ=zh(),{getSchemaPath:XZ}=gt(),ZZ=T_();RM.exports=e5;async function e5(e){try{let{schema_table:t,attributes:r}=YZ(e);WZ(e,r,t.hash_attribute),e.schema!==g_.SYSTEM_SCHEMA_NAME&&(r.includes(g_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(g_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(g_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(g_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await JZ(e.hdb_auth_header,t,r),s=XZ(e.schema,e.table),i=await zZ.openEnvironment(s,e.table),o=await jZ(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await ZZ(e,o)}catch(c){QZ.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(e5,"lmdbCreateRecords")});var OM=N((tye,bM)=>{"use strict";var yM=M(),t5=QA(),r5=Qd(),n5=require("fs-extra"),{getSchemaPath:s5}=gt();bM.exports=i5;async function i5(e){let t=[{name:e.schema,createddate:Date.now()}],r=new r5(yM.SYSTEM_SCHEMA_NAME,yM.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await t5(r),await n5.mkdirp(s5(e.schema))}a(i5,"lmdbCreateSchema")});var IM=N((nye,NM)=>{"use strict";var JA=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}};NM.exports=JA});var DM=N((cye,PM)=>{"use strict";var wM=ht(),XA=cn(),ZA=Pn().LMDB_ERRORS_ENUM,o5=Ht(),CM=j(),iye=re(),a5=require("lmdb"),c5=IM(),l5=M(),{OVERFLOW_MARKER:oye,MAX_SEARCH_KEY_LENGTH:aye}=o5,u5=l5.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function d5(e,t,r,n){if(XA.validateEnv(e),t===void 0)throw new Error(ZA.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(ZA.IDS_REQUIRED):new Error(ZA.IDS_MUST_BE_ITERABLE);try{let s=wM.listDBIs(e);wM.initializeDBIs(e,t,s);let i=new c5,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[u5]>n){i.skipped.push(o);continue}let T=e.dbis[t].ifVersion(o,a5.IF_EXISTS,()=>{e.dbis[t].remove(o);for(let m=0;m<s.length;m++){let g=s[m];if(!h.hasOwnProperty(g)||g===t)continue;let S=e.dbis[g],y=h[g];if(y!=null)try{let I=XA.getIndexedValues(y);if(I)for(let U=0,H=I.length;U<H;U++)S.remove(I[U],o)}catch{CM.warn(`cannot delete from attribute: ${g}, ${y}:${o}`)}}});c.push(T),l.push(o),i.original_records.push(h)}catch(h){CM.warn(h),i.skipped.push(o)}let u=[],d=await Promise.all(c);for(let E=0,f=d.length;E<f;E++)d[E]===!0?i.deleted.push(l[E]):(i.skipped.push(l[E]),u.push(E));let _=0;for(let E=0;E<u.length;E++){let f=u[E];i.original_records.splice(f-_,1),_++}return i.txn_time=XA.getNextMonotonicTime(),i}catch(s){throw s}}a(d5,"deleteRecords");PM.exports={deleteRecords:d5}});var A_=N((uye,MM)=>{"use strict";var Vl=re(),_5=DM(),f5=ht(),{getSchemaPath:E5}=gt(),h5=T_(),p5=j();MM.exports=m5;async function m5(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(Vl.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(Vl.isEmptyOrZeroLength(e.hash_values)&&!Vl.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];Vl.isEmpty(l)||e.hash_values.push(l)}}if(Vl.isEmptyOrZeroLength(e.hash_values))return LM([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(Vl.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=E5(e.schema,e.table),i=await f5.openEnvironment(s,e.table),o=await _5.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await h5(e,o)}catch(c){p5.error(`unable to write transaction due to ${c.message}`)}return LM(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(m5,"lmdbDeleteRecords");function LM(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(LM,"createDeleteResponse")});var tR=N((fye,UM)=>{"use strict";var S5=M(),_ye=cn();function eR(e,t){let r=Object.create(null);if(t.length===1&&S5.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(eR,"parseRow");function T5(e,t,r,n){let s=eR(r,e);n.push(s)}a(T5,"searchAll");function g5(e,t,r,n){let s=eR(r,e);n[t]=s}a(g5,"searchAllToMap");function A5(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(A5,"iterateDBI");function fc(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(fc,"pushResults");function R5(e,t,r,n,s,i){t.toString().endsWith(e)&&fc(t,r,n,s,i)}a(R5,"endsWith");function y5(e,t,r,n,s,i){t.toString().includes(e)&&fc(t,r,n,s,i)}a(y5,"contains");function b5(e,t,r,n,s,i){t>e&&fc(t,r,n,s,i)}a(b5,"greaterThanCompare");function O5(e,t,r,n,s,i){t>=e&&fc(t,r,n,s,i)}a(O5,"greaterThanEqualCompare");function N5(e,t,r,n,s,i){t<e&&fc(t,r,n,s,i)}a(N5,"lessThanCompare");function I5(e,t,r,n,s,i){t<=e&&fc(t,r,n,s,i)}a(I5,"lessThanEqualCompare");UM.exports={parseRow:eR,searchAll:T5,searchAllToMap:g5,iterateDBI:A5,endsWith:R5,contains:y5,greaterThanCompare:b5,greaterThanEqualCompare:O5,lessThanCompare:N5,lessThanEqualCompare:I5,pushResults:fc}});var Kl=N((Sye,GM)=>{"use strict";var Qo=ht(),hye=j(),Fn=cn(),Jh=Ht(),zt=Pn().LMDB_ERRORS_ENUM,pye=re(),w5=M(),Xh=tR(),{parseRow:C5}=Xh,mye=require("lmdb"),{OVERFLOW_MARKER:vM,MAX_SEARCH_KEY_LENGTH:P5}=Jh;function BM(e,t,r,n=!1,s=void 0,i=void 0){return Ec(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(BM,"iterateFullIndex");function R_(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,u=!1){return Ec(e,t,r,(d,_,E,f)=>{let S={transaction:d,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!l:!u,exclusiveStart:i===!0?u:l};return f===r?(S.values=!1,_.getRange(S).map(y=>({value:y}))):_.getRange(S)})}a(R_,"iterateRangeBetween");function Ec(e,t,r,n){let s=e.database||e,i=Qo.openDBI(s,r);i[Jh.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&Qo.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(Ec,"setupTransaction");function HM(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(vM)){if(!s)if(r)s=Qo.openDBI(e,r);else{let l=Qo.listDBIs(e);for(let u=0,d=l.length;u<d&&(s=Qo.openDBI(e,l[u]),!s[Jh.DBI_DEFINITION_NAME].is_hash_attribute);u++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(HM,"getOverflowCheck");function D5(e,t,r,n=!1,s=void 0,i=void 0){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);return Ec(e,t,t,(o,c,l)=>(Zh(r),r=y_(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(u=>C5(u.value,r))))}a(D5,"searchAll");function L5(e,t,r,n=!1,s=void 0,i=void 0){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);Zh(r),r=y_(e.database||e,r);let o=new Map;for(let{key:c,value:l}of BM(e,t,t,n,s,i))o.set(c,Xh.parseRow(l,r));return o}a(L5,"searchAllToMap");function M5(e,t,r=!1,n=void 0,s=void 0){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=BM(e,void 0,t,r,n,s),c=o.transaction,l=HM(c.database,c,void 0,t);for(let{key:u,value:d}of o){let _=l(u,d);i[_]===void 0&&(i[_]=[]),i[_].push(d)}return i}a(M5,"iterateDBI");function U5(e,t){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);return Qo.statDBI(e,t).entryCount}a(U5,"countAll");function v5(e,t,r,n,s=!1,i=void 0,o=void 0){return Jo(e,r,n),Ec(e,t,r,(c,l,u,d)=>(n=Fn.convertKeyValueToWrite(n),d===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(_=>({key:n,value:_}))))}a(v5,"equals");function B5(e,t,r){return Jo(e,t,r),Qo.openDBI(e,t).getValuesCount(r)}a(B5,"count");function H5(e,t,r,n,s=!1,i=void 0,o=void 0){return Jo(e,r,n),Ec(e,null,r,(c,l)=>{n=Fn.convertKeyValueToWrite(n);let u=!0;typeof n=="number"&&(u=!1);let d;if(s===!0){let _;for(let E of l.getKeys({transaction:c,start:n}))if(!E.startsWith(n)){_=E;break}return _!==void 0&&(Number.isInteger(o)?o++:i++),d=l.getRange({transaction:c,start:_,end:void 0,reverse:s,limit:i,offset:o}).map(E=>{let{key:f}=E;if(f!==_){if(f.toString().startsWith(n))return E;if(u===!0)return d.DONE}}),d.filter(E=>E)}else return d=l.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(_=>{if(_.key.toString().startsWith(n))return _;if(u===!0)return d.DONE}),u?d:d.filter(_=>_)})}a(H5,"startsWith");function x5(e,t,r,n,s=!1,i=void 0,o=void 0){return xM(e,t,r,n,s,i,o,!0)}a(x5,"endsWith");function xM(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return Jo(e,r,n),Ec(e,null,r,(l,u,d,_)=>{let E=HM(d,l,_,r);return o=Number.isInteger(o)?o:0,u.getKeys({transaction:l,end:s?!1:void 0,reverse:s}).flatMap(f=>{let h=f.toString();return h.endsWith(vM)?u.getValues(f,{transaction:l}).map(T=>{let m=E(f,T);if(c?m.endsWith(n):m.includes(n))return{key:m,value:T}}).filter(T=>T):(c?h.endsWith(n):h.includes(n))?u[Jh.DBI_DEFINITION_NAME].is_hash_attribute?{key:f,value:f}:u.getValues(f,{transaction:l}).map(T=>({key:f,value:T})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a(xM,"contains");function k5(e,t,r,n,s=!1,i=void 0,o=void 0){Jo(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),R_(e,t,r,n,l,s,i,o,!0,!1)}a(k5,"greaterThan");function F5(e,t,r,n,s=!1,i=void 0,o=void 0){Jo(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),R_(e,t,r,n,l,s,i,o,!1,!1)}a(F5,"greaterThanEqual");function G5(e,t,r,n,s=!1,i=void 0,o=void 0){Jo(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),R_(e,t,r,l,n,s,i,o,!1,!0)}a(G5,"lessThan");function q5(e,t,r,n,s=!1,i=void 0,o=void 0){Jo(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),R_(e,t,r,l,n,s,i,o,!1,!1)}a(q5,"lessThanEqual");function $5(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(Fn.validateEnv(e),r===void 0)throw new Error(zt.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(zt.START_VALUE_REQUIRED);if(s===void 0)throw new Error(zt.END_VALUE_REQUIRED);if(n=Fn.convertKeyValueToWrite(n),s=Fn.convertKeyValueToWrite(s),n>s)throw new Error(zt.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return R_(e,t,r,n,s,i,o,c)}a($5,"between");function V5(e,t,r,n){Fn.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);if(Zh(r),r=y_(s,r),n===void 0)throw new Error(zt.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=Xh.parseRow(c,r)),o}a(V5,"searchByHash");function K5(e,t,r){Fn.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(zt.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(K5,"checkHashExists");function Y5(e,t,r,n,s=[]){return FM(e,t,r,n,s),kM(e,t,r,n,s).map(i=>i[1])}a(Y5,"batchSearchByHash");function W5(e,t,r,n,s=[]){FM(e,t,r,n,s);let i=new Map;for(let[o,c]of kM(e,t,r,n,s))i.set(o,c);return i}a(W5,"batchSearchByHashToMap");function kM(e,t,r,n,s=[]){return Ec(e,t,t,(i,o,c)=>{r=y_(c,r);let l=r.length<3;return n.map(u=>{let d=c.dbis[t].get(u,{transaction:i,lazy:l});if(d)return[u,Xh.parseRow(d,r)];s.push(u)}).filter(u=>u)})}a(kM,"batchHashSearch");function FM(e,t,r,n,s){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);if(Zh(r),n==null)throw new Error(zt.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(zt.IDS_MUST_BE_ITERABLE)}a(FM,"initializeBatchSearchByHash");function Zh(e){if(!Array.isArray(e))throw e===void 0?new Error(zt.FETCH_ATTRIBUTES_REQUIRED):new Error(zt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(Zh,"validateFetchAttributes");function Jo(e,t,r){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(zt.SEARCH_VALUE_REQUIRED);if(r?.length>P5)throw new Error(zt.SEARCH_VALUE_TOO_LARGE)}a(Jo,"validateComparisonFunctions");function y_(e,t){return t.length===1&&w5.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=Qo.listDBIs(e)),t}a(y_,"setGetWholeRowAttributes");GM.exports={searchAll:D5,searchAllToMap:L5,count:B5,countAll:U5,equals:v5,startsWith:H5,endsWith:x5,contains:xM,searchByHash:V5,setGetWholeRowAttributes:y_,batchSearchByHash:Y5,batchSearchByHashToMap:W5,checkHashExists:K5,iterateDBI:M5,greaterThan:k5,greaterThanEqual:F5,lessThan:G5,lessThanEqual:q5,between:$5}});var Yl=N((gye,YM)=>{var qM=require("lodash"),$M=Tt(),xe=require("joi"),j5=re(),{hdb_schema_table:b_,checkValidTable:VM,hdb_table:KM,hdb_database:ep}=Ti(),{handleHDBError:z5,hdb_errors:Q5}=_e(),{getDatabases:J5}=(De(),oe(lt)),{HTTP_STATUS_CODES:X5}=Q5,Z5=xe.object({database:ep,schema:ep,table:KM,search_attribute:b_,search_value:xe.any().required(),get_attributes:xe.array().min(1).items(xe.alternatives(b_,xe.object())).optional(),desc:xe.bool(),limit:xe.number().integer().min(1),offset:xe.number().integer().min(0)}),e6=xe.object({database:ep,schema:ep,table:KM,operator:xe.string().valid("and","or").default("and").lowercase(),offset:xe.number().integer().min(0),limit:xe.number().integer().min(1),get_attributes:xe.array().min(1).items(xe.alternatives(b_,xe.object())).optional(),sort:xe.object({attribute:xe.alternatives(b_,xe.array().min(1)),descending:xe.bool().optional()}).optional(),conditions:xe.array().min(1).items(xe.alternatives(xe.object({operator:xe.string().valid("and","or").default("and").lowercase(),conditions:xe.array()}),xe.object({search_attribute:xe.alternatives(b_,xe.array().min(1)),search_type:xe.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:xe.when("search_type",{switch:[{is:"equals",then:xe.any()},{is:"between",then:xe.array().items(xe.alternatives([xe.string(),xe.number()])).length(2)}],otherwise:xe.alternatives(xe.string(),xe.number())}).required()}))).required()});YM.exports=function(e,t){let r=null;switch(t){case"value":r=$M.validateBySchema(e,Z5);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(VM("database",e.schema)),i(VM("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=$M.validateBySchema(e,e6);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=j5.checkGlobalSchemaTable(e.schema,e.table);if(s)return z5(new Error,s,X5.NOT_FOUND);let o=J5()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let l=a(d=>{for(let _=0,E=d.conditions.length;_<E;_++){let f=d.conditions[_];f.conditions?l(f):c.push(f.search_attribute)}},"addConditions");t==="conditions"&&l(e);let u=qM.filter(c,d=>d!=="*"&&!d.startsWith?.("$")&&d.attribute!=="*"&&!Array.isArray(d)&&!d.name&&!qM.some(o,_=>_===d||_.attribute===d||_.attribute===d.attribute));if(u&&u.length>0){let d=u.join(", ");return d=d.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${d}'`)}}return r}});var rR=N((Rye,WM)=>{"use strict";var t6=ht(),r6=Yl(),{getSchemaPath:n6}=gt();WM.exports=s6;function s6(e){let t=r6(e,"hashes");if(t)throw t;let r=n6(e.schema,e.table);return t6.openEnvironment(r,e.table)}a(s6,"initialize")});var nR=N((bye,jM)=>{"use strict";var i6=Kl(),o6=rR();jM.exports=a6;async function a6(e){let t=await o6(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return i6.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(a6,"lmdbGetDataByHash")});var Wl=N((Nye,zM)=>{"use strict";var sR=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};zM.exports=sR});var JM=N((Cye,QM)=>{"use strict";var wye=Wl(),c6=Kl(),l6=rR();QM.exports=u6;async function u6(e){let t=await l6(e),r=global.hdb_schema[e.schema][e.table];return c6.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(u6,"lmdbSearchByHash")});var $s=N((Dye,XM)=>{"use strict";var iR=class{static{a(this,"SearchObject")}constructor(t,r,n,s,i,o,c,l=!1,u=void 0,d=void 0){this.schema=t,this.table=r,this.search_attribute=n,this.search_value=s,this.hash_attribute=i,this.get_attributes=o,this.end_value=c,this.reverse=l,this.limit=u,this.offset=d}};XM.exports=iR});var tp=N((Mye,sU)=>{"use strict";var Wr=Kl(),d6=ht(),_6=re(),ke=Ht(),hc=M(),f6=Ji(),ZM=Pn().LMDB_ERRORS_ENUM,{getSchemaPath:E6}=gt(),ro=hc.SEARCH_WILDCARDS;async function h6(e,t,r){let n;e.schema===hc.SYSTEM_SCHEMA_NAME?n=f6[e.table]:n=global.hdb_schema[e.schema][e.table];let s=nU(e,n.hash_attribute,r,t);return tU(e,s,n.hash_attribute,r)}a(h6,"prepSearch");async function tU(e,t,r,n){let s=E6(e.schema,e.table),i=await d6.openEnvironment(s,e.table),o=rU(i,e,t,r),c=o.transaction||i;if([ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,ke.SEARCH_TYPES.SEARCH_ALL,ke.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(p6(e,r)===!1){let d=e.search_attribute;if(d===r)return n?eU(o,()=>!0):o.map(E=>({[r]:E.key}));let _=a(E=>({[r]:E.value,[d]:E.key}),"toObject");return n?eU(o,_):o.map(_)}let u=e.search_attribute===r?o.map(d=>d.key):o.map(d=>d.value);return n===!0?Wr.batchSearchByHashToMap(c,r,e.get_attributes,u):Wr.batchSearchByHash(c,r,e.get_attributes,u)}a(tU,"executeSearch");function rU(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 ke.SEARCH_TYPES.EQUALS:s=Wr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.CONTAINS:s=Wr.contains(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.ENDS_WITH:case ke.SEARCH_TYPES._ENDS_WITH:s=Wr.endsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.STARTS_WITH:case ke.SEARCH_TYPES._STARTS_WITH:s=Wr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return Wr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return Wr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case ke.SEARCH_TYPES.SEARCH_ALL:return Wr.searchAll(e,n,t.get_attributes,o,c,l);case ke.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return Wr.searchAllToMap(e,n,t.get_attributes,o,c,l);case ke.SEARCH_TYPES.BETWEEN:s=Wr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,l);break;case ke.SEARCH_TYPES.GREATER_THAN:case ke.SEARCH_TYPES._GREATER_THAN:s=Wr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.GREATER_THAN_EQUAL:case ke.SEARCH_TYPES._GREATER_THAN_EQUAL:s=Wr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.LESS_THAN:case ke.SEARCH_TYPES._LESS_THAN:s=Wr.lessThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case ke.SEARCH_TYPES.LESS_THAN_EQUAL:case ke.SEARCH_TYPES._LESS_THAN_EQUAL:s=Wr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;default:return Object.create(null)}return s}a(rU,"searchByType");function eU(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(eU,"createMapFromIterable");function p6(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(p6,"checkToFetchMore");function nU(e,t,r,n){if(_6.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),ro.indexOf(s)>-1)return r===!0?ke.SEARCH_TYPES.SEARCH_ALL_TO_MAP:ke.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(ro[0])<0&&s.indexOf(ro[1])<0)return c===!0?r===!0?ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:ke.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:ke.SEARCH_TYPES.EQUALS;if(ro.indexOf(i)>=0&&ro.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),ke.SEARCH_TYPES.CONTAINS;if(ro.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),ke.SEARCH_TYPES.ENDS_WITH;if(ro.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),ke.SEARCH_TYPES.STARTS_WITH;if(s.includes(ro[0])||s.includes(ro[1]))return ke.SEARCH_TYPES.EQUALS;throw new Error(ZM.UNKNOWN_SEARCH_TYPE)}else switch(n){case hc.VALUE_SEARCH_COMPARATORS.BETWEEN:return ke.SEARCH_TYPES.BETWEEN;case hc.VALUE_SEARCH_COMPARATORS.GREATER:return ke.SEARCH_TYPES.GREATER_THAN;case hc.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return ke.SEARCH_TYPES.GREATER_THAN_EQUAL;case hc.VALUE_SEARCH_COMPARATORS.LESS:return ke.SEARCH_TYPES.LESS_THAN;case hc.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return ke.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(ZM.UNKNOWN_SEARCH_TYPE)}}a(nU,"createSearchTypeFromSearchObject");sU.exports={executeSearch:tU,createSearchTypeFromSearchObject:nU,prepSearch:h6,searchByType:rU}});var oU=N((Bye,iU)=>{"use strict";var vye=$s(),m6=Yl(),S6=re(),T6=M(),g6=tp();iU.exports=A6;function A6(e,t){if(!S6.isEmpty(t)&&T6.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=m6(e,"value");if(n)throw n;return g6.prepSearch(e,t,!0)}a(A6,"lmdbGetDataByValue")});var O_=N((kye,aU)=>{"use strict";var xye=$s(),R6=Yl(),y6=re(),b6=M(),O6=tp();aU.exports=N6;async function N6(e,t){if(!y6.isEmpty(t)&&b6.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=R6(e,"value");if(n)throw n;return O6.prepSearch(e,t,!1)}a(N6,"lmdbSearchByValue")});var lU=N((qye,cU)=>{"use strict";var Gye=Ht(),oR=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}},aR=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},cR=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};cU.exports={SearchByConditionsObject:oR,SearchCondition:aR,SortAttribute:cR}});var EU=N((Yye,fU)=>{"use strict";var Vye=lU().SearchByConditionsObject,I6=$s(),w6=Yl(),lR=Kl(),rp=Ht(),{Resource:Kye}=(Vs(),oe(uR)),_U=tp(),C6=tR(),P6=require("lodash"),{getSchemaPath:D6}=gt(),uU=ht(),{handleHDBError:L6,hdb_errors:M6}=_e(),{HTTP_STATUS_CODES:U6}=M6,v6=1e8;fU.exports=B6;async function B6(e){let t=w6(e,"conditions");if(t)throw L6(t,t.message,U6.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=D6(e.schema,e.table),n=await uU.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let u of e.conditions)uU.openDBI(n,u.search_attribute);let i=P6.sortBy(e.conditions,u=>{if(u.estimated_count===void 0){let d=u.search_type;d===rp.SEARCH_TYPES.EQUALS?u.estimated_count=lR.count(n,u.search_attribute,u.search_value):d===rp.SEARCH_TYPES.CONTAINS||d===rp.SEARCH_TYPES.ENDS_WITH?u.estimated_count=1/0:u.estimated_count=v6}return u.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await dU(o,e,i[0],s.hash_attribute),l;if(!e.operator||e.operator.toLowerCase()==="and"){let u=n.dbis[s.hash_attribute],d=i.slice(1).map(_U.filterByType),_=d.length,E=lR.setGetWholeRowAttributes(n,e.get_attributes);l=c.map(f=>u.get(f,{transaction:o,lazy:!0})),_>0&&(l=l.filter(f=>{for(let h=0;h<_;h++)if(!d[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=>C6.parseRow(f,E))}else{for(let _=1;_<i.length;_++){let E=i[_],f=await dU(o,e,E,s.hash_attribute);c=c.concat(f)}let u=new Set,d=e.offset||0;c=c.filter(_=>u.has(_)?!1:(u.add(_),!0)).slice(d,e.limit&&e.limit+d),l=lR.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(B6,"lmdbSearchByConditions");async function dU(e,t,r,n){let s=new I6(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===rp.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,_U.searchByType(e,s,i,n).map(o=>o.value)}a(dU,"executeConditionSearch")});var N_=N((jye,hU)=>{"use strict";var H6=M().OPERATIONS_ENUM,dR=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=H6.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};hU.exports=dR});var _R=N((Qye,yU)=>{"use strict";var TU=$s(),gU=N_(),AU=O_(),RU=A_(),dn=M(),pU=re(),mU=ht(),{getTransactionAuditStorePath:x6,getSchemaPath:k6}=gt(),SU=j();yU.exports=F6;async function F6(e){try{if(pU.isEmpty(global.hdb_schema[e.schema])||pU.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await G6(e),await q6(e);let t=k6(e.schema,e.table);try{await mU.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")SU.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=x6(e.schema,e.table);await mU.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")SU.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(F6,"lmdbDropTable");async function G6(e){let t=new TU(dn.SYSTEM_SCHEMA_NAME,dn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,dn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[dn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await AU(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 gU(dn.SYSTEM_SCHEMA_NAME,dn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await RU(s)}a(G6,"deleteAttributesFromSystem");async function q6(e){let t=new TU(dn.SYSTEM_SCHEMA_NAME,dn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,dn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[dn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,dn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,dn.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await AU(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 gU(dn.SYSTEM_SCHEMA_NAME,dn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await RU(s)}catch(i){throw i}}a(q6,"dropTableFromSystem")});var OU=N((Xye,bU)=>{"use strict";var $6=require("fs-extra"),V6=$s(),K6=Wl(),Y6=N_(),W6=_R(),j6=A_(),z6=nR(),Q6=O_(),no=M(),{getSchemaPath:J6}=gt(),{handleHDBError:X6,hdb_errors:Z6}=_e(),{HDB_ERROR_MSGS:e8,HTTP_STATUS_CODES:t8}=Z6;bU.exports=r8;async function r8(e){let t;try{t=await n8(e.schema);let r=new V6(no.SYSTEM_SCHEMA_NAME,no.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,no.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[no.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await Q6(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await W6(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new Y6(no.SYSTEM_SCHEMA_NAME,no.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await j6(s);let i=J6(t);await $6.remove(i)}catch(r){throw r}}a(r8,"lmdbDropSchema");async function n8(e){let t=new K6(no.SYSTEM_SCHEMA_NAME,no.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[no.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await z6(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw X6(new Error,e8.SCHEMA_NOT_FOUND(e),t8.NOT_FOUND,void 0,void 0,!0);return n}a(n8,"validateDropSchema")});var I_=N((ebe,NU)=>{"use strict";var fR=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};NU.exports=fR});var hR=N((nbe,IU)=>{"use strict";var s8=require("fs-extra"),np=ht(),{getTransactionAuditStorePath:i8}=gt(),ER=Ht(),rbe=I_();IU.exports=o8;async function o8(e){let t;try{let r=i8(e.schema,e.table);await s8.mkdirp(r),t=await np.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{np.createDBI(t,ER.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),np.createDBI(t,ER.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),np.createDBI(t,ER.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(o8,"createTransactionsAuditEnvironment")});var PU=N((obe,CU)=>{"use strict";var pR=M(),wU=ht(),a8=sc(),{getSystemSchemaPath:c8,getSchemaPath:l8}=gt(),ibe=Ji(),u8=Mh(),mR=Lh(),d8=j(),_8=hR();CU.exports=f8;async function f8(e,t){let r=l8(t.schema,t.table),n=new mR(t.schema,t.table,pR.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new mR(t.schema,t.table,pR.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new mR(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await wU.createEnvironment(r,t.table),e!==void 0){let o=await wU.openEnvironment(c8(),pR.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await a8.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_table_attributes,[e]),n.skip_table_check=!0,s.skip_table_check=!0,i.skip_table_check=!0,await SR(n),await SR(s),await SR(i)}await _8(t)}catch(o){throw o}}a(f8,"lmdbCreateTable");async function SR(e){try{await u8(e)}catch(t){d8.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(SR,"createAttribute")});var LU=N((cbe,DU)=>{"use strict";var E8=f_(),h8=Jd(),p8=zh(),w_=M(),m8=sc().updateRecords,S8=ht(),{getSchemaPath:T8}=gt(),g8=T_(),A8=j();DU.exports=R8;async function R8(e){try{let{schema_table:t,attributes:r}=E8(e);h8(e,r,t.hash_attribute),e.schema!==w_.SYSTEM_SCHEMA_NAME&&(r.includes(w_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(w_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(w_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(w_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await p8(e.hdb_auth_header,t,r),s=T8(e.schema,e.table),i=await S8.openEnvironment(s,e.table),o=await m8(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await g8(e,o)}catch(c){A8.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(R8,"lmdbUpdateRecords")});var UU=N((ube,MU)=>{"use strict";var y8=M().OPERATIONS_ENUM,TR=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=y8.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};MU.exports=TR});var BU=N((fbe,vU)=>{"use strict";var _be=UU(),b8=f_(),O8=Jd(),N8=zh(),C_=M(),I8=sc().upsertRecords,w8=ht(),{getSchemaPath:C8}=gt(),P8=T_(),D8=j(),{handleHDBError:L8,hdb_errors:M8}=_e();vU.exports=U8;async function U8(e){let t;try{t=b8(e)}catch(l){throw L8(l,l.message,M8.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;O8(e,n,r.hash_attribute),e.schema!==C_.SYSTEM_SCHEMA_NAME&&(n.includes(C_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(C_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(C_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(C_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await N8(e.hdb_auth_header,r,n),i=C8(e.schema,e.table),o=await w8.openEnvironment(i,e.table),c=await I8(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await P8(e,c)}catch(l){D8.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(U8,"lmdbUpsertRecords")});var xU=N((hbe,HU)=>{"use strict";var gR=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};HU.exports=gR});var FU=N((mbe,kU)=>{"use strict";var AR=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}};kU.exports=AR});var $U=N((gbe,qU)=>{"use strict";var RR=ht(),{getTransactionAuditStorePath:v8}=gt(),Tbe=xU(),P_=Ht(),B8=re(),GU=FU(),H8=require("util").promisify,x8=H8(setTimeout),k8=1e4,F8=100;qU.exports=G8;async function G8(e){let t=v8(e.schema,e.table),r=await RR.openEnvironment(t,e.table,!0),n=RR.listDBIs(r);RR.initializeDBIs(r,P_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new GU;do s=await q8(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 x8(F8);while(s.transactions_deleted>0);return i}a(G8,"deleteAuditLogsBefore");async function q8(e,t){let r=new GU;try{let n=e.dbis[P_.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[P_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];B8.isEmpty(c)||(s=e.dbis[P_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[P_.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>k8)break}return await s,r}catch(n){throw n}}a(q8,"deleteTransactions")});var KU=N((Rbe,VU)=>{"use strict";var yR=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};VU.exports=yR});var WU=N((Obe,YU)=>{"use strict";var $8=$s(),V8=N_(),bbe=KU(),yi=M(),K8=re(),bR=ht(),Y8=Ji(),W8=O_(),j8=A_(),{getSchemaPath:z8}=gt();YU.exports=Q8;async function Q8(e,t=!0){let r;e.schema===yi.SYSTEM_SCHEMA_NAME?r=Y8[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await X8(e),s=z8(e.schema,e.table),i=await bR.openEnvironment(s,e.table);return t===!0&&await J8(e,i,r.hash_attribute),bR.dropDBI(i,e.attribute),n}a(Q8,"lmdbDropAttribute");async function J8(e,t,r){let n=bR.openDBI(t,r),s,i=e.attribute;for(let{key:o,value:c,version:l}of n.getRange({start:!1,versions:!0})){let u={};for(let d in c)d!==i&&(u[d]=c[d]);s=t.dbis[r].put(o,u,l)}await s}a(J8,"removeAttributeFromAllObjects");async function X8(e){let t=new $8(yi.SYSTEM_SCHEMA_NAME,yi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,yi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[yi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,yi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await W8(t)).filter(o=>o[yi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(K8.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[yi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new V8(yi.SYSTEM_SCHEMA_NAME,yi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return j8(i)}a(X8,"dropAttributeFromSystem")});var ZU=N((wbe,XU)=>{"use strict";var OR=ht(),jl=Ht(),Ibe=cn(),NR=M(),jU=re(),{getTransactionAuditStorePath:Z8}=gt(),e9=Kl(),sp=ql(),t9=j();XU.exports=r9;async function r9(e){let t=Z8(e.schema,e.table),r=await OR.openEnvironment(t,e.table,!0),n=OR.listDBIs(r);OR.initializeDBIs(r,jl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case NR.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return zU(r,e.search_values);case NR.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,s9(r,e.search_values,s);case NR.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return n9(r,e.search_values);default:return zU(r)}}a(r9,"readAuditLog");function zU(e,t=[0,Date.now()]){jU.isEmpty(t[0])&&(t[0]=0),jU.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[jl.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 sp,s))}a(zU,"searchTransactionsByTimestamp");function n9(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[jl.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,JU(e,i))}return Object.fromEntries(r)}a(n9,"searchTransactionsByUsername");function s9(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let u=t[c],d=e9.equals(e,jl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,jl.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,u);for(let{value:_}of d){let E=Number(_);n.has(E)?n.get(E).push(u.toString()):n.set(E,[u.toString()])}}let s=Array.from(n.keys()),i=JU(e,s),o=new Map;for(let c=0;c<i.length;c++){let l=i[c],u=l.timestamp,d=n.get(u);QU(l,"records",r,d,o),QU(l,"original_records",r,d,o)}return Object.fromEntries(o)}a(s9,"searchTransactionsByHashValues");function QU(e,t,r,n,s){let i=e.timestamp;if(e[t])for(let o=0;o<e[t].length;o++){let c=e[t][o],l=c[r].toString();if(n.indexOf(l)>=0)if(s.has(l)){let u=s.get(l),d=u[u.length-1];if(d.timestamp===i)d[t]=[c];else{let _=new sp(e.operation,e.user_name,i,void 0);_[t]=[c],u.push(_)}}else{let u=new sp(e.operation,e.user_name,i,void 0);u[t]=[c],s.set(l,[u])}}}a(QU,"loopRecords");function JU(e,t){let r=[];try{let n=e.dbis[jl.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 sp,i);r.push(o)}}catch(i){t9.warn(i)}return r}catch(n){throw n}}a(JU,"batchSearchTransactions")});var tv=N((Lbe,ev)=>{"use strict";var{getSchemaPath:Pbe}=gt(),Dbe=ht(),{database:i9}=(De(),oe(lt));ev.exports={writeTransaction:o9};async function o9(e,t,r){return i9({database:e,table:t}).transaction(r)}a(o9,"writeTransaction")});var iv=N((Ube,sv)=>{"use strict";var{getSchemaPath:rv}=gt(),nv=ht();sv.exports={flush:a9,resetReadTxn:c9};async function a9(e,t){return(await nv.openEnvironment(rv(e,t),t.toString())).flushed}a(a9,"flush");async function c9(e,t){try{(await nv.openEnvironment(rv(e,t),t.toString())).resetReadTxn()}catch{}}a(c9,"resetReadTxn")});var lv=N((Bbe,cv)=>{"use strict";var{Readable:l9}=require("stream"),{getDatabases:u9}=(De(),oe(lt)),{readSync:d9,openSync:_9,createReadStream:ov}=require("fs"),{open:f9}=require("lmdb"),av=o_(),E9=a_(),{AUDIT_STORE_OPTIONS:h9}=(zi(),oe(uv)),{INTERNAL_DBIS_NAME:p9,AUDIT_STORE_NAME:m9}=Ht();cv.exports=T9;var IR=32768,S9=100;async function T9(e){let t=e.database||e.schema||"data",r=u9()[t],n=new Date().toISOString(),s=e.tables||e.table&&[e.table];if(s){let u=r[s[0]];if(!u)throw new Error(`Can not find table ${s[0]}`);let d=u.dbisDB,_=f9({noSync:!0,maxDbs:E9.MAX_DBS}),E,f=_.openDB(p9,new av(!1)),h=d.useReadTransaction(),T=0,m=a(async function(S,y){y.encoding="binary",y.encoder=void 0;let I=_.openDB(S,y),U=d.openDB(S,y);for(let{key:H,version:X,value:Y}of U.getRange({start:null,transaction:h,versions:U.useVersions}))E=I.put(H,Y,X),T++%S9===0&&(await new Promise(V=>setTimeout(V,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:S,value:y}of d.getRange({transaction:h,start:!1}))if(s.some(I=>S.startsWith?.(I+"/"))){f.put(S,y);let[,I]=S.split("/"),U=!I,H=new av(!U,U);await m(S,H)}e.include_audit&&await m(m9,{...h9}),await E;let g=ov(_.path);return g.headers=l(),g.on("close",()=>{h.done(),_.close()}),g}let o=r[Object.keys(r)[0]].primaryStore,c=_9(o.path);return o.transaction(()=>{let u=Buffer.alloc(IR);d9(c,u,0,IR),o.resetReadTxn();let d=o.useReadTransaction();d.renew();let _=ov(null,{fd:c,start:IR}),E=new l9.from(async function*(){yield u;for await(let f of _)d.openTimer&&(d.openTimer=0),yield f;d.done()}());return E.headers=l(),E});function l(){let u=new Map;return u.set("content-type","application/octet-stream"),u.set("content-disposition",`attachment; filename="${t}"`),u.set("date",n),u}}a(T9,"getBackup")});var fv=N((xbe,_v)=>{"use strict";var g9=j(),{handleHDBError:A9}=_e(),R9=jP(),y9=Mh(),b9=QA(),O9=OM(),N9=A_(),I9=nR(),w9=JM(),C9=oU(),P9=O_(),D9=EU(),L9=OU(),M9=PU(),U9=LU(),v9=BU(),B9=$U(),H9=_R(),x9=WU(),k9=ZU(),F9=tv(),dv=iv(),G9=lv(),wR=class extends R9{static{a(this,"LMDBBridge")}async searchByConditions(t){return D9(t)}async getDataByHash(t){return await I9(t)}async searchByHash(t){return await w9(t)}async getDataByValue(t,r){return await C9(t,r)}async searchByValue(t){return await P9(t)}async createSchema(t){return await O9(t)}async dropSchema(t){return await L9(t)}async createTable(t,r){return await M9(t,r)}async dropTable(t){return await H9(t)}async createAttribute(t){return await y9(t)}async createRecords(t){return await b9(t)}async updateRecords(t){return await U9(t)}async upsertRecords(t){try{return await v9(t)}catch(r){throw A9(r,null,null,g9.ERR,r)}}async deleteRecords(t){return await N9(t)}async dropAttribute(t){return await x9(t)}async deleteAuditLogsBefore(t){return await B9(t)}async readAuditLog(t){return await k9(t)}writeTransaction(t,r,n){return F9.writeTransaction(t,r,n)}flush(t,r){return dv.flush(t,r)}resetReadTxn(t,r){return dv.resetReadTxn(t,r)}getBackup(t){return G9(t)}};_v.exports=wR});function Av(e){PR=e}function K9(){V9=setInterval(function(){for(let e of CR)if(e.stale){let t=e[Fe]?.url;mv.error(`Transaction was open too long and has been aborted, from table: ${e.lmdbDb?.name+(t?" path: "+t:"")}`),e.abort()}else e.stale=!0},$9).unref()}var DR,pv,mv,Sv,Tv,gv,Ev,CR,q9,D_,hv,PR,pc,ip,$9,V9,op=Ie(()=>{DR=L(cn()),pv=L(_e()),mv=L(j());Vs();Sv=L(se()),Tv=L(M()),gv=L(re()),Ev=100,CR=new Set,q9=(0,gv.convertToMS)(Sv.get(Tv.CONFIG_PARAMS.STORAGE_MAXTRANSACTIONQUEUETIME))||45e3;a(Av,"replicationConfirmation");pc=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),CR.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(CR.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(D_&&!this.overloadChecked&&performance.now()-hv>q9)throw new pv.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,DR.getNextMonotonicTime)()),t.timestamp||(t.timestamp=r);let n=t.retries||0;if(this.validated<this.writes.length)try{let _=this.validated;this.validated=this.writes.length;for(let f=_;f<this.validated;f++)this.writes[f]?.validate?.(this.timestamp);let E;for(let f=_;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 T=_;T<this.validated;T++){let m=this.writes[T];if(!m)continue;let g=m[f===0?"before":"beforeIntermediate"];if(g){let S=g();h?h.push?h.push(S):h=[h,S]:h=S}}h&&await(h.push?Promise.all(h):h)}}catch(f){throw this.abort(),f}return this.commit(t)})()}catch(_){throw this.abort(),_}n||this.doneReadTxn(),this.open=t?.letItLinger?2:0;let s,i=[],o=0;this.writes=this.writes.filter(_=>_);let c=a(_=>{_.commit(r,_.entry,n)},"doWrite"),l=a(()=>{let _=this.writes[o++];if(_)if(_.key){n>0&&(_.entry=_.store.getEntry(_.key));let E=_.store.ifVersion(_.key,_.entry?.version??null,l);s=s||E}else l();else for(let E of this.writes)c(E)},"nextCondition"),u=this.lmdbDb;if(this.writes.length>0&&(u?.retryRisk&&(u.retryRisk*=.99),this.writes.length+(u?.retryRisk||0)<Ev>>n?l():s=this.writes[0].store.transaction(()=>{for(let _ of this.writes)_.entry=_.store.getEntry(_.key),c(_);return!0})),s)return D_||(D_=s,hv=performance.now(),D_.then(()=>{D_=null})),s.then(_=>{if(_){if(this.next&&i.push(this.next.commit(t)),t?.flush&&i.push(this.writes[0].store.flushed),this.replicatedConfirmation){let E=this.writes[0].store.rootStore.databaseName,f=this.writes[this.writes.length-1];PR&&f&&i.push(PR(E,f.store.getEntry(f.key).localTime,this.replicatedConfirmation))}return this.writes=[],this.next=null,Promise.all(i).then(()=>({txnTime:r}))}else return u&&(u.retryRisk=(u.retryRisk||0)+Ev/2),t?t.retries=n+1:t={retries:1},this.commit(t)});let d={txnTime:r};if(this.next){let _=this.next?.commit(t);if(_?.then)return _?.then(E=>({txnTime:r,next:E}));d.next=_}return d}abort(){for(;this.readTxnsUsed>0;)this.doneReadTxn();this.open=0,this.writes=[]}},ip=class extends pc{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,DR.getNextMonotonicTime)())}getReadTxn(){}},$9=3e4;a(K9,"startMonitoringTxns");K9()});function Pt(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 pc;e.timestamp&&(n.timestamp=e.timestamp),e.replicatedConfirmation&&(n.replicatedConfirmation=e.replicatedConfirmation),n[Fe]=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 Rv,mc=Ie(()=>{Rv=L(fi());Vs();op();a(Pt,"transaction");(0,Rv._assignPackageExport)("transaction",Pt);Pt.commit=function(e){let t=(e[Fe]||e)?.transaction;if(!t)throw new Error("No active transaction is available to commit");return t.commit()};Pt.abort=function(e){let t=(e[Fe]||e)?.transaction;if(!t)throw new Error("No active transaction is available to abort");return t.abort()}});var Pv={};je(Pv,{ResourceBridge:()=>UR});function vR({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 bv(e,t){let r=bi(e),n=vR(e,r);if(!r)throw new Ks.ClientError(`Table ${e.table} not found`);let s;n&&r.attributes.length-n.length>2&&n.length<5&&(s=!0);let i={user:e.hdb_user,onlyIfCached:e.onlyIfCached,noCacheStore:e.noCacheStore,noCache:e.noCache,replicateFrom:e.replicateFrom},o;Pt(i,()=>new Promise(u=>o=u));let c=e.ids||e.hash_values,l=0;return{[Symbol.asyncIterator](){return{async next(){if(l<c.length){let u=c[l++],d;try{d=await r.get({id:u,lazy:s,select:n},i),d=d&&cp(d)}catch(_){d={message:_.toString()}}return t?{value:{key:u,value:d}}:{value:d}}else return o(),{done:!0}},return(u){return o(),{value:u,done:!0}},throw(u){return o(),{done:!0}}}}}}function bi(e){let t=e.database||e.schema||W9,r=ut()[t];if(!r)throw(0,Ks.handleHDBError)(new Error,Y9.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function Ov(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*Nv(e,t,r,n){let s,i=0;for await(let o of e.getHistory(t,r)){let c=o.operation??o.type;c==="put"&&(c="upsert");let{id:l,version:u,value:d}=o;if(s?.timestamp===u)s.hash_values.push(l),s.records.push(d);else{if(s&&(yield s,i++,n&&n<=i)){s=void 0;break}s={operation:c,user_name:o.user,timestamp:u,hash_values:[l],records:[d]}}}s&&(yield s)}var Iv,ap,Ks,wv,Ys,LR,MR,Cv,Y9,W9,j9,z9,yv,UR,Dv=Ie(()=>{"use strict";Iv=L(fv()),ap=L(Yl()),Ks=L(_e());De();wv=L(f_()),Ys=L(M()),LR=L(to()),MR=L(qs()),Cv=L(re());mc();lp();({HDB_ERROR_MSGS:Y9}=Ks.hdb_errors),W9="data",j9=1e4,z9=10,UR=class extends Iv.default{static{a(this,"ResourceBridge")}constructor(t){super(t),yv=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,ap.default)(t,"conditions");if(r)throw(0,Ks.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=bi(t);if(!n)throw new Ks.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:vR(t,n),sort:t.sort,allowFullScan:!0},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async createTable(t,r){let n=r.attributes,s=!!n,i=r.primary_key||r.hash_attribute;if(n)for(let o of n)o.is_primary_key?(o.isPrimaryKey=!0,delete o.is_primary_key):o.name===i&&i&&(o.isPrimaryKey=!0);else{if(!i)throw new Ks.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}]}Et({database:r.database??r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration,audit:r.audit})}async createAttribute(t){return await bi(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=bi(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=a((o,c,l)=>(c={...c},delete c[n],r.primaryStore.ifVersion(o,l,()=>r.primaryStore.put(o,c,l)).then(u=>{if(!u){let{value:d,version:_}=r.primaryStore.getEntry(o);return i(o,d,_)}})),"deleteRecord");for(let{key:o,value:c,version:l}of r.primaryStore.getRange({start:!0,versions:!0}))s=i(o,c,l),await new Promise(u=>setImmediate(u));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){bi(t).dropTable()}createSchema(t){return zl({database:t.schema,table:null}),LR.signalSchemaChange(new MR.SchemaEventMsg(process.pid,Ys.OPERATIONS_ENUM.CREATE_SCHEMA,t.schema))}async dropSchema(t){await BR(t.schema),LR.signalSchemaChange(new MR.SchemaEventMsg(process.pid,Ys.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,yv.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,wv.default)(t),s,i=ut()[t.schema][t.table],o={user:t.hdb_user,expiresAt:t.expiresAt,originatingOperation:t.operation};return t.replicateTo&&(o.replicateTo=t.replicateTo),t.replicatedConfirmation&&(o.replicatedConfirmation=t.replicatedConfirmation),Pt(o,async c=>{if(!i.schemaDefined){s=[];for(let d of n)i.attributes.find(E=>E.name==d)||s.push(d);s.length>0&&await i.addAttributes(s.map(d=>({name:d,indexed:!0})))}let l=[],u=[];for(let d of t.records){let _=d[i.primaryKey],E=_!=null&&await i.get(_,o);if(t.requires_existing&&!E||t.requires_no_existing&&E){u.push(d[i.primaryKey]);continue}E&&(E=cp(E));for(let f in d)if(Object.prototype.hasOwnProperty.call(d,f)){let h=d[f];if(typeof h=="function")try{let T=h([[E]]);Array.isArray(T)&&(h=T[0].func_val,d[f]=h)}catch(T){throw T.message+="Trying to set key "+f+" on object"+JSON.stringify(d),T}}if(E)for(let f in E)Object.prototype.hasOwnProperty.call(d,f)||(d[f]=E[f]);await(_==null?i.create(d,o):i.put(d,o)),l.push(d[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:l,new_attributes:s,skipped_hashes:u}})}async deleteRecords(t){let r=ut()[t.schema][t.table],n={user:t.hdb_user};return t.replicateTo&&(n.replicateTo=t.replicateTo),t.replicatedConfirmation&&(n.replicatedConfirmation=t.replicatedConfirmation),Pt(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 Ov(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=ut()[t.schema][t.table];if(!r.createdTimeProperty)throw new Ks.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:Ys.VALUE_SEARCH_COMPARATORS.LESS}]}),s=!1,i=[],o=[],c=0,l=[],u=a(async()=>{let d=await this.deleteRecords({schema:t.schema,table:t.table,hash_values:l});i.push(...d.deleted_hashes),o.push(...d.skipped_hashes),await(0,Cv.async_set_timeout)(z9),l=[],s=!0},"chunkDelete");for await(let d of n)l.push(d[r.primaryKey]),c++,c%j9===0&&await u();return l.length>0&&await u(),s?Ov(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,ap.default)(t,"hashes");if(r)throw r;return bv(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of bv(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&Ys.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,ap.default)(t,"value");if(n)throw n;let s=bi(t);if(!s)throw new Ks.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===Ys.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:vR(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache,replicateFrom:t.replicateFrom})}async getDataByValue(t,r){let n=new Map,s=bi(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){bi({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return bi(t).deleteHistory(t.timestamp,t.cleanup_deleted_records)}async readAuditLog(t){let r=bi(t),n={};switch(t.search_type){case Ys.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.operation??o.type;return c==="put"&&(c="upsert"),{operation:c,timestamp:o.version,user_name:o.user,hash_values:[i],records:[o.value]}});return n;case Ys.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:let s=t.search_values;for await(let i of Nv(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return Nv(r,t.search_values?.[0],t.search_values?.[1],t.limit)}}};a(vR,"getSelect");a(bv,"getRecords");a(bi,"getTable");a(Ov,"createDeleteResponse");a(Nv,"groupRecordsInHistory")});var Bn=N((Zbe,Lv)=>{"use strict";var{ResourceBridge:Q9}=(Dv(),oe(Pv)),J9=se();J9.initSync();var up;function X9(){return up||(up=new Q9,up)}a(X9,"getBridge");Lv.exports=X9()});var Bv=N((tOe,vv)=>{"use strict";var Mv=require("lodash"),L_=require("mathjs"),Z9=require("jsonata"),Uv=re();vv.exports={distinct_array:a(e=>Array.isArray(e)&&e.length>1?Mv.uniqWith(e,Mv.isEqual):e,"distinct_array"),searchJSON:e7,mad:M_.bind(null,L_.mad),mean:M_.bind(null,L_.mean),mode:M_.bind(null,L_.mode),prod:M_.bind(null,L_.prod),median:M_.bind(null,L_.median)};function M_(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(M_,"aggregateFunction");function e7(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(Uv.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),Uv.isEmpty(this.__ala__.res[r])){let n=Z9(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(e7,"searchJSON")});var xv=N((nOe,Hv)=>{"use strict";var nr=require("moment"),HR="YYYY-MM-DDTHH:mm:ss.SSSZZ";nr.suppressDeprecationWarnings=!0;Hv.exports={current_date:a(()=>nr().utc().format("YYYY-MM-DD"),"current_date"),current_time:a(()=>nr().utc().format("HH:mm:ss.SSS"),"current_time"),extract:a((e,t)=>{switch(t.toLowerCase()){case"year":return nr(e).utc().format("YYYY");case"month":return nr(e).utc().format("MM");case"day":return nr(e).utc().format("DD");case"hour":return nr(e).utc().format("HH");case"minute":return nr(e).utc().format("mm");case"second":return nr(e).utc().format("ss");case"millisecond":return nr(e).utc().format("SSS");default:break}},"extract"),date:a(e=>nr(e).utc().format(HR),"date"),date_format:a((e,t)=>nr(e).utc().format(t),"date_format"),date_add:a((e,t,r)=>nr(e).utc().add(t,r).valueOf(),"date_add"),date_sub:a((e,t,r)=>nr(e).utc().subtract(t,r).valueOf(),"date_sub"),date_diff:a((e,t,r)=>{let n=nr(e).utc(),s=nr(t).utc();return r?n.diff(s,r,!0):n.diff(s)},"date_diff"),now:a(()=>nr().utc().valueOf(),"now"),get_server_time:a(()=>nr().format(HR),"get_server_time"),offset_utc:a((e,t)=>nr(e).utc().utcOffset(t).format(HR),"offset_utc")}});var qv=N((iOe,Gv)=>{"use strict";var t7=require("@turf/area"),r7=require("@turf/length"),n7=require("@turf/circle"),s7=require("@turf/difference"),i7=require("@turf/distance"),o7=require("@turf/boolean-contains"),a7=require("@turf/boolean-equal"),c7=require("@turf/boolean-disjoint"),l7=require("@turf/helpers"),kv=M(),$e=re(),so=j();Gv.exports={geoArea:u7,geoLength:d7,geoCircle:_7,geoDifference:f7,geoDistance:Fv,geoNear:E7,geoContains:h7,geoEqual:p7,geoCrosses:m7,geoConvert:S7};function u7(e){if($e.isEmpty(e))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e));try{return t7.default(e)}catch(t){return so.trace(t,e),NaN}}a(u7,"geoArea");function d7(e,t){if($e.isEmpty(e))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e));try{return r7.default(e,{units:t||"kilometers"})}catch(r){return so.trace(r,e),NaN}}a(d7,"geoLength");function _7(e,t,r){if($e.isEmpty(e))return NaN;if($e.isEmpty(t))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e));try{return n7.default(e,t,{units:r||"kilometers"})}catch(n){return so.trace(n,e,t),NaN}}a(_7,"geoCircle");function f7(e,t){if($e.isEmpty(e))return NaN;if($e.isEmpty(t))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t));try{return s7(e,t)}catch(r){return so.trace(r,e,t),NaN}}a(f7,"geoDifference");function Fv(e,t,r){if($e.isEmpty(e))return NaN;if($e.isEmpty(t))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t));try{return i7.default(e,t,{units:r||"kilometers"})}catch(n){return so.trace(n,e,t),NaN}}a(Fv,"geoDistance");function E7(e,t,r,n){if($e.isEmpty(e)||$e.isEmpty(t))return!1;if($e.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t)),isNaN(r))throw new Error("distance must be a number");try{return Fv(e,t,n)<=r}catch(s){return so.trace(s,e,t),!1}}a(E7,"geoNear");function h7(e,t){if($e.isEmpty(e)||$e.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t));try{return o7.default(e,t)}catch(r){return so.trace(r,e,t),!1}}a(h7,"geoContains");function p7(e,t){if($e.isEmpty(e)||$e.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t));try{return a7.default(e,t)}catch(r){return so.trace(r,e,t),!1}}a(p7,"geoEqual");function m7(e,t){if($e.isEmpty(e)||$e.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=$e.autoCastJSON(e)),typeof t=="string"&&(t=$e.autoCastJSON(t));try{return!c7.default(e,t)}catch(r){return so.trace(r,e,t),!1}}a(m7,"geoCrosses");function S7(e,t,r){if($e.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if($e.isEmpty(t))throw new Error("geo_type is required");if($e.isEmpty(kv.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(kv.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=$e.autoCastJSON(e)),l7[t](e,r)}a(S7,"geoConvert")});var dp=N((aOe,$v)=>{var Sc=Bv(),Gn=xv(),Oi=qv();$v.exports=e=>{e.aggr.mad=e.aggr.MAD=Sc.mad,e.aggr.mean=e.aggr.MEAN=Sc.mean,e.aggr.mode=e.aggr.MODE=Sc.mode,e.aggr.prod=e.aggr.PROD=Sc.prod,e.aggr.median=e.aggr.MEDIAN=Sc.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=Sc.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=Sc.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=Gn.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Gn.current_time,e.fn.extract=e.fn.EXTRACT=Gn.extract,e.fn.date=e.fn.DATE=Gn.date,e.fn.date_format=e.fn.DATE_FORMAT=Gn.date_format,e.fn.date_add=e.fn.DATE_ADD=Gn.date_add,e.fn.date_sub=e.fn.DATE_SUB=Gn.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Gn.date_diff,e.fn.now=e.fn.NOW=Gn.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Gn.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Gn.get_server_time,e.fn.getdate=e.fn.GETDATE=Gn.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Gn.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=Oi.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=Oi.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=Oi.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=Oi.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=Oi.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=Oi.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=Oi.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=Oi.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=Oi.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=Oi.geoNear}});var Wv=N((cOe,Yv)=>{"use strict";var U_=require("lodash"),_n=require("alasql");_n.options.cache=!1;var T7=dp(),Vv=require("clone"),_p=require("recursive-iterator"),Ue=j(),et=re(),Ql=Bn(),g7=M(),{hdb_errors:A7}=_e(),{getDatabases:Kv}=(De(),oe(lt)),R7="IS NULL",Ws="There was a problem performing this search. Please check the logs and try again.";T7(_n);var xR=class{static{a(this,"SQLSearch")}constructor(t,r){if(et.isEmpty(t))throw Ue.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(),et.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!et.isEmptyOrZeroLength(n))return Ue.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw Ue.error("Error thrown from checkEmptySQL in SQLSearch class method search."),Ue.error(n),new Error(Ws)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw Ue.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),Ue.error(n),new Error(Ws)}if(Object.keys(this.data).length===0)return Ue.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw Ue.error("Error thrown from processJoins in SQLSearch class method search."),Ue.error(n),new Error(Ws)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw Ue.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),Ue.error(n),new Error(Ws)}try{return t=await this._finalSQL(),t}catch(n){throw Ue.error("Error thrown from finalSQL in SQLSearch class method search."),Ue.error(n),new Error(Ws)}}_getColumns(){let t=new _p(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(Vv(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=U_.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=Kv()[r.databaseid][r.tableid].primaryKey,this.data[n].__merged_data={},this.data[n].__merged_attributes=[],this.data[n].__merged_attr_map={}})}_conditionsToFetchAttributeValues(){if(et.isEmpty(this.statement.where)){Ue.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new _p(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!et.isEmpty(r)&&r.right)if(et.isNotEmptyAndHasValue(r.right.value)){let n=et.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new _n.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=et.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new _n.yy.LogicValue({value:i}):n instanceof _n.yy.StringValue&&et.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new _n.yy.NumValue({value:i}))});if(t){Ue.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new _p(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(!et.isEmpty(g7.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(et.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(et.isEmptyOrZeroLength(r.left.columnid)||et.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(et.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"=":!et.isEmpty(r.right.value)||!et.isEmpty(r.left.value)?n.add(et.isEmpty(r.right.value)?r.left.value:r.right.value):c=!0;break;case"IN":let l=Array.isArray(r.right)?r.right:r.left;for(let u=0;u<l.length;u++)if(l[u].value)n.add(l[u].value);else{c=!0;break}break;default:c=!0;break}this.exact_search_values[o].ignore=c,c?this.exact_search_values[o].values=new Set:this.exact_search_values[o].values=new Set([...this.exact_search_values[o].values,...n])}}}_setAliasesForColumns(){if(et.isEmptyOrZeroLength(this.all_table_attributes)&&et.isEmptyOrZeroLength(this.statement.from)&&et.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&&U_.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(et.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);et.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(et.isEmptyOrZeroLength(this.all_table_attributes)&&!et.isEmptyOrZeroLength(this.columns.columns))return t;if(et.isEmptyOrZeroLength(this.all_table_attributes)&&et.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await _n.promise(r)}catch(r){throw Ue.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),Ue.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(Vv(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(et.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(R7)>-1&&this.tables.forEach(s=>{let i={columnid:Kv()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=U_.uniqBy(this.fetch_attributes,s=>[s.table.databaseid,s.table.as?s.table.as:s.table.tableid,s.attribute].join()),r)return await this._simpleSQLQuery();let n=this.fetch_attributes.reduce((s,i)=>{let o=`${i.table.databaseid}_${i.table.as?i.table.as:i.table.tableid}`,c=this.data[o].__hash_name;return s[o]||(s[o]=[],s[o].push(null),this._addColumnToMergedAttributes(o,c)),i.attribute!==c&&(s[o].push(null),this._addColumnToMergedAttributes(o,i.attribute)),s},{});for(let s of this.fetch_attributes){let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`,o=this.data[i].__hash_name,c={schema:s.table.databaseid,table:s.table.tableid,get_attributes:[s.attribute]},l=!1,u=[s.table.databaseid,s.table.tableid,s.attribute].join("/");if(s.attribute===o&&(l=!0),!et.isEmpty(this.exact_search_values[u])&&!this.exact_search_values[u].ignore&&!et.isEmptyOrZeroLength(this.exact_search_values[u].values))if(l)try{c.hash_values=Array.from(this.exact_search_values[u].values);let d=await Ql.getDataByHash(c);for(let _ of c.hash_values)d.get(_)&&!this.data[i].__merged_data[_]&&(this.data[i].__merged_data[_]=[...n[i]],this._setMergedHashAttribute(i,_))}catch(d){throw Ue.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),Ue.error(d),new Error(Ws)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[u].values).map(async d=>{let _={...c};_.search_value=d;let E=await Ql.getDataByValue(_);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(d){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),Ue.error(d),new Error(Ws)}else if(!et.isEmpty(this.comparator_search_values[u])&&!this.comparator_search_values[u].ignore&&!et.isEmptyOrZeroLength(this.comparator_search_values[u].comparators))try{let d=this.comparator_search_values[u].comparators;for(let _=0,E=d.length;_<E;_++){let f=d[_];c.search_attribute=f.attribute,c.search_value=f.search_value;let h=await Ql.getDataByValue(c,f.operation);if(l)for(let[T]of h)this.data[i].__merged_data[T]||(this.data[i].__merged_data[T]=[...n[i]],this._setMergedHashAttribute(i,T));else for(let[T,m]of h)this.data[i].__merged_data[T]?this._updateMergedAttribute(i,T,s.attribute,m[s.attribute]):(this.data[i].__merged_data[T]=[...n[i]],this._updateMergedAttribute(i,T,s.attribute,m[s.attribute]),this._setMergedHashAttribute(i,T))}}catch(d){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),Ue.error(d),new Error(Ws)}else try{c.search_attribute=s.attribute,c.search_value="*";let d=await Ql.getDataByValue(c);if(l)for(let[_]of d)this.data[i].__merged_data[_]||(this.data[i].__merged_data[_]=[...n[i]],this._setMergedHashAttribute(i,_));else for(let[_,E]of d)this.data[i].__merged_data[_]?this._updateMergedAttribute(i,_,s.attribute,E[s.attribute]):(this.data[i].__merged_data[_]=[...n[i]],this._updateMergedAttribute(i,_,s.attribute,E[s.attribute]),this._setMergedHashAttribute(i,_))}catch(d){throw Ue.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),Ue.error(d),new Error(Ws)}}}_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 _n.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 _n.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new _n.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 _n.yy.FuncValue:new _n.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,T=f.as?f.as_orig:f.tableid_orig;o.push({key:`'${T}.${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 "${T}.${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 u="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(u="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(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 d="",_="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(d=this.statement.limit?"LIMIT "+this.statement.limit:"",_=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 _n.promise(h,t),t=null}catch(f){throw Ue.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),Ue.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 T=E[f];o.forEach(m=>{T[m.key]!==null&&T[m.key]!==void 0&&m.keys.add(T[m.key])})}o.forEach(f=>{let h=Object.keys(this.data[`${f.schema}_${f.table}`].__merged_data),T=U_.difference(h,[...f.keys].map(m=>m.toString()));for(let m=0,g=T.length;m<g;m++){let S=T[m];delete this.data[`${f.schema}_${f.table}`].__merged_data[S]}})}return{existing_attributes:c,joined_length:E?E.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new _p(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=U_.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 Ue.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),Ue.error(i),new Error(Ws)}}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 d in i)o.push(i[d][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 Ql.getDataByHash(c),u=s.columns.length;for(let d=0,_=o.length;d<_;d++){let E=o[d],f=l.get(E);for(let h=0;h<u;h++){let T=s.columns[h],m=f[T]===void 0?null:f[T];this.data[n].__merged_data[E].push(m)}}}}catch(r){throw Ue.error("Error thrown from getDataByHash function in SQLSearch class method getData."),Ue.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();Ue.trace(`Final SQL: ${s}`),n=await _n.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),Ue.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw Ue.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),Ue.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 Ue.error(A7.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),Ue.trace(r.stack),t}}_buildSQL(t=!0){let r=this.statement.toString();return r=r.replace(/NOT\(NULL\)/g,"NOT NULL"),this.statement.columns.forEach(n=>{if(n.funcid&&n.as){let s=n.toString().replace(" AS "+n.as,"");r=r.replace(n.toString(),s)}}),t===!0?this._convertColumnsToIndexes(r,this.tables):r}_convertColumnsToIndexes(t,r){let n=t,s={};r.forEach(i=>{i.databaseid_orig?s[`${i.databaseid_orig}_${i.as?i.as_orig:i.tableid_orig}`]=i.as?i.as:i.tableid:s[`${i.databaseid}_${i.as?i.as:i.tableid}`]=`\`${i.as?i.as:i.tableid}\``});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=s[i],u=new RegExp(`${l}.\`${o}\``,"g"),d=`${l}.[${c}]`;n=n.replace(u,d)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=new RegExp(`\`${o}\``,"g"),u=`[${c}]`;n=n.replace(l,u)});return n}async _simpleSQLQuery(){let t=this.statement.columns.reduce((n,s)=>(s.as_orig&&s.as_orig!=s.columnid_orig?n[s.columnid_orig]=s.as_orig:n[s.columnid_orig]||(n[s.columnid_orig]=s.columnid_orig),n),{}),r=this.fetch_attributes.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]||(n[i]={}),n[i][t[s.attribute]]=null,n},{});for(let n of this.fetch_attributes){let s=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`,i={schema:n.table.databaseid,table:n.table.tableid,get_attributes:[n.attribute]};try{i.search_attribute=n.attribute,i.search_value="*";let o=await Ql.getDataByValue(i);for(let[c,l]of o)this.data[s].__merged_data[c]||(l[n.attribute]===void 0&&(l[n.attribute]=null),this.data[s].__merged_data[c]={...r[s]}),this.data[s].__merged_data[c][t[n.attribute]]=l[n.attribute]??null}catch(o){throw Ue.error("There was an error when processing this SQL operation. Check your logs"),Ue.error(o),new Error(Ws)}}return Object.values(Object.values(this.data)[0].__merged_data)}};Yv.exports=xR});var Vr=N((uOe,jv)=>{"use strict";var y7=YP();jv.exports={searchByConditions:O7,searchByHash:N7,searchByValue:I7,search:w7};var kR=Bn(),{transformReq:FR}=re(),b7=Wv();async function O7(e){return FR(e),kR.searchByConditions(e)}a(O7,"searchByConditions");async function N7(e){FR(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of kR.searchByHash(e))r&&t.push(r);return t}a(N7,"searchByHash");async function I7(e){FR(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of kR.searchByValue(e))t.push(r);return t}a(I7,"searchByValue");function w7(e,t){try{let r=new y7(e);r.validate(),new b7(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(w7,"search")});var fp=N((_Oe,zv)=>{"use strict";var C7=Bn();zv.exports={writeTransaction:P7};function P7(e,t,r){return C7.writeTransaction(e,t,r)}a(P7,"writeTransaction")});var Zv=N((hOe,Xv)=>{"use strict";var D7=Vr(),L7=Gs(),Qv=j(),M7=un(),EOe=fp(),U7=require("clone"),qR=require("alasql"),v7=dp(),Jv=require("util"),B7=Jv.promisify(L7.getTableSchema),H7=Jv.promisify(D7.search),x7=M(),GR=re();v7(qR);Xv.exports={update:F7};var k7="There was a problem performing this update. Please check the logs and try again.";async function F7({statement:e,hdb_user:t}){let r=await B7(e.table.databaseid,e.table.tableid),n=G7(e.columns);GR.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=U7(s),c=GR.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,u=qR.parse(l).statements[0],d=await H7(u),_=q7(n,d);return $7(o,_,t)}a(F7,"update");function G7(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=qR.compile(`SELECT ${r.expression.toString()} AS [${x7.FUNC_VAL}] FROM ?`)}),t}catch(t){throw Qv.error(t),new Error(k7)}}a(G7,"createUpdateRecord");function q7(e,t){return GR.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(q7,"buildUpdateRecords");async function $7(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await M7.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){Qv.error(`Error delete new_attributes from update response: ${i}`)}return s}a($7,"updateRecords")});var t0=N((TOe,e0)=>{var V7=require("alasql"),K7=Vr(),Y7=j(),W7=Bn(),VR=require("util"),$R=re(),j7=M(),z7=Gs(),mOe=fp(),SOe=un(),Q7="record",J7="successfully deleted",X7=VR.callbackify(ree),Z7=VR.promisify(K7.search),eee=VR.promisify(z7.getTableSchema);e0.exports={convertDelete:X7};function tee(e){return`${e.deleted_hashes.length} ${Q7}${e.deleted_hashes.length===1?"":"s"} ${J7}`}a(tee,"generateReturnMessage");async function ree({statement:e,hdb_user:t}){let r=await eee(e.table.databaseid,e.table.tableid);$R.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=$R.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=V7.parse(o).statements[0],l={operation:j7.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await Z7(c);let u=await W7.deleteRecords(l);return $R.isEmptyOrZeroLength(u.message)&&(u.message=tee(u)),delete u.txn_time,u}catch(u){throw Y7.error(u),u.hdb_code?u.message:u}}a(ree,"convertDelete")});var o0=N((AOe,i0)=>{"use strict";var nee=eo(),{hdb_errors:r0}=_e(),{getDatabases:n0}=(De(),oe(lt));i0.exports={checkSchemaExists:s0,checkSchemaTableExists:see,schema_describe:nee};async function s0(e){if(!n0()[e])return r0.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(s0,"checkSchemaExists");async function see(e,t){let r=await s0(e);if(r)return r;if(!n0()[e][t])return r0.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(see,"checkSchemaTableExists")});var Jl=N((yOe,iee)=>{iee.exports={name:"harperdb",version:"4.4.27",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","cover:test":"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && nyc --no-clean --reporter=lcovonly npm run test:replication && 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 --no-clean --reporter=lcovonly npm run test:security && 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:replication && 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 && npm run test:security && 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","test:security":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/security/**/*.js' --config '../unitTests/.mocharc.json'","test:replication":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/replication/**/*.js' --config '../unitTests/.mocharc.json'","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",format:"prettier .","format:fix":"npm run format -- --write",lint:"eslint .","lint:fix":"npm run lint -- --fix"},dependencies:{"@aws-sdk/client-s3":"3.717.0","@aws-sdk/lib-storage":"3.717.0","@endo/static-module-record":"^1.0.4","@fastify/autoload":"5.10.0","@fastify/compress":"~6.5.0","@fastify/cors":"~9.0.1","@fastify/static":"~7.0.4","@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.6.0",chalk:"4.1.2",chokidar:"^4.0.3","cli-progress":"3.12.0",clone:"2.1.2","fast-glob":"3.3.2",fastify:"~4.29.0","fastify-plugin":"~4.5.1","fs-extra":"11.2.0",graphql:"^16.10.0","gunzip-maybe":"1.4.2","human-readable-ids":"1.0.4",inquirer:"8.2.6","is-number":"7.0.0",joi:"17.12.2","json-bigint-fixes":"1.1.0",json2csv:"5.0.7",jsonata:"1.8.7",jsonwebtoken:"9.0.2",lmdb:"3.2.6",lodash:"4.17.21",mathjs:"11.12.0",minimist:"1.2.8",moment:"2.30.1","mqtt-packet":"~9.0.0",msgpackr:"1.11.2",nats:"2.19.0",needle:"3.3.1","node-forge":"^1.3.1","node-stream-zip":"1.15.0","node-unix-socket":"0.2.5","normalize-path":"^3.0.0",ora:"5.4.1","ordered-binary":"1.5.3",papaparse:"5.4.1",passport:"0.6.0","passport-http":"0.3.0","passport-local":"1.0.0",pino:"8.16.0",pm2:"5.4.1",prompt:"1.3.0","properties-reader":"2.3.0","recursive-iterator":"3.3.0",semver:"7.5.4",send:"^1.1.0","serve-static":"2.1.0",ses:"1.1.0","stream-chain":"2.2.5","stream-json":"1.8.0",systeminformation:"5.24.5","tar-fs":"3.0.6",ulidx:"0.5.0",uuid:"10.0.0","validate.js":"0.13.1",ws:"8.18.0",yaml:"2.7.0"},devDependencies:{"@tsconfig/node16":"^1.0.3","@types/node":"20.14.8","@typescript-eslint/eslint-plugin":"^7.18.0","@typescript-eslint/parser":"^7.18.0",axios:"1.7.5",chai:"4.4.1","chai-integer":"0.1.0",esbuild:"^0.24.2",eslint:"^8.57.1","eslint-config-prettier":"^9.1.0","eslint-plugin-sonarjs":"^3.0.1",eventsource:"^2.0.2","graphql-http":"^1.22.3","hook-std":"3.0.0","intercept-stdout":"0.1.2",mkcert:"1.5.1",mocha:"^11.0.1","mocha-teamcity-reporter":"^4.2.0","mock-require":"3.0.3","mock-stdin":"1.0.0",mqtt:"~4.3.8",newman:"6.1.3","node-fetch":"2.6.7",nyc:"15.1.0",prettier:"3.3.3",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.7.2",undici:"^6.19.8","why-is-node-still-running":"^1.0.0"},overrides:{alasql:{xlsx:"0.18.5"}},optionalDependencies:{bufferutil:"^4.0.7","segfault-handler":"^1.3.0","utf-8-validate":"^5.0.10"}}});var k_={};je(k_,{addAnalyticsListener:()=>x_,recordAction:()=>pr,recordActionBinary:()=>qn,setAnalyticsEnabled:()=>oee});function oee(e){h0=e}function pr(e,t,r,n,s){if(!h0)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=pp.get(i);if(o)if(typeof e=="number"){let c=o.values,l=c.index++;if(l>=c.length){let u=c;o.values=c=new Float32Array(l*2),c.set(u),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},pp.set(i,o)}Ep||aee()}function qn(e,t,r,n,s){pr(!!e,t,r,n,s)}function x_(e){S0.push(e)}function aee(){Ep=performance.now(),setTimeout(async()=>{let e=performance.now()-Ep;Ep=0;let t=[],r={time:Date.now(),period:e,threadId:Tc.threadId,metrics:t};for(let[s,i]of pp){if(i.values){let o=i.values.subarray(0,i.values.index);o.sort();let c=o.length,l=0,u=[],d;for(let _ of T0){let E=Math.floor(c*_),f=o[E-1];if(E>l){let h=E-l;if(f===d){let T=u[u.length-1];typeof T=="number"?u[u.length-1]={value:T,count:1+h}:T.count+=h}else u.push(h>1?{value:f,count:h}:f),d=f;l=E}}t.push(Object.assign(i.description,{mean:i.total/c,distribution:u,count:c}))}else i.callback?t.push(Object.assign(i.description,i.callback(i))):t.push(Object.assign(i.description,{total:i.total,count:i.count}));await g0()}let n=process.memoryUsage();t.push({metric:"memory",threadId:Tc.threadId,byThread:!0,...n});for(let s of S0)s(t);pp=new Map,Tc.parentPort?Tc.parentPort.postMessage({type:m0,report:r}):y0({report:r})},p0).unref()}async function cee(e,t=6e4){let r=WR(),n=A0(),s=new Promise(T=>{let m=performance.now();setImmediate(()=>{let g=performance.now();g-m>5e3&&(0,v_.warn)("Unusually high event queue latency on the main thread of "+Math.round(g-m)+"ms"),m=performance.now()}),n.primaryStore.prefetch([1],()=>{let g=performance.now();g-m>5e3&&(0,v_.warn)("Unusually high task queue latency on the main thread of "+Math.round(g-m)+"ms"),T(g-m)})}),i;for(let T of n.primaryStore.getRange({start:1/0,end:!1,reverse:!0}))if(T.value?.time){i=T.value.time;break}if(Date.now()-t<i)return;let o,c=new Map,l=new Map,u=[],d;for(let{key:T,value:m}of r.primaryStore.getRange({start:i||!1,exclusiveStart:!0,end:1/0})){if(!m)continue;if(o){if(T>o+t)break}else o=T;d=T;let{metrics:g,threadId:S}=m;for(let y of g||[]){let{path:I,method:U,type:H,metric:X,count:Y,total:V,distribution:ne,threads:Q,...de}=y;Y||(Y=1);let W=X+(I?"-"+I:"");U!==void 0&&(W+="-"+U),H!==void 0&&(W+="-"+H);let ae=c.get(W);if(ae){if(ae.threads){let Ne=ae.threads[S];if(Ne)ae=Ne;else{ae.threads[S]={...de};continue}}ae.count||(ae.count=1);let Oe=ae.count;for(let Ne in de){let Me=de[Ne];typeof Me=="number"&&(ae[Ne]=(ae[Ne]*Oe+Me*Y)/(Oe+Y))}ae.count+=Y,V>=0&&(ae.total+=V,ae.ratio=ae.total/ae.count)}else ae={period:t,...y},delete ae.distribution,c.set(W,ae),ae.byThread&&(ae.threads=[],ae.threads[S]={...de},u.push(ae));if(ne){ne=ne.map(Ne=>typeof Ne=="number"?{value:Ne,count:1}:Ne);let Oe=l.get(W);Oe?Oe.push(...ne):l.set(W,ne)}}await g0()}for(let T of u){let{path:m,method:g,type:S,metric:y,count:I,total:U,distribution:H,threads:X,...Y}=T;X=X.filter(V=>V);for(let V in Y){if(typeof T[V]!="number")continue;let ne=0;for(let Q of X){let de=Q[V];typeof de=="number"&&(ne+=de)}T[V]=ne}T.count=X.length,delete T.threads,delete T.byThread}for(let[T,m]of l){let g=c.get(T);m.sort((Ne,Me)=>Ne.value>Me.value?1:-1);let S=g.count-1,y=[],I=0,U=0,H;for(let Ne of T0){let Me=S*Ne;for(;I<Me;)H=m[U++],I+=H.count,U===1&&I--;let Gr=m[U>1?U-2:0];H||(H=m[0]),y.push(H.value-(H.value-Gr.value)*(I-Me)/H.count)}let[X,Y,V,ne,Q,de,W,ae,Oe]=y;Object.assign(g,{p1:X,p10:Y,p25:V,median:ne,p75:Q,p90:de,p95:W,p99:ae,p999:Oe})}let _;for(let[T,m]of c)m.id=(0,hp.getNextMonotonicTime)(),m.time=d,n.primaryStore.put(m.id,m,{append:!0}).then(g=>{g||n.primaryStore.put(m.id,m)}),_=!0;let E=Date.now(),{idle:f,active:h}=performance.eventLoopUtilization();if(_||h*10>f){let T=(0,hp.getNextMonotonicTime)(),m={id:T,metric:"main-thread-utilization",idle:f-a0,active:h-c0,taskQueueLatency:await s,time:E,...process.memoryUsage()};n.primaryStore.put(T,m,{append:!0}).then(g=>{g||n.primaryStore.put(T,m)})}a0=f,c0=h}async function l0(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function WR(){return u0||(u0=Et({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function A0(){return d0||(d0=Et({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function dee(){R0=!0;let e=(0,H_.get)(YR.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await cee(p0,e),await l0(WR(),lee),await l0(A0(),uee)},Math.min(e/2,2147483647)).unref()}function y0(e,t){let r=e.report;r.threadId=t?.threadId||Tc.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(_0+=n.mean*n.count);r.totalBytesProcessed=_0,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(f0.get(t))}),f0.set(t,t.performance.eventLoopUtilization())),r.id=(0,hp.getNextMonotonicTime)(),WR().primaryStore.put(r.id,r),R0||dee(),_ee&&(b0=Eee(r))}async function Eee(e){if(await b0,!Xo){let r=(0,B_.dirname)((0,v_.getLogFilePath)());try{Xo=await(0,KR.open)((0,B_.join)(r,"analytics.log"),"r+")}catch{Xo=await(0,KR.open)((0,B_.join)(r,"analytics.log"),"w+")}}let t=(await Xo.stat()).size;if(t>fee){let r=Buffer.alloc(t);await Xo.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await Xo.write(r,{position:0}),await Xo.truncate(r.length),t=r.length}await Xo.write(JSON.stringify(e)+`
12
12
  `,t)}var Tc,E0,v_,B_,KR,hp,H_,YR,pp,h0,Ep,p0,m0,S0,T0,a0,c0,g0,lee,uee,u0,d0,R0,_0,f0,_ee,b0,Xo,fee,Ni=Ie(()=>{Tc=require("worker_threads"),E0=L(dt());De();v_=L(j()),B_=require("path"),KR=require("fs/promises"),hp=L(cn()),H_=L(se()),YR=L(M());qr();(0,H_.initSync)();pp=new Map,h0=(0,H_.get)(YR.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)>-1;a(oee,"setAnalyticsEnabled");a(pr,"recordAction");it.recordAnalytics=pr;a(qn,"recordActionBinary");Ep=0,p0=1e3,m0="analytics-report",S0=[];a(x_,"addAnalyticsListener");T0=[.01,.1,.25,.5,.75,.9,.95,.99,.999,1];a(aee,"sendAnalytics");a(cee,"aggregation");a0=0,c0=0,g0=a(()=>new Promise(setImmediate),"rest");a(l0,"cleanup");lee=36e5,uee=31536e6;a(WR,"getRawAnalyticsTable");a(A0,"getAnalyticsTable");(0,E0.setChildListenerByType)(m0,y0);a(dee,"startScheduledTasks");_0=0,f0=new Map,_ee=!1;a(y0,"recordAnalytics");fee=1e6;a(Eee,"logAnalytics")});var XR=N((BOe,B0)=>{"use strict";var{decode:hee}=require("msgpackr"),{isMainThread:MOe,parentPort:UOe,threadId:vOe}=require("worker_threads"),Tp=mr(),Xl=Ct(),QR=M(),jr=j(),zR=se(),pee=M(),{onMessageByType:mee}=dt(),w0=Zi(),{recordAction:O0,recordActionBinary:See}=(Ni(),oe(k_)),{publishToStream:Tee}=Tp,{ConsumerEvents:N0}=require("nats"),gee=Vr(),{promisify:Aee}=require("util"),C0=Aee(setTimeout),gp=1e4,Ap,Sp,Ree,yee,P0,F_=new Map,Zl=new Map;B0.exports={initialize:D0,ingestConsumer:JR,setSubscription:bee,setIgnoreOrigin:Iee,getDatabaseSubscriptions:Nee,updateConsumer:L0};async function D0(){mee(QR.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,async n=>{await L0(n)}),P0=!0,jr.notify("Initializing clustering ingest service.");let{connection:e,jsm:t,js:r}=await Tp.getNATSReferences();Ap=e,Sp=e.info.server_name,Ree=t,yee=r}a(D0,"initialize");async function L0(e){if(e.status==="start"){let{js:t,jsm:r}=await M0(e.node_domain_name);JR(e.stream_name,t,r,e.node_domain_name)}else if(e.status==="stop"){let t=F_.get(e.stream_name+e.node_domain_name);t&&(jr.notify("Closing ingest consumer for node:",e.node_domain_name,"stream:",e.stream_name),await t.close?.(),F_.set(e.stream_name+e.node_domain_name,"close")),Zl.get(e.node_domain_name)==="failed"&&Zl.set(e.node_domain_name,"close")}}a(L0,"updateConsumer");var Rp=new Map;function bee(e,t,r){let n=Rp.get(e);n||Rp.set(e,n=new Map),n.set(t,r),P0||D0().then(Oee)}a(bee,"setSubscription");async function Oee(){let e=await gee.searchByValue({database:"system",table:"hdb_nodes",search_attribute:"name",search_value:"*"});for await(let t of e){let r=t.name+Xl.SERVER_SUFFIX.LEAF,n,s;for(let i of t.subscriptions||[])if(i.subscribe===!0){if(!n&&({js:n,jsm:s}=await M0(r),!n))break;let{schema:o,table:c}=i,l=w0.createNatsTableStreamName(o,c);JR(l,n,s,r)}}}a(Oee,"accessConsumers");async function M0(e){let t,r,n=1;for(;!r;)try{t=await Ap.jetstream({domain:e}),r=await Ap.jetstreamManager({domain:e,checkAPI:!1})}catch(s){if(Zl.get(e)==="close")break;Zl.set(e,"failed"),n%10===1&&jr.warn("Nats ingest attempting to connect to:",e,"Nats error:",s.message);let i=n++*100<gp?n++*100:gp;await C0(i)}return{js:t,jsm:r}}a(M0,"connectToRemoteJS");function Nee(){return Rp}a(Nee,"getDatabaseSubscriptions");var U0;function Iee(e){U0=e}a(Iee,"setIgnoreOrigin");var v0=100,I0=new Array(v0),mp=0;async function JR(e,t,r,n){let{connection:s}=await Tp.getNATSReferences();Ap=s,Sp=s.info.server_name;let i,o=1;for(;!i;)try{i=await t.consumers.get(e,Sp),jr.notify("Initializing ingest consumer for node:",n,"stream:",e)}catch(u){if(Zl.get(n)==="close")break;o%10===1&&jr.warn("Nats ingest error getting consumer:",n,"stream:",e,"Nats error:",u.message),u.code==="404"&&(jr.notify("Nats ingest creating consumer for node:",n,"stream:",e),i=await Tp.createConsumer(r,e,Sp,new Date(Date.now()).toISOString()));let d=o++*100<gp?o++*100:gp;await C0(d)}let c=!1,l;for(;!c;){if(F_.get(e+n)==="close"||Zl.get(n)==="close"){F_.delete(e+n),c=!0;continue}l=await i.consume({max_messages:zR.get(QR.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS)??100,bind:!0}),F_.set(e+n,l);let u=!1;(async()=>{for await(let d of await l.status())if(d.type===N0.ConsumerDeleted&&(await l.close(),c=!0),d.type===N0.HeartbeatsMissed){let _=d.data;jr.trace(`${_} clustering ingest consumer heartbeats missed, node: ${n} stream: ${l.consumer.stream}`),_===100&&(jr.warn(`Restarting clustering ingest consumer due to missed heartbeat threshold being met, node: ${n} stream: ${l.consumer.stream}`),l.stop(),u=!0)}})();try{for await(let d of l)await I0[mp],I0[mp]=wee(d).catch(_=>{jr.error(_)}),++mp>=v0&&(mp=0)}catch(d){d.message==="consumer deleted"?(jr.notify("Nats consumer deleted, closing messages for node:",n,"stream:",l.consumer.stream),await l.close(),c=!0):jr.error("Error consuming clustering ingest, restarting consumer",d)}}}a(JR,"ingestConsumer");async function wee(e){let t=hee(e.data);O0(e.data.length,"bytes-received",e.subject,t.operation,"ingest"),jr.trace("Nats message processor message size:",e?.msg?._msg?.size,"bytes");let r=e.headers,n=!1,s=zR.get(QR.CONFIG_PARAMS.CLUSTERING_NODENAME);r.has(Xl.MSG_HEADERS.TRANSACTED_NODES)&&r.values(Xl.MSG_HEADERS.TRANSACTED_NODES).indexOf(s)>-1&&(n=!0);let i=r.get(Xl.MSG_HEADERS.ORIGIN);if(n||(n=i===s&&!U0),See(n,"echo",e.subject,t.operation,"ingest"),n){e.ack();return}r.append(Xl.MSG_HEADERS.TRANSACTED_NODES,s);try{let{operation:o,schema:c,next:l,table:u,records:d,hash_values:_,__origin:E,expiresAt:f}=t;jr.trace("processing message:",o,c,u,(d?"records: "+d.map(U=>U?.id):"")+(_?"ids: "+_:""),"with sequence:",e.seq),jr.trace(`messageProcessor nats msg id: ${e.headers.get(Xl.MSG_HEADERS.NATS_MSG_ID)}`);let h;d||(d=_);let T=new Promise(U=>h=U),{timestamp:m,user:g,node_name:S}=E||{},y=Rp.get(c)?.get(u);if(!y)throw new Error(`Missing table for replication message: ${u}`);if(o==="define_schema")t.type=o,t.onCommit=h,y.send(t);else if(d.length===1&&!l)y.send({type:jR(o),value:d[0],id:_?.[0],expiresAt:f,timestamp:m,table:u,onCommit:h,user:g,nodeName:S});else{let U=d.map((H,X)=>({type:jR(o),value:H,expiresAt:f,id:_?.[X],table:u}));for(;l;)U.push({type:jR(l.operation),value:l.record,expiresAt:l.expiresAt,id:l.id,table:l.table}),l=l.next;y.send({type:"transaction",writes:U,table:u,timestamp:m,onCommit:h,user:g,nodeName:S})}zR.get(pee.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&Tee(e.subject.split(".").slice(0,-1).join("."),w0.createNatsTableStreamName(c,u),e.headers,e.data),await T;let I=Date.now()-m;m&&O0(I,"replication-latency",e.subject,o,"ingest")}catch(o){jr.error(o)}e.ack()}a(wee,"messageProcessor");function jR(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}a(jR,"convertOperation")});var mr=N(($Oe,Z0)=>{"use strict";var Or=se();Or.initSync();var Cee=require("fs-extra"),Pee=require("semver"),$_=require("path"),{monotonicFactory:Dee}=require("ulidx"),x0=Dee(),Lee=require("util"),k0=require("child_process"),Mee=Lee.promisify(k0.exec),Uee=k0.spawn,Pr=Ct(),Je=M(),yp=re(),js=j(),bp=Zi(),vee=fp(),G_=wt(),{broadcast:Bee,onMessageByType:Hee,getWorkerIndex:xee}=dt(),{isMainThread:F0}=require("worker_threads"),{Encoder:kee,decode:ry}=require("msgpackr"),G0=new kee,{isEmpty:yc}=yp,q0=xn(),xOe=48*36e11;F0&&Hee(Je.ITC_EVENT_TYPES.RESTART,()=>{zr=void 0,Rc=void 0});var{connect:Fee,StorageType:Gee,RetentionPolicy:qee,AckPolicy:ny,DeliverPolicy:sy,DiscardPolicy:$ee,NatsConnection:kOe,JetStreamManager:FOe,JetStreamClient:GOe,StringCodec:qOe,JSONCodec:Vee,createInbox:iy,headers:Kee,ErrorCode:H0}=require("nats"),{PACKAGE_ROOT:Yee}=M(),Wee=Jl(),{recordAction:jee}=(Ni(),oe(k_)),$0=Vee(),zee="clustering",Qee=Wee.engines[Pr.NATS_SERVER_NAME],Jee=$_.join(Yee,"dependencies"),ty=$_.join(Jee,`${process.platform}-${process.arch}`,Pr.NATS_BINARY_NAME),ZR,ey,q_,gc,Ac;Z0.exports={runCommand:V0,checkNATSServerInstalled:Xee,createConnection:oy,getConnection:V_,getJetStreamManager:K_,getJetStream:Y0,getNATSReferences:Ii,getServerList:ete,createLocalStream:ay,listStreams:W0,deleteLocalStream:tte,getServerConfig:eu,listRemoteStreams:rte,viewStream:nte,viewStreamIterator:ste,publishToStream:ite,request:cte,reloadNATS:cy,reloadNATSHub:lte,reloadNATSLeaf:ute,extractServerName:ate,requestErrorHandler:dte,createLocalTableStream:J0,createTableStreams:Ete,purgeTableStream:X0,purgeSchemaTableStreams:hte,getStreamInfo:pte,updateLocalStreams:Ste,closeConnection:Zee,getJsmServerName:Op,addNatsMsgHeader:j0,clearClientCache:K0,updateRemoteConsumer:_te,createConsumer:z0,updateConsumerIterator:fte};async function V0(e,t=void 0){let{stdout:r,stderr:n}=await Mee(e,{cwd:t});if(n)throw new Error(n.replace(`
13
13
  `,""));return r.replace(`
14
14
  `,"")}a(V0,"runCommand");async function Xee(){try{await Cee.access(ty)}catch{return!1}let e=await V0(`${ty} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return Pee.eq(t,Qee)}a(Xee,"checkNATSServerInstalled");async function oy(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let o=await q0.getClusterUser();if(yc(o))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=o.username,r=o.decrypt_hash}js.trace("create nats connection called");let i=await Fee({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:Or.get(Je.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:Or.get(Je.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:Or.get(Je.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),js.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(o=>{o&&js.error("Error with Nats client connection, connection closed",o),i===zr&&K0()}),i}a(oy,"createConnection");function K0(){zr=void 0,gc=void 0,Ac=void 0,Rc=void 0}a(K0,"clearClientCache");async function Zee(){zr&&(await zr.drain(),zr=void 0,gc=void 0,Ac=void 0,Rc=void 0)}a(Zee,"closeConnection");var zr,Rc;async function V_(){return Rc||(Rc=oy(Or.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),zr=await Rc),zr||Rc}a(V_,"getConnection");async function K_(){if(gc)return gc;yc(zr)&&await V_();let{domain:e}=eu(Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(yc(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return gc=await zr.jetstreamManager({domain:e,timeout:6e4}),gc}a(K_,"getJetStreamManager");async function Y0(){if(Ac)return Ac;yc(zr)&&await V_();let{domain:e}=eu(Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(yc(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return Ac=zr.jetstream({domain:e,timeout:6e4}),Ac}a(Y0,"getJetStream");async function Ii(){let e=zr||await V_(),t=gc||await K_(),r=Ac||await Y0();return{connection:e,jsm:t,js:r}}a(Ii,"getNATSReferences");async function ete(e){let t=Or.get(Je.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await q0.getClusterUser(),s=await oy(t,r,n),i=iy(),o=s.subscribe(i),c=[],l,u=(async()=>{for await(let d of o){let _=$0.decode(d.data);_.response_time=Date.now()-l,c.push(_)}})();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 yp.async_set_timeout(e),await o.drain(),await s.close(),await u,c}a(ete,"getServerList");async function ay(e,t){let{jsm:r}=await Ii(),n=Or.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Or.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=Or.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:Gee.File,retention:qee.Limits,subjects:t,discard:$ee.Old,max_msgs:s,max_bytes:i,max_age:n})}a(ay,"createLocalStream");async function W0(){let{jsm:e}=await Ii(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}a(W0,"listStreams");async function tte(e){let{jsm:t}=await Ii();await t.streams.delete(e)}a(tte,"deleteLocalStream");async function rte(e){let{connection:t}=await Ii(),r=[],n=iy(),s=t.subscribe(n),i=(async()=>{for await(let o of s)r.push($0.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(rte,"listRemoteStreams");async function nte(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Ii(),i=x0(),o={durable_name:i,ack_policy:ny.Explicit};t&&(o.deliver_policy=sy.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];let u=[];for await(let d of l){let _=ry(d.data),E={nats_timestamp:d.info.timestampNanos,nats_sequence:d.info.streamSequence,entry:_};if(d.headers&&(E.origin=d.headers.get(Pr.MSG_HEADERS.ORIGIN)),u.push(E),d.ack(),d.info.pending===0)break}return await c.delete(),u}a(nte,"viewStream");async function*ste(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Ii(),i=x0(),o={durable_name:i,ack_policy:ny.Explicit};t&&(o.deliver_policy=sy.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];for await(let u of l){let d=ry(u.data);d[0]||(d=[d]);for(let _ of d){let E={nats_timestamp:u.info.timestampNanos,nats_sequence:u.info.streamSequence,entry:_};u.headers&&(E.origin=u.headers.get(Pr.MSG_HEADERS.ORIGIN)),yield E}if(u.ack(),u.info.pending===0)break}await c.delete()}a(ste,"viewStreamIterator");async function ite(e,t,r,n){js.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=j0(n,r);let{js:s}=await Ii(),i=await Op(),o=`${e}.${i}`,c=n instanceof Uint8Array?n:G0.encode(n);try{js.trace(`publishToStream publishing to subject: ${o}`),jee(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 Q0(async()=>{try{await s.publish(o,c,{headers:r})}catch{if(l.code&&l.code.toString()==="503"){js.trace(`publishToStream creating stream: ${t}`);let d=o.split(".");d[2]="*",await ay(t,[o]),await s.publish(o,c,{headers:r})}else throw l}});throw l}}a(ite,"publishToStream");function j0(e,t){t===void 0&&(t=Kee());let r=Or.get(Je.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(Pr.MSG_HEADERS.ORIGIN)&&r&&t.append(Pr.MSG_HEADERS.ORIGIN,r),t}a(j0,"addNatsMsgHeader");function eu(e){e=e.toLowerCase();let t=$_.join(Or.get(Je.CONFIG_PARAMS.ROOTPATH),zee);if(e===Je.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return yc(ey)&&(ey={port:G_.getConfigFromFile(Je.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:G_.getConfigFromFile(Je.CONFIG_PARAMS.CLUSTERING_NODENAME)+Pr.SERVER_SUFFIX.HUB,config_file:Pr.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:$_.join(t,Pr.PID_FILES.HUB),hdb_nats_path:t}),ey;if(e===Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return yc(ZR)&&(ZR={port:G_.getConfigFromFile(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:G_.getConfigFromFile(Je.CONFIG_PARAMS.CLUSTERING_NODENAME)+Pr.SERVER_SUFFIX.LEAF,config_file:Pr.NATS_CONFIG_FILES.LEAF_SERVER,domain:G_.getConfigFromFile(Je.CONFIG_PARAMS.CLUSTERING_NODENAME)+Pr.SERVER_SUFFIX.LEAF,pid_file_path:$_.join(t,Pr.PID_FILES.LEAF),hdb_nats_path:t}),ZR;js.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(eu,"getServerConfig");async function z0(e,t,r,n){try{await e.consumers.add(t,{ack_policy:ny.Explicit,durable_name:r,deliver_policy:sy.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}a(z0,"createConsumer");async function ote(e,t,r){await e.consumers.delete(t,r)}a(ote,"removeConsumer");function ate(e){return e.split(".")[1]}a(ate,"extractServerName");async function cte(e,t,r=6e4,n=iy()){if(!yp.isObject(t))throw new Error("data param must be an object");let s=G0.encode(t),{connection:i}=await Ii(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return ry(c.data)}a(cte,"request");function cy(e){return new Promise(async(t,r)=>{let n=Uee(ty,["--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(cy,"reloadNATS");async function lte(){let{pid_file_path:e}=eu(Je.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await cy(e)}a(lte,"reloadNATSHub");async function ute(){let{pid_file_path:e}=eu(Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await cy(e)}a(ute,"reloadNATSLeaf");function dte(e,t,r){let n;switch(e.code){case H0.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case H0.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}a(dte,"requestErrorHandler");async function _te(e,t){let r=t+Pr.SERVER_SUFFIX.LEAF,{connection:n}=await Ii(),{jsm:s}=await gte(r),{schema:i,table:o}=e,c=bp.createNatsTableStreamName(i,o),l=e.start_time?e.start_time:new Date(Date.now()).toISOString();await Q0(async()=>{if(e.subscribe===!0)await z0(s,c,n.info.server_name,l);else try{await ote(s,c,n.info.server_name)}catch(u){js.trace(u)}})}a(_te,"updateRemoteConsumer");async function fte(e,t,r,n){let s=bp.createNatsTableStreamName(e,t),i=r+Pr.SERVER_SUFFIX.LEAF,o={type:Je.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!F0&&xee()<Or.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=XR();await c(o)}await Bee(o),n==="stop"&&await yp.async_set_timeout(1e3)}a(fte,"updateConsumerIterator");function Q0(e){return vee.writeTransaction(Je.SYSTEM_SCHEMA_NAME,Je.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(Q0,"exclusiveLock");async function J0(e,t){let r=bp.createNatsTableStreamName(e,t),n=await Op(),s=mte(e,t,n);await ay(r,[s])}a(J0,"createLocalTableStream");async function Ete(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await J0(n,s)}}a(Ete,"createTableStreams");async function X0(e,t,r=void 0){if(Or.get(Je.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=bp.createNatsTableStreamName(e,t),{domain:s}=eu(Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await V_()).jetstreamManager({domain:s,timeout:24e4})).streams.purge(n,r)}catch(n){if(n.message==="stream not found")js.warn(n);else throw n}}a(X0,"purgeTableStream");async function hte(e,t){if(Or.get(Je.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await X0(e,t[r])}a(hte,"purgeSchemaTableStreams");async function pte(e){return(await K_()).streams.info(e)}a(pte,"getStreamInfo");function mte(e,t,r){return`${Pr.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}a(mte,"createSubjectName");async function Op(){if(q_)return q_;if(q_=(await K_())?.nc?.info?.server_name,q_===void 0)throw new Error("Unable to get jetstream manager server name");return q_}a(Op,"getJsmServerName");async function Ste(){let e=await K_(),t=await Op(),r=await W0();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let o=Tte(n),c=i.split(".");if(c[c.length-1]===t&&!o||s.name==="__HARPERDB_WORK_QUEUE__")continue;let u=i.split(".");u[u.length-1]=t;let d=u.join(".");js.trace(`Updating stream subject name from: ${i} to: ${d}`),s.subjects[0]=d,await e.streams.update(s.name,s)}}a(Ste,"updateLocalStreams");function Tte(e){let{config:t}=e,r=!1,n=Or.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=Or.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=Or.get(Je.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(Tte,"updateStreamLimits");async function gte(e){let t,r;try{t=await zr.jetstream({domain:e}),r=await zr.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw js.error("Unable to connect to:",e),n}return{js:t,jsm:r}}a(gte,"connectToRemoteJS")});var bc=N(Ip=>{var Np=j();for(let e of["trace","debug","info","warn","error","fatal","notify"])Np.logsAtLevel(e)&&(Ip[e]=Np[e]);Ip.loggerWithTag=e=>Np.loggerWithTag(e,!0);Ip.setLogLevel=Np.setLogLevel});function ly(e){let t=e.get(wp),r=t?(0,tu.unpack)(t):null;r||(r={remoteNameToId:{}});let n=ot(),s=!1;r.nodeName=ot();let i=r.remoteNameToId;if(i[n]!==0){let o=0,c;for(let l in i){let u=i[l];u===0?c=l:u>o&&(o=u)}if(c){o++,i[c]=o;let l=[Symbol.for("seq"),o];e.rootStore.dbisDb.transactionSync(()=>{e.rootStore.dbisDb.get(l)||e.rootStore.dbisDb.putSync(l,{seqId:W_(e)??1,nodes:[]})})}i[n]=0,e.putSync(wp,(0,tu.pack)(r))}return r}function Y_(e){return ly(e).remoteNameToId}function tB(e,t,r){let n=ly(r),s=n.remoteNameToId,i=new Map,o=!1;for(let c in t){let l=t[c],u=s[c];if(u==null){let d=0;for(let _ in s){let E=s[_];E>d&&(d=E)}u=d+1,s[c]=u,o=!0}i.set(l,u)}return o&&r.putSync(wp,(0,tu.pack)(n)),i}function Cp(e,t){let r=ly(t),n=r.remoteNameToId,s=n[e];if(s==null){let i=0;for(let o in n){let c=n[o];c>i&&(i=c)}s=i+1,n[e]=s,t.putSync(wp,(0,tu.pack)(r))}return eB.info?.("The remote node name map",e,n,s),s}var eB,tu,wp,uy=Ie(()=>{eB=L(bc());us();tu=require("msgpackr"),wp=Symbol.for("remote-ids");a(ly,"getIdMappingRecord");a(Y_,"exportIdMapping");a(tB,"remoteToLocalNodeId");a(Cp,"getIdOfRemoteNode")});var Zo,dy=Ie(()=>{Zo=class{constructor(t){this.error=t}static{a(this,"ErrorResource")}isError=!0;allowRead(){throw this.error}allowUpdate(){throw this.error}allowCreate(){throw this.error}allowDelete(){throw this.error}getId(){throw this.error}getContext(){throw this.error}get(){throw this.error}post(){throw this.error}put(){throw this.error}delete(){throw this.error}connect(){throw this.error}getResource(){return this}publish(){throw this.error}subscribe(){throw this.error}}});var sB={};je(sB,{Resources:()=>Pp,keyArrayToString:()=>ru,resetResources:()=>Ate,resources:()=>wi});function Ate(){return wi=new Pp}function ru(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var rB,nB,Pp,wi,nu=Ie(()=>{mc();dy();rB=L(j()),nB=L(_e()),Pp=class extends Map{static{a(this,"Resources")}isWorker=!0;loginPath;set(t,r,n,s){if(!r)throw new Error("Must provide a resource");t.startsWith("/")&&(t=t.replace(/^\/+/,""));let i={Resource:r,path:t,exportTypes:n,hasSubPaths:!1,relativeURL:""},o=super.get(t);if(o&&(o.Resource.databaseName!==r.databaseName||o.Resource.tableName!==r.tableName)&&!s){let c=new nB.ServerError(`Conflicting paths for ${t}`);rB.default.error(c),i.Resource=new Zo(c)}super.set(t,i);for(let[c,l]of this){let u=2;for(;(u=c.indexOf("/",u))>-1;){let d=this.get(c.slice(0,u));d&&(d.hasSubPaths=!0),u+=2}}}getMatch(t,r){let n=2,s;for(;(n=t.indexOf("/",n))>-1;){let c=t.slice(0,n),l=this.get(c);if(!l&&c.indexOf(".")>-1){let u=c.split(".");l=this.get(u[0])}if(l&&(!r||l.exportTypes?.[r]!==!1)){if(l.relativeURL=t.slice(n),!l.hasSubPaths)return l;s=l}n+=2}if(s)return s;let i=t.indexOf("?"),o=i>-1?t.slice(0,i):t;return s=this.get(o),!s&&o.indexOf(".")>-1&&(s=this.get(o.split(".")[0])),s&&(!r||s.exportTypes?.[r]!==!1)?s.relativeURL=i>-1?t.slice(i):"":s||(s=this.get(""),s&&(!r||s.exportTypes?.[r]!==!1)&&(t[0]!=="/"&&(t="/"+t),s.relativeURL=t)),s}getResource(t,r){let n=this.getMatch(t);if(n)return t=n.relativeURL,n.Resource.getResource(this.pathToId(t,n.Resource),r)}call(t,r,n){return Pt(r,async()=>{let s=this.getMatch(t);if(s)return t=s.relativeURL,n(s.Resource,s.path,t)})}setRepresentation(t,r,n){}};a(Ate,"resetResources");a(ru,"keyArrayToString")});function Ey(e,t,r,n,s){let i=e.primaryStore.env.path,o=e.primaryStore.tableId,c;s?.crossThreads===!1?(c=oB,Rte(e.primaryStore,e.auditStore)):(c=iB,e.primaryStore.env.hasSubscriptionCommitListener||(e.primaryStore.env.hasSubscriptionCommitListener=!0,e.primaryStore.on("committed",()=>{aB(iB[i])})));let l=c[i]||(c[i]=[]);if(l.auditStore=e.auditStore,l.lastTxnTime==null&&(l.lastTxnTime=Date.now()),s?.scope==="full-database")return;let u=l[o];u||(u=l[o]=new Map,u.envs=l,u.tableId=o,u.store=e.primaryStore),t=ru(t);let d=new fy(r);d.startTime=n;let _=u.get(t);return _?_.push(d):(u.set(t,_=[d]),_.tables=u,_.key=t),d.subscriptions=_,d}function aB(e){if(!e)return;let t=e.auditStore;t.resetReadTxn(),cB(e.auditStore);let r;for(let{key:n,value:s}of t.getRange({start:e.lastTxnTime,exclusiveStart:!0})){e.lastTxnTime=n;let i=xt(s),o=e[i.tableId];if(!o)continue;let c=i.recordId,l=ru(c),u=0;do{let d=o.get(l);if(d){for(let E of d)if(!(u>0&&!(E.includeDescendants&&!(E.onlyChildren&&u>1)))){if(E.startTime>=n){(0,_y.info)("omitting",c,E.startTime,n);continue}try{let f;E.supportsTransactions&&E.txnInProgress!==i.version&&(f=!0,E.txnInProgress||(r?r.push(E):r=[E]),E.txnInProgress=i.version),E.listener(c,i,n,f)}catch(f){console.error(f),(0,_y.info)(f)}}}if(l==null)break;let _=l.lastIndexOf?.("/",l.length-2);_!==l.length-1&&u++,_>-1?l=l.slice(0,_+1):l=null}while(!0)}if(r)for(let n of r)n.txnInProgress=null,n.listener(null,{type:"end_txn"},e.lastTxnTime,!0)}function Rte(e,t){let r=t||e,n=r.env;if(!n.hasAfterCommitListener){n.hasAfterCommitListener=!0;let s=n.path;r.on("aftercommit",({next:i,last:o,txnId:c})=>{let l=oB[s];if(!l)return;let u=a(()=>{r.threadLocalWrites||(r.threadLocalWrites=new Float64Array(r.getUserSharedBuffer("last-thread-local-write",new ArrayBuffer(8)))),l.txnTime=r.threadLocalWrites[0]||Date.now();try{aB(l)}finally{r.threadLocalWrites[0]=l.lastTxnTime,r.unlock("thread-local-writes")}},"acquiredLock");r.attemptLock("thread-local-writes",u)&&u()})}}function cB(e){e.nextTransaction?.resolve();let t;e.nextTransaction=new Promise(r=>{t=r}),e.nextTransaction.resolve=t}function lB(e){return e.nextTransaction||(Ey({primaryStore:e,auditStore:e},null,null,0,{scope:"full-database"}),cB(e)),e.nextTransaction}var _y,iB,oB,fy,hy=Ie(()=>{_y=L(j());Dl();nu();zi();iB=Object.create(null),oB=Object.create(null);a(Ey,"addSubscription");fy=class extends Mn{static{a(this,"Subscription")}listener;subscriptions;startTime;constructor(t){super(),this.listener=t,this.on("close",()=>this.end())}end(){if(this.subscriptions){if(this.subscriptions.splice(this.subscriptions.indexOf(this),1),this.subscriptions.length===0){let t=this.subscriptions.tables;if(t){let r=this.subscriptions.key;if(t.delete(r),t.size===0){let n=t.envs,s=t.dbi;delete n[s]}}}this.subscriptions=null}}toJSON(){return{name:"subscription"}}};a(aB,"notifyFromTransactionData");a(Rte,"listenToCommits");a(cB,"nextTransaction");a(lB,"whenNextTransaction")});var hB={};je(hB,{commits_awaiting_replication:()=>ou,getHDBNodeTable:()=>Sr,iterateRoutes:()=>z_,shouldReplicateToNode:()=>j_,subscribeToNodeUpdates:()=>au});function Sr(){return uB||(uB=Et({table:"hdb_nodes",database:"system",attributes:[{name:"name",isPrimaryKey:!0},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"url"},{attribute:"routes"},{attribute:"ca"},{attribute:"ca_info"},{attribute:"replicates"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]}))}function au(e){Sr().subscribe({}).then(async t=>{for await(let r of t){let n=r?.value?.name;EB.debug?.("adding node",n,"on node",ot()," on process",process.pid),server.nodes=server.nodes.filter(s=>s.name!==n),r.type==="put"&&n!==ot()&&(r.value?server.nodes.push(r.value):console.error("Invalid node update event",r)),(r.type==="put"||r.type==="delete")&&e(r.value,r.id)}})}function j_(e,t){return(e.replicates===!0||e.replicates?.sends)&&databases[t]&&Sr().primaryStore.get(ot())?.replicates||e.subscriptions?.some(r=>(r.database||r.schema)===t&&r.subscribe)}function yte(){au(e=>{ea({},(t,r)=>{let n=e.name,s=dB.get(n);if(s||dB.set(n,s=new Map),s.has(r))return;let i;for(let o in t)if(i=t[o].auditStore,i)break;if(i){let o=new Float64Array(i.getUserSharedBuffer(["replicated",r,n],new ArrayBuffer(8),{callback:a(()=>{let c=o[0],l=o.lastTime;for(let{txnTime:u,onConfirm:d}of ou.get(r)||[])u>l&&u<=c&&d();o.lastTime=c},"callback")}));o.lastTime=0,s.set(r,o)}})})}function*z_(e){for(let t of e.routes||[]){let r=t.url,n;if(typeof t=="string"?t.includes("://")?r=t:n=t:n=t.hostname??t.host,n&&!r){let s=su.default.get(iu.CONFIG_PARAMS.REPLICATION_SECUREPORT)??(!su.default.get(iu.CONFIG_PARAMS.REPLICATION_PORT)&&su.default.get(iu.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_SECUREPORT)),i;(i=n.match(/:(\d+)$/)?.[1])?n=n.slice(0,-i[0].length-1):t.port?i=t.port:i=s||su.default.get(iu.CONFIG_PARAMS.REPLICATION_PORT)||su.default.get(iu.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT);let o=i?.lastIndexOf?.(":");o>0&&(i=+i.slice(o+1).replace(/[\[\]]/g,"")),r=(s?"wss://":"ws://")+n+":"+i}if(!r){_B.isMainThread&&console.error("Invalid route, must specify a url or host (with port)");continue}yield{replicates:!t.subscriptions,url:r,subscription:t.subscriptions,routes:t.routes,start_time:t.startTime}}}var _B,fB,su,iu,EB,uB,dB,ou,cu=Ie(()=>{De();us();op();_B=require("worker_threads"),fB=L(_e()),su=L(se()),iu=L(M()),EB=L(bc());server.nodes=[];a(Sr,"getHDBNodeTable");a(au,"subscribeToNodeUpdates");a(j_,"shouldReplicateToNode");dB=new Map;Av((e,t,r)=>{if(r>server.nodes.length)throw new fB.ClientError(`Cannot confirm replication to more nodes (${r}) than are in the network (${server.nodes.length})`);ou||(ou=new Map,yte());let n=ou.get(e);return n||(n=[],ou.set(e,n)),new Promise(s=>{let i=0;n.push({txnTime:t,onConfirm:a(()=>{++i===r&&s()},"onConfirm")})})});a(yte,"startSubscriptionToReplications");a(z_,"iterateRoutes")});var gB={};je(gB,{connectedToNode:()=>Oc,disconnectedFromNode:()=>du,ensureNode:()=>oo,requestClusterStatus:()=>TB,startOnMainThread:()=>my});async function my(e){let t=0,r=ut();for(let i of Object.getOwnPropertyNames(r)){let o=r[i];for(let c in o){let l=o[c];if(l.auditStore){Dp.set(i,W_(l.auditStore));break}}}Ci.whenThreadsStarted.then(async()=>{let i=[];for await(let o of r.system.hdb_nodes.search([]))i.push(o);for(let o of z_(e))try{let c=!o.subscriptions;if(c){let u=ot();Sr().primaryStore.get(u)===void 0&&await oo(u,{name:u,url:e.url??ta(),replicates:!0})}let l=o.trusted!==!1;if(c&&o.replicates==null&&(o.replicates=!0),i.find(u=>u.url===o.url))continue;s(o)}catch(c){console.error(c)}au(s)});let n;function s(i,o=i?.name){let c=ot()&&o===ot()||ta()&&i?.url===ta();if(c){let _=!!i?.replicates;if(n!==void 0&&n!==_)for(let E of Sr().search([]))E.replicates&&E.name!==o&&s(E,E.name);n=_}if(_t.trace("Setting up node replication for",i),!i){for(let[_,E]of io){let f;for(let[h,{worker:T,nodes:m}]of E){let g=m[0];if(g&&g.name==o){f=!0;for(let[S,{worker:y}]of E)E.delete(S),_t.warn("Node was deleted, unsubscribing from node",o,S,_),y?.postMessage({type:"unsubscribe-from-node",node:o,database:S,url:_});break}}if(f){io.get(_).iterator.remove(),io.delete(_);return}}return}if(c)return;if(!i.url){_t.info(`Node ${i.name} is missing url`);return}let l=io.get(i.url);if(l&&l.iterator.remove(),!(i.replicates===!0||i.replicates?.sends)&&!i.subscriptions?.length&&!l)return;if(_t.info(`Added node ${i.name} at ${i.url} for process ${ot()}`),i.replicates&&i.subscriptions&&(i={...i,subscriptions:null}),i.name){for(let[_,E]of lu)if(i.url===E.url){lu.delete(_);break}lu.set(i.name,i)}let u=ut();if(l||(l=new Map,io.set(i.url,l)),l.iterator=ea(e,(_,E,f)=>{f?d(E,!0):d(E,!1)}),i.subscriptions)for(let _ of i.subscriptions){let E=_.database||_.schema;u[E]||(_t.warn(`Database ${E} not found for node ${i.name}, making a subscription anyway`),d(E,!1))}function d(_,E){_t.trace("Setting up replication for database",_,"on node",i.name);let f=l.get(_),h,T=[{replicateByDefault:E,...i}];Dp.has(_)&&(T.push({replicateByDefault:E,name:ot(),start_time:Dp.get(_),end_time:Date.now(),replicates:!0}),Dp.delete(_));let m=j_(i,_),g=Ci.workers.filter(S=>S.name==="http");if(f?(h=f.worker,f.nodes=T):m&&(t=t%g.length,h=g[t++],l.set(_,{worker:h,nodes:T,url:i.url}),h?.on("exit",()=>{l.get(_)?.worker===h&&(l.delete(_),d(_,E))})),m)setTimeout(()=>{let S={type:"subscribe-to-node",database:_,nodes:T};h?h.postMessage(S):uu(S)},bte);else{_t.info("Node no longer should be used, unsubscribing from node",i.replicates,!!u[_],Sr().primaryStore.get(ot())?.replicates),Sr().primaryStore.get(ot())?.replicates||(n=!1);let S={type:"unsubscribe-from-node",database:_,url:i.url,name:i.name};h?h.postMessage(S):Mp(S)}}a(d,"onDatabase")}a(s,"onNodeUpdate"),du=a(function(i){try{_t.info("Disconnected from node",i.name,i.url,"finished",!!i.finished);let o=Array.from(lu.keys()),c=o.sort(),l=c.indexOf(i.name||zs(i.url));if(l===-1){_t.warn("Disconnected node not found in node map",i.name,o);return}let u=io.get(i.url),d=u?.get(i.database);if(!d){_t.warn("Disconnected node not found in replication map",i.database,u);return}if(d.connected=!1,i.finished)return;let _=d.nodes[0];if(!(_.replicates===!0||_.replicates?.sends||_.subscriptions?.length))return;let E=(l+1)%c.length;for(;l!==E;){let f=c[E],h=lu.get(f);u=io.get(h.url);let T=u?.get(i.database);if(!T){E=(E+1)%c.length;continue}let{worker:m,nodes:g}=T,S=!1;for(let y of d.nodes){if(g.some(I=>I.name===y.name)){_t.info(`Disconnected node is already failing over to ${f} for ${i.database}`);continue}g.push(y),S=!0}if(!S){_t.info(`Disconnected node ${i.name} has no nodes to fail over to ${f}`);return}d.redirectingTo=T,_t.info(`Failing over ${i.database} from ${i.name} to ${f}`),m?m.postMessage({type:"subscribe-to-node",database:i.database,nodes:g}):uu({database:i.database,nodes:g});return}_t.warn("Unable to find any other node to fail over to",i.name,i.url)}catch(o){_t.error("Error failing over node",o)}},"disconnectedFromNode"),Oc=a(function(i){let o=io.get(i.url),c=o?.get(i.database);if(!c){_t.warn("Connected node not found in replication map, this may be because the node is being removed",i.database,o);return}if(c.connected=!0,c.latency=i.latency,c.catchingUpFrom=i.lastSendTime,c.redirectingTo){let{worker:l,nodes:u}=c.redirectingTo,d=u.find(_=>_.name===i.name);c.redirectingTo=null,d&&(u.splice(u.indexOf(d),1),l?l.postMessage({type:"subscribe-to-node",database:i.database,nodes:u}):uu({database:i.database,nodes:u}))}},"connectedToNode"),(0,Ci.onMessageByType)("disconnected-from-node",du),(0,Ci.onMessageByType)("connected-to-node",Oc),(0,Ci.onMessageByType)("request-cluster-status",TB)}function TB(e,t){let r=[];for(let[n,s]of lu)try{let i=io.get(s.url);_t.info("Getting cluster status for",n,s.url,"has dbs",i?.size);let o=[];if(i){for(let[l,{worker:u,connected:d,nodes:_,latency:E,catchingUpFrom:f}]of i)o.push({database:l,connected:d,latency:E,catching_up_from:f?new Date(f).toISOString():"up-to-date",thread_id:u?.threadId,nodes:_.map(h=>h.name)});let c=(0,py.cloneDeep)(s);c.database_sockets=o,delete c.ca,delete c.node_name,delete c.__updatedtime__,delete c.__createdtime__,r.push(c)}}catch(i){_t.warn("Error getting cluster status for",s?.url,i)}return t?.postMessage({type:"cluster-status",connections:r}),{connections:r}}async function oo(e,t){let r=Sr();e=e??zs(t.url),t.name=e;try{if(t.ca){let s=new SB.X509Certificate(t.ca);t.ca_info={issuer:s.issuer.replace(/\n/g," "),subject:s.subject.replace(/\n/g," "),subject_alt_name:s.subjectAltName,serial_number:s.serialNumber,valid_from:s.validFrom,valid_to:s.validTo}}}catch(s){_t.error("Error parsing replication CA info for hdb_nodes table",s.message)}let n=r.primaryStore.get(e);if(_t.debug(`Ensuring node ${e} at ${t.url}, existing record:`,n,"new record:",t),!n)await r.put(t);else{t.replicates&&!pB.default.get(mB.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(t.subscriptions=null);for(let s in t)if(n[s]!==t[s]&&s==="subscriptions"&&t[s]&&n[s]){let i=[],o=(0,py.cloneDeep)(n[s]);for(let c of t[s]){let l=!1;for(let u of o)if((c.database??c.schema)===(u.database??u.schema)&&c.table===u.table){u.publish=c.publish,u.subscribe=c.subscribe,l=!0;break}l||i.push(c)}t.subscriptions=[...o,...i];break}_t.info(`Updating node ${e} at ${t.url}`),await r.patch(t)}}var Ci,Lp,_t,py,pB,mB,SB,bte,io,du,Oc,lu,Dp,Q_=Ie(()=>{De();Ci=L(dt());us();Lp=require("worker_threads");cu();_t=L(j()),py=require("lodash"),pB=L(se()),mB=L(M()),SB=require("crypto"),bte=200,io=new Map,lu=new Map,Dp=new Map;a(my,"startOnMainThread");a(TB,"requestClusterStatus");Lp.parentPort&&(du=a(e=>{Lp.parentPort.postMessage({type:"disconnected-from-node",...e})},"disconnectedFromNode"),Oc=a(e=>{Lp.parentPort.postMessage({type:"connected-to-node",...e})},"connectedToNode"),(0,Ci.onMessageByType)("subscribe-to-node",e=>{uu(e)}),(0,Ci.onMessageByType)("unsubscribe-from-node",e=>{Mp(e)}));a(oo,"ensureNode")});var Up=N((mNe,AB)=>{"use strict";var Ote=M().OPERATIONS_ENUM,Sy=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=Ote.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};AB.exports=Sy});var yB=N((TNe,RB)=>{"use strict";var Nte={OPERATION:"operation",REFRESH:"refresh"},Ty=class{static{a(this,"JWTTokens")}constructor(t,r){this.operation_token=t,this.refresh_token=r}},gy=class{static{a(this,"JWTRSAKeys")}constructor(t,r,n){this.public_key=t,this.private_key=r,this.passphrase=n}};RB.exports={JWTTokens:Ty,TOKEN_TYPE_ENUM:Nte,JWTRSAKeys:gy}});var _u=N((ANe,IB)=>{"use strict";var X_=require("jsonwebtoken"),Ay=require("fs-extra"),Ry=re(),ds=M(),{handleHDBError:fn,hdb_errors:Ite}=_e(),{HTTP_STATUS_CODES:En,AUTHENTICATION_ERROR_MSGS:hn}=Ite,J_=j(),bB=qh(),Oy=xn(),wte=un().update,Cte=Up(),Pte=to(),{UserEventMsg:Dte}=qs(),ra=se();ra.initSync();var yy=require("path"),{JWTTokens:Lte,JWTRSAKeys:Mte,TOKEN_TYPE_ENUM:vp}=yB(),Ute=ra.get(ds.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY)?ra.get(ds.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY):"1d",vte=ra.get(ds.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY)?ra.get(ds.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY):"30d",Bp="RS256",by;IB.exports={createTokens:Bte,validateOperationToken:xte,refreshOperationToken:Hte,validateRefreshToken:NB,getJWTRSAKeys:Z_};async function Bte(e){if(Ry.isEmpty(e)||typeof e!="object")throw fn(new Error,hn.INVALID_AUTH_OBJECT,En.BAD_REQUEST,void 0,void 0,!0);if(Ry.isEmpty(e.username))throw fn(new Error,hn.USERNAME_REQUIRED,En.BAD_REQUEST,void 0,void 0,!0);if(Ry.isEmpty(e.password))throw fn(new Error,hn.PASSWORD_REQUIRED,En.BAD_REQUEST,void 0,void 0,!0);let t;try{if(t=await Oy.findAndValidateUser(e.username,e.password),!t)throw fn(new Error,hn.INVALID_CREDENTIALS,En.UNAUTHORIZED,void 0,void 0,!0)}catch(E){throw J_.error(E),fn(new Error,hn.INVALID_CREDENTIALS,En.UNAUTHORIZED,void 0,void 0,!0)}let r=await Z_(),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 OB(i,r.private_key,r.passphrase),c=await X_.sign(i,{key:r.private_key,passphrase:r.passphrase},{expiresIn:vte,algorithm:Bp,subject:vp.REFRESH}),l=bB.hash(c),u=new Cte(ds.SYSTEM_SCHEMA_NAME,ds.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,[{username:e.username,refresh_token:l}]),d,_;try{d=await wte(u)}catch(E){J_.error(E),_=E}if(_!==void 0||d.skipped_hashes.length>0)throw fn(new Error,hn.REFRESH_TOKEN_SAVE_FAILED,En.INTERNAL_SERVER_ERROR);return Pte.signalUserChange(new Dte(process.pid)),new Lte(o,c)}a(Bte,"createTokens");async function OB(e,t,r){return await X_.sign(e,{key:t,passphrase:r},{expiresIn:Ute,algorithm:Bp,subject:vp.OPERATION})}a(OB,"signOperationToken");async function Z_(){if(by===void 0)try{let e=yy.join(ra.getHdbBasePath(),ds.LICENSE_KEY_DIR_NAME,ds.JWT_ENUM.JWT_PASSPHRASE_NAME),t=yy.join(ra.getHdbBasePath(),ds.LICENSE_KEY_DIR_NAME,ds.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r=yy.join(ra.getHdbBasePath(),ds.LICENSE_KEY_DIR_NAME,ds.JWT_ENUM.JWT_PUBLIC_KEY_NAME),n=(await Ay.readFile(e)).toString(),s=(await Ay.readFile(t)).toString(),i=(await Ay.readFile(r)).toString();by=new Mte(i,s,n)}catch(e){throw J_.error(e),fn(new Error,hn.NO_ENCRYPTION_KEYS,En.INTERNAL_SERVER_ERROR)}return by}a(Z_,"getJWTRSAKeys");async function Hte(e){if(!e)throw fn(new Error,hn.INVALID_BODY,En.BAD_REQUEST,void 0,void 0,!0);if(!e.refresh_token)throw fn(new Error,hn.REFRESH_TOKEN_REQUIRED,En.BAD_REQUEST,void 0,void 0,!0);await NB(e.refresh_token);let t=await Z_(),r=await X_.decode(e.refresh_token);return{operation_token:await OB({username:r.username,super_user:r.super_user,cluster_user:r.cluster_user},t.private_key,t.passphrase)}}a(Hte,"refreshOperationToken");async function xte(e){try{let t=await Z_(),r=await X_.verify(e,t.public_key,{algorithms:Bp,subject:vp.OPERATION});return await Oy.findAndValidateUser(r.username,void 0,!1)}catch(t){throw J_.warn(t),t.name&&t.name==="TokenExpiredError"?fn(new Error,hn.TOKEN_EXPIRED,En.FORBIDDEN):fn(new Error,hn.INVALID_TOKEN,En.UNAUTHORIZED)}}a(xte,"validateOperationToken");async function NB(e){let t;try{let r=await Z_(),n=await X_.verify(e,r.public_key,{algorithms:Bp,subject:vp.REFRESH});t=await Oy.findAndValidateUser(n.username,void 0,!1)}catch(r){throw J_.warn(r),r.name&&r.name==="TokenExpiredError"?fn(new Error,hn.TOKEN_EXPIRED,En.FORBIDDEN):fn(new Error,hn.INVALID_TOKEN,En.UNAUTHORIZED)}if(!bB.validate(t.refresh_token,e))throw fn(new Error,hn.INVALID_TOKEN,En.UNAUTHORIZED);return t}a(NB,"validateRefreshToken")});var Xs=N(XB=>{"use strict";var sr=require("path"),{watch:kte}=require("chokidar"),pn=require("fs-extra"),fu=require("node-forge"),UB=require("net"),{generateKeyPair:Iy,X509Certificate:ao,createPrivateKey:vB}=require("crypto"),Fte=require("util");Iy=Fte.promisify(Iy);var yt=fu.pki,Qs=require("joi"),{v4:BB}=require("uuid"),{validateBySchema:Dy}=Tt(),pt=j(),_s=se(),Es=M(),{CONFIG_PARAMS:Eu}=Es,Js=pg(),{ClientError:sa}=_e(),Ic=require("node:tls"),{relative:HB,join:Gte}=require("node:path"),{CERT_PREFERENCE_APP:yNe,CERTIFICATE_VALUES:wB}=Js,qte=Wa(),wy=wt(),CB=parseInt(process.version.slice(1))<20,{table:$te,getDatabases:Vte,databases:Ny}=(De(),oe(lt)),{getJWTRSAKeys:PB}=_u();Object.assign(XB,{generateKeys:Uy,updateConfigCert:KB,createCsr:Jte,signCertificate:Xte,setCertTable:hu,loadCertificates:qB,reviewSelfSignedCert:By,createTLSSelector:jB,listCertificates:QB,addCertificate:sre,removeCertificate:ore,createNatsCerts:tre,generateCertsKeys:ere,getReplicationCert:tf,getReplicationCertAuth:Qte,renewSelfSigned:rre,hostnamesFromCert:JB,getKey:are});var{urlToNodeName:xB,getThisNodeUrl:Kte,getThisNodeName:xp,clearThisNodeName:Yte}=(us(),oe(aa)),{readFileSync:Wte,statSync:kB}=require("node:fs"),bNe=se(),{getTicketKeys:jte,onMessageFromWorkers:zte}=dt(),na=j(),{isMainThread:FB}=require("worker_threads"),{TLSSocket:GB,createSecureContext:ONe}=require("node:tls"),Ly=3650,ef=["127.0.0.1","localhost","::1"],My=[{name:"countryName",value:"USA"},{name:"stateOrProvinceName",value:"Colorado"},{name:"localityName",value:"Denver"},{name:"organizationName",value:"HarperDB, Inc."}];zte(async e=>{e.type===Es.ITC_EVENT_TYPES.RESTART&&(_s.initSync(!0),await By())});var Dr;function oa(){return Dr||(Dr=Vte().system.hdb_certificate,Dr||(Dr=$te({table:"hdb_certificate",database:"system",attributes:[{name:"name",isPrimaryKey:!0},{attribute:"uses"},{attribute:"certificate"},{attribute:"is_authority"},{attribute:"private_key_name"},{attribute:"details"},{attribute:"is_self_signed"},{attribute:"__updatedtime__"}]}))),Dr}a(oa,"getCertTable");async function tf(){let e=jB("operations-api"),t={secureContexts:null,setSecureContext:a(s=>{},"setSecureContext")};await e.initialize(t);let r=t.secureContexts.get(xp());if(!r)return;let n=new ao(r.options.cert);return r.cert_parsed=n,r.issuer=n.issuer,r}a(tf,"getReplicationCert");async function Qte(){oa();let e=(await tf()).options.cert,r=new ao(e).issuer.match(/CN=(.*)/)?.[1];return Dr.get(r)}a(Qte,"getReplicationCertAuth");var DB,ia=new Map;function qB(){if(DB)return;DB=!0;let e=[{configKey:Eu.TLS},{configKey:Eu.OPERATIONSAPI_TLS}];oa();let t=sr.dirname(wy.getConfigFilePath()),r;for(let{configKey:n}of e){let s=wy.getConfigFromFile(n);if(s){Array.isArray(s)||(s=[s]);for(let i of s){let o=i.privateKey,c=o&&HB(Gte(t,"keys"),o);c&&LB(o,l=>{ia.set(c,l)},"private key");for(let l of[!1,!0]){let u=i[l?"certificateAuthority":"certificate"];if(u&&FB){let d;LB(u,_=>{if(wB.cert===_)return;let E=i.hostname??i.hostnames??i.host??i.hosts;E&&!Array.isArray(E)&&(E=[E]);let f=YB(u),h=new ao(f),T;try{T=Hy(h)}catch(y){pt.error("error extracting common name from certificate",y);return}if(T==null){pt.error("error extracting common name from certificate");return}if(h.checkIssued(new ao(wB.cert)))return;let m=Dr.primaryStore.get(T),g=kB(u).mtimeMs,S=!m||m.is_self_signed?1:m.file_timestamp??m.__updatedtime__;if(m&&g<=S){g<S&&pt.info(`Certificate ${T} at ${u} is older (${new Date(g)}) than the certificate in the database (${S>1?new Date(S):"only self signed certificate available"})`);return}r=Dr.put({name:T,uses:["https",...n.includes("operations")?["operations"]:[]],ciphers:i.ciphers,certificate:f,private_key_name:c,is_authority:l,hostnames:E,file_timestamp:g,details:{issuer:h.issuer.replace(/\n/g," "),subject:h.subject.replace(/\n/g," "),subject_alt_name:h.subjectAltName,serial_number:h.serialNumber,valid_from:h.validFrom,valid_to:h.validTo}})},l?"certificate authority":"certificate")}}}}}return r}a(qB,"loadCertificates");function LB(e,t,r){let n,s=a((i,o)=>{try{let c=o.mtimeMs;c&&c!==n&&(n&&FB&&pt.warn(`Reloading ${r}:`,i),n=c,t(YB(i)))}catch(c){pt.error(`Error loading ${r}:`,i,c)}},"loadFile");pn.existsSync(e)?s(e,kB(e)):pt.error(`${r} file not found:`,e),kte(e,{persistent:!1}).on("change",s)}a(LB,"loadAndWatch");function Cy(){let e=Kte();if(e==null){let t=ef[0];return pt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return xB(e)}a(Cy,"getHost");function Hp(){let e=xp();if(e==null){let t=ef[0];return pt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return e}a(Hp,"getCommonName");async function Jte(){let e=await tf(),t=yt.certificateFromPem(e.options.cert),r=yt.privateKeyFromPem(e.options.key);pt.info("Creating CSR with cert named:",e.name);let n=yt.createCertificationRequest();n.publicKey=t.publicKey;let s=[{name:"commonName",value:Hp()},...My];pt.info("Creating CSR with subject",s),n.setSubject(s);let i=[{name:"unstructuredName",value:"HarperDB, Inc."},{name:"extensionRequest",extensions:$B()}];return pt.info("Creating CSR with attributes",i),n.setAttributes(i),n.sign(r),fu.pki.certificationRequestToPem(n)}a(Jte,"createCsr");function $B(){let e=ef.includes(Hp())?ef:[...ef,Hp()];return e.includes(Cy())||e.push(Cy()),[{name:"basicConstraints",cA:!1,critical:!0},{name:"keyUsage",digitalSignature:!0,keyEncipherment:!0,critical:!0},{name:"extKeyUsage",serverAuth:!0,clientAuth:!0},{name:"nsCertType",client:!0,server:!0},{name:"subjectAltName",altNames:e.map(t=>UB.isIP(t)?{type:7,ip:t}:{type:2,value:t})}]}a($B,"certExtensions");async function Xte(e){let t={},r=sr.join(_s.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME);if(e.csr){let n,s;oa();for await(let d of Dr.search([]))if(d.is_authority&&!d.details.issuer.includes("HarperDB-Certificate-Authority")){if(ia.has(d.private_key_name)){n=ia.get(d.private_key_name),s=d;break}else if(d.private_key_name&&await pn.exists(sr.join(r,d.private_key_name))){n=pn.readFile(sr.join(r,d.private_key_name)),s=d;break}}if(!n){let d=await Py();s=d.ca,n=d.private_key}n=yt.privateKeyFromPem(n),t.signingCA=s.certificate;let i=yt.certificateFromPem(s.certificate);pt.info("Signing CSR with cert named",s.name);let o=yt.certificationRequestFromPem(e.csr);try{o.verify()}catch(d){return pt.error(d),new Error("Error verifying CSR: "+d.message)}let c=fu.pki.createCertificate();c.serialNumber=Math.random().toString().slice(2,10),c.validity.notBefore=new Date;let l=new Date;c.validity.notAfter=l,c.validity.notAfter.setDate(l.getDate()+Ly),pt.info("sign cert setting validity:",c.validity),pt.info("sign cert setting subject from CSR:",o.subject.attributes),c.setSubject(o.subject.attributes),pt.info("sign cert setting issuer:",i.subject.attributes),c.setIssuer(i.subject.attributes);let u=o.getAttribute({name:"extensionRequest"}).extensions;pt.info("sign cert adding extensions from CSR:",u),c.setExtensions(u),c.publicKey=o.publicKey,c.sign(n,fu.md.sha256.create()),t.certificate=yt.certificateToPem(c)}else pt.info("Sign cert did not receive a CSR from:",e.url,"only the CA will be returned");return t}a(Xte,"signCertificate");async function Zte(e,t){await hu({name:xp(),uses:["https","wss"],certificate:e,private_key_name:"privateKey.pem",is_authority:!1,is_self_signed:!0}),await hu({name:t.subject.getField("CN").value,uses:["https","wss"],certificate:yt.certificateToPem(t),private_key_name:"privateKey.pem",is_authority:!0,is_self_signed:!0})}a(Zte,"createCertificateTable");async function hu(e){let t=new ao(e.certificate);e.details={issuer:t.issuer.replace(/\n/g," "),subject:t.subject.replace(/\n/g," "),subject_alt_name:t.subjectAltName,serial_number:t.serialNumber,valid_from:t.validFrom,valid_to:t.validTo},oa(),await Dr.patch(e)}a(hu,"setCertTable");async function Uy(){let e=await Iy("rsa",{modulusLength:4096,publicKeyEncoding:{type:"spki",format:"pem"},privateKeyEncoding:{type:"pkcs8",format:"pem"}});return{public_key:yt.publicKeyFromPem(e.publicKey),private_key:yt.privateKeyFromPem(e.privateKey)}}a(Uy,"generateKeys");async function vy(e,t,r){let n=yt.createCertificate();if(!t){let o=await tf();t=yt.certificateFromPem(o.options.cert).publicKey}n.publicKey=t,n.serialNumber=Math.random().toString().slice(2,10),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+Ly);let i=[{name:"commonName",value:Hp()},...My];return n.setSubject(i),n.setIssuer(r.subject.attributes),n.setExtensions($B()),n.sign(e,fu.md.sha256.create()),yt.certificateToPem(n)}a(vy,"generateCertificates");async function Py(){let e=await QB(),t;for(let r of e){if(!r.is_authority)continue;let n=await zB(r.private_key_name);if(r.private_key_name&&n&&new ao(r.certificate).checkPrivateKey(vB(n))){pt.trace(`CA named: ${r.name} found with matching private key`),t={ca:r,private_key:n};break}}if(t)return t;pt.trace("No CA found with matching private key")}a(Py,"getCertAuthority");async function VB(e,t,r=!0){let n=yt.createCertificate();n.publicKey=t,n.serialNumber=Math.random().toString().slice(2,10),n.validity.notBefore=new Date;let s=new Date;n.validity.notAfter=s,n.validity.notAfter.setDate(s.getDate()+Ly);let i=[{name:"commonName",value:`HarperDB-Certificate-Authority-${_s.get(Eu.REPLICATION_HOSTNAME)??xB(_s.get(Eu.REPLICATION_URL))??BB().split("-")[0]}`},...My];n.setSubject(i),n.setIssuer(i),n.setExtensions([{name:"basicConstraints",cA:!0,critical:!0},{name:"keyUsage",keyCertSign:!0,critical:!0}]),n.sign(e,fu.md.sha256.create());let o=sr.join(_s.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME),c=sr.join(o,Js.PRIVATEKEY_PEM_NAME);return r&&await pn.writeFile(c,yt.privateKeyToPem(e)),n}a(VB,"generateCertAuthority");async function ere(){let{private_key:e,public_key:t}=await Uy(),r=await VB(e,t),n=await vy(e,t,r);await Zte(n,r),KB()}a(ere,"generateCertsKeys");async function tre(){let e=await vy(yt.privateKeyFromPem(Js.CERTIFICATE_VALUES.key),void 0,yt.certificateFromPem(Js.CERTIFICATE_VALUES.cert)),t=sr.join(_s.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME),r=sr.join(t,Js.NATS_CERTIFICATE_PEM_NAME);await pn.exists(r)||await pn.writeFile(r,e);let n=sr.join(t,Js.NATS_CA_PEM_NAME);await pn.exists(n)||await pn.writeFile(n,Js.CERTIFICATE_VALUES.cert)}a(tre,"createNatsCerts");async function rre(){oa();for await(let e of Dr.search([{attribute:"is_self_signed",value:!0}]))await Dr.delete(e.name);await By()}a(rre,"renewSelfSigned");async function By(){Yte(),await qB(),oa();let e=await Py();if(!e){pt.notify("A matching Certificate Authority and key was not found. A new CA will be created in advance, so it's available if needed.");let r=_s.get(Eu.TLS_PRIVATEKEY),n=sr.join(_s.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME),s,i=HB(n,r);try{s=yt.privateKeyFromPem(await pn.readFile(r))}catch(c){pt.warn("Unable to parse the TLS key",r,"A new key will be generated and used to create Certificate Authority",c),{private_key:s}=await Uy(),await pn.exists(sr.join(n,Js.PRIVATEKEY_PEM_NAME))&&(i=`privateKey${BB().split("-")[0]}.pem`),await pn.writeFile(sr.join(n,i),yt.privateKeyToPem(s))}let o=await VB(s,yt.setRsaPublicKey(s.n,s.e),!1);await hu({name:o.subject.getField("CN").value,uses:["https"],certificate:yt.certificateToPem(o),private_key_name:i,is_authority:!0,is_self_signed:!0})}if(!await tf()){let r=xp();pt.notify(`A suitable replication certificate was not found, creating new self singed cert named: ${r}`),e=e??await Py();let n=yt.certificateFromPem(e.ca.certificate),s=n.publicKey,i=await vy(yt.privateKeyFromPem(e.private_key),s,n);await hu({name:r,uses:["https","operations","wss"],certificate:i,is_authority:!1,private_key_name:e.ca.private_key_name,is_self_signed:!0})}}a(By,"reviewSelfSignedCert");function KB(){let e=qte(Object.keys(Es.CONFIG_PARAM_MAP),!0),t=sr.join(_s.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME),r=sr.join(t,Js.PRIVATEKEY_PEM_NAME),n=sr.join(t,Js.NATS_CERTIFICATE_PEM_NAME),s=sr.join(t,Js.NATS_CA_PEM_NAME),i=Es.CONFIG_PARAMS,o={[i.TLS_PRIVATEKEY]:e[i.TLS_PRIVATEKEY.toLowerCase()]?e[i.TLS_PRIVATEKEY.toLowerCase()]:r};e[i.TLS_CERTIFICATE.toLowerCase()]&&(o[i.TLS_CERTIFICATE]=e[i.TLS_CERTIFICATE.toLowerCase()]),e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(o[i.TLS_CERTIFICATEAUTHORITY]=e[i.TLS_CERTIFICATEAUTHORITY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_CERTIFICATE]=e[i.OPERATIONSAPI_TLS_CERTIFICATE.toLowerCase()]),e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_PRIVATEKEY]=e[i.OPERATIONSAPI_TLS_PRIVATEKEY.toLowerCase()]),e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]&&(o[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY]=e[i.OPERATIONSAPI_TLS_CERTIFICATEAUTHORITY.toLowerCase()]),(e[i.CLUSTERING_ENABLED.toLowerCase()]||e.clustering)&&(o[i.CLUSTERING_TLS_CERTIFICATE]=e[i.CLUSTERING_TLS_CERTIFICATE.toLowerCase()]??n,o[i.CLUSTERING_TLS_CERT_AUTH]=e[i.CLUSTERING_TLS_CERT_AUTH.toLowerCase()]??s,o[i.CLUSTERING_TLS_PRIVATEKEY]=e[i.CLUSTERING_TLS_PRIVATEKEY.toLowerCase()]??r),wy.updateConfigValue(void 0,void 0,o,!1,!0)}a(KB,"updateConfigCert");function YB(e){return e.startsWith("-----BEGIN")?e:Wte(e,"utf8")}a(YB,"readPEM");var MB=Ic.createSecureContext;Ic.createSecureContext=function(e){if(!e.cert||!e.key)return MB(e);let t={...e};delete t.key,delete t.cert;let r=MB(t);return r.context.setCert(e.cert),r.context.setKey(e.key,void 0),r};var WB=Ic.Server;Ic.Server=function(e,t){return e.ALPNCallback&&(e.ALPNProtocols=null),WB.call(this,e,t)};Ic.Server.prototype=WB.prototype;var nre=GB.prototype._init;GB.prototype._init=function(e,t){nre.call(this,e,t);let r=this;this._handle.oncertcb=function(n){let s=n.servername;r._SNICallback(s,(i,o)=>{this.sni_context=o?.context||o,this.certCbDone()})}};var Nc=new Map;function jB(e,t){let r=new Map,n,s=!1;return i.initialize=o=>i.ready?i.ready:(o&&(o.secureContexts=r,o.secureContextsListeners=[]),i.ready=new Promise((c,l)=>{async function u(){try{r.clear(),Nc.clear();let d=0;for await(let _ of Ny.system.hdb_certificate.search([])){let E=_.certificate,f=new ao(E);_.is_authority&&(f.asString=E,Nc.set(f.subject,E))}for await(let _ of Ny.system.hdb_certificate.search([]))try{if(_.is_authority)continue;let E=e==="operations-api",f=_.is_self_signed?1:2;E&&_.uses?.includes?.("operations")&&(f+=1);let h=await zB(_.private_key_name),T=_.certificate,m=new ao(T);if(Nc.has(m.issuer)&&(T+=`