harperdb 4.4.20 → 4.4.21
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.
- package/README.md +1 -1
- package/bin/harperdb.js +3 -3
- package/bin/lite.js +3 -3
- package/launchServiceScripts/launchInstallNATSServer.js +1 -1
- package/launchServiceScripts/launchNatsIngestService.js +3 -3
- package/launchServiceScripts/launchNatsReplyService.js +3 -3
- package/launchServiceScripts/launchUpdateNodes4-0-0.js +3 -3
- package/npm-shrinkwrap.json +63 -57
- package/package.json +1 -1
- package/server/jobs/jobProcess.js +3 -3
- package/server/threads/threadServer.js +3 -3
- package/studio/build-local/asset-manifest.json +2 -2
- package/studio/build-local/index.html +1 -1
- package/studio/build-local/static/js/{main.12321ebb.js → main.68d1da05.js} +2 -2
- package/utility/scripts/restartHdb.js +3 -3
- /package/studio/build-local/static/js/{main.12321ebb.js.LICENSE.txt → main.68d1da05.js.LICENSE.txt} +0 -0
|
@@ -8,14 +8,14 @@ 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:vQ.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(kQ,"findPs")});var Ht=N((Mge,RC)=>{"use strict";var FQ="__dbis__",GQ="__txns__",qQ="__environment_name__",$Q="__dbi_defintion__",VQ={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"},KQ=["__createdtime__","__updatedtime__"],YQ="\uFFFF",AC={TIMESTAMP:"timestamp",HASH_VALUE:"hash_value",USER_NAME:"user_name"},WQ=Object.values(AC);RC.exports={AUDIT_STORE_NAME:GQ,INTERNAL_DBIS_NAME:FQ,DBI_DEFINITION_NAME:$Q,SEARCH_TYPES:VQ,TIMESTAMP_NAMES:KQ,MAX_SEARCH_KEY_LENGTH:256,ENVIRONMENT_NAME_KEY:qQ,TRANSACTIONS_DBI_NAMES_ENUM:AC,TRANSACTIONS_DBIS:WQ,OVERFLOW_MARKER:YQ}});var Dn=N((Uge,PC)=>{"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"},jQ=IC[OC.INTERNAL_SERVER_ERROR],zQ={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")},QQ={CONFIG_VALIDATION:a(e=>`HarperDB config file validation error: ${e}`,"CONFIG_VALIDATION")},JQ={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"},XQ={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"},ZQ={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"},e2={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."},t2={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")},r2={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"},n2={OUTER_JOIN_TRANSLATION_ERROR:"There was an error translating the final SQL outer join data."},s2={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")},DC={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")},i2={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"},o2={CLUSTERING_NOT_ENABLED:"Clustering must be enabled to perform this operation."},a2={...wC,...JQ,...zQ,...e2,...t2,...r2,...n2,...s2,...ZQ,...CC,...DC,...i2,...o2,...QQ};PC.exports={CHECK_LOGS_WRAPPER:NC,HDB_ERROR_MSGS:a2,DEFAULT_ERROR_MSGS:IC,DEFAULT_ERROR_RESP:jQ,HTTP_STATUS_CODES:OC,LMDB_ERRORS_ENUM:XQ,AUTHENTICATION_ERROR_MSGS:wC,VALIDATION_ERROR_MSGS:CC,ITC_ERRORS:DC}});var _e=N((Bge,UC)=>{"use strict";var Cl=Dn(),c2=W(),l2=M(),ah=class extends Error{static{a(this,"HdbError")}constructor(t,r,n,s,i){super(),Error.captureStackTrace(this,LC),this.statusCode=n||Cl.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR,this.http_resp_msg=r||(Cl.DEFAULT_ERROR_MSGS[n]?Cl.DEFAULT_ERROR_MSGS[n]:Cl.DEFAULT_ERROR_MSGS[Cl.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&&c2[s](i)}},pg=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}},mg=class extends Error{static{a(this,"ServerError")}constructor(t,r){super(t),this.statusCode=r||500}};function LC(e,t,r,n=l2.LOG_LEVELS.ERROR,s=null,i=!1){if(MC(e))return e;let o=new ah(e,t,r,n,s);return i&&delete o.stack,o}a(LC,"handleHDBError");function MC(e){return e.__proto__.constructor.name===ah.name}a(MC,"isHDBError");UC.exports={isHDBError:MC,handleHDBError:LC,ClientError:pg,ServerError:mg,hdb_errors:Cl}});var Sg=N(vC=>{"use strict";var u2={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
|
`)},d2="certificate.pem",_2="privateKey.pem",f2="caCertificate.pem",E2="natsCertificate.pem",h2="natsCaCertificate.pem",Rt={DEFAULT:"default","DEFAULT-CA":"default-ca",SERVER:"server",CA:"ca","OPERATIONS-API":"operations-api","OPERATIONS-CA":"operations-ca"},p2={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"]},m2={[Rt.SERVER]:2,[Rt.DEFAULT]:1},S2={[Rt["OPERATIONS-API"]]:3,[Rt.SERVER]:2,[Rt.DEFAULT]:1},T2={[Rt["OPERATIONS-API"]]:3,[Rt.SERVER]:2,[Rt.DEFAULT]:1},g2={[Rt["OPERATIONS-CA"]]:3,[Rt.CA]:2,[Rt["DEFAULT-CA"]]:1},A2={[Rt["OPERATIONS-CA"]]:3,[Rt.CA]:2,[Rt["DEFAULT-CA"]]:1},R2={[Rt.CA]:2,[Rt["DEFAULT-CA"]]:1};Object.assign(vC,{CERTIFICATE_PEM_NAME:d2,PRIVATEKEY_PEM_NAME:_2,CA_PEM_NAME:f2,CERT_NAME:Rt,CERT_CONFIG_NAME_MAP:p2,CERT_PREFERENCE_APP:m2,CERT_PREFERENCE_OPS:S2,CERT_PREFERENCE_REP:T2,CA_CERT_PREFERENCE_REP:g2,CA_CERT_PREFERENCE_OPS:A2,CA_CERT_PREFERENCE_APP:R2,CERTIFICATE_VALUES:u2,NATS_CERTIFICATE_PEM_NAME:E2,NATS_CA_PEM_NAME:h2})});var Tt=N((kge,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:y2,validateObjectAsync:b2,validateBySchema:O2};function y2(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(y2,"validateObject");async function b2(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(b2,"validateObjectAsync");function O2(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(O2,"validateBySchema")});var gg=N((qge,qC)=>{"use strict";var FC=require("fs-extra"),me=require("joi"),N2=require("os"),{boolean:He,string:It,number:tr,array:Qa}=me.types(),{totalmem:HC}=require("os"),za=require("path"),I2=W(),Tg=te(),Gge=Sg(),xC=M(),w2=Tt(),kC="log",C2="components",D2="Invalid logging.rotation.maxSize unit. Available units are G, M or K",P2="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",L2="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",M2="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",U2="rootPath config parameter is undefined",sn=me.alternatives([tr.min(0),It]).optional().empty(null),ch=me.alternatives([Qa.items(It,{host:It.required(),port:sn},{hostname:It.required(),port:sn}).empty(null),Qa.items(It)]),pi,GC=!1;qC.exports={configValidator:v2,routesValidator:G2,route_constraints:ch};function v2(e,t=!1){if(GC=t,pi=e.rootPath,Tg.isEmpty(pi))throw U2;let r=He.optional(),n=tr.min(0).max(1e3).empty(null).default(F2),s=It.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(qd),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(qd),l=me.custom(H2).empty(null).default(qd),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:ch}).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:ch}).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:Qa.optional().empty(null),databases:me.alternatives(It,Qa),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(k2).optional().empty(null),maxSize:It.custom(x2).optional().empty(null),path:It.optional().empty(null).default(qd)}).required(),root:s,stdStreams:He.required(),auditLog:He.required()}).required(),operationsApi:me.object({network:me.object({cors:He.optional(),corsAccessList:Qa.optional(),headersTimeout:tr.min(1).optional(),keepAliveTimeout:tr.min(1).optional(),port:sn,domainSocket:me.optional().empty("hdb/operations-server").default(qd),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:Qa.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([Qa.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(v2,"configValidator");function B2(e){return GC||FC.existsSync(e)?null:`Specified path ${e} does not exist.`}a(B2,"doesPathExist");function H2(e,t){me.assert(e,It.pattern(/^[\\\/]$|([\\\/a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=B2(e);if(r)return t.message(r)}a(H2,"validatePath");function x2(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(D2);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(L2):e}a(x2,"validateRotationMaxSize");function k2(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message(P2);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(M2):e}a(k2,"validateRotationInterval");function F2(e,t){let r=t.state.path.join("."),n=N2.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),I2.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}a(F2,"setDefaultThreads");function qd(e,t){let r=t.state.path.join(".");if(!Tg.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if(Tg.isEmpty(pi))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return za.join(pi,C2);case"logging.root":return za.join(pi,kC);case"clustering.leafServer.streams.path":return za.join(pi,"clustering","leaf");case"storage.path":let n=za.join(pi,xC.LEGACY_DATABASES_DIR_NAME);return FC.existsSync(n)?n:za.join(pi,xC.DATABASES_DIR_NAME);case"logging.rotation.path":return za.join(pi,kC);case"operationsApi.network.domainSocket":return r==null?null:za.join(pi,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(qd,"setDefaultRoot");function G2(e){let t=me.object({routes:ch});return w2.validateBySchema({routes:e},t)}a(G2,"routesValidator")});var Ja={};je(Ja,{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=te(),hr=W(),{configValidator:q2,routesValidator:VC}=gg(),$r=require("fs-extra"),YC=require("yaml"),Ln=require("path"),$2=require("is-number"),WC=require("properties-reader"),V2=require("lodash"),{handleHDBError:K2}=_e(),{HTTP_STATUS_CODES:Y2,HDB_ERROR_MSGS:Dl}=Dn(),{server:W2}=(qr(),oe(Ja)),{DATABASES_PARAM_CONFIG:$d,CONFIG_PARAMS:Pn,CONFIG_PARAM_MAP:ks}=on,j2="Unable to get config value because config is uninitialized",z2="Config successfully initialized",Q2="Error backing up config file",J2="Empty parameter sent to getConfigValue",jC=Ln.join(on.PACKAGE_ROOT,"config","yaml",on.HDB_DEFAULT_CONFIG_FILE),X2=Ln.join(on.PACKAGE_ROOT,"config","yaml","defaultNatsConfig.yaml"),Z2="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"},lh,jt,uh;Object.assign(ZC,{createConfigFile:e4,getDefaultConfig:t4,getConfigValue:QC,initConfig:dh,flattenConfig:Pl,updateConfigValue:JC,updateConfigObject:n4,getConfiguration:o4,setConfiguration:a4,readConfigFile:bg,getClusteringRoutes:c4,initOldConfig:XC,getConfigFromFile:l4,getConfigFilePath:Xa,addConfig:u4,deleteConfigFromFile:d4,getConfigObj:_4,resolvePath:Ag,getFlatConfigObj:f4});function Ag(e){if(e?.startsWith("~/"))return Ln.join(Er.getHomeDir(),e.slice(1));let t=se();return Ln.resolve(t.getHdbBasePath(),e)}a(Ag,"resolvePath");function e4(e,t=!1){let r=Vo(jC);if(e.clustering_enabled||e.CLUSTERING_ENABLED||e.clustering){let c=YC.parseDocument($r.readFileSync(X2,"utf8"),{simpleKeys:!0});r.addIn(["clustering"],c.toJSON().clustering)}lh=Pl(r.toJSON());let n;for(let c in e){let l=ks[c.toLowerCase()];if(l===Pn.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=Rg(l,e[c]);l==="rootPath"&&d?.endsWith("/")&&(d=d.slice(0,-1));try{r.setIn([...u],d)}catch(_){hr.error(_)}}}n&&zC(r,n),yg(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(e4,"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($d.TABLES))for(let i in n[s][$d.TABLES])for(let o in n[s][$d.TABLES][i]){let c=n[s][$d.TABLES][i][o],l=[Pn.DATABASES,s,$d.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=[Pn.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 t4(e){if(lh===void 0){let r=Vo(jC);lh=Pl(r.toJSON())}let t=ks[e.toLowerCase()];if(t!==void 0)return lh[t.toLowerCase()]}a(t4,"getDefaultConfig");function QC(e){if(e==null){hr.info(J2);return}if(jt===void 0){hr.trace(j2);return}let t=ks[e.toLowerCase()];if(t!==void 0)return jt[t.toLowerCase()]}a(QC,"getConfigValue");function Xa(e=Er.getPropsFilePath()){let t=Er.getEnvCliRootPath();if(t)return Ag(Ln.join(t,on.HDB_CONFIG_FILE));let r=WC(e);return Ag(r.get(on.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY))}a(Xa,"getConfigFilePath");function dh(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=Xa(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=Vo(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}`)}r4(n,r),yg(n);let s=n.toJSON();if(W2.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(z2)}}a(dh,"initConfig");function r4(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(r4,"checkForUpdatedConfig");function yg(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 Dl.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 Dl.CONFIG_VALIDATION("operationsApi.network.port and operationsApi.network.securePort cannot be the same value");let n=q2(r,t);if(n.error)throw Dl.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(yg,"validateConfig");function n4(e,t){jt===void 0&&(jt={});let r=ks[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(n4,"updateConfigObject");function JC(e,t,r=void 0,n=!1,s=!1,i=!1){jt===void 0&&dh();let o=QC(ks.hdb_root),c=Ln.join(o,on.HDB_CONFIG_FILE),l=Vo(c),u;if(r===void 0&&e.toLowerCase()===Pn.DATABASES)u=t;else if(r===void 0){let E;if(i)E=e;else if(E=ks[e.toLowerCase()],E===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let f=E.split("_"),h=Rg(E,t);l.setIn([...f],h)}else for(let E in r){let f=ks[E.toLowerCase()];if(f===Pn.HTTP_SECUREPORT&&r[E]===jt[Pn.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),f===Pn.OPERATIONSAPI_NETWORK_SECUREPORT&&r[E]===jt[Pn.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&l.setIn(["operationsApi","network","port"],null),f===Pn.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=Rg(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),yg(l);let d=l.getIn(["rootPath"]),_=Ln.join(d,on.HDB_CONFIG_FILE);n===!0&&s4(c,d),$r.writeFileSync(_,String(l)),s&&(jt=Pl(l.toJSON())),hr.trace(`Config parameter: ${e} updated with value: ${t}`)}a(JC,"updateConfigValue");function s4(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(Q2),hr.error(r)}}a(s4,"backupConfigFile");var i4=["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}),uh=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])&&!i4.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;!Pn[l.toUpperCase()]&&ks[l]&&(s[ks[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 Rg(e,t){if(e===Pn.CLUSTERING_NODENAME||e===Pn.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($2(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(Rg,"castConfigValue");function o4(){let e=Er.getPropsFilePath(),t=Xa(e);return Vo(t).toJSON()}a(o4,"getConfiguration");async function a4(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return JC(void 0,void 0,s,!0),Z2}catch(i){throw typeof i=="string"||i instanceof String?K2(i,i,Y2.BAD_REQUEST,void 0,void 0,!0):i}}a(a4,"setConfiguration");function bg(){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=Xa(e);return Vo(t).toJSON()}a(bg,"readConfigFile");function Vo(e){return YC.parseDocument($r.readFileSync(e,"utf8"),{simpleKeys:!0})}a(Vo,"parseYamlDoc");function c4(){let e=bg(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=Er.isEmptyOrZeroLength(t)?[]:t;let r=VC(t);if(r)throw Dl.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=Er.isEmptyOrZeroLength(n)?[]:n;let s=VC(n);if(s)throw Dl.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 Dl.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(c4,"getClusteringRoutes");function XC(e){let t=WC(e);jt={};for(let r in ks){let n=t.get(r.toUpperCase());if(Er.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=ks[r].toLowerCase();s===Pn.LOGGING_ROOT?jt[s]=Ln.dirname(n):jt[s]=n}return jt}a(XC,"initOldConfig");function l4(e){let t=bg();return V2.get(t,e.replaceAll("_","."))}a(l4,"getConfigFromFile");async function u4(e,t){let r=Vo(Xa());r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),await $r.writeFile(Xa(),String(r))}a(u4,"addConfig");function d4(e){let t=Xa(Er.getPropsFilePath()),r=Vo(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=Ln.join(n,on.HDB_CONFIG_FILE);$r.writeFileSync(s,String(r))}a(d4,"deleteConfigFromFile");function _4(){return uh||(dh(),uh)}a(_4,"getConfigObj");function f4(){return jt||dh(),jt}a(f4,"getFlatConfigObj")});var se=N((sD,iD)=>{"use strict";var Og=require("fs-extra"),Za=require("path"),eD=require("os"),E4=require("properties-reader"),Kd=W(),Vd=te(),De=M(),_h=wt(),h4="Error initializing environment manager",fh="BOOT_PROPS_FILE_PATH",tD=!1,p4={[De.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[De.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},Qi={};Object.assign(sD,iD.exports={BOOT_PROPS_FILE_PATH:fh,getHdbBasePath:m4,setHdbBasePath:S4,get:rD,initSync:g4,setProperty:Qe,initTestEnvironment:R4,setCloneVar:A4});function m4(){return Qi[De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(m4,"getHdbBasePath");function S4(e){Qi[De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(S4,"setHdbBasePath");function rD(e){let t=_h.getConfigValue(e);return t===void 0?Qi[e]:t}a(rD,"get");function Qe(e,t){p4[e]&&(Qi[e]=t),_h.updateConfigObject(e,t)}a(Qe,"setProperty");function T4(){let e;try{e=Vd.getPropsFilePath(),Og.accessSync(e,Og.constants.F_OK|Og.constants.R_OK),tD=!0;let t=E4(e);return Qi[De.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(De.HDB_SETTINGS_NAMES.INSTALL_USER),Qi[De.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(De.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),Qi[fh]=e,!0}catch{return Kd.trace(`Environment manager found no properties file at ${e}`),!1}}a(T4,"doesPropFileExist");function g4(e=!1){try{((tD||T4()||Vd.noBootFile())&&!nD||e)&&(_h.initConfig(e),Qi[De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=_h.getConfigValue(De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){Kd.error(h4),Kd.error(t),console.error(t),process.exit(1)}}a(g4,"initSync");var nD=!1;function A4(e){nD=e}a(A4,"setCloneVar");function R4(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=Za.join(__dirname,"../../","unitTests");Qi[fh]=Za.join(l,"hdb_boot_properties.file"),Qe(De.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,Za.join(l,"settings.test")),Qe(De.HDB_SETTINGS_NAMES.INSTALL_USER,eD.userInfo()?eD.userInfo().username:void 0),Qe(De.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),Qe(De.HDB_SETTINGS_NAMES.LOG_PATH_KEY,Za.join(l,"envDir","log")),Qe(De.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),Qe(De.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),Qe(De.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),Qe(De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,Za.join(l,"envDir")),Qe(De.CONFIG_PARAMS.STORAGE_PATH,Za.join(l,"envDir")),s&&(Qe(De.CONFIG_PARAMS.HTTP_SECUREPORT,rD(De.CONFIG_PARAMS.HTTP_PORT)),Qe(De.CONFIG_PARAMS.HTTP_PORT,null)),Qe(De.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,!!s),Qe(De.CONFIG_PARAMS.HTTP_PORT,9926),Qe(De.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),Qe(De.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT,9925),Qe(De.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,Vd.isEmpty(i)?!1:i),Qe(De.CONFIG_PARAMS.HTTP_CORS,Vd.isEmpty(i)?!1:i),Qe(De.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),Qe(De.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),Qe(De.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),Qe(De.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),Qe(De.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,Za.resolve(__dirname,"../../unitTests/server/fastifyRoutes/custom_functions")),Qe(De.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,Vd.isEmpty(c)?!1:c),o&&(Qe("CORS_ACCESSLIST",o),Qe(De.CONFIG_PARAMS.HTTP_CORSACCESSLIST,o)),n&&(Qe(De.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,n),Qe(De.CONFIG_PARAMS.HTTP_TIMEOUT,n)),t&&(Qe(De.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),Qe(De.CONFIG_PARAMS.HTTP_KEEPALIVETIMEOUT,t)),r&&(Qe(De.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),Qe(De.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${fh}. Please check your boot props and settings files`;Kd.fatal(r),Kd.error(t)}}a(R4,"initTestEnvironment")});var gt=N((Wge,_D)=>{"use strict";var Qd=M(),y4=te(),an=se(),Jd=require("path"),b4=require("minimist"),oD=require("fs-extra"),aD=require("lodash");an.initSync();var{CONFIG_PARAMS:Ko,DATABASES_PARAM_CONFIG:Yd,SYSTEM_SCHEMA_NAME:Eh}=Qd,Wd,jd,zd;function cD(){if(Wd!==void 0)return Wd;if(an.getHdbBasePath()!==void 0)return Wd=an.get(Ko.STORAGE_PATH)||Jd.join(an.getHdbBasePath(),Qd.DATABASES_DIR_NAME),Wd}a(cD,"getBaseSchemaPath");function lD(){if(jd!==void 0)return jd;if(an.getHdbBasePath()!==void 0)return jd=dD(Eh),jd}a(lD,"getSystemSchemaPath");function uD(){if(zd!==void 0)return zd;if(an.getHdbBasePath()!==void 0)return zd=an.get(Qd.CONFIG_PARAMS.STORAGE_AUDIT_PATH)||Jd.join(an.getHdbBasePath(),Qd.TRANSACTIONS_DIR_NAME),zd}a(uD,"getTransactionAuditStoreBasePath");function O4(e,t){let r=an.get(Ko.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||Jd.join(uD(),e.toString())}a(O4,"getTransactionAuditStorePath");function dD(e,t){e=e.toString(),t=t&&t.toString();let r=an.get(Qd.CONFIG_PARAMS.DATABASES)?.[e];return t&&r?.tables?.[t]?.path||r?.path||Jd.join(cD(),e)}a(dD,"getSchemaPath");function N4(e,t){e=e.toString(),t=t.toString();let r=process.env;Object.assign(r,b4(process.argv));let n=r[Ko.DATABASES.toUpperCase()];if(n){let i;try{i=JSON.parse(n)}catch(o){if(!y4.isObject(n))throw o;i=n}for(let o of i){let c=o[Eh];if(!c)continue;let l=an.get(Ko.DATABASES);l=l??{};let u=c?.tables?.[t]?.[Yd.PATH];if(u)return aD.set(l,[Eh,Yd.TABLES,t,Yd.PATH],u),an.setProperty(Ko.DATABASES,l),u;let d=c?.[Yd.PATH];if(d)return aD.set(l,[Eh,Yd.PATH],d),an.setProperty(Ko.DATABASES,l),d}}let s=r[Ko.STORAGE_PATH.toUpperCase()];if(s){if(!oD.pathExistsSync(s))throw new Error(s+" does not exist");let i=Jd.join(s,e);return oD.mkdirsSync(i),an.setProperty(Ko.STORAGE_PATH,s),i}return lD()}a(N4,"initSystemSchemaPaths");function I4(){Wd=void 0,jd=void 0,zd=void 0}a(I4,"resetPaths");_D.exports={getBaseSchemaPath:cD,getSystemSchemaPath:lD,getTransactionAuditStorePath:O4,getTransactionAuditStoreBasePath:uD,getSchemaPath:dD,initSystemSchemaPaths:N4,resetPaths:I4}});var cn=N((Jge,mD)=>{"use strict";var w4=Dn().LMDB_ERRORS_ENUM,zge=require("lmdb"),C4=Ht(),Qge=require("buffer").Buffer,{OVERFLOW_MARKER:fD,MAX_SEARCH_KEY_LENGTH:hh}=C4,ED=["number","string","symbol","boolean","bigint"];function D4(e){if(e=e?.primaryStore||e,!e)throw new Error(w4.ENV_REQUIRED)}a(D4,"validateEnv");function P4(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(P4,"stringifyData");function L4(e){return e instanceof Date?e.valueOf():e}a(L4,"convertKeyValueToWrite");function M4(e,t){if(e===null)return t?[null]:void 0;if(e===void 0)return;if(ED.includes(typeof e))return e.length>hh?[e.slice(0,hh)+fD]:[e];let r;if(Array.isArray(e)){r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n];if(ED.includes(typeof i))i.length>hh?r.push(i.slice(0,hh)+fD):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(M4,"getIndexedValues");var ph=0,hD=0;function pD(){hD=Date.now()-performance.now()}a(pD,"adjustStartTime");pD();var U4=6e4;setInterval(pD,U4).unref();function v4(){let e=performance.now()+hD;return e>ph?(ph=e,e):(ph+=488e-6,ph)}a(v4,"getNextMonotonicTime");mD.exports={validateEnv:D4,stringifyData:P4,convertKeyValueToWrite:L4,getNextMonotonicTime:v4,getIndexedValues:M4}});var Xd=N((Zge,SD)=>{"use strict";var B4=M().OPERATIONS_ENUM,Ng=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i=void 0){this.operation=B4.INSERT,this.schema=t,this.table=r,this.hash_attribute=n,this.records=s,this.__origin=i}};SD.exports=Ng});var Zd=N((rAe,RD)=>{"use strict";var tAe=Xd(),mh=M(),Ig=te(),TD=W(),H4=require("uuid"),{handleHDBError:Sh,hdb_errors:x4}=_e(),{HDB_ERROR_MSGS:Th,HTTP_STATUS_CODES:gh}=x4;RD.exports=gD;function gD(e,t,r){for(let s=0;s<t.length;s++)AD(t[s]);let{records:n}=e;for(let s=0;s<n.length;s++){let i=n[s];k4(i,r,e.operation)}}a(gD,"processRows");gD.validateAttribute=AD;function AD(e){if(Buffer.byteLength(String(e))>mh.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw Sh(new Error,Th.ATTR_NAME_LENGTH_ERR(e),gh.BAD_REQUEST,void 0,void 0,!0);if(Ig.isEmptyOrZeroLength(e)||Ig.isEmpty(e.trim()))throw Sh(new Error,Th.ATTR_NAME_NULLISH_ERR,gh.BAD_REQUEST,void 0,void 0,!0)}a(AD,"validateAttribute");function k4(e,t,r){if(!e.hasOwnProperty(t)||Ig.isEmptyOrZeroLength(e[t])){if(r===mh.OPERATIONS_ENUM.INSERT||r===mh.OPERATIONS_ENUM.UPSERT){e[t]=H4.v4();return}throw TD.error("Update transaction aborted due to record with no hash value:",e),Sh(new Error,Th.RECORD_MISSING_HASH_ERR,gh.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>mh.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw TD.error(e),Sh(new Error,Th.HASH_VAL_LENGTH_ERR,gh.BAD_REQUEST,void 0,void 0,!0)}a(k4,"validateHash")});var yD,Mn,wg,Ll=Ie(()=>{yD=require("events"),Mn=class extends yD.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;drainCloseListener;currentDrainResolver;[Symbol.asyncIterator](){let t=new wg;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)}},wg=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 Pg={};je(Pg,{loadGQLSchema:()=>q4,start:()=>Dg,startOnMainThread:()=>G4});function Dg({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 j=de.value.value;V.computed={from:m(j,de,X)},V.version==null&&(V.version=j)}else de.name.value==="version"&&(V.version=de.value.value);V.computed=V.computed||!0}else if(Q==="relationship"){let de={};for(let j of ne.arguments)de[j.name.value]=j.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 j of ne.arguments)j.name.value==="role"&&de.push(j.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):F4.includes(g.type)||(0,OD.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,Cg.dirname)(n),g.tableClass):i.set((0,Cg.dirname)(n)+"/"+(g.export.name||g.type),g.tableClass,g.export));function m(g,S,y){return new bD.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 Cg,bD,OD,F4,G4,q4,ND=Ie(()=>{Cg=require("path"),bD=require("node:vm");Pe();OD=L(dt()),F4=["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(Dg,"start");G4=Dg,q4=Dg({ensureTable:Et}).handleFile});var MD={};je(MD,{parse:()=>Mg,streamAsJSON:()=>e_,stringify:()=>ec});function e_(e){return new Lg({value:e})}function ID(e){return console.error(e),JSON.stringify(e.toString())}function wD(e,t,r){return e?.then?r?e.then(t,r):e.then(t):t(e)}function ec(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===PD)return LD(e);if(t.resolution)return t.resolution.then(()=>ec(e));throw t}}function LD(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+=LD(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+ec(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function Mg(e){return e?.length>0?(typeof e!="string"&&(e=e.toString()),K4.test(e)?$4.parse(e):JSON.parse(e)):null}var CD,DD,$4,V4,PD,Lg,K4,Ug=Ie(()=>{CD=require("stream"),DD=L(require("json-bigint-fixes")),$4=(0,DD.default)({useNativeBigInt:!0}),V4=1e4,PD={message:"Cannot serialize BigInt to JSON"};BigInt.prototype.toJSON=function(){throw PD};a(e_,"streamAsJSON");Lg=class extends CD.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),ID)}catch(s){yield ID(s)}else yield ec(t)}else yield ec(t)}_read(){if(!this._amReading){if(this._amReading=!0,this.done)return this.push(null);wD(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>V4?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 wD(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(ID,"handleError");a(wD,"when");a(ec,"stringify");a(LD,"jsStringify");K4=/[[,:]\s*-?\d{16,}/;a(Mg,"parse")});var YD=N((uAe,KD)=>{"use strict";var vg=require("recursive-iterator"),Y4=require("alasql"),Bg=require("clone"),UD=te(),{handleHDBError:vD,hdb_errors:W4}=_e(),{HDB_ERROR_MSGS:BD,HTTP_STATUS_CODES:HD}=W4,{getDatabases:j4}=(Pe(),oe(lt)),z4=["DISTINCT_ARRAY"],xD=Symbol("validateTables"),Hg=Symbol("validateTable"),lAe=Symbol("getAllColumns"),kD=Symbol("validateAllColumns"),Ah=Symbol("findColumn"),FD=Symbol("validateOrderBy"),t_=Symbol("validateSegment"),xg=Symbol("validateColumn"),GD=Symbol("setColumnsForTable"),qD=Symbol("checkColumnsForAsterisk"),$D=Symbol("validateGroupBy"),VD=Symbol("hasColumns"),kg=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[xD](),this[qD](),this[kD]()}[xD](){if(this[VD]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[Hg](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[Hg](t.table)})}}[VD](){let t=!1,r=new vg(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[Hg](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=j4();if(!r[t.databaseid])throw vD(new Error,BD.SCHEMA_NOT_FOUND(t.databaseid),HD.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw vD(new Error,BD.TABLE_NOT_FOUND(t.databaseid,t.tableid),HD.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=Bg(s);i.table=Bg(t),this.attributes.push(i)})}[Ah](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)}[qD](){let t=new vg(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[GD](r.tableid)}[GD](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new Y4.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[kD](){this[t_](this.statement.columns,!1),this[t_](this.statement.joins,!1),this[t_](this.statement.where,!1),this[$D](this.statement.group,!1),this[t_](this.statement.order,!0)}[t_](t,r){if(!t)return;let n=new vg(t),s=[];for(let{node:i,path:o}of n)!UD.isEmpty(i)&&!UD.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[FD](i):s.push(this[xg](i)));return s}[$D](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&z4.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=Bg(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[Ah](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[Ah](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`}[FD](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[xg](t)}[xg](t){let r=this[Ah](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]}};KD.exports=kg});var jD=N((_Ae,WD)=>{"use strict";var Fg=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")}};WD.exports=Fg});var QD=N((EAe,zD)=>{"use strict";var Gg=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};zD.exports=Gg});var eP={};je(eP,{HAS_EXPIRATION:()=>bh,HAS_RESIDENCY_ID:()=>zg,HAS_STRUCTURE_UPDATE:()=>Oh,LAST_TIMESTAMP_PLACEHOLDER:()=>i_,LOCAL_TIMESTAMP:()=>Q4,METADATA:()=>r_,NO_TIMESTAMP:()=>$g,PENDING_LOCAL_TIME:()=>Qg,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>jg,RecordEncoder:()=>Wg,TIMESTAMP_ASSIGN_LAST:()=>X4,TIMESTAMP_ASSIGN_NEW:()=>XD,TIMESTAMP_ASSIGN_PREVIOUS:()=>ZD,TIMESTAMP_PLACEHOLDER:()=>Rh,TIMESTAMP_RECORD_PREVIOUS:()=>Vg,getUpdateRecord:()=>Jg,handleLocalTimeForGets:()=>Nh});function eJ(){return s_[0]=s_[0]^64,J4.getFloat64(0)}function Nh(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?.[r_];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?.[r_]>=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[r_];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,tc.push(new WeakRef(this))),o.call(this)},i.prototype.done=function(){if(c.call(this),this.isDone)for(let l=0;l<tc.length;l++){let u=tc[l].deref();(!u||u.isDone||u.isCommitted)&&tc.splice(l--,1)}},i.prototype.done.isTracked=!0}return e}function Jg(e,t,r){return function(n,s,i,o,c=-1,l,u,d="put",_,E){_||l==null?Ml=i?.localTime?Vg|ZD:$g:Ml=l?i?.localTime?Vg|16384:XD|16384:$g;let f=u?.expiresAt;if(f>=0&&(c|=bh),n_=c,Kg=f,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let h={version:o,instructedWrite:Ml>0},T,m=0;try{let g=i?.residencyId,S=u?.residencyId;S&&(Yg=S,n_|=zg,m|=rc),g!==S&&(m|=nc,g||(g=0)),c&bh&&(m|=a_),u?.originatingOperation&&(m|=o_),_&&(h.ifVersion=T=i?.version??null);let y=e.put(n,s,h);if(l){let I=u?.user?.username;if(E&&(yh=e.encoder.encode(E)),e.encoder.hasStructureUpdate&&(m|=Oh,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,Ul(o,t,n,X,u?.nodeId??server.replication.getThisNodeId(r)??0,I,d,yh,m,S,g,f),{ifVersion:T}),y}}r.put(i_,Ul(o,t,n,i?.localTime?1:0,u?.nodeId??server.replication?.getThisNodeId(r)??0,I,d,yh,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 JD,qg,Rh,i_,jg,Q4,r_,s_,J4,$g,XD,X4,ZD,Vg,bh,zg,Qg,Oh,Z4,yh,Ml,n_,Kg,Yg,Wg,tc,vl=Ie(()=>{JD=require("msgpackr");Ji();qg=L(W()),Rh=new Uint8Array([1,1,1,1,4,64,0,0]),i_=new Uint8Array([1,1,1,1,1,0,0,0]),jg=new Uint8Array([1,1,1,1,3,64,0,0]),Q4=Symbol("local-timestamp"),r_=Symbol("metadata"),s_=new Uint8Array(8),J4=new DataView(s_.buffer,0,8),$g=0,XD=0,X4=1,ZD=3,Vg=4,bh=16,zg=32,Qg=1,Oh=256,Ml=0,n_=-1,Kg=-1,Yg=0,Wg=class extends JD.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(s,i){if(Ml||n_>=0){let o=0,c=Ml;c&&(o+=8,Ml=0);let l=n_,u=Kg,d=Yg;l>=0&&(o+=2,n_=-1,u>=0&&(o+=8,Kg=-1),d&&(o+=4,Yg=0));let _=Z4=r.call(this,s,i|2048|o);yh=_.subarray((_.start||0)+o,_.end);let E=_.start||0;return c&&(Rh[4]=c,Rh[5]=c>>8,_.set(Rh,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(s_,0,c),c+=8;else for(let E=0;E<8;E++)s_[E]=t[c++];l=eJ(),i=t[c]}let u,d;i<32&&(o=i|t[c+1]<<5,c+=2,o&bh&&(u=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8),o&zg&&(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:_,[r_]: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(eJ,"getTimestamp");a(Nh,"handleLocalTimeForGets");tc=[];setInterval(()=>{for(let e=0;e<tc.length;e++){let t=tc[e].deref();!t||t.isDone||t.isCommitted?tc.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(qg.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):qg.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(Jg,"getUpdateRecord")});var c_=N((TAe,rP)=>{"use strict";var tP=se(),tJ=M(),{RecordEncoder:rJ}=(vl(),oe(eP)),SAe=require("fs");tP.initSync();var nJ=tP.get(tJ.CONFIG_PARAMS.STORAGE_CACHING)!==!1,Xg=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=nJ&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:rJ})}};rP.exports=Xg});var l_=N((AAe,nP)=>{"use strict";var Un=se(),as=M();Un.initSync();var Ih=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(as.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Un.get(as.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Un.get(as.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Un.get(as.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Un.get(as.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Un.get(as.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Un.get(as.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Un.get(as.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Un.get(as.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Un.get(as.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Un.get(as.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Un.get(as.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};nP.exports=Ih;Ih.MAX_DBS=1e4});var ht=N((yAe,fP)=>{"use strict";var eA=require("lmdb"),Fs=require("fs-extra"),vn=require("path"),wh=cn(),oP=W(),ln=Dn().LMDB_ERRORS_ENUM,Ch=QD(),tA=c_(),aP=l_(),Yo=Ht(),sP=M(),{table:sJ,resetDatabases:iJ}=(Pe(),oe(lt)),iP=se(),Gs=Yo.INTERNAL_DBIS_NAME,cP=Yo.DBI_DEFINITION_NAME,oJ="data.mdb",aJ="lock.mdb",u_=".mdb",cJ="-lock",Zg=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=cs(t,r),this.key_type=this.dbi[Yo.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[Yo.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new eA.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function Dh(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(Dh,"pathEnvNameValidation");async function rA(e,t,r=!0){try{await Fs.access(e)}catch(n){throw n.code==="ENOENT"?new Error(ln.INVALID_BASE_PATH):n}try{let n=vn.join(e,t+u_);return await Fs.access(n,Fs.constants.R_OK|Fs.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await Fs.access(vn.join(e,t,oJ),Fs.constants.R_OK|Fs.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(rA,"validateEnvironmentPath");function Ph(e,t){if(wh.validateEnv(e),t===void 0)throw new Error(ln.DBI_NAME_REQUIRED)}a(Ph,"validateEnvDBIName");async function lJ(e,t,r=!1,n=!1){Dh(e,t);let s=vn.basename(e);t=t.toString();let i=iP.get(sP.CONFIG_PARAMS.DATABASES);i||iP.setProperty(sP.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await rA(e,t,n),lP(e,t,r)}catch(o){if(o.message===ln.INVALID_ENVIRONMENT){let c=vn.join(e,t);await Fs.mkdirp(n?c:e);let l=new aP(n?c:c+u_,!1),u=eA.open(l);u.dbis=Object.create(null);let d=new tA(!1);u.openDB(Gs,d),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let _=nA(e,t,r);return u[Yo.ENVIRONMENT_NAME_KEY]=_,global.lmdb_map[_]=u,u}throw o}}a(lJ,"createEnvironment");async function uJ(e,t,r,n=!0){Dh(e,t),t=t.toString();let s=vn.join(e,t);return sJ({table:t,database:vn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(uJ,"copyEnvironment");async function lP(e,t,r=!1){Dh(e,t),t=t.toString();let n=nA(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 rA(e,t),i=vn.join(e,t+u_),o=s!=i,c=new aP(s,o),l=eA.open(c);l.dbis=Object.create(null);let u=dP(l);for(let d=0;d<u.length;d++)cs(l,u[d]);return l[Yo.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(lP,"openEnvironment");async function dJ(e,t,r=!1){Dh(e,t),t=t.toString();let n=vn.join(e,t+u_),s=await rA(e,t);if(global.lmdb_map!==void 0){let i=nA(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await uP(o),delete global.lmdb_map[i]}}await Fs.remove(s),await Fs.remove(s===n?s+cJ:vn.join(vn.dirname(s),aJ))}a(dJ,"deleteEnvironment");async function uP(e){wh.validateEnv(e);let t=e[Yo.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(uP,"closeEnvironment");function nA(e,t,r=!1){let s=`${vn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(nA,"getCachedEnvironmentName");function _J(e){wh.validateEnv(e);let t=Object.create(null),r=cs(e,Gs);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==Gs)try{t[n]=Object.assign(new Ch,s)}catch{oP.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(_J,"listDBIDefinitions");function dP(e){wh.validateEnv(e);let t=[],r=cs(e,Gs);for(let{key:n}of r.getRange({start:!1}))n!==Gs&&t.push(n);return t}a(dP,"listDBIs");function fJ(e,t){let n=cs(e,Gs).getEntry(t),s=new Ch;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{oP.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(fJ,"getDBIDefinition");function _P(e,t,r,n=!r){if(Ph(e,t),t=t.toString(),t===Gs)throw new Error(ln.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return cs(e,t)}catch(s){if(s.message===ln.DBI_DOES_NOT_EXIST){let i=new tA(r,n===!0),o=e.openDB(t,i),c=new Ch(r===!0,n);return o[cP]=c,cs(e,Gs).putSync(t,c),e.dbis[t]=o,o}throw s}}a(_P,"createDBI");function cs(e,t){if(Ph(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==Gs?r=fJ(e,t):r=new Ch,r===void 0)throw new Error(ln.DBI_DOES_NOT_EXIST);let n;try{let s=new tA(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[cP]=r,e.dbis[t]=n,n}a(cs,"openDBI");function EJ(e,t){Ph(e,t),t=t.toString();let r=cs(e,t),n=r.getStats();return r[Yo.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(EJ,"statDBI");async function hJ(e,t){try{let r=vn.join(e,t+u_);return(await Fs.stat(r)).size}catch{throw new Error(ln.INVALID_ENVIRONMENT)}}a(hJ,"environmentDataSize");function pJ(e,t){if(Ph(e,t),t=t.toString(),t===Gs)throw new Error(ln.CANNOT_DROP_INTERNAL_DBIS_NAME);cs(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],cs(e,Gs).removeSync(t)}a(pJ,"dropDBI");function mJ(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{cs(e,i)}catch(o){if(o.message===ln.DBI_DOES_NOT_EXIST)_P(e,i,i!==t,i===t),n=!0;else throw o}}n&&iJ()}a(mJ,"initializeDBIs");fP.exports={openDBI:cs,openEnvironment:lP,createEnvironment:lJ,listDBIs:dP,listDBIDefinitions:_J,createDBI:_P,dropDBI:pJ,statDBI:EJ,deleteEnvironment:dJ,initializeDBIs:mJ,TransactionCursor:Zg,environmentDataSize:hJ,copyEnvironment:uJ,closeEnvironment:uP}});var hP=N((OAe,EP)=>{"use strict";var sA=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};EP.exports=sA});var mP=N((IAe,pP)=>{"use strict";var iA=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}};pP.exports=iA});var TP=N((CAe,SP)=>{"use strict";var oA=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};SP.exports=oA});var ic=N((UAe,RP)=>{"use strict";var SJ=ht(),TJ=hP(),gJ=mP(),AJ=TP(),mi=cn(),d_=Dn().LMDB_ERRORS_ENUM,RJ=Ht(),Xi=M(),yJ=te(),bJ=require("uuid"),PAe=require("lmdb"),{handleHDBError:OJ,hdb_errors:NJ}=_e(),{OVERFLOW_MARKER:LAe,MAX_SEARCH_KEY_LENGTH:MAe}=RJ,gP=se();gP.initSync();var Lh=gP.get(Xi.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),aA=Xi.TIME_STAMP_NAMES_ENUM.CREATED_TIME,sc=Xi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function IJ(e,t,r,n,s=mi.getNextMonotonicTime()){dA(e,t,r,n),cA(e,t,r);let i=new TJ,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l];AP(u,!0,s);let d=wJ(e,t,r,u),_=u[t];o.push(d),c.push(_)}return lA(o,c,n,i,s)}a(IJ,"insertRecords");function wJ(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][Xi.FUNC_VAL],n[o]=c)}let l=mi.getIndexedValues(c),u=e.dbis[o];if(l){Lh&&u.prefetch(l.map(d=>({key:d,value:s})),Mh);for(let d=0,_=l.length;d<_;d++)u.put(l[d],s)}}Lh&&e.dbis[t].prefetch([s],Mh),e.dbis[t].put(s,n,n[sc])})}a(wJ,"insertRecord");function CJ(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(CJ,"removeSkippedRecords");function AP(e,t,r){let n=r>0;(n||!Number.isInteger(e[sc]))&&(e[sc]=r||(r=mi.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[aA]))&&(e[aA]=r||mi.getNextMonotonicTime()):delete e[aA]}a(AP,"setTimestamps");function cA(e,t,r){r.indexOf(Xi.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(Xi.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(Xi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(Xi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),SJ.initializeDBIs(e,t,r)}a(cA,"initializeTransaction");async function DJ(e,t,r,n,s=mi.getNextMonotonicTime()){dA(e,t,r,n),cA(e,t,r);let i=new gJ,o=[],c=[],l=[];for(let u=0;u<n.length;u++){let d=n[u],_=d[t],E;try{E=uA(e,t,d,_,i,!0,s)}catch{i.skipped_hashes.push(_),o.push(u);continue}c.push(E),l.push(_)}return lA(c,l,n,i,s,o)}a(DJ,"updateRecords");async function PJ(e,t,r,n,s=mi.getNextMonotonicTime()){try{dA(e,t,r,n)}catch(l){throw OJ(l,l.message,NJ.HTTP_STATUS_CODES.BAD_REQUEST)}cA(e,t,r);let i=new AJ,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l],d;yJ.isEmpty(u[t])?(d=bJ.v4(),u[t]=d):d=u[t];let _=uA(e,t,u,d,i,!1,s);o.push(_),c.push(d)}return lA(o,c,n,i,s)}a(PJ,"upsertRecords");async function lA(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(),CJ(r,i),n}a(lA,"finalizeWrite");function uA(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(AP(r,!d,o),Number.isInteger(r[sc])&&u[sc]>r[sc])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][Xi.FUNC_VAL],r[h]=T)}if(T===g)continue;let S=mi.getIndexedValues(g);if(S){Lh&&m.prefetch(S.map(y=>({key:y,value:n})),Mh);for(let y=0,I=S.length;y<I;y++)m.remove(S[y],n)}if(S=mi.getIndexedValues(T),S){Lh&&m.prefetch(S.map(y=>({key:y,value:n})),Mh);for(let y=0,I=S.length;y<I;y++)m.put(S[y],n)}}let f={...u,...r};c.put(n,f,f[sc])},"do_put");return l?_=c.ifVersion(n,l.version,E):_=c.ifNoExists(n,E),_.then(f=>f?!0:uA(e,t,r,n,s,i,o))}a(uA,"updateUpsertRecord");function LJ(e,t,r){if(mi.validateEnv(e),t===void 0)throw new Error(d_.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(d_.WRITE_ATTRIBUTES_REQUIRED):new Error(d_.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(LJ,"validateBasic");function dA(e,t,r,n){if(LJ(e,t,r),!Array.isArray(n))throw n===void 0?new Error(d_.RECORDS_REQUIRED):new Error(d_.RECORDS_MUST_BE_ARRAY)}a(dA,"validateWrite");function Mh(){}a(Mh,"noop");RP.exports={insertRecords:IJ,updateRecords:DJ,upsertRecords:PJ}});var Zi=N((BAe,MJ)=>{MJ.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((HAe,OP)=>{"use strict";var bP=te(),yP=M(),Bl=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Si=require("joi"),Wo={schema_format:{pattern:Bl,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},UJ=Si.alternatives(Si.string().min(1).max(Wo.schema_length.maximum).pattern(Bl).messages({"string.pattern.base":"{:#label} "+Wo.schema_format.message}),Si.number(),Si.array()).required(),vJ=Si.alternatives(Si.string().min(1).max(Wo.schema_length.maximum).pattern(Bl).messages({"string.pattern.base":"{:#label} "+Wo.schema_format.message}),Si.number()),BJ=Si.alternatives(Si.string().min(1).max(Wo.schema_length.maximum).pattern(Bl).messages({"string.pattern.base":"{:#label} "+Wo.schema_format.message}),Si.number()).required();function HJ(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>Wo.schema_length.maximum?`'${e}' maximum of 250 characters`:Bl.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(HJ,"checkValidTable");function xJ(e,t){return bP.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(xJ,"validateSchemaExists");function kJ(e,t){let r=t.state.ancestors[0].schema;return bP.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(kJ,"validateTableExists");function FJ(e,t){return e.toLowerCase()===yP.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${yP.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(FJ,"validateSchemaName");OP.exports={common_validators:Wo,schema_regex:Bl,hdb_schema_table:UJ,validateSchemaExists:xJ,validateTableExists:kJ,validateSchemaName:FJ,checkValidTable:HJ,hdb_database:vJ,hdb_table:BJ}});var Uh=N((kAe,NP)=>{var{common_validators:gi}=Ti(),f_=Tt(),__="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_(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(E_,"makeAttributesStrings");function GJ(e){return e=E_(e),rr.table.presence=!1,rr.attribute.presence=!1,rr.hash_attribute.presence=!1,f_.validateObject(e,rr)}a(GJ,"schema_object");function qJ(e){return e=E_(e),rr.table.presence={message:__},rr.attribute.presence=!1,rr.hash_attribute.presence=!1,f_.validateObject(e,rr)}a(qJ,"table_object");function $J(e){return e=E_(e),rr.table.presence={message:__},rr.attribute.presence=!1,f_.validateObject(e,rr)}a($J,"create_table_object");function VJ(e){return e=E_(e),rr.table.presence={message:__},rr.attribute.presence={message:__},rr.hash_attribute.presence=!1,f_.validateObject(e,rr)}a(VJ,"attribute_object");function KJ(e){return e=E_(e),rr.table.presence={message:__},rr.attribute.presence=!1,rr.hash_attribute.presence=!1,f_.validateObject(e,rr)}a(KJ,"describe_table");function YJ(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(YJ,"validateTableResidence");NP.exports={schema_object:GJ,create_table_object:$J,table_object:qJ,attribute_object:VJ,describe_table:KJ,validateTableResidence:YJ}});var wP=N((GAe,IP)=>{"use strict";var WJ=require("uuid"),_A=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||WJ.v4(),this.schema_table=`${this.schema}.${this.table}`}};IP.exports=_A});var vh=N(($Ae,CP)=>{"use strict";var jJ=wP(),fA=class extends jJ{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}};CP.exports=fA});var PP=N((KAe,DP)=>{"use strict";DP.exports=QJ;var zJ="inserted";function QJ(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===zJ?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(QJ,"returnObject")});var Bh=N((jAe,vP)=>{"use strict";var JJ=M(),EA=ht(),XJ=ic(),{getSystemSchemaPath:ZJ,getSchemaPath:e3}=gt(),WAe=Zi(),t3=Uh(),r3=vh(),n3=PP(),{handleHDBError:LP,hdb_errors:UP}=_e(),MP=te(),{HTTP_STATUS_CODES:s3}=UP,i3="inserted";vP.exports=o3;async function o3(e){let t=t3.attribute_object(e);if(t)throw LP(new Error,t.message,UP.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=!e.skip_table_check&&MP.checkGlobalSchemaTable(e.schema,e.table);if(r)throw LP(new Error,r,s3.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=MP.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 r3(e.schema,e.table,e.attribute,e.id);try{let i=await EA.openEnvironment(e3(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}`);EA.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await EA.openEnvironment(ZJ(),JJ.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await XJ.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_attribute_attributes,[s]);return n3(i3,c,{records:[s]},l)}catch(i){throw i}}a(o3,"lmdbCreateAttribute")});var pA=N((QAe,HP)=>{var{hdb_table:a3,hdb_database:BP}=Ti(),c3=Tt(),hA=require("joi"),l3={undefined:"undefined",null:"null"},u3=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||l3[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"),d3=hA.object({database:BP,schema:BP,table:a3,records:hA.array().items(hA.object().custom(u3)).required()});HP.exports=function(e){return c3.validateBySchema(e,d3)}});var h_=N((ZAe,kP)=>{"use strict";var eo=te(),xP=W(),XAe=pA(),{getDatabases:_3}=(Pe(),oe(lt)),{ClientError:oc}=_e();kP.exports=f3;function f3(e){if(eo.isEmpty(e))throw new oc("invalid update parameters defined.");if(eo.isEmptyOrZeroLength(e.schema))throw new oc("invalid schema specified.");if(eo.isEmptyOrZeroLength(e.table))throw new oc("invalid table specified.");if(!Array.isArray(e.records))throw new oc("records must be an array");let t=_3()[e.schema]?.[e.table];if(eo.isEmpty(t))throw new oc(`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&&eo.isEmptyOrZeroLength(o[r]))throw xP.error("a valid hash attribute must be provided with update record:",o),new oc("a valid hash attribute must be provided with update record, check log for more info");if(!eo.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw xP.error(`a valid hash value must be provided with ${e.operation} record:`,o),new oc(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!eo.isEmpty(o[r])&&o[r]!==""&&n.has(eo.autoCast(o[r]))&&(o.skip=!0),n.add(eo.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(f3,"insertUpdateValidate")});var GP=N((tRe,FP)=>{"use strict";var mA=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};FP.exports=mA});var VP=N((nRe,$P)=>{"use strict";var SA=ht(),E3=W(),qP=Dn().LMDB_ERRORS_ENUM;$P.exports=h3;async function h3(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 SA.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==qP.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await SA.closeEnvironment(global.lmdb_map[n]),await SA.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==qP.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){E3.error(t)}}a(h3,"cleanLMDBMap")});var to=N((iRe,jP)=>{"use strict";var p_=require("crypto"),p3=se(),{CONFIG_PARAMS:m3}=M(),YP="aes-256-cbc",S3=32,T3=16,TA=64,WP=32,g3=TA+WP,KP=new Map;jP.exports={encrypt:A3,decrypt:R3,createNatsTableStreamName:y3};function A3(e){let t=p_.randomBytes(S3),r=p_.randomBytes(T3),n=p_.createCipheriv(YP,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(A3,"encrypt");function R3(e){let t=e.substr(0,TA),r=e.substr(TA,WP),n=e.substr(g3,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=p_.createDecipheriv(YP,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(R3,"decrypt");function y3(e,t){let r=p3.get(m3.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=KP.get(r);return n||(n=p_.createHash("md5").update(r).digest("hex"),KP.set(r,n)),n}a(y3,"createNatsTableStreamName")});var ro=N((cRe,JP)=>{"use strict";var aRe=Vr(),m_=W(),zP=Uh(),b3=to(),Hh=te(),{handleHDBError:xh,hdb_errors:O3}=_e(),{HDB_ERROR_MSGS:kh,HTTP_STATUS_CODES:gA}=O3,QP=se();QP.initSync();var{getDatabases:AA}=(Pe(),oe(lt)),N3=require("fs-extra"),I3=M();JP.exports={describeAll:w3,describeTable:Fh,describeSchema:C3};async function w3(e={}){try{let t=Hh.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=AA(),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 Fh({schema:_,table:f,exact_count:u});else if(n&&n[_].describe&&n[_].tables[f].describe){let T=n[_].tables[f].attribute_permissions;h=await Fh({schema:_,table:f,exact_count:u},T)}h&&l.push(h)}catch(h){m_.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 m_.error("Got an error in describeAll"),m_.error(t),xh(new Error,kh.DESCRIBE_ALL_ERR)}}a(w3,"describeAll");async function Fh(e,t){Hh.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=zP.describe_table(e);if(i)throw i;let c=AA()[r];if(!c)throw xh(new Error,kh.SCHEMA_NOT_FOUND(e.schema),gA.NOT_FOUND);let l=c[n];if(!l)throw xh(new Error,kh.TABLE_NOT_FOUND(e.schema,e.table),gA.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 N3.stat(l.primaryStore.env.path)).size}catch(f){m_.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")),QP.get(I3.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(E.clustering_stream_name=b3.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){m_.warn(`unable to stat table dbi due to ${f}`)}return E}a(Fh,"descTable");async function C3(e){Hh.transformReq(e);let t=zP.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=AA()[n];if(!i)throw xh(new Error,kh.SCHEMA_NOT_FOUND(e.schema),gA.NOT_FOUND);let o={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),Hh.isEmpty(l)||l.describe){let u=await Fh({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);u&&(o[u.name]=u)}}return o}a(C3,"describeSchema")});var ls=N((_Re,rL)=>{var D3=Zi(),{callbackify:ZP,promisify:P3}=require("util"),{getDatabases:eL}=(Pe(),oe(lt));rL.exports={setSchemaDataToGlobal:XP,getTableSchema:L3,getSystemSchema:M3,setSchemaDataToGlobalAsync:P3(XP)};var tL=ro(),uRe=ZP(tL.describeAll),dRe=ZP(tL.describeTable);function XP(e){global.hdb_schema=eL(),e&&e()}a(XP,"setSchemaDataToGlobal");function L3(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(L3,"getTableSchema");function M3(){return D3}a(M3,"getSystemSchema")});var un=N((ERe,oL)=>{"use strict";var qh=pA(),Cr=te(),U3=require("util"),$h=Bn(),v3=ls(),nL=W(),{handleHDBError:ac,hdb_errors:B3}=_e(),{HTTP_STATUS_CODES:cc}=B3,H3=U3.promisify(v3.getTableSchema),x3="updated",sL="inserted",iL="upserted";oL.exports={insert:F3,update:G3,upsert:q3,validation:k3,flush:$3};async function k3(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 H3(e.schema,e.table),r=qh(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(k3,"validation");async function F3(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=qh(e);if(t)throw ac(new Error,t.message,cc.BAD_REQUEST);Cr.transformReq(e);let r=Cr.checkSchemaTableExist(e.schema,e.table);if(r)throw ac(new Error,r,cc.BAD_REQUEST);let n=await $h.createRecords(e);return Gh(sL,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(F3,"insertData");async function G3(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=qh(e);if(t)throw ac(new Error,t.message,cc.BAD_REQUEST);Cr.transformReq(e);let r=Cr.checkSchemaTableExist(e.schema,e.table);if(r)throw ac(new Error,r,cc.BAD_REQUEST);let n=await $h.updateRecords(e);return Cr.isEmpty(n.existing_rows)?Gh(x3,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):Gh(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(G3,"updateData");async function q3(e){if(e.operation!=="upsert")throw ac(new Error,"invalid operation, must be upsert",cc.INTERNAL_SERVER_ERROR);let t=qh(e);if(t)throw ac(new Error,t.message,cc.BAD_REQUEST);Cr.transformReq(e);let r=Cr.checkSchemaTableExist(e.schema,e.table);if(r)throw ac(new Error,r,cc.BAD_REQUEST);let n=await $h.upsertRecords(e);return Gh(iL,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(q3,"upsertData");function Gh(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(Gh,"returnObject");function $3(e){return Cr.transformReq(e),$h.flush(e.schema,e.table)}a($3,"flush")});var yA=N((pRe,lL)=>{var V3=Tt(),RA=require("joi"),{hdb_table:K3,hdb_database:aL}=Ti(),cL={schema:aL,database:aL,table:K3},Y3={date:RA.date().iso().required()},W3={timestamp:RA.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};lL.exports=function(e,t){let r=t==="timestamp"?{...cL,...W3}:{...cL,...Y3},n=RA.object(r);return V3.validateBySchema(e,n)}});var _L=N((mRe,dL)=>{var j3=Tt(),bA=require("joi"),{hdb_table:z3,hdb_database:uL}=Ti(),Q3=bA.object({schema:uL,database:uL,table:z3,hash_values:bA.array().required(),ids:bA.array()});dL.exports=function(e){return j3.validateBySchema(e,Q3)}});var wA=N((SRe,fL)=>{"use strict";var OA=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}},NA=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}},IA=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};fL.exports={InsertObject:OA,NoSQLSeachObject:NA,DeleteResponseObject:IA}});var dc=N((gRe,SL)=>{"use strict";var hL=yA(),J3=_L(),lc=te(),EL=require("moment"),pL=W(),{promisify:X3,callbackify:Z3}=require("util"),uc=M(),eX=ls(),CA=X3(eX.getTableSchema),DA=Bn(),{DeleteResponseObject:tX}=wA(),{handleHDBError:jo,hdb_errors:rX}=_e(),{HDB_ERROR_MSGS:Vh,HTTP_STATUS_CODES:zo}=rX,nX="records successfully deleted",sX=Z3(mL);SL.exports={delete:sX,deleteRecord:mL,deleteFilesBefore:iX,deleteAuditLogsBefore:oX};async function iX(e){let t=hL(e,"date");if(t)throw jo(t,t.message,zo.BAD_REQUEST,void 0,void 0,!0);if(lc.transformReq(e),!EL(e.date,EL.ISO_8601).isValid())throw jo(new Error,Vh.INVALID_DATE,zo.BAD_REQUEST,uc.LOG_LEVELS.ERROR,Vh.INVALID_DATE,!0);let n=lc.checkSchemaTableExist(e.schema,e.table);if(n)throw jo(new Error,n,zo.NOT_FOUND,uc.LOG_LEVELS.ERROR,n,!0);let s=await DA.deleteRecordsBefore(e);if(await CA(e.schema,e.table),pL.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(iX,"deleteFilesBefore");async function oX(e){let t=hL(e,"timestamp");if(t)throw jo(t,t.message,zo.BAD_REQUEST,void 0,void 0,!0);if(lc.transformReq(e),isNaN(e.timestamp))throw jo(new Error,Vh.INVALID_VALUE("Timestamp"),zo.BAD_REQUEST,uc.LOG_LEVELS.ERROR,Vh.INVALID_VALUE("Timestamp"),!0);let r=lc.checkSchemaTableExist(e.schema,e.table);if(r)throw jo(new Error,r,zo.NOT_FOUND,uc.LOG_LEVELS.ERROR,r,!0);let n=await DA.deleteAuditLogsBefore(e);return await CA(e.schema,e.table),pL.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(oX,"deleteAuditLogsBefore");async function mL(e){e.ids&&(e.hash_values=e.ids);let t=J3(e);if(t)throw jo(t,t.message,zo.BAD_REQUEST,void 0,void 0,!0);lc.transformReq(e);let r=lc.checkSchemaTableExist(e.schema,e.table);if(r)throw jo(new Error,r,zo.NOT_FOUND,uc.LOG_LEVELS.ERROR,r,!0);try{await CA(e.schema,e.table);let n=await DA.deleteRecords(e);return lc.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${nX}`),n}catch(n){if(n.message===uc.SEARCH_NOT_FOUND_MESSAGE){let s=new tX;return s.message=uc.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(mL,"deleteRecord")});var Kh=N((RRe,AL)=>{var aX=require("crypto"),TL=9;function cX(e){let t=uX(TL),r=gL(e+t);return t+r}a(cX,"createHash");function lX(e,t){let r=e?.substr(0,TL),n=r+gL(t+r);return e===n}a(lX,"validateHash");function uX(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(uX,"generateSalt");function gL(e){return aX.createHash("md5").update(e).digest("hex")}a(gL,"md5");AL.exports={hash:cX,validate:lX}});var yL=N((bRe,RL)=>{var PA=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 dX(e){return Kr.password.presence=!0,Kr.username.presence=!0,Kr.role.presence=!0,Kr.active.presence=!0,PA.validateObject(e,Kr)}a(dX,"addUserValidation");function _X(e){return Kr.password.presence=!1,Kr.username.presence=!0,Kr.role.presence=!1,Kr.active.presence=!1,PA.validateObject(e,Kr)}a(_X,"alterUserValidation");function fX(e){return Kr.password.presence=!1,Kr.username.presence=!0,Kr.role.presence=!1,Kr.active.presence=!1,PA.validateObject(e,Kr)}a(fX,"dropUserValidation");RL.exports={addUserValidation:dX,alterUserValidation:_X,dropUserValidation:fX}});var Ct=N((IRe,OL)=>{"use strict";var{platform:NRe}=require("os"),EX="nats-server.zip",LA="nats-server",hX=process.platform==="win32"?`${LA}.exe`:LA,pX=/^[^\s.,*>]+$/,bL="__request__",mX=a(e=>`${e}.${bL}`,"REQUEST_SUBJECT"),SX={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},TX={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},gX={HUB:"hub.pid",LEAF:"leaf.pid"},AX={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},RX={SUCCESS:"success",ERROR:"error"},yX={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},bX={TXN:"txn",MSGID:"msgid"},Hl={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},OX={[Hl.ERR]:1,[Hl.WRN]:2,[Hl.INF]:3,[Hl.DBG]:4,[Hl.TRC]:5},NX={debug:"-D",trace:"-DVV"};OL.exports={NATS_SERVER_ZIP:EX,NATS_SERVER_NAME:LA,NATS_BINARY_NAME:hX,PID_FILES:gX,NATS_CONFIG_FILES:TX,SERVER_SUFFIX:AX,NATS_TERM_CONSTRAINTS_RX:pX,REQUEST_SUFFIX:bL,UPDATE_REMOTE_RESPONSE_STATUSES:RX,CLUSTER_STATUS_STATUSES:yX,REQUEST_SUBJECT:mX,SUBJECT_PREFIXES:bX,MSG_HEADERS:SX,LOG_LEVELS:Hl,LOG_LEVEL_FLAGS:NX,LOG_LEVEL_HIERARCHY:OX}});var IL=N((CRe,NL)=>{"use strict";var Yh=M(),Wh=class{static{a(this,"BaseLicense")}constructor(t=0,r=Yh.RAM_ALLOCATION_ENUM.DEFAULT,n=Yh.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},MA=class extends Wh{static{a(this,"ExtendedLicense")}constructor(t=0,r=Yh.RAM_ALLOCATION_ENUM.DEFAULT,n=Yh.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};NL.exports={BaseLicense:Wh,ExtendedLicense:MA}});var _c=N((PRe,UL)=>{"use strict";var kl=require("fs-extra"),CL=Kh(),DL=require("crypto"),IX=require("moment"),wX=require("uuid").v4,Yr=W(),vA=require("path"),CX=te(),Qo=M(),{totalmem:wL}=require("os"),DX=IL().ExtendedLicense,xl="invalid license key format",PX="061183",LX="mofi25",MX="aes-256-cbc",UX=16,vX=32,PL=se(),{resolvePath:LL}=wt();PL.initSync();var UA;UL.exports={validateLicense:ML,generateFingerPrint:HX,licenseSearch:xA,getLicense:FX,checkMemoryLimit:GX};function BA(){return vA.join(PL.getHdbBasePath(),Qo.LICENSE_KEY_DIR_NAME,Qo.LICENSE_FILE_NAME)}a(BA,"getLicenseDirPath");function BX(){let e=BA();return LL(vA.join(e,Qo.LICENSE_FILE_NAME))}a(BX,"getLicenseFilePath");function HA(){let e=BA();return LL(vA.join(e,Qo.REG_KEY_FILE_NAME))}a(HA,"getFingerPrintFilePath");async function HX(){let e=HA();try{return await kl.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await xX();throw Yr.error(`Error writing fingerprint file to ${e}`),Yr.error(t),new Error("There was an error generating the fingerprint")}}a(HX,"generateFingerPrint");async function xX(){let e=wX(),t=CL.hash(e),r=HA();try{await kl.mkdirp(BA()),await kl.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(xX,"writeFingerprint");function ML(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:Qo.RAM_ALLOCATION_ENUM.DEFAULT,version:Qo.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return Yr.error("empty license key passed to validate."),r;let n=HA(),s=!1;try{s=kl.statSync(n)}catch(i){Yr.error(i)}if(s){let i;try{i=kl.readFileSync(n,"utf8")}catch{Yr.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(LX),c=o[1];c=Buffer.concat([Buffer.from(c)],UX);let l=Buffer.concat([Buffer.from(i)],vX),u=DL.createDecipheriv(MX,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=kX(o[0],i);if(f)d=f;else throw r.valid_license=!1,r.valid_machine=!1,console.error(xl),Yr.error(xl),new Error(xl)}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(xl),Yr.error(xl),new Error(xl)}else r.exp_date=d;r.exp_date<IX().valueOf()&&(r.valid_date=!1),CL.validate(o[1],`${PX}${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 kX(e,t){try{let r=DL.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(kX,"checkOldLicense");function xA(){let e=new DX,t=[];try{t=kl.readFileSync(BX(),"utf-8").split(Qo.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(CX.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=Qo.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return UA=e,e}a(xA,"licenseSearch");async function FX(){return UA||await xA(),UA}a(FX,"getLicense");function GX(){let e=xA().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(GX,"checkMemoryLimit")});var xn=N((BRe,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:QX,alterUser:JX,dropUser:ZX,getSuperUser:nZ,userInfo:eZ,listUsers:zh,listUsersExternal:tZ,setUsersToGlobal:Gl,findAndValidateUser:jL,getClusterUser:sZ,USERNAME_REQUIRED:xL,ALTERUSER_NOTHING_TO_UPDATE:kL,EMPTY_PASSWORD:FL,EMPTY_ROLE:GL,ACTIVE_BOOLEAN:qL};var $L=un(),qX=dc(),GA=Kh(),VL=yL(),KL=Vr(),qA=no(),Hn=te(),YL=require("validate.js"),Ke=W(),{promisify:$X}=require("util"),$A=to(),vL=M(),BL=Ct(),VX=wt(),MRe=se(),URe=_c(),KX=Zi(),{table:vRe}=(Pe(),oe(lt)),{handleHDBError:Ai,hdb_errors:YX}=_e(),{HTTP_STATUS_CODES:Ri,AUTHENTICATION_ERROR_MSGS:kA,HDB_ERROR_MSGS:Fl}=YX,{UserEventMsg:VA}=qs(),FA=require("lodash"),{server:KA}=(qr(),oe(Ja)),WX=W();KA.getUser=(e,t)=>jL(e,t,t!=null);var WL={username:!0,active:!0,role:!0,password:!0},HL=new Map,jh=KL.searchByValue,jX=KL.searchByHash,zX=$X(qX.delete);async function QX(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 jh(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,Fl.ROLE_NAME_NOT_FOUND(t.role),Ri.NOT_FOUND,void 0,void 0,!0);if(s.length>1)throw Ai(new Error,Fl.DUP_ROLES_FOUND(t.role),Ri.CONFLICT,void 0,void 0,!0);s[0].permission.cluster_user===!0&&(t.hash=$A.encrypt(t.password)),t.password=GA.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 Gl()}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,Fl.USER_ALREADY_EXISTS(t.username),Ri.CONFLICT,void 0,void 0,!0);let c={...t};return c.role=s[0],qA.signalUserChange(new VA(process.pid)),`${c.username} successfully added`}a(QX,"addUser");async function JX(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=XX(t.username);if(!Hn.isEmpty(t.password)&&!Hn.isEmptyOrZeroLength(t.password.trim())&&(r&&(t.hash=$A.encrypt(t.password)),t.password=GA.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 jh(i)||[])}catch(c){throw Ke.error("Got an error searching for a role."),Ke.error(c),c}if(!o||o.length===0){let c=Fl.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=Fl.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 Gl()}catch(i){throw Ke.error("Got an error setting users to global"),Ke.error(i),i}return qA.signalUserChange(new VA(process.pid)),s}a(JX,"alterUser");function XX(e){let t=!1,r=global.hdb_users.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(XX,"isClusterUser");async function ZX(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,Fl.USER_NOT_EXIST(e.username),Ri.NOT_FOUND,void 0,void 0,!0);let n;try{n=await zX(r)}catch(s){throw Ke.error("Got an error deleting a user."),Ke.error(s),s}Ke.debug(n);try{await Gl()}catch(s){throw Ke.error("Got an error setting users to global."),Ke.error(s),s}return qA.signalUserChange(new VA(process.pid)),`${e.username} successfully deleted`}catch(t){throw t}}a(ZX,"dropUser");async function eZ(e){let t={};try{if(!e||!e.hdb_user)return"There was no user info in the body";t=FA.cloneDeep(e.hdb_user);let r={schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]},n;try{n=await jX(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(eZ,"userInfo");async function tZ(){let e;try{e=await zh()}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(tZ,"listUsersExternal");async function zh(){try{let e={schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]},t;try{t=await jh(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]=FA.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 jh(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=FA.cloneDeep(o),o.role=r[o.role],rZ(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(zh,"listUsers");function rZ(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(KX)){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(rZ,"appendSystemTablesToRole");async function Gl(){try{let e=await zh();global.hdb_users=e}catch(e){throw Ke.error(e),e}}a(Gl,"setUsersToGlobal");async function jL(e,t,r=!0){global.hdb_users||await Gl();let n=global.hdb_users.get(e);if(!n){if(!r)return{username:e};throw Ai(new Error,kA.GENERIC_AUTH_FAIL,Ri.UNAUTHORIZED,void 0,void 0,!0)}if(n&&!n.active)throw Ai(new Error,kA.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(GA.validate(n.password,t))HL.set(t,n.password);else throw Ai(new Error,kA.GENERIC_AUTH_FAIL,Ri.UNAUTHORIZED,void 0,void 0,!0)}return s}a(jL,"findAndValidateUser");async function nZ(){global.hdb_users||await Gl();for(let[,e]of global.hdb_users)if(e.role.role==="super_user")return e}a(nZ,"getSuperUser");async function sZ(){let e=await zh(),t=VX.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=$A.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(sZ,"getClusterUser");var zL=[];KA.invalidateUser=function(e){for(let t of zL)try{t(e)}catch(r){WX.error("Error invalidating user",r)}};KA.onInvalidatedUser=function(e){zL.push(e)}});var T_=N((FRe,eM)=>{"use strict";var fc=W(),kn=M(),iZ=VP(),xRe=ls(),kRe=ro(),oZ=xn(),{validateEvent:JL}=qs(),S_=Bn(),aZ=require("process"),{resetDatabases:cZ}=(Pe(),oe(lt)),lZ={[kn.ITC_EVENT_TYPES.SCHEMA]:uZ,[kn.ITC_EVENT_TYPES.USER]:ZL};async function uZ(e){let t=JL(e);if(t){fc.error(t);return}fc.trace("ITC schemaHandler received schema event:",e),await iZ(e.message),await dZ(e.message)}a(uZ,"schemaHandler");async function dZ(e){try{S_.resetReadTxn(kn.SYSTEM_SCHEMA_NAME,kn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),S_.resetReadTxn(kn.SYSTEM_SCHEMA_NAME,kn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),S_.resetReadTxn(kn.SYSTEM_SCHEMA_NAME,kn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=cZ();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){fc.error(t)}}a(dZ,"syncSchemaMetadata");var XL=[];async function ZL(e){try{try{S_.resetReadTxn(kn.SYSTEM_SCHEMA_NAME,kn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),S_.resetReadTxn(kn.SYSTEM_SCHEMA_NAME,kn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){fc.warn(r)}let t=JL(e);if(t){fc.error(t);return}fc.trace(`ITC userHandler ${kn.HDB_ITC_CLIENT_PREFIX}${aZ.pid} received user event:`,e),await oZ.setUsersToGlobal();for(let r of XL)r()}catch(t){fc.error(t)}}a(ZL,"userHandler");ZL.addListener=function(e){XL.push(e)};eM.exports=lZ});var qs=N((YRe,rM)=>{"use strict";var qRe=W(),YA=te(),_Z=M(),{ITC_ERRORS:g_}=Dn(),{parentPort:$Re,threadId:fZ,isMainThread:EZ,workerData:VRe}=require("worker_threads"),{onMessageFromWorkers:hZ,broadcast:KRe,broadcastWithAcknowledgement:pZ}=dt();rM.exports={sendItcEvent:mZ,validateEvent:tM,SchemaEventMsg:SZ,UserEventMsg:TZ};var Qh;hZ(async(e,t)=>{Qh=Qh||T_(),tM(e),Qh[e.type]&&await Qh[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function mZ(e){return!EZ&&e.message&&(e.message.originator=fZ),pZ(e)}a(mZ,"sendItcEvent");function tM(e){if(typeof e!="object")return g_.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||YA.isEmpty(e.type))return g_.MISSING_TYPE;if(!e.hasOwnProperty("message")||YA.isEmpty(e.message))return g_.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||YA.isEmpty(e.message.originator))return g_.MISSING_ORIGIN;if(_Z.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return g_.INVALID_EVENT(e.type)}a(tM,"validateEvent");function SZ(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(SZ,"SchemaEventMsg");function TZ(e){this.originator=e}a(TZ,"UserEventMsg")});var no=N((zRe,oM)=>{"use strict";var nM=M(),jRe=te(),Jh=W(),sM=GP(),ql,{sendItcEvent:iM}=qs();function gZ(e){try{Jh.info("signalSchemaChange called with message:",e),ql=ql||T_();let t=new sM(nM.ITC_EVENT_TYPES.SCHEMA,e);return ql.schema(t),iM(t)}catch(t){Jh.error(t)}}a(gZ,"signalSchemaChange");function AZ(e){try{Jh.trace("signalUserChange called with message:",e),ql=ql||T_();let t=new sM(nM.ITC_EVENT_TYPES.USER,e);return ql.user(t),iM(t)}catch(t){Jh.error(t)}}a(AZ,"signalUserChange");oM.exports={signalSchemaChange:gZ,signalUserChange:AZ}});var Xh=N((JRe,cM)=>{"use strict";var aM=te(),RZ=M(),yZ=W(),bZ=Bh(),OZ=vh(),NZ=no(),{SchemaEventMsg:IZ}=qs(),wZ="already exists in";cM.exports=CZ;async function CZ(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 DZ(e,t.schema,t.name,i)})),s}a(CZ,"lmdbCheckForNewAttributes");async function DZ(e,t,r,n){let s=new OZ(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await PZ(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(wZ))yZ.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(DZ,"createNewAttribute");async function PZ(e){let t;return t=await bZ(e),NZ.signalSchemaChange(new IZ(process.pid,RZ.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(PZ,"createAttribute")});var $l=N((ZRe,lM)=>{"use strict";var WA=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=WA});var dM=N((tye,uM)=>{"use strict";var LZ=$l(),MZ=M().OPERATIONS_ENUM,jA=class extends LZ{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(MZ.INSERT,r,n,s,i),this.records=t}};uM.exports=jA});var fM=N((nye,_M)=>{"use strict";var UZ=$l(),vZ=M().OPERATIONS_ENUM,zA=class extends UZ{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(vZ.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};_M.exports=zA});var hM=N((iye,EM)=>{"use strict";var BZ=$l(),HZ=M().OPERATIONS_ENUM,QA=class extends BZ{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(HZ.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};EM.exports=QA});var mM=N((aye,pM)=>{"use strict";var xZ=$l(),kZ=M().OPERATIONS_ENUM,JA=class extends xZ{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(kZ.DELETE,n,s,t,i),this.original_records=r}};pM.exports=JA});var A_=N((uye,AM)=>{"use strict";var lye=require("path"),SM=ht(),FZ=dM(),GZ=fM(),qZ=hM(),$Z=mM(),Vl=Ht(),TM=te(),{CONFIG_PARAMS:VZ}=M(),gM=se();gM.initSync();var Zh=M().OPERATIONS_ENUM,{getTransactionAuditStorePath:KZ}=gt();AM.exports=YZ;async function YZ(e,t){if(gM.get(VZ.LOGGING_AUDITLOG)===!1)return;let r=KZ(e.schema,e.table),n=await SM.openEnvironment(r,e.table,!0),s=WZ(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){SM.initializeDBIs(n,Vl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Vl.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[Vl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[Vl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),TM.isEmpty(s.user_name)||n.dbis[Vl.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[Vl.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(YZ,"writeTransaction");function WZ(e,t){let r=TM.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===Zh.INSERT)return new FZ(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Zh.UPDATE)return new GZ(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Zh.UPSERT)return new qZ(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Zh.DELETE)return new $Z(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(WZ,"createTransactionObject")});var XA=N((fye,RM)=>{"use strict";var jZ=h_(),_ye=Xd(),R_=M(),zZ=Zd(),QZ=ic().insertRecords,JZ=ht(),XZ=W(),ZZ=Xh(),{getSchemaPath:e5}=gt(),t5=A_();RM.exports=r5;async function r5(e){try{let{schema_table:t,attributes:r}=jZ(e);zZ(e,r,t.hash_attribute),e.schema!==R_.SYSTEM_SCHEMA_NAME&&(r.includes(R_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(R_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(R_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(R_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await ZZ(e.hdb_auth_header,t,r),s=e5(e.schema,e.table),i=await JZ.openEnvironment(s,e.table),o=await QZ(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await t5(e,o)}catch(c){XZ.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(r5,"lmdbCreateRecords")});var OM=N((hye,bM)=>{"use strict";var yM=M(),n5=XA(),s5=Xd(),i5=require("fs-extra"),{getSchemaPath:o5}=gt();bM.exports=a5;async function a5(e){let t=[{name:e.schema,createddate:Date.now()}],r=new s5(yM.SYSTEM_SCHEMA_NAME,yM.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await n5(r),await i5.mkdirp(o5(e.schema))}a(a5,"lmdbCreateSchema")});var IM=N((mye,NM)=>{"use strict";var ZA=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=ZA});var PM=N((Rye,DM)=>{"use strict";var wM=ht(),eR=cn(),tR=Dn().LMDB_ERRORS_ENUM,c5=Ht(),CM=W(),Tye=te(),l5=require("lmdb"),u5=IM(),d5=M(),{OVERFLOW_MARKER:gye,MAX_SEARCH_KEY_LENGTH:Aye}=c5,_5=d5.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function f5(e,t,r,n){if(eR.validateEnv(e),t===void 0)throw new Error(tR.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(tR.IDS_REQUIRED):new Error(tR.IDS_MUST_BE_ITERABLE);try{let s=wM.listDBIs(e);wM.initializeDBIs(e,t,s);let i=new u5,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[_5]>n){i.skipped.push(o);continue}let T=e.dbis[t].ifVersion(o,l5.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=eR.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=eR.getNextMonotonicTime(),i}catch(s){throw s}}a(f5,"deleteRecords");DM.exports={deleteRecords:f5}});var y_=N((bye,MM)=>{"use strict";var Kl=te(),E5=PM(),h5=ht(),{getSchemaPath:p5}=gt(),m5=A_(),S5=W();MM.exports=T5;async function T5(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(Kl.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(Kl.isEmptyOrZeroLength(e.hash_values)&&!Kl.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];Kl.isEmpty(l)||e.hash_values.push(l)}}if(Kl.isEmptyOrZeroLength(e.hash_values))return LM([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(Kl.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=p5(e.schema,e.table),i=await h5.openEnvironment(s,e.table),o=await E5.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await m5(e,o)}catch(c){S5.error(`unable to write transaction due to ${c.message}`)}return LM(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(T5,"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 nR=N((Iye,UM)=>{"use strict";var g5=M(),Nye=cn();function rR(e,t){let r=Object.create(null);if(t.length===1&&g5.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(rR,"parseRow");function A5(e,t,r,n){let s=rR(r,e);n.push(s)}a(A5,"searchAll");function R5(e,t,r,n){let s=rR(r,e);n[t]=s}a(R5,"searchAllToMap");function y5(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(y5,"iterateDBI");function Ec(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(Ec,"pushResults");function b5(e,t,r,n,s,i){t.toString().endsWith(e)&&Ec(t,r,n,s,i)}a(b5,"endsWith");function O5(e,t,r,n,s,i){t.toString().includes(e)&&Ec(t,r,n,s,i)}a(O5,"contains");function N5(e,t,r,n,s,i){t>e&&Ec(t,r,n,s,i)}a(N5,"greaterThanCompare");function I5(e,t,r,n,s,i){t>=e&&Ec(t,r,n,s,i)}a(I5,"greaterThanEqualCompare");function w5(e,t,r,n,s,i){t<e&&Ec(t,r,n,s,i)}a(w5,"lessThanCompare");function C5(e,t,r,n,s,i){t<=e&&Ec(t,r,n,s,i)}a(C5,"lessThanEqualCompare");UM.exports={parseRow:rR,searchAll:A5,searchAllToMap:R5,iterateDBI:y5,endsWith:b5,contains:O5,greaterThanCompare:N5,greaterThanEqualCompare:I5,lessThanCompare:w5,lessThanEqualCompare:C5,pushResults:Ec}});var Yl=N((Lye,GM)=>{"use strict";var Jo=ht(),Cye=W(),Fn=cn(),ep=Ht(),zt=Dn().LMDB_ERRORS_ENUM,Dye=te(),D5=M(),tp=nR(),{parseRow:P5}=tp,Pye=require("lmdb"),{OVERFLOW_MARKER:vM,MAX_SEARCH_KEY_LENGTH:L5}=ep;function BM(e,t,r,n=!1,s=void 0,i=void 0){return hc(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 b_(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,u=!1){return hc(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(b_,"iterateRangeBetween");function hc(e,t,r,n){let s=e.database||e,i=Jo.openDBI(s,r);i[ep.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&Jo.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(hc,"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=Jo.openDBI(e,r);else{let l=Jo.listDBIs(e);for(let u=0,d=l.length;u<d&&(s=Jo.openDBI(e,l[u]),!s[ep.DBI_DEFINITION_NAME].is_hash_attribute);u++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(HM,"getOverflowCheck");function M5(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 hc(e,t,t,(o,c,l)=>(rp(r),r=O_(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(u=>P5(u.value,r))))}a(M5,"searchAll");function U5(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);rp(r),r=O_(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,tp.parseRow(l,r));return o}a(U5,"searchAllToMap");function v5(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(v5,"iterateDBI");function B5(e,t){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);return Jo.statDBI(e,t).entryCount}a(B5,"countAll");function H5(e,t,r,n,s=!1,i=void 0,o=void 0){return Xo(e,r,n),hc(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(H5,"equals");function x5(e,t,r){return Xo(e,t,r),Jo.openDBI(e,t).getValuesCount(r)}a(x5,"count");function k5(e,t,r,n,s=!1,i=void 0,o=void 0){return Xo(e,r,n),hc(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(k5,"startsWith");function F5(e,t,r,n,s=!1,i=void 0,o=void 0){return xM(e,t,r,n,s,i,o,!0)}a(F5,"endsWith");function xM(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return Xo(e,r,n),hc(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[ep.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 G5(e,t,r,n,s=!1,i=void 0,o=void 0){Xo(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),b_(e,t,r,n,l,s,i,o,!0,!1)}a(G5,"greaterThan");function q5(e,t,r,n,s=!1,i=void 0,o=void 0){Xo(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),b_(e,t,r,n,l,s,i,o,!1,!1)}a(q5,"greaterThanEqual");function $5(e,t,r,n,s=!1,i=void 0,o=void 0){Xo(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),b_(e,t,r,l,n,s,i,o,!1,!0)}a($5,"lessThan");function V5(e,t,r,n,s=!1,i=void 0,o=void 0){Xo(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),b_(e,t,r,l,n,s,i,o,!1,!1)}a(V5,"lessThanEqual");function K5(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 b_(e,t,r,n,s,i,o,c)}a(K5,"between");function Y5(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(rp(r),r=O_(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=tp.parseRow(c,r)),o}a(Y5,"searchByHash");function W5(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(W5,"checkHashExists");function j5(e,t,r,n,s=[]){return FM(e,t,r,n,s),kM(e,t,r,n,s).map(i=>i[1])}a(j5,"batchSearchByHash");function z5(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(z5,"batchSearchByHashToMap");function kM(e,t,r,n,s=[]){return hc(e,t,t,(i,o,c)=>{r=O_(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,tp.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(rp(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 rp(e){if(!Array.isArray(e))throw e===void 0?new Error(zt.FETCH_ATTRIBUTES_REQUIRED):new Error(zt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(rp,"validateFetchAttributes");function Xo(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>L5)throw new Error(zt.SEARCH_VALUE_TOO_LARGE)}a(Xo,"validateComparisonFunctions");function O_(e,t){return t.length===1&&D5.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=Jo.listDBIs(e)),t}a(O_,"setGetWholeRowAttributes");GM.exports={searchAll:M5,searchAllToMap:U5,count:x5,countAll:B5,equals:H5,startsWith:k5,endsWith:F5,contains:xM,searchByHash:Y5,setGetWholeRowAttributes:O_,batchSearchByHash:j5,batchSearchByHashToMap:z5,checkHashExists:W5,iterateDBI:v5,greaterThan:G5,greaterThanEqual:q5,lessThan:$5,lessThanEqual:V5,between:K5}});var Wl=N((Uye,YM)=>{var qM=require("lodash"),$M=Tt(),xe=require("joi"),Q5=te(),{hdb_schema_table:N_,checkValidTable:VM,hdb_table:KM,hdb_database:np}=Ti(),{handleHDBError:J5,hdb_errors:X5}=_e(),{getDatabases:Z5}=(Pe(),oe(lt)),{HTTP_STATUS_CODES:e6}=X5,t6=xe.object({database:np,schema:np,table:KM,search_attribute:N_,search_value:xe.any().required(),get_attributes:xe.array().min(1).items(xe.alternatives(N_,xe.object())).optional(),desc:xe.bool(),limit:xe.number().integer().min(1),offset:xe.number().integer().min(0)}),r6=xe.object({database:np,schema:np,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(N_,xe.object())).optional(),sort:xe.object({attribute:xe.alternatives(N_,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(N_,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,t6);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,r6);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=Q5.checkGlobalSchemaTable(e.schema,e.table);if(s)return J5(new Error,s,e6.NOT_FOUND);let o=Z5()[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 sR=N((Bye,WM)=>{"use strict";var n6=ht(),s6=Wl(),{getSchemaPath:i6}=gt();WM.exports=o6;function o6(e){let t=s6(e,"hashes");if(t)throw t;let r=i6(e.schema,e.table);return n6.openEnvironment(r,e.table)}a(o6,"initialize")});var iR=N((xye,jM)=>{"use strict";var a6=Yl(),c6=sR();jM.exports=l6;async function l6(e){let t=await c6(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return a6.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(l6,"lmdbGetDataByHash")});var jl=N((Fye,zM)=>{"use strict";var oR=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=oR});var JM=N(($ye,QM)=>{"use strict";var qye=jl(),u6=Yl(),d6=sR();QM.exports=_6;async function _6(e){let t=await d6(e),r=global.hdb_schema[e.schema][e.table];return u6.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(_6,"lmdbSearchByHash")});var $s=N((Kye,XM)=>{"use strict";var aR=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=aR});var sp=N((Wye,sU)=>{"use strict";var Wr=Yl(),f6=ht(),E6=te(),ke=Ht(),pc=M(),h6=Zi(),ZM=Dn().LMDB_ERRORS_ENUM,{getSchemaPath:p6}=gt(),so=pc.SEARCH_WILDCARDS;async function m6(e,t,r){let n;e.schema===pc.SYSTEM_SCHEMA_NAME?n=h6[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(m6,"prepSearch");async function tU(e,t,r,n){let s=p6(e.schema,e.table),i=await f6.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(S6(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 S6(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(S6,"checkToFetchMore");function nU(e,t,r,n){if(E6.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),so.indexOf(s)>-1)return r===!0?ke.SEARCH_TYPES.SEARCH_ALL_TO_MAP:ke.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(so[0])<0&&s.indexOf(so[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(so.indexOf(i)>=0&&so.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),ke.SEARCH_TYPES.CONTAINS;if(so.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),ke.SEARCH_TYPES.ENDS_WITH;if(so.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),ke.SEARCH_TYPES.STARTS_WITH;if(s.includes(so[0])||s.includes(so[1]))return ke.SEARCH_TYPES.EQUALS;throw new Error(ZM.UNKNOWN_SEARCH_TYPE)}else switch(n){case pc.VALUE_SEARCH_COMPARATORS.BETWEEN:return ke.SEARCH_TYPES.BETWEEN;case pc.VALUE_SEARCH_COMPARATORS.GREATER:return ke.SEARCH_TYPES.GREATER_THAN;case pc.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return ke.SEARCH_TYPES.GREATER_THAN_EQUAL;case pc.VALUE_SEARCH_COMPARATORS.LESS:return ke.SEARCH_TYPES.LESS_THAN;case pc.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:m6,searchByType:rU}});var oU=N((Qye,iU)=>{"use strict";var zye=$s(),T6=Wl(),g6=te(),A6=M(),R6=sp();iU.exports=y6;function y6(e,t){if(!g6.isEmpty(t)&&A6.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=T6(e,"value");if(n)throw n;return R6.prepSearch(e,t,!0)}a(y6,"lmdbGetDataByValue")});var I_=N((Zye,aU)=>{"use strict";var Xye=$s(),b6=Wl(),O6=te(),N6=M(),I6=sp();aU.exports=w6;async function w6(e,t){if(!O6.isEmpty(t)&&N6.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=b6(e,"value");if(n)throw n;return I6.prepSearch(e,t,!1)}a(w6,"lmdbSearchByValue")});var lU=N((rbe,cU)=>{"use strict";var tbe=Ht(),cR=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}},lR=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},uR=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};cU.exports={SearchByConditionsObject:cR,SearchCondition:lR,SortAttribute:uR}});var EU=N((obe,fU)=>{"use strict";var sbe=lU().SearchByConditionsObject,C6=$s(),D6=Wl(),dR=Yl(),ip=Ht(),{Resource:ibe}=(Vs(),oe(_R)),_U=sp(),P6=nR(),L6=require("lodash"),{getSchemaPath:M6}=gt(),uU=ht(),{handleHDBError:U6,hdb_errors:v6}=_e(),{HTTP_STATUS_CODES:B6}=v6,H6=1e8;fU.exports=x6;async function x6(e){let t=D6(e,"conditions");if(t)throw U6(t,t.message,B6.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=M6(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=L6.sortBy(e.conditions,u=>{if(u.estimated_count===void 0){let d=u.search_type;d===ip.SEARCH_TYPES.EQUALS?u.estimated_count=dR.count(n,u.search_attribute,u.search_value):d===ip.SEARCH_TYPES.CONTAINS||d===ip.SEARCH_TYPES.ENDS_WITH?u.estimated_count=1/0:u.estimated_count=H6}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=dR.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=>P6.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=dR.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(x6,"lmdbSearchByConditions");async function dU(e,t,r,n){let s=new C6(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===ip.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 w_=N((cbe,hU)=>{"use strict";var k6=M().OPERATIONS_ENUM,fR=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=k6.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};hU.exports=fR});var ER=N((ube,yU)=>{"use strict";var TU=$s(),gU=w_(),AU=I_(),RU=y_(),dn=M(),pU=te(),mU=ht(),{getTransactionAuditStorePath:F6,getSchemaPath:G6}=gt(),SU=W();yU.exports=q6;async function q6(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 $6(e),await V6(e);let t=G6(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=F6(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(q6,"lmdbDropTable");async function $6(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($6,"deleteAttributesFromSystem");async function V6(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(V6,"dropTableFromSystem")});var OU=N((_be,bU)=>{"use strict";var K6=require("fs-extra"),Y6=$s(),W6=jl(),j6=w_(),z6=ER(),Q6=y_(),J6=iR(),X6=I_(),io=M(),{getSchemaPath:Z6}=gt(),{handleHDBError:e8,hdb_errors:t8}=_e(),{HDB_ERROR_MSGS:r8,HTTP_STATUS_CODES:n8}=t8;bU.exports=s8;async function s8(e){let t;try{t=await i8(e.schema);let r=new Y6(io.SYSTEM_SCHEMA_NAME,io.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,io.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[io.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await X6(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await z6(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new j6(io.SYSTEM_SCHEMA_NAME,io.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await Q6(s);let i=Z6(t);await K6.remove(i)}catch(r){throw r}}a(s8,"lmdbDropSchema");async function i8(e){let t=new W6(io.SYSTEM_SCHEMA_NAME,io.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[io.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await J6(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw e8(new Error,r8.SCHEMA_NOT_FOUND(e),n8.NOT_FOUND,void 0,void 0,!0);return n}a(i8,"validateDropSchema")});var C_=N((Ebe,NU)=>{"use strict";var hR=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};NU.exports=hR});var mR=N((mbe,IU)=>{"use strict";var o8=require("fs-extra"),op=ht(),{getTransactionAuditStorePath:a8}=gt(),pR=Ht(),pbe=C_();IU.exports=c8;async function c8(e){let t;try{let r=a8(e.schema,e.table);await o8.mkdirp(r),t=await op.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{op.createDBI(t,pR.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),op.createDBI(t,pR.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),op.createDBI(t,pR.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(c8,"createTransactionsAuditEnvironment")});var DU=N((gbe,CU)=>{"use strict";var SR=M(),wU=ht(),l8=ic(),{getSystemSchemaPath:u8,getSchemaPath:d8}=gt(),Tbe=Zi(),_8=Bh(),TR=vh(),f8=W(),E8=mR();CU.exports=h8;async function h8(e,t){let r=d8(t.schema,t.table),n=new TR(t.schema,t.table,SR.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new TR(t.schema,t.table,SR.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new TR(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(u8(),SR.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await l8.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 gR(n),await gR(s),await gR(i)}await E8(t)}catch(o){throw o}}a(h8,"lmdbCreateTable");async function gR(e){try{await _8(e)}catch(t){f8.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(gR,"createAttribute")});var LU=N((Rbe,PU)=>{"use strict";var p8=h_(),m8=Zd(),S8=Xh(),D_=M(),T8=ic().updateRecords,g8=ht(),{getSchemaPath:A8}=gt(),R8=A_(),y8=W();PU.exports=b8;async function b8(e){try{let{schema_table:t,attributes:r}=p8(e);m8(e,r,t.hash_attribute),e.schema!==D_.SYSTEM_SCHEMA_NAME&&(r.includes(D_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(D_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(D_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(D_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await S8(e.hdb_auth_header,t,r),s=A8(e.schema,e.table),i=await g8.openEnvironment(s,e.table),o=await T8(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await R8(e,o)}catch(c){y8.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(b8,"lmdbUpdateRecords")});var UU=N((bbe,MU)=>{"use strict";var O8=M().OPERATIONS_ENUM,AR=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=O8.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};MU.exports=AR});var BU=N((Ibe,vU)=>{"use strict";var Nbe=UU(),N8=h_(),I8=Zd(),w8=Xh(),P_=M(),C8=ic().upsertRecords,D8=ht(),{getSchemaPath:P8}=gt(),L8=A_(),M8=W(),{handleHDBError:U8,hdb_errors:v8}=_e();vU.exports=B8;async function B8(e){let t;try{t=N8(e)}catch(l){throw U8(l,l.message,v8.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;I8(e,n,r.hash_attribute),e.schema!==P_.SYSTEM_SCHEMA_NAME&&(n.includes(P_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(P_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(P_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(P_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await w8(e.hdb_auth_header,r,n),i=P8(e.schema,e.table),o=await D8.openEnvironment(i,e.table),c=await C8(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await L8(e,c)}catch(l){M8.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(B8,"lmdbUpsertRecords")});var xU=N((Cbe,HU)=>{"use strict";var RR=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};HU.exports=RR});var FU=N((Pbe,kU)=>{"use strict";var yR=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=yR});var $U=N((Ube,qU)=>{"use strict";var bR=ht(),{getTransactionAuditStorePath:H8}=gt(),Mbe=xU(),L_=Ht(),x8=te(),GU=FU(),k8=require("util").promisify,F8=k8(setTimeout),G8=1e4,q8=100;qU.exports=$8;async function $8(e){let t=H8(e.schema,e.table),r=await bR.openEnvironment(t,e.table,!0),n=bR.listDBIs(r);bR.initializeDBIs(r,L_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new GU;do s=await V8(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 F8(q8);while(s.transactions_deleted>0);return i}a($8,"deleteAuditLogsBefore");async function V8(e,t){let r=new GU;try{let n=e.dbis[L_.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[L_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];x8.isEmpty(c)||(s=e.dbis[L_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[L_.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>G8)break}return await s,r}catch(n){throw n}}a(V8,"deleteTransactions")});var KU=N((Bbe,VU)=>{"use strict";var OR=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};VU.exports=OR});var WU=N((kbe,YU)=>{"use strict";var K8=$s(),Y8=w_(),xbe=KU(),yi=M(),W8=te(),NR=ht(),j8=Zi(),z8=I_(),Q8=y_(),{getSchemaPath:J8}=gt();YU.exports=X8;async function X8(e,t=!0){let r;e.schema===yi.SYSTEM_SCHEMA_NAME?r=j8[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await e9(e),s=J8(e.schema,e.table),i=await NR.openEnvironment(s,e.table);return t===!0&&await Z8(e,i,r.hash_attribute),NR.dropDBI(i,e.attribute),n}a(X8,"lmdbDropAttribute");async function Z8(e,t,r){let n=NR.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(Z8,"removeAttributeFromAllObjects");async function e9(e){let t=new K8(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 z8(t)).filter(o=>o[yi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(W8.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 Y8(yi.SYSTEM_SCHEMA_NAME,yi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return Q8(i)}a(e9,"dropAttributeFromSystem")});var ZU=N((qbe,XU)=>{"use strict";var IR=ht(),zl=Ht(),Gbe=cn(),wR=M(),jU=te(),{getTransactionAuditStorePath:t9}=gt(),r9=Yl(),ap=$l(),n9=W();XU.exports=s9;async function s9(e){let t=t9(e.schema,e.table),r=await IR.openEnvironment(t,e.table,!0),n=IR.listDBIs(r);IR.initializeDBIs(r,zl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case wR.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return zU(r,e.search_values);case wR.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,o9(r,e.search_values,s);case wR.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return i9(r,e.search_values);default:return zU(r)}}a(s9,"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[zl.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 ap,s))}a(zU,"searchTransactionsByTimestamp");function i9(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[zl.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,JU(e,i))}return Object.fromEntries(r)}a(i9,"searchTransactionsByUsername");function o9(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let u=t[c],d=r9.equals(e,zl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,zl.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(o9,"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 ap(e.operation,e.user_name,i,void 0);_[t]=[c],u.push(_)}}else{let u=new ap(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[zl.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 ap,i);r.push(o)}}catch(i){n9.warn(i)}return r}catch(n){throw n}}a(JU,"batchSearchTransactions")});var tv=N((Ybe,ev)=>{"use strict";var{getSchemaPath:Vbe}=gt(),Kbe=ht(),{database:a9}=(Pe(),oe(lt));ev.exports={writeTransaction:c9};async function c9(e,t,r){return a9({database:e,table:t}).transaction(r)}a(c9,"writeTransaction")});var iv=N((jbe,sv)=>{"use strict";var{getSchemaPath:rv}=gt(),nv=ht();sv.exports={flush:l9,resetReadTxn:u9};async function l9(e,t){return(await nv.openEnvironment(rv(e,t),t.toString())).flushed}a(l9,"flush");async function u9(e,t){try{(await nv.openEnvironment(rv(e,t),t.toString())).resetReadTxn()}catch{}}a(u9,"resetReadTxn")});var lv=N((Qbe,cv)=>{"use strict";var{Readable:d9}=require("stream"),{getDatabases:_9}=(Pe(),oe(lt)),{readSync:f9,openSync:E9,createReadStream:ov}=require("fs"),{open:h9}=require("lmdb"),av=c_(),p9=l_(),{AUDIT_STORE_OPTIONS:m9}=(Ji(),oe(uv)),{INTERNAL_DBIS_NAME:S9,AUDIT_STORE_NAME:T9}=Ht();cv.exports=A9;var CR=32768,g9=100;async function A9(e){let t=e.database||e.schema||"data",r=_9()[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,_=h9({noSync:!0,maxDbs:p9.MAX_DBS}),E,f=_.openDB(S9,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++%g9===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(T9,{...m9}),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=E9(o.path);return o.transaction(()=>{let u=Buffer.alloc(CR);f9(c,u,0,CR),o.resetReadTxn();let d=o.useReadTransaction();d.renew();let _=ov(null,{fd:c,start:CR}),E=new d9.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(A9,"getBackup")});var fv=N((Xbe,_v)=>{"use strict";var R9=W(),{handleHDBError:y9}=_e(),b9=jD(),O9=Bh(),N9=XA(),I9=OM(),w9=y_(),C9=iR(),D9=JM(),P9=oU(),L9=I_(),M9=EU(),U9=OU(),v9=DU(),B9=LU(),H9=BU(),x9=$U(),k9=ER(),F9=WU(),G9=ZU(),q9=tv(),dv=iv(),$9=lv(),DR=class extends b9{static{a(this,"LMDBBridge")}async searchByConditions(t){return M9(t)}async getDataByHash(t){return await C9(t)}async searchByHash(t){return await D9(t)}async getDataByValue(t,r){return await P9(t,r)}async searchByValue(t){return await L9(t)}async createSchema(t){return await I9(t)}async dropSchema(t){return await U9(t)}async createTable(t,r){return await v9(t,r)}async dropTable(t){return await k9(t)}async createAttribute(t){return await O9(t)}async createRecords(t){return await N9(t)}async updateRecords(t){return await B9(t)}async upsertRecords(t){try{return await H9(t)}catch(r){throw y9(r,null,null,R9.ERR,r)}}async deleteRecords(t){return await w9(t)}async dropAttribute(t){return await F9(t)}async deleteAuditLogsBefore(t){return await x9(t)}async readAuditLog(t){return await G9(t)}writeTransaction(t,r,n){return q9.writeTransaction(t,r,n)}flush(t,r){return dv.flush(t,r)}resetReadTxn(t,r){return dv.resetReadTxn(t,r)}getBackup(t){return $9(t)}};_v.exports=DR});function Av(e){LR=e}function W9(){Y9=setInterval(function(){for(let e of PR)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},K9).unref()}var MR,pv,mv,Sv,Tv,gv,Ev,PR,V9,M_,hv,LR,mc,cp,K9,Y9,lp=Ie(()=>{MR=L(cn()),pv=L(_e()),mv=L(W());Vs();Sv=L(se()),Tv=L(M()),gv=L(te()),Ev=100,PR=new Set,V9=(0,gv.convertToMS)(Sv.get(Tv.CONFIG_PARAMS.STORAGE_MAXTRANSACTIONQUEUETIME))||45e3;a(Av,"replicationConfirmation");mc=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),PR.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(PR.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(M_&&!this.overloadChecked&&performance.now()-hv>V9)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,MR.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 M_||(M_=s,hv=performance.now(),M_.then(()=>{M_=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];LR&&f&&i.push(LR(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=[]}},cp=class extends mc{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,MR.getNextMonotonicTime)())}getReadTxn(){}},K9=3e4;a(W9,"startMonitoringTxns");W9()});function Dt(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 mc;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,Sc=Ie(()=>{Rv=L(fi());Vs();lp();a(Dt,"transaction");(0,Rv._assignPackageExport)("transaction",Dt);Dt.commit=function(e){let t=(e[Fe]||e)?.transaction;if(!t)throw new Error("No active transaction is available to commit");return t.commit()};Dt.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 Dv={};je(Dv,{ResourceBridge:()=>BR});function HR({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=HR(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;Dt(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&&dp(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||z9,r=ut()[t];if(!r)throw(0,Ks.handleHDBError)(new Error,j9.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,up,Ks,wv,Ys,UR,vR,Cv,j9,z9,Q9,J9,yv,BR,Pv=Ie(()=>{"use strict";Iv=L(fv()),up=L(Wl()),Ks=L(_e());Pe();wv=L(h_()),Ys=L(M()),UR=L(no()),vR=L(qs()),Cv=L(te());Sc();_p();({HDB_ERROR_MSGS:j9}=Ks.hdb_errors),z9="data",Q9=1e4,J9=10,BR=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,up.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:HR(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 Ql({database:t.schema,table:null}),UR.signalSchemaChange(new vR.SchemaEventMsg(process.pid,Ys.OPERATIONS_ENUM.CREATE_SCHEMA,t.schema))}async dropSchema(t){await xR(t.schema),UR.signalSchemaChange(new vR.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),Dt(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=dp(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),Dt(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)(J9),l=[],s=!0},"chunkDelete");for await(let d of n)l.push(d[r.primaryKey]),c++,c%Q9===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,up.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,up.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:HR(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(HR,"getSelect");a(bv,"getRecords");a(bi,"getTable");a(Ov,"createDeleteResponse");a(Nv,"groupRecordsInHistory")});var Bn=N((fOe,Lv)=>{"use strict";var{ResourceBridge:X9}=(Pv(),oe(Dv)),Z9=se();Z9.initSync();var fp;function e7(){return fp||(fp=new X9,fp)}a(e7,"getBridge");Lv.exports=e7()});var Bv=N((hOe,vv)=>{"use strict";var Mv=require("lodash"),U_=require("mathjs"),t7=require("jsonata"),Uv=te();vv.exports={distinct_array:a(e=>Array.isArray(e)&&e.length>1?Mv.uniqWith(e,Mv.isEqual):e,"distinct_array"),searchJSON:r7,mad:v_.bind(null,U_.mad),mean:v_.bind(null,U_.mean),mode:v_.bind(null,U_.mode),prod:v_.bind(null,U_.prod),median:v_.bind(null,U_.median)};function v_(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(v_,"aggregateFunction");function r7(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=t7(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(r7,"searchJSON")});var xv=N((mOe,Hv)=>{"use strict";var nr=require("moment"),kR="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(kR),"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(kR),"get_server_time"),offset_utc:a((e,t)=>nr(e).utc().utcOffset(t).format(kR),"offset_utc")}});var qv=N((TOe,Gv)=>{"use strict";var n7=require("@turf/area"),s7=require("@turf/length"),i7=require("@turf/circle"),o7=require("@turf/difference"),a7=require("@turf/distance"),c7=require("@turf/boolean-contains"),l7=require("@turf/boolean-equal"),u7=require("@turf/boolean-disjoint"),d7=require("@turf/helpers"),kv=M(),$e=te(),oo=W();Gv.exports={geoArea:_7,geoLength:f7,geoCircle:E7,geoDifference:h7,geoDistance:Fv,geoNear:p7,geoContains:m7,geoEqual:S7,geoCrosses:T7,geoConvert:g7};function _7(e){if($e.isEmpty(e))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e));try{return n7.default(e)}catch(t){return oo.trace(t,e),NaN}}a(_7,"geoArea");function f7(e,t){if($e.isEmpty(e))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e));try{return s7.default(e,{units:t||"kilometers"})}catch(r){return oo.trace(r,e),NaN}}a(f7,"geoLength");function E7(e,t,r){if($e.isEmpty(e))return NaN;if($e.isEmpty(t))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e));try{return i7.default(e,t,{units:r||"kilometers"})}catch(n){return oo.trace(n,e,t),NaN}}a(E7,"geoCircle");function h7(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 o7(e,t)}catch(r){return oo.trace(r,e,t),NaN}}a(h7,"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 a7.default(e,t,{units:r||"kilometers"})}catch(n){return oo.trace(n,e,t),NaN}}a(Fv,"geoDistance");function p7(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 oo.trace(s,e,t),!1}}a(p7,"geoNear");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 oo.trace(r,e,t),!1}}a(m7,"geoContains");function S7(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 l7.default(e,t)}catch(r){return oo.trace(r,e,t),!1}}a(S7,"geoEqual");function T7(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!u7.default(e,t)}catch(r){return oo.trace(r,e,t),!1}}a(T7,"geoCrosses");function g7(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)),d7[t](e,r)}a(g7,"geoConvert")});var Ep=N((AOe,$v)=>{var Tc=Bv(),Gn=xv(),Oi=qv();$v.exports=e=>{e.aggr.mad=e.aggr.MAD=Tc.mad,e.aggr.mean=e.aggr.MEAN=Tc.mean,e.aggr.mode=e.aggr.MODE=Tc.mode,e.aggr.prod=e.aggr.PROD=Tc.prod,e.aggr.median=e.aggr.MEDIAN=Tc.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=Tc.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=Tc.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((ROe,Yv)=>{"use strict";var B_=require("lodash"),_n=require("alasql");_n.options.cache=!1;var A7=Ep(),Vv=require("clone"),hp=require("recursive-iterator"),Ue=W(),et=te(),Jl=Bn(),R7=M(),{hdb_errors:y7}=_e(),{getDatabases:Kv}=(Pe(),oe(lt)),b7="IS NULL",Ws="There was a problem performing this search. Please check the logs and try again.";A7(_n);var FR=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 hp(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=B_.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 hp(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 hp(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(R7.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&&B_.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(b7)>-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=B_.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 Jl.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 Jl.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 Jl.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 Jl.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=B_.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 hp(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=B_.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 Jl.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(y7.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 Jl.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=FR});var Vr=N((bOe,jv)=>{"use strict";var O7=YD();jv.exports={searchByConditions:I7,searchByHash:w7,searchByValue:C7,search:D7};var GR=Bn(),{transformReq:qR}=te(),N7=Wv();async function I7(e){return qR(e),GR.searchByConditions(e)}a(I7,"searchByConditions");async function w7(e){qR(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of GR.searchByHash(e))r&&t.push(r);return t}a(w7,"searchByHash");async function C7(e){qR(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of GR.searchByValue(e))t.push(r);return t}a(C7,"searchByValue");function D7(e,t){try{let r=new O7(e);r.validate(),new N7(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(D7,"search")});var pp=N((NOe,zv)=>{"use strict";var P7=Bn();zv.exports={writeTransaction:L7};function L7(e,t,r){return P7.writeTransaction(e,t,r)}a(L7,"writeTransaction")});var Zv=N((COe,Xv)=>{"use strict";var M7=Vr(),U7=ls(),Qv=W(),v7=un(),wOe=pp(),B7=require("clone"),VR=require("alasql"),H7=Ep(),Jv=require("util"),x7=Jv.promisify(U7.getTableSchema),k7=Jv.promisify(M7.search),F7=M(),$R=te();H7(VR);Xv.exports={update:q7};var G7="There was a problem performing this update. Please check the logs and try again.";async function q7({statement:e,hdb_user:t}){let r=await x7(e.table.databaseid,e.table.tableid),n=$7(e.columns);$R.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=B7(s),c=$R.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,u=VR.parse(l).statements[0],d=await k7(u),_=V7(n,d);return K7(o,_,t)}a(q7,"update");function $7(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=VR.compile(`SELECT ${r.expression.toString()} AS [${F7.FUNC_VAL}] FROM ?`)}),t}catch(t){throw Qv.error(t),new Error(G7)}}a($7,"createUpdateRecord");function V7(e,t){return $R.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(V7,"buildUpdateRecords");async function K7(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await v7.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(K7,"updateRecords")});var t0=N((MOe,e0)=>{var Y7=require("alasql"),W7=Vr(),j7=W(),z7=Bn(),YR=require("util"),KR=te(),Q7=M(),J7=ls(),POe=pp(),LOe=un(),X7="record",Z7="successfully deleted",eee=YR.callbackify(see),tee=YR.promisify(W7.search),ree=YR.promisify(J7.getTableSchema);e0.exports={convertDelete:eee};function nee(e){return`${e.deleted_hashes.length} ${X7}${e.deleted_hashes.length===1?"":"s"} ${Z7}`}a(nee,"generateReturnMessage");async function see({statement:e,hdb_user:t}){let r=await ree(e.table.databaseid,e.table.tableid);KR.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=KR.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=Y7.parse(o).statements[0],l={operation:Q7.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await tee(c);let u=await z7.deleteRecords(l);return KR.isEmptyOrZeroLength(u.message)&&(u.message=nee(u)),delete u.txn_time,u}catch(u){throw j7.error(u),u.hdb_code?u.message:u}}a(see,"convertDelete")});var o0=N((vOe,i0)=>{"use strict";var iee=ro(),{hdb_errors:r0}=_e(),{getDatabases:n0}=(Pe(),oe(lt));i0.exports={checkSchemaExists:s0,checkSchemaTableExists:oee,schema_describe:iee};async function s0(e){if(!n0()[e])return r0.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(s0,"checkSchemaExists");async function oee(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(oee,"checkSchemaTableExists")});var Xl=N((HOe,aee)=>{aee.exports={name:"harperdb",version:"4.4.20",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","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 G_={};je(G_,{addAnalyticsListener:()=>F_,recordAction:()=>pr,recordActionBinary:()=>qn,setAnalyticsEnabled:()=>cee});function cee(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=Tp.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},Tp.set(i,o)}mp||lee()}function qn(e,t,r,n,s){pr(!!e,t,r,n,s)}function F_(e){S0.push(e)}function lee(){mp=performance.now(),setTimeout(async()=>{let e=performance.now()-mp;mp=0;let t=[],r={time:Date.now(),period:e,threadId:gc.threadId,metrics:t};for(let[s,i]of Tp){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:gc.threadId,byThread:!0,...n});for(let s of S0)s(t);Tp=new Map,gc.parentPort?gc.parentPort.postMessage({type:m0,report:r}):y0({report:r})},p0).unref()}async function uee(e,t=6e4){let r=zR(),n=A0(),s=new Promise(T=>{let m=performance.now();setImmediate(()=>{let g=performance.now();g-m>5e3&&(0,H_.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,H_.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 j=X+(I?"-"+I:"");U!==void 0&&(j+="-"+U),H!==void 0&&(j+="-"+H);let ae=c.get(j);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(j,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(j);Oe?Oe.push(...ne):l.set(j,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,j,ae,Oe]=y;Object.assign(g,{p1:X,p10:Y,p25:V,median:ne,p75:Q,p90:de,p95:j,p99:ae,p999:Oe})}let _;for(let[T,m]of c)m.id=(0,Sp.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,Sp.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 zR(){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 fee(){R0=!0;let e=(0,k_.get)(jR.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await uee(p0,e),await l0(zR(),dee),await l0(A0(),_ee)},Math.min(e/2,2147483647)).unref()}function y0(e,t){let r=e.report;r.threadId=t?.threadId||gc.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,Sp.getNextMonotonicTime)(),zR().primaryStore.put(r.id,r),R0||fee(),Eee&&(b0=pee(r))}async function pee(e){if(await b0,!Zo){let r=(0,x_.dirname)((0,H_.getLogFilePath)());try{Zo=await(0,WR.open)((0,x_.join)(r,"analytics.log"),"r+")}catch{Zo=await(0,WR.open)((0,x_.join)(r,"analytics.log"),"w+")}}let t=(await Zo.stat()).size;if(t>hee){let r=Buffer.alloc(t);await Zo.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await Zo.write(r,{position:0}),await Zo.truncate(r.length),t=r.length}await Zo.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}`)}r4(n,r),yg(n);let s=n.toJSON();if(W2.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(z2)}}a(dh,"initConfig");function r4(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(r4,"checkForUpdatedConfig");function yg(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 Dl.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 Dl.CONFIG_VALIDATION("operationsApi.network.port and operationsApi.network.securePort cannot be the same value");let n=q2(r,t);if(n.error)throw Dl.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(yg,"validateConfig");function n4(e,t){jt===void 0&&(jt={});let r=ks[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(n4,"updateConfigObject");function JC(e,t,r=void 0,n=!1,s=!1,i=!1){jt===void 0&&dh();let o=QC(ks.hdb_root),c=Ln.join(o,on.HDB_CONFIG_FILE),l=Vo(c),u;if(r===void 0&&e.toLowerCase()===Pn.DATABASES)u=t;else if(r===void 0){let E;if(i)E=e;else if(E=ks[e.toLowerCase()],E===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let f=E.split("_"),h=Rg(E,t);l.setIn([...f],h)}else for(let E in r){let f=ks[E.toLowerCase()];if(f===Pn.HTTP_SECUREPORT&&r[E]===jt[Pn.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),f===Pn.OPERATIONSAPI_NETWORK_SECUREPORT&&r[E]===jt[Pn.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&l.setIn(["operationsApi","network","port"],null),f===Pn.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=Rg(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),yg(l);let d=l.getIn(["rootPath"]),_=Ln.join(d,on.HDB_CONFIG_FILE);n===!0&&s4(c,d),$r.writeFileSync(_,String(l)),s&&(jt=Pl(l.toJSON())),hr.trace(`Config parameter: ${e} updated with value: ${t}`)}a(JC,"updateConfigValue");function s4(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(Q2),hr.error(r)}}a(s4,"backupConfigFile");var i4=["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}),uh=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])&&!i4.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;!Pn[l.toUpperCase()]&&ks[l]&&(s[ks[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 Rg(e,t){if(e===Pn.CLUSTERING_NODENAME||e===Pn.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($2(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(Rg,"castConfigValue");function o4(){let e=Er.getPropsFilePath(),t=Xa(e);return Vo(t).toJSON()}a(o4,"getConfiguration");async function a4(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return JC(void 0,void 0,s,!0),Z2}catch(i){throw typeof i=="string"||i instanceof String?K2(i,i,Y2.BAD_REQUEST,void 0,void 0,!0):i}}a(a4,"setConfiguration");function bg(){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=Xa(e);return Vo(t).toJSON()}a(bg,"readConfigFile");function Vo(e){return YC.parseDocument($r.readFileSync(e,"utf8"),{simpleKeys:!0})}a(Vo,"parseYamlDoc");function c4(){let e=bg(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=Er.isEmptyOrZeroLength(t)?[]:t;let r=VC(t);if(r)throw Dl.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=Er.isEmptyOrZeroLength(n)?[]:n;let s=VC(n);if(s)throw Dl.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 Dl.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(c4,"getClusteringRoutes");function XC(e){let t=WC(e);jt={};for(let r in ks){let n=t.get(r.toUpperCase());if(Er.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=ks[r].toLowerCase();s===Pn.LOGGING_ROOT?jt[s]=Ln.dirname(n):jt[s]=n}return jt}a(XC,"initOldConfig");function l4(e){let t=bg();return V2.get(t,e.replaceAll("_","."))}a(l4,"getConfigFromFile");async function u4(e,t){let r=Vo(Xa());r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),await $r.writeFile(Xa(),String(r))}a(u4,"addConfig");function d4(e){let t=Xa(Er.getPropsFilePath()),r=Vo(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=Ln.join(n,on.HDB_CONFIG_FILE);$r.writeFileSync(s,String(r))}a(d4,"deleteConfigFromFile");function _4(){return uh||(dh(),uh)}a(_4,"getConfigObj");function f4(){return jt||dh(),jt}a(f4,"getFlatConfigObj")});var se=N((sD,iD)=>{"use strict";var Og=require("fs-extra"),Za=require("path"),eD=require("os"),E4=require("properties-reader"),Kd=W(),Vd=te(),De=M(),_h=wt(),h4="Error initializing environment manager",fh="BOOT_PROPS_FILE_PATH",tD=!1,p4={[De.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[De.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},Qi={};Object.assign(sD,iD.exports={BOOT_PROPS_FILE_PATH:fh,getHdbBasePath:m4,setHdbBasePath:S4,get:rD,initSync:g4,setProperty:Qe,initTestEnvironment:R4,setCloneVar:A4});function m4(){return Qi[De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(m4,"getHdbBasePath");function S4(e){Qi[De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(S4,"setHdbBasePath");function rD(e){let t=_h.getConfigValue(e);return t===void 0?Qi[e]:t}a(rD,"get");function Qe(e,t){p4[e]&&(Qi[e]=t),_h.updateConfigObject(e,t)}a(Qe,"setProperty");function T4(){let e;try{e=Vd.getPropsFilePath(),Og.accessSync(e,Og.constants.F_OK|Og.constants.R_OK),tD=!0;let t=E4(e);return Qi[De.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(De.HDB_SETTINGS_NAMES.INSTALL_USER),Qi[De.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(De.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),Qi[fh]=e,!0}catch{return Kd.trace(`Environment manager found no properties file at ${e}`),!1}}a(T4,"doesPropFileExist");function g4(e=!1){try{((tD||T4()||Vd.noBootFile())&&!nD||e)&&(_h.initConfig(e),Qi[De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=_h.getConfigValue(De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){Kd.error(h4),Kd.error(t),console.error(t),process.exit(1)}}a(g4,"initSync");var nD=!1;function A4(e){nD=e}a(A4,"setCloneVar");function R4(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=Za.join(__dirname,"../../","unitTests");Qi[fh]=Za.join(l,"hdb_boot_properties.file"),Qe(De.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,Za.join(l,"settings.test")),Qe(De.HDB_SETTINGS_NAMES.INSTALL_USER,eD.userInfo()?eD.userInfo().username:void 0),Qe(De.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),Qe(De.HDB_SETTINGS_NAMES.LOG_PATH_KEY,Za.join(l,"envDir","log")),Qe(De.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),Qe(De.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),Qe(De.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),Qe(De.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,Za.join(l,"envDir")),Qe(De.CONFIG_PARAMS.STORAGE_PATH,Za.join(l,"envDir")),s&&(Qe(De.CONFIG_PARAMS.HTTP_SECUREPORT,rD(De.CONFIG_PARAMS.HTTP_PORT)),Qe(De.CONFIG_PARAMS.HTTP_PORT,null)),Qe(De.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,!!s),Qe(De.CONFIG_PARAMS.HTTP_PORT,9926),Qe(De.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),Qe(De.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT,9925),Qe(De.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,Vd.isEmpty(i)?!1:i),Qe(De.CONFIG_PARAMS.HTTP_CORS,Vd.isEmpty(i)?!1:i),Qe(De.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),Qe(De.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),Qe(De.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),Qe(De.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),Qe(De.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,Za.resolve(__dirname,"../../unitTests/server/fastifyRoutes/custom_functions")),Qe(De.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,Vd.isEmpty(c)?!1:c),o&&(Qe("CORS_ACCESSLIST",o),Qe(De.CONFIG_PARAMS.HTTP_CORSACCESSLIST,o)),n&&(Qe(De.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,n),Qe(De.CONFIG_PARAMS.HTTP_TIMEOUT,n)),t&&(Qe(De.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),Qe(De.CONFIG_PARAMS.HTTP_KEEPALIVETIMEOUT,t)),r&&(Qe(De.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),Qe(De.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${fh}. Please check your boot props and settings files`;Kd.fatal(r),Kd.error(t)}}a(R4,"initTestEnvironment")});var gt=N((Wge,_D)=>{"use strict";var Qd=M(),y4=te(),an=se(),Jd=require("path"),b4=require("minimist"),oD=require("fs-extra"),aD=require("lodash");an.initSync();var{CONFIG_PARAMS:Ko,DATABASES_PARAM_CONFIG:Yd,SYSTEM_SCHEMA_NAME:Eh}=Qd,Wd,jd,zd;function cD(){if(Wd!==void 0)return Wd;if(an.getHdbBasePath()!==void 0)return Wd=an.get(Ko.STORAGE_PATH)||Jd.join(an.getHdbBasePath(),Qd.DATABASES_DIR_NAME),Wd}a(cD,"getBaseSchemaPath");function lD(){if(jd!==void 0)return jd;if(an.getHdbBasePath()!==void 0)return jd=dD(Eh),jd}a(lD,"getSystemSchemaPath");function uD(){if(zd!==void 0)return zd;if(an.getHdbBasePath()!==void 0)return zd=an.get(Qd.CONFIG_PARAMS.STORAGE_AUDIT_PATH)||Jd.join(an.getHdbBasePath(),Qd.TRANSACTIONS_DIR_NAME),zd}a(uD,"getTransactionAuditStoreBasePath");function O4(e,t){let r=an.get(Ko.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||Jd.join(uD(),e.toString())}a(O4,"getTransactionAuditStorePath");function dD(e,t){e=e.toString(),t=t&&t.toString();let r=an.get(Qd.CONFIG_PARAMS.DATABASES)?.[e];return t&&r?.tables?.[t]?.path||r?.path||Jd.join(cD(),e)}a(dD,"getSchemaPath");function N4(e,t){e=e.toString(),t=t.toString();let r=process.env;Object.assign(r,b4(process.argv));let n=r[Ko.DATABASES.toUpperCase()];if(n){let i;try{i=JSON.parse(n)}catch(o){if(!y4.isObject(n))throw o;i=n}for(let o of i){let c=o[Eh];if(!c)continue;let l=an.get(Ko.DATABASES);l=l??{};let u=c?.tables?.[t]?.[Yd.PATH];if(u)return aD.set(l,[Eh,Yd.TABLES,t,Yd.PATH],u),an.setProperty(Ko.DATABASES,l),u;let d=c?.[Yd.PATH];if(d)return aD.set(l,[Eh,Yd.PATH],d),an.setProperty(Ko.DATABASES,l),d}}let s=r[Ko.STORAGE_PATH.toUpperCase()];if(s){if(!oD.pathExistsSync(s))throw new Error(s+" does not exist");let i=Jd.join(s,e);return oD.mkdirsSync(i),an.setProperty(Ko.STORAGE_PATH,s),i}return lD()}a(N4,"initSystemSchemaPaths");function I4(){Wd=void 0,jd=void 0,zd=void 0}a(I4,"resetPaths");_D.exports={getBaseSchemaPath:cD,getSystemSchemaPath:lD,getTransactionAuditStorePath:O4,getTransactionAuditStoreBasePath:uD,getSchemaPath:dD,initSystemSchemaPaths:N4,resetPaths:I4}});var cn=N((Jge,mD)=>{"use strict";var w4=Dn().LMDB_ERRORS_ENUM,zge=require("lmdb"),C4=Ht(),Qge=require("buffer").Buffer,{OVERFLOW_MARKER:fD,MAX_SEARCH_KEY_LENGTH:hh}=C4,ED=["number","string","symbol","boolean","bigint"];function D4(e){if(e=e?.primaryStore||e,!e)throw new Error(w4.ENV_REQUIRED)}a(D4,"validateEnv");function P4(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(P4,"stringifyData");function L4(e){return e instanceof Date?e.valueOf():e}a(L4,"convertKeyValueToWrite");function M4(e,t){if(e===null)return t?[null]:void 0;if(e===void 0)return;if(ED.includes(typeof e))return e.length>hh?[e.slice(0,hh)+fD]:[e];let r;if(Array.isArray(e)){r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n];if(ED.includes(typeof i))i.length>hh?r.push(i.slice(0,hh)+fD):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(M4,"getIndexedValues");var ph=0,hD=0;function pD(){hD=Date.now()-performance.now()}a(pD,"adjustStartTime");pD();var U4=6e4;setInterval(pD,U4).unref();function v4(){let e=performance.now()+hD;return e>ph?(ph=e,e):(ph+=488e-6,ph)}a(v4,"getNextMonotonicTime");mD.exports={validateEnv:D4,stringifyData:P4,convertKeyValueToWrite:L4,getNextMonotonicTime:v4,getIndexedValues:M4}});var Xd=N((Zge,SD)=>{"use strict";var B4=M().OPERATIONS_ENUM,Ng=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i=void 0){this.operation=B4.INSERT,this.schema=t,this.table=r,this.hash_attribute=n,this.records=s,this.__origin=i}};SD.exports=Ng});var Zd=N((rAe,RD)=>{"use strict";var tAe=Xd(),mh=M(),Ig=te(),TD=W(),H4=require("uuid"),{handleHDBError:Sh,hdb_errors:x4}=_e(),{HDB_ERROR_MSGS:Th,HTTP_STATUS_CODES:gh}=x4;RD.exports=gD;function gD(e,t,r){for(let s=0;s<t.length;s++)AD(t[s]);let{records:n}=e;for(let s=0;s<n.length;s++){let i=n[s];k4(i,r,e.operation)}}a(gD,"processRows");gD.validateAttribute=AD;function AD(e){if(Buffer.byteLength(String(e))>mh.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw Sh(new Error,Th.ATTR_NAME_LENGTH_ERR(e),gh.BAD_REQUEST,void 0,void 0,!0);if(Ig.isEmptyOrZeroLength(e)||Ig.isEmpty(e.trim()))throw Sh(new Error,Th.ATTR_NAME_NULLISH_ERR,gh.BAD_REQUEST,void 0,void 0,!0)}a(AD,"validateAttribute");function k4(e,t,r){if(!e.hasOwnProperty(t)||Ig.isEmptyOrZeroLength(e[t])){if(r===mh.OPERATIONS_ENUM.INSERT||r===mh.OPERATIONS_ENUM.UPSERT){e[t]=H4.v4();return}throw TD.error("Update transaction aborted due to record with no hash value:",e),Sh(new Error,Th.RECORD_MISSING_HASH_ERR,gh.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>mh.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw TD.error(e),Sh(new Error,Th.HASH_VAL_LENGTH_ERR,gh.BAD_REQUEST,void 0,void 0,!0)}a(k4,"validateHash")});var yD,Mn,wg,Ll=Ie(()=>{yD=require("events"),Mn=class extends yD.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;drainCloseListener;currentDrainResolver;[Symbol.asyncIterator](){let t=new wg;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)}},wg=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 Pg={};je(Pg,{loadGQLSchema:()=>q4,start:()=>Dg,startOnMainThread:()=>G4});function Dg({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 j=de.value.value;V.computed={from:m(j,de,X)},V.version==null&&(V.version=j)}else de.name.value==="version"&&(V.version=de.value.value);V.computed=V.computed||!0}else if(Q==="relationship"){let de={};for(let j of ne.arguments)de[j.name.value]=j.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 j of ne.arguments)j.name.value==="role"&&de.push(j.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):F4.includes(g.type)||(0,OD.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,Cg.dirname)(n),g.tableClass):i.set((0,Cg.dirname)(n)+"/"+(g.export.name||g.type),g.tableClass,g.export));function m(g,S,y){return new bD.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 Cg,bD,OD,F4,G4,q4,ND=Ie(()=>{Cg=require("path"),bD=require("node:vm");Pe();OD=L(dt()),F4=["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(Dg,"start");G4=Dg,q4=Dg({ensureTable:Et}).handleFile});var MD={};je(MD,{parse:()=>Mg,streamAsJSON:()=>e_,stringify:()=>ec});function e_(e){return new Lg({value:e})}function ID(e){return console.error(e),JSON.stringify(e.toString())}function wD(e,t,r){return e?.then?r?e.then(t,r):e.then(t):t(e)}function ec(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===PD)return LD(e);if(t.resolution)return t.resolution.then(()=>ec(e));throw t}}function LD(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+=LD(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+ec(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function Mg(e){return e?.length>0?(typeof e!="string"&&(e=e.toString()),K4.test(e)?$4.parse(e):JSON.parse(e)):null}var CD,DD,$4,V4,PD,Lg,K4,Ug=Ie(()=>{CD=require("stream"),DD=L(require("json-bigint-fixes")),$4=(0,DD.default)({useNativeBigInt:!0}),V4=1e4,PD={message:"Cannot serialize BigInt to JSON"};BigInt.prototype.toJSON=function(){throw PD};a(e_,"streamAsJSON");Lg=class extends CD.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),ID)}catch(s){yield ID(s)}else yield ec(t)}else yield ec(t)}_read(){if(!this._amReading){if(this._amReading=!0,this.done)return this.push(null);wD(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>V4?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 wD(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(ID,"handleError");a(wD,"when");a(ec,"stringify");a(LD,"jsStringify");K4=/[[,:]\s*-?\d{16,}/;a(Mg,"parse")});var YD=N((uAe,KD)=>{"use strict";var vg=require("recursive-iterator"),Y4=require("alasql"),Bg=require("clone"),UD=te(),{handleHDBError:vD,hdb_errors:W4}=_e(),{HDB_ERROR_MSGS:BD,HTTP_STATUS_CODES:HD}=W4,{getDatabases:j4}=(Pe(),oe(lt)),z4=["DISTINCT_ARRAY"],xD=Symbol("validateTables"),Hg=Symbol("validateTable"),lAe=Symbol("getAllColumns"),kD=Symbol("validateAllColumns"),Ah=Symbol("findColumn"),FD=Symbol("validateOrderBy"),t_=Symbol("validateSegment"),xg=Symbol("validateColumn"),GD=Symbol("setColumnsForTable"),qD=Symbol("checkColumnsForAsterisk"),$D=Symbol("validateGroupBy"),VD=Symbol("hasColumns"),kg=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[xD](),this[qD](),this[kD]()}[xD](){if(this[VD]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[Hg](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[Hg](t.table)})}}[VD](){let t=!1,r=new vg(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[Hg](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=j4();if(!r[t.databaseid])throw vD(new Error,BD.SCHEMA_NOT_FOUND(t.databaseid),HD.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw vD(new Error,BD.TABLE_NOT_FOUND(t.databaseid,t.tableid),HD.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=Bg(s);i.table=Bg(t),this.attributes.push(i)})}[Ah](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)}[qD](){let t=new vg(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[GD](r.tableid)}[GD](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new Y4.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[kD](){this[t_](this.statement.columns,!1),this[t_](this.statement.joins,!1),this[t_](this.statement.where,!1),this[$D](this.statement.group,!1),this[t_](this.statement.order,!0)}[t_](t,r){if(!t)return;let n=new vg(t),s=[];for(let{node:i,path:o}of n)!UD.isEmpty(i)&&!UD.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[FD](i):s.push(this[xg](i)));return s}[$D](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&z4.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=Bg(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[Ah](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[Ah](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`}[FD](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[xg](t)}[xg](t){let r=this[Ah](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]}};KD.exports=kg});var jD=N((_Ae,WD)=>{"use strict";var Fg=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")}};WD.exports=Fg});var QD=N((EAe,zD)=>{"use strict";var Gg=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};zD.exports=Gg});var eP={};je(eP,{HAS_EXPIRATION:()=>bh,HAS_RESIDENCY_ID:()=>zg,HAS_STRUCTURE_UPDATE:()=>Oh,LAST_TIMESTAMP_PLACEHOLDER:()=>i_,LOCAL_TIMESTAMP:()=>Q4,METADATA:()=>r_,NO_TIMESTAMP:()=>$g,PENDING_LOCAL_TIME:()=>Qg,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>jg,RecordEncoder:()=>Wg,TIMESTAMP_ASSIGN_LAST:()=>X4,TIMESTAMP_ASSIGN_NEW:()=>XD,TIMESTAMP_ASSIGN_PREVIOUS:()=>ZD,TIMESTAMP_PLACEHOLDER:()=>Rh,TIMESTAMP_RECORD_PREVIOUS:()=>Vg,getUpdateRecord:()=>Jg,handleLocalTimeForGets:()=>Nh});function eJ(){return s_[0]=s_[0]^64,J4.getFloat64(0)}function Nh(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?.[r_];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?.[r_]>=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[r_];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,tc.push(new WeakRef(this))),o.call(this)},i.prototype.done=function(){if(c.call(this),this.isDone)for(let l=0;l<tc.length;l++){let u=tc[l].deref();(!u||u.isDone||u.isCommitted)&&tc.splice(l--,1)}},i.prototype.done.isTracked=!0}return e}function Jg(e,t,r){return function(n,s,i,o,c=-1,l,u,d="put",_,E){_||l==null?Ml=i?.localTime?Vg|ZD:$g:Ml=l?i?.localTime?Vg|16384:XD|16384:$g;let f=u?.expiresAt;if(f>=0&&(c|=bh),n_=c,Kg=f,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let h={version:o,instructedWrite:Ml>0},T,m=0;try{let g=i?.residencyId,S=u?.residencyId;S&&(Yg=S,n_|=zg,m|=rc),g!==S&&(m|=nc,g||(g=0)),c&bh&&(m|=a_),u?.originatingOperation&&(m|=o_),_&&(h.ifVersion=T=i?.version??null);let y=e.put(n,s,h);if(l){let I=u?.user?.username;if(E&&(yh=e.encoder.encode(E)),e.encoder.hasStructureUpdate&&(m|=Oh,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,Ul(o,t,n,X,u?.nodeId??server.replication.getThisNodeId(r)??0,I,d,yh,m,S,g,f),{ifVersion:T}),y}}r.put(i_,Ul(o,t,n,i?.localTime?1:0,u?.nodeId??server.replication?.getThisNodeId(r)??0,I,d,yh,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 JD,qg,Rh,i_,jg,Q4,r_,s_,J4,$g,XD,X4,ZD,Vg,bh,zg,Qg,Oh,Z4,yh,Ml,n_,Kg,Yg,Wg,tc,vl=Ie(()=>{JD=require("msgpackr");Ji();qg=L(W()),Rh=new Uint8Array([1,1,1,1,4,64,0,0]),i_=new Uint8Array([1,1,1,1,1,0,0,0]),jg=new Uint8Array([1,1,1,1,3,64,0,0]),Q4=Symbol("local-timestamp"),r_=Symbol("metadata"),s_=new Uint8Array(8),J4=new DataView(s_.buffer,0,8),$g=0,XD=0,X4=1,ZD=3,Vg=4,bh=16,zg=32,Qg=1,Oh=256,Ml=0,n_=-1,Kg=-1,Yg=0,Wg=class extends JD.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(s,i){if(Ml||n_>=0){let o=0,c=Ml;c&&(o+=8,Ml=0);let l=n_,u=Kg,d=Yg;l>=0&&(o+=2,n_=-1,u>=0&&(o+=8,Kg=-1),d&&(o+=4,Yg=0));let _=Z4=r.call(this,s,i|2048|o);yh=_.subarray((_.start||0)+o,_.end);let E=_.start||0;return c&&(Rh[4]=c,Rh[5]=c>>8,_.set(Rh,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(s_,0,c),c+=8;else for(let E=0;E<8;E++)s_[E]=t[c++];l=eJ(),i=t[c]}let u,d;i<32&&(o=i|t[c+1]<<5,c+=2,o&bh&&(u=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8),o&zg&&(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:_,[r_]: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(eJ,"getTimestamp");a(Nh,"handleLocalTimeForGets");tc=[];setInterval(()=>{for(let e=0;e<tc.length;e++){let t=tc[e].deref();!t||t.isDone||t.isCommitted?tc.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(qg.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):qg.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(Jg,"getUpdateRecord")});var c_=N((TAe,rP)=>{"use strict";var tP=se(),tJ=M(),{RecordEncoder:rJ}=(vl(),oe(eP)),SAe=require("fs");tP.initSync();var nJ=tP.get(tJ.CONFIG_PARAMS.STORAGE_CACHING)!==!1,Xg=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=nJ&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:rJ})}};rP.exports=Xg});var l_=N((AAe,nP)=>{"use strict";var Un=se(),as=M();Un.initSync();var Ih=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(as.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Un.get(as.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Un.get(as.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Un.get(as.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Un.get(as.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Un.get(as.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Un.get(as.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Un.get(as.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Un.get(as.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Un.get(as.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Un.get(as.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Un.get(as.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};nP.exports=Ih;Ih.MAX_DBS=1e4});var ht=N((yAe,fP)=>{"use strict";var eA=require("lmdb"),Fs=require("fs-extra"),vn=require("path"),wh=cn(),oP=W(),ln=Dn().LMDB_ERRORS_ENUM,Ch=QD(),tA=c_(),aP=l_(),Yo=Ht(),sP=M(),{table:sJ,resetDatabases:iJ}=(Pe(),oe(lt)),iP=se(),Gs=Yo.INTERNAL_DBIS_NAME,cP=Yo.DBI_DEFINITION_NAME,oJ="data.mdb",aJ="lock.mdb",u_=".mdb",cJ="-lock",Zg=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=cs(t,r),this.key_type=this.dbi[Yo.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[Yo.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new eA.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function Dh(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(Dh,"pathEnvNameValidation");async function rA(e,t,r=!0){try{await Fs.access(e)}catch(n){throw n.code==="ENOENT"?new Error(ln.INVALID_BASE_PATH):n}try{let n=vn.join(e,t+u_);return await Fs.access(n,Fs.constants.R_OK|Fs.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await Fs.access(vn.join(e,t,oJ),Fs.constants.R_OK|Fs.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(rA,"validateEnvironmentPath");function Ph(e,t){if(wh.validateEnv(e),t===void 0)throw new Error(ln.DBI_NAME_REQUIRED)}a(Ph,"validateEnvDBIName");async function lJ(e,t,r=!1,n=!1){Dh(e,t);let s=vn.basename(e);t=t.toString();let i=iP.get(sP.CONFIG_PARAMS.DATABASES);i||iP.setProperty(sP.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await rA(e,t,n),lP(e,t,r)}catch(o){if(o.message===ln.INVALID_ENVIRONMENT){let c=vn.join(e,t);await Fs.mkdirp(n?c:e);let l=new aP(n?c:c+u_,!1),u=eA.open(l);u.dbis=Object.create(null);let d=new tA(!1);u.openDB(Gs,d),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let _=nA(e,t,r);return u[Yo.ENVIRONMENT_NAME_KEY]=_,global.lmdb_map[_]=u,u}throw o}}a(lJ,"createEnvironment");async function uJ(e,t,r,n=!0){Dh(e,t),t=t.toString();let s=vn.join(e,t);return sJ({table:t,database:vn.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(uJ,"copyEnvironment");async function lP(e,t,r=!1){Dh(e,t),t=t.toString();let n=nA(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 rA(e,t),i=vn.join(e,t+u_),o=s!=i,c=new aP(s,o),l=eA.open(c);l.dbis=Object.create(null);let u=dP(l);for(let d=0;d<u.length;d++)cs(l,u[d]);return l[Yo.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(lP,"openEnvironment");async function dJ(e,t,r=!1){Dh(e,t),t=t.toString();let n=vn.join(e,t+u_),s=await rA(e,t);if(global.lmdb_map!==void 0){let i=nA(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await uP(o),delete global.lmdb_map[i]}}await Fs.remove(s),await Fs.remove(s===n?s+cJ:vn.join(vn.dirname(s),aJ))}a(dJ,"deleteEnvironment");async function uP(e){wh.validateEnv(e);let t=e[Yo.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(uP,"closeEnvironment");function nA(e,t,r=!1){let s=`${vn.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(nA,"getCachedEnvironmentName");function _J(e){wh.validateEnv(e);let t=Object.create(null),r=cs(e,Gs);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==Gs)try{t[n]=Object.assign(new Ch,s)}catch{oP.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(_J,"listDBIDefinitions");function dP(e){wh.validateEnv(e);let t=[],r=cs(e,Gs);for(let{key:n}of r.getRange({start:!1}))n!==Gs&&t.push(n);return t}a(dP,"listDBIs");function fJ(e,t){let n=cs(e,Gs).getEntry(t),s=new Ch;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{oP.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(fJ,"getDBIDefinition");function _P(e,t,r,n=!r){if(Ph(e,t),t=t.toString(),t===Gs)throw new Error(ln.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return cs(e,t)}catch(s){if(s.message===ln.DBI_DOES_NOT_EXIST){let i=new tA(r,n===!0),o=e.openDB(t,i),c=new Ch(r===!0,n);return o[cP]=c,cs(e,Gs).putSync(t,c),e.dbis[t]=o,o}throw s}}a(_P,"createDBI");function cs(e,t){if(Ph(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==Gs?r=fJ(e,t):r=new Ch,r===void 0)throw new Error(ln.DBI_DOES_NOT_EXIST);let n;try{let s=new tA(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[cP]=r,e.dbis[t]=n,n}a(cs,"openDBI");function EJ(e,t){Ph(e,t),t=t.toString();let r=cs(e,t),n=r.getStats();return r[Yo.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(EJ,"statDBI");async function hJ(e,t){try{let r=vn.join(e,t+u_);return(await Fs.stat(r)).size}catch{throw new Error(ln.INVALID_ENVIRONMENT)}}a(hJ,"environmentDataSize");function pJ(e,t){if(Ph(e,t),t=t.toString(),t===Gs)throw new Error(ln.CANNOT_DROP_INTERNAL_DBIS_NAME);cs(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],cs(e,Gs).removeSync(t)}a(pJ,"dropDBI");function mJ(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{cs(e,i)}catch(o){if(o.message===ln.DBI_DOES_NOT_EXIST)_P(e,i,i!==t,i===t),n=!0;else throw o}}n&&iJ()}a(mJ,"initializeDBIs");fP.exports={openDBI:cs,openEnvironment:lP,createEnvironment:lJ,listDBIs:dP,listDBIDefinitions:_J,createDBI:_P,dropDBI:pJ,statDBI:EJ,deleteEnvironment:dJ,initializeDBIs:mJ,TransactionCursor:Zg,environmentDataSize:hJ,copyEnvironment:uJ,closeEnvironment:uP}});var hP=N((OAe,EP)=>{"use strict";var sA=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};EP.exports=sA});var mP=N((IAe,pP)=>{"use strict";var iA=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}};pP.exports=iA});var TP=N((CAe,SP)=>{"use strict";var oA=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};SP.exports=oA});var ic=N((UAe,RP)=>{"use strict";var SJ=ht(),TJ=hP(),gJ=mP(),AJ=TP(),mi=cn(),d_=Dn().LMDB_ERRORS_ENUM,RJ=Ht(),Xi=M(),yJ=te(),bJ=require("uuid"),PAe=require("lmdb"),{handleHDBError:OJ,hdb_errors:NJ}=_e(),{OVERFLOW_MARKER:LAe,MAX_SEARCH_KEY_LENGTH:MAe}=RJ,gP=se();gP.initSync();var Lh=gP.get(Xi.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),aA=Xi.TIME_STAMP_NAMES_ENUM.CREATED_TIME,sc=Xi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function IJ(e,t,r,n,s=mi.getNextMonotonicTime()){dA(e,t,r,n),cA(e,t,r);let i=new TJ,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l];AP(u,!0,s);let d=wJ(e,t,r,u),_=u[t];o.push(d),c.push(_)}return lA(o,c,n,i,s)}a(IJ,"insertRecords");function wJ(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][Xi.FUNC_VAL],n[o]=c)}let l=mi.getIndexedValues(c),u=e.dbis[o];if(l){Lh&&u.prefetch(l.map(d=>({key:d,value:s})),Mh);for(let d=0,_=l.length;d<_;d++)u.put(l[d],s)}}Lh&&e.dbis[t].prefetch([s],Mh),e.dbis[t].put(s,n,n[sc])})}a(wJ,"insertRecord");function CJ(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(CJ,"removeSkippedRecords");function AP(e,t,r){let n=r>0;(n||!Number.isInteger(e[sc]))&&(e[sc]=r||(r=mi.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[aA]))&&(e[aA]=r||mi.getNextMonotonicTime()):delete e[aA]}a(AP,"setTimestamps");function cA(e,t,r){r.indexOf(Xi.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(Xi.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(Xi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(Xi.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),SJ.initializeDBIs(e,t,r)}a(cA,"initializeTransaction");async function DJ(e,t,r,n,s=mi.getNextMonotonicTime()){dA(e,t,r,n),cA(e,t,r);let i=new gJ,o=[],c=[],l=[];for(let u=0;u<n.length;u++){let d=n[u],_=d[t],E;try{E=uA(e,t,d,_,i,!0,s)}catch{i.skipped_hashes.push(_),o.push(u);continue}c.push(E),l.push(_)}return lA(c,l,n,i,s,o)}a(DJ,"updateRecords");async function PJ(e,t,r,n,s=mi.getNextMonotonicTime()){try{dA(e,t,r,n)}catch(l){throw OJ(l,l.message,NJ.HTTP_STATUS_CODES.BAD_REQUEST)}cA(e,t,r);let i=new AJ,o=[],c=[];for(let l=0;l<n.length;l++){let u=n[l],d;yJ.isEmpty(u[t])?(d=bJ.v4(),u[t]=d):d=u[t];let _=uA(e,t,u,d,i,!1,s);o.push(_),c.push(d)}return lA(o,c,n,i,s)}a(PJ,"upsertRecords");async function lA(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(),CJ(r,i),n}a(lA,"finalizeWrite");function uA(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(AP(r,!d,o),Number.isInteger(r[sc])&&u[sc]>r[sc])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][Xi.FUNC_VAL],r[h]=T)}if(T===g)continue;let S=mi.getIndexedValues(g);if(S){Lh&&m.prefetch(S.map(y=>({key:y,value:n})),Mh);for(let y=0,I=S.length;y<I;y++)m.remove(S[y],n)}if(S=mi.getIndexedValues(T),S){Lh&&m.prefetch(S.map(y=>({key:y,value:n})),Mh);for(let y=0,I=S.length;y<I;y++)m.put(S[y],n)}}let f={...u,...r};c.put(n,f,f[sc])},"do_put");return l?_=c.ifVersion(n,l.version,E):_=c.ifNoExists(n,E),_.then(f=>f?!0:uA(e,t,r,n,s,i,o))}a(uA,"updateUpsertRecord");function LJ(e,t,r){if(mi.validateEnv(e),t===void 0)throw new Error(d_.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(d_.WRITE_ATTRIBUTES_REQUIRED):new Error(d_.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(LJ,"validateBasic");function dA(e,t,r,n){if(LJ(e,t,r),!Array.isArray(n))throw n===void 0?new Error(d_.RECORDS_REQUIRED):new Error(d_.RECORDS_MUST_BE_ARRAY)}a(dA,"validateWrite");function Mh(){}a(Mh,"noop");RP.exports={insertRecords:IJ,updateRecords:DJ,upsertRecords:PJ}});var Zi=N((BAe,MJ)=>{MJ.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((HAe,OP)=>{"use strict";var bP=te(),yP=M(),Bl=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Si=require("joi"),Wo={schema_format:{pattern:Bl,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},UJ=Si.alternatives(Si.string().min(1).max(Wo.schema_length.maximum).pattern(Bl).messages({"string.pattern.base":"{:#label} "+Wo.schema_format.message}),Si.number(),Si.array()).required(),vJ=Si.alternatives(Si.string().min(1).max(Wo.schema_length.maximum).pattern(Bl).messages({"string.pattern.base":"{:#label} "+Wo.schema_format.message}),Si.number()),BJ=Si.alternatives(Si.string().min(1).max(Wo.schema_length.maximum).pattern(Bl).messages({"string.pattern.base":"{:#label} "+Wo.schema_format.message}),Si.number()).required();function HJ(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>Wo.schema_length.maximum?`'${e}' maximum of 250 characters`:Bl.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(HJ,"checkValidTable");function xJ(e,t){return bP.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(xJ,"validateSchemaExists");function kJ(e,t){let r=t.state.ancestors[0].schema;return bP.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(kJ,"validateTableExists");function FJ(e,t){return e.toLowerCase()===yP.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${yP.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(FJ,"validateSchemaName");OP.exports={common_validators:Wo,schema_regex:Bl,hdb_schema_table:UJ,validateSchemaExists:xJ,validateTableExists:kJ,validateSchemaName:FJ,checkValidTable:HJ,hdb_database:vJ,hdb_table:BJ}});var Uh=N((kAe,NP)=>{var{common_validators:gi}=Ti(),f_=Tt(),__="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_(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(E_,"makeAttributesStrings");function GJ(e){return e=E_(e),rr.table.presence=!1,rr.attribute.presence=!1,rr.hash_attribute.presence=!1,f_.validateObject(e,rr)}a(GJ,"schema_object");function qJ(e){return e=E_(e),rr.table.presence={message:__},rr.attribute.presence=!1,rr.hash_attribute.presence=!1,f_.validateObject(e,rr)}a(qJ,"table_object");function $J(e){return e=E_(e),rr.table.presence={message:__},rr.attribute.presence=!1,f_.validateObject(e,rr)}a($J,"create_table_object");function VJ(e){return e=E_(e),rr.table.presence={message:__},rr.attribute.presence={message:__},rr.hash_attribute.presence=!1,f_.validateObject(e,rr)}a(VJ,"attribute_object");function KJ(e){return e=E_(e),rr.table.presence={message:__},rr.attribute.presence=!1,rr.hash_attribute.presence=!1,f_.validateObject(e,rr)}a(KJ,"describe_table");function YJ(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(YJ,"validateTableResidence");NP.exports={schema_object:GJ,create_table_object:$J,table_object:qJ,attribute_object:VJ,describe_table:KJ,validateTableResidence:YJ}});var wP=N((GAe,IP)=>{"use strict";var WJ=require("uuid"),_A=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||WJ.v4(),this.schema_table=`${this.schema}.${this.table}`}};IP.exports=_A});var vh=N(($Ae,CP)=>{"use strict";var jJ=wP(),fA=class extends jJ{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}};CP.exports=fA});var PP=N((KAe,DP)=>{"use strict";DP.exports=QJ;var zJ="inserted";function QJ(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===zJ?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(QJ,"returnObject")});var Bh=N((jAe,vP)=>{"use strict";var JJ=M(),EA=ht(),XJ=ic(),{getSystemSchemaPath:ZJ,getSchemaPath:e3}=gt(),WAe=Zi(),t3=Uh(),r3=vh(),n3=PP(),{handleHDBError:LP,hdb_errors:UP}=_e(),MP=te(),{HTTP_STATUS_CODES:s3}=UP,i3="inserted";vP.exports=o3;async function o3(e){let t=t3.attribute_object(e);if(t)throw LP(new Error,t.message,UP.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=!e.skip_table_check&&MP.checkGlobalSchemaTable(e.schema,e.table);if(r)throw LP(new Error,r,s3.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=MP.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 r3(e.schema,e.table,e.attribute,e.id);try{let i=await EA.openEnvironment(e3(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}`);EA.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await EA.openEnvironment(ZJ(),JJ.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await XJ.insertRecords(o,HDB_TABLE_INFO.hash_attribute,hdb_attribute_attributes,[s]);return n3(i3,c,{records:[s]},l)}catch(i){throw i}}a(o3,"lmdbCreateAttribute")});var pA=N((QAe,HP)=>{var{hdb_table:a3,hdb_database:BP}=Ti(),c3=Tt(),hA=require("joi"),l3={undefined:"undefined",null:"null"},u3=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||l3[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"),d3=hA.object({database:BP,schema:BP,table:a3,records:hA.array().items(hA.object().custom(u3)).required()});HP.exports=function(e){return c3.validateBySchema(e,d3)}});var h_=N((ZAe,kP)=>{"use strict";var eo=te(),xP=W(),XAe=pA(),{getDatabases:_3}=(Pe(),oe(lt)),{ClientError:oc}=_e();kP.exports=f3;function f3(e){if(eo.isEmpty(e))throw new oc("invalid update parameters defined.");if(eo.isEmptyOrZeroLength(e.schema))throw new oc("invalid schema specified.");if(eo.isEmptyOrZeroLength(e.table))throw new oc("invalid table specified.");if(!Array.isArray(e.records))throw new oc("records must be an array");let t=_3()[e.schema]?.[e.table];if(eo.isEmpty(t))throw new oc(`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&&eo.isEmptyOrZeroLength(o[r]))throw xP.error("a valid hash attribute must be provided with update record:",o),new oc("a valid hash attribute must be provided with update record, check log for more info");if(!eo.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw xP.error(`a valid hash value must be provided with ${e.operation} record:`,o),new oc(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!eo.isEmpty(o[r])&&o[r]!==""&&n.has(eo.autoCast(o[r]))&&(o.skip=!0),n.add(eo.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(f3,"insertUpdateValidate")});var GP=N((tRe,FP)=>{"use strict";var mA=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};FP.exports=mA});var VP=N((nRe,$P)=>{"use strict";var SA=ht(),E3=W(),qP=Dn().LMDB_ERRORS_ENUM;$P.exports=h3;async function h3(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 SA.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==qP.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await SA.closeEnvironment(global.lmdb_map[n]),await SA.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==qP.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){E3.error(t)}}a(h3,"cleanLMDBMap")});var to=N((iRe,jP)=>{"use strict";var p_=require("crypto"),p3=se(),{CONFIG_PARAMS:m3}=M(),YP="aes-256-cbc",S3=32,T3=16,TA=64,WP=32,g3=TA+WP,KP=new Map;jP.exports={encrypt:A3,decrypt:R3,createNatsTableStreamName:y3};function A3(e){let t=p_.randomBytes(S3),r=p_.randomBytes(T3),n=p_.createCipheriv(YP,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(A3,"encrypt");function R3(e){let t=e.substr(0,TA),r=e.substr(TA,WP),n=e.substr(g3,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=p_.createDecipheriv(YP,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(R3,"decrypt");function y3(e,t){let r=p3.get(m3.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=KP.get(r);return n||(n=p_.createHash("md5").update(r).digest("hex"),KP.set(r,n)),n}a(y3,"createNatsTableStreamName")});var ro=N((cRe,JP)=>{"use strict";var aRe=Vr(),m_=W(),zP=Uh(),b3=to(),Hh=te(),{handleHDBError:xh,hdb_errors:O3}=_e(),{HDB_ERROR_MSGS:kh,HTTP_STATUS_CODES:gA}=O3,QP=se();QP.initSync();var{getDatabases:AA}=(Pe(),oe(lt)),N3=require("fs-extra"),I3=M();JP.exports={describeAll:w3,describeTable:Fh,describeSchema:C3};async function w3(e={}){try{let t=Hh.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=AA(),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 Fh({schema:_,table:f,exact_count:u});else if(n&&n[_].describe&&n[_].tables[f].describe){let T=n[_].tables[f].attribute_permissions;h=await Fh({schema:_,table:f,exact_count:u},T)}h&&l.push(h)}catch(h){m_.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 m_.error("Got an error in describeAll"),m_.error(t),xh(new Error,kh.DESCRIBE_ALL_ERR)}}a(w3,"describeAll");async function Fh(e,t){Hh.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=zP.describe_table(e);if(i)throw i;let c=AA()[r];if(!c)throw xh(new Error,kh.SCHEMA_NOT_FOUND(e.schema),gA.NOT_FOUND);let l=c[n];if(!l)throw xh(new Error,kh.TABLE_NOT_FOUND(e.schema,e.table),gA.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 N3.stat(l.primaryStore.env.path)).size}catch(f){m_.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")),QP.get(I3.CONFIG_PARAMS.CLUSTERING_ENABLED)&&(E.clustering_stream_name=b3.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){m_.warn(`unable to stat table dbi due to ${f}`)}return E}a(Fh,"descTable");async function C3(e){Hh.transformReq(e);let t=zP.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=AA()[n];if(!i)throw xh(new Error,kh.SCHEMA_NOT_FOUND(e.schema),gA.NOT_FOUND);let o={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),Hh.isEmpty(l)||l.describe){let u=await Fh({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);u&&(o[u.name]=u)}}return o}a(C3,"describeSchema")});var ls=N((_Re,rL)=>{var D3=Zi(),{callbackify:ZP,promisify:P3}=require("util"),{getDatabases:eL}=(Pe(),oe(lt));rL.exports={setSchemaDataToGlobal:XP,getTableSchema:L3,getSystemSchema:M3,setSchemaDataToGlobalAsync:P3(XP)};var tL=ro(),uRe=ZP(tL.describeAll),dRe=ZP(tL.describeTable);function XP(e){global.hdb_schema=eL(),e&&e()}a(XP,"setSchemaDataToGlobal");function L3(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(L3,"getTableSchema");function M3(){return D3}a(M3,"getSystemSchema")});var un=N((ERe,oL)=>{"use strict";var qh=pA(),Cr=te(),U3=require("util"),$h=Bn(),v3=ls(),nL=W(),{handleHDBError:ac,hdb_errors:B3}=_e(),{HTTP_STATUS_CODES:cc}=B3,H3=U3.promisify(v3.getTableSchema),x3="updated",sL="inserted",iL="upserted";oL.exports={insert:F3,update:G3,upsert:q3,validation:k3,flush:$3};async function k3(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 H3(e.schema,e.table),r=qh(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(k3,"validation");async function F3(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=qh(e);if(t)throw ac(new Error,t.message,cc.BAD_REQUEST);Cr.transformReq(e);let r=Cr.checkSchemaTableExist(e.schema,e.table);if(r)throw ac(new Error,r,cc.BAD_REQUEST);let n=await $h.createRecords(e);return Gh(sL,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(F3,"insertData");async function G3(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=qh(e);if(t)throw ac(new Error,t.message,cc.BAD_REQUEST);Cr.transformReq(e);let r=Cr.checkSchemaTableExist(e.schema,e.table);if(r)throw ac(new Error,r,cc.BAD_REQUEST);let n=await $h.updateRecords(e);return Cr.isEmpty(n.existing_rows)?Gh(x3,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):Gh(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(G3,"updateData");async function q3(e){if(e.operation!=="upsert")throw ac(new Error,"invalid operation, must be upsert",cc.INTERNAL_SERVER_ERROR);let t=qh(e);if(t)throw ac(new Error,t.message,cc.BAD_REQUEST);Cr.transformReq(e);let r=Cr.checkSchemaTableExist(e.schema,e.table);if(r)throw ac(new Error,r,cc.BAD_REQUEST);let n=await $h.upsertRecords(e);return Gh(iL,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(q3,"upsertData");function Gh(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(Gh,"returnObject");function $3(e){return Cr.transformReq(e),$h.flush(e.schema,e.table)}a($3,"flush")});var yA=N((pRe,lL)=>{var V3=Tt(),RA=require("joi"),{hdb_table:K3,hdb_database:aL}=Ti(),cL={schema:aL,database:aL,table:K3},Y3={date:RA.date().iso().required()},W3={timestamp:RA.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};lL.exports=function(e,t){let r=t==="timestamp"?{...cL,...W3}:{...cL,...Y3},n=RA.object(r);return V3.validateBySchema(e,n)}});var _L=N((mRe,dL)=>{var j3=Tt(),bA=require("joi"),{hdb_table:z3,hdb_database:uL}=Ti(),Q3=bA.object({schema:uL,database:uL,table:z3,hash_values:bA.array().required(),ids:bA.array()});dL.exports=function(e){return j3.validateBySchema(e,Q3)}});var wA=N((SRe,fL)=>{"use strict";var OA=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}},NA=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}},IA=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};fL.exports={InsertObject:OA,NoSQLSeachObject:NA,DeleteResponseObject:IA}});var dc=N((gRe,SL)=>{"use strict";var hL=yA(),J3=_L(),lc=te(),EL=require("moment"),pL=W(),{promisify:X3,callbackify:Z3}=require("util"),uc=M(),eX=ls(),CA=X3(eX.getTableSchema),DA=Bn(),{DeleteResponseObject:tX}=wA(),{handleHDBError:jo,hdb_errors:rX}=_e(),{HDB_ERROR_MSGS:Vh,HTTP_STATUS_CODES:zo}=rX,nX="records successfully deleted",sX=Z3(mL);SL.exports={delete:sX,deleteRecord:mL,deleteFilesBefore:iX,deleteAuditLogsBefore:oX};async function iX(e){let t=hL(e,"date");if(t)throw jo(t,t.message,zo.BAD_REQUEST,void 0,void 0,!0);if(lc.transformReq(e),!EL(e.date,EL.ISO_8601).isValid())throw jo(new Error,Vh.INVALID_DATE,zo.BAD_REQUEST,uc.LOG_LEVELS.ERROR,Vh.INVALID_DATE,!0);let n=lc.checkSchemaTableExist(e.schema,e.table);if(n)throw jo(new Error,n,zo.NOT_FOUND,uc.LOG_LEVELS.ERROR,n,!0);let s=await DA.deleteRecordsBefore(e);if(await CA(e.schema,e.table),pL.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(iX,"deleteFilesBefore");async function oX(e){let t=hL(e,"timestamp");if(t)throw jo(t,t.message,zo.BAD_REQUEST,void 0,void 0,!0);if(lc.transformReq(e),isNaN(e.timestamp))throw jo(new Error,Vh.INVALID_VALUE("Timestamp"),zo.BAD_REQUEST,uc.LOG_LEVELS.ERROR,Vh.INVALID_VALUE("Timestamp"),!0);let r=lc.checkSchemaTableExist(e.schema,e.table);if(r)throw jo(new Error,r,zo.NOT_FOUND,uc.LOG_LEVELS.ERROR,r,!0);let n=await DA.deleteAuditLogsBefore(e);return await CA(e.schema,e.table),pL.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(oX,"deleteAuditLogsBefore");async function mL(e){e.ids&&(e.hash_values=e.ids);let t=J3(e);if(t)throw jo(t,t.message,zo.BAD_REQUEST,void 0,void 0,!0);lc.transformReq(e);let r=lc.checkSchemaTableExist(e.schema,e.table);if(r)throw jo(new Error,r,zo.NOT_FOUND,uc.LOG_LEVELS.ERROR,r,!0);try{await CA(e.schema,e.table);let n=await DA.deleteRecords(e);return lc.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${nX}`),n}catch(n){if(n.message===uc.SEARCH_NOT_FOUND_MESSAGE){let s=new tX;return s.message=uc.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(mL,"deleteRecord")});var Kh=N((RRe,AL)=>{var aX=require("crypto"),TL=9;function cX(e){let t=uX(TL),r=gL(e+t);return t+r}a(cX,"createHash");function lX(e,t){let r=e?.substr(0,TL),n=r+gL(t+r);return e===n}a(lX,"validateHash");function uX(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(uX,"generateSalt");function gL(e){return aX.createHash("md5").update(e).digest("hex")}a(gL,"md5");AL.exports={hash:cX,validate:lX}});var yL=N((bRe,RL)=>{var PA=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 dX(e){return Kr.password.presence=!0,Kr.username.presence=!0,Kr.role.presence=!0,Kr.active.presence=!0,PA.validateObject(e,Kr)}a(dX,"addUserValidation");function _X(e){return Kr.password.presence=!1,Kr.username.presence=!0,Kr.role.presence=!1,Kr.active.presence=!1,PA.validateObject(e,Kr)}a(_X,"alterUserValidation");function fX(e){return Kr.password.presence=!1,Kr.username.presence=!0,Kr.role.presence=!1,Kr.active.presence=!1,PA.validateObject(e,Kr)}a(fX,"dropUserValidation");RL.exports={addUserValidation:dX,alterUserValidation:_X,dropUserValidation:fX}});var Ct=N((IRe,OL)=>{"use strict";var{platform:NRe}=require("os"),EX="nats-server.zip",LA="nats-server",hX=process.platform==="win32"?`${LA}.exe`:LA,pX=/^[^\s.,*>]+$/,bL="__request__",mX=a(e=>`${e}.${bL}`,"REQUEST_SUBJECT"),SX={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},TX={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},gX={HUB:"hub.pid",LEAF:"leaf.pid"},AX={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},RX={SUCCESS:"success",ERROR:"error"},yX={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},bX={TXN:"txn",MSGID:"msgid"},Hl={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},OX={[Hl.ERR]:1,[Hl.WRN]:2,[Hl.INF]:3,[Hl.DBG]:4,[Hl.TRC]:5},NX={debug:"-D",trace:"-DVV"};OL.exports={NATS_SERVER_ZIP:EX,NATS_SERVER_NAME:LA,NATS_BINARY_NAME:hX,PID_FILES:gX,NATS_CONFIG_FILES:TX,SERVER_SUFFIX:AX,NATS_TERM_CONSTRAINTS_RX:pX,REQUEST_SUFFIX:bL,UPDATE_REMOTE_RESPONSE_STATUSES:RX,CLUSTER_STATUS_STATUSES:yX,REQUEST_SUBJECT:mX,SUBJECT_PREFIXES:bX,MSG_HEADERS:SX,LOG_LEVELS:Hl,LOG_LEVEL_FLAGS:NX,LOG_LEVEL_HIERARCHY:OX}});var IL=N((CRe,NL)=>{"use strict";var Yh=M(),Wh=class{static{a(this,"BaseLicense")}constructor(t=0,r=Yh.RAM_ALLOCATION_ENUM.DEFAULT,n=Yh.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},MA=class extends Wh{static{a(this,"ExtendedLicense")}constructor(t=0,r=Yh.RAM_ALLOCATION_ENUM.DEFAULT,n=Yh.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};NL.exports={BaseLicense:Wh,ExtendedLicense:MA}});var _c=N((PRe,UL)=>{"use strict";var kl=require("fs-extra"),CL=Kh(),DL=require("crypto"),IX=require("moment"),wX=require("uuid").v4,Yr=W(),vA=require("path"),CX=te(),Qo=M(),{totalmem:wL}=require("os"),DX=IL().ExtendedLicense,xl="invalid license key format",PX="061183",LX="mofi25",MX="aes-256-cbc",UX=16,vX=32,PL=se(),{resolvePath:LL}=wt();PL.initSync();var UA;UL.exports={validateLicense:ML,generateFingerPrint:HX,licenseSearch:xA,getLicense:FX,checkMemoryLimit:GX};function BA(){return vA.join(PL.getHdbBasePath(),Qo.LICENSE_KEY_DIR_NAME,Qo.LICENSE_FILE_NAME)}a(BA,"getLicenseDirPath");function BX(){let e=BA();return LL(vA.join(e,Qo.LICENSE_FILE_NAME))}a(BX,"getLicenseFilePath");function HA(){let e=BA();return LL(vA.join(e,Qo.REG_KEY_FILE_NAME))}a(HA,"getFingerPrintFilePath");async function HX(){let e=HA();try{return await kl.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await xX();throw Yr.error(`Error writing fingerprint file to ${e}`),Yr.error(t),new Error("There was an error generating the fingerprint")}}a(HX,"generateFingerPrint");async function xX(){let e=wX(),t=CL.hash(e),r=HA();try{await kl.mkdirp(BA()),await kl.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(xX,"writeFingerprint");function ML(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:Qo.RAM_ALLOCATION_ENUM.DEFAULT,version:Qo.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return Yr.error("empty license key passed to validate."),r;let n=HA(),s=!1;try{s=kl.statSync(n)}catch(i){Yr.error(i)}if(s){let i;try{i=kl.readFileSync(n,"utf8")}catch{Yr.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(LX),c=o[1];c=Buffer.concat([Buffer.from(c)],UX);let l=Buffer.concat([Buffer.from(i)],vX),u=DL.createDecipheriv(MX,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=kX(o[0],i);if(f)d=f;else throw r.valid_license=!1,r.valid_machine=!1,console.error(xl),Yr.error(xl),new Error(xl)}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(xl),Yr.error(xl),new Error(xl)}else r.exp_date=d;r.exp_date<IX().valueOf()&&(r.valid_date=!1),CL.validate(o[1],`${PX}${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 kX(e,t){try{let r=DL.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(kX,"checkOldLicense");function xA(){let e=new DX,t=[];try{t=kl.readFileSync(BX(),"utf-8").split(Qo.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(CX.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=Qo.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return UA=e,e}a(xA,"licenseSearch");async function FX(){return UA||await xA(),UA}a(FX,"getLicense");function GX(){let e=xA().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(GX,"checkMemoryLimit")});var xn=N((BRe,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:QX,alterUser:JX,dropUser:ZX,getSuperUser:nZ,userInfo:eZ,listUsers:zh,listUsersExternal:tZ,setUsersToGlobal:Gl,findAndValidateUser:jL,getClusterUser:sZ,USERNAME_REQUIRED:xL,ALTERUSER_NOTHING_TO_UPDATE:kL,EMPTY_PASSWORD:FL,EMPTY_ROLE:GL,ACTIVE_BOOLEAN:qL};var $L=un(),qX=dc(),GA=Kh(),VL=yL(),KL=Vr(),qA=no(),Hn=te(),YL=require("validate.js"),Ke=W(),{promisify:$X}=require("util"),$A=to(),vL=M(),BL=Ct(),VX=wt(),MRe=se(),URe=_c(),KX=Zi(),{table:vRe}=(Pe(),oe(lt)),{handleHDBError:Ai,hdb_errors:YX}=_e(),{HTTP_STATUS_CODES:Ri,AUTHENTICATION_ERROR_MSGS:kA,HDB_ERROR_MSGS:Fl}=YX,{UserEventMsg:VA}=qs(),FA=require("lodash"),{server:KA}=(qr(),oe(Ja)),WX=W();KA.getUser=(e,t)=>jL(e,t,t!=null);var WL={username:!0,active:!0,role:!0,password:!0},HL=new Map,jh=KL.searchByValue,jX=KL.searchByHash,zX=$X(qX.delete);async function QX(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 jh(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,Fl.ROLE_NAME_NOT_FOUND(t.role),Ri.NOT_FOUND,void 0,void 0,!0);if(s.length>1)throw Ai(new Error,Fl.DUP_ROLES_FOUND(t.role),Ri.CONFLICT,void 0,void 0,!0);s[0].permission.cluster_user===!0&&(t.hash=$A.encrypt(t.password)),t.password=GA.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 Gl()}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,Fl.USER_ALREADY_EXISTS(t.username),Ri.CONFLICT,void 0,void 0,!0);let c={...t};return c.role=s[0],qA.signalUserChange(new VA(process.pid)),`${c.username} successfully added`}a(QX,"addUser");async function JX(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=XX(t.username);if(!Hn.isEmpty(t.password)&&!Hn.isEmptyOrZeroLength(t.password.trim())&&(r&&(t.hash=$A.encrypt(t.password)),t.password=GA.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 jh(i)||[])}catch(c){throw Ke.error("Got an error searching for a role."),Ke.error(c),c}if(!o||o.length===0){let c=Fl.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=Fl.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 Gl()}catch(i){throw Ke.error("Got an error setting users to global"),Ke.error(i),i}return qA.signalUserChange(new VA(process.pid)),s}a(JX,"alterUser");function XX(e){let t=!1,r=global.hdb_users.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(XX,"isClusterUser");async function ZX(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,Fl.USER_NOT_EXIST(e.username),Ri.NOT_FOUND,void 0,void 0,!0);let n;try{n=await zX(r)}catch(s){throw Ke.error("Got an error deleting a user."),Ke.error(s),s}Ke.debug(n);try{await Gl()}catch(s){throw Ke.error("Got an error setting users to global."),Ke.error(s),s}return qA.signalUserChange(new VA(process.pid)),`${e.username} successfully deleted`}catch(t){throw t}}a(ZX,"dropUser");async function eZ(e){let t={};try{if(!e||!e.hdb_user)return"There was no user info in the body";t=FA.cloneDeep(e.hdb_user);let r={schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]},n;try{n=await jX(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(eZ,"userInfo");async function tZ(){let e;try{e=await zh()}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(tZ,"listUsersExternal");async function zh(){try{let e={schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]},t;try{t=await jh(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]=FA.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 jh(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=FA.cloneDeep(o),o.role=r[o.role],rZ(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(zh,"listUsers");function rZ(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(KX)){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(rZ,"appendSystemTablesToRole");async function Gl(){try{let e=await zh();global.hdb_users=e}catch(e){throw Ke.error(e),e}}a(Gl,"setUsersToGlobal");async function jL(e,t,r=!0){global.hdb_users||await Gl();let n=global.hdb_users.get(e);if(!n){if(!r)return{username:e};throw Ai(new Error,kA.GENERIC_AUTH_FAIL,Ri.UNAUTHORIZED,void 0,void 0,!0)}if(n&&!n.active)throw Ai(new Error,kA.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(GA.validate(n.password,t))HL.set(t,n.password);else throw Ai(new Error,kA.GENERIC_AUTH_FAIL,Ri.UNAUTHORIZED,void 0,void 0,!0)}return s}a(jL,"findAndValidateUser");async function nZ(){global.hdb_users||await Gl();for(let[,e]of global.hdb_users)if(e.role.role==="super_user")return e}a(nZ,"getSuperUser");async function sZ(){let e=await zh(),t=VX.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=$A.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(sZ,"getClusterUser");var zL=[];KA.invalidateUser=function(e){for(let t of zL)try{t(e)}catch(r){WX.error("Error invalidating user",r)}};KA.onInvalidatedUser=function(e){zL.push(e)}});var T_=N((FRe,eM)=>{"use strict";var fc=W(),kn=M(),iZ=VP(),xRe=ls(),kRe=ro(),oZ=xn(),{validateEvent:JL}=qs(),S_=Bn(),aZ=require("process"),{resetDatabases:cZ}=(Pe(),oe(lt)),lZ={[kn.ITC_EVENT_TYPES.SCHEMA]:uZ,[kn.ITC_EVENT_TYPES.USER]:ZL};async function uZ(e){let t=JL(e);if(t){fc.error(t);return}fc.trace("ITC schemaHandler received schema event:",e),await iZ(e.message),await dZ(e.message)}a(uZ,"schemaHandler");async function dZ(e){try{S_.resetReadTxn(kn.SYSTEM_SCHEMA_NAME,kn.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),S_.resetReadTxn(kn.SYSTEM_SCHEMA_NAME,kn.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),S_.resetReadTxn(kn.SYSTEM_SCHEMA_NAME,kn.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=cZ();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){fc.error(t)}}a(dZ,"syncSchemaMetadata");var XL=[];async function ZL(e){try{try{S_.resetReadTxn(kn.SYSTEM_SCHEMA_NAME,kn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),S_.resetReadTxn(kn.SYSTEM_SCHEMA_NAME,kn.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){fc.warn(r)}let t=JL(e);if(t){fc.error(t);return}fc.trace(`ITC userHandler ${kn.HDB_ITC_CLIENT_PREFIX}${aZ.pid} received user event:`,e),await oZ.setUsersToGlobal();for(let r of XL)r()}catch(t){fc.error(t)}}a(ZL,"userHandler");ZL.addListener=function(e){XL.push(e)};eM.exports=lZ});var qs=N((YRe,rM)=>{"use strict";var qRe=W(),YA=te(),_Z=M(),{ITC_ERRORS:g_}=Dn(),{parentPort:$Re,threadId:fZ,isMainThread:EZ,workerData:VRe}=require("worker_threads"),{onMessageFromWorkers:hZ,broadcast:KRe,broadcastWithAcknowledgement:pZ}=dt();rM.exports={sendItcEvent:mZ,validateEvent:tM,SchemaEventMsg:SZ,UserEventMsg:TZ};var Qh;hZ(async(e,t)=>{Qh=Qh||T_(),tM(e),Qh[e.type]&&await Qh[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function mZ(e){return!EZ&&e.message&&(e.message.originator=fZ),pZ(e)}a(mZ,"sendItcEvent");function tM(e){if(typeof e!="object")return g_.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||YA.isEmpty(e.type))return g_.MISSING_TYPE;if(!e.hasOwnProperty("message")||YA.isEmpty(e.message))return g_.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||YA.isEmpty(e.message.originator))return g_.MISSING_ORIGIN;if(_Z.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return g_.INVALID_EVENT(e.type)}a(tM,"validateEvent");function SZ(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(SZ,"SchemaEventMsg");function TZ(e){this.originator=e}a(TZ,"UserEventMsg")});var no=N((zRe,oM)=>{"use strict";var nM=M(),jRe=te(),Jh=W(),sM=GP(),ql,{sendItcEvent:iM}=qs();function gZ(e){try{Jh.info("signalSchemaChange called with message:",e),ql=ql||T_();let t=new sM(nM.ITC_EVENT_TYPES.SCHEMA,e);return ql.schema(t),iM(t)}catch(t){Jh.error(t)}}a(gZ,"signalSchemaChange");function AZ(e){try{Jh.trace("signalUserChange called with message:",e),ql=ql||T_();let t=new sM(nM.ITC_EVENT_TYPES.USER,e);return ql.user(t),iM(t)}catch(t){Jh.error(t)}}a(AZ,"signalUserChange");oM.exports={signalSchemaChange:gZ,signalUserChange:AZ}});var Xh=N((JRe,cM)=>{"use strict";var aM=te(),RZ=M(),yZ=W(),bZ=Bh(),OZ=vh(),NZ=no(),{SchemaEventMsg:IZ}=qs(),wZ="already exists in";cM.exports=CZ;async function CZ(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 DZ(e,t.schema,t.name,i)})),s}a(CZ,"lmdbCheckForNewAttributes");async function DZ(e,t,r,n){let s=new OZ(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await PZ(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(wZ))yZ.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(DZ,"createNewAttribute");async function PZ(e){let t;return t=await bZ(e),NZ.signalSchemaChange(new IZ(process.pid,RZ.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(PZ,"createAttribute")});var $l=N((ZRe,lM)=>{"use strict";var WA=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=WA});var dM=N((tye,uM)=>{"use strict";var LZ=$l(),MZ=M().OPERATIONS_ENUM,jA=class extends LZ{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(MZ.INSERT,r,n,s,i),this.records=t}};uM.exports=jA});var fM=N((nye,_M)=>{"use strict";var UZ=$l(),vZ=M().OPERATIONS_ENUM,zA=class extends UZ{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(vZ.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};_M.exports=zA});var hM=N((iye,EM)=>{"use strict";var BZ=$l(),HZ=M().OPERATIONS_ENUM,QA=class extends BZ{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(HZ.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};EM.exports=QA});var mM=N((aye,pM)=>{"use strict";var xZ=$l(),kZ=M().OPERATIONS_ENUM,JA=class extends xZ{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(kZ.DELETE,n,s,t,i),this.original_records=r}};pM.exports=JA});var A_=N((uye,AM)=>{"use strict";var lye=require("path"),SM=ht(),FZ=dM(),GZ=fM(),qZ=hM(),$Z=mM(),Vl=Ht(),TM=te(),{CONFIG_PARAMS:VZ}=M(),gM=se();gM.initSync();var Zh=M().OPERATIONS_ENUM,{getTransactionAuditStorePath:KZ}=gt();AM.exports=YZ;async function YZ(e,t){if(gM.get(VZ.LOGGING_AUDITLOG)===!1)return;let r=KZ(e.schema,e.table),n=await SM.openEnvironment(r,e.table,!0),s=WZ(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){SM.initializeDBIs(n,Vl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,Vl.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[Vl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[Vl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),TM.isEmpty(s.user_name)||n.dbis[Vl.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[Vl.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(YZ,"writeTransaction");function WZ(e,t){let r=TM.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===Zh.INSERT)return new FZ(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Zh.UPDATE)return new GZ(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Zh.UPSERT)return new qZ(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===Zh.DELETE)return new $Z(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(WZ,"createTransactionObject")});var XA=N((fye,RM)=>{"use strict";var jZ=h_(),_ye=Xd(),R_=M(),zZ=Zd(),QZ=ic().insertRecords,JZ=ht(),XZ=W(),ZZ=Xh(),{getSchemaPath:e5}=gt(),t5=A_();RM.exports=r5;async function r5(e){try{let{schema_table:t,attributes:r}=jZ(e);zZ(e,r,t.hash_attribute),e.schema!==R_.SYSTEM_SCHEMA_NAME&&(r.includes(R_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(R_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(R_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(R_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await ZZ(e.hdb_auth_header,t,r),s=e5(e.schema,e.table),i=await JZ.openEnvironment(s,e.table),o=await QZ(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await t5(e,o)}catch(c){XZ.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(r5,"lmdbCreateRecords")});var OM=N((hye,bM)=>{"use strict";var yM=M(),n5=XA(),s5=Xd(),i5=require("fs-extra"),{getSchemaPath:o5}=gt();bM.exports=a5;async function a5(e){let t=[{name:e.schema,createddate:Date.now()}],r=new s5(yM.SYSTEM_SCHEMA_NAME,yM.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await n5(r),await i5.mkdirp(o5(e.schema))}a(a5,"lmdbCreateSchema")});var IM=N((mye,NM)=>{"use strict";var ZA=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=ZA});var PM=N((Rye,DM)=>{"use strict";var wM=ht(),eR=cn(),tR=Dn().LMDB_ERRORS_ENUM,c5=Ht(),CM=W(),Tye=te(),l5=require("lmdb"),u5=IM(),d5=M(),{OVERFLOW_MARKER:gye,MAX_SEARCH_KEY_LENGTH:Aye}=c5,_5=d5.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function f5(e,t,r,n){if(eR.validateEnv(e),t===void 0)throw new Error(tR.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(tR.IDS_REQUIRED):new Error(tR.IDS_MUST_BE_ITERABLE);try{let s=wM.listDBIs(e);wM.initializeDBIs(e,t,s);let i=new u5,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[_5]>n){i.skipped.push(o);continue}let T=e.dbis[t].ifVersion(o,l5.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=eR.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=eR.getNextMonotonicTime(),i}catch(s){throw s}}a(f5,"deleteRecords");DM.exports={deleteRecords:f5}});var y_=N((bye,MM)=>{"use strict";var Kl=te(),E5=PM(),h5=ht(),{getSchemaPath:p5}=gt(),m5=A_(),S5=W();MM.exports=T5;async function T5(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(Kl.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(Kl.isEmptyOrZeroLength(e.hash_values)&&!Kl.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];Kl.isEmpty(l)||e.hash_values.push(l)}}if(Kl.isEmptyOrZeroLength(e.hash_values))return LM([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(Kl.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=p5(e.schema,e.table),i=await h5.openEnvironment(s,e.table),o=await E5.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await m5(e,o)}catch(c){S5.error(`unable to write transaction due to ${c.message}`)}return LM(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(T5,"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 nR=N((Iye,UM)=>{"use strict";var g5=M(),Nye=cn();function rR(e,t){let r=Object.create(null);if(t.length===1&&g5.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(rR,"parseRow");function A5(e,t,r,n){let s=rR(r,e);n.push(s)}a(A5,"searchAll");function R5(e,t,r,n){let s=rR(r,e);n[t]=s}a(R5,"searchAllToMap");function y5(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(y5,"iterateDBI");function Ec(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(Ec,"pushResults");function b5(e,t,r,n,s,i){t.toString().endsWith(e)&&Ec(t,r,n,s,i)}a(b5,"endsWith");function O5(e,t,r,n,s,i){t.toString().includes(e)&&Ec(t,r,n,s,i)}a(O5,"contains");function N5(e,t,r,n,s,i){t>e&&Ec(t,r,n,s,i)}a(N5,"greaterThanCompare");function I5(e,t,r,n,s,i){t>=e&&Ec(t,r,n,s,i)}a(I5,"greaterThanEqualCompare");function w5(e,t,r,n,s,i){t<e&&Ec(t,r,n,s,i)}a(w5,"lessThanCompare");function C5(e,t,r,n,s,i){t<=e&&Ec(t,r,n,s,i)}a(C5,"lessThanEqualCompare");UM.exports={parseRow:rR,searchAll:A5,searchAllToMap:R5,iterateDBI:y5,endsWith:b5,contains:O5,greaterThanCompare:N5,greaterThanEqualCompare:I5,lessThanCompare:w5,lessThanEqualCompare:C5,pushResults:Ec}});var Yl=N((Lye,GM)=>{"use strict";var Jo=ht(),Cye=W(),Fn=cn(),ep=Ht(),zt=Dn().LMDB_ERRORS_ENUM,Dye=te(),D5=M(),tp=nR(),{parseRow:P5}=tp,Pye=require("lmdb"),{OVERFLOW_MARKER:vM,MAX_SEARCH_KEY_LENGTH:L5}=ep;function BM(e,t,r,n=!1,s=void 0,i=void 0){return hc(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 b_(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,u=!1){return hc(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(b_,"iterateRangeBetween");function hc(e,t,r,n){let s=e.database||e,i=Jo.openDBI(s,r);i[ep.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&Jo.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(hc,"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=Jo.openDBI(e,r);else{let l=Jo.listDBIs(e);for(let u=0,d=l.length;u<d&&(s=Jo.openDBI(e,l[u]),!s[ep.DBI_DEFINITION_NAME].is_hash_attribute);u++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(HM,"getOverflowCheck");function M5(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 hc(e,t,t,(o,c,l)=>(rp(r),r=O_(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(u=>P5(u.value,r))))}a(M5,"searchAll");function U5(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);rp(r),r=O_(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,tp.parseRow(l,r));return o}a(U5,"searchAllToMap");function v5(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(v5,"iterateDBI");function B5(e,t){if(Fn.validateEnv(e),t===void 0)throw new Error(zt.HASH_ATTRIBUTE_REQUIRED);return Jo.statDBI(e,t).entryCount}a(B5,"countAll");function H5(e,t,r,n,s=!1,i=void 0,o=void 0){return Xo(e,r,n),hc(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(H5,"equals");function x5(e,t,r){return Xo(e,t,r),Jo.openDBI(e,t).getValuesCount(r)}a(x5,"count");function k5(e,t,r,n,s=!1,i=void 0,o=void 0){return Xo(e,r,n),hc(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(k5,"startsWith");function F5(e,t,r,n,s=!1,i=void 0,o=void 0){return xM(e,t,r,n,s,i,o,!0)}a(F5,"endsWith");function xM(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return Xo(e,r,n),hc(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[ep.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 G5(e,t,r,n,s=!1,i=void 0,o=void 0){Xo(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),b_(e,t,r,n,l,s,i,o,!0,!1)}a(G5,"greaterThan");function q5(e,t,r,n,s=!1,i=void 0,o=void 0){Xo(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),b_(e,t,r,n,l,s,i,o,!1,!1)}a(q5,"greaterThanEqual");function $5(e,t,r,n,s=!1,i=void 0,o=void 0){Xo(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),b_(e,t,r,l,n,s,i,o,!1,!0)}a($5,"lessThan");function V5(e,t,r,n,s=!1,i=void 0,o=void 0){Xo(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),b_(e,t,r,l,n,s,i,o,!1,!1)}a(V5,"lessThanEqual");function K5(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 b_(e,t,r,n,s,i,o,c)}a(K5,"between");function Y5(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(rp(r),r=O_(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=tp.parseRow(c,r)),o}a(Y5,"searchByHash");function W5(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(W5,"checkHashExists");function j5(e,t,r,n,s=[]){return FM(e,t,r,n,s),kM(e,t,r,n,s).map(i=>i[1])}a(j5,"batchSearchByHash");function z5(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(z5,"batchSearchByHashToMap");function kM(e,t,r,n,s=[]){return hc(e,t,t,(i,o,c)=>{r=O_(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,tp.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(rp(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 rp(e){if(!Array.isArray(e))throw e===void 0?new Error(zt.FETCH_ATTRIBUTES_REQUIRED):new Error(zt.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(rp,"validateFetchAttributes");function Xo(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>L5)throw new Error(zt.SEARCH_VALUE_TOO_LARGE)}a(Xo,"validateComparisonFunctions");function O_(e,t){return t.length===1&&D5.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=Jo.listDBIs(e)),t}a(O_,"setGetWholeRowAttributes");GM.exports={searchAll:M5,searchAllToMap:U5,count:x5,countAll:B5,equals:H5,startsWith:k5,endsWith:F5,contains:xM,searchByHash:Y5,setGetWholeRowAttributes:O_,batchSearchByHash:j5,batchSearchByHashToMap:z5,checkHashExists:W5,iterateDBI:v5,greaterThan:G5,greaterThanEqual:q5,lessThan:$5,lessThanEqual:V5,between:K5}});var Wl=N((Uye,YM)=>{var qM=require("lodash"),$M=Tt(),xe=require("joi"),Q5=te(),{hdb_schema_table:N_,checkValidTable:VM,hdb_table:KM,hdb_database:np}=Ti(),{handleHDBError:J5,hdb_errors:X5}=_e(),{getDatabases:Z5}=(Pe(),oe(lt)),{HTTP_STATUS_CODES:e6}=X5,t6=xe.object({database:np,schema:np,table:KM,search_attribute:N_,search_value:xe.any().required(),get_attributes:xe.array().min(1).items(xe.alternatives(N_,xe.object())).optional(),desc:xe.bool(),limit:xe.number().integer().min(1),offset:xe.number().integer().min(0)}),r6=xe.object({database:np,schema:np,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(N_,xe.object())).optional(),sort:xe.object({attribute:xe.alternatives(N_,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(N_,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,t6);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,r6);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=Q5.checkGlobalSchemaTable(e.schema,e.table);if(s)return J5(new Error,s,e6.NOT_FOUND);let o=Z5()[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 sR=N((Bye,WM)=>{"use strict";var n6=ht(),s6=Wl(),{getSchemaPath:i6}=gt();WM.exports=o6;function o6(e){let t=s6(e,"hashes");if(t)throw t;let r=i6(e.schema,e.table);return n6.openEnvironment(r,e.table)}a(o6,"initialize")});var iR=N((xye,jM)=>{"use strict";var a6=Yl(),c6=sR();jM.exports=l6;async function l6(e){let t=await c6(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return a6.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(l6,"lmdbGetDataByHash")});var jl=N((Fye,zM)=>{"use strict";var oR=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=oR});var JM=N(($ye,QM)=>{"use strict";var qye=jl(),u6=Yl(),d6=sR();QM.exports=_6;async function _6(e){let t=await d6(e),r=global.hdb_schema[e.schema][e.table];return u6.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(_6,"lmdbSearchByHash")});var $s=N((Kye,XM)=>{"use strict";var aR=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=aR});var sp=N((Wye,sU)=>{"use strict";var Wr=Yl(),f6=ht(),E6=te(),ke=Ht(),pc=M(),h6=Zi(),ZM=Dn().LMDB_ERRORS_ENUM,{getSchemaPath:p6}=gt(),so=pc.SEARCH_WILDCARDS;async function m6(e,t,r){let n;e.schema===pc.SYSTEM_SCHEMA_NAME?n=h6[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(m6,"prepSearch");async function tU(e,t,r,n){let s=p6(e.schema,e.table),i=await f6.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(S6(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 S6(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(S6,"checkToFetchMore");function nU(e,t,r,n){if(E6.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),so.indexOf(s)>-1)return r===!0?ke.SEARCH_TYPES.SEARCH_ALL_TO_MAP:ke.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(so[0])<0&&s.indexOf(so[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(so.indexOf(i)>=0&&so.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),ke.SEARCH_TYPES.CONTAINS;if(so.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),ke.SEARCH_TYPES.ENDS_WITH;if(so.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),ke.SEARCH_TYPES.STARTS_WITH;if(s.includes(so[0])||s.includes(so[1]))return ke.SEARCH_TYPES.EQUALS;throw new Error(ZM.UNKNOWN_SEARCH_TYPE)}else switch(n){case pc.VALUE_SEARCH_COMPARATORS.BETWEEN:return ke.SEARCH_TYPES.BETWEEN;case pc.VALUE_SEARCH_COMPARATORS.GREATER:return ke.SEARCH_TYPES.GREATER_THAN;case pc.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return ke.SEARCH_TYPES.GREATER_THAN_EQUAL;case pc.VALUE_SEARCH_COMPARATORS.LESS:return ke.SEARCH_TYPES.LESS_THAN;case pc.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:m6,searchByType:rU}});var oU=N((Qye,iU)=>{"use strict";var zye=$s(),T6=Wl(),g6=te(),A6=M(),R6=sp();iU.exports=y6;function y6(e,t){if(!g6.isEmpty(t)&&A6.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=T6(e,"value");if(n)throw n;return R6.prepSearch(e,t,!0)}a(y6,"lmdbGetDataByValue")});var I_=N((Zye,aU)=>{"use strict";var Xye=$s(),b6=Wl(),O6=te(),N6=M(),I6=sp();aU.exports=w6;async function w6(e,t){if(!O6.isEmpty(t)&&N6.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=b6(e,"value");if(n)throw n;return I6.prepSearch(e,t,!1)}a(w6,"lmdbSearchByValue")});var lU=N((rbe,cU)=>{"use strict";var tbe=Ht(),cR=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}},lR=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},uR=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};cU.exports={SearchByConditionsObject:cR,SearchCondition:lR,SortAttribute:uR}});var EU=N((obe,fU)=>{"use strict";var sbe=lU().SearchByConditionsObject,C6=$s(),D6=Wl(),dR=Yl(),ip=Ht(),{Resource:ibe}=(Vs(),oe(_R)),_U=sp(),P6=nR(),L6=require("lodash"),{getSchemaPath:M6}=gt(),uU=ht(),{handleHDBError:U6,hdb_errors:v6}=_e(),{HTTP_STATUS_CODES:B6}=v6,H6=1e8;fU.exports=x6;async function x6(e){let t=D6(e,"conditions");if(t)throw U6(t,t.message,B6.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=M6(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=L6.sortBy(e.conditions,u=>{if(u.estimated_count===void 0){let d=u.search_type;d===ip.SEARCH_TYPES.EQUALS?u.estimated_count=dR.count(n,u.search_attribute,u.search_value):d===ip.SEARCH_TYPES.CONTAINS||d===ip.SEARCH_TYPES.ENDS_WITH?u.estimated_count=1/0:u.estimated_count=H6}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=dR.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=>P6.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=dR.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(x6,"lmdbSearchByConditions");async function dU(e,t,r,n){let s=new C6(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===ip.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 w_=N((cbe,hU)=>{"use strict";var k6=M().OPERATIONS_ENUM,fR=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=k6.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};hU.exports=fR});var ER=N((ube,yU)=>{"use strict";var TU=$s(),gU=w_(),AU=I_(),RU=y_(),dn=M(),pU=te(),mU=ht(),{getTransactionAuditStorePath:F6,getSchemaPath:G6}=gt(),SU=W();yU.exports=q6;async function q6(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 $6(e),await V6(e);let t=G6(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=F6(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(q6,"lmdbDropTable");async function $6(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($6,"deleteAttributesFromSystem");async function V6(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(V6,"dropTableFromSystem")});var OU=N((_be,bU)=>{"use strict";var K6=require("fs-extra"),Y6=$s(),W6=jl(),j6=w_(),z6=ER(),Q6=y_(),J6=iR(),X6=I_(),io=M(),{getSchemaPath:Z6}=gt(),{handleHDBError:e8,hdb_errors:t8}=_e(),{HDB_ERROR_MSGS:r8,HTTP_STATUS_CODES:n8}=t8;bU.exports=s8;async function s8(e){let t;try{t=await i8(e.schema);let r=new Y6(io.SYSTEM_SCHEMA_NAME,io.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,io.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[io.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await X6(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await z6(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new j6(io.SYSTEM_SCHEMA_NAME,io.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await Q6(s);let i=Z6(t);await K6.remove(i)}catch(r){throw r}}a(s8,"lmdbDropSchema");async function i8(e){let t=new W6(io.SYSTEM_SCHEMA_NAME,io.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[io.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await J6(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw e8(new Error,r8.SCHEMA_NOT_FOUND(e),n8.NOT_FOUND,void 0,void 0,!0);return n}a(i8,"validateDropSchema")});var C_=N((Ebe,NU)=>{"use strict";var hR=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};NU.exports=hR});var mR=N((mbe,IU)=>{"use strict";var o8=require("fs-extra"),op=ht(),{getTransactionAuditStorePath:a8}=gt(),pR=Ht(),pbe=C_();IU.exports=c8;async function c8(e){let t;try{let r=a8(e.schema,e.table);await o8.mkdirp(r),t=await op.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{op.createDBI(t,pR.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),op.createDBI(t,pR.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),op.createDBI(t,pR.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(c8,"createTransactionsAuditEnvironment")});var DU=N((gbe,CU)=>{"use strict";var SR=M(),wU=ht(),l8=ic(),{getSystemSchemaPath:u8,getSchemaPath:d8}=gt(),Tbe=Zi(),_8=Bh(),TR=vh(),f8=W(),E8=mR();CU.exports=h8;async function h8(e,t){let r=d8(t.schema,t.table),n=new TR(t.schema,t.table,SR.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new TR(t.schema,t.table,SR.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new TR(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(u8(),SR.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await l8.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 gR(n),await gR(s),await gR(i)}await E8(t)}catch(o){throw o}}a(h8,"lmdbCreateTable");async function gR(e){try{await _8(e)}catch(t){f8.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a(gR,"createAttribute")});var LU=N((Rbe,PU)=>{"use strict";var p8=h_(),m8=Zd(),S8=Xh(),D_=M(),T8=ic().updateRecords,g8=ht(),{getSchemaPath:A8}=gt(),R8=A_(),y8=W();PU.exports=b8;async function b8(e){try{let{schema_table:t,attributes:r}=p8(e);m8(e,r,t.hash_attribute),e.schema!==D_.SYSTEM_SCHEMA_NAME&&(r.includes(D_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(D_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(D_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(D_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await S8(e.hdb_auth_header,t,r),s=A8(e.schema,e.table),i=await g8.openEnvironment(s,e.table),o=await T8(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await R8(e,o)}catch(c){y8.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(b8,"lmdbUpdateRecords")});var UU=N((bbe,MU)=>{"use strict";var O8=M().OPERATIONS_ENUM,AR=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=O8.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};MU.exports=AR});var BU=N((Ibe,vU)=>{"use strict";var Nbe=UU(),N8=h_(),I8=Zd(),w8=Xh(),P_=M(),C8=ic().upsertRecords,D8=ht(),{getSchemaPath:P8}=gt(),L8=A_(),M8=W(),{handleHDBError:U8,hdb_errors:v8}=_e();vU.exports=B8;async function B8(e){let t;try{t=N8(e)}catch(l){throw U8(l,l.message,v8.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;I8(e,n,r.hash_attribute),e.schema!==P_.SYSTEM_SCHEMA_NAME&&(n.includes(P_.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(P_.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(P_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(P_.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await w8(e.hdb_auth_header,r,n),i=P8(e.schema,e.table),o=await D8.openEnvironment(i,e.table),c=await C8(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await L8(e,c)}catch(l){M8.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(B8,"lmdbUpsertRecords")});var xU=N((Cbe,HU)=>{"use strict";var RR=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};HU.exports=RR});var FU=N((Pbe,kU)=>{"use strict";var yR=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=yR});var $U=N((Ube,qU)=>{"use strict";var bR=ht(),{getTransactionAuditStorePath:H8}=gt(),Mbe=xU(),L_=Ht(),x8=te(),GU=FU(),k8=require("util").promisify,F8=k8(setTimeout),G8=1e4,q8=100;qU.exports=$8;async function $8(e){let t=H8(e.schema,e.table),r=await bR.openEnvironment(t,e.table,!0),n=bR.listDBIs(r);bR.initializeDBIs(r,L_.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new GU;do s=await V8(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 F8(q8);while(s.transactions_deleted>0);return i}a($8,"deleteAuditLogsBefore");async function V8(e,t){let r=new GU;try{let n=e.dbis[L_.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[L_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];x8.isEmpty(c)||(s=e.dbis[L_.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[L_.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>G8)break}return await s,r}catch(n){throw n}}a(V8,"deleteTransactions")});var KU=N((Bbe,VU)=>{"use strict";var OR=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};VU.exports=OR});var WU=N((kbe,YU)=>{"use strict";var K8=$s(),Y8=w_(),xbe=KU(),yi=M(),W8=te(),NR=ht(),j8=Zi(),z8=I_(),Q8=y_(),{getSchemaPath:J8}=gt();YU.exports=X8;async function X8(e,t=!0){let r;e.schema===yi.SYSTEM_SCHEMA_NAME?r=j8[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await e9(e),s=J8(e.schema,e.table),i=await NR.openEnvironment(s,e.table);return t===!0&&await Z8(e,i,r.hash_attribute),NR.dropDBI(i,e.attribute),n}a(X8,"lmdbDropAttribute");async function Z8(e,t,r){let n=NR.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(Z8,"removeAttributeFromAllObjects");async function e9(e){let t=new K8(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 z8(t)).filter(o=>o[yi.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(W8.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 Y8(yi.SYSTEM_SCHEMA_NAME,yi.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return Q8(i)}a(e9,"dropAttributeFromSystem")});var ZU=N((qbe,XU)=>{"use strict";var IR=ht(),zl=Ht(),Gbe=cn(),wR=M(),jU=te(),{getTransactionAuditStorePath:t9}=gt(),r9=Yl(),ap=$l(),n9=W();XU.exports=s9;async function s9(e){let t=t9(e.schema,e.table),r=await IR.openEnvironment(t,e.table,!0),n=IR.listDBIs(r);IR.initializeDBIs(r,zl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case wR.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return zU(r,e.search_values);case wR.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,o9(r,e.search_values,s);case wR.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return i9(r,e.search_values);default:return zU(r)}}a(s9,"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[zl.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 ap,s))}a(zU,"searchTransactionsByTimestamp");function i9(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[zl.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,JU(e,i))}return Object.fromEntries(r)}a(i9,"searchTransactionsByUsername");function o9(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let u=t[c],d=r9.equals(e,zl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,zl.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(o9,"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 ap(e.operation,e.user_name,i,void 0);_[t]=[c],u.push(_)}}else{let u=new ap(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[zl.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 ap,i);r.push(o)}}catch(i){n9.warn(i)}return r}catch(n){throw n}}a(JU,"batchSearchTransactions")});var tv=N((Ybe,ev)=>{"use strict";var{getSchemaPath:Vbe}=gt(),Kbe=ht(),{database:a9}=(Pe(),oe(lt));ev.exports={writeTransaction:c9};async function c9(e,t,r){return a9({database:e,table:t}).transaction(r)}a(c9,"writeTransaction")});var iv=N((jbe,sv)=>{"use strict";var{getSchemaPath:rv}=gt(),nv=ht();sv.exports={flush:l9,resetReadTxn:u9};async function l9(e,t){return(await nv.openEnvironment(rv(e,t),t.toString())).flushed}a(l9,"flush");async function u9(e,t){try{(await nv.openEnvironment(rv(e,t),t.toString())).resetReadTxn()}catch{}}a(u9,"resetReadTxn")});var lv=N((Qbe,cv)=>{"use strict";var{Readable:d9}=require("stream"),{getDatabases:_9}=(Pe(),oe(lt)),{readSync:f9,openSync:E9,createReadStream:ov}=require("fs"),{open:h9}=require("lmdb"),av=c_(),p9=l_(),{AUDIT_STORE_OPTIONS:m9}=(Ji(),oe(uv)),{INTERNAL_DBIS_NAME:S9,AUDIT_STORE_NAME:T9}=Ht();cv.exports=A9;var CR=32768,g9=100;async function A9(e){let t=e.database||e.schema||"data",r=_9()[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,_=h9({noSync:!0,maxDbs:p9.MAX_DBS}),E,f=_.openDB(S9,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++%g9===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(T9,{...m9}),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=E9(o.path);return o.transaction(()=>{let u=Buffer.alloc(CR);f9(c,u,0,CR),o.resetReadTxn();let d=o.useReadTransaction();d.renew();let _=ov(null,{fd:c,start:CR}),E=new d9.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(A9,"getBackup")});var fv=N((Xbe,_v)=>{"use strict";var R9=W(),{handleHDBError:y9}=_e(),b9=jD(),O9=Bh(),N9=XA(),I9=OM(),w9=y_(),C9=iR(),D9=JM(),P9=oU(),L9=I_(),M9=EU(),U9=OU(),v9=DU(),B9=LU(),H9=BU(),x9=$U(),k9=ER(),F9=WU(),G9=ZU(),q9=tv(),dv=iv(),$9=lv(),DR=class extends b9{static{a(this,"LMDBBridge")}async searchByConditions(t){return M9(t)}async getDataByHash(t){return await C9(t)}async searchByHash(t){return await D9(t)}async getDataByValue(t,r){return await P9(t,r)}async searchByValue(t){return await L9(t)}async createSchema(t){return await I9(t)}async dropSchema(t){return await U9(t)}async createTable(t,r){return await v9(t,r)}async dropTable(t){return await k9(t)}async createAttribute(t){return await O9(t)}async createRecords(t){return await N9(t)}async updateRecords(t){return await B9(t)}async upsertRecords(t){try{return await H9(t)}catch(r){throw y9(r,null,null,R9.ERR,r)}}async deleteRecords(t){return await w9(t)}async dropAttribute(t){return await F9(t)}async deleteAuditLogsBefore(t){return await x9(t)}async readAuditLog(t){return await G9(t)}writeTransaction(t,r,n){return q9.writeTransaction(t,r,n)}flush(t,r){return dv.flush(t,r)}resetReadTxn(t,r){return dv.resetReadTxn(t,r)}getBackup(t){return $9(t)}};_v.exports=DR});function Av(e){LR=e}function W9(){Y9=setInterval(function(){for(let e of PR)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},K9).unref()}var MR,pv,mv,Sv,Tv,gv,Ev,PR,V9,M_,hv,LR,mc,cp,K9,Y9,lp=Ie(()=>{MR=L(cn()),pv=L(_e()),mv=L(W());Vs();Sv=L(se()),Tv=L(M()),gv=L(te()),Ev=100,PR=new Set,V9=(0,gv.convertToMS)(Sv.get(Tv.CONFIG_PARAMS.STORAGE_MAXTRANSACTIONQUEUETIME))||45e3;a(Av,"replicationConfirmation");mc=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),PR.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(PR.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(M_&&!this.overloadChecked&&performance.now()-hv>V9)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,MR.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 M_||(M_=s,hv=performance.now(),M_.then(()=>{M_=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];LR&&f&&i.push(LR(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=[]}},cp=class extends mc{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,MR.getNextMonotonicTime)())}getReadTxn(){}},K9=3e4;a(W9,"startMonitoringTxns");W9()});function Dt(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 mc;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,Sc=Ie(()=>{Rv=L(fi());Vs();lp();a(Dt,"transaction");(0,Rv._assignPackageExport)("transaction",Dt);Dt.commit=function(e){let t=(e[Fe]||e)?.transaction;if(!t)throw new Error("No active transaction is available to commit");return t.commit()};Dt.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 Dv={};je(Dv,{ResourceBridge:()=>BR});function HR({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=HR(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;Dt(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&&dp(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||z9,r=ut()[t];if(!r)throw(0,Ks.handleHDBError)(new Error,j9.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,up,Ks,wv,Ys,UR,vR,Cv,j9,z9,Q9,J9,yv,BR,Pv=Ie(()=>{"use strict";Iv=L(fv()),up=L(Wl()),Ks=L(_e());Pe();wv=L(h_()),Ys=L(M()),UR=L(no()),vR=L(qs()),Cv=L(te());Sc();_p();({HDB_ERROR_MSGS:j9}=Ks.hdb_errors),z9="data",Q9=1e4,J9=10,BR=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,up.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:HR(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 Ql({database:t.schema,table:null}),UR.signalSchemaChange(new vR.SchemaEventMsg(process.pid,Ys.OPERATIONS_ENUM.CREATE_SCHEMA,t.schema))}async dropSchema(t){await xR(t.schema),UR.signalSchemaChange(new vR.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),Dt(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=dp(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),Dt(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)(J9),l=[],s=!0},"chunkDelete");for await(let d of n)l.push(d[r.primaryKey]),c++,c%Q9===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,up.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,up.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:HR(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(HR,"getSelect");a(bv,"getRecords");a(bi,"getTable");a(Ov,"createDeleteResponse");a(Nv,"groupRecordsInHistory")});var Bn=N((fOe,Lv)=>{"use strict";var{ResourceBridge:X9}=(Pv(),oe(Dv)),Z9=se();Z9.initSync();var fp;function e7(){return fp||(fp=new X9,fp)}a(e7,"getBridge");Lv.exports=e7()});var Bv=N((hOe,vv)=>{"use strict";var Mv=require("lodash"),U_=require("mathjs"),t7=require("jsonata"),Uv=te();vv.exports={distinct_array:a(e=>Array.isArray(e)&&e.length>1?Mv.uniqWith(e,Mv.isEqual):e,"distinct_array"),searchJSON:r7,mad:v_.bind(null,U_.mad),mean:v_.bind(null,U_.mean),mode:v_.bind(null,U_.mode),prod:v_.bind(null,U_.prod),median:v_.bind(null,U_.median)};function v_(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(v_,"aggregateFunction");function r7(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=t7(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(r7,"searchJSON")});var xv=N((mOe,Hv)=>{"use strict";var nr=require("moment"),kR="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(kR),"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(kR),"get_server_time"),offset_utc:a((e,t)=>nr(e).utc().utcOffset(t).format(kR),"offset_utc")}});var qv=N((TOe,Gv)=>{"use strict";var n7=require("@turf/area"),s7=require("@turf/length"),i7=require("@turf/circle"),o7=require("@turf/difference"),a7=require("@turf/distance"),c7=require("@turf/boolean-contains"),l7=require("@turf/boolean-equal"),u7=require("@turf/boolean-disjoint"),d7=require("@turf/helpers"),kv=M(),$e=te(),oo=W();Gv.exports={geoArea:_7,geoLength:f7,geoCircle:E7,geoDifference:h7,geoDistance:Fv,geoNear:p7,geoContains:m7,geoEqual:S7,geoCrosses:T7,geoConvert:g7};function _7(e){if($e.isEmpty(e))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e));try{return n7.default(e)}catch(t){return oo.trace(t,e),NaN}}a(_7,"geoArea");function f7(e,t){if($e.isEmpty(e))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e));try{return s7.default(e,{units:t||"kilometers"})}catch(r){return oo.trace(r,e),NaN}}a(f7,"geoLength");function E7(e,t,r){if($e.isEmpty(e))return NaN;if($e.isEmpty(t))return NaN;typeof e=="string"&&(e=$e.autoCastJSON(e));try{return i7.default(e,t,{units:r||"kilometers"})}catch(n){return oo.trace(n,e,t),NaN}}a(E7,"geoCircle");function h7(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 o7(e,t)}catch(r){return oo.trace(r,e,t),NaN}}a(h7,"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 a7.default(e,t,{units:r||"kilometers"})}catch(n){return oo.trace(n,e,t),NaN}}a(Fv,"geoDistance");function p7(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 oo.trace(s,e,t),!1}}a(p7,"geoNear");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 oo.trace(r,e,t),!1}}a(m7,"geoContains");function S7(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 l7.default(e,t)}catch(r){return oo.trace(r,e,t),!1}}a(S7,"geoEqual");function T7(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!u7.default(e,t)}catch(r){return oo.trace(r,e,t),!1}}a(T7,"geoCrosses");function g7(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)),d7[t](e,r)}a(g7,"geoConvert")});var Ep=N((AOe,$v)=>{var Tc=Bv(),Gn=xv(),Oi=qv();$v.exports=e=>{e.aggr.mad=e.aggr.MAD=Tc.mad,e.aggr.mean=e.aggr.MEAN=Tc.mean,e.aggr.mode=e.aggr.MODE=Tc.mode,e.aggr.prod=e.aggr.PROD=Tc.prod,e.aggr.median=e.aggr.MEDIAN=Tc.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=Tc.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=Tc.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((ROe,Yv)=>{"use strict";var B_=require("lodash"),_n=require("alasql");_n.options.cache=!1;var A7=Ep(),Vv=require("clone"),hp=require("recursive-iterator"),Ue=W(),et=te(),Jl=Bn(),R7=M(),{hdb_errors:y7}=_e(),{getDatabases:Kv}=(Pe(),oe(lt)),b7="IS NULL",Ws="There was a problem performing this search. Please check the logs and try again.";A7(_n);var FR=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 hp(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=B_.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 hp(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 hp(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(R7.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&&B_.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(b7)>-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=B_.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 Jl.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 Jl.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 Jl.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 Jl.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=B_.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 hp(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=B_.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 Jl.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(y7.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 Jl.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=FR});var Vr=N((bOe,jv)=>{"use strict";var O7=YD();jv.exports={searchByConditions:I7,searchByHash:w7,searchByValue:C7,search:D7};var GR=Bn(),{transformReq:qR}=te(),N7=Wv();async function I7(e){return qR(e),GR.searchByConditions(e)}a(I7,"searchByConditions");async function w7(e){qR(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of GR.searchByHash(e))r&&t.push(r);return t}a(w7,"searchByHash");async function C7(e){qR(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of GR.searchByValue(e))t.push(r);return t}a(C7,"searchByValue");function D7(e,t){try{let r=new O7(e);r.validate(),new N7(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(D7,"search")});var pp=N((NOe,zv)=>{"use strict";var P7=Bn();zv.exports={writeTransaction:L7};function L7(e,t,r){return P7.writeTransaction(e,t,r)}a(L7,"writeTransaction")});var Zv=N((COe,Xv)=>{"use strict";var M7=Vr(),U7=ls(),Qv=W(),v7=un(),wOe=pp(),B7=require("clone"),VR=require("alasql"),H7=Ep(),Jv=require("util"),x7=Jv.promisify(U7.getTableSchema),k7=Jv.promisify(M7.search),F7=M(),$R=te();H7(VR);Xv.exports={update:q7};var G7="There was a problem performing this update. Please check the logs and try again.";async function q7({statement:e,hdb_user:t}){let r=await x7(e.table.databaseid,e.table.tableid),n=$7(e.columns);$R.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=B7(s),c=$R.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,u=VR.parse(l).statements[0],d=await k7(u),_=V7(n,d);return K7(o,_,t)}a(q7,"update");function $7(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=VR.compile(`SELECT ${r.expression.toString()} AS [${F7.FUNC_VAL}] FROM ?`)}),t}catch(t){throw Qv.error(t),new Error(G7)}}a($7,"createUpdateRecord");function V7(e,t){return $R.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(V7,"buildUpdateRecords");async function K7(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await v7.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(K7,"updateRecords")});var t0=N((MOe,e0)=>{var Y7=require("alasql"),W7=Vr(),j7=W(),z7=Bn(),YR=require("util"),KR=te(),Q7=M(),J7=ls(),POe=pp(),LOe=un(),X7="record",Z7="successfully deleted",eee=YR.callbackify(see),tee=YR.promisify(W7.search),ree=YR.promisify(J7.getTableSchema);e0.exports={convertDelete:eee};function nee(e){return`${e.deleted_hashes.length} ${X7}${e.deleted_hashes.length===1?"":"s"} ${Z7}`}a(nee,"generateReturnMessage");async function see({statement:e,hdb_user:t}){let r=await ree(e.table.databaseid,e.table.tableid);KR.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=KR.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=Y7.parse(o).statements[0],l={operation:Q7.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await tee(c);let u=await z7.deleteRecords(l);return KR.isEmptyOrZeroLength(u.message)&&(u.message=nee(u)),delete u.txn_time,u}catch(u){throw j7.error(u),u.hdb_code?u.message:u}}a(see,"convertDelete")});var o0=N((vOe,i0)=>{"use strict";var iee=ro(),{hdb_errors:r0}=_e(),{getDatabases:n0}=(Pe(),oe(lt));i0.exports={checkSchemaExists:s0,checkSchemaTableExists:oee,schema_describe:iee};async function s0(e){if(!n0()[e])return r0.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(s0,"checkSchemaExists");async function oee(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(oee,"checkSchemaTableExists")});var Xl=N((HOe,aee)=>{aee.exports={name:"harperdb",version:"4.4.21",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","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 G_={};je(G_,{addAnalyticsListener:()=>F_,recordAction:()=>pr,recordActionBinary:()=>qn,setAnalyticsEnabled:()=>cee});function cee(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=Tp.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},Tp.set(i,o)}mp||lee()}function qn(e,t,r,n,s){pr(!!e,t,r,n,s)}function F_(e){S0.push(e)}function lee(){mp=performance.now(),setTimeout(async()=>{let e=performance.now()-mp;mp=0;let t=[],r={time:Date.now(),period:e,threadId:gc.threadId,metrics:t};for(let[s,i]of Tp){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:gc.threadId,byThread:!0,...n});for(let s of S0)s(t);Tp=new Map,gc.parentPort?gc.parentPort.postMessage({type:m0,report:r}):y0({report:r})},p0).unref()}async function uee(e,t=6e4){let r=zR(),n=A0(),s=new Promise(T=>{let m=performance.now();setImmediate(()=>{let g=performance.now();g-m>5e3&&(0,H_.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,H_.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 j=X+(I?"-"+I:"");U!==void 0&&(j+="-"+U),H!==void 0&&(j+="-"+H);let ae=c.get(j);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(j,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(j);Oe?Oe.push(...ne):l.set(j,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,j,ae,Oe]=y;Object.assign(g,{p1:X,p10:Y,p25:V,median:ne,p75:Q,p90:de,p95:j,p99:ae,p999:Oe})}let _;for(let[T,m]of c)m.id=(0,Sp.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,Sp.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 zR(){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 fee(){R0=!0;let e=(0,k_.get)(jR.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await uee(p0,e),await l0(zR(),dee),await l0(A0(),_ee)},Math.min(e/2,2147483647)).unref()}function y0(e,t){let r=e.report;r.threadId=t?.threadId||gc.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,Sp.getNextMonotonicTime)(),zR().primaryStore.put(r.id,r),R0||fee(),Eee&&(b0=pee(r))}async function pee(e){if(await b0,!Zo){let r=(0,x_.dirname)((0,H_.getLogFilePath)());try{Zo=await(0,WR.open)((0,x_.join)(r,"analytics.log"),"r+")}catch{Zo=await(0,WR.open)((0,x_.join)(r,"analytics.log"),"w+")}}let t=(await Zo.stat()).size;if(t>hee){let r=Buffer.alloc(t);await Zo.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await Zo.write(r,{position:0}),await Zo.truncate(r.length),t=r.length}await Zo.write(JSON.stringify(e)+`
|
|
12
12
|
`,t)}var gc,E0,H_,x_,WR,Sp,k_,jR,Tp,h0,mp,p0,m0,S0,T0,a0,c0,g0,dee,_ee,u0,d0,R0,_0,f0,Eee,b0,Zo,hee,Ni=Ie(()=>{gc=require("worker_threads"),E0=L(dt());Pe();H_=L(W()),x_=require("path"),WR=require("fs/promises"),Sp=L(cn()),k_=L(se()),jR=L(M());qr();(0,k_.initSync)();Tp=new Map,h0=(0,k_.get)(jR.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)>-1;a(cee,"setAnalyticsEnabled");a(pr,"recordAction");it.recordAnalytics=pr;a(qn,"recordActionBinary");mp=0,p0=1e3,m0="analytics-report",S0=[];a(F_,"addAnalyticsListener");T0=[.01,.1,.25,.5,.75,.9,.95,.99,.999,1];a(lee,"sendAnalytics");a(uee,"aggregation");a0=0,c0=0,g0=a(()=>new Promise(setImmediate),"rest");a(l0,"cleanup");dee=36e5,_ee=31536e6;a(zR,"getRawAnalyticsTable");a(A0,"getAnalyticsTable");(0,E0.setChildListenerByType)(m0,y0);a(fee,"startScheduledTasks");_0=0,f0=new Map,Eee=!1;a(y0,"recordAnalytics");hee=1e6;a(pee,"logAnalytics")});var ey=N((QOe,B0)=>{"use strict";var{decode:mee}=require("msgpackr"),{isMainThread:WOe,parentPort:jOe,threadId:zOe}=require("worker_threads"),Rp=mr(),Zl=Ct(),XR=M(),jr=W(),JR=se(),See=M(),{onMessageByType:Tee}=dt(),w0=to(),{recordAction:O0,recordActionBinary:gee}=(Ni(),oe(G_)),{publishToStream:Aee}=Rp,{ConsumerEvents:N0}=require("nats"),Ree=Vr(),{promisify:yee}=require("util"),C0=yee(setTimeout),yp=1e4,bp,Ap,bee,Oee,D0,q_=new Map,eu=new Map;B0.exports={initialize:P0,ingestConsumer:ZR,setSubscription:Nee,setIgnoreOrigin:Cee,getDatabaseSubscriptions:wee,updateConsumer:L0};async function P0(){Tee(XR.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,async n=>{await L0(n)}),D0=!0,jr.notify("Initializing clustering ingest service.");let{connection:e,jsm:t,js:r}=await Rp.getNATSReferences();bp=e,Ap=e.info.server_name,bee=t,Oee=r}a(P0,"initialize");async function L0(e){if(e.status==="start"){let{js:t,jsm:r}=await M0(e.node_domain_name);ZR(e.stream_name,t,r,e.node_domain_name)}else if(e.status==="stop"){let t=q_.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?.(),q_.set(e.stream_name+e.node_domain_name,"close")),eu.get(e.node_domain_name)==="failed"&&eu.set(e.node_domain_name,"close")}}a(L0,"updateConsumer");var Op=new Map;function Nee(e,t,r){let n=Op.get(e);n||Op.set(e,n=new Map),n.set(t,r),D0||P0().then(Iee)}a(Nee,"setSubscription");async function Iee(){let e=await Ree.searchByValue({database:"system",table:"hdb_nodes",search_attribute:"name",search_value:"*"});for await(let t of e){let r=t.name+Zl.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);ZR(l,n,s,r)}}}a(Iee,"accessConsumers");async function M0(e){let t,r,n=1;for(;!r;)try{t=await bp.jetstream({domain:e}),r=await bp.jetstreamManager({domain:e,checkAPI:!1})}catch(s){if(eu.get(e)==="close")break;eu.set(e,"failed"),n%10===1&&jr.warn("Nats ingest attempting to connect to:",e,"Nats error:",s.message);let i=n++*100<yp?n++*100:yp;await C0(i)}return{js:t,jsm:r}}a(M0,"connectToRemoteJS");function wee(){return Op}a(wee,"getDatabaseSubscriptions");var U0;function Cee(e){U0=e}a(Cee,"setIgnoreOrigin");var v0=100,I0=new Array(v0),gp=0;async function ZR(e,t,r,n){let{connection:s}=await Rp.getNATSReferences();bp=s,Ap=s.info.server_name;let i,o=1;for(;!i;)try{i=await t.consumers.get(e,Ap),jr.notify("Initializing ingest consumer for node:",n,"stream:",e)}catch(u){if(eu.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 Rp.createConsumer(r,e,Ap,new Date(Date.now()).toISOString()));let d=o++*100<yp?o++*100:yp;await C0(d)}let c=!1,l;for(;!c;){if(q_.get(e+n)==="close"||eu.get(n)==="close"){q_.delete(e+n),c=!0;continue}l=await i.consume({max_messages:JR.get(XR.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS)??100,bind:!0}),q_.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[gp],I0[gp]=Dee(d).catch(_=>{jr.error(_)}),++gp>=v0&&(gp=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(ZR,"ingestConsumer");async function Dee(e){let t=mee(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=JR.get(XR.CONFIG_PARAMS.CLUSTERING_NODENAME);r.has(Zl.MSG_HEADERS.TRANSACTED_NODES)&&r.values(Zl.MSG_HEADERS.TRANSACTED_NODES).indexOf(s)>-1&&(n=!0);let i=r.get(Zl.MSG_HEADERS.ORIGIN);if(n||(n=i===s&&!U0),gee(n,"echo",e.subject,t.operation,"ingest"),n){e.ack();return}r.append(Zl.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(Zl.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=Op.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:QR(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:QR(o),value:H,expiresAt:f,id:_?.[X],table:u}));for(;l;)U.push({type:QR(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})}JR.get(See.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&Aee(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(Dee,"messageProcessor");function QR(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}a(QR,"convertOperation")});var mr=N((nNe,Z0)=>{"use strict";var br=se();br.initSync();var Pee=require("fs-extra"),Lee=require("semver"),K_=require("path"),{monotonicFactory:Mee}=require("ulidx"),x0=Mee(),Uee=require("util"),k0=require("child_process"),vee=Uee.promisify(k0.exec),Bee=k0.spawn,Dr=Ct(),Je=M(),Np=te(),js=W(),Ip=to(),Hee=pp(),$_=wt(),{broadcast:xee,onMessageByType:kee,getWorkerIndex:Fee}=dt(),{isMainThread:F0}=require("worker_threads"),{Encoder:Gee,decode:sy}=require("msgpackr"),G0=new Gee,{isEmpty:bc}=Np,q0=xn(),XOe=48*36e11;F0&&kee(Je.ITC_EVENT_TYPES.RESTART,()=>{zr=void 0,yc=void 0});var{connect:qee,StorageType:$ee,RetentionPolicy:Vee,AckPolicy:iy,DeliverPolicy:oy,DiscardPolicy:Kee,NatsConnection:ZOe,JetStreamManager:eNe,JetStreamClient:tNe,StringCodec:rNe,JSONCodec:Yee,createInbox:ay,headers:Wee,ErrorCode:H0}=require("nats"),{PACKAGE_ROOT:jee}=M(),zee=Xl(),{recordAction:Qee}=(Ni(),oe(G_)),$0=Yee(),Jee="clustering",Xee=zee.engines[Dr.NATS_SERVER_NAME],Zee=K_.join(jee,"dependencies"),ny=K_.join(Zee,`${process.platform}-${process.arch}`,Dr.NATS_BINARY_NAME),ty,ry,V_,Ac,Rc;Z0.exports={runCommand:V0,checkNATSServerInstalled:ete,createConnection:cy,getConnection:Y_,getJetStreamManager:W_,getJetStream:Y0,getNATSReferences:Ii,getServerList:rte,createLocalStream:ly,listStreams:W0,deleteLocalStream:nte,getServerConfig:tu,listRemoteStreams:ste,viewStream:ite,viewStreamIterator:ote,publishToStream:ate,request:ute,reloadNATS:uy,reloadNATSHub:dte,reloadNATSLeaf:_te,extractServerName:lte,requestErrorHandler:fte,createLocalTableStream:J0,createTableStreams:pte,purgeTableStream:X0,purgeSchemaTableStreams:mte,getStreamInfo:Ste,updateLocalStreams:gte,closeConnection:tte,getJsmServerName:wp,addNatsMsgHeader:j0,clearClientCache:K0,updateRemoteConsumer:Ete,createConsumer:z0,updateConsumerIterator:hte};async function V0(e,t=void 0){let{stdout:r,stderr:n}=await vee(e,{cwd:t});if(n)throw new Error(n.replace(`
|
|
13
13
|
`,""));return r.replace(`
|
|
14
14
|
`,"")}a(V0,"runCommand");async function ete(){try{await Pee.access(ny)}catch{return!1}let e=await V0(`${ny} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return Lee.eq(t,Xee)}a(ete,"checkNATSServerInstalled");async function cy(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let o=await q0.getClusterUser();if(bc(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 qee({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:br.get(Je.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:br.get(Je.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:br.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(cy,"createConnection");function K0(){zr=void 0,Ac=void 0,Rc=void 0,yc=void 0}a(K0,"clearClientCache");async function tte(){zr&&(await zr.drain(),zr=void 0,Ac=void 0,Rc=void 0,yc=void 0)}a(tte,"closeConnection");var zr,yc;async function Y_(){return yc||(yc=cy(br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),zr=await yc),zr||yc}a(Y_,"getConnection");async function W_(){if(Ac)return Ac;bc(zr)&&await Y_();let{domain:e}=tu(Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(bc(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return Ac=await zr.jetstreamManager({domain:e,timeout:6e4}),Ac}a(W_,"getJetStreamManager");async function Y0(){if(Rc)return Rc;bc(zr)&&await Y_();let{domain:e}=tu(Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(bc(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return Rc=zr.jetstream({domain:e,timeout:6e4}),Rc}a(Y0,"getJetStream");async function Ii(){let e=zr||await Y_(),t=Ac||await W_(),r=Rc||await Y0();return{connection:e,jsm:t,js:r}}a(Ii,"getNATSReferences");async function rte(e){let t=br.get(Je.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await q0.getClusterUser(),s=await cy(t,r,n),i=ay(),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 Np.async_set_timeout(e),await o.drain(),await s.close(),await u,c}a(rte,"getServerList");async function ly(e,t){let{jsm:r}=await Ii(),n=br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:$ee.File,retention:Vee.Limits,subjects:t,discard:Kee.Old,max_msgs:s,max_bytes:i,max_age:n})}a(ly,"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 nte(e){let{jsm:t}=await Ii();await t.streams.delete(e)}a(nte,"deleteLocalStream");async function ste(e){let{connection:t}=await Ii(),r=[],n=ay(),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(ste,"listRemoteStreams");async function ite(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Ii(),i=x0(),o={durable_name:i,ack_policy:iy.Explicit};t&&(o.deliver_policy=oy.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 _=sy(d.data),E={nats_timestamp:d.info.timestampNanos,nats_sequence:d.info.streamSequence,entry:_};if(d.headers&&(E.origin=d.headers.get(Dr.MSG_HEADERS.ORIGIN)),u.push(E),d.ack(),d.info.pending===0)break}return await c.delete(),u}a(ite,"viewStream");async function*ote(e,t=void 0,r=void 0){let{jsm:n,js:s}=await Ii(),i=x0(),o={durable_name:i,ack_policy:iy.Explicit};t&&(o.deliver_policy=oy.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=sy(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(Dr.MSG_HEADERS.ORIGIN)),yield E}if(u.ack(),u.info.pending===0)break}await c.delete()}a(ote,"viewStreamIterator");async function ate(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 wp(),o=`${e}.${i}`,c=n instanceof Uint8Array?n:G0.encode(n);try{js.trace(`publishToStream publishing to subject: ${o}`),Qee(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 ly(t,[o]),await s.publish(o,c,{headers:r})}else throw l}});throw l}}a(ate,"publishToStream");function j0(e,t){t===void 0&&(t=Wee());let r=br.get(Je.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(Dr.MSG_HEADERS.ORIGIN)&&r&&t.append(Dr.MSG_HEADERS.ORIGIN,r),t}a(j0,"addNatsMsgHeader");function tu(e){e=e.toLowerCase();let t=K_.join(br.get(Je.CONFIG_PARAMS.ROOTPATH),Jee);if(e===Je.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return bc(ry)&&(ry={port:$_.getConfigFromFile(Je.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:$_.getConfigFromFile(Je.CONFIG_PARAMS.CLUSTERING_NODENAME)+Dr.SERVER_SUFFIX.HUB,config_file:Dr.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:K_.join(t,Dr.PID_FILES.HUB),hdb_nats_path:t}),ry;if(e===Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return bc(ty)&&(ty={port:$_.getConfigFromFile(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:$_.getConfigFromFile(Je.CONFIG_PARAMS.CLUSTERING_NODENAME)+Dr.SERVER_SUFFIX.LEAF,config_file:Dr.NATS_CONFIG_FILES.LEAF_SERVER,domain:$_.getConfigFromFile(Je.CONFIG_PARAMS.CLUSTERING_NODENAME)+Dr.SERVER_SUFFIX.LEAF,pid_file_path:K_.join(t,Dr.PID_FILES.LEAF),hdb_nats_path:t}),ty;js.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(tu,"getServerConfig");async function z0(e,t,r,n){try{await e.consumers.add(t,{ack_policy:iy.Explicit,durable_name:r,deliver_policy:oy.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}a(z0,"createConsumer");async function cte(e,t,r){await e.consumers.delete(t,r)}a(cte,"removeConsumer");function lte(e){return e.split(".")[1]}a(lte,"extractServerName");async function ute(e,t,r=6e4,n=ay()){if(!Np.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 sy(c.data)}a(ute,"request");function uy(e){return new Promise(async(t,r)=>{let n=Bee(ny,["--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(uy,"reloadNATS");async function dte(){let{pid_file_path:e}=tu(Je.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await uy(e)}a(dte,"reloadNATSHub");async function _te(){let{pid_file_path:e}=tu(Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await uy(e)}a(_te,"reloadNATSLeaf");function fte(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(fte,"requestErrorHandler");async function Ete(e,t){let r=t+Dr.SERVER_SUFFIX.LEAF,{connection:n}=await Ii(),{jsm:s}=await Rte(r),{schema:i,table:o}=e,c=Ip.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 cte(s,c,n.info.server_name)}catch(u){js.trace(u)}})}a(Ete,"updateRemoteConsumer");async function hte(e,t,r,n){let s=Ip.createNatsTableStreamName(e,t),i=r+Dr.SERVER_SUFFIX.LEAF,o={type:Je.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!F0&&Fee()<br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=ey();await c(o)}await xee(o),n==="stop"&&await Np.async_set_timeout(1e3)}a(hte,"updateConsumerIterator");function Q0(e){return Hee.writeTransaction(Je.SYSTEM_SCHEMA_NAME,Je.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(Q0,"exclusiveLock");async function J0(e,t){let r=Ip.createNatsTableStreamName(e,t),n=await wp(),s=Tte(e,t,n);await ly(r,[s])}a(J0,"createLocalTableStream");async function pte(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(pte,"createTableStreams");async function X0(e,t,r=void 0){if(br.get(Je.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=Ip.createNatsTableStreamName(e,t),{domain:s}=tu(Je.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await Y_()).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 mte(e,t){if(br.get(Je.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await X0(e,t[r])}a(mte,"purgeSchemaTableStreams");async function Ste(e){return(await W_()).streams.info(e)}a(Ste,"getStreamInfo");function Tte(e,t,r){return`${Dr.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}a(Tte,"createSubjectName");async function wp(){if(V_)return V_;if(V_=(await W_())?.nc?.info?.server_name,V_===void 0)throw new Error("Unable to get jetstream manager server name");return V_}a(wp,"getJsmServerName");async function gte(){let e=await W_(),t=await wp(),r=await W0();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let o=Ate(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(gte,"updateLocalStreams");function Ate(e){let{config:t}=e,r=!1,n=br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=br.get(Je.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=br.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(Ate,"updateStreamLimits");async function Rte(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(Rte,"connectToRemoteJS")});var Oc=N(Dp=>{var Cp=W();for(let e of["trace","debug","info","warn","error","fatal","notify"])Cp.logsAtLevel(e)&&(Dp[e]=Cp[e]);Dp.loggerWithTag=e=>Cp.loggerWithTag(e,!0);Dp.setLogLevel=Cp.setLogLevel});function dy(e){let t=e.get(Pp),r=t?(0,ru.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:z_(e)??1,nodes:[]})})}i[n]=0,e.putSync(Pp,(0,ru.pack)(r))}return r}function j_(e){return dy(e).remoteNameToId}function tB(e,t,r){let n=dy(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(Pp,(0,ru.pack)(n)),i}function Lp(e,t){let r=dy(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(Pp,(0,ru.pack)(r))}return eB.info?.("The remote node name map",e,n,s),s}var eB,ru,Pp,_y=Ie(()=>{eB=L(Oc());us();ru=require("msgpackr"),Pp=Symbol.for("remote-ids");a(dy,"getIdMappingRecord");a(j_,"exportIdMapping");a(tB,"remoteToLocalNodeId");a(Lp,"getIdOfRemoteNode")});var ea,fy=Ie(()=>{ea=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:()=>Mp,keyArrayToString:()=>nu,resetResources:()=>yte,resources:()=>wi});function yte(){return wi=new Mp}function nu(e){return Array.isArray(e)?e[e.length-1]===null?e.slice(0,-1).join("/")+"/":e.join("/"):e}var rB,nB,Mp,wi,su=Ie(()=>{Sc();fy();rB=L(W()),nB=L(_e()),Mp=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 ea(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 Dt(r,async()=>{let s=this.getMatch(t);if(s)return t=s.relativeURL,n(s.Resource,s.path,t)})}setRepresentation(t,r,n){}};a(yte,"resetResources");a(nu,"keyArrayToString")});function py(e,t,r,n,s){let i=e.primaryStore.env.path,o=e.primaryStore.tableId,c;s?.crossThreads===!1?(c=oB,bte(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=nu(t);let d=new hy(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=nu(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,Ey.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,Ey.info)(f)}}}if(l==null)break;let _=l.lastIndexOf?.("/",l.length-2);_>-1?l=l.slice(0,_):l=null,u++}while(!0)}if(r)for(let n of r)n.txnInProgress=null,n.listener(null,{type:"end_txn"},e.lastTxnTime,!0)}function bte(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||(py({primaryStore:e,auditStore:e},null,null,0,{scope:"full-database"}),cB(e)),e.nextTransaction}var Ey,iB,oB,hy,my=Ie(()=>{Ey=L(W());Ll();su();Ji();iB=Object.create(null),oB=Object.create(null);a(py,"addSubscription");hy=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(bte,"listenToCommits");a(cB,"nextTransaction");a(lB,"whenNextTransaction")});var hB={};je(hB,{commits_awaiting_replication:()=>au,getHDBNodeTable:()=>Sr,iterateRoutes:()=>J_,shouldReplicateToNode:()=>Q_,subscribeToNodeUpdates:()=>cu});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 cu(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 Q_(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 Ote(){cu(e=>{ta({},(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 au.get(r)||[])u>l&&u<=c&&d();o.lastTime=c},"callback")}));o.lastTime=0,s.set(r,o)}})})}function*J_(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=iu.default.get(ou.CONFIG_PARAMS.REPLICATION_SECUREPORT)??(!iu.default.get(ou.CONFIG_PARAMS.REPLICATION_PORT)&&iu.default.get(ou.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||iu.default.get(ou.CONFIG_PARAMS.REPLICATION_PORT)||iu.default.get(ou.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,iu,ou,EB,uB,dB,au,lu=Ie(()=>{Pe();us();lp();_B=require("worker_threads"),fB=L(_e()),iu=L(se()),ou=L(M()),EB=L(Oc());server.nodes=[];a(Sr,"getHDBNodeTable");a(cu,"subscribeToNodeUpdates");a(Q_,"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})`);au||(au=new Map,Ote());let n=au.get(e);return n||(n=[],au.set(e,n)),new Promise(s=>{let i=0;n.push({txnTime:t,onConfirm:a(()=>{++i===r&&s()},"onConfirm")})})});a(Ote,"startSubscriptionToReplications");a(J_,"iterateRoutes")});var gB={};je(gB,{connectedToNode:()=>Nc,disconnectedFromNode:()=>_u,ensureNode:()=>co,requestClusterStatus:()=>TB,startOnMainThread:()=>Ty});async function Ty(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){Up.set(i,z_(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 J_(e))try{let c=!o.subscriptions;if(c){let u=ot();Sr().primaryStore.get(u)===void 0&&await co(u,{name:u,url:e.url??ra(),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)}cu(s)});let n;function s(i,o=i?.name){let c=ot()&&o===ot()||ra()&&i?.url===ra();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 ao){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){ao.get(_).iterator.remove(),ao.delete(_);return}}return}if(c)return;if(!i.url){_t.info(`Node ${i.name} is missing url`);return}let l=ao.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 uu)if(i.url===E.url){uu.delete(_);break}uu.set(i.name,i)}let u=ut();if(l||(l=new Map,ao.set(i.url,l)),l.iterator=ta(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}];Up.has(_)&&(T.push({replicateByDefault:E,name:ot(),start_time:Up.get(_),end_time:Date.now(),replicates:!0}),Up.delete(_));let m=Q_(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):du(S)},Nte);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):Bp(S)}}a(d,"onDatabase")}a(s,"onNodeUpdate"),_u=a(function(i){try{_t.info("Disconnected from node",i.name,i.url,"finished",!!i.finished);let o=Array.from(uu.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=ao.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=uu.get(f);u=ao.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}):du({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"),Nc=a(function(i){let o=ao.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}):du({database:i.database,nodes:u}))}},"connectedToNode"),(0,Ci.onMessageByType)("disconnected-from-node",_u),(0,Ci.onMessageByType)("connected-to-node",Nc),(0,Ci.onMessageByType)("request-cluster-status",TB)}function TB(e,t){let r=[];for(let[n,s]of uu)try{let i=ao.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,Sy.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 co(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,Sy.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,vp,_t,Sy,pB,mB,SB,Nte,ao,_u,Nc,uu,Up,X_=Ie(()=>{Pe();Ci=L(dt());us();vp=require("worker_threads");lu();_t=L(W()),Sy=require("lodash"),pB=L(se()),mB=L(M()),SB=require("crypto"),Nte=200,ao=new Map,uu=new Map,Up=new Map;a(Ty,"startOnMainThread");a(TB,"requestClusterStatus");vp.parentPort&&(_u=a(e=>{vp.parentPort.postMessage({type:"disconnected-from-node",...e})},"disconnectedFromNode"),Nc=a(e=>{vp.parentPort.postMessage({type:"connected-to-node",...e})},"connectedToNode"),(0,Ci.onMessageByType)("subscribe-to-node",e=>{du(e)}),(0,Ci.onMessageByType)("unsubscribe-from-node",e=>{Bp(e)}));a(co,"ensureNode")});var Hp=N((PNe,AB)=>{"use strict";var Ite=M().OPERATIONS_ENUM,gy=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=Ite.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};AB.exports=gy});var yB=N((MNe,RB)=>{"use strict";var wte={OPERATION:"operation",REFRESH:"refresh"},Ay=class{static{a(this,"JWTTokens")}constructor(t,r){this.operation_token=t,this.refresh_token=r}},Ry=class{static{a(this,"JWTRSAKeys")}constructor(t,r,n){this.public_key=t,this.private_key=r,this.passphrase=n}};RB.exports={JWTTokens:Ay,TOKEN_TYPE_ENUM:wte,JWTRSAKeys:Ry}});var fu=N((vNe,IB)=>{"use strict";var ef=require("jsonwebtoken"),yy=require("fs-extra"),by=te(),ds=M(),{handleHDBError:fn,hdb_errors:Cte}=_e(),{HTTP_STATUS_CODES:En,AUTHENTICATION_ERROR_MSGS:hn}=Cte,Z_=W(),bB=Kh(),Iy=xn(),Dte=un().update,Pte=Hp(),Lte=no(),{UserEventMsg:Mte}=qs(),na=se();na.initSync();var Oy=require("path"),{JWTTokens:Ute,JWTRSAKeys:vte,TOKEN_TYPE_ENUM:xp}=yB(),Bte=na.get(ds.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY)?na.get(ds.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY):"1d",Hte=na.get(ds.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY)?na.get(ds.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY):"30d",kp="RS256",Ny;IB.exports={createTokens:xte,validateOperationToken:Fte,refreshOperationToken:kte,validateRefreshToken:NB,getJWTRSAKeys:tf};async function xte(e){if(by.isEmpty(e)||typeof e!="object")throw fn(new Error,hn.INVALID_AUTH_OBJECT,En.BAD_REQUEST,void 0,void 0,!0);if(by.isEmpty(e.username))throw fn(new Error,hn.USERNAME_REQUIRED,En.BAD_REQUEST,void 0,void 0,!0);if(by.isEmpty(e.password))throw fn(new Error,hn.PASSWORD_REQUIRED,En.BAD_REQUEST,void 0,void 0,!0);let t;try{if(t=await Iy.findAndValidateUser(e.username,e.password),!t)throw fn(new Error,hn.INVALID_CREDENTIALS,En.UNAUTHORIZED,void 0,void 0,!0)}catch(E){throw Z_.error(E),fn(new Error,hn.INVALID_CREDENTIALS,En.UNAUTHORIZED,void 0,void 0,!0)}let r=await tf(),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 ef.sign(i,{key:r.private_key,passphrase:r.passphrase},{expiresIn:Hte,algorithm:kp,subject:xp.REFRESH}),l=bB.hash(c),u=new Pte(ds.SYSTEM_SCHEMA_NAME,ds.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,[{username:e.username,refresh_token:l}]),d,_;try{d=await Dte(u)}catch(E){Z_.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 Lte.signalUserChange(new Mte(process.pid)),new Ute(o,c)}a(xte,"createTokens");async function OB(e,t,r){return await ef.sign(e,{key:t,passphrase:r},{expiresIn:Bte,algorithm:kp,subject:xp.OPERATION})}a(OB,"signOperationToken");async function tf(){if(Ny===void 0)try{let e=Oy.join(na.getHdbBasePath(),ds.LICENSE_KEY_DIR_NAME,ds.JWT_ENUM.JWT_PASSPHRASE_NAME),t=Oy.join(na.getHdbBasePath(),ds.LICENSE_KEY_DIR_NAME,ds.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r=Oy.join(na.getHdbBasePath(),ds.LICENSE_KEY_DIR_NAME,ds.JWT_ENUM.JWT_PUBLIC_KEY_NAME),n=(await yy.readFile(e)).toString(),s=(await yy.readFile(t)).toString(),i=(await yy.readFile(r)).toString();Ny=new vte(i,s,n)}catch(e){throw Z_.error(e),fn(new Error,hn.NO_ENCRYPTION_KEYS,En.INTERNAL_SERVER_ERROR)}return Ny}a(tf,"getJWTRSAKeys");async function kte(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 tf(),r=await ef.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(kte,"refreshOperationToken");async function Fte(e){try{let t=await tf(),r=await ef.verify(e,t.public_key,{algorithms:kp,subject:xp.OPERATION});return await Iy.findAndValidateUser(r.username,void 0,!1)}catch(t){throw Z_.warn(t),t.name&&t.name==="TokenExpiredError"?fn(new Error,hn.TOKEN_EXPIRED,En.FORBIDDEN):fn(new Error,hn.INVALID_TOKEN,En.UNAUTHORIZED)}}a(Fte,"validateOperationToken");async function NB(e){let t;try{let r=await tf(),n=await ef.verify(e,r.public_key,{algorithms:kp,subject:xp.REFRESH});t=await Iy.findAndValidateUser(n.username,void 0,!1)}catch(r){throw Z_.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"),pn=require("fs-extra"),Eu=require("node-forge"),UB=require("net"),{generateKeyPair:Cy,X509Certificate:lo,createPrivateKey:vB}=require("crypto"),Gte=require("util");Cy=Gte.promisify(Cy);var yt=Eu.pki,Qs=require("joi"),{v4:BB}=require("uuid"),{validateBySchema:My}=Tt(),pt=W(),_s=se(),Es=M(),{CONFIG_PARAMS:hu}=Es,Js=Sg(),{ClientError:ia}=_e(),wc=require("node:tls"),{relative:HB,join:qte}=require("node:path"),{CERT_PREFERENCE_APP:HNe,CERTIFICATE_VALUES:wB}=Js,$te=ja(),Dy=wt(),CB=parseInt(process.version.slice(1))<20,{table:Vte,getDatabases:Kte,databases:wy}=(Pe(),oe(lt)),{getJWTRSAKeys:DB}=fu();Object.assign(XB,{generateKeys:By,updateConfigCert:KB,createCsr:Zte,signCertificate:ere,setCertTable:pu,loadCertificates:qB,reviewSelfSignedCert:xy,createTLSSelector:jB,listCertificates:QB,addCertificate:ore,removeCertificate:cre,createNatsCerts:nre,generateCertsKeys:rre,getReplicationCert:nf,getReplicationCertAuth:Xte,renewSelfSigned:sre,hostnamesFromCert:JB,getKey:lre});var{urlToNodeName:xB,getThisNodeUrl:Yte,getThisNodeName:Gp,clearThisNodeName:Wte}=(us(),oe(ca)),{readFileSync:jte,watchFile:zte,statSync:kB}=require("node:fs"),xNe=se(),{getTicketKeys:Qte,onMessageFromWorkers:Jte}=dt(),sa=W(),{isMainThread:FB}=require("worker_threads"),{TLSSocket:GB,createSecureContext:kNe}=require("node:tls"),Uy=3650,rf=["127.0.0.1","localhost","::1"],vy=[{name:"countryName",value:"USA"},{name:"stateOrProvinceName",value:"Colorado"},{name:"localityName",value:"Denver"},{name:"organizationName",value:"HarperDB, Inc."}];Jte(async e=>{e.type===Es.ITC_EVENT_TYPES.RESTART&&(_s.initSync(!0),await xy())});var Pr;function aa(){return Pr||(Pr=Kte().system.hdb_certificate,Pr||(Pr=Vte({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__"}]}))),Pr}a(aa,"getCertTable");async function nf(){let e=jB("operations-api"),t={secureContexts:null,setSecureContext:a(s=>{},"setSecureContext")};await e.initialize(t);let r=t.secureContexts.get(Gp());if(!r)return;let n=new lo(r.options.cert);return r.cert_parsed=n,r.issuer=n.issuer,r}a(nf,"getReplicationCert");async function Xte(){aa();let e=(await nf()).options.cert,r=new lo(e).issuer.match(/CN=(.*)/)?.[1];return Pr.get(r)}a(Xte,"getReplicationCertAuth");var PB,oa=new Map;function qB(){if(PB)return;PB=!0;let e=[{configKey:hu.TLS},{configKey:hu.OPERATIONSAPI_TLS}];aa();let t=sr.dirname(Dy.getConfigFilePath()),r;for(let{configKey:n}of e){let s=Dy.getConfigFromFile(n);if(s){Array.isArray(s)||(s=[s]);for(let i of s){let o=i.privateKey,c=o&&HB(qte(t,"keys"),o);c&&LB(o,l=>{oa.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 lo(f),T;try{T=ky(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 lo(wB.cert)))return;let m=Pr.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=Pr.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=i.mtimeMs;c&&c!==n&&(o&&FB&&pt.warn(`Reloading ${r}:`,e),n=c,t(YB(e)))}catch(c){pt.error(`Error loading ${r}:`,e,c)}},"loadFile");pn.existsSync(e)?s(kB(e)):pt.error(`${r} file not found:`,e),zte(e,{persistent:!1},s)}a(LB,"loadAndWatch");function Py(){let e=Yte();if(e==null){let t=rf[0];return pt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return xB(e)}a(Py,"getHost");function Fp(){let e=Gp();if(e==null){let t=rf[0];return pt.info("replication url is missing from harperdb-config.yaml, using default host"+t),t}return e}a(Fp,"getCommonName");async function Zte(){let e=await nf(),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:Fp()},...vy];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),Eu.pki.certificationRequestToPem(n)}a(Zte,"createCsr");function $B(){let e=rf.includes(Fp())?rf:[...rf,Fp()];return e.includes(Py())||e.push(Py()),[{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 ere(e){let t={},r=sr.join(_s.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME);if(e.csr){let n,s;aa();for await(let d of Pr.search([]))if(d.is_authority&&!d.details.issuer.includes("HarperDB-Certificate-Authority")){if(oa.has(d.private_key_name)){n=oa.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 Ly();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=Eu.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()+Uy),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,Eu.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(ere,"signCertificate");async function tre(e,t){await pu({name:Gp(),uses:["https","wss"],certificate:e,private_key_name:"privateKey.pem",is_authority:!1,is_self_signed:!0}),await pu({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(tre,"createCertificateTable");async function pu(e){let t=new lo(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},aa(),await Pr.patch(e)}a(pu,"setCertTable");async function By(){let e=await Cy("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(By,"generateKeys");async function Hy(e,t,r){let n=yt.createCertificate();if(!t){let o=await nf();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()+Uy);let i=[{name:"commonName",value:Fp()},...vy];return n.setSubject(i),n.setIssuer(r.subject.attributes),n.setExtensions($B()),n.sign(e,Eu.md.sha256.create()),yt.certificateToPem(n)}a(Hy,"generateCertificates");async function Ly(){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 lo(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(Ly,"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()+Uy);let i=[{name:"commonName",value:`HarperDB-Certificate-Authority-${_s.get(hu.REPLICATION_HOSTNAME)??xB(_s.get(hu.REPLICATION_URL))??BB().split("-")[0]}`},...vy];n.setSubject(i),n.setIssuer(i),n.setExtensions([{name:"basicConstraints",cA:!0,critical:!0},{name:"keyUsage",keyCertSign:!0,critical:!0}]),n.sign(e,Eu.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 rre(){let{private_key:e,public_key:t}=await By(),r=await VB(e,t),n=await Hy(e,t,r);await tre(n,r),KB()}a(rre,"generateCertsKeys");async function nre(){let e=await Hy(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(nre,"createNatsCerts");async function sre(){aa();for await(let e of Pr.search([{attribute:"is_self_signed",value:!0}]))await Pr.delete(e.name);await xy()}a(sre,"renewSelfSigned");async function xy(){Wte(),await qB(),aa();let e=await Ly();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(hu.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 By(),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 pu({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 nf()){let r=Gp();pt.notify(`A suitable replication certificate was not found, creating new self singed cert named: ${r}`),e=e??await Ly();let n=yt.certificateFromPem(e.ca.certificate),s=n.publicKey,i=await Hy(yt.privateKeyFromPem(e.private_key),s,n);await pu({name:r,uses:["https","operations","wss"],certificate:i,is_authority:!1,private_key_name:e.ca.private_key_name,is_self_signed:!0})}}a(xy,"reviewSelfSignedCert");function KB(){let e=$te(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),Dy.updateConfigValue(void 0,void 0,o,!1,!0)}a(KB,"updateConfigCert");function YB(e){return e.startsWith("-----BEGIN")?e:jte(e,"utf8")}a(YB,"readPEM");var MB=wc.createSecureContext;wc.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=wc.Server;wc.Server=function(e,t){return e.ALPNCallback&&(e.ALPNProtocols=null),WB.call(this,e,t)};wc.Server.prototype=WB.prototype;var ire=GB.prototype._init;GB.prototype._init=function(e,t){ire.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 Ic=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(),Ic.clear();let d=0;for await(let _ of wy.system.hdb_certificate.search([])){let E=_.certificate,f=new lo(E);_.is_authority&&(f.asString=E,Ic.set(f.subject,E))}for await(let _ of wy.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 lo(T);if(Ic.has(m.issuer)&&(T+=`
|
|
15
15
|
`+Ic.get(m.issuer)),!h||!T)throw new Error("Missing private key or certificate for secure server");let g={ciphers:_.ciphers,ticketKeys:Qte(),availableCAs:Ic,ca:t&&Array.from(Ic.values()),cert:T,key:h,key_file:_.private_key_name,is_self_signed:_.is_self_signed};o&&(g.sessionIdContext=o.sessionIdContext);let S=wc.createSecureContext(g);S.name=_.name,S.options=g,S.quality=f,S.certificateAuthorities=Array.from(Ic),S.certStart=T.toString().slice(0,100);let y=_.hostnames??JB(m);Array.isArray(y)||(y=[y]);let I;for(let U of y)if(U){U[0]==="*"&&(s=!0,U=U.slice(1)),U===Py()&&(f+=2),UB.isIP(U)&&(I=!0);let H=r.get(U)?.quality??0;f>H&&r.set(U,S)}else sa.error("No hostname found for certificate at",wc.certificate);sa.trace("Adding TLS",S.name,"for",o.ports||"client","cert named",_.name,"hostnames",y,"quality",f,"best quality",d),f>d&&(i.defaultContext=n=S,d=f,o&&(o.defaultContext=S))}catch(E){sa.error("Error applying TLS for",_.name,E)}o?.secureContextsListeners.forEach(_=>_()),c(n)}catch(d){l(d)}}a(u,"updateTLS"),wy.system.hdb_certificate.subscribe({listener:a(()=>setTimeout(()=>u(),1500).unref(),"listener"),omitCurrent:!0}),u()})),i;function i(o,c){sa.info("TLS requested for",o||"(no SNI)",this.isReplicationConnection);let l=o;for(;;){let d=r.get(l);if(d)return sa.debug("Found certificate for",o,d.certStart),d.replicationContext&&(this.isReplicationConnection||CB)&&(d=d.replicationContext),c(null,d);if(s&&l){let _=l.indexOf(".",1);_<0?l="":l=l.slice(_)}else break}o?sa.debug("No certificate found to match",o,"using the default certificate"):sa.debug("No SNI, using the default certificate",n?.name);let u=n;u?u.replicationContext&&(this.isReplicationConnection||CB)&&(u=u.replicationContext):sa.info("No default certificate found"),c(null,u)}a(i,"SNICallback")}a(jB,"createTLSSelector");async function zB(e){let t=oa.get(e);return!t&&e?await pn.readFile(sr.join(_s.get(hu.ROOTPATH),Es.LICENSE_KEY_DIR_NAME,e),"utf8"):t}a(zB,"getPrivateKeyByName");async function QB(){aa();let e=[];for await(let t of Pr.search([]))e.push(t);return e}a(QB,"listCertificates");async function ore(e){let t=My(e,Qs.object({name:Qs.string().required(),certificate:Qs.string().required(),is_authority:Qs.boolean().required(),private_key:Qs.string(),hosts:Qs.array(),uses:Qs.array()}));if(t)throw new ia(t.message);let{name:r,certificate:n,private_key:s,is_authority:i}=e,o=new lo(n),c=!1,l=!1,u;for(let[f,h]of oa)!s&&!c&&o.checkPrivateKey(vB(h))&&(c=!0,u=f),s&&s===h&&(l=!0,u=f);if(!i&&!s&&!c)throw new ia("A suitable private key was not found for this certificate");let d;if(!r){try{d=ky(o)}catch(f){pt.error(f)}if(d==null)throw new ia("Error extracting certificate common name, please provide a name parameter")}let _=are(r??d);s&&!c&&!l&&(await pn.writeFile(sr.join(_s.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME,_+".pem"),s),oa.set(_,s));let E={name:r??d,certificate:n,is_authority:i,hosts:e.hosts,uses:e.uses};return(!i||i&&u||i&&s)&&(E.private_key_name=u??_+".pem"),await pu(E),"Successfully added certificate: "+_}a(ore,"addCertificate");function are(e){return e.replace(/[^a-z0-9\.]/gi,"-")}a(are,"sanitizeName");async function cre(e){let t=My(e,Qs.object({name:Qs.string().required()}));if(t)throw new ia(t.message);let{name:r}=e;aa();let n=await Pr.get(r);if(!n)throw new ia(r+" not found");let{private_key_name:s}=n;if(s){let i=Array.from(await Pr.search([{attribute:"private_key_name",value:s}]));i.length===1&&i[0].name===r&&(pt.info("Removing private key named",s),await pn.remove(sr.join(_s.getHdbBasePath(),Es.LICENSE_KEY_DIR_NAME,s)))}return await Pr.delete(r),"Successfully removed "+r}a(cre,"removeCertificate");function ky(e){return e.subject.match(/CN=(.*)/)?.[1]}a(ky,"extractCommonName");function JB(e){return e.subjectAltName?e.subjectAltName.split(",").map(t=>{let r=t.indexOf(":");if(t=t.slice(r+1),t=t.trim(),t[0]==='"')try{t=JSON.parse(t)}catch{}return t.indexOf("=")>-1?t.match(/CN=([^,]*)/)?.[1]:t}).filter(t=>t):[ky(e)]}a(JB,"hostnamesFromCert");async function lre(e){if(e.bypass_auth!==!0)throw new ia("Unauthorized","401");let t=My(e,Qs.object({name:Qs.string().required()}));if(t)throw new ia(t.message);let{name:r}=e;if(r===".jwtPrivate")return(await DB()).private_key;if(r===".jwtPublic")return(await DB()).public_key;if(oa.get(r))return oa.get(e.name);throw new ia("Key not found")}a(lre,"getKey")});async function Ky(e,t){let{authorization:r,rejectUnauthorized:n}=t||{},s=ot(),i;if(e.includes("wss://")){if(!Gy){let l=(0,hH.createTLSSelector)("operations-api"),u={secureContexts:null};await l.initialize(u),Gy=u.secureContexts}if(i=Gy.get(s),i&&fe.debug?.("Creating web socket for URL",e,"with certificate named:",i.name),!i&&n!==!1)throw new Error("Unable to find a valid certificate to use for replication to connect to "+e)}let o={};r&&(o.Authorization=r);let c={headers:o,localAddress:s?.startsWith("127.0")?s:void 0,servername:(0,mH.isIP)(t?.serverName)?void 0:t?.serverName,noDelay:!0,highWaterMark:128*1024,ALPNProtocols:["http/1.1","harperdb-replication"],rejectUnauthorized:n!==!1,secureContext:void 0};return i&&(c.secureContext=pH.createSecureContext({...i.options,ca:Array.from(Dc)})),new fH.WebSocket(e,"harperdb-replication-v1",c)}function Yp(e,t,r){let n=t.port||t.securePort,s=Vy.pid%1e3+"-"+EH.threadId+(n?"s:"+n:"c:"+t.url?.slice(-4))+" "+Math.random().toString().slice(2,3),i=0,o=Buffer.allocUnsafeSlow(1024),c=0,l=new DataView(o.buffer,0,1024),u=t.database,d=t.databaseSubscriptions||Cc,_,E,f=!1,h=t.subscription;h?.then&&h.then(ie=>h=ie);let T=t.tables||u&&ut()[u];if(!r){fe.error?.("No authorization provided"),ss(1008,"Unauthorized");return}let m=new Map,g=[],S=r.name;S&&t.connection&&(t.connection.nodeName=S);let y,I,U,H,X,Y,V=1e3,ne,Q=0,de=0,j=0,ae=0;if(t.url){let ie=a(()=>{X&&j===e._socket?.bytesRead&&ae===e._socket?.bytesWritten?e.terminate():(X=performance.now(),e.ping(),j=e._socket?.bytesRead,ae=e._socket?.bytesWritten)},"send_ping");U=setInterval(ie,lH).unref(),ie()}else Oe();function Oe(){clearTimeout(H),j=e._socket?.bytesRead,ae=e._socket?.bytesWritten,H=setTimeout(()=>{j===e._socket?.bytesRead&&ae===e._socket?.bytesWritten&&(fe.warn?.(`Timeout waiting for ping from ${S}, terminating connection and reconnecting`),e.terminate())},lH*2).unref()}a(Oe,"resetPingTimer"),u&&Ka(u);let Ne,Me,Gr=[],Dd=[],Fa,wn=[],Pd=[],Nl=[],Uw=150,jE=0,vt=0,Ga,qa,vs,Bs,zE;e.on("message",ie=>{Q=performance.now();try{let Se=ie.dataView=new Pc(ie.buffer,ie.byteOffset,ie.byteLength);if(ie[0]>127){let A=(0,ct.decode)(ie),[w,R,b]=A;switch(w){case eH:{if(R){if(S){if(S!==R){fe.error?.(s,`Node name mismatch, expecting to connect to ${S}, but peer reported name as ${R}, disconnecting`),e.send((0,ct.encode)([mu])),ss(1008,"Node name mismatch");return}}else if(S=R,t.connection?.tentativeNode){let x=t.connection.tentativeNode;x.name=S,t.connection.tentativeNode=null,co(S,x)}if(t.connection&&(t.connection.nodeName=S),fe.debug?.(s,"received node name:",S,"db:",u),!u)try{Ka(u=A[2]),u==="system"&&(Ne=ta(t,(x,q)=>{Va(q)&&Ir(q)}),e.on("close",()=>{Ne?.remove()}))}catch(x){fe.warn?.(s,"Error setting database",x),e.send((0,ct.encode)([mu])),ss(1008,x.message);return}$a()}break}case aH:{fe.debug?.(s,"Received table definitions for",R.map(x=>x.table));for(let x of R){let q=A[2];x.database=q;let ee;Va(q)&&(q==="system"?We[q]?.[x.table]||(ee=qy(x,We[q]?.[x.table])):ee=qy(x,We[q]?.[x.table]),_||(_=ee?.auditStore),T||(T=ut()?.[q]))}break}case mu:ss();break;case sH:try{let x=r?.replicates||r?.subscribers||r?.name;server.operation(R,{user:r},!x).then(q=>{Array.isArray(q)&&(q={results:q}),q.requestId=R.requestId,e.send((0,ct.encode)([$p,q]))},q=>{e.send((0,ct.encode)([$p,{requestId:R.requestId,error:q instanceof Error?q.toString():q}]))})}catch(x){e.send((0,ct.encode)([$p,{requestId:R.requestId,error:x instanceof Error?x.toString():x}]))}break;case $p:let{resolve:D,reject:O}=m.get(R.requestId);R.error?O(new Error(R.error)):D(R),m.delete(R.requestId);break;case Fy:let B=A[3];T||(u?fe.error?.(s,"No tables found for",u):fe.error?.(s,"Database name never received"));let k=T[B];k=qy({table:B,database:u,attributes:R.attributes,schemaDefined:R.schemaDefined},k),Gr[b]={name:B,decoder:new ct.Packr({useBigIntExtension:!0,randomAccessStructure:!0,freezeData:!0,typedStructs:R.typedStructs,structures:R.structures}),getEntry(x){return k.primaryStore.getEntry(x)},rootStore:k.primaryStore.rootStore};break;case tH:zE=_?tB(S,R,_):new Map,Fa=A[2],fe.debug?.(s,`Acknowledged subscription request, receiving messages for nodes: ${Fa}`);break;case rH:let C=b;Nl[C]=R;break;case oH:let F=["replicated",u,S];E||(E=new Float64Array(_.getUserSharedBuffer(F,new ArrayBuffer(8)))),E[0]=R,fe.trace?.(s,"received and broadcasting committed update",R),E.buffer.notify();break;case iH:y=R,h.send({type:"end_txn",localTime:y,remoteNodeIds:g});break;case nH:{let x=R,q;try{let ee=A[3],G=Dd[b]||(Dd[b]=T[A[4]]);if(!G)return fe.warn?.("Unknown table id trying to handle record request",b);let Re=G.primaryStore.getBinaryFast(Symbol.for("structures")),Ee=Re.length;if(Ee!==vt){vt=Ee;let re=(0,ct.decode)(Re);e.send((0,ct.encode)([Fy,{typedStructs:re.typed,structures:re.named},b,G.tableName]))}let Ae=G.primaryStore.getBinaryFast(ee);if(Ae){let re=G.primaryStore.decoder.decode(Ae,{valueAsBuffer:!0});q=(0,ct.encode)([qp,x,{value:re.value,expiresAt:re.expiresAt,version:re.version,residencyId:re.residencyId,nodeId:re.nodeId,user:re.user}])}else q=(0,ct.encode)([qp,x])}catch(ee){q=(0,ct.encode)([qp,x,{error:ee.message}])}e.send(q);break}case qp:{let{resolve:x,reject:q,tableId:ee,key:G}=m.get(A[1]),Re=A[2];if(Re?.error)q(new Error(Re.error));else if(Re){let Ee=Gr[ee].decoder.decode(Re.value);Re.value=Ee,Re.key=G,x(Re)}else x();m.delete(A[1]);break}case ZB:{Bs=R;let x,q,ee=!1;if(h){if(u!==h.databaseName&&!h.then){fe.error?.("Subscription request for wrong database",u,h.databaseName);return}}else h=d.get(u);if(fe.debug?.(s,"received subscription request for",u,"at",Bs),!h){let ce;h=new Promise(Ye=>{fe.debug?.("Waiting for subscription to database "+u),ce=Ye}),h.ready=ce,Cc.set(u,h)}if(r.name)q=Sr().subscribe(r.name),q.then(async ce=>{x=ce;for await(let Ye of x){let rt=Ye.value;if(!(rt?.replicates===!0||rt?.replicates?.receives||rt?.subscriptions?.some(Ze=>(Ze.database||Ze.schema)===u&&Ze.publish!==!1))){ee=!0,e.send((0,ct.encode)([mu])),ss(1008,`Unauthorized database subscription to ${u}`);return}}},ce=>{fe.error?.(s,"Error subscribing to HDB nodes",ce)});else if(!(r?.role?.permission?.super_user||r.replicates)){e.send((0,ct.encode)([mu])),ss(1008,`Unauthorized database subscription to ${u}`);return}if(vs&&(fe.debug?.(s,"stopping previous subscription",u),vs.emit("close")),Bs.length===0)return;let G=Bs[0],Re=a(ce=>{if(ce&&(G.replicateByDefault?!G.tables.includes(ce.tableName):G.tables.includes(ce.tableName)))return{table:ce}},"tableToTableEntry"),Ee={txnTime:0},Ae,re,K=1/0,ge,Be=a((ce,Ye)=>{if(K=Ye,ce.type==="end_txn"){Ee.txnTime&&(o[i]!==66&&fe.error?.("Invalid encoding of message"),di(9),di(Kp),Ya(ge=Ye),we()),i=c,Ee.txnTime=0;return}let rt=ce.nodeId,Ze=ce.tableId,st=re[Ze];if(!st&&(st=re[Ze]=Re(h.tableById[Ze]),!st))return fe.debug?.("Not subscribed to table",Ze);let Bt=st.table,ko=Bt.primaryStore,Yt=ko.encoder;(ce.extendedType&Oh||!Yt.typedStructs)&&(Yt._mergeStructures(Yt.getStructures()),Yt.typedStructs&&(Yt.lastTypedStructuresLength=Yt.typedStructs.length));let QE=Ae[rt];if(!(QE&&QE.startTime<Ye&&(!QE.endTime||QE.endTime>Ye)))return sf&&fe.trace?.(s,"skipping replication update",ce.recordId,"to:",S,"from:",rt,"subscribed:",Ae),vw();sf&&fe.trace?.(s,"sending replication update",ce.recordId,"to:",S,"from:",rt,"subscribed:",Ae);let ZT=ce.version;Ee.txnTime!==ZT&&(Ee.txnTime&&(sf&&fe.trace?.(s,"new txn time, sending queued txn",Ee.txnTime),o[i]!==66&&fe.error?.("Invalid encoding of message"),we()),Ee.txnTime=ZT,i=c,Ya(ZT));let Wa=ce.residencyId,eg=ji(Wa,Bt),JE;if(eg&&!eg.includes(S)){let wl=ji(ce.previousResidencyId,Bt);if(wl&&!wl.includes(S)&&(ce.type==="put"||ce.type==="patch")||Bt.getResidencyById)return vw();let vd=ce.recordId;fe.trace?.(s,"sending invalidation",vd,S,"from",rt);let ng=0;Wa&&(ng|=rc),ce.previousResidencyId&&(ng|=nc);let sg,XE=null;for(let Bw in Bt.indices){if(!XE){if(sg=ce.getValue(ko,!0),!sg)break;XE={}}XE[Bw]=sg[Bw]}JE=Ul(ce.version,Ze,vd,null,rt,ce.user,ce.type==="put"||ce.type==="patch"?"invalidate":ce.type,Yt.encode(XE),ng,Wa,ce.previousResidencyId,ce.expiresAt)}function vw(){fe.trace?.(s,"skipping audit record",ce.recordId),Y||(Y=setTimeout(()=>{Y=null,(ge||0)+cH/2<K&&(sf&&fe.trace?.(s,"sending skipped sequence update",K),e.send((0,ct.encode)([iH,K])))},cH).unref())}a(vw,"skipAuditRecord");let tg=Yt.typedStructs,rg=Yt.structures;if((tg?.length!=st.typed_length||rg?.length!=st.structure_length)&&(st.typed_length=tg?.length,st.structure_length=rg.length,fe.debug?.(s,"send table struct",st.typed_length,st.structure_length),st.sentName||(st.sentName=!0),e.send((0,ct.encode)([Fy,{typedStructs:tg,structures:rg,attributes:Bt.attributes,schemaDefined:Bt.schemaDefined},Ze,st.table.tableName]))),Wa&&!Pd[Wa]&&(e.send((0,ct.encode)([rH,eg,Wa])),Pd[Wa]=!0),JE)di(JE.length),Ud(JE);else{let wl=ce.encoded,vd=wl[0]===66?8:0;di(wl.length-vd),Ud(wl,vd)}},"sendAuditRecord"),we=a(()=>{c-i>8?(e.send(o.subarray(i,c)),fe.debug?.(s,"Sent message, size:",c-i)):fe.debug?.(s,"skipping empty transaction")},"sendQueuedData");vs=new $y.EventEmitter,vs.once("close",()=>{ee=!0,x?.end()});for(let{startTime:ce}of Bs)ce<K&&(K=ce);(q||Promise.resolve()).then(async()=>{h=await h,_=h.auditStore,re=h.tableById.map(Re),Ae=[];for(let{name:Ye,startTime:rt,endTime:Ze}of Bs){let st=Lp(Ye,_);fe.debug?.("subscription to",Ye,"using local id",st,"starting",rt),Ae[st]={startTime:rt,endTime:Ze}}Ir(u),Ne||(Ne=Lc(Ye=>{Ye.databaseName===u&&Ir(u)}),Me=of(Ye=>{Ye===u&&(e.send((0,ct.encode)([mu])),ss())}),e.on("close",()=>{Ne?.remove(),Me?.remove()})),e.send((0,ct.encode)([tH,j_(h.auditStore),Bs.map(({name:Ye})=>Ye)]));let ce=!0;do{isFinite(K)||(fe.warn?.("Invalid sequence id "+K),ss(1008,"Invalid sequence id"+K));let Ye;if(ce&&!ee&&(ce=!1,!(Yy(_)<=K)&&dH.default.get(_H.CONFIG_PARAMS.REPLICATION_COPYTABLESTOCATCHUP)!==!1&&server.nodes[0]?.name===S)){fe.info?.("Replicating all tables to",S);let Ze=K,st=Wp(_);for(let Bt in T){if(!Re(Bt))continue;let ko=T[Bt];for(let Yt of ko.primaryStore.getRange({snapshot:!1})){if(ee)return;Yt.localTime>=K&&(fe.trace?.(s,"Copying record from",u,Bt,Yt.key,Yt.localTime),Ze=Math.max(Yt.localTime,Ze),Ye=!0,Be({recordId:Yt.key,tableId:ko.tableId,type:"put",getValue(){return Yt.value},encoded:ko.primaryStore.getBinary(Yt.key),version:Yt.version,residencyId:Yt.residencyId,nodeId:st},Yt.localTime))}}K=Ze}for(let{key:rt,value:Ze}of _.getRange({start:K||1,exclusiveStart:!0,snapshot:!1})){if(ee)return;de=rt;let st=xt(Ze);Be(st,rt),e._socket.writableNeedDrain?await new Promise(Bt=>e._socket.once("drain",Bt)):await new Promise(setImmediate),vs.startTime=rt,Ye=!0}Ye&&Be({type:"end_txn"},K),de=0,await lB(_)}while(!ee)}).catch(ce=>{fe.error?.(s,"Error handling subscription to node",ce),ss(1008,"Error handling subscription to node")});break}}return}Se.position=8;let tt=!0,v,p;do{let A=Se.readInt();if(A===9&&Se.getUint8(Se.position)==Kp){Se.position++,y=p=Se.readFloat64(),fe.trace?.("received remote sequence update",y,u);break}let w=Se.position,R=xt(ie,w,w+A),b=Gr[R.tableId];b||fe.error?.(`No table found with an id of ${R.tableId}`);let D;R.residencyId&&(D=Nl[R.residencyId],fe.trace?.(s,"received residency list",D,R.type,R.recordId));try{v={table:b.name,id:R.recordId,type:R.type,nodeId:zE.get(R.nodeId),residencyList:D,timestamp:R.version,value:R.getValue(b),user:R.user,beginTxn:tt,expiresAt:R.expiresAt}}catch(O){throw O.message+="typed structures for current decoder"+JSON.stringify(b.decoder.typedStructs),O}tt=!1,sf&&fe.trace?.(s,"received replication message",R.type,"id",v.id,"version",R.version,"nodeId",v.nodeId,"value",v.value),h.send(v),Se.position=w+A}while(Se.position<ie.byteLength);jE++,pr(ie.byteLength,"bytes-received",S+"."+u+"."+v.table,"replication","ingest"),jE>Uw&&!Ga&&(Ga=!0,e.pause()),h.send({type:"end_txn",localTime:y,remoteNodeIds:g,onCommit(){if(v){let A=Date.now()-v.timestamp;pr(A,"replication-latency",S+"."+u+"."+v.table,v.type,"ingest")}jE--,Ga&&(Ga=!1,e.resume()),!I&&p&&(fe.trace?.(s,"queuing confirmation of a commit at",p),setTimeout(()=>{e.send((0,ct.encode)([oH,I])),fe.trace?.(s,"sent confirmation of a commit at",I),I=null},ure)),I=p}})}catch(Se){fe.error?.(s,"Error handling incoming replication message",Se)}}),e.on("ping",Oe),e.on("pong",()=>{t.connection&&(t.connection.latency=performance.now()-X,Nc({name:S,database:u,url:t.url,lastSendTime:de,latency:t.connection.latency})),X=null}),e.on("close",(ie,Se)=>{clearInterval(U),clearTimeout(H),vs&&vs.emit("close"),qa&&qa.end();for(let[tt,{reject:v}]of m)v(new Error(`Connection closed ${Se?.toString()} ${ie}`));fe.debug?.(s,"closed",ie,Se?.toString())});function Ve(){}a(Ve,"recordRemoteNodeSequence");function ss(ie,Se){e.isFinished=!0,e.close(ie,Se)}a(ss,"close");function $a(){if(f||(f=!0,t.connection?.on("subscriptions-updated",$a)),t.connection?.isFinished)throw new Error("Can not make a subscription request on a connection that is already closed");let ie=new Map;try{for(let v of h?.dbisDB?.getRange({start:Symbol.for("seq"),end:[Symbol.for("seq"),Buffer.from([255])]})||[])for(let p of v.value.nodes||[])p.lastTxnTime>(ie.get(p.id)??0)&&ie.set(p.id,p.lastTxnTime)}catch(v){if(!v.message.includes("Can not re"))throw v}let Se=t.connection?.nodeSubscriptions?.[0];g=[];let tt=t.connection?.nodeSubscriptions.map((v,p)=>{let A=[],{replicateByDefault:w}=v;if(v.subscriptions){for(let O of v.subscriptions)if(O.subscribe&&(O.schema||O.database)===u){let B=O.table;T?.[B]?.replicate!==!1&&A.push(B)}w=!1}else for(let O in T)(w?T[O].replicate===!1:T[O].replicate)&&A.push(O);let R=_&&Lp(v.name,_),b=h?.dbisDB?.get([Symbol.for("seq"),R])??1,D=Math.max(b?.seqId??1,(typeof v.start_time=="string"?new Date(v.start_time).getTime():v.start_time)??1);if(fe.debug?.("Starting time recorded in db",v.name,R,u,b?.seqId,"start time:",D),Se!==v){D>5e3&&(D-=5e3);let O=_&&Lp(Se.name,_),B=h?.dbisDB?.get([Symbol.for("seq"),O])??1;for(let k of B?.nodes||[])k.name===v.name&&(D=k.seqId,fe.debug?.("Using sequence id from proxy node",Se.name,D))}return g.push(R),ie.get(R)>D&&(D=ie.get(R),fe.debug?.("Updating start time from more recent txn recorded",Se.name,D)),{name:v.name,replicateByDefault:w,tables:A,startTime:D,endTime:v.end_time}});if(tt)if(fe.debug?.(s,"sending subscription request",tt,h?.dbisDB?.path),clearTimeout(ne),tt.length>0)e.send((0,ct.encode)([ZB,tt]));else{let v=a(()=>{let p=performance.now();ne=setTimeout(()=>{Q<=p?ss(1008,"No nodes to subscribe to"):v()},V)},"schedule_close");v()}}a($a,"sendSubscriptionRequestUpdate");function ji(ie,Se){if(!ie)return;let tt=wn[ie];return tt||(tt=Se.getResidencyRecord(ie),wn[ie]=tt),tt}a(ji,"getResidence");function Va(ie){return!(la&&la!="*"&&!la[ie]&&!la.includes?.(ie)&&!la.some?.(Se=>Se.name===ie))}a(Va,"checkDatabaseAccess");function Ka(ie){if(h=h||d.get(ie),!Va(ie))throw new Error(`Access to database "${ie}" is not permitted`);h||fe.warn?.(`No database named "${ie}" was declared and registered`),_=h?.auditStore,T||(T=ut()?.[ie]);let Se=ot();if(Se===S)throw Se?new Error("Should not connect to self",Se):new Error("Node name not defined");return Ld(Se,ie),!0}a(Ka,"setDatabase");function Ld(ie,Se){let tt=ut()?.[Se],v=[];for(let p in tt){let A=tt[p];v.push({table:p,schemaDefined:A.schemaDefined,attributes:A.attributes.map(w=>({name:w.name,type:w.type,isPrimaryKey:w.isPrimaryKey}))})}fe.trace?.("Sending database info for node",ie,"database name",Se),e.send((0,ct.encode)([eH,ie,Se,v]))}a(Ld,"sendNodeDBName");function Ir(ie){let Se=ut()?.[ie],tt=[];for(let v in Se){if(Bs&&!Bs.some(A=>A.replicateByDefault?!A.tables.includes(v):A.tables.includes(v)))continue;let p=Se[v];tt.push({table:v,schemaDefined:p.schemaDefined,attributes:p.attributes.map(A=>({name:A.name,type:A.type,isPrimaryKey:A.isPrimaryKey}))})}e.send((0,ct.encode)([aH,tt,ie]))}a(Ir,"sendDBSchema");let Il=1,Md=[];return{end(){qa&&qa.end(),vs&&vs.emit("close")},getRecord(ie){let Se=Il++;return new Promise((tt,v)=>{let p=[nH,Se,ie.table.tableId,ie.id];Md[ie.table.tableId]||(p.push(ie.table.tableName),Md[ie.table.tableId]=!0),e.send((0,ct.encode)(p)),m.set(Se,{tableId:ie.table.tableId,key:ie.id,resolve(A){let{table:w,entry:R}=ie;tt(A),A&&w._recordRelocate(R,A)},reject:v})})},sendOperation(ie){let Se=Il++;return ie.requestId=Se,e.send((0,ct.encode)([sH,ie])),new Promise((tt,v)=>{m.set(Se,{resolve:tt,reject:v})})}};function di(ie){xo(5),ie<128?o[c++]=ie:ie<16384?(l.setUint16(c,ie|32768),c+=2):ie<1056964608?(l.setUint32(c,ie|3221225472),c+=4):(o[c]=255,l.setUint32(c+1,ie),c+=5)}function Ud(ie,Se=0,tt=ie.length){let v=tt-Se;xo(v),ie.copy(o,c,Se,tt),c+=v}function Ya(ie){xo(8),l.setFloat64(c,ie),c+=8}function xo(ie){if(ie+16>o.length-c){let Se=Buffer.allocUnsafeSlow(c+ie-i+65536>>10<<11);o.copy(Se,0,i,c),c=c-i,i=0,o=Se,l=new DataView(o.buffer,0,o.length)}}}function qy(e,t){let r=e.database??"data";if(r!=="data"&&!We[r]){fe.warn?.("Database not found",e.database);return}t||(t={});let n=!1,s=e.schemaDefined,i=t.attributes||[];for(let o=0;o<e.attributes?.length;o++){let c=e.attributes[o],l=i[o];(!l||l.name!==c.name||l.type!==c.type)&&(n=!0,s||(c.indexed=!0),i[o]=c)}return n?(fe.debug?.("(Re)creating",e),Et({table:e.table,database:e.database,schemaDefined:e.schemaDefined,attributes:i,...t})):t}var dH,_H,ct,fH,EH,fe,$y,hH,pH,Vy,mH,ZB,eH,tH,mu,rH,Fy,nH,qp,sH,$p,iH,oH,aH,SH,Cc,sf,cH,ure,lH,Gy,uH,Vp,TH=Ie(()=>{Pe();Ji();_y();my();us();dH=L(se()),_H=L(M());vl();ct=require("msgpackr"),fH=require("ws"),EH=require("worker_threads"),fe=L(Oc());X_();$y=require("events"),hH=L(Xs()),pH=L(require("node:tls"));lu();Vy=L(require("node:process")),mH=require("node:net");Ni();ZB=129,eH=140,tH=141,mu=142,rH=130,Fy=132,nH=133,qp=134,sH=136,$p=137,iH=143,oH=144,aH=145,SH=new Map,Cc=new Map,sf=!0,cH=300,ure=2,lH=3e4;a(Ky,"createWebSocket");uH=1e3,Vp=class extends $y.EventEmitter{constructor(r,n,s,i,o){super();this.url=r;this.subscription=n;this.databaseName=s;this.nodeName=i;this.authorization=o;this.nodeName=this.nodeName??zs(r)}static{a(this,"NodeReplicationConnection")}socket;startTime;retryTime=uH;retries=0;isConnected=!0;isFinished=!1;nodeSubscriptions=[];latency=0;replicateTablesByDefault;session;sessionResolve;sessionReject;async connect(){this.session||this.resetSession();let r=[];this.socket=await Ky(this.url,{serverName:this.nodeName,authorization:this.authorization});let n;fe.debug?.(`Connecting to ${this.url}, db: ${this.databaseName}, process ${Vy.pid}`),this.socket.on("open",()=>{this.socket._socket.unref(),fe.info?.(`Connected to ${this.url}, db: ${this.databaseName}`),this.retries=0,this.retryTime=uH,Nc({name:this.nodeName,database:this.databaseName,url:this.url}),this.isConnected=!0,n=Yp(this.socket,{database:this.databaseName,subscription:this.subscription,url:this.url,connection:this},{replicates:!0}),this.sessionResolve(n)}),this.socket.on("error",s=>{s.code==="SELF_SIGNED_CERT_IN_CHAIN"?(fe.warn?.(`Can not connect to ${this.url}, this server does not have a certificate authority for the certificate provided by ${this.url}`),s.isHandled=!0):s.code!=="ECONNREFUSED"&&(s.code==="UNABLE_TO_VERIFY_LEAF_SIGNATURE"?fe.error?.(`Can not connect to ${this.url}, the certificate provided by ${this.url} is not trusted, this node needs to be added to the cluster, or a certificate authority needs to be added`):fe.error?.(`Error in connection to ${this.url} due to ${s.message}`)),this.sessionReject(s)}),this.socket.on("close",(s,i)=>{if(this.isConnected&&(_u({name:this.nodeName,database:this.databaseName,url:this.url,finished:this.socket.isFinished}),this.isConnected=!1),this.socket.isFinished){this.isFinished=!0,n?.end(),this.emit("finished");return}if(++this.retries%20===1){let o=i?.toString();fe.warn?.(`${n?"Disconnected from":"Failed to connect to"} ${this.url} (db: "${this.databaseName}"), due to ${o?'"'+o+'" ':""}(code: ${s})`)}n=null,this.resetSession(),setTimeout(()=>{this.connect()},this.retryTime).unref(),this.retryTime+=this.retryTime>>3})}resetSession(){this.session=new Promise((r,n)=>{this.sessionResolve=r,this.sessionReject=n})}subscribe(r,n){this.nodeSubscriptions=r,this.replicateTablesByDefault=n,this.emit("subscriptions-updated",r)}unsubscribe(){this.socket.isFinished=!0,this.socket.close(1008,"No longer subscribed")}getRecord(r){return this.session.then(n=>n.getRecord(r))}};a(Yp,"replicateOverWS");a(qy,"ensureTableIfChanged")});var ca={};je(ca,{clearThisNodeName:()=>Sre,disableReplication:()=>Ere,enabled_databases:()=>la,forEachReplicatedDatabase:()=>ta,getThisNodeId:()=>Wp,getThisNodeName:()=>ot,getThisNodeUrl:()=>ra,hostnameToUrl:()=>Jp,lastTimeInAuditStore:()=>z_,monitorNodeCAs:()=>IH,replicateOperation:()=>gre,replication_certificate_authorities:()=>Dc,sendOperationToNode:()=>cf,servers:()=>_re,setReplicator:()=>CH,start:()=>fre,startOnMainThread:()=>Ty,subscribeToNode:()=>du,unsubscribeFromNode:()=>Bp,urlToNodeName:()=>zs});function fre(e){if(e.port||(e.port=hs.default.get(Mc.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_PORT)),e.securePort||(e.securePort=hs.default.get(Mc.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_SECUREPORT)),!ot())throw new Error("Can not load replication without a url (see replication.url in the config)");let t=new Map;for(let n of J_(e))t.set(zs(n.url),n);hre(e),e={mtls:!0,isOperationsServer:!0,maxPayload:10*1024*1024*1024,...e};let r=it.ws(async(n,s,i,o)=>{if(s.headers.get("sec-websocket-protocol")!=="harperdb-replication-v1")return o(n,s,i);await i,n._socket.unref(),Yp(n,e,s?.user),n.on("error",c=>{c.code!=="ECONNREFUSED"&&Tr.error("Error in connection to "+this.url,c.message)})},e);e.runFirst=!0,it.http((n,s)=>{if(n.isWebSocket&&n.headers.get("Sec-WebSocket-Protocol")==="harperdb-replication-v1"){!n.authorized&&n._nodeRequest.socket.authorizationError&&Tr.error(`Incoming client connection from ${n.ip} did not have valid certificate, you may need turn on enableRootCAs in the config if you are using a publicly signed certificate, or add the CA to the server's trusted CAs`,n._nodeRequest.socket.authorizationError);let i=Sr().primaryStore;if(n.authorized&&n.peerCertificate.subject){let o=n.peerCertificate.subject,c=o&&(i.get(o.CN)||t.get(o.CN));c?n.user=c:Tr.warn(`No node found for certificate common name ${o.CN}, available nodes are ${Array.from(i.getRange({}).filter(({value:l})=>l).map(({key:l})=>l)).join(", ")} and routes ${Array.from(t.keys()).join(", ")}, connection will require credentials.`)}else{let o=i.get(n.ip)||t.get(n.ip);o?n.user=o:Tr.warn(`No node found for IP address ${n.ip}, available nodes are ${Array.from(new Set([...i.getKeys(),...t.keys()])).join(", ")}, connection will require credentials.`)}}return s(n)},e);for(let n of r)if(n.secureContexts){let s=a(()=>{let i=new Set(n.secureContexts.values());n.defaultContext&&i.add(n.defaultContext);for(let o of i)try{let c=Array.from(Dc);o.options.availableCAs&&c.push(...o.options.availableCAs.values());let l={...o.options,ca:c};o.replicationContext=Qp.createSecureContext(l)}catch(c){Tr.error("Error creating replication TLS config",c)}},"updateContexts");n.secureContextsListeners.push(s),IH(s),hs.default.get(Mc.CONFIG_PARAMS.REPLICATION_ENABLEROOTCAS)!==!1&&s()}}function IH(e){let t=0;cu(r=>{r?.ca&&(Dc.add(r.ca),Dc.size!==t&&(t=Dc.size,e?.()))})}function Ere(e=!0){NH=e}function hre(e){NH||(ut(),la=e.databases,ta(e,(t,r)=>{if(!t){let n=e.databaseSubscriptions||Cc;for(let[s,i]of af){let o=i.get(r);o&&(o.subscribe([],!1),i.delete(r))}n.delete(r);return}for(let n in t){let s=t[n];CH(r,s,e),SH.get(s)?.forEach(i=>i(s))}}))}function CH(e,t,r){if(!t)return console.error(`Attempt to replicate non-existent table ${t.name} from database ${e}`);if(t.replicate===!1||t.sources?.some(s=>s.isReplicator))return;let n;t.sourcedFrom(class wH extends Lr{static{a(this,"Replicator")}static connection;static subscription;static async subscribe(){let i=r.databaseSubscriptions||Cc,o=i.get(e),c=o?.tableById||[];c[t.tableId]=t;let l=o?.ready;if(Tr.trace("Setting up replicator subscription to database",e),!o?.auditStore)return this.subscription=o=new Mn,i.set(e,o),o.tableById=c,o.auditStore=t.auditStore,o.dbisDB=t.dbisDB,o.databaseName=e,l&&l(o),o;this.subscription=o}static subscribeOnThisThread(i,o){return!0}static async load(i){if(i){let o=i.residencyId,c=i.residency||t.dbisDB.get([Symbol.for("residency_by_id"),o]);if(c){let l,u=new Set;do{let d;for(let E of c){let f=pre(E,wH.subscription,e);f?.isConnected&&!u.has(f)&&(!d||f.latency<d.latency)&&(d=f)}if(!d)throw l||new bH.ServerError("No connection to any other nodes are available",502);let _={requestId:dre++,table:t,entry:i,id:i.key};u.add(d);try{return await d.getRecord(_)}catch(E){if(d.isConnected)throw E;Tr.warn("Error in load from node",zp,E),l||(l=E)}}while(!0)}}}static isReplicator=!0},{intermediateSource:!0})}function DH(e,t,r,n,s){let i=af.get(e);i||af.set(e,i=new Map);let o=i.get(r);if(o)return o;if(t)return i.set(r,o=new Vp(e,t,r,n,s)),o.connect(),o.once("finished",()=>i.delete(r)),o}function pre(e,t,r){let n=gH.get(e)?.get(r);if(n)return n;let s=Sr().primaryStore.get(e);return s?.url&&(n=DH(s.url,t,r,e,s.authorization),gH.set(e,af.get(s.url))),n}async function cf(e,t,r){r||(r={}),r.serverName=e.name;let n=await Ky(e.url,r),s=Yp(n,{},{});return new Promise((i,o)=>{n.on("open",()=>{i(s.sendOperation(t))}),n.on("error",c=>{o(c)}),n.on("close",c=>{Tr.info("Sending operation connection to "+e.url+" closed",c)})}).finally(()=>{n.close()})}function du(e){try{OH.isMainThread&&Tr.trace("Subscribing on main thread (should not happen in multi-threaded instance)",e.nodes[0].url,e.database);let t=Cc.get(e.database);if(!t){let n;t=new Promise(s=>{Tr.info("Waiting for subscription to database "+e.database),n=s}),t.ready=n,Cc.set(e.database,t)}let r=DH(e.nodes[0].url,t,e.database,e.nodes[0].name,e.nodes[0].authorization);e.nodes[0].name===void 0?r.tentativeNode=e.nodes[0]:r.nodeName=e.nodes[0].name,r.subscribe(e.nodes.filter(n=>Q_(n,e.database)),e.replicateByDefault)}catch(t){Tr.error("Error in subscription to node",e.nodes[0]?.url,t)}}async function Bp({name:e,url:t,database:r}){Tr.trace("Unsubscribing from node",e,t,r,"nodes",Array.from(Sr().primaryStore.getRange({})));let n=af.get(t);if(n){let s=n.get(r);s&&(s.unsubscribe(),n.delete(r))}}function mre(){if(Wy!==void 0)return Wy;let e=hs.default.get(Mc.CONFIG_PARAMS.OPERATIONSAPI_TLS_CERTIFICATE)||hs.default.get(Mc.CONFIG_PARAMS.TLS_CERTIFICATE);if(e)return Wy=new RH.X509Certificate((0,yH.readFileSync)(e)).subject.match(/CN=(.*)/)?.[1]??null}function ot(){return zp||(zp=hs.default.get("replication_hostname")??zs(hs.default.get("replication_url"))??mre()??AH("operationsapi_network_secureport")??AH("operationsapi_network_port")??"127.0.0.1")}function Sre(){zp=void 0}function AH(e){let t=hs.default.get(e),r=t?.lastIndexOf?.(":");if(r>0)return t.slice(0,r)}function jp(e){let t=hs.default.get(e),r=t?.lastIndexOf?.(":");return r>0?+t.slice(r+1).replace(/[\[\]]/g,""):+t}function Wp(e){return j_(e)?.[ot()]}function ra(){let e=hs.default.get("replication_url");return e||Jp(ot())}function Jp(e){let t=jp("replication_port");if(t)return`ws://${e}:${t}`;if(t=jp("replication_secureport"),t)return`wss://${e}:${t}`;if(t=jp("operationsapi_network_port"),t)return`ws://${e}:${t}`;if(t=jp("operationsapi_network_secureport"),t)return`wss://${e}:${t}`}function zs(e){if(e)return new URL(e).hostname}function ta(e,t){for(let n of Object.getOwnPropertyNames(We))r(n);return of(n=>{r(n)}),Lc((n,s)=>{r(n.databaseName)});function r(n){let s=We[n];Tr.trace("Checking replication status of ",n,e?.databases),e?.databases===void 0||e.databases==="*"||e.databases.includes(n)||e.databases.some?.(i=>i.name===n)||!s?t(s,n,!0):Tre(n)&&t(s,n,!1)}a(r,"forDatabase")}function Tre(e){let t=We[e];for(let r in t)if(t[r].replicate)return!0}function z_(e){for(let t of e.getKeys({limit:1,reverse:!0}))return t}async function gre(e){let t={message:""};if(e.replicated){e.replicated=!1,Tr.trace?.("Replicating operation",e.operation,"to nodes",it.nodes.map(n=>n.name));let r=await Promise.allSettled(it.nodes.map(n=>cf(n,e)));t.replicated=r.map((n,s)=>{let i=n.status==="rejected"?{status:"failed",reason:n.reason.toString()}:n.value;return i.node=it.nodes[s]?.name,i})}return t}var hs,Tr,RH,yH,Mc,Qp,bH,OH,NH,dre,_re,Dc,la,af,gH,Wy,zp,us=Ie(()=>{Pe();Vs();Ll();TH();qr();hs=L(se()),Tr=L(W()),RH=require("crypto"),yH=require("fs");X_();lu();Mc=L(M());_y();Qp=L(require("node:tls")),bH=L(_e()),OH=require("worker_threads"),dre=1,_re=[],Dc=hs.default.get(Mc.CONFIG_PARAMS.REPLICATION_ENABLEROOTCAS)!==!1?new Set(Qp.rootCertificates):new Set;a(fre,"start");a(IH,"monitorNodeCAs");a(Ere,"disableReplication");a(hre,"assignReplicationSource");a(CH,"setReplicator");af=new Map;a(DH,"getConnection");gH=new Map;a(pre,"getConnectionByName");a(cf,"sendOperationToNode");a(du,"subscribeToNode");a(Bp,"unsubscribeFromNode");a(mre,"getCommonNameFromCert");a(ot,"getThisNodeName");a(Sre,"clearThisNodeName");Object.defineProperty(it,"hostname",{get(){return ot()}});a(AH,"getHostFromListeningPort");a(jp,"getPortFromListeningPort");a(Wp,"getThisNodeId");it.replication={getThisNodeId:Wp,exportIdMapping:j_};a(ra,"getThisNodeUrl");a(Jp,"hostnameToUrl");a(zs,"urlToNodeName");a(ta,"forEachReplicatedDatabase");a(Tre,"hasExplicitlyReplicatedTable");a(z_,"lastTimeInAuditStore");a(gre,"replicateOperation")});var tm=N((EIe,vH)=>{"use strict";var Su=Uh(),Tu=o0(),Are=W(),Rre=require("uuid").v4,fIe=require("clone"),Zp=no(),gu=M(),yre=require("util"),ua=Bn(),{handleHDBError:mn,hdb_errors:bre}=_e(),{HDB_ERROR_MSGS:Xp,HTTP_STATUS_CODES:Sn}=bre,{SchemaEventMsg:em}=qs(),PH=mr(),{getDatabases:Ore}=(Pe(),oe(lt)),{transformReq:Au}=te(),{replicateOperation:LH}=(us(),oe(ca));vH.exports={createSchema:Nre,createSchemaStructure:MH,createTable:Ire,createTableStructure:UH,createAttribute:Lre,dropSchema:wre,dropTable:Cre,dropAttribute:Dre,getBackup:Mre};async function Nre(e){let t=await MH(e);return Zp.signalSchemaChange(new em(process.pid,e.operation,e.schema)),t}a(Nre,"createSchema");async function MH(e){let t=Su.schema_object(e);if(t)throw mn(t,t.message,Sn.BAD_REQUEST,void 0,void 0,!0);if(Au(e),!await Tu.checkSchemaExists(e.schema))throw mn(new Error,Xp.SCHEMA_EXISTS_ERR(e.schema),Sn.BAD_REQUEST,gu.LOG_LEVELS.ERROR,Xp.SCHEMA_EXISTS_ERR(e.schema),!0);return await ua.createSchema(e),`database '${e.schema}' successfully created`}a(MH,"createSchemaStructure");async function Ire(e){return Au(e),e.hash_attribute=e.primary_key??e.hash_attribute,await UH(e)}a(Ire,"createTable");async function UH(e){let t=Su.create_table_object(e);if(t)throw mn(t,t.message,Sn.BAD_REQUEST,void 0,void 0,!0);if(Su.validateTableResidence(e.residence),!await Tu.checkSchemaTableExists(e.schema,e.table))throw mn(new Error,Xp.TABLE_EXISTS_ERR(e.schema,e.table),Sn.BAD_REQUEST,gu.LOG_LEVELS.ERROR,Xp.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:Rre(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await ua.createTable(n,e);else throw mn(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",Sn.BAD_REQUEST);else await ua.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}a(UH,"createTableStructure");async function wre(e){let t=!e.schema&&!e.database?new Error("database is required"):void 0,r=Su.schema_object(e),n=t??r;if(n)throw mn(n,n.message,Sn.BAD_REQUEST,void 0,void 0,!0);Au(e);let s=await Tu.checkSchemaExists(e.schema);if(s)throw mn(new Error,s,Sn.NOT_FOUND,gu.LOG_LEVELS.ERROR,s,!0);let i=await Tu.schema_describe.describeSchema({schema:e.schema}),o=Object.keys(global.hdb_schema[e.schema]);await ua.dropSchema(e),Zp.signalSchemaChange(new em(process.pid,e.operation,e.schema)),await PH.purgeSchemaTableStreams(e.schema,o);let c=await LH(e);return c.message=`successfully deleted '${e.schema}'`,c}a(wre,"dropSchema");async function Cre(e){let t=Su.table_object(e);if(t)throw mn(t,t.message,Sn.BAD_REQUEST,void 0,void 0,!0);Au(e);let r=await Tu.checkSchemaTableExists(e.schema,e.table);if(r)throw mn(new Error,r,Sn.NOT_FOUND,gu.LOG_LEVELS.ERROR,r,!0);await ua.dropTable(e),await PH.purgeTableStream(e.schema,e.table);let n=await LH(e);return n.message=`successfully deleted table '${e.schema}.${e.table}'`,n}a(Cre,"dropTable");async function Dre(e){let t=Su.attribute_object(e);if(t)throw mn(t,t.message,Sn.BAD_REQUEST,void 0,void 0,!0);Au(e);let r=await Tu.checkSchemaTableExists(e.schema,e.table);if(r)throw mn(new Error,r,Sn.NOT_FOUND,gu.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw mn(new Error,"You cannot drop a hash attribute",Sn.BAD_REQUEST,void 0,void 0,!0);if(gu.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw mn(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,Sn.BAD_REQUEST,void 0,void 0,!0);try{return await ua.dropAttribute(e),Pre(e),Zp.signalSchemaChange(new em(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw Are.error(`Got an error deleting attribute ${yre.inspect(e)}.`),n}}a(Dre,"dropAttribute");function Pre(e){let t=Object.values(global.hdb_schema[e.schema][e.table].attributes);for(let r=0;r<t.length;r++)t[r].attribute===e.attribute&&global.hdb_schema[e.schema][e.table].attributes.splice(r,1)}a(Pre,"dropAttributeFromGlobal");async function Lre(e){Au(e);let t=Ore()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw mn(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,Sn.BAD_REQUEST,void 0,void 0,!0);return await ua.createAttribute(e),Zp.signalSchemaChange(new em(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}a(Lre,"createAttribute");function Mre(e){return ua.getBackup(e)}a(Mre,"getBackup")});var HH=N((pIe,BH)=>{"use strict";var{OPERATIONS_ENUM:Ure}=M(),jy=class{static{a(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=Ure.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};BH.exports=jy});var zy=N((TIe,qH)=>{"use strict";var vre=Bn(),SIe=HH(),rm=te(),nm=M(),Bre=se(),{handleHDBError:xH,hdb_errors:Hre}=_e(),{HDB_ERROR_MSGS:kH,HTTP_STATUS_CODES:FH}=Hre,xre=Object.values(nm.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),GH="To use this operation audit log must be enabled in harperdb-config.yaml";qH.exports=kre;async function kre(e){if(rm.isEmpty(e.schema))throw new Error(kH.SCHEMA_REQUIRED_ERR);if(rm.isEmpty(e.table))throw new Error(kH.TABLE_REQUIRED_ERR);if(!Bre.get(nm.CONFIG_PARAMS.LOGGING_AUDITLOG))throw xH(new Error,GH,FH.BAD_REQUEST,nm.LOG_LEVELS.ERROR,GH,!0);let t=rm.checkSchemaTableExist(e.schema,e.table);if(t)throw xH(new Error,t,FH.NOT_FOUND,nm.LOG_LEVELS.ERROR,t,!0);if(!rm.isEmpty(e.search_type)&&xre.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await vre.readAuditLog(e)}a(kre,"readAuditLog")});var VH=N((AIe,$H)=>{"use strict";var{OPERATIONS_ENUM:Fre}=M(),Qy=class{static{a(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=Fre.GET_BACKUP,this.schema=t,this.table=r}};$H.exports=Qy});var WH=N((OIe,YH)=>{"use strict";var Gre=Bn(),yIe=VH(),Jy=te(),qre=M(),bIe=se(),{handleHDBError:$re,hdb_errors:Vre}=_e(),{HDB_ERROR_MSGS:KH,HTTP_STATUS_CODES:Kre}=Vre;YH.exports=Yre;async function Yre(e){if(Jy.isEmpty(e.schema))throw new Error(KH.SCHEMA_REQUIRED_ERR);if(Jy.isEmpty(e.table))throw new Error(KH.TABLE_REQUIRED_ERR);let t=Jy.checkSchemaTableExist(e.schema,e.table);if(t)throw $re(new Error,t,Kre.NOT_FOUND,qre.LOG_LEVELS.ERROR,t,!0);return await Gre.getBackup(read_audit_log_object)}a(Yre,"getBackup")});var ZH=N((IIe,XH)=>{var Ru=require("validate.js"),zH=Tt(),yu=M(),{handleHDBError:Wre,hdb_errors:jre}=_e(),{HDB_ERROR_MSGS:Qt,HTTP_STATUS_CODES:zre}=jre,Xy=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),Qre={STRUCTURE_USER:"structure_user"},jH=Object.values(yu.ROLE_TYPES_ENUM),Jre="attribute_permissions",Xre="attribute_name",{PERMS_CRUD_ENUM:bu}=yu,Zre=[Jre,...Object.values(bu)],QH=[bu.READ,bu.INSERT,bu.UPDATE],ene=[Xre,...QH];function tne(e){let t=Xy();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,JH(e,t)}a(tne,"addRoleValidation");function rne(e){let t=Xy();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,JH(e,t)}a(rne,"alterRoleValidation");function nne(e){let t=Xy();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,zH.validateObject(e,t)}a(nne,"dropRoleValidation");var sne=["operation","role","id","permission","hdb_user","hdb_auth_header","access"];function JH(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)sne.includes(n[o])||s.push(n[o]);s.length>0&&ir(Qt.INVALID_ROLE_JSON_KEYS(s),r);let i=zH.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{ir(o,r)}),e.permission){let o=ine(e);o&&ir(o,r),jH.forEach(c=>{e.permission[c]&&!Ru.isBoolean(e.permission[c])&&ir(Qt.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(jH.indexOf(o)<0){if(o===Qre.STRUCTURE_USER){let l=e.permission[o];if(typeof l=="boolean")continue;if(Array.isArray(l)){for(let u=0,d=l.length;u<d;u++){let _=l[u];global.hdb_schema[_]||ir(Qt.SCHEMA_NOT_FOUND(_),r)}continue}ir(Qt.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){ir(Qt.SCHEMA_NOT_FOUND(o),r);continue}if(c.tables)for(let l in c.tables){let u=c.tables[l];if(!l||!global.hdb_schema[o][l]){ir(Qt.TABLE_NOT_FOUND(o,l),r);continue}if(Object.keys(u).forEach(d=>{Zre.includes(d)||ir(Qt.INVALID_PERM_KEY(d),r,o,l)}),Object.values(bu).forEach(d=>{Ru.isDefined(u[d])?Ru.isBoolean(u[d])||ir(Qt.TABLE_PERM_NOT_BOOLEAN(d),r,o,l):ir(Qt.TABLE_PERM_MISSING(d),r,o,l)}),u.attribute_permissions===void 0){ir(Qt.ATTR_PERMS_ARRAY_MISSING,r,o,l);continue}else if(!(Array.isArray(u.attribute_permissions)||u.attribute_permissions===null)){ir(Qt.ATTR_PERMS_NOT_ARRAY,r,o,l);continue}if(u.attribute_permissions){let d=global.hdb_schema[o][l].attributes.map(({attribute:E})=>E),_={read:!1,insert:!1,update:!1};for(let E in u.attribute_permissions){let f=u.attribute_permissions[E];if(Object.keys(f).forEach(T=>{!ene.includes(T)&&T!==bu.DELETE&&ir(Qt.INVALID_ATTR_PERM_KEY(T),r,o,l)}),!Ru.isDefined(f.attribute_name)){ir(Qt.ATTR_PERM_MISSING_NAME,r,o,l);continue}let h=f.attribute_name;if(!d.includes(h)){ir(Qt.INVALID_ATTRIBUTE_IN_PERMS(h),r,o,l);continue}QH.forEach(T=>{Ru.isDefined(f[T])?Ru.isBoolean(f[T])||ir(Qt.ATTR_PERM_NOT_BOOLEAN(T,h),r,o,l):ir(Qt.ATTR_PERM_MISSING(T,h),r,o,l)}),!_.read&&f.read===!0&&(_.read=!0),!_.insert&&f.insert===!0&&(_.insert=!0),!_.update&&f.update===!0&&(_.update=!0)}if(u.read===!1&&_.read===!0||u.insert===!1&&_.insert===!0||u.update===!1&&_.update===!0){let E=`${o}.${l}`;ir(Qt.MISMATCHED_TABLE_ATTR_PERMS(E),r,o,l)}}}}return one(r)}a(JH,"customValidate");XH.exports={addRoleValidation:tne,alterRoleValidation:rne,dropRoleValidation:nne};function ine(e){let{operation:t,permission:r}=e;if(t===yu.OPERATIONS_ENUM.ADD_ROLE||t===yu.OPERATIONS_ENUM.ALTER_ROLE){let n=r.super_user===!0,s=r.cluster_user===!0;if(Object.keys(r).length>1&&(n||s)){if(s&&n)return Qt.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?yu.ROLE_TYPES_ENUM.SUPER_USER:yu.ROLE_TYPES_ENUM.CLUSTER_USER;return Qt.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(ine,"validateNoSUPerms");function one(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:Qt.ROLE_PERMS_ERROR,...e};return Wre(new Error,n,zre.BAD_REQUEST)}else return null}a(one,"generateRolePermResponse");function ir(e,t,r,n){if(!r)t.main_permissions.push(e);else{let s=n?r+"_"+n:r;t.schema_permissions[s]?t.schema_permissions[s].push(e):t.schema_permissions[s]=[e]}}a(ir,"addPermError")});var uf=N((DIe,nx)=>{"use strict";var ex=un(),tx=Vr(),ane=dc(),eb=ZH(),tb=no(),CIe=require("uuid").v4,cne=require("util"),sm=M(),lne=te(),rb=tx.searchByValue,une=tx.searchByHash,dne=cne.promisify(ane.delete),_ne=$s(),fne=jl(),{hdb_errors:Ene,handleHDBError:Uc}=_e(),{HDB_ERROR_MSGS:rx,HTTP_STATUS_CODES:lf}=Ene,{UserEventMsg:nb}=qs();nx.exports={addRole:hne,alterRole:pne,dropRole:mne,listRoles:Sne};function Zy(e){try{e.hdb_auth_header&&delete e.hdb_auth_header,e.HDB_INTERNAL_PATH&&delete e.HDB_INTERNAL_PATH,e.operation&&delete e.operation,e.hdb_user&&delete e.hdb_user}catch{}return e}a(Zy,"scrubRoleDetails");async function hne(e){let t=eb.addRoleValidation(e);if(t)throw t;e=Zy(e);let r={schema:"system",table:"hdb_role",search_attribute:"role",search_value:e.role,hash_attribute:"id",get_attributes:["*"]},n;try{n=Array.from(await rb(r)||[])}catch(i){throw Uc(i)}if(n&&n.length>0)throw Uc(new Error,rx.ROLE_ALREADY_EXISTS(e.role),lf.CONFLICT,void 0,void 0,!0);e.id||(e.id=e.role);let s={operation:"insert",schema:"system",table:"hdb_role",hash_attribute:"id",records:[e]};return await ex.insert(s),tb.signalUserChange(new nb(process.pid)),e=Zy(e),e}a(hne,"addRole");async function pne(e){let t=eb.alterRoleValidation(e);if(t)throw t;e=Zy(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await ex.update(r)}catch(s){throw Uc(s)}if(n&&n?.message==="updated 0 of 1 records")throw Uc(new Error,"Invalid role id",lf.BAD_REQUEST,void 0,void 0,!0);return await tb.signalUserChange(new nb(process.pid)),e}a(pne,"alterRole");async function mne(e){let t=eb.dropRoleValidation(e);if(t)throw Uc(new Error,t,lf.BAD_REQUEST,void 0,void 0,!0);let r=new fne(sm.SYSTEM_SCHEMA_NAME,sm.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await une(r));if(n.length===0)throw Uc(new Error,rx.ROLE_NOT_FOUND,lf.NOT_FOUND,void 0,void 0,!0);let s=new _ne(sm.SYSTEM_SCHEMA_NAME,sm.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await rb(s)),o=!1;if(lne.isEmptyOrZeroLength(i)===!1){for(let l=0;l<i.length;l++)if(i[l].active===!0){o=!0;break}}if(o===!0)throw Uc(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,lf.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await dne(c),tb.signalUserChange(new nb(process.pid)),`${n[0].role} successfully deleted`}a(mne,"dropRole");async function Sne(){return rb({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(Sne,"listRoles")});var ax=N((LIe,ox)=>{"use strict";var Tne=se(),da=require("joi"),gne=Tt(),sx=require("moment"),Ane=require("fs-extra"),sb=require("path"),Rne=require("lodash"),df=M(),{LOG_LEVELS:vc}=M(),yne="YYYY-MM-DD hh:mm:ss",bne=sb.resolve(__dirname,"../logs");ox.exports=function(e){return gne.validateBySchema(e,One)};var One=da.object({from:da.custom(ix),until:da.custom(ix),level:da.valid(vc.NOTIFY,vc.FATAL,vc.ERROR,vc.WARN,vc.INFO,vc.DEBUG,vc.TRACE),order:da.valid("asc","desc"),limit:da.number().min(1),start:da.number().min(0),log_name:da.custom(Nne)});function ix(e,t){if(sx(e,sx.ISO_8601).format(yne)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(ix,"validateDatetime");function Nne(e,t){if(Rne.invert(df.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=Tne.get(df.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?df.LOG_NAMES.HDB:e,i=s===df.LOG_NAMES.INSTALL?sb.join(bne,df.LOG_NAMES.INSTALL):sb.join(n,s);return Ane.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(Nne,"validateReadLogPath")});var ob=N((UIe,lx)=>{"use strict";var im=M(),Ine=W(),wne=se(),Cne=ax(),ib=require("path"),cx=require("fs-extra"),{once:Dne}=require("events"),{handleHDBError:Pne,hdb_errors:Lne}=_e(),{PACKAGE_ROOT:Mne}=M(),Une=ib.join(Mne,"logs"),vne=1e3,Bne=200;lx.exports=Hne;async function Hne(e){let t=Cne(e);if(t)throw Pne(t,t.message,Lne.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=wne.get(im.HDB_SETTINGS_NAMES.LOG_PATH_KEY),n=e.log_name===void 0?im.LOG_NAMES.HDB:e.log_name,s=n===im.LOG_NAMES.INSTALL?ib.join(Une,im.LOG_NAMES.INSTALL):ib.join(r,n),i=e.level!==void 0,o=i?e.level:void 0,c=e.from!==void 0,l=c?new Date(e.from):void 0,u=e.until!==void 0,d=u?new Date(e.until):void 0,_=e.limit===void 0?vne:e.limit,E=e.order===void 0?void 0:e.order,f=e.start===void 0?0:e.start,h=f+_,T=0;E==="desc"&&!l&&!d&&(T=Math.max(cx.statSync(s).size-(h+5)*Bne,0));let m=cx.createReadStream(s,{start:T});m.on("error",H=>{Ine.error(H)});let g=0,S=[],y="",I;m.on("data",H=>{let X=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;H=y+H;let Y=0,V;for(;(V=X.exec(H))&&!m.destroyed;){I&&(I.message=H.slice(Y,V.index),U(I));let[ne,Q,de]=V,j=de.split("] ["),ae=j[0],Oe=j[1];j.splice(0,2),I={timestamp:Q,thread:ae,level:Oe,tags:j,message:""},Y=V.index+ne.length}y=H.slice(Y)}),m.on("end",H=>{m.destroyed||I&&(I.message=y.trim(),U(I))}),m.resume();function U(H){let X,Y,V;switch(!0){case(i&&c&&u):X=new Date(H.timestamp),Y=new Date(l),V=new Date(d),H.level===o&&X>=Y&&X<=V&&g<f?g++:H.level===o&&X>=Y&&X<=V&&(_a(H,E,S),g++,g===h&&m.destroy());break;case(i&&c):X=new Date(H.timestamp),Y=new Date(l),H.level===o&&X>=Y&&g<f?g++:H.level===o&&X>=Y&&(_a(H,E,S),g++,g===h&&m.destroy());break;case(i&&u):X=new Date(H.timestamp),V=new Date(d),H.level===o&&X<=V&&g<f?g++:H.level===o&&X<=V&&(_a(H,E,S),g++,g===h&&m.destroy());break;case(c&&u):X=new Date(H.timestamp),Y=new Date(l),V=new Date(d),X>=Y&&X<=V&&g<f?g++:X>=Y&&X<=V&&(_a(H,E,S),g++,g===h&&m.destroy());break;case i:H.level===o&&g<f?g++:H.level===o&&(_a(H,E,S),g++,g===h&&m.destroy());break;case c:X=new Date(H.timestamp),Y=new Date(l),X>=Y&&g<f?g++:X>=Y&&g>=f&&(_a(H,E,S),g++,g===h&&m.destroy());break;case u:X=new Date(H.timestamp),V=new Date(d),X<=V&&g<f?g++:X<=V&&g>=f&&(_a(H,E,S),g++,g===h&&m.destroy());break;default:g<f?g++:(_a(H,E,S),g++,g===h&&m.destroy())}}return a(U,"onLogMessage"),await Dne(m,"close"),S}a(Hne,"readLog");function _a(e,t,r){t==="desc"?xne(e,r):t==="asc"?kne(e,r):r.push(e)}a(_a,"pushLineToResult");function xne(e,t){let r=new Date(e.timestamp),n=0,s=t.length;for(;n<s;){let i=n+s>>>1;new Date(t[i].timestamp)>r?n=i+1:s=i}t.splice(n,0,e)}a(xne,"insertDescending");function kne(e,t){let r=new Date(e.timestamp),n=0,s=t.length;for(;n<s;){let i=n+s>>>1;new Date(t[i].timestamp)<r?n=i+1:s=i}t.splice(n,0,e)}a(kne,"insertAscending")});var om=N((FIe,fx)=>{"use strict";var ab=require("joi"),{string:Ou,boolean:ux,date:Fne}=ab.types(),Gne=Tt(),{validateSchemaExists:BIe,validateTableExists:HIe,validateSchemaName:xIe}=Ti(),qne=M(),$ne=Ct(),dx=se();dx.initSync();var kIe=Ou.invalid(dx.get(qne.CONFIG_PARAMS.CLUSTERING_NODENAME)??"node_name").pattern($ne.NATS_TERM_CONSTRAINTS_RX).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >","any.invalid":"'node_name' cannot be this nodes name"}).empty(null),_x={operation:Ou.valid("add_node","update_node","set_node_replication"),node_name:Ou.optional(),subscriptions:ab.array().items({table:Ou.optional(),schema:Ou.optional(),database:Ou.optional(),subscribe:ux.required(),publish:ux.required().custom(Kne),start_time:Fne.iso()})};function Vne(e){return Gne.validateBySchema(e,ab.object(_x))}a(Vne,"addUpdateNodeValidator");function Kne(e,t){if(t.state.ancestors[2].operation==="add_node"&&e===!1&&t.state.ancestors[0].subscribe===!1)return t.message(`'subscriptions[${t.state.path[1]}]' subscribe and/or publish must be set to true when adding a node`)}a(Kne,"checkForFalsy");fx.exports={addUpdateNodeValidator:Vne,validation_schema:_x}});var hx=N((qIe,Ex)=>{var Yne=Tt(),Wne={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};Ex.exports=function(e){return Yne.validateObject(e,Wne)}});var cb=N((VIe,Sx)=>{"use strict";var jne=hx(),Nu=require("passport"),zne=require("passport-local").Strategy,Qne=require("passport-http").BasicStrategy,Jne=require("util"),Xne=xn(),mx=Jne.callbackify(Xne.findAndValidateUser),$Ie=Dn(),Zne=M(),px=fu();Nu.use(new zne(function(e,t,r){mx(e,t,r)}));Nu.use(new Qne(function(e,t,r){mx(e,t,r)}));Nu.serializeUser(function(e,t){t(null,e)});Nu.deserializeUser(function(e,t){t(null,e)});function ese(e,t,r){if(e.raw?.user!==void 0)return r(null,e.raw.user);let n,s;if(e.headers?.authorization){let o=e.headers.authorization.split(" ");n=o[0],s=o[1]}function i(o,c){return o?r(o):c?r(null,c):r("Must login")}switch(a(i,"handleResponse"),n){case"Basic":Nu.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===Zne.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?px.validateRefreshToken(s).then(o=>{e.body.refresh_token=s,r(null,o)}).catch(o=>{r(o)}):px.validateOperationToken(s).then(o=>{r(null,o)}).catch(o=>{r(o)});break;default:Nu.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(ese,"authorize");function tse(e,t){let r=jne(e);if(r){t(r);return}let n={authorized:!0,messages:[]},s=e.user.role;if(!s?.permission)return t("Invalid role");let i=JSON.parse(s.permission);if(i.super_user)return t(null,n);if(!i[e.schema])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.schema} schema`),t(null,n);if(!i[e.schema].tables[e.table])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.table} table`),t(null,n);if(!i[e.schema].tables[e.table][e.operation])return n.authorized=!1,n.messages.push(`Not authorized to access ${e.operation} on ${e.table} table`),t(null,n);if(i[e.schema].tables[e.table].attribute_permissions&&!e.attributes)return n.authorized=!1,n.messages.push(`${e.schema}.${e.table} has attribute permissions. Missing attributes to validate`),t(null,n);if(i[e.schema].tables[e.table].attribute_permissions&&e.attributes){let o=i[e.schema].tables[e.table].attribute_permissions;for(let c in o)e.attributes.indexOf(o[c].attribute_name)>-1&&!o[c][e.operation]&&(n.authorized=!1,n.messages.push(`Not authorized to ${e.operation} ${o[c].attribute_name} `))}return t(null,n)}a(tse,"checkPermissions");Sx.exports={authorize:ese,checkPermissions:tse}});var Iu=N((YIe,Tx)=>{"use strict";var lb=class{static{a(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},ub=class{static{a(this,"NodeSubscription")}constructor(t,r,n,s){this.schema=t,this.table=r,this.publish=n,this.subscribe=s}};Tx.exports={Node:lb,NodeSubscription:ub}});var Ax=N((jIe,gx)=>{"use strict";var rse=M().OPERATIONS_ENUM,db=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=rse.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};gx.exports=db});var _f=N((QIe,Rx)=>{"use strict";var _b=class{static{a(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},fb=class{static{a(this,"RemotePayloadSubscription")}constructor(t,r,n,s,i,o,c){this.schema=t,this.table=r,this.hash_attribute=n,this.publish=s,this.subscribe=i,this.start_time=o,c!==void 0&&(this.attributes=c)}};Rx.exports={RemotePayloadObject:_b,RemotePayloadSubscription:fb}});var bx=N((XIe,yx)=>{"use strict";var Eb=class{static{a(this,"TableSizeObject")}constructor(t,r,n=0,s=0,i=0,o=0){this.schema=t,this.table=r,this.table_size=n,this.record_count=s,this.transaction_log_size=i,this.transaction_log_record_count=o}};yx.exports=Eb});var Nx=N((swe,Ox)=>{"use strict";var nse=bx(),ewe=Ht(),twe=ht(),sse=W(),{getSchemaPath:rwe,getTransactionAuditStorePath:nwe}=gt(),{getDatabases:ise}=(Pe(),oe(lt));Ox.exports=ose;async function ose(e){let t=new nse;try{let r=ise()[e.schema]?.[e.name],n=r.primaryStore.getStats(),s=r.auditStore?.getStats();t.schema=e.schema,t.table=e.name,t.record_count=n.entryCount,t.transaction_log_record_count=s.entryCount}catch(r){sse.warn(`unable to stat table dbi due to ${r}`)}return t}a(ose,"lmdbGetTableSize")});var wx=N((owe,Ix)=>{"use strict";var hb=class{static{a(this,"SystemInformationObject")}constructor(t,r,n,s,i,o,c){this.system=t,this.time=r,this.cpu=n,this.memory=s,this.disk=i,this.network=o,this.harperdb_processes=c}};Ix.exports=hb});var Cu=N((_we,Lx)=>{"use strict";var ase=require("fs-extra"),cse=require("path"),Qr=require("systeminformation"),fa=W(),Cx=mr(),cwe=Ct(),wu=M(),lse=Nx(),use=ro(),{getThreadInfo:Dx}=dt(),ff=se();ff.initSync();var dse=wx(),{openEnvironment:lwe}=ht(),{getSchemaPath:uwe}=gt(),{database:dwe,databases:pb}=(Pe(),oe(lt)),am;Lx.exports={getHDBProcessInfo:gb,getNetworkInfo:Rb,getDiskInfo:Ab,getMemoryInfo:Tb,getCPUInfo:Sb,getTimeInfo:mb,getSystemInformation:yb,systemInformation:_se,getTableSize:bb,getMetrics:Ob};function mb(){return Qr.time()}a(mb,"getTimeInfo");async function Sb(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:o,governor:c,socket:l,cache:u,...d}=await Qr.cpu();d.cpu_speed=await Qr.cpuCurrentSpeed();let{raw_currentload:_,raw_currentload_idle:E,raw_currentload_irq:f,raw_currentload_nice:h,raw_currentload_system:T,raw_currentload_user:m,cpus:g,...S}=await Qr.currentLoad();return S.cpus=[],g.forEach(y=>{let{raw_load:I,raw_load_idle:U,raw_load_irq:H,raw_load_nice:X,raw_load_system:Y,raw_load_user:V,...ne}=y;S.cpus.push(ne)}),d.current_load=S,d}catch(e){return fa.error(`error in getCPUInfo: ${e}`),{}}}a(Sb,"getCPUInfo");async function Tb(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await Qr.mem();return Object.assign(s,process.memoryUsage())}catch(e){return fa.error(`error in getMemoryInfo: ${e}`),{}}}a(Tb,"getMemoryInfo");async function gb(){let e={core:[],clustering:[]};try{let t=await Qr.processes(),r;try{r=Number.parseInt(await ase.readFile(cse.join(ff.get(wu.CONFIG_PARAMS.ROOTPATH),wu.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===wu.NODE_ERROR_CODES.ENOENT)fa.warn("Unable to locate 'hdb.pid' file, try stopping and starting HarperDB. This could be because HarperDB is not running.");else throw n}t.list.forEach(n=>{n.pid===r?e.core.push(n):n.name==="nats-server"&&e.clustering.push(n)});for(let n of e.core)for(let s of t.list)s.pid===n.parentPid&&(s.name==="PM2"||s.command==="PM2")&&(n.parent="PM2");return e}catch(t){return fa.error(`error in getHDBProcessInfo: ${t}`),e}}a(gb,"getHDBProcessInfo");async function Ab(){let e={};try{if(!ff.get(wu.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_DISK))return e;let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await Qr.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:l,...u}=await Qr.fsStats();return e.read_write=u,e.size=await Qr.fsSize(),e}catch(t){return fa.error(`error in getDiskInfo: ${t}`),e}}a(Ab,"getDiskInfo");async function Rb(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return ff.get(wu.CONFIG_PARAMS.OPERATIONSAPI_SYSINFO_NETWORK)&&(e.default_interface=await Qr.networkInterfaceDefault(),e.latency=await Qr.inetChecksite("google.com"),(await Qr.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:o,dhcp:c,dnsSuffix:l,ieee8021xAuth:u,ieee8021xState:d,carrier_changes:_,...E}=n;e.interfaces.push(E)}),(await Qr.networkStats()).forEach(n=>{let{rx_sec:s,tx_sec:i,ms:o,...c}=n;e.stats.push(c)})),e}catch(t){return fa.error(`error in getNetworkInfo: ${t}`),e}}a(Rb,"getNetworkInfo");async function yb(){if(am!==void 0)return am;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:o,...c}=await Qr.osInfo();e=c;let l=await Qr.versions("node, npm");return e.node_version=l.node,e.npm_version=l.npm,am=e,am}catch(t){return fa.error(`error in getSystemInformation: ${t}`),e}}a(yb,"getSystemInformation");async function bb(){let e=[],t=await use.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await lse(n));return e}a(bb,"getTableSize");async function Ob(){let e={};for(let t in pb){let r=e[t]={},n=r.tables={};for(let s in pb[t])try{let i=pb[t][s];if(!r.readers&&(Object.assign(r,i.primaryStore.rootStore.getStats()),delete r.root,r.readers=i.primaryStore.rootStore.readerList().split(/\n\s+/).slice(1).map(l=>{let[u,d,_]=l.trim().split(" ");return{pid:u,thread:d,txnid:_}}),i.auditStore)){let{treeDepth:l,treeBranchPageCount:u,treeLeafPageCount:d,entryCount:_,overflowPages:E}=i.auditStore.getStats();r.audit={treeDepth:l,treeBranchPageCount:u,treeLeafPageCount:d,entryCount:_,overflowPages:E}}let o=i.primaryStore.getStats(),c={};for(let l of["treeDepth","treeBranchPageCount","treeLeafPageCount","entryCount","overflowPages"])c[l]=o[l];n[s]=c}catch(i){fa.notify(`Error getting stats for table ${s}: ${i}`)}}return e}a(Ob,"getMetrics");async function Px(){if(ff.get(wu.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{jsm:e}=await Cx.getNATSReferences(),t=await Cx.listStreams(),r=[];for(let n of t){let s=[],i=await e.consumers.list(n.config.name);for await(let c of i)s.push({name:c.name,created:c.created,num_ack_pending:c.num_ack_pending,num_redelivered:c.num_redelivered,num_waiting:c.num_waiting,num_pending:c.num_pending});let o={stream_name:n.config.name,database:n.config.subjects[0].split(".")[1],table:n.config.subjects[0].split(".")[2],state:n.state,consumers:s};r.push(o)}return r}}a(Px,"getNatsStreamInfo");async function _se(e){let t=new dse;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await yb(),t.time=mb(),t.cpu=await Sb(),t.memory=await Tb(),t.disk=await Ab(),t.network=await Rb(),t.harperdb_processes=await gb(),t.table_size=await bb(),t.metrics=await Ob(),t.threads=await Dx(),t.replication=await Px(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await yb();break;case"time":t.time=mb();break;case"cpu":t.cpu=await Sb();break;case"memory":t.memory=await Tb();break;case"disk":t.disk=await Ab();break;case"network":t.network=await Rb();break;case"harperdb_processes":t.harperdb_processes=await gb();break;case"table_size":t.table_size=await bb();break;case"database_metrics":case"metrics":t.metrics=await Ob();break;case"threads":t.threads=await Dx();break;case"replication":t.replication=await Px();break;default:break}return t}a(_se,"systemInformation")});var Bc=N((Ewe,Mx)=>{"use strict";Mx.exports={version:fse,printVersion:Ese};var cm=Xl();function fse(){if(cm)return cm.version}a(fse,"version");function Ese(){cm&&console.log(`HarperDB Version ${cm.version}`)}a(Ese,"printVersion")});var Di=N((Swe,Hx)=>{"use strict";var hse=un(),Nb=te(),pse=require("util"),Hc=M(),Ux=se();Ux.initSync();var mse=cb(),vx=Vr(),{Node:pwe,NodeSubscription:mwe}=Iu(),Sse=jl(),Tse=Ax(),{RemotePayloadObject:gse,RemotePayloadSubscription:Ase}=_f(),{handleHDBError:Rse,hdb_errors:yse}=_e(),{HTTP_STATUS_CODES:bse,HDB_ERROR_MSGS:Ose}=yse,Nse=$s(),Ise=Cu(),wse=Bc(),{getDatabases:Cse}=(Pe(),oe(lt)),Dse=pse.promisify(mse.authorize),Pse=vx.searchByHash,Lse=vx.searchByValue;Hx.exports={authHeaderToUser:Mse,isEmpty:Use,getNodeRecord:vse,upsertNodeRecord:Bse,buildNodePayloads:Hse,checkClusteringEnabled:xse,getAllNodeRecords:kse,getSystemInfo:Fse,reverseSubscription:Bx};async function Mse(e){let t={headers:{authorization:e.hdb_auth_header}};return e.hdb_user=await Dse(t,null),e}a(Mse,"authHeaderToUser");function Use(e){return e==null}a(Use,"isEmpty");async function vse(e){let t=new Sse(Hc.SYSTEM_SCHEMA_NAME,Hc.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return Pse(t)}a(vse,"getNodeRecord");async function Bse(e){let t=new Tse(Hc.SYSTEM_SCHEMA_NAME,Hc.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return hse.upsert(t)}a(Bse,"upsertNodeRecord");function Bx(e){if(Nb.isEmpty(e.subscribe)||Nb.isEmpty(e.publish))throw new Error("Received invalid subscription object");let{schema:t,table:r,hash_attribute:n}=e,s={schema:t,table:r,hash_attribute:n};return e.subscribe===!0&&e.publish===!1?(s.subscribe=!1,s.publish=!0):e.subscribe===!1&&e.publish===!0?(s.subscribe=!0,s.publish=!1):(s.subscribe=e.subscribe,s.publish=e.publish),s}a(Bx,"reverseSubscription");function Hse(e,t,r,n){let s=[];for(let i=0,o=e.length;i<o;i++){let c=e[i],{schema:l,table:u}=c,d=Nb.getTableHashAttribute(l,u),{subscribe:_,publish:E}=Bx(c),f=Cse()[l]?.[u],h=new Ase(l,u,d,E,_,c.start_time,f.schemaDefined?f.attributes:void 0);s.push(h)}return new gse(r,t,s,n)}a(Hse,"buildNodePayloads");function xse(){if(!Ux.get(Hc.CONFIG_PARAMS.CLUSTERING_ENABLED))throw Rse(new Error,Ose.CLUSTERING_NOT_ENABLED,bse.BAD_REQUEST,void 0,void 0,!0)}a(xse,"checkClusteringEnabled");async function kse(){let e=new Nse(Hc.SYSTEM_SCHEMA_NAME,Hc.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await Lse(e))}a(kse,"getAllNodeRecords");async function Fse(){let e=await Ise.getSystemInformation();return{hdb_version:wse.version(),node_version:e.node_version,platform:e.platform}}a(Fse,"getSystemInfo")});var Ib=N((gwe,Kx)=>{"use strict";var lm=mr(),xx=te(),kx=Ct(),Fx=M(),um=W(),Gx=tm(),Gse=C_(),{RemotePayloadObject:qse}=_f(),{handleHDBError:qx,hdb_errors:$se}=_e(),{HTTP_STATUS_CODES:$x}=$se,{NodeSubscription:Vx}=Iu();Kx.exports=Vse;async function Vse(e,t){let r;try{r=await lm.request(`${t}.${kx.REQUEST_SUFFIX}`,new qse(Fx.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),um.trace("Response from remote describe all request:",r)}catch(o){um.error(`addNode received error from describe all request to remote node: ${o}`);let c=lm.requestErrorHandler(o,"add_node",t);throw qx(new Error,c,$x.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===kx.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let o=`Error returned from remote node ${t}: ${r.message}`;throw qx(new Error,o,$x.INTERNAL_SERVER_ERROR,"error",o)}let n=r.message,s=[],i=[];for(let o of e){let{table:c}=o,l=o.database??o.schema??"data";if(l===Fx.SYSTEM_SCHEMA_NAME){await lm.createLocalTableStream(l,c);let h=new Vx(l,c,o.publish,o.subscribe);h.start_time=o.start_time,i.push(h);continue}let u=xx.doesSchemaExist(l),d=n[l]!==void 0,_=c?xx.doesTableExist(l,c):!0,E=c?n?.[l]?.[c]!==void 0:!0;if(!u&&!d||!_&&!E){s.push(o);continue}if(!u&&d&&(um.trace(`addNode creating schema: ${l}`),await Gx.createSchema({operation:"create_schema",schema:l})),!_&&E){um.trace(`addNode creating table: ${c} in schema: ${l} with attributes ${JSON.stringify(n[l][c].attributes)}`);let h=new Gse(l,c,n[l][c].hash_attribute);n[l][c].attributes&&(h.attributes=n[l][c].attributes),await Gx.createTable(h)}await lm.createLocalTableStream(l,c);let f=new Vx(l,c,o.publish,o.subscribe);f.start_time=o.start_time,i.push(f)}return{added:i,skipped:s}}a(Vse,"reviewSubscriptions")});var xc={};je(xc,{addNodeBack:()=>zse,removeNodeBack:()=>Qse,setNode:()=>jse});async function jse(e){e.node_name&&!e.hostname&&(e.hostname=e.node_name),e.verify_tls!==void 0&&(e.rejectUnauthorized=e.verify_tls);let{url:t,hostname:r}=e;t?r||(r=e.hostname=zs(t)):t=Jp(r);let n=(0,Wx.validateBySchema)(e,Wse);if(n)throw(0,uo.handleHDBError)(n,n.message,Yse.BAD_REQUEST,void 0,void 0,!0);if(e.operation==="remove_node"){if(!t&&!r)throw new uo.ClientError("url or hostname is required for remove_node operation");let f=r,h=Sr(),T=await h.get(f);if(!T)throw new uo.ClientError(f+" does not exist");try{await cf({url:T.url},{operation:Ef.OPERATIONS_ENUM.REMOVE_NODE_BACK,name:T?.subscriptions?.length>0?ot():f},void 0)}catch(m){$n.warn(`Error removing node from target node ${f}, if it is offline and we be online in the future, you may need to clean up this node manually, or retry:`,m)}return await h.delete(f),`Successfully removed '${f}' from cluster`}if(!t)throw new uo.ClientError("url required for this operation");let s=ra();if(s==null)throw new uo.ClientError("replication url is missing from harperdb-config.yaml");let i,o,c;if(t?.startsWith("wss:")){i=await(0,ps.getReplicationCert)();let f=await(0,ps.getReplicationCertAuth)();if(!i)throw new Error("Unable to find a certificate to use for replication");i.options.is_self_signed?(o=await(0,ps.createCsr)(),$n.info("Sending CSR to target node:",t)):f&&(c=f.certificate,$n.info("Sending CA named",f.name,"to target node",t))}let l={operation:Ef.OPERATIONS_ENUM.ADD_NODE_BACK,hostname:(0,jx.get)(Ef.CONFIG_PARAMS.REPLICATION_HOSTNAME),target_hostname:r,url:s,csr:o,cert_auth:c,authorization:e.retain_authorization?e.authorization:null};if(e.subscriptions?l.subscriptions=e.subscriptions.map(Yx):l.subscriptions=null,e.hasOwnProperty("subscribe")||e.hasOwnProperty("publish")){let f=Yx(e);l.subscribe=f.subscribe,l.publish=f.publish}e?.authorization?.username&&e?.authorization?.password&&(e.authorization="Basic "+Buffer.from(e.authorization.username+":"+e.authorization.password).toString("base64"));let u,d;try{u=await cf({url:t},l,e)}catch(f){f.message=`Error returned from ${t}: `+f.message,$n.warn("Error adding node:",t,"to cluster:",f),d=f}if(o&&(!u?.certificate||!u?.certificate?.includes?.("BEGIN CERTIFICATE")))throw d?(d.message+=" and connection was required to sign certificate",d):new Error(`Unexpected certificate signature response from node ${t} response: ${JSON.stringify(u)}`);o&&($n.info("CSR response received from node:",t,"saving certificate and CA in hdb_certificate"),await(0,ps.setCertTable)({name:Kse.certificateFromPem(u.signingCA).issuer.getField("CN").value,certificate:u.signingCA,is_authority:!0}),u.certificate&&await(0,ps.setCertTable)({name:ot(),uses:["https","operations","wss"],certificate:u.certificate,private_key_name:i?.options?.key_file,is_authority:!1,is_self_signed:!1}),c=u.signingCA);let _={url:t,ca:u?.usingCA};if(e.hostname&&(_.name=e.hostname),e.subscriptions?_.subscriptions=e.subscriptions:_.replicates=!0,e.start_time&&(_.start_time=typeof e.start_time=="string"?new Date(e.start_time).getTime():e.start_time),e.retain_authorization&&(_.authorization=e.authorization),_.replicates){let f={url:s,ca:c,replicates:!0,subscriptions:null};e.retain_authorization&&(f.authorization=e.authorization),e.start_time&&(f.start_time=e.start_time),await co(ot(),f)}await co(u?u.nodeName:_.name??zs(t),_);let E;return e.operation==="update_node"?E=`Successfully updated '${t}'`:E=`Successfully added '${t}' to cluster`,d&&(E+=" but there was an error updating target node: "+d.message),E}async function zse(e){$n.trace("addNodeBack received request:",e);let t=await(0,ps.signCertificate)(e),r;e.csr?(r=t.signingCA,$n.info("addNodeBack received CSR from node:",e.url,"this node will use and respond with CA that was used to issue CSR")):(r=e?.cert_auth,$n.info("addNodeBack received CA from node:",e.url));let n={url:e.url,ca:r};e.subscriptions?n.subscriptions=e.subscriptions:(n.replicates=!0,n.subscriptions=null),e.start_time&&(n.start_time=e.start_time),e.authorization&&(n.authorization=e.authorization);let s=await(0,ps.getReplicationCertAuth)();if(n.replicates){let i={url:ra(),ca:s?.certificate,replicates:!0,subscriptions:null};e.start_time&&(i.start_time=e.start_time),e.authorization&&(i.authorization=e.authorization),await co(ot(),i)}return await co(e.hostname,n),t.nodeName=ot(),t.usingCA=s?.certificate,$n.info("addNodeBack responding to:",e.url,"with CA named:",s?.name),t}async function Qse(e){$n.trace("removeNodeBack received request:",e),await Sr().delete(e.name)}function Yx(e){let{subscribe:t,publish:r}=e;return{...e,subscribe:r,publish:t}}var ps,Wx,Du,jx,Ef,$n,uo,Kse,Yse,Wse,kc=Ie(()=>{ps=L(Xs()),Wx=L(Tt()),Du=L(require("joi")),jx=L(se()),Ef=L(M());X_();lu();us();$n=L(W()),uo=L(_e()),{pki:Kse}=require("node-forge"),{HTTP_STATUS_CODES:Yse}=uo.hdb_errors,Wse=Du.default.object({hostname:Du.default.string(),verify_tls:Du.default.boolean(),replicates:Du.default.boolean(),subscriptions:Du.default.array()});a(jse,"setNode");a(zse,"addNodeBack");a(Qse,"removeNodeBack");a(Yx,"reverseSubscription")});var mf=N((wwe,Qx)=>{"use strict";var{handleHDBError:dm,hdb_errors:Jse}=_e(),{HTTP_STATUS_CODES:_m}=Jse,{addUpdateNodeValidator:Xse}=om(),fm=W(),Em=M(),zx=Ct(),Zse=te(),hf=mr(),pf=Di(),wb=se(),eie=Ib(),{Node:tie,NodeSubscription:rie}=Iu(),{broadcast:nie}=dt(),{setNode:sie}=(kc(),oe(xc)),Nwe=se(),Iwe=M(),iie="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",oie="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",aie=wb.get(Em.CONFIG_PARAMS.CLUSTERING_NODENAME);Qx.exports=cie;async function cie(e,t=!1){if(fm.trace("addNode called with:",e),wb.get(Em.CONFIG_PARAMS.REPLICATION_URL)||wb.get(Em.CONFIG_PARAMS.REPLICATION_HOSTNAME))return sie(e);pf.checkClusteringEnabled();let r=Xse(e);if(r)throw dm(r,r.message,_m.BAD_REQUEST,void 0,void 0,!0);let n=e.node_name;if(!t){let _=await pf.getNodeRecord(n);if(!Zse.isEmptyOrZeroLength(_))throw dm(new Error,`Node '${n}' has already been added, perform update_node to proceed.`,_m.BAD_REQUEST,void 0,void 0,!0)}let{added:s,skipped:i}=await eie(e.subscriptions,n),o={message:void 0,added:s,skipped:i};if(s.length===0)return o.message=iie,o;let c=pf.buildNodePayloads(s,aie,Em.OPERATIONS_ENUM.ADD_NODE,await pf.getSystemInfo()),l=[];for(let _=0,E=s.length;_<E;_++){let f=s[_];s[_].start_time===void 0&&delete s[_].start_time,l.push(new rie(f.schema,f.table,f.publish,f.subscribe))}fm.trace("addNode sending remote payload:",c);let u;try{u=await hf.request(`${n}.${zx.REQUEST_SUFFIX}`,c)}catch(_){fm.error(`addNode received error from request: ${_}`);for(let f=0,h=s.length;f<h;f++){let T=s[f];T.publish=!1,T.subscribe=!1,await hf.updateRemoteConsumer(T,n)}let E=hf.requestErrorHandler(_,"add_node",n);throw dm(new Error,E,_m.INTERNAL_SERVER_ERROR,"error",E)}if(u.status===zx.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let _=`Error returned from remote node ${n}: ${u.message}`;throw dm(new Error,_,_m.INTERNAL_SERVER_ERROR,"error",_)}fm.trace(u);for(let _=0,E=s.length;_<E;_++){let f=s[_];await hf.updateRemoteConsumer(f,n),f.subscribe===!0&&await hf.updateConsumerIterator(f.schema,f.table,n,"start")}let d=new tie(n,l,u.system_info);return await pf.upsertNodeRecord(d),nie({type:"nats_update"}),i.length>0?o.message=oie:o.message=`Successfully added '${n}' to manifest`,o}a(cie,"addNode")});var Lb=N((Pwe,Xx)=>{"use strict";var{handleHDBError:Cb,hdb_errors:lie}=_e(),{HTTP_STATUS_CODES:Db}=lie,{addUpdateNodeValidator:uie}=om(),Sf=W(),hm=M(),Jx=Ct(),Dwe=te(),Tf=mr(),gf=Di(),Pb=se(),{cloneDeep:die}=require("lodash"),_ie=Ib(),{Node:fie,NodeSubscription:Eie}=Iu(),{broadcast:hie}=dt(),{setNode:pie}=(kc(),oe(xc)),mie="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",Sie="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",Tie=Pb.get(hm.CONFIG_PARAMS.CLUSTERING_NODENAME);Xx.exports=gie;async function gie(e){if(Sf.trace("updateNode called with:",e),Pb.get(hm.CONFIG_PARAMS.REPLICATION_URL)??Pb.get(hm.CONFIG_PARAMS.REPLICATION_HOSTNAME))return pie(e);gf.checkClusteringEnabled();let t=uie(e);if(t)throw Cb(t,t.message,Db.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await gf.getNodeRecord(r);s.length>0&&(n=die(s));let{added:i,skipped:o}=await _ie(e.subscriptions,r),c={message:void 0,updated:i,skipped:o};if(i.length===0)return c.message=mie,c;let l=gf.buildNodePayloads(i,Tie,hm.OPERATIONS_ENUM.UPDATE_NODE,await gf.getSystemInfo());for(let d=0,_=i.length;d<_;d++){let E=i[d];Sf.trace(`updateNode updating work stream for node: ${r} subscription:`,E),i[d].start_time===void 0&&delete i[d].start_time}Sf.trace("updateNode sending remote payload:",l);let u;try{u=await Tf.request(`${r}.${Jx.REQUEST_SUFFIX}`,l)}catch(d){Sf.error(`updateNode received error from request: ${d}`);let _=Tf.requestErrorHandler(d,"update_node",r);throw Cb(new Error,_,Db.INTERNAL_SERVER_ERROR,"error",_)}if(u.status===Jx.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let d=`Error returned from remote node ${r}: ${u.message}`;throw Cb(new Error,d,Db.INTERNAL_SERVER_ERROR,"error",d)}Sf.trace(u);for(let d=0,_=i.length;d<_;d++){let E=i[d];await Tf.updateRemoteConsumer(E,r),E.subscribe===!0?await Tf.updateConsumerIterator(E.schema,E.table,r,"start"):await Tf.updateConsumerIterator(E.schema,E.table,r,"stop")}return n||(n=[new fie(r,[],u.system_info)]),await Aie(n[0],i,u.system_info),o.length>0?c.message=Sie:c.message=`Successfully updated '${r}'`,c}a(gie,"updateNode");async function Aie(e,t,r){let n=e;for(let s=0,i=t.length;s<i;s++){let o=t[s],c=!1;for(let l=0,u=e.subscriptions.length;l<u;l++){let d=n.subscriptions[l];if(d.schema===o.schema&&d.table===o.table){d.publish=o.publish,d.subscribe=o.subscribe,c=!0;break}}c||n.subscriptions.push(new Eie(o.schema,o.table,o.publish,o.subscribe))}n.system_info=r,await gf.upsertNodeRecord(n),hie({type:"nats_update"})}a(Aie,"updateNodeTable")});var nk=N((Mwe,rk)=>{"use strict";var tk=require("joi"),{string:Zx}=tk.types(),Rie=Tt(),ek=M(),yie=se(),bie=Ct();rk.exports=Oie;function Oie(e){let t=Zx.invalid(yie.get(ek.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(bie.NATS_TERM_CONSTRAINTS_RX).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >","any.invalid":"'node_name' cannot be this nodes name"}).empty(null),r=tk.object({operation:Zx.valid(ek.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return Rie.validateBySchema(e,r)}a(Oie,"removeNodeValidator")});var Rf=N((vwe,ck)=>{"use strict";var{handleHDBError:sk,hdb_errors:Nie}=_e(),{HTTP_STATUS_CODES:ik}=Nie,Iie=nk(),Af=W(),ok=Di(),wie=te(),Pu=M(),ak=Ct(),Mb=mr(),Ub=se(),{RemotePayloadObject:Cie}=_f(),{NodeSubscription:Die}=Iu(),Pie=w_(),Lie=dc(),{broadcast:Mie}=dt(),{setNode:Uie}=(kc(),oe(xc)),vie=Ub.get(Pu.CONFIG_PARAMS.CLUSTERING_NODENAME);ck.exports=Bie;async function Bie(e){if(Af.trace("removeNode called with:",e),Ub.get(Pu.CONFIG_PARAMS.REPLICATION_URL)??Ub.get(Pu.CONFIG_PARAMS.REPLICATION_HOSTNAME))return Uie(e);ok.checkClusteringEnabled();let t=Iie(e);if(t)throw sk(t,t.message,ik.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await ok.getNodeRecord(r);if(wie.isEmptyOrZeroLength(n))throw sk(new Error,`Node '${r}' was not found.`,ik.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new Cie(Pu.OPERATIONS_ENUM.REMOVE_NODE,vie,[]),i,o=!1;for(let l=0,u=n.subscriptions.length;l<u;l++){let d=n.subscriptions[l];d.subscribe===!0&&await Mb.updateConsumerIterator(d.schema,d.table,r,"stop");try{await Mb.updateRemoteConsumer(new Die(d.schema,d.table,!1,!1),r)}catch(_){Af.error(_)}}try{i=await Mb.request(`${r}.${ak.REQUEST_SUFFIX}`,s),Af.trace("Remove node reply from remote node:",r,i)}catch(l){Af.error("removeNode received error from request:",l),o=!0}let c=new Pie(Pu.SYSTEM_SCHEMA_NAME,Pu.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await Lie.deleteRecord(c),Mie({type:"nats_update"}),i?.status===ak.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||o?(Af.error("Error returned from remote node:",r,i?.message),`Successfully removed '${r}' from local manifest, however there was an error reaching remote node. Check the logs for more details.`):`Successfully removed '${r}' from manifest`}a(Bie,"removeNode")});var dk=N((Hwe,uk)=>{"use strict";var lk=require("joi"),{string:Hie,array:xie}=lk.types(),kie=Tt(),Fie=om();uk.exports=Gie;function Gie(e){let t=lk.object({operation:Hie.valid("configure_cluster").required(),connections:xie.items(Fie.validation_schema).required()});return kie.validateBySchema(e,t)}a(Gie,"configureClusterValidator")});var vb=N((kwe,pk)=>{"use strict";var _k=M(),pm=W(),qie=te(),$ie=se(),Vie=Rf(),Kie=mf(),Yie=Di(),Wie=dk(),{handleHDBError:fk,hdb_errors:jie}=_e(),{HTTP_STATUS_CODES:Ek}=jie,zie="Configure cluster complete.",Qie="Failed to configure the cluster. Check the logs for more details.",Jie="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";pk.exports=Xie;async function Xie(e){pm.trace("configure cluster called with:",e);let t=Wie(e);if(t)throw fk(t,t.message,Ek.BAD_REQUEST,void 0,void 0,!0);let r=await Yie.getAllNodeRecords(),n=[];if($ie.get(_k.CONFIG_PARAMS.CLUSTERING_ENABLED)){for(let d=0,_=r.length;d<_;d++){let E=await hk(Vie,{operation:_k.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[d].name},r[d].name);n.push(E)}pm.trace("All results from configure_cluster remove node:",n)}let s=[],i=e.connections.length;for(let d=0;d<i;d++){let _=e.connections[d],E=await hk(Kie,_,_.node_name);s.push(E)}pm.trace("All results from configure_cluster add node:",s);let o=[],c=[],l=!1,u=n.concat(s);for(let d=0,_=u.length;d<_;d++){let E=u[d];E.status==="rejected"&&(pm.error(E.node_name,E?.error?.message,E?.error?.stack),o.includes(E.node_name)||o.push(E.node_name)),(E?.result?.message?.includes?.("Successfully")||E?.result?.includes?.("Successfully"))&&(l=!0),!(typeof E.result=="string"&&E.result.includes("Successfully removed")||E.status==="rejected")&&c.push({node_name:E?.node_name,response:E?.result})}if(qie.isEmptyOrZeroLength(o))return{message:zie,connections:c};if(l)return{message:Jie,failed_nodes:o,connections:c};throw fk(new Error,Qie,Ek.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(Xie,"configureCluster");async function hk(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){return{node_name:r,error:n,status:"rejected"}}}a(hk,"functionWrapper")});var gk=N((Gwe,Tk)=>{"use strict";var yf=require("joi"),Zie=Tt(),{validateSchemaExists:mk,validateTableExists:eoe,validateSchemaName:Sk}=Ti(),toe=yf.object({operation:yf.string().valid("purge_stream"),schema:yf.string().custom(mk).custom(Sk).optional(),database:yf.string().custom(mk).custom(Sk).optional(),table:yf.string().custom(eoe).required()});function roe(e){return Zie.validateBySchema(e,toe)}a(roe,"purgeStreamValidator");Tk.exports=roe});var Bb=N(($we,Ak)=>{"use strict";var{handleHDBError:noe,hdb_errors:soe}=_e(),{HTTP_STATUS_CODES:ioe}=soe,ooe=gk(),aoe=mr(),coe=Di();Ak.exports=loe;async function loe(e){e.schema=e.schema??e.database;let t=ooe(e);if(t)throw noe(t,t.message,ioe.BAD_REQUEST,void 0,void 0,!0);coe.checkClusteringEnabled();let{schema:r,table:n,options:s}=e;return await aoe.purgeTableStream(r,n,s),`Successfully purged table '${r}.${n}'`}a(loe,"purgeStream")});var Sm=N((Kwe,wk)=>{"use strict";var xb=Di(),uoe=mr(),mm=se(),Lu=M(),Fc=Ct(),doe=te(),Hb=W(),{RemotePayloadObject:_oe}=_f(),{ErrorCode:Rk}=require("nats"),{parentPort:yk}=require("worker_threads"),{onMessageByType:foe}=dt(),{getThisNodeName:Eoe}=(us(),oe(ca)),{requestClusterStatus:hoe}=(X_(),oe(gB)),bk=mm.get(Lu.CONFIG_PARAMS.CLUSTERING_ENABLED),Ok=mm.get(Lu.CONFIG_PARAMS.CLUSTERING_NODENAME);wk.exports={clusterStatus:poe,buildNodeStatus:Ik};var Nk;foe("cluster-status",async e=>{Nk(e)});async function poe(){if(mm.get(Lu.CONFIG_PARAMS.REPLICATION_URL)||mm.get(Lu.CONFIG_PARAMS.REPLICATION_HOSTNAME)){let n;return yk?(yk.postMessage({type:"request-cluster-status"}),n=await new Promise(s=>{Nk=s})):n=hoe(),n.node_name=Eoe(),n.is_enabled=!0,n}let e={node_name:Ok,is_enabled:bk,connections:[]};if(!bk)return e;let t=await xb.getAllNodeRecords();if(doe.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(Ik(t[n],e.connections));return await Promise.allSettled(r),e}a(poe,"clusterStatus");async function Ik(e,t){let r=e.name,n=new _oe(Lu.OPERATIONS_ENUM.CLUSTER_STATUS,Ok,void 0,await xb.getSystemInfo()),s,i,o=Fc.CLUSTER_STATUS_STATUSES.OPEN;try{let l=Date.now();s=await uoe.request(Fc.REQUEST_SUBJECT(r),n),i=Date.now()-l,s.status===Fc.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=Fc.CLUSTER_STATUS_STATUSES.CLOSED,Hb.error(`Error getting node status from ${r} `,s))}catch(l){Hb.warn(`Error getting node status from ${r}`,l),l.code===Rk.NoResponders?o=Fc.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:l.code===Rk.Timeout?o=Fc.CLUSTER_STATUS_STATUSES.TIMEOUT:o=Fc.CLUSTER_STATUS_STATUSES.CLOSED}let c=new moe(r,o,s?.message?.ports?.clustering,s?.message?.ports?.operations_api,i,s?.message?.uptime,e.subscriptions,s?.message?.system_info);try{let l={name:r,system_info:s?.message?.system_info};e.system_info?.hdb_version!==Lu.PRE_4_0_0_VERSION&&await xb.upsertNodeRecord(l)}catch(l){Hb.error("Cluster status encountered an error updating system info for node:",r,l)}t.push(c)}a(Ik,"buildNodeStatus");function moe(e,t,r,n,s,i,o,c){this.node_name=e,this.status=t,this.ports={clustering:r,operations_api:n},this.latency_ms=s,this.uptime=i,this.subscriptions=o,this.system_info=c}a(moe,"NodeStatusObject")});var Fb=N((Wwe,Ck)=>{"use strict";var{handleHDBError:Soe,hdb_errors:Toe}=_e(),{HTTP_STATUS_CODES:goe}=Toe,Aoe=mr(),Roe=Di(),kb=te(),Tm=require("joi"),yoe=Tt(),boe=2e3,Ooe=Tm.object({timeout:Tm.number().min(1),connected_nodes:Tm.boolean(),routes:Tm.boolean()});Ck.exports=Noe;async function Noe(e){Roe.checkClusteringEnabled();let t=yoe.validateBySchema(e,Ooe);if(t)throw Soe(t,t.message,goe.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||kb.autoCastBoolean(n),o=s===void 0||kb.autoCastBoolean(s),c={nodes:[]},l=await Aoe.getServerList(r??boe),u={};if(i)for(let d=0,_=l.length;d<_;d++){let E=l[d].statsz;E&&(u[l[d].server.name]=E.routes)}for(let d=0,_=l.length;d<_;d++){if(l[d].statsz)continue;let E=l[d].server,f=l[d].data;if(E.name.endsWith("-hub")){let h={name:E.name.slice(0,-4),response_time:l[d].response_time};i&&(h.connected_nodes=[],u[E.name]&&u[E.name].forEach(T=>{h.connected_nodes.includes(T.name.slice(0,-4))||h.connected_nodes.push(T.name.slice(0,-4))})),o&&(h.routes=f.cluster?.urls?f.cluster?.urls.map(T=>({host:T.split(":")[0],port:kb.autoCast(T.split(":")[1])})):[]),c.nodes.push(h)}}return c}a(Noe,"clusterNetwork")});var Mk=N((zwe,Lk)=>{"use strict";var Gb=require("joi"),Dk=Tt(),{route_constraints:Pk}=gg();Lk.exports={setRoutesValidator:Ioe,deleteRoutesValidator:woe};function Ioe(e){let t=Gb.object({server:Gb.valid("hub","leaf"),routes:Pk.required()});return Dk.validateBySchema(e,t)}a(Ioe,"setRoutesValidator");function woe(e){let t=Gb.object({routes:Pk.required()});return Dk.validateBySchema(e,t)}a(woe,"deleteRoutesValidator")});var gm=N((Jwe,Fk)=>{"use strict";var _o=wt(),qb=te(),ms=M(),Mu=se(),Uk=Mk(),{handleHDBError:vk,hdb_errors:Coe}=_e(),{HTTP_STATUS_CODES:Bk}=Coe,Hk="cluster routes successfully set",xk="cluster routes successfully deleted";Fk.exports={setRoutes:Poe,getRoutes:Loe,deleteRoutes:Moe};function Doe(e){let t=_o.getClusteringRoutes(),r=e.server==="hub"?t.hub_routes:t.leaf_routes,n=e.server==="hub"?t.leaf_routes:t.hub_routes,s=[],i=[];for(let o=0,c=e.routes.length;o<c;o++){let l=e.routes[o];l.port=qb.autoCast(l.port);let u=r.some(_=>_.host===l.host&&_.port===l.port),d=n.some(_=>_.host===l.host&&_.port===l.port);u||d?s.push(l):(r.push(l),i.push(l))}return e.server==="hub"?_o.updateConfigValue(ms.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r):_o.updateConfigValue(ms.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,r),{message:Hk,set:i,skipped:s}}a(Doe,"setRoutesNats");function Poe(e){let t=Uk.setRoutesValidator(e);if(t)throw vk(t,t.message,Bk.BAD_REQUEST,void 0,void 0,!0);if(Mu.get(ms.CONFIG_PARAMS.CLUSTERING_ENABLED))return Doe(e);let r=[],n=[],s=Mu.get(ms.CONFIG_PARAMS.REPLICATION_ROUTES)??[];return e.routes.forEach(i=>{kk(s,i)?n.push(i):(s.push(i),r.push(i))}),_o.updateConfigValue(ms.CONFIG_PARAMS.REPLICATION_ROUTES,s),{message:Hk,set:r,skipped:n}}a(Poe,"setRoutes");function kk(e,t){return typeof t=="string"?e.includes(t):typeof t=="object"&&t!==null?e.some(r=>(r.host===t.host||r.hostname===t.hostname)&&r.port===t.port):!1}a(kk,"existsInArray");function Loe(){if(Mu.get(ms.CONFIG_PARAMS.CLUSTERING_ENABLED)){let e=_o.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}else return Mu.get(ms.CONFIG_PARAMS.REPLICATION_ROUTES)??[]}a(Loe,"getRoutes");function Moe(e){let t=Uk.deleteRoutesValidator(e);if(t)throw vk(t,t.message,Bk.BAD_REQUEST,void 0,void 0,!0);if(Mu.get(ms.CONFIG_PARAMS.CLUSTERING_ENABLED))return Uoe(e);let r=[],n=[],s=Mu.get(ms.CONFIG_PARAMS.REPLICATION_ROUTES)??[],i=[];return s.forEach(o=>{kk(e.routes,o)?r.push(o):(i.push(o),n.push(o))}),_o.updateConfigValue(ms.CONFIG_PARAMS.REPLICATION_ROUTES,i),{message:xk,deleted:r,skipped:n}}a(Moe,"deleteRoutes");function Uoe(e){let t=_o.getClusteringRoutes(),r=t.hub_routes,n=t.leaf_routes,s=[],i=[],o=!1,c=!1;for(let l=0,u=e.routes.length;l<u;l++){let d=e.routes[l],_=!1;for(let E=0,f=r.length;E<f;E++){let h=r[E];if(d.host===h.host&&d.port===h.port){r.splice(E,1),_=!0,o=!0,s.push(d);break}}if(!_){let E=!0;for(let f=0,h=n.length;f<h;f++){let T=n[f];if(d.host===T.host&&d.port===T.port){n.splice(f,1),c=!0,E=!1,s.push(d);break}}E&&i.push(d)}}return o&&(r=qb.isEmptyOrZeroLength(r)?null:r,_o.updateConfigValue(ms.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,r)),c&&(n=qb.isEmptyOrZeroLength(n)?null:n,_o.updateConfigValue(ms.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n)),{message:xk,deleted:s,skipped:i}}a(Uoe,"deleteRoutesNats")});var qk=N((Zwe,Gk)=>{"use strict";var bf=require("alasql"),Gc=require("recursive-iterator"),Zs=W(),voe=te(),Of=M(),$b=class{static{a(this,"sql_statement_bucket")}constructor(t){this.ast=t,this.affected_attributes=new Map,this.table_lookup=new Map,this.schema_lookup=new Map,this.table_to_schema_lookup=new Map,Hoe(this.ast,this.affected_attributes,this.table_lookup,this.schema_lookup,this.table_to_schema_lookup)}getAttributesBySchemaTableName(t,r){if(!t||!r||!this.affected_attributes)return[];if(this.affected_attributes.has(t))return!this.affected_attributes.get(t).has(r)&&(r=this.table_lookup.get(r),!r)?[]:this.affected_attributes.get(t).get(r)}getAllTables(){let t=[];if(!this.affected_attributes)return t;for(let r of this.affected_attributes.keys())t.push(Array.from(this.affected_attributes.get(r).keys()));return t}getTablesBySchemaName(t){return!t||!this.affected_attributes?[]:Array.from(this.affected_attributes.get(t).keys())}getSchemas(){return this.affected_attributes?Array.from(this.affected_attributes.keys()):[]}getAst(){return this.ast}updateAttributeWildcardsForRolePerms(t){let r=this.ast.columns.filter(s=>Of.SEARCH_WILDCARDS.includes(s.columnid));if(r.length===0)return this.ast;let n=this.ast.from[0].databaseid;return this.ast.columns=this.ast.columns.filter(s=>!Of.SEARCH_WILDCARDS.includes(s.columnid)),r.forEach(s=>{let i=this.table_to_schema_lookup.has(s.tableid)?this.table_to_schema_lookup.get(s.tableid):n,o=this.table_lookup.has(s.tableid)?this.table_lookup.get(s.tableid):this.ast.from[0].tableid;if(t[i]&&t[i].tables[o]&&t[i].tables[o][Of.PERMS_CRUD_ENUM.READ]){let c;t[i].tables[o].attribute_permissions.length>0?c=Boe(t[i].tables[o].attribute_permissions):c=global.hdb_schema[i][o].attributes.map(u=>({attribute_name:u.attribute}));let l=this.affected_attributes.get(i).get(o).filter(u=>!Of.SEARCH_WILDCARDS.includes(u));c.forEach(({attribute_name:u})=>{let d=new bf.yy.Column({columnid:u});s.tableid&&(d.tableid=s.tableid),this.ast.columns.push(d),l.includes(u)||l.push(u)}),this.affected_attributes.get(i).set(o,l)}}),this.ast}};function Boe(e){return e.filter(t=>t[Of.PERMS_CRUD_ENUM.READ])}a(Boe,"filterReadRestrictedAttrs");function Hoe(e,t,r,n,s){xoe(e,t,r,n,s)}a(Hoe,"interpretAST");function Nf(e,t,r,n,s){if(!(!e||!e.databaseid)&&(t.has(e.databaseid)||t.set(e.databaseid,new Map),t.get(e.databaseid).has(e.tableid)||t.get(e.databaseid).set(e.tableid,[]),e.as&&(r.has(e.as)||r.set(e.as,e.tableid),n&&!n.has(e.as)&&n.set(e.as,e.databaseid)),s)){let i=e.databaseid,o=e.tableid;e.as&&(o=e.as),s.set(o,i)}}a(Nf,"addSchemaTableToMap");function xoe(e,t,r,n,s){if(!e){Zs.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof bf.yy.Insert?qoe(e,t,r):e instanceof bf.yy.Select?koe(e,t,r,n,s):e instanceof bf.yy.Update?Foe(e,t,r):e instanceof bf.yy.Delete?Goe(e,t,r):Zs.error("AST in getRecordAttributesAST() is not a valid SQL type.")}a(xoe,"getRecordAttributesAST");function koe(e,t,r,n,s){if(!e){Zs.info("getSelectAttributes: invalid SQL syntax tree");return}if(!e.from||e.from[0]===void 0)return;let i=e.from[0].databaseid;if(voe.isEmptyOrZeroLength(i)){Zs.error("No schema specified");return}e.from.forEach(c=>{Nf(c,t,r,n,s)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),Nf(c.table,t,r,n,s)});let o=new Gc(e.columns);for(let{node:c}of o)if(c&&c.columnid){let l=c.tableid,u=n.has(l)?n.get(l):i;if(l||(l=e.from[0].tableid),!t.get(u).has(l))if(r.has(l))l=r.get(l);else{Zs.info(`table specified as ${l} not found.`);return}t.get(u).get(l).indexOf(c.columnid)<0&&t.get(u).get(l).push(c.columnid)}if(e.where){let c=new Gc(e.where),l=e.from[0].tableid;for(let{node:u}of c)if(u&&u.columnid){let d=u.tableid?u.tableid:l;if(!t.get(i).has(d))if(r.has(d))d=r.get(d);else{Zs.info(`table specified as ${d} not found.`);continue}t.get(i).get(d).indexOf(u.columnid)<0&&t.get(i).get(d).push(u.columnid)}}if(e.joins&&e.joins.forEach(c=>{let l=new Gc(c.on);for(let{node:u}of l)if(u&&u.columnid){let d=u.tableid,_=s.get(d);if(!t.get(_).has(d))if(r.has(d))d=r.get(d);else{Zs.info(`table specified as ${d} not found.`);continue}t.get(_).get(d).indexOf(u.columnid)<0&&t.get(_).get(d).push(u.columnid)}}),e.order){let c=new Gc(e.order);for(let{node:l}of c)if(l&&l.columnid){let u=l.tableid,d=n.has(u)?n.get(u):i;if(u||(u=e.from[0].tableid),!t.get(d).has(u))if(r.has(u))u=r.get(u);else{Zs.info(`table specified as ${u} not found.`);return}t.get(d).get(u).indexOf(l.columnid)<0&&t.get(d).get(u).push(l.columnid)}}}a(koe,"getSelectAttributes");function Foe(e,t,r){if(!e){Zs.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new Gc(e.columns),s=e.table.databaseid;Nf(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&Vb(e.table.tableid,s,i.columnid,t,r)}a(Foe,"getUpdateAttributes");function Goe(e,t,r){if(!e){Zs.info("getDeleteAttributes: invalid SQL syntax tree");return}let n=new Gc(e.where),s=e.table.databaseid;Nf(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&Vb(e.table.tableid,s,i.columnid,t,r)}a(Goe,"getDeleteAttributes");function qoe(e,t,r){if(!e){Zs.info("getInsertAttributes: invalid SQL syntax tree");return}let n=new Gc(e.columns),s=e.into.databaseid;Nf(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&Vb(e.into.tableid,s,i.columnid,t,r)}a(qoe,"getInsertAttributes");function Vb(e,t,r,n,s){if(!n.get(t))return;let i=e;n.get(t).has(i)||(i=s.get(i)),n.get(t).get(i).push(r)}a(Vb,"pushAttribute");Gk.exports=$b});var Wb=N((tCe,Yk)=>{var Am=_c(),$k=require("chalk"),Vn=W(),Vk=require("prompt"),{promisify:$oe}=require("util"),Kb=M(),Voe=require("fs-extra"),Koe=require("path"),Yoe=te(),Woe=Bc(),Kk=se();Kk.initSync();var joe=require("moment"),zoe=$oe(Vk.get),Qoe=Koe.join(Kk.getHdbBasePath(),Kb.LICENSE_KEY_DIR_NAME,Kb.LICENSE_FILE_NAME,Kb.LICENSE_FILE_NAME);Yk.exports={getFingerprint:Xoe,setLicense:Joe,parseLicense:Yb,register:Zoe,getRegistrationInfo:tae};async function Joe(e){if(e&&e.key&&e.company){try{Vn.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await Yb(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw Vn.error(r),Vn.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}a(Joe,"setLicense");async function Xoe(){let e={};try{e=await Am.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw Vn.error(r),Vn.error(t),new Error(r)}return e}a(Xoe,"getFingerprint");async function Yb(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");Vn.info("Validating license input...");let r=Am.validateLicense(e,t);if(Vn.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(Vn.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(Vn.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{Vn.info("writing license to disk"),await Voe.writeFile(Qoe,JSON.stringify({license_key:e,company:t}))}catch(n){throw Vn.error("Failed to write License"),n}return"Registration successful."}a(Yb,"parseLicense");async function Zoe(){let e=await eae();return Yb(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(Zoe,"register");async function eae(){let e=await Am.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:$k.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:$k.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{Vk.start()}catch(n){Vn.error(n)}let r;try{r=await zoe(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}a(eae,"promptForRegistration");async function tae(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await Am.getLicense()}catch(r){throw Vn.error(`There was an error when searching licenses due to: ${r.message}`),r}if(Yoe.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=Woe.version(),e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=joe.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(tae,"getRegistrationInfo")});var jk=N((nCe,Wk)=>{"use strict";var rae=Ct(),jb=class{static{a(this,"HubConfigObject")}constructor(t,r,n,s,i,o,c,l,u,d,_,E,f,h){this.port=t,o===null&&(o=void 0),this.server_name=r+rae.SERVER_SUFFIX.HUB,this.pid_file=n,this.max_payload=67108864,this.reconnect_error_reports=100,this.jetstream={enabled:!1},this.tls={cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l},this.leafnodes={port:u,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c}},this.cluster={name:d,port:_,routes:E,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l}},this.accounts={SYS:{users:f},HDB:{users:h}},this.system_account="SYS"}};Wk.exports=jb});var Jk=N((iCe,Qk)=>{"use strict";var zk=Ct(),zb=class{static{a(this,"LeafConfigObject")}constructor(t,r,n,s,i,o,c,l,u,d,_){this.port=t,_===null&&(_=void 0),this.server_name=r+zk.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+zk.SERVER_SUFFIX.LEAF},this.tls={cert_file:u,key_file:d,ca_file:_,insecure:!0},this.leafnodes={remotes:[{tls:{ca_file:_,insecure:!0},urls:i,account:"SYS"},{tls:{ca_file:_,insecure:!0},urls:o,account:"HDB"}]},this.accounts={SYS:{users:c},HDB:{users:l,jetstream:"enabled"}},this.system_account="SYS"}};Qk.exports=zb});var Zk=N((aCe,Xk)=>{"use strict";var Qb=class{static{a(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};Xk.exports=Qb});var tF=N((lCe,eF)=>{"use strict";var nae=Ct(),Jb=class{static{a(this,"SysUserObject")}constructor(t,r){this.user=t+nae.SERVER_SUFFIX.ADMIN,this.password=r}};eF.exports=Jb});var Om=N((dCe,sF)=>{"use strict";var qc=require("path"),$c=require("fs-extra"),sae=jk(),iae=Jk(),oae=Zk(),aae=tF(),Xb=xn(),vu=te(),Tn=wt(),ym=M(),If=Ct(),{CONFIG_PARAMS:Jt}=ym,Bu=W(),wf=se(),rF=to(),Zb=mr(),cae=Xs(),Uu="clustering",lae=1e4,nF=50;sF.exports={generateNatsConfig:dae,removeNatsConfig:_ae,getHubConfigPath:uae};function uae(){let e=wf.get(Jt.ROOTPATH);return qc.join(e,Uu,If.NATS_CONFIG_FILES.HUB_SERVER)}a(uae,"getHubConfigPath");async function dae(e=!1,t=void 0){let r=wf.get(Jt.ROOTPATH);$c.ensureDirSync(qc.join(r,"clustering","leaf")),wf.initSync();let n=Tn.getConfigFromFile(Jt.CLUSTERING_TLS_CERT_AUTH),s=Tn.getConfigFromFile(Jt.CLUSTERING_TLS_PRIVATEKEY),i=Tn.getConfigFromFile(Jt.CLUSTERING_TLS_CERTIFICATE);!await $c.exists(i)&&!await $c.exists(!n)&&await cae.createNatsCerts();let o=qc.join(r,Uu,If.PID_FILES.HUB),c=qc.join(r,Uu,If.PID_FILES.LEAF),l=Tn.getConfigFromFile(Jt.CLUSTERING_LEAFSERVER_STREAMS_PATH),u=qc.join(r,Uu,If.NATS_CONFIG_FILES.HUB_SERVER),d=qc.join(r,Uu,If.NATS_CONFIG_FILES.LEAF_SERVER),_=Tn.getConfigFromFile(Jt.CLUSTERING_TLS_INSECURE),E=Tn.getConfigFromFile(Jt.CLUSTERING_TLS_VERIFY),f=Tn.getConfigFromFile(Jt.CLUSTERING_NODENAME),h=Tn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await Zb.checkNATSServerInstalled()||bm("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let T=await Xb.listUsers(),m=Tn.getConfigFromFile(Jt.CLUSTERING_USER),g=await Xb.getClusterUser();(vu.isEmpty(g)||g.active!==!0)&&bm(`Invalid cluster user '${m}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await Rm(Jt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await Rm(Jt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await Rm(Jt.CLUSTERING_HUBSERVER_NETWORK_PORT),await Rm(Jt.CLUSTERING_LEAFSERVER_NETWORK_PORT));let S=[],y=[];for(let[ne,Q]of T.entries())Q.role?.role===ym.ROLE_TYPES_ENUM.CLUSTER_USER&&Q.active&&(S.push(new aae(Q.username,rF.decrypt(Q.hash))),y.push(new oae(Q.username,rF.decrypt(Q.hash))));let I=[],{hub_routes:U}=Tn.getClusteringRoutes();if(!vu.isEmptyOrZeroLength(U))for(let ne of U)I.push(`tls://${g.sys_name_encoded}:${g.uri_encoded_d_hash}@${ne.host}:${ne.port}`);let H=new sae(Tn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_NETWORK_PORT),f,o,i,s,n,_,E,h,Tn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_CLUSTER_NAME),Tn.getConfigFromFile(Jt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),I,S,y);n==null&&(delete H.tls.ca_file,delete H.leafnodes.tls.ca_file),t=vu.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===ym.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await $c.writeJson(u,H),Bu.trace(`Hub server config written to ${u}`));let X=`tls://${g.sys_name_encoded}:${g.uri_encoded_d_hash}@0.0.0.0:${h}`,Y=`tls://${g.uri_encoded_name}:${g.uri_encoded_d_hash}@0.0.0.0:${h}`,V=new iae(Tn.getConfigFromFile(Jt.CLUSTERING_LEAFSERVER_NETWORK_PORT),f,c,l,[X],[Y],S,y,i,s,n,_);n==null&&delete V.tls.ca_file,(t===void 0||t===ym.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await $c.writeJson(d,V),Bu.trace(`Leaf server config written to ${d}`))}a(dae,"generateNatsConfig");async function Rm(e){let t=wf.get(e);return vu.isEmpty(t)&&bm(`port undefined for '${e}'`),await vu.isPortTaken(t)&&bm(`'${e}' port '${t}' is is in use by another process, check to see if HarperDB is already running or another process is using this port.`),!0}a(Rm,"isPortAvailable");function bm(e){let t=`Error generating clustering config: ${e}`;Bu.error(t),console.error(t),process.exit(1)}a(bm,"generateNatsConfigError");async function _ae(e){let{port:t,config_file:r}=Zb.getServerConfig(e),{username:n,decrypt_hash:s}=await Xb.getClusterUser(),i=0,o=2e3;for(;i<nF;){try{let d=await Zb.createConnection(t,n,s,!1);if(d.protocol.connected===!0){d.close();break}}catch(d){Bu.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${d}`)}if(i++,i>=nF)throw new Error(`Operations API timed out attempting to connect to ${e}. This is commonly caused by incorrect clustering config. Check hdb.log for further details.`);let u=o*(i*2);u>3e4&&Bu.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await vu.async_set_timeout(u)}let c="0".repeat(lae),l=qc.join(wf.get(Jt.ROOTPATH),Uu,r);await $c.writeFile(l,c),await $c.remove(l),Bu.notify(e,"started.")}a(_ae,"removeNatsConfig")});var uF=N((fCe,lF)=>{"use strict";var Kn=se(),fae=_c(),Ge=M(),Cf=Ct(),fo=require("path"),{PACKAGE_ROOT:Im}=M(),iF=se(),Nm=te(),Hu="/dev/null",Eae=fo.join(Im,"launchServiceScripts"),oF=fo.join(Im,"utility/scripts"),hae=fo.join(oF,Ge.HDB_RESTART_SCRIPT),aF=fo.resolve(Im,"dependencies",`${process.platform}-${process.arch}`,Cf.NATS_BINARY_NAME);function cF(){let t=fae.licenseSearch().ram_allocation||Ge.RAM_ALLOCATION_ENUM.DEFAULT,r=Ge.MEM_SETTING_KEY+t,n={[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.HDB,IS_SCRIPTED_SERVICE:!0};return Nm.noBootFile()&&(n[Ge.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Nm.getEnvCliRootPath()),{name:Ge.PROCESS_DESCRIPTORS.HDB,script:Ge.LAUNCH_SERVICE_SCRIPTS.MAIN,exec_mode:"fork",env:n,node_args:r,cwd:Im}}a(cF,"generateMainServerConfig");var pae=9930;function mae(){Kn.initSync(!0);let e=Kn.get(Ge.CONFIG_PARAMS.ROOTPATH),t=fo.join(e,"clustering",Cf.NATS_CONFIG_FILES.HUB_SERVER),r=fo.join(Kn.get(Ge.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Ge.LOG_NAMES.HDB),n=iF.get(Ge.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),s=Cf.LOG_LEVEL_FLAGS[Kn.get(Ge.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Ge.PROCESS_DESCRIPTORS.CLUSTERING_HUB+(n!==pae?"-"+n:""),script:aF,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.CLUSTERING_HUB},merge_logs:!0,out_file:r,error_file:r,instances:1};return Kn.get(Ge.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Hu,i.error_file=Hu),i}a(mae,"generateNatsHubServerConfig");var Sae=9940;function Tae(){Kn.initSync(!0);let e=Kn.get(Ge.CONFIG_PARAMS.ROOTPATH),t=fo.join(e,"clustering",Cf.NATS_CONFIG_FILES.LEAF_SERVER),r=fo.join(Kn.get(Ge.HDB_SETTINGS_NAMES.LOG_PATH_KEY),Ge.LOG_NAMES.HDB),n=iF.get(Ge.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),s=Cf.LOG_LEVEL_FLAGS[Kn.get(Ge.CONFIG_PARAMS.CLUSTERING_LOGLEVEL)]??void 0,i={name:Ge.PROCESS_DESCRIPTORS.CLUSTERING_LEAF+(n!==Sae?"-"+n:""),script:aF,args:s?`${s} -c ${t}`:`-c ${t}`,exec_mode:"fork",env:{[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.CLUSTERING_LEAF},merge_logs:!0,out_file:r,error_file:r,instances:1};return Kn.get(Ge.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(i.out_file=Hu,i.error_file=Hu),i}a(Tae,"generateNatsLeafServerConfig");function gae(){Kn.initSync();let e=fo.join(Kn.get(Ge.CONFIG_PARAMS.LOGGING_ROOT),Ge.LOG_NAMES.HDB),t={name:Ge.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0,script:Ge.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,exec_mode:"fork",env:{[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0},merge_logs:!0,out_file:e,error_file:e,instances:1,cwd:Eae,autorestart:!1};return Kn.get(Ge.HDB_SETTINGS_NAMES.LOG_TO_FILE)||(t.out_file=Hu,t.error_file=Hu),t}a(gae,"generateClusteringUpgradeV4ServiceConfig");function Aae(){let e={[Ge.PROCESS_NAME_ENV_PROP]:Ge.PROCESS_DESCRIPTORS.RESTART_HDB};return Nm.noBootFile()&&(e[Ge.CONFIG_PARAMS.ROOTPATH.toUpperCase()]=Nm.getEnvCliRootPath()),{...{name:Ge.PROCESS_DESCRIPTORS.RESTART_HDB,exec_mode:"fork",env:e,instances:1,autorestart:!1,cwd:oF},script:hae}}a(Aae,"generateRestart");function Rae(){return{apps:[cF()]}}a(Rae,"generateAllServiceConfigs");lF.exports={generateAllServiceConfigs:Rae,generateMainServerConfig:cF,generateRestart:Aae,generateNatsHubServerConfig:mae,generateNatsLeafServerConfig:Tae,generateClusteringUpgradeV4ServiceConfig:gae}});var xu=N((pCe,bF)=>{"use strict";var at=M(),yae=te(),ho=Om(),wm=mr(),Eo=Ct(),Ea=uF(),Cm=se(),Vc=W(),bae=Di(),{startWorker:dF,onMessageFromWorkers:Oae}=dt(),Nae=Cu(),hCe=require("util"),Iae=require("child_process"),wae=require("fs"),{execFile:Cae}=Iae,Xe;bF.exports={enterPM2Mode:Dae,start:ha,stop:eO,reload:fF,restart:EF,list:tO,describe:mF,connect:po,kill:vae,startAllServices:Bae,startService:rO,getUniqueServicesList:SF,restartAllServices:Hae,isServiceRegistered:TF,reloadStopStart:gF,restartHdb:pF,deleteProcess:Mae,startClusteringProcesses:RF,startClusteringThreads:yF,isHdbRestartRunning:Uae,isClusteringRunning:kae,stopClustering:xae,reloadClustering:Fae,expectedRestartOfChildren:hF};var Df=!1;Oae(e=>{e.type==="restart"&&Cm.initSync(!0)});function Dae(){Df=!0}a(Dae,"enterPM2Mode");function po(){return Xe||(Xe=require("pm2")),new Promise((e,t)=>{Xe.connect((r,n)=>{r&&t(r),e(n)})})}a(po,"connect");var Jr,Pae=10,_F;function ha(e,t=!1){if(Df)return Lae(e);let r=Cae(e.script,e.args.split(" "),e);r.name=e.name,r.config=e,r.on("exit",async i=>{let o=Jr.indexOf(r);o>-1&&Jr.splice(o,1),!_F&&i!==0&&(e.restarts=(e.restarts||0)+1,e.restarts<Pae&&(wae.existsSync(ho.getHubConfigPath())?ha(e):(await ho.generateNatsConfig(!0),ha(e),await new Promise(c=>setTimeout(c,3e3)),await ho.removeNatsConfig(at.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await ho.removeNatsConfig(at.PROCESS_DESCRIPTORS.CLUSTERING_LEAF))))});let n={serviceName:e.name.replace(/ /g,"-")};function s(i){let o=Cm.get(at.CONFIG_PARAMS.CLUSTERING_LOGLEVEL),c=/\[\d+][^\[]+\[(\w+)]/g,l,u=0,d;for(;l=c.exec(i);){if(l.index&&Eo.LOG_LEVEL_HIERARCHY[o]>=Eo.LOG_LEVEL_HIERARCHY[d||"info"]){let f=d===Eo.LOG_LEVELS.ERR||d===Eo.LOG_LEVELS.WRN?Vc.OUTPUTS.STDERR:Vc.OUTPUTS.STDOUT;Vc.logCustomLevel(d||"info",f,n,i.slice(u,l.index).trim())}let[_,E]=l;u=l.index+_.length,d=Eo.LOG_LEVELS[E]}if(Eo.LOG_LEVEL_HIERARCHY[o]>=Eo.LOG_LEVEL_HIERARCHY[d||"info"]){let _=d===Eo.LOG_LEVELS.ERR||d===Eo.LOG_LEVELS.WRN?Vc.OUTPUTS.STDERR:Vc.OUTPUTS.STDOUT;Vc.logCustomLevel(d||"info",_,n,i.slice(u).trim())}}if(a(s,"extractMessages"),r.stdout.on("data",s),r.stderr.on("data",s),r.unref(),!Jr&&(Jr=[],!t)){let i=a(()=>{_F=!0,Jr&&(Jr.map(o=>o.kill()),process.exit(0))},"kill_children");process.on("exit",i),process.on("SIGINT",i),process.on("SIGQUIT",i),process.on("SIGTERM",i)}Jr.push(r)}a(ha,"start");function Lae(e){return new Promise(async(t,r)=>{try{await po()}catch(n){r(n)}Xe.start(e,(n,s)=>{n&&(Xe.disconnect(),r(n)),Xe.disconnect(),t(s)})})}a(Lae,"startWithPM2");function eO(e){if(!Df){for(let t of Jr||[])t.name===e&&(Jr.splice(Jr.indexOf(t),1),t.kill());return}return new Promise(async(t,r)=>{try{await po()}catch(n){r(n)}Xe.stop(e,async(n,s)=>{n&&(Xe.disconnect(),r(n)),Xe.delete(e,(i,o)=>{i&&(Xe.disconnect(),r(n)),Xe.disconnect(),t(o)})})})}a(eO,"stop");function fF(e){return new Promise(async(t,r)=>{try{await po()}catch(n){r(n)}Xe.reload(e,(n,s)=>{n&&(Xe.disconnect(),r(n)),Xe.disconnect(),t(s)})})}a(fF,"reload");function EF(e){if(!Df){hF();for(let t of Jr||[])t.name===e&&t.kill()}return new Promise(async(t,r)=>{try{await po()}catch(n){r(n)}Xe.restart(e,(n,s)=>{Xe.disconnect(),t(s)})})}a(EF,"restart");function hF(){for(let e of Jr||[])e.config&&(e.config.restarts=0)}a(hF,"expectedRestartOfChildren");function Mae(e){return new Promise(async(t,r)=>{try{await po()}catch(n){r(n)}Xe.delete(e,(n,s)=>{n&&(Xe.disconnect(),r(n)),Xe.disconnect(),t(s)})})}a(Mae,"deleteProcess");async function pF(){await ha(Ea.generateRestart())}a(pF,"restartHdb");async function Uae(){let e=await tO();for(let t in e)if(e[t].name===at.PROCESS_DESCRIPTORS.RESTART_HDB)return!0;return!1}a(Uae,"isHdbRestartRunning");function tO(){return new Promise(async(e,t)=>{try{await po()}catch(r){t(r)}Xe.list((r,n)=>{r&&(Xe.disconnect(),t(r)),Xe.disconnect(),e(n)})})}a(tO,"list");function mF(e){return new Promise(async(t,r)=>{try{await po()}catch(n){r(n)}Xe.describe(e,(n,s)=>{n&&(Xe.disconnect(),r(n)),Xe.disconnect(),t(s)})})}a(mF,"describe");function vae(){if(!Df){for(let e of Jr||[])e.kill();Jr=[];return}return new Promise(async(e,t)=>{try{await po()}catch(r){t(r)}Xe.killDaemon((r,n)=>{r&&(Xe.disconnect(),t(r)),Xe.disconnect(),e(n)})})}a(vae,"kill");async function Bae(){try{await RF(),await yF(),await ha(Ea.generateAllServiceConfigs())}catch(e){throw Xe?.disconnect(),e}}a(Bae,"startAllServices");async function rO(e,t=!1){try{let r;switch(e=e.toLowerCase(),e){case at.PROCESS_DESCRIPTORS.HDB.toLowerCase():r=Ea.generateMainServerConfig();break;case at.PROCESS_DESCRIPTORS.CLUSTERING_INGEST_SERVICE.toLowerCase():r=Ea.generateNatsIngestServiceConfig();break;case at.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE.toLowerCase():r=Ea.generateNatsReplyServiceConfig();break;case at.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase():r=Ea.generateNatsHubServerConfig(),await ha(r,t),await ho.removeNatsConfig(e);return;case at.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase():r=Ea.generateNatsLeafServerConfig(),await ha(r,t),await ho.removeNatsConfig(e);return;case at.PROCESS_DESCRIPTORS.CLUSTERING_UPGRADE_4_0_0.toLowerCase():r=Ea.generateClusteringUpgradeV4ServiceConfig();break;default:throw new Error(`Start service called with unknown service config: ${e}`)}await ha(r)}catch(r){throw Xe?.disconnect(),r}}a(rO,"startService");async function SF(){try{let e=await tO(),t={};for(let r=0,n=e.length;r<n;r++){let s=e[r];t[s.name]===void 0&&(t[s.name]={name:s.name,exec_mode:s.pm2_env.exec_mode})}return t}catch(e){throw Xe?.disconnect(),e}}a(SF,"getUniqueServicesList");async function Hae(e=[]){try{let t=!1,r=await SF();for(let n=0,s=Object.values(r).length;n<s;n++){let o=Object.values(r)[n].name;e.includes(o)||(o===at.PROCESS_DESCRIPTORS.HDB?t=!0:await EF(o))}t&&await gF(at.PROCESS_DESCRIPTORS.HDB)}catch(t){throw Xe?.disconnect(),t}}a(Hae,"restartAllServices");async function TF(e){if(Jr?.find(r=>r.name===e))return!0;let t=await Nae.getHDBProcessInfo();return t.core.length&&t.core[0]?.parent==="PM2"}a(TF,"isServiceRegistered");async function gF(e){let t=Cm.get(at.CONFIG_PARAMS.THREADS_COUNT)??Cm.get(at.CONFIG_PARAMS.THREADS),r=await mF(e),n=yae.isEmptyOrZeroLength(r)?0:r.length;t!==n?(await eO(e),await rO(e)):e===at.PROCESS_DESCRIPTORS.HDB?await pF():await fF(e)}a(gF,"reloadStopStart");var AF;async function RF(e=!1){for(let t in at.CLUSTERING_PROCESSES){let r=at.CLUSTERING_PROCESSES[t];await rO(r,e)}}a(RF,"startClusteringProcesses");async function yF(){AF=dF(at.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE,{name:at.PROCESS_DESCRIPTORS.CLUSTERING_REPLY_SERVICE});try{await wm.deleteLocalStream("__HARPERDB_WORK_QUEUE__")}catch{}await wm.updateLocalStreams();let e=await bae.getAllNodeRecords();for(let t=0,r=e.length;t<r;t++)if(e[t].system_info?.hdb_version===at.PRE_4_0_0_VERSION){Vc.info("Starting clustering upgrade 4.0.0 process"),dF(at.LAUNCH_SERVICE_SCRIPTS.NODES_UPGRADE_4_0_0,{name:"Upgrade-4-0-0"});break}}a(yF,"startClusteringThreads");async function xae(){for(let e in at.CLUSTERING_PROCESSES)if(e!==at.CLUSTERING_PROCESSES.CLUSTERING_INGEST_PROC_DESCRIPTOR)if(e===at.CLUSTERING_PROCESSES.CLUSTERING_REPLY_SERVICE_DESCRIPTOR)await AF.terminate();else{let t=at.CLUSTERING_PROCESSES[e];await eO(t)}}a(xae,"stopClustering");async function kae(){for(let e in at.CLUSTERING_PROCESSES){let t=at.CLUSTERING_PROCESSES[e];if(await TF(t)===!1)return!1}return!0}a(kae,"isClusteringRunning");async function Fae(){await ho.generateNatsConfig(!0),await wm.reloadNATSHub(),await wm.reloadNATSLeaf(),await ho.removeNatsConfig(at.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase()),await ho.removeNatsConfig(at.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())}a(Fae,"reloadClustering")});var iO={};je(iO,{compactOnStart:()=>Gae,copyDb:()=>DF});async function Gae(){pa.notify("Running compact on start"),console.log("Running compact on start");let e=(0,nO.get)(ma.CONFIG_PARAMS.ROOTPATH),t=new Map,r=ut();(0,sO.updateConfigValue)(ma.CONFIG_PARAMS.STORAGE_COMPACTONSTART,!1);try{for(let n in r){if(n==="system"||n.endsWith("-copy"))continue;let s;for(let l in r[n]){s=r[n][l].primaryStore.path;break}if(!s){console.log("Couldn't find any tables in database",n);continue}let i=(0,Dm.join)(e,"backup",n+".mdb"),o=(0,Dm.join)(e,ma.DATABASES_DIR_NAME,n+"-copy.mdb"),c=0;try{c=await OF(n),console.log("Database",n,"before compact has a total record count of",c)}catch(l){pa.error("Error getting record count for database",n,l),console.error("Error getting record count for database",n,l)}t.set(n,{db_path:s,copy_dest:o,backup_dest:i,record_count:c}),await DF(n,o),console.log("Backing up",n,"to",i),await(0,Kc.move)(s,i,{overwrite:!0})}try{ku()}catch(n){pa.error("Error resetting databases after backup",n),console.error("Error resetting databases after backup",n)}for(let[n,{db_path:s,copy_dest:i}]of t)console.log("Moving copy compacted",n,"to",s),await(0,Kc.move)(i,s,{overwrite:!0}),await(0,Kc.remove)((0,Dm.join)(e,ma.DATABASES_DIR_NAME,`${n}-copy.mdb-lock`));try{ku()}catch(n){pa.error("Error resetting databases after backup",n),console.error("Error resetting databases after backup",n),process.exit(0)}}catch(n){pa.error("Error compacting database, rolling back operation",n),console.error("Error compacting database, rolling back operation",n),(0,sO.updateConfigValue)(ma.CONFIG_PARAMS.STORAGE_COMPACTONSTART,!1);for(let[s,{db_path:i,backup_dest:o}]of t){console.error("Moving backup database",o,"back to",i);try{await(0,Kc.move)(o,i,{overwrite:!0})}catch(c){console.error(c)}}throw ku(),n}for(let[n,{backup_dest:s,record_count:i}]of t){let o=!0,c=await OF(n);if(console.log("Database",n,"after compact has a total record count of",c),i!==c){o=!1;let l=`There is a discrepancy between pre and post compact record count for database ${n}.
|
|
16
16
|
Total record count before compaction: ${i}, total after: ${c}.
|
|
17
17
|
Database backup has not been removed and can be found here: ${s}`;pa.error(l),console.error(l)}(0,nO.get)(ma.CONFIG_PARAMS.STORAGE_COMPACTONSTARTKEEPBACKUP)===!0||o===!1||(console.log("Removing backup",s),await(0,Kc.remove)(s))}}async function OF(e){let t=await(0,CF.describeSchema)({database:e}),r=0;for(let n in t)r+=t[n].record_count;return r}async function DF(e,t){console.log("copyDb start");let r=ut()[e],n;for(let _ in r){n=r[_].primaryStore.rootStore;break}let s=n.dbisDb,i=n.auditStore,o=(0,NF.open)(new IF.default(t)),c=o.openDB(Pm.INTERNAL_DBIS_NAME),l,u=0,d=s.useReadTransaction();try{for(let{key:E,value:f}of s.getRange({transaction:d})){let h=f.is_hash_attribute||f.isPrimaryKey,T,m;if(h&&(T=f.compression,m=Lm(),m?f.compression=m:delete f.compression,T?.dictionary?.toString()===m?.dictionary?.toString()&&(T=null,m=null)),c.put(E,f),!(h||f.indexed))continue;let g=new wF.default(!h,h);g.encoding="binary",g.compression=T;let S=n.openDB(E,g);S.decoder=null,S.decoderCopies=!1,S.encoding="binary",g.compression=m;let y=o.openDB(E,g);y.encoder=null,console.log("copying",E,"from",e,"to",t),await _(S,y,h,d)}if(i){let E=n.openDB(Pm.AUDIT_STORE_NAME,Pf);console.log("copying audit log for",e,"to",t),_(i,E,!1,d)}async function _(E,f,h,T){let m=0,g=0,S=1e7,y=null;for(;S-- >0;)try{for(let I of E.getKeys({start:y,transaction:T}))try{y=I;let{value:U,version:H}=E.getEntry(I,{transaction:T});l=f.put(I,U,h?H:void 0),m++,T.openTimer&&(T.openTimer=0),g+=(I?.length||10)+U.length,u++>5e3&&(await l,console.log("copied",m,"entries",g,"bytes"),u=0)}catch(U){console.error("Error copying record",typeof I=="symbol"?"symbol":I,"from",e,"to",t,U)}console.log("finish copying, copied",m,"entries",g,"bytes");return}catch{if(typeof y=="string"){if(y==="z")return console.error("Reached end of dbi",y,"for",e,"to",t);y=y.slice(0,-2)+"z"}else if(typeof y=="number")y++;else return console.error("Unknown key type",y,"for",e,"to",t)}}a(_,"copyDbi"),await l,console.log("copied database "+e+" to "+t)}finally{d.done(),o.close()}}var NF,Dm,Kc,nO,IF,wF,Pm,ma,CF,sO,pa,oO=Ie(()=>{Pe();NF=require("lmdb"),Dm=require("path"),Kc=require("fs-extra"),nO=L(se()),IF=L(l_()),wF=L(c_()),Pm=L(Ht()),ma=L(M());Ji();CF=L(ro()),sO=L(wt()),pa=L(W());a(Gae,"compactOnStart");a(OF,"getTotalDBRecordCount");a(DF,"copyDb")});var qu=N((bCe,HF)=>{"use strict";var qae=require("minimist"),{isMainThread:cO,parentPort:Mf,threadId:ACe}=require("worker_threads"),Pt=M(),{PROCESS_DESCRIPTORS_VALIDATE:Fu}=Pt,Pi=W(),lO=te(),Um=Om(),Mm=mr(),RCe=Ct(),UF=wt(),ei=xu(),PF=Cu(),{compactOnStart:$ae}=(oO(),oe(iO)),Vae=ja(),{restartWorkers:vm,onMessageByType:Kae}=dt(),{handleHDBError:Yae,hdb_errors:Wae}=_e(),{HTTP_STATUS_CODES:jae}=Wae,Uf=se(),{sendOperationToNode:LF,getThisNodeName:zae,monitorNodeCAs:Qae}=(us(),oe(ca)),{getHDBNodeTable:yCe}=(lu(),oe(hB));Uf.initSync();var Lf=`Restarting HarperDB. This may take up to ${Pt.RESTART_TIMEOUT_MS/1e3} seconds.`,Jae="Restart is not available from the CLI when running in non-pm2 mode. Either call restart from the API or stop and start HarperDB.",MF="Clustering is not enabled so cannot be restarted",Xae="Invalid service",Gu,Ss;HF.exports={restart:vF,restartService:uO};cO&&Kae(Pt.ITC_EVENT_TYPES.RESTART,async(e,t)=>{e.workerType?await uO({service:e.workerType}):vF({operation:"restart"}),t.postMessage({type:"restart-complete"})});async function vF(e){Ss=Object.keys(e).length===0,Gu=await ei.isServiceRegistered(Pt.HDB_PROC_DESCRIPTOR);let t=qae(process.argv);if(t.service){await uO(t);return}if(Ss&&!Gu){console.error(Jae);return}if(Ss&&console.log(Lf),Gu){ei.enterPM2Mode(),Pi.notify(Lf);let r=Vae(Object.keys(Pt.CONFIG_PARAM_MAP),!0);return lO.isEmptyOrZeroLength(Object.keys(r))||UF.updateConfigValue(void 0,void 0,r,!0,!0),Zae(),Lf}return cO?(Pi.notify(Lf),Uf.get(Pt.CONFIG_PARAMS.STORAGE_COMPACTONSTART)&&await $ae(),setTimeout(()=>{vm()},50)):Mf.postMessage({type:Pt.ITC_EVENT_TYPES.RESTART}),Lf}a(vF,"restart");async function uO(e){let{service:t}=e;if(Pt.PROCESS_DESCRIPTORS_VALIDATE[t]===void 0)throw Yae(new Error,Xae,jae.BAD_REQUEST,void 0,void 0,!0);if(ei.expectedRestartOfChildren(),Gu=await ei.isServiceRegistered(Pt.HDB_PROC_DESCRIPTOR),!cO){e.replicated&&Qae(),Mf.postMessage({type:Pt.ITC_EVENT_TYPES.RESTART,workerType:t}),Mf.ref(),await new Promise(s=>{Mf.on("message",i=>{i.type==="restart-complete"&&(s(),Mf.unref())})});let n;if(e.replicated){e.replicated=!1,n=[];for(let s of server.nodes){if(s.name===zae())continue;let{job_id:i}=await LF(s,e);n.push(await new Promise((o,c)=>{let u=2400,d=setInterval(async()=>{if(u--<=0){clearInterval(d);let f=new Error("Timed out waiting for restart job to complete");f.replicated=n,c(f)}let E=(await LF(s,{operation:"get_job",id:i})).results[0];if(E.status==="COMPLETE"&&(clearInterval(d),o({node:s.name,message:E.message})),E.status==="ERROR"){clearInterval(d);let f=new Error(E.message);f.replicated=n,c(f)}},250)}))}return{replicated:n}}return}let r;switch(t){case Fu.clustering:if(!Uf.get(Pt.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=MF;break}Ss&&console.log("Restarting clustering"),Pi.notify("Restarting clustering"),await BF();break;case Fu.clustering_config:case Fu["clustering config"]:if(!Uf.get(Pt.CONFIG_PARAMS.CLUSTERING_ENABLED)){r=MF;break}Ss&&console.log("Restarting clustering_config"),Pi.notify("Restarting clustering_config"),await ei.reloadClustering();break;case"custom_functions":case"custom functions":case Fu.harperdb:case Fu.http_workers:case Fu.http:if(Ss&&!Gu){r=`Restart ${t} is not available from the CLI when running in non-pm2 mode. Either call restart ${t} from the API or stop and start HarperDB.`;break}Ss&&console.log("Restarting http_workers"),Pi.notify("Restarting http_workers"),Ss?await ei.restart(Pt.HDB_PROC_DESCRIPTOR):await vm("http");break;default:r=`Unrecognized service: ${t}`;break}return r?(Pi.error(r),Ss&&console.error(r),r):(t==="custom_functions"&&(t="Custom Functions"),`Restarting ${t}`)}a(uO,"restartService");async function Zae(){await BF(),await ei.restart(Pt.HDB_PROC_DESCRIPTOR),await lO.async_set_timeout(2e3),Uf.get(Pt.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await aO(),Ss&&(await Mm.closeConnection(),process.exit(0))}a(Zae,"restartPM2Mode");async function BF(){if(!UF.getConfigFromFile(Pt.CONFIG_PARAMS.CLUSTERING_ENABLED))return;if((await PF.getHDBProcessInfo()).clustering.length===0)Pi.trace("Clustering not running, restart will start clustering services"),await Um.generateNatsConfig(!0),await ei.startClusteringProcesses(),await ei.startClusteringThreads(),await aO(),Ss&&await Mm.closeConnection();else{await Um.generateNatsConfig(!0),Gu?(Pi.trace("Restart clustering restarting PM2 managed Hub and Leaf servers"),await ei.restart(Pt.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await ei.restart(Pt.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)):(await PF.getHDBProcessInfo()).clustering.forEach(s=>{Pi.trace("Restart clustering killing process pid",s.pid),process.kill(s.pid)}),await lO.async_set_timeout(3e3),await aO(),await Mm.updateLocalStreams(),Ss&&await Mm.closeConnection(),Pi.trace("Restart clustering restarting ingest and reply service threads");let t=vm(Pt.LAUNCH_SERVICE_SCRIPTS.NATS_INGEST_SERVICE),r=vm(Pt.LAUNCH_SERVICE_SCRIPTS.NATS_REPLY_SERVICE);await t,await r}}a(BF,"restartClustering");async function aO(){await Um.removeNatsConfig(Pt.PROCESS_DESCRIPTORS.CLUSTERING_HUB),await Um.removeNatsConfig(Pt.PROCESS_DESCRIPTORS.CLUSTERING_LEAF)}a(aO,"removeNatsConfig")});var jF=N((ICe,WF)=>{"use strict";var NCe=require("lodash"),gn=M(),{handleHDBError:xF,hdb_errors:ece}=_e(),{HDB_ERROR_MSGS:tce,HTTP_STATUS_CODES:rce}=ece,dO=W();WF.exports={getRolePermissions:sce};var Yc=Object.create(null),nce=a(e=>({key:e,perms:{}}),"perms_template_obj"),qF=a((e=!1)=>({describe:e,tables:{}}),"schema_perms_template"),$F=a((e=!1,t=!1,r=!1,n=!1)=>({[gn.PERMS_CRUD_ENUM.READ]:e,[gn.PERMS_CRUD_ENUM.INSERT]:t,[gn.PERMS_CRUD_ENUM.UPDATE]:r,[gn.PERMS_CRUD_ENUM.DELETE]:n}),"permissions_template"),_O=a((e=!1,t=!1,r=!1,n=!1,s=!1)=>({attribute_permissions:[],describe:e,...$F(t,r,n,s)}),"table_perms_template"),kF=a((e,t=$F())=>({attribute_name:e,describe:YF(t),[vf]:t[vf],[fO]:t[fO],[EO]:t[EO]}),"attr_perms_template"),FF=a((e,t=!1)=>({attribute_name:e,describe:t,[vf]:t}),"timestamp_attr_perms_template"),{READ:vf,INSERT:fO,UPDATE:EO}=gn.PERMS_CRUD_ENUM,VF=Object.values(gn.PERMS_CRUD_ENUM),KF=[vf,fO,EO];function sce(e){let t;try{if(e.permission.super_user||e.permission.cluster_user)return e.permission;let r={...global.hdb_schema};delete r[gn.SYSTEM_SCHEMA_NAME],t=e.role;let n=JSON.stringify([e.__updatedtime__,r]);if(Yc[t]&&Yc[t].key===n)return Yc[t].perms;let s=ice(e,r);return Yc[t]?Yc[t].key=n:Yc[t]=nce(n),Yc[t].perms=s,s}catch(r){if(!e[gn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]||e[gn.TIME_STAMP_NAMES_ENUM.UPDATED_TIME]<gn.PERMS_UPDATE_RELEASE_TIMESTAMP){let n=`Role permissions for role '${t}' must be updated to align with new structure from the 2.2.0 release.`;throw dO.error(n),dO.debug(r),xF(new Error,tce.OUTDATED_PERMS_TRANSLATION_ERROR,rce.BAD_REQUEST)}else{let n=`There was an error while translating role permissions for role: ${t}.
|
|
18
|
-
${r.stack}`;throw dO.error(n),xF(new Error)}}}a(sce,"getRolePermissions");function ice(e,t){let r=Object.create(null);r.super_user=!1;let n=e.permission;r[gn.SYSTEM_SCHEMA_NAME]=n[gn.SYSTEM_SCHEMA_NAME],r.structure_user=n.structure_user;let s=Array.isArray(e.permission.structure_user)||e.permission.structure_user===!0?e.permission.structure_user:[];return Object.keys(t).forEach(i=>{if(s===!0||s.indexOf(i)>-1){r[i]=oce(t[i]);return}r[i]=qF(),n[i]?(n[i].describe&&(r[i].describe=!0),Object.keys(t[i]).forEach(o=>{if(n[i].tables[o]){let c=n[i].tables[o],l=t[i][o],u=ace(c,l);r[i].describe||VF.forEach(d=>{u[d]&&(r[i].describe=!0)}),r[i].tables[o]=u}else r[i].tables[o]=_O()})):Object.keys(t[i]).forEach(o=>{r[i].tables[o]=_O()})}),r}a(ice,"translateRolePermissions");function oce(e){let t=qF(!0);return Object.keys(e).forEach(r=>{t.tables[r]=_O(!0,!0,!0,!0,!0)}),t}a(oce,"createStructureUserPermissions");function ace(e,t){let{attribute_permissions:r}=e;if(r?.length>0){let s={...e};s.attribute_permissions=[];let i=r.reduce((u,d)=>{let{attribute_name:_}=d,E=d;return gn.TIME_STAMP_NAMES.includes(_)&&(E=FF(_,d[vf])),u[_]=E,u},{}),o=t.primaryKey||t.hash_attribute,c=!!i[o],l=kF(o);return t.attributes.forEach(({attribute:u})=>{if(i[u]){let d=i[u];d.describe=YF(d),s.attribute_permissions.push(d),c||cce(d,l)}else if(u!==o){let d;gn.TIME_STAMP_NAMES.includes(u)?d=FF(u):d=kF(u),s.attribute_permissions.push(d)}}),c||s.attribute_permissions.push(l),s.describe=GF(s),s}else return e.describe=GF(e),e}a(ace,"getTableAttrPerms");function GF(e){return VF.filter(t=>e[t]).length>0}a(GF,"getSchemaTableDescribePerm");function YF(e){return KF.filter(t=>e[t]).length>0}a(YF,"getAttributeDescribePerm");function cce(e,t){KF.forEach(r=>{e[r]&&!t[r]&&(t[r]=!0,t.describe=!0)})}a(cce,"checkForHashPerms")});var zF={};je(zF,{Headers:()=>mo,appendHeader:()=>Bm,mergeHeaders:()=>hO});function Bm(e,t,r,n){if(e.append)e.append(t,r,n);else if(e.set){let s=e.get(t);if(s)if(n)r=(typeof s=="string"?s:s.join(", "))+", "+r;else if(typeof s=="string")r=[s,r];else{s.push(r);return}return e.set(t,r)}else e[t]=(e[t]?e[t]+", ":"")+r}function hO(e,t){(typeof e.set!="function"||typeof e.has!="function")&&(e=new mo(e));for(let[r,n]of t)e.has(r)?r.toLowerCase()==="set-cookie"&&e.append?.(r,n,!0):e.set(r,n);return e}var mo,Bf=Ie(()=>{mo=class extends Map{static{a(this,"Headers")}constructor(t){if(t)if(t[Symbol.iterator])super(t);else{super();for(let r in t)this.set(r,t[r])}else super()}set(t,r){return typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r),super.set(t.toLowerCase(),[t,r])}get(t){return typeof t!="string"&&(t=""+t),super.get(t.toLowerCase())?.[1]}has(t){return typeof t!="string"&&(t=""+t),super.has(t.toLowerCase())}setIfNone(t,r){typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r);let n=t.toLowerCase();if(!super.has(n))return super.set(n,[t,r])}append(t,r,n){typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r);let s=t.toLowerCase(),i=super.get(s);if(i){let o=i[1];if(n)r=(typeof o=="string"?o:o.join(", "))+", "+r;else if(typeof o=="string")r=[o,r];else{o.push(r);return}}return super.set(s,[t,r])}[Symbol.iterator](){return super.values()[Symbol.iterator]()}};a(Bm,"appendHeader");a(hO,"mergeHeaders")});var Hf={};je(Hf,{authentication:()=>rG,bypassAuth:()=>hce,login:()=>mce,logout:()=>Sce,start:()=>pce});function hce(){tG=!0}async function rG(e,t){let r=e.headers.asObject,n=r.authorization,s=r.cookie,i=r.origin,o=[];try{if(i){let f=e.isOperationsServer?_ce?dce:[]:uce?lce:[];if(f.includes(i)||f.includes("*")){if(e.method==="OPTIONS"){let h=new mo([["Access-Control-Allow-Methods","POST, GET, PUT, DELETE, PATCH, OPTIONS"],["Access-Control-Allow-Headers","Accept, Content-Type, Authorization"],["Access-Control-Allow-Origin",i]]);return Hm&&h.set("Access-Control-Allow-Credentials","true"),{status:200,headers:h}}o.push("Access-Control-Allow-Origin",i),Hm&&o.push("Access-Control-Allow-Credentials","true")}}let l,u;if(Hm){i||(i=r.host);let f=(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session=",h=s?.split(/;\s+/)||[];for(let T of h)if(T.startsWith(f)){let m=T.indexOf(";");l=T.slice(f.length,m===-1?T.length:m),u=await QF.get(l);break}e.session=u||(u={})}let d=a((f,h,T)=>{let m=new $u.AuthAuditLog(f,h,Or.AUTH_AUDIT_TYPES.AUTHENTICATION,r["x-forwarded-for"]??e.ip,e.method,e.pathname);m.auth_strategy=T,l&&(m.session_id=l),r.referer&&(m.referer=r.referer),r.origin&&(m.origin=r.origin),h===Or.AUTH_AUDIT_STATUS.SUCCESS?pO.notify(m):pO.error(m)},"authAuditLog");if(!e.authorized&&e.mtlsConfig&&e.peerCertificate.subject&&e?._nodeRequest?.socket?.authorizationError&&pO.error("Authorization error:",e._nodeRequest.socket.authorizationError),e.mtlsConfig&&e.authorized&&e.peerCertificate.subject){let f=e.mtlsConfig.user;f!==null?((f===void 0||f==="Common Name"||f==="CN")&&(f=e.peerCertificate.subject.CN),e.user=await it.getUser(f,null,e),d(f,Or.AUTH_AUDIT_STATUS.SUCCESS,"mTLS")):(0,$u.debug)("HTTPS/WSS mTLS authorized connection (mTLS did not authorize a user)","from",e.ip)}let _;if(!e.user)if(n){if(_=Wc.get(n),!_){let f=n.indexOf(" "),h=n.slice(0,f),T=n.slice(f+1),m,g;try{switch(h){case"Basic":let S=atob(T),y=S.indexOf(":");m=S.slice(0,y),g=S.slice(y+1),_=m||g?await it.getUser(m,g,e):null;break;case"Bearer":try{_=await(0,xm.validateOperationToken)(T)}catch(I){if(I.message==="invalid token")try{return await(0,xm.validateRefreshToken)(T),c({status:-1})}catch{throw I}}break}}catch(S){return Ece&&(Wc.get(T)||(Wc.set(T,T),d(m,Or.AUTH_AUDIT_STATUS.FAILURE,h))),c({status:401,body:jc({error:S.message},e)})}Wc.set(n,_),fce&&d(_.username,Or.AUTH_AUDIT_STATUS.SUCCESS,h)}e.user=_}else u?.user?e.user=await it.getUser(u.user,null,e):(tG&&(e.ip?.includes("127.0.0.")||e.ip=="::1")||e?._nodeRequest?.socket?.server?._pipeName&&e.ip===void 0)&&(e.user=await(0,XF.getSuperUser)());Hm&&(e.session.update=function(f){if(!l){l=(0,ZF.v4)();let T=`${(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session="}${l}; Path=/; Expires=Tue, 01 Oct 8307 19:33:20 GMT; HttpOnly${e.protocol==="https"?"; SameSite=None; Secure":""}`;o?o.push("Set-Cookie",T):E?.headers?.set&&E.headers.set("Set-Cookie",T)}return e.protocol==="https"&&(o?(i&&o.push("Access-Control-Expose-Headers","X-Hdb-Session"),o.push("X-Hdb-Session","Secure")):E?.headers?.set&&(i&&E.headers.set("Access-Control-Expose-Headers","X-Hdb-Session"),E.headers.set("X-Hdb-Session","Secure"))),f.id=l,QF.put(f)},e.login=async function(f,h){e.user=await it.getUser(f,h,e),e.session.update({user:e.user&&(e.user.getId?.()??e.user.username)})});let E=await t(e);return E&&(E.status===401&&(r["user-agent"]?.startsWith("Mozilla")&&r.accept?.startsWith("text/html")&&wi.loginPath?(E.status=302,E.headers.set("Location",wi.loginPath(e))):E.headers.set("WWW-Authenticate","Basic")),c(E))}catch(l){throw c(l)}function c(l){let u=o.length;if(u>0){let d=l.headers;d||(l.headers=d=new mo);for(let _=0;_<u;){let E=o[_++];d.set(E,o[_++])}}return o=null,l}a(c,"applyResponseHeaders")}function pce({server:e,port:t,securePort:r}){e.http(rG,t||r?{port:t,securePort:r}:{port:"all"}),JF||(JF=!0,setInterval(()=>{Wc=new Map},Ts.get(Or.CONFIG_PARAMS.AUTHENTICATION_CACHETTL)).unref(),eG.user.addListener(()=>{Wc=new Map}))}async function mce(e){if(!e.baseRequest?.login)throw new Error("No session for login");return e.baseResponse.headers.set=(t,r)=>{e.fastifyResponse.header(t,r)},await e.baseRequest.login(e.username,e.password),"Login successful"}async function Sce(e){if(!e.baseRequest.session)throw new Error("No session for logout");return await e.baseRequest.session.update({user:null}),"Logout successful"}var XF,xm,ZF,Ts,Or,$u,eG,pO,lce,uce,dce,_ce,QF,Hm,tG,fce,Ece,Wc,JF,km=Ie(()=>{XF=L(xn());qr();su();xm=L(fu());Pe();ZF=require("uuid"),Ts=L(se()),Or=L(M()),$u=L(W()),eG=L(T_());Bf();zc();pO=(0,$u.loggerWithTag)("auth-event");Ts.initSync();lce=Ts.get(Or.CONFIG_PARAMS.HTTP_CORSACCESSLIST),uce=Ts.get(Or.CONFIG_PARAMS.HTTP_CORS),dce=Ts.get(Or.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORSACCESSLIST),_ce=Ts.get(Or.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORS),QF=Et({table:"hdb_session",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"user"}]}),Hm=Ts.get(Or.CONFIG_PARAMS.AUTHENTICATION_ENABLESESSIONS)??!0,tG=process.env.AUTHENTICATION_AUTHORIZELOCAL??Ts.get(Or.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE,fce=Ts.get(Or.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)??!1,Ece=Ts.get(Or.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)??!1,Wc=new Map;it.onInvalidatedUser(()=>{Wc=new Map});a(hce,"bypassAuth");a(rG,"authentication");a(pce,"start");a(mce,"login");a(Sce,"logout")});var lG=N((BCe,cG)=>{"use strict";var ye=require("joi"),nG=require("fs-extra"),sG=require("path"),Yn=Tt(),iG=se(),oG=M(),aG=W(),{hdb_errors:Tce}=_e(),{HDB_ERROR_MSGS:Xr}=Tce,So=/^[a-zA-Z0-9-_]+$/,gce=/^[a-zA-Z0-9-_]+$/;cG.exports={getDropCustomFunctionValidator:Rce,setCustomFunctionValidator:yce,addComponentValidator:Ice,dropCustomFunctionProjectValidator:wce,packageComponentValidator:Cce,deployComponentValidator:Dce,setComponentFileValidator:bce,getComponentFileValidator:Nce,dropComponentFileValidator:Oce,addSSHKeyValidator:Pce,updateSSHKeyValidator:Lce,deleteSSHKeyValidator:Mce,setSSHKnownHostsValidator:Uce};function Fm(e,t,r){try{let n=iG.get(oG.CONFIG_PARAMS.COMPONENTSROOT),s=sG.join(n,t);return nG.existsSync(s)?e?t:r.message(Xr.PROJECT_EXISTS):e?r.message(Xr.NO_PROJECT):t}catch(n){return aG.error(n),r.message(Xr.VALIDATION_ERR)}}a(Fm,"checkProjectExists");function xf(e,t){return e.includes("..")?t.message("Invalid file path"):e}a(xf,"checkFilePath");function Ace(e,t,r,n){try{let s=iG.get(oG.CONFIG_PARAMS.COMPONENTSROOT),i=sG.join(s,e,t,r+".js");return nG.existsSync(i)?r:n.message(Xr.NO_FILE)}catch(s){return aG.error(s),n.message(Xr.VALIDATION_ERR)}}a(Ace,"checkFileExists");function Rce(e){let t=ye.object({project:ye.string().pattern(So).custom(Fm.bind(null,!0)).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),type:ye.string().valid("helpers","routes").required(),file:ye.string().pattern(So).custom(Ace.bind(null,e.project,e.type)).custom(xf).required().messages({"string.pattern.base":Xr.BAD_FILE_NAME})});return Yn.validateBySchema(e,t)}a(Rce,"getDropCustomFunctionValidator");function yce(e){let t=ye.object({project:ye.string().pattern(So).custom(Fm.bind(null,!0)).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),type:ye.string().valid("helpers","routes").required(),file:ye.string().custom(xf).required(),function_content:ye.string().required()});return Yn.validateBySchema(e,t)}a(yce,"setCustomFunctionValidator");function bce(e){let t=ye.object({project:ye.string().pattern(So).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),file:ye.string().custom(xf).required(),payload:ye.string().allow("").optional(),encoding:ye.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return Yn.validateBySchema(e,t)}a(bce,"setComponentFileValidator");function Oce(e){let t=ye.object({project:ye.string().pattern(So).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),file:ye.string().custom(xf).optional()});return Yn.validateBySchema(e,t)}a(Oce,"dropComponentFileValidator");function Nce(e){let t=ye.object({project:ye.string().required(),file:ye.string().custom(xf).required(),encoding:ye.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return Yn.validateBySchema(e,t)}a(Nce,"getComponentFileValidator");function Ice(e){let t=ye.object({project:ye.string().pattern(So).custom(Fm.bind(null,!1)).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME})});return Yn.validateBySchema(e,t)}a(Ice,"addComponentValidator");function wce(e){let t=ye.object({project:ye.string().pattern(So).custom(Fm.bind(null,!0)).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME})});return Yn.validateBySchema(e,t)}a(wce,"dropCustomFunctionProjectValidator");function Cce(e){let t=ye.object({project:ye.string().pattern(So).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),skip_node_modules:ye.boolean(),skip_symlinks:ye.boolean()});return Yn.validateBySchema(e,t)}a(Cce,"packageComponentValidator");function Dce(e){let t=ye.object({project:ye.string().pattern(So).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),package:ye.string().optional(),restart:ye.alternatives().try(ye.boolean(),ye.string().valid("rolling")).optional()});return Yn.validateBySchema(e,t)}a(Dce,"deployComponentValidator");function Pce(e){let t=ye.object({name:ye.string().pattern(gce).required().messages({"string.pattern.base":Xr.BAD_SSH_KEY_NAME}),key:ye.string().required(),host:ye.string().required(),hostname:ye.string().required(),known_hosts:ye.string().optional()});return Yn.validateBySchema(e,t)}a(Pce,"addSSHKeyValidator");function Lce(e){let t=ye.object({name:ye.string().required(),key:ye.string().required()});return Yn.validateBySchema(e,t)}a(Lce,"updateSSHKeyValidator");function Mce(e){let t=ye.object({name:ye.string().required()});return Yn.validateBySchema(e,t)}a(Mce,"deleteSSHKeyValidator");function Uce(e){let t=ye.object({known_hosts:ye.string().required()});return Yn.validateBySchema(e,t)}a(Uce,"setSSHKnownHostsValidator")});var kf=N((xCe,hG)=>{"use strict";var Gm=require("joi"),Sa=require("path"),Vu=require("fs-extra"),{exec:vce}=require("child_process"),Bce=require("util"),uG=Bce.promisify(vce),Qc=M(),{handleHDBError:Ku,hdb_errors:Hce}=_e(),{HTTP_STATUS_CODES:Yu}=Hce,Jc=se(),xce=Tt(),Xc=W();Jc.initSync();var mO=Jc.get(Qc.CONFIG_PARAMS.COMPONENTSROOT),dG="npm install --force --omit=dev --json",kce=`${dG} --dry-run`,Fce=Jc.get(Qc.CONFIG_PARAMS.ROOTPATH),qm=Sa.join(Fce,"ssh");hG.exports={installModules:Vce,auditModules:Kce,installAllRootModules:Gce,uninstallRootModule:qce,linkHarperdb:$ce,runCommand:Wu};async function Gce(e=!1,t=Jc.get(Qc.CONFIG_PARAMS.ROOTPATH)){await $m();let r=!1,n=process.env;Vu.pathExistsSync(qm)&&Vu.readdirSync(qm).forEach(s=>{s.includes(".key")&&!r&&(n={GIT_SSH_COMMAND:"ssh -F "+Sa.join(qm,"config")+" -o UserKnownHostsFile="+Sa.join(qm,"known_hosts"),...process.env},r=!0)});try{let s=Jc.get(Qc.CONFIG_PARAMS.ROOTPATH),i=Sa.join(s,"node_modules","harperdb");Vu.lstatSync(i).isSymbolicLink()&&Vu.unlinkSync(i)}catch(s){s.code!=="ENOENT"&&Xc.error("Error removing symlink:",s)}await Wu(e?"npm install --force --ignore-scripts":"npm install --force",t,n)}a(Gce,"installAllRootModules");async function qce(e){await Wu(`npm uninstall ${e}`,Jc.get(Qc.CONFIG_PARAMS.ROOTPATH))}a(qce,"uninstallRootModule");async function $ce(){await $m(),await Wu(`npm link ${Qc.PACKAGE_ROOT}`,Jc.get(Qc.CONFIG_PARAMS.ROOTPATH))}a($ce,"linkHarperdb");async function Wu(e,t=void 0,r=process.env){let n,s;try{({stdout:n,stderr:s}=await uG(e,{cwd:t,env:r}))}catch(i){throw new Error(i.stderr.replace(`
|
|
18
|
+
${r.stack}`;throw dO.error(n),xF(new Error)}}}a(sce,"getRolePermissions");function ice(e,t){let r=Object.create(null);r.super_user=!1;let n=e.permission;r[gn.SYSTEM_SCHEMA_NAME]=n[gn.SYSTEM_SCHEMA_NAME],r.structure_user=n.structure_user;let s=Array.isArray(e.permission.structure_user)||e.permission.structure_user===!0?e.permission.structure_user:[];return Object.keys(t).forEach(i=>{if(s===!0||s.indexOf(i)>-1){r[i]=oce(t[i]);return}r[i]=qF(),n[i]?(n[i].describe&&(r[i].describe=!0),Object.keys(t[i]).forEach(o=>{if(n[i].tables[o]){let c=n[i].tables[o],l=t[i][o],u=ace(c,l);r[i].describe||VF.forEach(d=>{u[d]&&(r[i].describe=!0)}),r[i].tables[o]=u}else r[i].tables[o]=_O()})):Object.keys(t[i]).forEach(o=>{r[i].tables[o]=_O()})}),r}a(ice,"translateRolePermissions");function oce(e){let t=qF(!0);return Object.keys(e).forEach(r=>{t.tables[r]=_O(!0,!0,!0,!0,!0)}),t}a(oce,"createStructureUserPermissions");function ace(e,t){let{attribute_permissions:r}=e;if(r?.length>0){let s={...e};s.attribute_permissions=[];let i=r.reduce((u,d)=>{let{attribute_name:_}=d,E=d;return gn.TIME_STAMP_NAMES.includes(_)&&(E=FF(_,d[vf])),u[_]=E,u},{}),o=t.primaryKey||t.hash_attribute,c=!!i[o],l=kF(o);return t.attributes.forEach(({attribute:u})=>{if(i[u]){let d=i[u];d.describe=YF(d),s.attribute_permissions.push(d),c||cce(d,l)}else if(u!==o){let d;gn.TIME_STAMP_NAMES.includes(u)?d=FF(u):d=kF(u),s.attribute_permissions.push(d)}}),c||s.attribute_permissions.push(l),s.describe=GF(s),s}else return e.describe=GF(e),e}a(ace,"getTableAttrPerms");function GF(e){return VF.filter(t=>e[t]).length>0}a(GF,"getSchemaTableDescribePerm");function YF(e){return KF.filter(t=>e[t]).length>0}a(YF,"getAttributeDescribePerm");function cce(e,t){KF.forEach(r=>{e[r]&&!t[r]&&(t[r]=!0,t.describe=!0)})}a(cce,"checkForHashPerms")});var zF={};je(zF,{Headers:()=>mo,appendHeader:()=>Bm,mergeHeaders:()=>hO});function Bm(e,t,r,n){if(e.append)e.append(t,r,n);else if(e.set){let s=e.get(t);if(s)if(n)r=(typeof s=="string"?s:s.join(", "))+", "+r;else if(typeof s=="string")r=[s,r];else{s.push(r);return}return e.set(t,r)}else e[t]=(e[t]?e[t]+", ":"")+r}function hO(e,t){(typeof e.set!="function"||typeof e.has!="function")&&(e=new mo(e));for(let[r,n]of t)e.has(r)?r.toLowerCase()==="set-cookie"&&e.append?.(r,n,!0):e.set(r,n);return e}var mo,Bf=Ie(()=>{mo=class extends Map{static{a(this,"Headers")}constructor(t){if(t)if(t[Symbol.iterator])super(t);else{super();for(let r in t)this.set(r,t[r])}else super()}set(t,r){return typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r),super.set(t.toLowerCase(),[t,r])}get(t){return typeof t!="string"&&(t=""+t),super.get(t.toLowerCase())?.[1]}has(t){return typeof t!="string"&&(t=""+t),super.has(t.toLowerCase())}setIfNone(t,r){typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r);let n=t.toLowerCase();if(!super.has(n))return super.set(n,[t,r])}append(t,r,n){typeof t!="string"&&(t=""+t),typeof r!="string"&&(r=""+r);let s=t.toLowerCase(),i=super.get(s);if(i){let o=i[1];if(n)r=(typeof o=="string"?o:o.join(", "))+", "+r;else if(typeof o=="string")r=[o,r];else{o.push(r);return}}return super.set(s,[t,r])}[Symbol.iterator](){return super.values()[Symbol.iterator]()}};a(Bm,"appendHeader");a(hO,"mergeHeaders")});var Hf={};je(Hf,{authentication:()=>rG,bypassAuth:()=>hce,login:()=>mce,logout:()=>Sce,start:()=>pce});function hce(){tG=!0}async function rG(e,t){let r=e.headers.asObject,n=r.authorization,s=r.cookie,i=r.origin,o=[];try{if(i){let f=e.isOperationsServer?_ce?dce:[]:uce?lce:[];if(f.includes(i)||f.includes("*")){if(e.method==="OPTIONS"){let h=new mo([["Access-Control-Allow-Methods","POST, GET, PUT, DELETE, PATCH, OPTIONS"],["Access-Control-Allow-Headers","Accept, Content-Type, Authorization"],["Access-Control-Allow-Origin",i]]);return Hm&&h.set("Access-Control-Allow-Credentials","true"),{status:200,headers:h}}o.push("Access-Control-Allow-Origin",i),Hm&&o.push("Access-Control-Allow-Credentials","true")}}let l,u;if(Hm){i||(i=r.host);let f=(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session=",h=s?.split(/;\s+/)||[];for(let T of h)if(T.startsWith(f)){let m=T.indexOf(";");l=T.slice(f.length,m===-1?T.length:m),u=await QF.get(l);break}e.session=u||(u={})}let d=a((f,h,T)=>{let m=new $u.AuthAuditLog(f,h,Or.AUTH_AUDIT_TYPES.AUTHENTICATION,r["x-forwarded-for"]??e.ip,e.method,e.pathname);m.auth_strategy=T,l&&(m.session_id=l),r.referer&&(m.referer=r.referer),r.origin&&(m.origin=r.origin),h===Or.AUTH_AUDIT_STATUS.SUCCESS?pO.notify(m):pO.error(m)},"authAuditLog");if(!e.authorized&&e.mtlsConfig&&e.peerCertificate.subject&&e?._nodeRequest?.socket?.authorizationError&&pO.error("Authorization error:",e._nodeRequest.socket.authorizationError),e.mtlsConfig&&e.authorized&&e.peerCertificate.subject){let f=e.mtlsConfig.user;f!==null?((f===void 0||f==="Common Name"||f==="CN")&&(f=e.peerCertificate.subject.CN),e.user=await it.getUser(f,null,e),d(f,Or.AUTH_AUDIT_STATUS.SUCCESS,"mTLS")):(0,$u.debug)("HTTPS/WSS mTLS authorized connection (mTLS did not authorize a user)","from",e.ip)}let _;if(!e.user)if(n){if(_=Wc.get(n),!_){let f=n.indexOf(" "),h=n.slice(0,f),T=n.slice(f+1),m,g;try{switch(h){case"Basic":let S=atob(T),y=S.indexOf(":");m=S.slice(0,y),g=S.slice(y+1),_=m||g?await it.getUser(m,g,e):null;break;case"Bearer":try{_=await(0,xm.validateOperationToken)(T)}catch(I){if(I.message==="invalid token")try{return await(0,xm.validateRefreshToken)(T),c({status:-1})}catch{throw I}}break}}catch(S){return Ece&&(Wc.get(T)||(Wc.set(T,T),d(m,Or.AUTH_AUDIT_STATUS.FAILURE,h))),c({status:401,body:jc({error:S.message},e)})}Wc.set(n,_),fce&&d(_.username,Or.AUTH_AUDIT_STATUS.SUCCESS,h)}e.user=_}else u?.user?e.user=await it.getUser(u.user,null,e):(tG&&(e.ip?.includes("127.0.0.")||e.ip=="::1")||e?._nodeRequest?.socket?.server?._pipeName&&e.ip===void 0)&&(e.user=await(0,XF.getSuperUser)());Hm&&(e.session.update=function(f){if(!l){l=(0,ZF.v4)();let T=`${(i?i.replace(/^https?:\/\//,"").replace(/\W/,"_")+"-":"")+"hdb-session="}${l}; Path=/; Expires=Tue, 01 Oct 8307 19:33:20 GMT; HttpOnly${e.protocol==="https"?"; SameSite=None; Secure":""}`;o?o.push("Set-Cookie",T):E?.headers?.set&&E.headers.set("Set-Cookie",T)}return e.protocol==="https"&&(o?(i&&o.push("Access-Control-Expose-Headers","X-Hdb-Session"),o.push("X-Hdb-Session","Secure")):E?.headers?.set&&(i&&E.headers.set("Access-Control-Expose-Headers","X-Hdb-Session"),E.headers.set("X-Hdb-Session","Secure"))),f.id=l,QF.put(f)},e.login=async function(f,h){e.user=await it.getUser(f,h,e),e.session.update({user:e.user&&(e.user.getId?.()??e.user.username)})});let E=await t(e);return E&&(E.status===401&&(r["user-agent"]?.startsWith("Mozilla")&&r.accept?.startsWith("text/html")&&wi.loginPath?(E.status=302,E.headers.set("Location",wi.loginPath(e))):E.headers.set("WWW-Authenticate","Basic")),c(E))}catch(l){throw c(l)}function c(l){let u=o.length;if(u>0){let d=l.headers;d||(l.headers=d=new mo);for(let _=0;_<u;){let E=o[_++];d.set(E,o[_++])}}return o=null,l}a(c,"applyResponseHeaders")}function pce({server:e,port:t,securePort:r}){e.http(rG,t||r?{port:t,securePort:r}:{port:"all"}),JF||(JF=!0,setInterval(()=>{Wc=new Map},Ts.get(Or.CONFIG_PARAMS.AUTHENTICATION_CACHETTL)).unref(),eG.user.addListener(()=>{Wc=new Map}))}async function mce(e){if(!e.baseRequest?.login)throw new Error("No session for login");return e.baseResponse.headers.set=(t,r)=>{e.fastifyResponse.header(t,r)},await e.baseRequest.login(e.username,e.password??""),"Login successful"}async function Sce(e){if(!e.baseRequest.session)throw new Error("No session for logout");return await e.baseRequest.session.update({user:null}),"Logout successful"}var XF,xm,ZF,Ts,Or,$u,eG,pO,lce,uce,dce,_ce,QF,Hm,tG,fce,Ece,Wc,JF,km=Ie(()=>{XF=L(xn());qr();su();xm=L(fu());Pe();ZF=require("uuid"),Ts=L(se()),Or=L(M()),$u=L(W()),eG=L(T_());Bf();zc();pO=(0,$u.loggerWithTag)("auth-event");Ts.initSync();lce=Ts.get(Or.CONFIG_PARAMS.HTTP_CORSACCESSLIST),uce=Ts.get(Or.CONFIG_PARAMS.HTTP_CORS),dce=Ts.get(Or.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORSACCESSLIST),_ce=Ts.get(Or.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_CORS),QF=Et({table:"hdb_session",database:"system",attributes:[{name:"id",isPrimaryKey:!0},{name:"user"}]}),Hm=Ts.get(Or.CONFIG_PARAMS.AUTHENTICATION_ENABLESESSIONS)??!0,tG=process.env.AUTHENTICATION_AUTHORIZELOCAL??Ts.get(Or.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE,fce=Ts.get(Or.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)??!1,Ece=Ts.get(Or.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)??!1,Wc=new Map;it.onInvalidatedUser(()=>{Wc=new Map});a(hce,"bypassAuth");a(rG,"authentication");a(pce,"start");a(mce,"login");a(Sce,"logout")});var lG=N((BCe,cG)=>{"use strict";var ye=require("joi"),nG=require("fs-extra"),sG=require("path"),Yn=Tt(),iG=se(),oG=M(),aG=W(),{hdb_errors:Tce}=_e(),{HDB_ERROR_MSGS:Xr}=Tce,So=/^[a-zA-Z0-9-_]+$/,gce=/^[a-zA-Z0-9-_]+$/;cG.exports={getDropCustomFunctionValidator:Rce,setCustomFunctionValidator:yce,addComponentValidator:Ice,dropCustomFunctionProjectValidator:wce,packageComponentValidator:Cce,deployComponentValidator:Dce,setComponentFileValidator:bce,getComponentFileValidator:Nce,dropComponentFileValidator:Oce,addSSHKeyValidator:Pce,updateSSHKeyValidator:Lce,deleteSSHKeyValidator:Mce,setSSHKnownHostsValidator:Uce};function Fm(e,t,r){try{let n=iG.get(oG.CONFIG_PARAMS.COMPONENTSROOT),s=sG.join(n,t);return nG.existsSync(s)?e?t:r.message(Xr.PROJECT_EXISTS):e?r.message(Xr.NO_PROJECT):t}catch(n){return aG.error(n),r.message(Xr.VALIDATION_ERR)}}a(Fm,"checkProjectExists");function xf(e,t){return e.includes("..")?t.message("Invalid file path"):e}a(xf,"checkFilePath");function Ace(e,t,r,n){try{let s=iG.get(oG.CONFIG_PARAMS.COMPONENTSROOT),i=sG.join(s,e,t,r+".js");return nG.existsSync(i)?r:n.message(Xr.NO_FILE)}catch(s){return aG.error(s),n.message(Xr.VALIDATION_ERR)}}a(Ace,"checkFileExists");function Rce(e){let t=ye.object({project:ye.string().pattern(So).custom(Fm.bind(null,!0)).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),type:ye.string().valid("helpers","routes").required(),file:ye.string().pattern(So).custom(Ace.bind(null,e.project,e.type)).custom(xf).required().messages({"string.pattern.base":Xr.BAD_FILE_NAME})});return Yn.validateBySchema(e,t)}a(Rce,"getDropCustomFunctionValidator");function yce(e){let t=ye.object({project:ye.string().pattern(So).custom(Fm.bind(null,!0)).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),type:ye.string().valid("helpers","routes").required(),file:ye.string().custom(xf).required(),function_content:ye.string().required()});return Yn.validateBySchema(e,t)}a(yce,"setCustomFunctionValidator");function bce(e){let t=ye.object({project:ye.string().pattern(So).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),file:ye.string().custom(xf).required(),payload:ye.string().allow("").optional(),encoding:ye.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return Yn.validateBySchema(e,t)}a(bce,"setComponentFileValidator");function Oce(e){let t=ye.object({project:ye.string().pattern(So).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),file:ye.string().custom(xf).optional()});return Yn.validateBySchema(e,t)}a(Oce,"dropComponentFileValidator");function Nce(e){let t=ye.object({project:ye.string().required(),file:ye.string().custom(xf).required(),encoding:ye.string().valid("utf8","ASCII","binary","hex","base64","utf16le","latin1","ucs2").optional()});return Yn.validateBySchema(e,t)}a(Nce,"getComponentFileValidator");function Ice(e){let t=ye.object({project:ye.string().pattern(So).custom(Fm.bind(null,!1)).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME})});return Yn.validateBySchema(e,t)}a(Ice,"addComponentValidator");function wce(e){let t=ye.object({project:ye.string().pattern(So).custom(Fm.bind(null,!0)).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME})});return Yn.validateBySchema(e,t)}a(wce,"dropCustomFunctionProjectValidator");function Cce(e){let t=ye.object({project:ye.string().pattern(So).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),skip_node_modules:ye.boolean(),skip_symlinks:ye.boolean()});return Yn.validateBySchema(e,t)}a(Cce,"packageComponentValidator");function Dce(e){let t=ye.object({project:ye.string().pattern(So).required().messages({"string.pattern.base":Xr.BAD_PROJECT_NAME}),package:ye.string().optional(),restart:ye.alternatives().try(ye.boolean(),ye.string().valid("rolling")).optional()});return Yn.validateBySchema(e,t)}a(Dce,"deployComponentValidator");function Pce(e){let t=ye.object({name:ye.string().pattern(gce).required().messages({"string.pattern.base":Xr.BAD_SSH_KEY_NAME}),key:ye.string().required(),host:ye.string().required(),hostname:ye.string().required(),known_hosts:ye.string().optional()});return Yn.validateBySchema(e,t)}a(Pce,"addSSHKeyValidator");function Lce(e){let t=ye.object({name:ye.string().required(),key:ye.string().required()});return Yn.validateBySchema(e,t)}a(Lce,"updateSSHKeyValidator");function Mce(e){let t=ye.object({name:ye.string().required()});return Yn.validateBySchema(e,t)}a(Mce,"deleteSSHKeyValidator");function Uce(e){let t=ye.object({known_hosts:ye.string().required()});return Yn.validateBySchema(e,t)}a(Uce,"setSSHKnownHostsValidator")});var kf=N((xCe,hG)=>{"use strict";var Gm=require("joi"),Sa=require("path"),Vu=require("fs-extra"),{exec:vce}=require("child_process"),Bce=require("util"),uG=Bce.promisify(vce),Qc=M(),{handleHDBError:Ku,hdb_errors:Hce}=_e(),{HTTP_STATUS_CODES:Yu}=Hce,Jc=se(),xce=Tt(),Xc=W();Jc.initSync();var mO=Jc.get(Qc.CONFIG_PARAMS.COMPONENTSROOT),dG="npm install --force --omit=dev --json",kce=`${dG} --dry-run`,Fce=Jc.get(Qc.CONFIG_PARAMS.ROOTPATH),qm=Sa.join(Fce,"ssh");hG.exports={installModules:Vce,auditModules:Kce,installAllRootModules:Gce,uninstallRootModule:qce,linkHarperdb:$ce,runCommand:Wu};async function Gce(e=!1,t=Jc.get(Qc.CONFIG_PARAMS.ROOTPATH)){await $m();let r=!1,n=process.env;Vu.pathExistsSync(qm)&&Vu.readdirSync(qm).forEach(s=>{s.includes(".key")&&!r&&(n={GIT_SSH_COMMAND:"ssh -F "+Sa.join(qm,"config")+" -o UserKnownHostsFile="+Sa.join(qm,"known_hosts"),...process.env},r=!0)});try{let s=Jc.get(Qc.CONFIG_PARAMS.ROOTPATH),i=Sa.join(s,"node_modules","harperdb");Vu.lstatSync(i).isSymbolicLink()&&Vu.unlinkSync(i)}catch(s){s.code!=="ENOENT"&&Xc.error("Error removing symlink:",s)}await Wu(e?"npm install --force --ignore-scripts --no-bin-links":"npm install --force --no-bin-links",t,n)}a(Gce,"installAllRootModules");async function qce(e){await Wu(`npm uninstall ${e}`,Jc.get(Qc.CONFIG_PARAMS.ROOTPATH))}a(qce,"uninstallRootModule");async function $ce(){await $m(),await Wu(`npm link ${Qc.PACKAGE_ROOT}`,Jc.get(Qc.CONFIG_PARAMS.ROOTPATH))}a($ce,"linkHarperdb");async function Wu(e,t=void 0,r=process.env){let n,s;try{({stdout:n,stderr:s}=await uG(e,{cwd:t,env:r}))}catch(i){throw new Error(i.stderr.replace(`
|
|
19
19
|
`,""))}return s&&!s.includes("Debugger listening")&&!s.includes("warn using --force")&&Xc.error("Error running NPM command:",e,s),Xc.trace(n,s),n?.replace(`
|
|
20
20
|
`,"")}a(Wu,"runCommand");async function Vce(e){let t="install_node_modules is deprecated. Dependencies are automatically installed on deploy, and install_node_modules can lead to inconsistent behavior";Xc.warn(t,e);let r=EG(e);if(r)throw Ku(r,r.message,Yu.BAD_REQUEST);let{projects:n,dry_run:s}=e,i=s===!0?kce:dG;await $m(),await fG(n);let o={};for(let c=0,l=n.length;c<l;c++){let u=n[c];o[u]={npm_output:null,npm_error:null};let d=Sa.join(mO,u),_,E=null;try{let{stdout:f,stderr:h}=await uG(i,{cwd:d});_=f?f.replace(`
|
|
21
21
|
`,""):null,E=h?h.replace(`
|
|
@@ -130,4 +130,4 @@ Reindexing upgrade started for transaction logs`),Io.notify("Reindexing upgrade
|
|
|
130
130
|
Connection: close\r
|
|
131
131
|
\r
|
|
132
132
|
`))}},25).unref()}o.close?.(()=>{if(At.get(Zt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&_d()==0)try{FK($K(At.get(Zt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)))}catch{}clearInterval(c),setTimeout(()=>{console.log("forced close server",i,XS),o.cantCleanupProperly||Nn.warn("Had to forcefully exit the thread",XS),process.exit(0)},5e3).unref()})}if(VK||process.env.DEV_MODE)try{require("inspector").close()}catch(i){Nn.info("Could not close debugger",i)}}}).ref();let e;IE&&!nme&&(e=YK()),Promise.resolve(e).then(()=>{if(_d()===0)try{eme(PI)}catch(t){console.error("Error displaying start-up log",t)}wE?.postMessage({type:Zt.ITC_EVENT_TYPES.CHILD_STARTED})})})}a(KK,"startServers");function YK(){let e=[];for(let t in $i){let r=$i[t];if(t.includes?.("/")&&_d()==0){Wpe(t)&&FK(t),e.push(new Promise((o,c)=>{r.listen({path:t},()=>{o({port:t,name:r.name,protocol_name:r.protocol_name}),Nn.info("Domain socket listening on "+t)}).on("error",c)}));continue}let n,s=At.get(Zt.CONFIG_PARAMS.HTTP_THREADRANGE);if(s){let o=typeof s=="string"?s.split("-"):s,c=_d();if(c<o[0]||c>o[1])continue}let i;try{let o=t.lastIndexOf(":");o>0?IE?n={fd:IE(+t.slice(o+1).replace(/[\[\]]/g,""),t.slice(0,o))}:n={host:+t.slice(o+1).replace(/[\[\]]/g,""),port:t.slice(0,o)}:IE?n={fd:IE(+t,"::")}:n={port:t}}catch(o){console.error(`Unable to bind to port ${t}`,o);continue}e.push(new Promise((o,c)=>{r.listen(n,()=>{o({port:t,name:r.name,protocol_name:r.protocol_name}),Nn.trace("Listening on port "+t,XS)}).on("error",c)}))}return Promise.all(e)}a(YK,"listenOnPorts");!CI&&!Gpe?.noServerStart&&KK();function UI(e,t,r){let n=e?.read?e:new qpe({fd:e,readable:!0,writable:!0,allowHalfOpen:!0}),s=$i[t];if(s.isSecure&&(n.startTime=performance.now()),s)typeof s=="function"?s(n):s.emit("connection",n),r&&n.emit("data",r);else{let i=a(o=>{setTimeout(()=>{let c=$i[t];c?(typeof c=="function"?c(n):c.emit("connection",n),r&&n.emit("data",r)):o<5?i(o+1):(Nn.error(`Server on port ${t} was not registered`),n.destroy())},1e3)},"retry");i(1)}return n}a(UI,"deliverSocket");var vK=new Map;function sme(e){let{port:t,event:r,data:n,requestId:s}=e,i;switch(i=vK.get(s),r){case"connection":i=UI(void 0,t),vK.set(s,i),i.write=(c,l,u)=>(wE.postMessage({requestId:s,event:"data",data:c.toString("latin1")}),u&&u(),!0),i.end=(c,l,u)=>(wE.postMessage({requestId:s,event:"end",data:c?.toString("latin1")}),u&&u(),!0);let o=i.destroy;i.destroy=()=>{o.call(i),wE.postMessage({requestId:s,event:"destroy"})};break;case"data":i._readableState.destroyed||i.emit("data",Buffer.from(n,"latin1"));break;case"drain":i._readableState.destroyed||i.emit("drain",{});break;case"end":i._readableState.destroyed||i.emit("end",{});break;case"error":i._readableState.destroyed||i.emit("error",{});break}}a(sme,"proxyRequest");var{getComponentName:eT}=(Jf(),oe(Qf));function vI(e,t,r=!0){t||(t=At.get(Zt.CONFIG_PARAMS.HTTP_PORT));let n=$i[t];if(n){let s=n.lastServer||n;if(s===e)throw new Error(`Can not register the same server twice for the same port ${t}`);if(r&&!!s.sessionIdContext!=!!e.sessionIdContext&&+t)throw new Error(`Can not mix secure HTTPS and insecure HTTP on the same port ${t}`);s.off("unhandled",kK),s.on("unhandled",(i,o)=>{e.cantCleanupProperly&&(n.cantCleanupProperly=!0),e.emit("request",i,o)}),n.lastServer=e}else $i[t]=e;e.on("unhandled",kK)}a(vI,"registerServer");function BI(e){let t=[],r=e?.securePort;return r&&t.push({port:r,secure:!0}),r=e?.port,r&&t.push({port:r,secure:!1}),t.length===0&&(t=[],At.get(Zt.CONFIG_PARAMS.HTTP_PORT)!=null&&t.push({port:At.get(Zt.CONFIG_PARAMS.HTTP_PORT),secure:At.get(Zt.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS)}),At.get(Zt.CONFIG_PARAMS.HTTP_SECUREPORT)!=null&&t.push({port:At.get(Zt.CONFIG_PARAMS.HTTP_SECUREPORT),secure:!0})),e?.isOperationsServer&&At.get(Zt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)&&t.push({port:$K(At.get(Zt.CONFIG_PARAMS.OPERATIONSAPI_NETWORK_DOMAINSOCKET)),secure:!1}),t}a(BI,"getPorts");function HI(e,t){let r=[];for(let{port:n,secure:s}of BI(t))r.push(WK(n,s,t?.isOperationsServer,t?.mtls)),typeof e=="function"?LI[t?.runFirst?"unshift":"push"]({listener:e,port:t?.port||n}):(e.isSecure=s,vI(e,n,!1)),ZS[n]=rT(LI,n);return r}a(HI,"httpServer");function tT(e,t){let r=PI.get(e)??[];PI.set(e,[...r,t])}a(tT,"setPortServerMap");function WK(e,t,r,n){if(tT(e,{protocol_name:t?"HTTPS":"HTTP",name:eT()}),!JS[e]){let s=r?"operationsApi_network":"http",i=At.get(s+"_keepAliveTimeout"),o=At.get(s+"_timeout"),c=At.get(s+"_headersTimeout"),l={noDelay:!0,keepAliveTimeout:i,headersTimeout:c,requestTimeout:o,highWaterMark:128*1024,noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600,maxHeaderSize:At.get(Zt.CONFIG_PARAMS.HTTP_MAXHEADERSIZE)},u=At.get(s+"_mtls"),d=At.get(s+"_mtls_required");t&&Object.assign(l,{allowHTTP1:!0,rejectUnauthorized:!!d,requestCert:!!(u||n),ticketKeys:Qpe(),SNICallback:qK(r?"operations-api":"server",u),ALPNCallback:a(function(f){return f.protocols.includes("harperdb-replication")&&(this.isReplicationConnection=!0),"http/1.1"},"ALPNCallback"),ALPNProtocols:null});let _=Zpe(),E=JS[e]=(t?Ype:Vpe)(l,async(f,h)=>{try{let m=performance.now(),g=new GK(f,h);r&&(g.isOperationsServer=!0);let S=await ZS[e](g);if(!S){if(g._nodeResponse.statusCode)return;S=jK(g)}if(S.headers?.set||(S.headers=new DI(S.headers)),_?S.headers?.set?.("Server","Unlicensed HarperDB, this should only be used for educational and development purposes"):S.headers?.set?.("Server","HarperDB"),S.status===-1){for(let ne of S.headers||[])h.setHeader(ne[0],ne[1]);return f.baseRequest=g,h.baseResponse=S,JS[e].emit("unhandled",f,h)}let y=S.status||200,I=performance.now(),U=I-m,H=S.body,X;if(!S.handlesHeaders){let ne=S.headers||new DI;H?H.length>=0&&(typeof H=="string"?ne.set("Content-Length",Buffer.byteLength(H)):ne.set("Content-Length",H.length),X=!0):(ne.set("Content-Length","0"),X=!0);let Q=`hdb;dur=${U.toFixed(2)}`;S.wasCacheMiss&&(Q+=", miss"),Xpe(ne,"Server-Timing",Q,!0),h.headersSent||h.writeHead(y,ne&&(ne[Symbol.iterator]?Array.from(ne):ne)),X&&h.end(H)}let Y=g.handlerPath,V=g.method;if(OE(U,"duration",Y,V,S.wasCacheMiss==null?void 0:S.wasCacheMiss?"cache-miss":"cache-hit"),MK(y<400,"success",Y,V),MK(1,"response_"+y,Y,V),!X)if(H instanceof ReadableStream&&(H=UK.fromWeb(H)),(H[Symbol.iterator]||H[Symbol.asyncIterator])&&(H=UK.from(H)),H?.pipe){H.pipe(h),H.destroy&&h.on("close",()=>{H.destroy()});let ne=0;H.on("data",Q=>{ne+=Q.length}),H.on("end",()=>{OE(performance.now()-I,"transfer",Y,V),OE(ne,"bytes-sent",Y,V)})}else H?.then?H.then(ne=>{h.end(ne)},T):h.end(H)}catch(m){T(m)}function T(m){let g=m.headers;h.writeHead(m.statusCode||500,g&&(g[Symbol.iterator]?Array.from(g):g)),h.end(m.toString()),m.statusCode?m.statusCode===500?Nn.warn(m):Nn.info(m):Nn.error(m)}a(T,"onError")});i>=0&&(E.keepAliveTimeout=i),c>=0&&(E.headersTimeout=c),t&&(E.ports||(E.ports=[]),E.ports.push(e),l.SNICallback.initialize(E),u&&(E.mtlsConfig=u),E.on("secureConnection",f=>{f._parent.startTime&&OE(performance.now()-f._parent.startTime,"tls-handshake",e),OE(f.isSessionReused(),"tls-reused",e)}),E.isSecure=!0),vI(E,e)}return JS[e]}a(WK,"getHTTPServer");function rT(e,t){let r=jK;for(let n=e.length;n>0;){let{listener:s,port:i}=e[--n];if(i===t||i==="all"){let o=r;r=a((...c)=>s(...c,o),"next_callback")}}return r}a(rT,"makeCallbackChain");function jK(e){return e.user&&(e._nodeRequest.user=e.user),{status:-1,body:"Not found",headers:new DI}}a(jK,"unhandled");function ime(e,t){HI(e,{requestOnly:!0,...t})}a(ime,"onRequest");function ome(e,t){let r;if(t.securePort){tT(t.securePort,{protocol_name:"TLS",name:eT()});let n=qK("server",t.mtls);r=zpe({rejectUnauthorized:!!t.mtls?.required,requestCert:!!t.mtls,noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600,SNICallback:n},e),n.initialize(r),$i[t.securePort]=r}return t.port&&(tT(t.port,{protocol_name:"TCP",name:eT()}),r=$pe(e,{noDelay:!0,keepAlive:!0,keepAliveInitialDelay:600}),$i[t.port]=r),r}a(ome,"onSocket");Object.defineProperty(Kpe.prototype,"upgrade",{get(){return"connection"in this.headers&&"upgrade"in this.headers&&this.headers.connection.includes("Upgrade")&&this.headers.upgrade.toLowerCase()=="websocket"},set(e){}});var BK=[],MI={};function zK(e,t){for(let{port:r}of BI(t))BK[t?.runFirst?"unshift":"push"]({listener:e,port:r}),MI[r]=rT(BK,r)}a(zK,"onUpgrade");var HK=[],xK={};function ame(e,t){let r=[];for(let{port:n,secure:s}of BI(t)){tT(n,{protocol_name:s?"WSS":"WS",name:eT()});let i=WK(n,s,t?.isOperationsServer,t?.mtls);NE[n]||(NE[n]=new jpe({noServer:!0,maxPayload:t.maxPayload??100*1024*1024}),NE[n].on("connection",(o,c)=>{let l=new GK(c);l.isWebSocket=!0;let u=ZS[n](l);xK[n](o,l,u)}),zK((o,c,l,u)=>o.__harperdb_request_upgraded?u(o,c,l):NE[n].handleUpgrade(o,c,l,d=>{o.__harperdb_request_upgraded=!0,u(o,c,l),NE[n].emit("connection",d,o)}),{port:n}),i.on("upgrade",(o,c,l)=>{MI[n]&&MI[n](o,c,l)})),r.push(i),HK[t?.runFirst?"unshift":"push"]({listener:e,port:n}),xK[n]=rT(HK,n),ZS[n]=rT(LI,n)}return r}a(ame,"onWebSocket");function kK(e,t){t.writeHead(404),t.end(`Not found
|
|
133
|
-
`)}a(kK,"defaultNotFound")});var LK={};je(LK,{startHTTPThreads:()=>lme,startSocketServer:()=>$I,updateWorkerIdleness:()=>nY});async function lme(e=2,t){try{if(t)GI(0,1,!0);else{let{loadRootComponents:r}=nT();if(e===0)return(0,Ds.setMainIsWorker)(!0),await xI().startServers(),Promise.resolve([]);await r()}rY();for(let r=0;r<e;r++)GI(r,e);return Promise.all(tY)}finally{(0,Ds.threadsHaveStarted)()}}function rY(){let e=(0,ZK.checkMemoryLimit)();e&&!process.env.DEV_MODE&&(console.error(e),FI=setInterval(()=>{oT.notify(e)},cme).unref())}function GI(e,t=1,r){if(kI++,(0,Ds.startWorker)("server/threads/threadServer.js",{name:md.THREAD_TYPES.HTTP,workerIndex:e,threadCount:t,async onStarted(n){let s=new Promise((o,c)=>{function l(u){u.type===md.CLUSTER_MESSAGE_TYPE_ENUM.CHILD_STARTED&&(n.removeListener("message",l),o(n))}a(l,"onMessage"),n.on("message",l),n.on("error",c)});tY.push(s),await s,fd.push(n),n.expectedIdle=1,n.lastIdle=0,n.requests=1,n.on("message",o=>{if(o.requestId){let c=iT.get(o.requestId);c&&c(o)}}),n.on("exit",i),n.on("shutdown",i);function i(){let o=fd.indexOf(n);o>-1&&fd.splice(o,1)}if(a(i,"removeWorker"),Ed){let o=Ed;Ed=[];for(let c of o)eY[c.localPort](null,c)}}}),r){let n=setInterval(()=>{qI?qI=!1:(clearInterval(n),console.log("shut down dynamic thread due to inactivity"),(0,Ds.shutdownWorkers)(),kI=0,setTimeout(()=>{global.gc?.()},5e3))},1e4)}}function $I(e=0,t){if(typeof e=="string")try{(0,aT.existsSync)(e)&&(0,aT.unlinkSync)(e)}catch{}let r;t?t==="ip"?r=ume:r=dme(t):r=VI;let n=(0,hd.createServer)({allowHalfOpen:!0,pauseOnConnect:!r.readsData}).listen(e);if(n._handle){n._handle.onconnection=eY[e]=function(i,o){r.readsData||(o.reading=!1,o.readStop()),qI=!0,r(o,(c,l)=>{if(!c){if(QK){let d=o._socket||new hd.Socket({handle:o,writable:!0,readable:!0});QK.deliverSocket(d,e,l),d.resume()}else kI>0?(Ed.length===0&&setTimeout(()=>{Ed.length>0&&console.warn("Incoming sockets/requests have been queued for workers to start, and no workers have handled them. Check to make sure an error is not preventing workers from starting")},1e4).unref(),o.localPort=e,Ed.push(o)):(console.log("start up a dynamic thread to handle request"),GI(0));pr(!1,"socket-routed");return}c.requests++;let u=o.fd;if(u>=0)c.postMessage({port:e,fd:u,data:l});else{let d=o._socket||new hd.Socket({handle:o,writable:!0,readable:!0});Eme(d,c,e)}pr(!0,"socket-routed")})};let s=Xl();oT.info(`HarperDB ${s.version} Server running on port ${e}`)}return n.on("error",s=>{console.error("Error in socket server",s)}),process.env._UNREF_SERVER&&n.unref(),n}function VI(e,t){let r,n=0;for(let s of fd){if(s.threadId===-1)continue;let i=s.expectedIdle/s.requests;if(i>n)r=s;else if(n>=sT)return sT=i,t(r);n=i}sT=0,t(r)}function ume(e,t){let r={};e.getpeername(r);let n=r.address,s=pd.get(n),i=Date.now();if(s&&s.worker.threadId!==-1)return s.lastUsed=i,t(s.worker);VI(e,o=>{pd.set(n,{worker:o,lastUsed:i}),t(o)})}function dme(e){let t=new RegExp(`${e}:\\s*(.+)`,"i");return r.readsData=!0,r;function r(n,s){let i=new hd.Socket({handle:n,readable:!0,writable:!0});n._socket=i,i.on("data",o=>{n.readStop();let l=o.toString("latin1").match(t)?.[1],u=pd.get(l),d=Date.now();if(u&&u.worker.threadId!==-1)return u.lastUsed=d,s(u.worker);VI(n,_=>{pd.set(l,{worker:_,lastUsed:d}),s(_,o)})})}a(r,"findByHeaderAffinity")}function nY(){sT=0;for(let e of fd)e.expectedIdle=e.recentELU.idle+_me,e.requests=1;fd.sort((e,t)=>e.expectedIdle>t.expectedIdle?-1:1)}function Eme(e,t,r){let n=fme++;t.postMessage({port:r,requestId:n,event:"connection"}),e.on("data",s=>{let i=s.toString("latin1");t.postMessage({port:r,requestId:n,data:i,event:"data"})}).on("close",s=>{t.postMessage({port:r,requestId:n,event:"close",hadError:s})}).on("error",s=>{t.postMessage({port:r,requestId:n,event:"error",error:s})}).on("drain",s=>{t.postMessage({port:r,requestId:n,event:"drain",error:s})}).on("end",()=>{t.postMessage({port:r,requestId:n,event:"end"})}).resume(),iT.set(n,s=>{s.event=="data"&&e.write(Buffer.from(s.data,"latin1")),s.event=="end"&&(e.end(s.data&&Buffer.from(s.data,"latin1")),iT.delete(n)),s.event=="destroy"&&(e.destroy(),iT.delete(n))})}var Ds,hd,md,oT,aT,XK,ZK,fd,Ed,eY,QK,kI,tY,FI,cme,qI,sT,JK,pd,_me,iT,fme,wI=Ie(()=>{Ds=L(dt()),hd=require("net"),md=L(M()),oT=L(W()),aT=require("fs");Ni();XK=require("worker_threads"),ZK=L(_c()),fd=[],Ed=[],eY=[],kI=0,tY=[];XK.isMainThread&&(process.on("uncaughtException",e=>{e.code!=="ECONNRESET"&&e.message!=="write EIO"&&console.error("uncaughtException",e)}),(0,Ds.onMessageFromWorkers)(e=>{e.type===md.ITC_EVENT_TYPES.RESTART&&FI&&(clearInterval(FI),rY())}));cme=6e5;a(lme,"startHTTPThreads");a(rY,"licenseWarning");a(GI,"startHTTPWorker");a($I,"startSocketServer");sT=0;a(VI,"findMostIdleWorker");JK=36e5,pd=new Map;a(ume,"findByRemoteAddressAffinity");a(dme,"makeFindByHeaderAffinity");setInterval(()=>{let e=Date.now();for(let[t,r]of pd)r.lastUsed+JK<e&&pd.delete(t)},JK).unref();_me=1e3;a(nY,"updateWorkerIdleness");(0,Ds.setMonitorListener)(nY);iT=new Map,fme=1;a(Eme,"proxySocket")});var aY=N(($Le,oY)=>{"use strict";var hme=require("cluster"),ml=se();ml.initSync();var iY=M(),xLe=require("util"),Ho=W(),kLe=require("fs"),pme=require("fastify"),FLe=Xl(),mme=require("@fastify/cors"),Sme=require("@fastify/compress"),Tme=require("@fastify/static"),gme=FN(),Ame=require("path"),{PACKAGE_ROOT:Rme}=M(),yme=ls(),bme=te(),Ome=xn(),Nme=_c(),{server:Ime}=(qr(),oe(Ja)),{node_request_key:GLe}=(vS(),oe(JN)),{authHandler:wme,handlePostRequest:Cme,serverErrorHandler:Dme,reqBodyValidationHandler:Pme}=LS(),qLe=require("net"),{registerContentHandlers:Lme}=(zc(),oe($$)),Mme=6e4,Ume=1024*1024*1024,vme="TRUE",{CONFIG_PARAMS:DE}=iY,Sd;oY.exports={hdbServer:sY,start:sY};async function sY(e){try{Ho.debug("In Fastify server"+process.cwd()),Ho.debug(`Running with NODE_ENV set as: ${process.env.NODE_ENV}`),Ho.debug(`HarperDB server process ${process.pid} starting up.`),global.clustering_on=!1,global.isMaster=hme.isMaster,await Bme();let t=e.securePort>0;Sd=Hme(t),await Sd.ready(),e||(e={}),e.isOperationsServer=!0;try{Ime.http(Sd.server,e),Sd.server.closeIdleConnections||await Sd.listen({port:0,host:"::"})}catch(r){throw Sd.close(),Ho.error(r),Ho.error("Error configuring operations server"),r}}catch(t){console.error(`Failed to build server on ${process.pid}`,t),Ho.fatal(t),process.exit(1)}}a(sY,"operationsServer");async function Bme(){Ho.trace("Configuring HarperDB process."),yme.setSchemaDataToGlobal(),await Ome.setUsersToGlobal(),await Nme.getLicense()}a(Bme,"setUp");function Hme(e){Ho.debug(`HarperDB process starting to build ${e?"HTTPS":"HTTP"} server.`);let t=xme(e),r=pme(t);r.server.headersTimeout=Fme(),r.setErrorHandler(Dme);let n=kme();n&&r.register(mme,n),r.register(function(i,o,c){i.setNotFoundHandler(function(l,u){r.server.emit("unhandled",l.raw,u.raw)}),c()}),r.register(gme),r.register(Sme),r.register(Tme,{root:Ame.join(Rme,"studio/build-local")}),Lme(r);let s=ml.get(iY.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON);return r.get("/",function(i,o){return!bme.isEmpty(s)&&s.toString().toLowerCase()==="true"?o.sendFile("index.html"):o.sendFile("running.html")}),r.post("/",{preValidation:[Pme,wme],config:{isOperation:!0}},async function(i,o){return i.body?.operation?.startsWith("restart")&&o.header("Connection","close"),Cme(i,o)}),r.get("/health",()=>"HarperDB is running."),Ho.debug(`HarperDB process starting up ${e?"HTTPS":"HTTP"} server listener.`),r}a(Hme,"buildServer");function xme(e){let t=ml.get(DE.OPERATIONSAPI_NETWORK_TIMEOUT),r=ml.get(DE.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT);return{bodyLimit:Ume,connectionTimeout:t,keepAliveTimeout:r,forceCloseConnections:!0,return503OnClosing:!1,https:e}}a(xme,"getServerOptions");function kme(){let e=ml.get(DE.OPERATIONSAPI_NETWORK_CORS),t=ml.get(DE.OPERATIONSAPI_NETWORK_CORSACCESSLIST),r;return e&&(e===!0||e.toUpperCase()===vme)&&(r={origin:!0,allowedHeaders:["Content-Type","Authorization","Accept"],credentials:!1},t&&t.length>0&&t[0]!==null&&t[0]!=="*"&&(r.origin=(n,s)=>s(null,t.indexOf(n)!==-1))),r}a(kme,"getCORSOpts");function Fme(){return ml.get(DE.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT)??Mme}a(Fme,"getHeaderTimeoutConfig")});var QI={};je(QI,{disableNATS:()=>qme,publishToStream:()=>uT,setNATSReplicator:()=>KI,setPublishToStream:()=>$me,setSubscription:()=>zI,start:()=>Gme});function Gme(){PE.default.get(LE.default.CONFIG_PARAMS.CLUSTERING_ENABLED)&&Kme()}function qme(e=!0){_Y=e}function $me(e,t){uT=e,zI=t}function Kme(){if(_Y||process.env._DISABLE_NATS)return;let e=ut(),t=Object.keys(e);t.push("system");for(let r of t){let n=e[r];for(let s in n){let i=n[s];KI(s,r,i)}}Lc((r,n)=>{KI(r.tableName,r.databaseName,r),n&&EY(r)}),!cY&&(cY=!0)}function KI(e,t,r){if(t==="system"&&Yme.includes(e))return;if(!r)return console.error(`Attempt to replicate non-existent table ${e} from database ${t}`);if(r.sources.some(s=>s?.isNATSReplicator))return;r.sourcedFrom(class extends Lr{static{a(this,"NATSReplicator")}put(i){return n(this.getContext()).addWrite(t,{operation:"put",table:e,id:this[ze],record:i})}delete(){return n(this.getContext()).addWrite(t,{operation:"delete",table:e,id:this[ze]})}publish(i){return n(this.getContext()).addWrite(t,{operation:"publish",table:e,id:this[ze],record:i})}patch(i){return n(this.getContext()).addWrite(t,{operation:"patch",table:e,id:this[ze],record:i})}invalidate(){n(this.getContext()).addWrite(t,{operation:"invalidate",table:e,id:this[ze]})}static defineSchema(i){EY(i)}static subscribe(){let i=new Mn;return zI(t,e,i),i}static subscribeOnThisThread(i){return i<(PE.default.get(LE.default.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)??Vme)}static isEqual(i){return i.isNATSReplicator}static isNATSReplicator=!0;static shouldReceiveInvalidations=!0},{intermediateSource:!0});function n(s){let i=s?.transaction?.nats;if(!i)if(s?.transaction){s.transaction.nats=i=new cT(s.transaction,s);let o=s.transaction;for(;o.next;)o=o.next;o.next=s.transaction.nats,i.user=s.user,i.context=s}else i=fY;return i}a(n,"getNATSTransaction")}function EY(e){let t=PE.default.get(LE.default.CONFIG_PARAMS.CLUSTERING_NODENAME);uT(`${WI.SUBJECT_PREFIXES.TXN}.${e.databaseName}.${e.tableName}`,(0,jI.createNatsTableStreamName)(e.databaseName,e.tableName),void 0,{operation:"define_schema",schema:e.databaseName,table:e.tableName,attributes:e.attributes,__origin:{timestamp:Date.now(),node_name:t}})}var lY,WI,jI,uY,dY,PE,LE,lT,_Y,uT,zI,Vme,fY,cY,Yme,cT,YI,hY=Ie(()=>{Pe();Vs();lY=L(mr()),WI=L(Ct()),jI=L(to());Ll();uY=L(ey()),dY=L(cn()),PE=L(se()),LE=L(M()),lT=L(W());a(Gme,"start");a(qme,"disableNATS");uT=lY.publishToStream,zI=uY.setSubscription;a($me,"setPublishToStream");Vme=2;a(Kme,"assignReplicationSource");Yme=["hdb_job","hdb_analytics","hdb_raw_analytics","hdb_info","hdb_license"];a(KI,"setNATSReplicator");a(EY,"publishSchema");cT=class{constructor(t,r){this.transaction=t;this.options=r}static{a(this,"NATSTransaction")}user;writes_by_db=new Map;addWrite(t,r){r.expiresAt=this.context?.expiresAt;let n=this.writes_by_db.get(t);n||this.writes_by_db.set(t,n=[]),n.push(r)}commit({timestamp:t}){let r=PE.default.get(LE.default.CONFIG_PARAMS.CLUSTERING_NODENAME),n=[];for(let[s,i]of this.writes_by_db){let o=[],c=[],l,u;for(let d of i){let _=d.table,E=d.operation=="put"?"upsert":d.operation;l||(lT.trace(`Sending transaction event ${E}`),u=l={operation:E,schema:s,table:_,__origin:{user:this.user?.username,timestamp:t,node_name:r}},l.hash_values=c,E!=="delete"&&E!=="invalidate"&&(l.records=o)),l.table===_&&l.operation===E?(o.push(d.record),c.push(d.id)):u=u.next={operation:E,table:_,id:d.id,record:d.record},d.expiresAt&&(u.expiresAt=d.expiresAt)}l&&n.push(uT(`${WI.SUBJECT_PREFIXES.TXN}.${s}.${l.table}`,(0,jI.createNatsTableStreamName)(s,l.table),void 0,l)?.catch(d=>{throw lT.error("An error has occurred trying to replicate transaction",l,d),d.statusCode=504,d}))}return Promise.all(n)}},YI=class extends cT{static{a(this,"ImmmediateNATSTransaction")}constructor(){super({get timestamp(){return(0,dY.getNextMonotonicTime)()}})}addWrite(t,r){super.addWrite(t,r),this.commit({})}};fY=new YI});async function gY({clientId:e,user:t,clean:r,will:n,keepalive:s}){let i;if(e&&!r){let o=await JI.get(e,{returnNonexistent:!0});i=new ew(e,t,o),o&&(i.sessionWasPresent=!0)}else{if(e){let o=await JI.get(e);o&&o.delete()}i=new _T(e,t)}return n&&(n.id=e,n.user={username:t?.username},ME.put(n)),s&&(i.keepalive=s,i.receivedPacket()),i}function XI(){return dT++,dT>65500&&(dT=1),dT}function ZI(e,t,r){let{topic:n,retain:s}=e;e.data=t,e.async=!0,r.authorize=!0;let i=wi.getMatch(n,"mqtt");if(!i)throw new Error(`Can not publish to topic ${n} as it does not exist, no resource has been defined to handle this topic`);e.url=i.relativeURL;let o=i.Resource;return Dt(r,()=>s?t===void 0?o.delete(e,r):o.put(e,e.data,r):o.publish(e,e.data,r))}var mY,Ua,SY,TY,pY,JI,ME,dT,_T,ew,AY=Ie(()=>{Pe();su();mY=L(cn()),Ua=L(W());Sc();SY=L(dt()),TY=L(xI());qr();pY=100,JI=Et({database:"system",table:"hdb_durable_session",attributes:[{name:"id",isPrimaryKey:!0},{name:"subscriptions",type:"array",elements:{attributes:[{name:"topic"},{name:"qos"},{name:"startTime"},{name:"acks"}]}}]}),ME=Et({database:"system",table:"hdb_session_will",attributes:[{name:"id",isPrimaryKey:!0},{name:"topic",type:"string"},{name:"data"},{name:"qos",type:"number"},{name:"retain",type:"boolean"},{name:"user",type:"any"}]});(0,SY.getWorkerIndex)()===0&&(async()=>{await TY.when_components_loaded,await new Promise(e=>setTimeout(e,2e3));for await(let e of ME.search({})){let t=e.data,r={...e};r.user?.username&&(r.user=await it.getUser(r.user.username));try{await ZI(r,t,r)}catch{(0,Ua.warn)("Failed to publish will",t)}ME.delete(e.id)}})();a(gY,"getSession");dT=1;a(XI,"getNextMessageId");_T=class{static{a(this,"SubscriptionsSession")}listener;sessionId;user;request;socket;subscriptions=[];awaitingAcks;sessionWasPresent;keepalive;keepaliveTimer;constructor(t,r){this.sessionId=t,this.user=r}async addSubscription(t,r,n){let{topic:s,rh:i,startTime:o}=t,c=s.indexOf("?"),l,u;if(c>-1?(l=s.slice(c),u=s.slice(0,c)):u=s,!u)throw new Error("No topic provided");if(u.indexOf(".")>-1)throw new Error("Dots are not allowed in topic names");let d=this.subscriptions.find(g=>g.topic===s),_;d?(_=i>0,d.end(),this.subscriptions.splice(this.subscriptions.indexOf(d),1)):_=i===2;let E={search:l,async:!0,user:this.user,startTime:o,omitCurrent:_,url:""};o&&(0,Ua.trace)("Resuming subscription from",s,"from",o);let f=wi.getMatch(u,"mqtt");if(!f){let g=new Error(`The topic ${s} does not exist, no resource has been defined to handle this topic`);throw g.statusCode=404,g}if(E.url=f.relativeURL,E.url.indexOf("+")>-1||E.url.indexOf("#")>-1){let g=E.url.slice(1);if(g.indexOf("#")>-1&&g.indexOf("#")!==g.length-1)throw new Error("Multi-level wildcards can only be used at the end of a topic");if(E.isCollection=!0,g.indexOf("+")===g.length-1)E.onlyChildren=!0,E.url="/"+g.slice(0,g.length-1);else{let S=g.split("/"),y;for(let H=0;H<S.length;H++)if(S[H].indexOf("+")>-1)if(S[H]==="+")y=!0;else throw new Error("Single-level wildcards can only be used as a topic level (between or after slashes)");if(n&&y)throw new Error("Filters can not be combined");let I=!0;S[S.length-1]==="#"&&(S.length--,I=!1),y&&(n=a(H=>{let X=H.id;if(!Array.isArray(X)||I&&X.length!==S.length)return!1;for(let Y=0;Y<S.length;Y++)if(S[Y]!=="+"&&S[Y]!==X[Y])return!1;return!0},"filter"));let U=S.indexOf("+");E.url="/"+(U>-1?S.slice(0,U):S).concat("").join("/")}}let h=f.path,T=f.Resource,m=await Dt(E,async()=>{let g=this.createContext();g.topic=s,g.retainHandling=i;let S=await T.subscribe(E,g);if(!S)return;if(!S[Symbol.asyncIterator])throw new Error(`Subscription is not (async) iterable for topic ${s}`);let y=(async()=>{for await(let I of S)try{let U;if(I.type&&I.type!=="put"&&I.type!=="delete"&&I.type!=="message"&&I.type!=="patch"||n&&!n(I))continue;r?(I.topic=s,U=this.needsAcknowledge(I)):(I.acknowledge?.(),U=XI());let H=I.id;if(Array.isArray(H)&&(H=nu(H)),H==null&&(H=""),await this.listener(h+"/"+H,I.value,U,t)===!1)break;this.awaitingAcks?.size>pY?await new Promise(Y=>setTimeout(Y,this.awaitingAcks.size-pY)):await new Promise(setImmediate)}catch(U){(0,Ua.warn)(U)}})();return S});if(m)return m.topic=s,m.qos=t.qos,this.subscriptions.push(m),m}resume(){}needsAcknowledge(t){let r=XI();return t.acknowledge&&(this.awaitingAcks||(this.awaitingAcks=new Map),this.awaitingAcks.set(r,{acknowledge:t.acknowledge})),r}acknowledge(t){let r=this.awaitingAcks?.get(t);r&&(this.awaitingAcks.delete(t),r.acknowledge())}async removeSubscription(t){let r=this.subscriptions.find(n=>n.topic===t);if(r)return r.end(),this.subscriptions.splice(this.subscriptions.indexOf(r),1),!0}async publish(t,r){return ZI(t,r,this.createContext())}createContext(){let t={session:this,socket:this.socket,user:this.user,authorize:!0};return this.request&&(t.request=this.request,t.url=this.request.url,t.headers=this.request.headers),t}setListener(t){this.listener=t}disconnect(t){this.keepaliveTimer&&clearTimeout(this.keepaliveTimer);let r=this.createContext();Dt(r,async()=>{try{if(!t){let n=await ME.get(this.sessionId);n?.doesExist()&&await ZI(n,n.data,r)}}finally{await ME.delete(this.sessionId)}}).catch(n=>{(0,Ua.warn)(`Error publishing MQTT will for ${this.sessionId}`,n)});for(let n of this.subscriptions)n.end();this.subscriptions=[]}receivedPacket(){this.keepalive&&(clearTimeout(this.keepaliveTimer),this.keepaliveTimer=setTimeout(()=>{this.socket?.destroy?this.socket.destroy(new Error("Keepalive timeout")):this.socket?.terminate()},this.keepalive*1500))}};a(ZI,"publish");ew=class extends _T{static{a(this,"DurableSubscriptionsSession")}sessionRecord;constructor(t,r,n){super(t,r),this.sessionRecord=n||{id:t,subscriptions:[]}}async resume(){for(let t of this.sessionRecord.subscriptions||[])await this.resumeSubscription({omitCurrent:!0,topic:t.topic,qos:t.qos,startTime:t.startTime},!0,t.acks?r=>!t.acks.includes(r.localTime):null)}resumeSubscription(t,r,n){return super.addSubscription(t,r,n)}needsAcknowledge(t){this.awaitingAcks||(this.awaitingAcks=new Map);let r=XI(),n={topic:t.topic,timestamp:t.localTime};return t.acknowledge&&(n.acknowledge=t.acknowledge),this.awaitingAcks.set(r,n),r}acknowledge(t){let r=this.awaitingAcks?.get(t);if(!r)return;this.awaitingAcks?.delete(t),r.acknowledge?.();let n=r.topic;for(let[,s]of this.awaitingAcks)if(s.topic===n&&s.timestamp<r.timestamp){for(let i of this.sessionRecord.subscriptions)if(i.topic===n){i.acks||(i.acks=[]),i.acks.push(r.timestamp),(0,Ua.trace)("Received ack",n,r.timestamp),this.sessionRecord.update();return}}for(let s of this.sessionRecord.subscriptions)s.topic===n&&(s.startTime=r.timestamp);this.sessionRecord.update()}async addSubscription(t,r){await this.resumeSubscription(t,r);let{qos:n,startTime:s}=t;return n>0&&!s&&this.saveSubscriptions(),t.qos}removeSubscription(t){let r=this.subscriptions.find(s=>s.topic===t),n=super.removeSubscription(t);return r.qos>0&&this.saveSubscriptions(),n}saveSubscriptions(){this.sessionRecord.subscriptions=this.subscriptions.map(t=>{let r=t.startTime;return r||(r=t.startTime=(0,mY.getNextMonotonicTime)()),(0,Ua.trace)("Added durable subscription",t.topic,r),{qos:t.qos,topic:t.topic,startTime:r}}),JI.put(this.sessionRecord)}}});var rw={};je(rw,{bypassAuth:()=>Wme,start:()=>jme});function Wme(){NY=!0}function jme({server:e,port:t,network:r,webSocket:n,securePort:s,requireAuthentication:i}){e.mqtt||(e.mqtt={requireAuthentication:i,sessions:new Set,events:new OY.EventEmitter},e.mqtt.events.on("error",()=>{}));let o=e.mqtt,c=[],l=r?.mtls;return n&&(c=e.ws((u,d,_,E)=>{if(d.headers.get("sec-websocket-protocol")!=="mqtt")return E(u,d,_);o.events.emit("connection",u),dr.debug?.("Received WebSocket connection for MQTT from",u._socket.remoteAddress);let{onMessage:f,onClose:h}=yY(u,T=>{u.send(T)},d,Promise.resolve(_).then(()=>d?.user),o);u.on("message",f),u.on("close",h),u.on("error",T=>{dr.info?.("WebSocket error",T)})},{...n})),(t||s)&&c.push(e.socket(async u=>{let d;if(o.events.emit("connection",u),dr.debug?.(`Received ${u.getCertificate?"SSL":"TCP"} connection for MQTT from ${u.remoteAddress}`),l){if(u.authorized)try{let f=l.user;if(f!==null){(f===void 0||f==="Common Name"||f==="CN")&&(f=u.getPeerCertificate().subject.CN);try{d=await e.getUser(f,null,null),(0,Td.get)(kr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&ET.notify?.({username:d?.username,status:kr.AUTH_AUDIT_STATUS.SUCCESS,type:kr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"MQTT mTLS",remote_address:u.remoteAddress})}catch(h){throw(0,Td.get)(kr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&ET.error?.({username:f,status:kr.AUTH_AUDIT_STATUS.FAILURE,type:kr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"mqtt",remote_address:u.remoteAddress}),h}}else dr.debug?.("MQTT mTLS authorized connection (mTLS did not authorize a user)","from",u.remoteAddress)}catch(f){o.events.emit("error",f,u),dr.error?.(f)}else if(l.required)return dr.info?.(`Unauthorized connection attempt, no authorized client certificate provided, error: ${u.authorizationError}`),u.end()}!d&&NY&&u.remoteAddress.includes("127.0.0.1")&&(d=await(0,bY.getSuperUser)(),dr.debug?.("Auto-authorizing local connection",d?.username));let{onMessage:_,onClose:E}=yY(u,f=>u.write(f),null,d,o);u.on("data",_),u.on("close",E),u.on("error",f=>{dr.info?.("Socket error",f)})},{port:t,securePort:s,mtls:l})),c}function yY(e,t,r,n,s){RY||(RY=!0,F_(_=>{fT>0&&_.push({metric:"mqtt-connections",connections:fT,byThread:!0})}));let i;fT++;let o,c={protocolVersion:4},l=(0,hT.parser)({protocolVersion:5});function u(_){l.parse(_)}a(u,"onMessage");function d(){fT--,i||(i=!0,o?.disconnect?.(),s.events.emit("disconnected",o,e),s.sessions.delete(o),qn(!1,"connection","mqtt","disconnect"),dr.debug?.("MQTT connection was closed",e.remoteAddress))}return a(d,"onClose"),l.on("packet",async _=>{n?.then&&(n=await n);let E=_.cmd;if(o)o.then&&await o;else if(E!=="connect"){dr.info?.("Received packet before connection was established, closing connection"),e?.destroy?e.destroy():e?.terminate();return}let f=_.topic,h=f?.indexOf("/",1),T=h>0?f.slice(0,h):f;pr(_.length,"bytes-received",T,g(_),"mqtt");try{switch(o?.receivedPacket?.(),E){case"connect":if(c.protocolVersion=_.protocolVersion,_.username)try{n=await it.getUser(_.username,_.password.toString(),r),(0,Td.get)(kr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&ET.notify?.({username:n?.username,status:kr.AUTH_AUDIT_STATUS.SUCCESS,type:kr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"MQTT",remote_address:e.remoteAddress})}catch(V){return(0,Td.get)(kr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&ET.error?.({username:_.username,status:kr.AUTH_AUDIT_STATUS.FAILURE,type:kr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"mqtt",remote_address:e.remoteAddress}),s.events.emit("auth-failed",_,e,V),qn(!1,"connection","mqtt","connect"),m({cmd:"connack",reasonCode:4,returnCode:134})}if(!n&&s.requireAuthentication)return s.events.emit("auth-failed",_,e),qn(!1,"connection","mqtt","connect"),m({cmd:"connack",reasonCode:4,returnCode:134});try{if(s.authorizeClient?.(_,n),_.will){let V=e.deserialize||(e.deserialize=bo(r?.headers.get?.("content-type")));_.will.data=_.will.payload?.length>0?V(_.will.payload):void 0,delete _.will.payload}o=gY({user:n,..._}),o=await o,o.socket=e,r&&(o.request=r),s.sessions.add(o)}catch(V){return dr.error?.(V),s.events.emit("auth-failed",_,e,V),qn(!1,"connection","mqtt","connect"),m({cmd:"connack",reasonCode:V.code||5,returnCode:V.code||128})}s.events.emit("connected",o,e),qn(!0,"connection","mqtt","connect"),m({cmd:"connack",sessionPresent:o.sessionWasPresent,reasonCode:0,returnCode:0}),o.setListener((V,ne,Q,de)=>{try{if(i)throw new Error("Session disconnected while trying to send message to",V);let j=V.indexOf("/",1),ae=j>0?V.slice(0,j):V;m({cmd:"publish",topic:V,payload:S(ne),messageId:Q||Math.floor(Math.random()*1e8),qos:de.qos},ae);let Oe=e._socket??e;return Oe.writableNeedDrain?new Promise(Ne=>Oe.once("drain",Ne)):!Oe.closed}catch(j){return dr.error?.(j),o?.disconnect(),s.sessions.delete(o),!1}}),o.sessionWasPresent&&await o.resume();break;case"subscribe":let y=[];for(let V of _.subscriptions){let ne;try{let Q=await o.addSubscription(V,V.qos>=1);ne=Q?Q.qos||0:c.protocolVersion<5?128:143}catch(Q){s.events.emit("error",Q,e,V,o),Q.statusCode?Q.statusCode===500?dr.warn?.(Q):dr.info?.(Q):dr.error?.(Q),ne=c.protocolVersion<5?128:Q.statusCode===403?135:Q.statusCode===404?143:128}y.push(ne)}await o.committed,m({cmd:"suback",granted:y,messageId:_.messageId});break;case"unsubscribe":{let V=[];for(let ne of _.unsubscriptions)V.push(o.removeSubscription(ne)?0:17);m({cmd:"unsuback",granted:V,messageId:_.messageId});break}case"pubrel":m({cmd:"pubcomp",messageId:_.messageId,reasonCode:0});return;case"publish":let I=_.qos===2?"pubrec":"puback",U=e.deserialize||(e.deserialize=bo(r?.headers.get?.("content-type"))),X=(_.payload?.length||0)>0?U(_.payload):void 0,Y;try{Y=await o.publish(_,X)}catch(V){s.events.emit("error",V,e,_,o),dr.warn?.(V),_.qos>0&&m({cmd:I,messageId:_.messageId,reasonCode:128},_.topic);break}_.qos>0&&m({cmd:I,messageId:_.messageId,reasonCode:Y===!1?144:0},_.topic);break;case"pubrec":m({cmd:"pubrel",messageId:_.messageId,reasonCode:0});break;case"pubcomp":case"puback":o.acknowledge(_.messageId);break;case"pingreq":m({cmd:"pingresp"});break;case"disconnect":i=!0,o?.disconnect(!0),s.events.emit("disconnected",o,e),s.sessions.delete(o),qn(!0,"connection","mqtt","disconnect"),dr.debug?.("Received disconnect command, closing MQTT session",e.remoteAddress),e.close?e.close():e.end();break}}catch(y){s.events.emit("error",y,e,_,o),dr.error?.(y),m({cmd:"disconnect"})}function m(y,I){let U=(0,hT.generate)(y,c);t(U),pr(U.length,"bytes-sent",I,g(y),"mqtt")}a(m,"sendPacket");function g(y){return y.qos>0?y.cmd+",qos="+y.qos:y.cmd}a(g,"packetMethodName");function S(y){return jc(y,r)}a(S,"serialize")}),l.on("error",_=>{dr.warn("MQTT parsing error, closing connection:",_.message),e?.destroy?e.destroy():e?.terminate()}),{onMessage:u,onClose:d}}var hT,bY,Td,kr,tw,OY,ET,dr,NY,RY,fT,IY=Ie(()=>{hT=require("mqtt-packet");AY();bY=L(xn());zc();Ni();qr();Td=L(se()),kr=L(M()),tw=L(Oc()),OY=require("events"),ET=(0,tw.loggerWithTag)("auth-event"),dr=(0,tw.loggerWithTag)("mqtt"),NY=(0,Td.get)(kr.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE;a(Wme,"bypassAuth");a(jme,"start");fT=0;a(yY,"onSocket")});var Qf={};je(Qf,{component_errors:()=>Ad,getComponentName:()=>Zme,loadComponent:()=>ST,loadComponentDirectories:()=>UY,setErrorReporter:()=>Xme});function UY(e,t){t&&(sw=t),e&&(iw=e);let r=[];if((0,Nt.existsSync)(nw)){let s=(0,Nt.readdirSync)(nw,{withFileTypes:!0});for(let i of s){if(!i.isDirectory()&&!i.isSymbolicLink())continue;let o=i.name,c=(0,Ot.join)(nw,o);r.push(ST(c,sw,"hdb",!1))}}let n=process.env.RUN_HDB_APP;return n&&r.push(ST(n,sw,n,!1,null,!!process.env.DEV_MODE)),Promise.all(r).then(()=>{MY=!0})}function Xme(e){UE=e}async function ST(e,t,r,n,s,i){let o=(0,Nt.realpathSync)(e);if(pT.has(o))return pT.get(o);pT.set(o,!0),s&&(iw=s);try{let c;n&&(Ad=new Map);let l=(0,Ot.join)(e,n?"harperdb-config.yaml":"config.yaml");(0,Nt.existsSync)(l)?c=n?(0,TT.getConfigObj)():(0,CY.parseDocument)((0,Nt.readFileSync)(l,"utf8")).toJSON():c=ow;let u=(0,Ot.join)(e,"node_modules","harperdb");try{Sl.isMainThread&&(n||(0,Nt.existsSync)(u)&&(0,Nt.realpathSync)(yd.PACKAGE_ROOT)!==(0,Nt.realpathSync)(u))&&((0,Nt.rmSync)(u,{recursive:!0,force:!0}),(0,Nt.existsSync)((0,Ot.join)(e,"node_modules"))||(0,Nt.mkdirSync)((0,Ot.join)(e,"node_modules")),(0,Nt.symlinkSync)(yd.PACKAGE_ROOT,u,"dir"))}catch(E){gd.default.error("Error symlinking harperdb module",E)}let d=mT,_=n;for(let E in c){mT=E;let f=c[E];if(Ad.set(n?E:(0,Ot.basename)(e),!1),!f)continue;let h,T=f.package;try{if(T){let I=e,U;for(;!(0,Nt.existsSync)(U=(0,Ot.join)(I,"node_modules",E));)if(I=(0,Ot.dirname)(I),I.length<(0,LY.getHdbBasePath)().length){U=null;break}if(U)h=await ST(U,t,r,!1),_=!0;else throw new Error(`Unable to find package ${E}:${T}`)}else h=Jme[E];if(!h)continue;let m=a(I=>(I.origin=r,Et(I)),"ensureTable"),g=f.network||(f.port||f.securePort)&&f,S=g?.securePort||g?.https&&g.port,y=!g?.https&&g?.port;if(Sl.isMainThread&&(h=await h.startOnMainThread?.({server:it,ensureTable:m,port:y,securePort:S,resources:t,...f})||h,n&&g))for(let I of[y,S])try{if(+I&&!wY.includes(I)){let U=aw.get(yd.CONFIG_PARAMS.HTTP_SESSIONAFFINITY);U&&gd.default.warn("Session affinity is not recommended and may cause memory leaks"),(U||!US)&&(wY.push(I),$I(I,U))}}catch(U){console.error("Error listening on socket",I,U,E)}if(t.isWorker&&(h=await h.start?.({server:it,ensureTable:m,port:y,securePort:S,resources:t,...f})||h),iw.set(h,!0),(h.handleFile||h.handleDirectory||h.setupFile||h.setupDirectory)&&f.files!=null){if(f.files.includes(".."))throw(0,PY.handleHDBError)("Can not reference parent directories");let I=(0,Ot.join)(e,f.files).replace(/\\/g,"/"),U=I.indexOf("/*");if(U>-1&&f.files!==ow[E]?.files&&!(0,Nt.existsSync)(I.slice(0,U)))throw new Error(`The path '${I.slice(0,U)}' does not exist and cannot be used as the base of the resolved 'files' path value '${f.files}'`);let H=(0,Ot.basename)(e),X=f.path||"/";X=X.startsWith("/")?X:X.startsWith("./")?"/"+H+X.slice(2):X==="."?"/"+H:"/"+H+"/"+X;let Y,V,ne;if(f.root){let de=f.root;de.startsWith("/")&&(de=de.slice(1)),de.endsWith("/")&&(de=de.slice(0,-1)),de+="/",V=(0,Ot.join)(e,de)}else(ne=I.indexOf("/*"))>-1?(V=I.slice(0,ne+1),Y=(0,Ot.relative)(e,V)):f.files.indexOf("/")>-1&&(V=I.slice(0,I.lastIndexOf("/")+1),Y=(0,Ot.relative)(e,V));let Q=!1;if(Sl.isMainThread&&h.setupDirectory&&(Q=await h.setupDirectory?.(X,V,t)),t.isWorker&&h.handleDirectory&&(Q=await h.handleDirectory?.(X,V,t)),Q){_=!0;continue}for(let de of await(0,DY.default)(I,{onlyFiles:!1,objectMode:!0})){let{path:j,dirent:ae}=de;_=!0;let Oe=(0,Ot.relative)(e,j).replace(/\\/g,"/");if(Y)if(Oe.startsWith(Y))Oe=Oe.slice(Y.length+1);else throw new Error(`The root path '${f.root}' does not reference a valid part of the file path '${Oe}'.The root path should be used to indicate the relative path/part of the file path for determining the exported web path.`);let Ne=X+(X.endsWith("/")?"":"/")+Oe;try{if(ae.isFile()){let Me=await Qme(j);Sl.isMainThread&&await h.setupFile?.(Me,Ne,j,t),t.isWorker&&await h.handleFile?.(Me,Ne,j,t)}else Sl.isMainThread&&await h.setupDirectory?.(Ne,j,t),t.isWorker&&await h.handleDirectory?.(Ne,j,t)}catch(Me){Me.message=`Could not load ${ae.isFile()?"file":"directory"} '${j}'${f.module?" using '"+f.module+"'":""} for application '${e}' due to: ${Me.message}`,UE?.(Me),((0,Rd.getWorkerIndex)()===0?console:gd.default).error(Me),t.set(f.path||"/",new ea(Me)),Ad.set(n?E:(0,Ot.basename)(e),Me.message)}}}}catch(m){m.message=`Could not load component '${E}' for application '${(0,Ot.basename)(e)}' due to: ${m.message}`,UE?.(m),((0,Rd.getWorkerIndex)()===0?console:gd.default).error(m),t.set(f.path||"/",new ea(m),null,!0),Ad.set(n?E:(0,Ot.basename)(e),m.message)}}if(mT=d,Sl.isMainThread&&!MY&&i&&(0,Rd.watchDir)(e,async()=>UY()),c.extensionModule){let E=await bS((0,Ot.join)(e,c.extensionModule));return pT.set(o,E),E}if(!_&&t.isWorker){let E=`${e} did not load any modules, resources, or files, is this a valid component?`;UE?.(new Error(E)),((0,Rd.getWorkerIndex)()===0?console:gd.default).error(E),Ad.set((0,Ot.basename)(e),E)}}catch(c){console.error(`Could not load application directory ${e}`,c),c.message=`Could not load application due to ${c.message}`,UE?.(c),t.set("",new ea(c))}}var Nt,Ot,Sl,CY,aw,yd,DY,Rd,gd,PY,LY,zme,TT,Qme,nw,iw,MY,sw,Ad,Jme,ow,wY,pT,UE,mT,Zme,Jf=Ie(()=>{Nt=require("fs"),Ot=require("path"),Sl=require("worker_threads"),CY=require("yaml"),aw=L(se()),yd=L(M());ND();Z$();nV();aV();cV();RV();t1();a1();DY=L(require("fast-glob")),Rd=L(dt()),gd=L(W());bN();qr();PY=L(_e());Pe();wI();LY=L(se()),zme=L(aY());km();hY();us();IY();TT=L(wt());vS();fy();({readFile:Qme}=Nt.promises),nw=(0,TT.resolvePath)(aw.get(yd.CONFIG_PARAMS.COMPONENTSROOT)),iw=new Map,Ad=new Map;a(UY,"loadComponentDirectories");Jme={REST:CS,rest:CS,graphql:RN,graphqlSchema:Pg,roles:yN,jsResource:NN,fastifyRoutes:YN,login:wN,static:WN,operationsApi:zme,customFunctions:{},http:{},clustering:QI,replication:ca,authentication:Hf,mqtt:rw},ow={rest:!0,graphql:!0,graphqlSchema:{files:"*.graphql"},roles:{files:"roles.yaml"},jsResource:{files:"resources.js"},fastifyRoutes:{files:"routes/*.js",path:"."}};Object.defineProperty(ow,"static",{value:{files:"web/**"}});wY=[],pT=new Map;a(Xme,"setErrorReporter");Zme=a(()=>mT,"getComponentName");a(ST,"loadComponent")});var nT=N((mMe,BY)=>{var{isMainThread:vY}=require("worker_threads"),{getTables:eSe,getDatabases:hMe,table:pMe}=(Pe(),oe(lt)),{loadComponentDirectories:tSe,loadComponent:rSe}=(Jf(),oe(Qf)),{resetResources:nSe}=(su(),oe(sB)),sSe=SO(),iSe=wt(),{dirname:oSe}=require("path"),{getConnection:aSe}=mr(),cSe=se(),{CONFIG_PARAMS:lSe}=M(),{loadCertificates:uSe}=Xs(),cw=new Map;async function dSe(e=!1){!vY&&cSe.get(lSe.CLUSTERING_ENABLED)&&aSe();try{vY&&await sSe()}catch(n){console.error(n)}let t=nSe();eSe(),t.isWorker=e,await uSe(),await rSe(oSe(iSe.getConfigFilePath()),t,"hdb",!0,cw),await tSe(cw,t);let r=[];for(let[n]of cw)n.ready&&r.push(n.ready());r.length>0&&await Promise.all(r)}a(dSe,"loadRootComponents");BY.exports.loadRootComponents=dSe});var dt=N((TMe,ai)=>{"use strict";var{Worker:_Se,MessageChannel:fSe,parentPort:Vi,isMainThread:fw,threadId:ESe,workerData:Ki}=require("worker_threads"),{PACKAGE_ROOT:hSe}=M(),{join:FY,isAbsolute:pSe,extname:mSe}=require("path"),{server:GY}=(qr(),oe(Ja)),{watch:SSe,readdir:TSe}=require("fs/promises"),{totalmem:HY}=require("os"),vE=M(),qY=se(),Yi=W(),{randomBytes:gSe}=require("crypto"),{_assignPackageExport:ASe}=fi(),RSe=M(),xY=1024*1024,va=[],Ps=[],ySe=50,Ew=1e4,bSe="restart",$Y="request_thread_info",VY="resource_report",KY="thread_info",YY="added-port",OSe="ack",lw;ASe("threads",Ps);ai.exports={startWorker:uw,restartWorkers:pw,shutdownWorkers:DSe,workers:va,setMonitorListener:xSe,onMessageFromWorkers:PSe,onMessageByType:ZY,broadcast:MSe,broadcastWithAcknowledgement:vSe,setChildListenerByType:CSe,getWorkerIndex:WY,getWorkerCount:jY,getTicketKeys:QY,setMainIsWorker:ISe,setTerminateTimeout:NSe,restartNumber:Ki?.restartNumber||1};Ps.onMessageByType=ZY;Ps.sendToThread=function(e,t){if(!t?.type)throw new Error("A message with a type must be provided");let r=Ps.find(n=>n.threadId===e);if(r)return r.postMessage(t),!0};ai.exports.whenThreadsStarted=new Promise(e=>{ai.exports.threadsHaveStarted=e});var hw;function NSe(e){Ew=e}a(NSe,"setTerminateTimeout");function WY(){return Ki?Ki.workerIndex:hw?0:void 0}a(WY,"getWorkerIndex");function jY(){return Ki?Ki.workerCount:hw?1:void 0}a(jY,"getWorkerCount");function ISe(e){hw=e,ai.exports.threadsHaveStarted()}a(ISe,"setMainIsWorker");var zY=1,gT;function QY(){return gT||(gT=fw?gSe(48):Ki.ticketKeys,gT)}a(QY,"getTicketKeys");Object.defineProperty(GY,"workerIndex",{get(){return WY()}});Object.defineProperty(GY,"workerCount",{get(){return jY()}});var JY={[$Y](e,t){BSe(t)},[VY](e,t){HSe(t,e)}};function uw(e,t={}){let r=process.constrainedMemory?.()||HY();r=Math.min(r,HY(),2e4*xY);let n=qY.get(vE.CONFIG_PARAMS.THREADS_MAXHEAPMEMORY)??Math.max(Math.floor(r/xY/(10+(t.threadCount||1)/4)),512),s=Math.min(Math.max(n>>6,16),64),i=[],o=[];for(let l of Ps){let u=new fSe;u.existingPort=l,i.push(u),o.push(u.port2)}mSe(e)||(e+=".js");let c=new _Se(pSe(e)?e:FY(hSe,e),{resourceLimits:{maxOldGenerationSizeMb:n,maxYoungGenerationSizeMb:s},execArgv:["--enable-source-maps"],argv:process.argv.slice(2),workerData:{addPorts:o,addThreadIds:i.map(l=>l.existingPort.threadId),workerIndex:t.workerIndex,workerCount:zY=t.threadCount,name:t.name,restartNumber:ai.exports.restartNumber,ticketKeys:QY()},transferList:o,...t});for(let{port1:l,existingPort:u}of i)u.postMessage({type:YY,port:l,threadId:c.threadId},[l]);return RT(c,!0),c.unexpectedRestarts=t.unexpectedRestarts||0,c.startCopy=()=>uw(e,t),c.on("error",l=>{Yi.error(`Worker index ${t.workerIndex} error:`,l)}),c.on("exit",l=>{va.splice(va.indexOf(c),1),!c.wasShutdown&&t.autoRestart!==!1&&(c.unexpectedRestarts<ySe?(t.unexpectedRestarts=c.unexpectedRestarts+1,uw(e,t)):Yi.error(`Thread has been restarted ${c.restarts} times and will not be restarted`))}),c.on("message",l=>{JY[l.type]?.(l,c)}),va.push(c),FSe(),t.onStarted&&t.onStarted(c),c.name=t.name,c}a(uw,"startWorker");var wSe=[vE.THREAD_TYPES.HTTP];async function pw(e=null,t=Math.max(zY>3,1),r=!0){if(fw){if(r){let{loadRootComponents:o}=nT();await o()}ai.exports.restartNumber++,t<1&&(t=t*va.length);let n=[],s=[];for(let o of va.slice(0)){if(e&&o.name!==e||o.wasShutdown)continue;Yi.trace("sending shutdown request to ",o.threadId),o.postMessage({restartNumber:ai.exports.restartNumber,type:vE.ITC_EVENT_TYPES.SHUTDOWN}),o.wasShutdown=!0,o.emit("shutdown",{});let c=wSe.indexOf(o.name)>-1,l=new Promise(u=>{let d=setTimeout(()=>{Yi.warn("Thread did not voluntarily terminate, terminating from the outside",o.threadId),o.terminate()},Ew*2).unref();o.on("exit",()=>{clearTimeout(d),n.splice(n.indexOf(l)),!c&&r&&o.startCopy(),u()})});if(n.push(l),c&&r){let u=o.startCopy(),d=new Promise(_=>{let E=a(f=>{f.type===RSe.ITC_EVENT_TYPES.CHILD_STARTED&&(Yi.trace("Worker has started",u.threadId),_(),s.splice(s.indexOf(d)),u.off("message",E))},"startListener");Yi.trace("Waiting for worker to start",u.threadId),u.on("message",E)});s.push(d),n.length>=t&&await Promise.race(n),s.length>=t&&await Promise.race(s)}}await Promise.all(n),await Promise.all(s);let{restartService:i}=qu();r&&(e==="http"||!e)&&qY.get(vE.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await i({service:"clustering"})}else Vi.postMessage({type:bSe,workerType:e})}a(pw,"restartWorkers");function CSe(e,t){JY[e]=t}a(CSe,"setChildListenerByType");function DSe(e){return pw(e,1/0,!1)}a(DSe,"shutdownWorkers");var XY=[];function PSe(e){XY.push(e)}a(PSe,"onMessageFromWorkers");var dw=new Map;function ZY(e,t){let r=dw.get(e);r||dw.set(e,r=[]),r.push(t)}a(ZY,"onMessageByType");var LSe=10;async function MSe(e,t){let r=0;for(let n of Ps)try{n.postMessage(e),r++>LSe&&(r=0,await new Promise(setImmediate))}catch(s){Yi.error("Unable to send message to worker",s)}t&&tW(e,null)}a(MSe,"broadcast");var AT=new Map,USe=1;function vSe(e){return new Promise(t=>{let r=0;for(let n of Ps)try{let s=USe++,i=a(()=>{AT.delete(s),--r===0&&t(),n!==Vi&&--n.refCount===0&&n.unref()},"ack_handler");i.port=n,n.ref(),n.refCount=(n.refCount||0)+1,AT.set(e.requestId=s,i),n.hasAckCloseListener||(n.hasAckCloseListener=!0,n.on(n.close?"close":"exit",()=>{for(let[,o]of AT)o.port===n&&o()})),n.postMessage(e),r++}catch(s){Yi.error("Unable to send message to worker",s)}r===0&&t()})}a(vSe,"broadcastWithAcknowledgement");function BSe(e){e.postMessage({type:KY,workers:eW()})}a(BSe,"sendThreadInfo");function eW(){let e=Date.now();return va.map(t=>({threadId:t.threadId,name:t.name,heapTotal:t.resources?.heapTotal,heapUsed:t.resources?.heapUsed,externalMemory:t.resources?.external,arrayBuffers:t.resources?.arrayBuffers,sinceLastUpdate:e-t.resources?.updated,...t.recentELU}))}a(eW,"getChildWorkerInfo");function HSe(e,t){e.resources=t,e.resources.updated=Date.now()}a(HSe,"recordResourceReport");var _w;function xSe(e){_w=e}a(xSe,"setMonitorListener");var kSe=1e3,kY=!1;function FSe(){kY||(kY=!0,setInterval(()=>{for(let e of va){let t=e.performance.eventLoopUtilization(),r;e.lastTotalELU?r=e.performance.eventLoopUtilization(t,e.lastTotalELU):r=t,e.lastTotalELU=t,e.recentELU=r}_w&&_w()},kSe).unref())}a(FSe,"startMonitoring");var GSe=1e3;if(Vi&&Ki?.addPorts){RT(Vi);for(let e=0,t=Ki.addPorts.length;e<t;e++){let r=Ki.addPorts[e];r.threadId=Ki.addThreadIds[e],RT(r)}setInterval(()=>{let e=process.memoryUsage();Vi.postMessage({type:VY,heapTotal:e.heapTotal,heapUsed:e.heapUsed,external:e.external,arrayBuffers:e.arrayBuffers})},GSe).unref(),lw=a(()=>new Promise((e,t)=>{Vi.on("message",r),Vi.postMessage({type:$Y});function r(n){n.type===KY&&(Vi.off("message",r),e(n.workers))}a(r,"receiveThreadInfo")}),"getThreadInfo")}else lw=eW;ai.exports.getThreadInfo=lw;function RT(e,t){Ps.push(e),e.on("message",r=>{if(r.type===YY)r.port.threadId=r.threadId,RT(r.port);else if(r.type===OSe){let n=AT.get(r.id);n&&n()}else tW(r,e)}).on("close",()=>{Ps.splice(Ps.indexOf(e),1)}).on("exit",()=>{Ps.splice(Ps.indexOf(e),1)}),t?e.refCount=100:e.unref()}a(RT,"addPort");function tW(e,t){for(let n of XY)n(e,t);let r=dw.get(e.type);if(r)for(let n of r)try{n(e,t)}catch(s){Yi.error(s)}}a(tW,"notifyMessageListeners");if(fw){let e,t,r=new Set,n=a(async(s,i)=>{i&&(e=i);for(let o of await TSe(s,{withFileTypes:!0}))o.isDirectory()&&o.name!=="node_modules"&&n(FY(s,o.name));try{for await(let{filename:o}of SSe(s,{persistent:!1}))r.add(o),t&&clearTimeout(t),t=setTimeout(async()=>{e&&await e(),await pw(),console.log("Reloaded HarperDB components, changed files:",Array.from(r)),r.clear()},100)}catch(o){console.warn("Error trying to watch component directory",s,o)}},"watch_dir");ai.exports.watchDir=n,process.env.WATCH_DIR&&n(process.env.WATCH_DIR)}else Vi.on("message",async e=>{let{type:t}=e;t===vE.ITC_EVENT_TYPES.SHUTDOWN&&(ai.exports.restartNumber=e.restartNumber,Vi.unref(),setTimeout(()=>{Yi.warn("Thread did not voluntarily terminate",ESe),process.exit(0)},Ew).unref())})});var uv={};je(uv,{AUDIT_STORE_OPTIONS:()=>Pf,Decoder:()=>Pc,HAS_CURRENT_RESIDENCY_ID:()=>rc,HAS_EXPIRATION_EXTENDED_TYPE:()=>a_,HAS_ORIGINATING_OPERATION:()=>o_,HAS_PREVIOUS_RESIDENCY_ID:()=>nc,REMOTE_SEQUENCE_UPDATE:()=>Kp,createAuditEntry:()=>Ul,getLastRemoved:()=>Yy,openAuditStore:()=>IT,readAuditEntry:()=>xt,removeAuditEntry:()=>wT,setAuditRetention:()=>$Se,transactionKeyEncoder:()=>dW});function IT(e){let t=e.auditStore=e.openDB(mw.AUDIT_STORE_NAME,{create:!1,...Pf});t||(t=e.auditStore=e.openDB(mw.AUDIT_STORE_NAME,Pf),nW(t,1)),t.rootStore=e;let r=[];t.addDeleteRemovalCallback=function(i,o){return r[i]=o,t.deleteCallbacks=r,{remove(){delete r[i]}}};let n=null;function s(i=yT){clearTimeout(n),n=setTimeout(async()=>{if(t.rootStore.status==="closed"||t.rootStore.status==="closing")return;let o=0,c,l;try{for(let{key:u,value:d}of t.getRange({start:1,snapshot:!1,end:Date.now()-Sw}))if(c=wT(t,u,d),l=u,await new Promise(setImmediate),++o>=qSe){i=10;break}await c}finally{o===0?i=Math.min(i<<1,Sw/10):nW(t,l),s(i)}},i).unref()}if(a(s,"scheduleAuditCleanup"),t.scheduleAuditCleanup=s,(0,HE.getWorkerIndex)()===(0,HE.getWorkerCount)()-1&&s(yT),(0,HE.getWorkerIndex)()===0&&!rW)for(let i of t.getKeys({reverse:!0,limit:1}))i>Date.now()&&(rW=!0,NT.error("The current time is before the last recorded entry in the audit log. Time reversal can undermine the integrity of data tracking and certificate validation and the time must be corrected."));return t}function wT(e,t,r){if((VSe(r)&15)===Tw){let n=xt(r),s=n.tableId;e.deleteCallbacks?.[s]?.(n.recordId)}return e.remove(t)}function nW(e,t){gw[0]=t,e.put(Symbol.for("last-removed"),_W)}function Yy(e){let t=e.get(Symbol.for("last-removed"));if(t)return _W.set(t),gw[0]}function $Se(e,t=yT){Sw=e,yT=t}function Ul(e,t,r,n,s,i,o,c,l,u,d,_,E){let f=fW[o];if(!f)throw new Error(`Invalid audit entry type ${o}`);let h=1;if(n&&(n>1?Ba.setFloat64(0,n):Ls.set(jg),h=9),l){if(l&16761087)throw new Error("Illegal extended type");h++}g(s),g(t),m(r),Ba.setFloat64(h,e),h+=8,l&rc&&g(u),l&nc&&g(d),l&a_&&(Ba.setFloat64(h,_),h+=8),l&o_&&g(EW[E]),i?m(i):Ls[h++]=0,l?Ba.setUint16(n?8:0,f|l|32768):Ls[n?8:0]=f;let T=Ls.subarray(0,h);if(c)return Buffer.concat([T,c]);return T;function m(S){let y=h;h+=1,h=(0,Tl.writeKey)(S,Ls,h);let I=h-y-1;I>127?I>16383?(NT.error("Key or username was too large for audit entry",S),h=y+1,Ls[y]=0):(Ls.copyWithin(y+2,y+1,h),Ba.setUint16(y,I|32768),h++):Ls[y]=I}function g(S){S<128?Ls[h++]=S:S<16384?(Ba.setUint16(h,S|32768),h+=2):S<1056964608?(Ba.setUint32(h,S|3221225472),h+=4):(Ls[h]=255,Ba.setUint32(h+1,S),h+=5)}}function VSe(e){let t=0;e[0]==66&&(t=8);let r=e[t];if(r<128)return r;let n=e.dataView||(e.dataView=new Pc(e.buffer,e.byteOffset,e.byteLength));return n.position=t,n.readInt()}function xt(e,t=0,r=void 0){try{let n=e.dataView||(e.dataView=new Pc(e.buffer,e.byteOffset,e.byteLength));n.position=t;let s;e[n.position]==66&&(s=n.readFloat64());let i=n.readInt(),o=n.readInt(),c=n.readInt(),l=n.readInt(),u=n.position,d=n.position+=l,_=n.readFloat64(),E,f,h,T;if(i&rc&&(E=n.readInt()),i&nc&&(f=n.readInt()),i&a_&&(h=n.readFloat64()),i&o_){let S=n.readInt();T=EW[S]}l=n.readInt();let m=n.position,g=n.position+=l;return{type:fW[i&7],tableId:c,nodeId:o,get recordId(){return(0,Tl.readKey)(e,u,d)},getBinaryRecordId(){return e.subarray(u,d)},version:_,previousLocalTime:s,get user(){return g>m?(0,Tl.readKey)(e,m,g):void 0},get encoded(){return t?e.subarray(t,r):e},getValue(S,y,I){if(i&bT||i&BE&&!y)return S.decoder.decode(e.subarray(n.position,r));if(i&BE&&I)return Aw(S.getEntry(this.recordId),I,S)},getBinaryValue(){return i&(bT|BE)?e.subarray(n.position,r):void 0},extendedType:i,residencyId:E,previousResidencyId:f,expiresAt:h,originatingOperation:T}}catch(n){return NT.error("Reading audit entry error",n,e),{}}}var Tl,OT,mw,lW,HE,uW,NT,Ls,Ba,dW,Pf,Sw,qSe,gw,_W,yT,rW,bT,BE,sW,Tw,iW,oW,aW,cW,Kp,rc,nc,o_,a_,fW,EW,Pc,Ji=Ie(()=>{Tl=require("ordered-binary"),OT=L(se()),mw=L(Ht()),lW=L(M()),HE=L(dt()),uW=L(te());vl();NT=L(W());CT();(0,OT.initSync)();Ls=Buffer.alloc(1024),Ba=new DataView(Ls.buffer,Ls.byteOffset,1024),dW={writeKey(e,t,r){return e===i_?(t.set(i_,r),r+8):typeof e=="number"?((t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).setFloat64(r,e),r+8):(0,Tl.writeKey)(e,t,r)},readKey(e,t,r){return e[t]===66?(e.dataView||(e.dataView=new DataView(e.buffer,e.byteOffset,e.byteLength))).getFloat64(t):(0,Tl.readKey)(e,t,r)}},Pf={encoding:"binary",keyEncoder:dW},Sw=(0,uW.convertToMS)((0,OT.get)(lW.CONFIG_PARAMS.LOGGING_AUDITRETENTION))||86400*3,qSe=1e3,gw=new Float64Array(1),_W=new Uint8Array(gw.buffer),yT=1e4,rW=!1;a(IT,"openAuditStore");a(wT,"removeAuditEntry");a(nW,"updateLastRemoved");a(Yy,"getLastRemoved");a($Se,"setAuditRetention");bT=16,BE=32,sW=1,Tw=2,iW=3,oW=4,aW=5,cW=6,Kp=11,rc=512,nc=1024,o_=2048,a_=4096,fW={put:sW|bT,[sW]:"put",delete:Tw,[Tw]:"delete",message:iW|bT,[iW]:"message",invalidate:oW|BE,[oW]:"invalidate",patch:aW|BE,[aW]:"patch",relocate:cW,[cW]:"relocate"},EW={insert:1,update:2,upsert:3,1:"insert",2:"update",3:"upsert"};a(Ul,"createAuditEntry");a(VSe,"readAction");a(xt,"readAuditEntry");Pc=class extends DataView{static{a(this,"Decoder")}position=0;readInt(){let t;return t=this.getUint8(this.position++),t>=128?t>=192?t===255?(t=this.getUint32(this.position),this.position+=4,t):(t=this.getUint32(this.position-1)&1073741823,this.position+=3,t):(t=this.getUint16(this.position-1)&32767,this.position++,t):t}readFloat64(){try{let t=this.getFloat64(this.position);return this.position+=8,t}catch(t){throw t.message=`Error reading float64: ${t.message} at position ${this.position}`,t}}}});var Rw={};je(Rw,{add:()=>DT,applyReverse:()=>hW,getRecordAtTime:()=>Aw,rebuildUpdateBefore:()=>PT});function DT(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n+BigInt(r.value):isNaN(e[t])?e[t]=r.value:e[t]=n+r.value}function PT(e,t,r){let n=null;for(let s in e)if(s in t){let i=t[s];if(i?.__op__){let o=e[s];if(o?.__op__)if(o.__op__===i.__op__)n||(n={}),n[s]=o;else throw new Error("Can not merge updates with different operations");else n||(n={}),n[s]=o,DT(n,s,i)}else r&&(n||(n={}),n[s]=i)}else n||(n={}),n[s]=e[s];return n}function hW(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=KSe[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=pW}}function Aw(e,t,r){let n=r.rootStore.auditStore,s={...e.value},i=e.localTime;for(;i>t;){let l=n.get(i),u=xt(l);switch(u.type){case"put":s=u.getValue(r);break;case"patch":hW(s,u.getValue(r));break;case"delete":s=null}i=u.previousLocalTime}let o={},c=0;for(let l in s)s[l]===pW&&(o[l]=!0,c++);for(;c>0&&i>0;){let l=n.get(i),u=xt(l),d;switch(u.type){case"put":d=u.getValue(r);break;case"patch":d=u.getValue(r);break}for(let _ in d)o[_]&&(s[_]=d[_],o[_]=!1,c--);i=u.previousLocalTime}if(c>0)for(let l in o)s[l]=null;return s}var KSe,pW,CT=Ie(()=>{Ji();a(DT,"add");DT.reverse=function(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n-BigInt(r.value):isNaN(e[t])||(e[t]=n-r.value)};KSe={add:DT};a(PT,"rebuildUpdateBefore");a(hW,"applyReverse");pW={};a(Aw,"getRecordAtTime")});function Zn(e){return e[_r]||(e[_r]=Object.create(null))}function BT(e,t){let r=e.prototype,n={},s=t.attributes||t.properties||[];for(let o of s){let c=o.name,l,u;if(o.resolve)u={get(){return o.resolve(this,this[Fe])},set(d){return o.set(this,d)},configurable:!0};else{switch(o.type){case"String":l=a(function(d){if(!(typeof d=="string"||d==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a string, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"ID":l=a(function(d){if(!(typeof d=="string"||d?.length>0&&d.every?.(_=>typeof _=="string")||d==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a string, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"Float":case"Number":l=a(function(d){let _=d?.__op__?d.value:d;if(!(typeof _=="number"||d==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a number, attempt to assign ${_}`);Zn(this)[c]=d},"set");break;case"Int":l=a(function(d){let _=d?.__op__?d.value:d;if(!(_>>0===_||d==null&&o.nullable!==!1))if(typeof _=="number"&&Math.abs((_>>0)-_)<=1)_=Math.round(_),d?.__op__?d.value=_:d=_;else throw new Ms.ClientError(`${c} must be an integer between -2147483648 and 2147483647, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"Long":l=a(function(d){let _=d?.__op__?d.value:d;if(!(Math.round(_)===d&&Math.abs(_)<=9007199254740992||d==null&&o.nullable!==!1))if(typeof _=="number"&&Math.abs(_)<=9007199254740992)_=Math.round(_),d?.__op__?d.value=_:d=_;else throw new Ms.ClientError(`${c} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"BigInt":l=a(function(d){let _=d?.__op__?d.value:d;if(!(typeof _=="bigint"||d==null&&o.nullable!==!1))if(typeof _=="string"||typeof _=="number")_=BigInt(_),d?.__op__?d.value=_:d=_;else throw new Ms.ClientError(`${c} must be a number, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"Boolean":l=a(function(d){if(!(typeof d=="boolean"||d==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a boolean, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"Date":l=a(function(d){if(!(d instanceof Date||d==null&&o.nullable!==!1))if(typeof d=="string"||typeof d=="number")d=new Date(d);else throw new Ms.ClientError(`${c} must be a Date, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"Bytes":l=a(function(d){if(!(d instanceof Uint8Array||d==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a Buffer or Uint8Array, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"Any":case void 0:l=a(function(d){Zn(this)[c]=d},"set");break;default:l=a(function(d){if(!(typeof d=="object"||d==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be an object, attempt to assign ${d}`);Zn(this)[c]=d},"set")}u={get(){let d=this[_r];if(d&&c in d){let E=d[c];if(E?.__op__){let f=this[ve]?.[c];return E.update(f)}return E}let _=this[ve]?.[c];if(_&&typeof _=="object"){let E=SW(_,o);if(E)return d||(d=this[_r]=Object.create(null)),d[c]=E}return _},set:l,enumerable:!0,configurable:!0}}u.get.isAttribute=!0,n[c]=u,(!(c in r)||Object.getOwnPropertyDescriptor(r,c)?.get?.isAttribute)&&Object.defineProperty(r,c,u)}i("getProperty",function(o){let c=n[o];if(c)return c.get.call(this);let l=this[_r];return l?.[o]!==void 0?l[o]:this[ve]?.[o]}),i("set",function(o,c){let l=n[o];if(l)return l.set.call(this,c);if(t.sealed)throw new Ms.ClientError("Can not add a property to a sealed table schema");Zn(this)[o]=c}),i("deleteProperty",function(o){Zn(this)[o]=void 0}),i("toJSON",function(){let o=this[_r],c;for(let u in o){c||(c={...this[ve]});let d=o[u];if(d?.__op__){let _=c[u];d=d.update(_)}c[u]=d}return Object.keys(this).length>0&&(c||(c={...this[ve]}),Object.assign(c,this)),c||this[ve]}),r.get||i("get",r.getProperty),r.delete||i("delete",r.deleteProperty);function i(o,c){Object.defineProperty(r,o,{value:c,configurable:!0})}a(i,"setMethod")}function SW(e,t){let r;switch(e.constructor){case Object:return t?((r=t.TrackedObject)||(t.TrackedObject=r=class{static{a(this,"TrackedObject")}constructor(s){if(s?.[ve])throw new Error("Can not track an already tracked object, check for circular references");this[ve]=s}},BT(r,t)),new r(e)):new LT(e);case Array:let n=new UT(e.length);n[ve]=e;for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=SW(o,t?.elements)),n[s]=o}return n;default:return e}}function dp(e){let t=e[_r],r;for(let s in t){r||(r={...e[ve]});let i=t[s];if(i&&typeof i=="object")if(i.__op__){let o=r[s];i=i.update(o)}else i=dp(i);r[s]=i}return Object.keys(e).length>0&&(r||(r={...e[ve]}),Object.assign(r,e)),r||e[ve]}function Al(e,t=e[_r]){let r;if(mW.call(e,ve)&&e.constructor===Array&&!Object.isFrozen(e)){r=e;for(let n=0,s=e.length;n<s;n++){let i=e[n];if(i&&typeof i=="object"){let o=Al(i);o!==i&&r===e&&(r=e.slice(0)),i=o}r[n]=i}return Object.freeze(r)}for(let n in t){r||(r={...e[ve]});let s=t[n];if(s&&typeof s=="object")if(s.__op__){let i=Rw[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=Al(s);r[n]=s}return r?Object.freeze(r):mW.call(e,ve)?e[ve]:e}function MT(e){let t=e[ve];if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[gl]||e.length!==t.length)return!0;for(let r=0,n=e.length;r<n;r++){let s=t[r],i=e[r];if(s&&i?.[ve]===s){if(MT(i))return!0}else return!0}}else{let r=e[_r];if(r&&!t)return!0;for(let n in r){let s=r[n];if(s&&typeof s=="object"){let i=t[n];if(i&&s[ve]===i){if(MT(s))return!0}else return!0}else return!0}}return!1}var Ms,_r,LT,mW,gl,UT,vT,_p=Ie(()=>{Vs();Ms=L(_e());CT();_r=Symbol("own-data");a(Zn,"getChanges");a(BT,"assignTrackedAccessors");a(SW,"trackObject");LT=class{static{a(this,"GenericTrackedObject")}constructor(t){if(t?.[ve])throw new Error("Can not track an already tracked object, check for circular references");this[ve]=t}};BT(LT,{});a(dp,"collapseData");mW=Object.prototype.hasOwnProperty;a(Al,"updateAndFreeze");a(MT,"hasChanges");gl=Symbol.for("has-array-changes"),UT=class extends Array{static{a(this,"TrackedArray")}[gl];constructor(t){super(t)}splice(...t){return this[gl]=!0,super.splice(...t)}push(...t){return this[gl]=!0,super.push(...t)}pop(){return this[gl]=!0,super.pop()}unshift(...t){return this[gl]=!0,super.unshift(...t)}shift(){return this[gl]=!0,super.shift()}};UT.prototype.constructor=Array;vT=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var _R={};je(_R,{CONTEXT:()=>Fe,ID_PROPERTY:()=>ze,IS_COLLECTION:()=>ci,MultiPartId:()=>xT,RECORD_PROPERTY:()=>ve,Resource:()=>Lr,snake_case:()=>WSe,transformForSelect:()=>kT});function WSe(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function TW(e,t){if(Rl=!1,e==="")return null;if(e=e.slice(1),t.splitSegments){if(e.indexOf("/")===-1)return e===""?(Rl=!0,null):t.coerceId(decodeURIComponent(e));let r=e.split("/"),n=new xT;for(let s=0;s<r.length;s++){let i=r[s];if(!i&&s===r.length-1){Rl=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}else{if(e==="")return Rl=!0,null;e[e.length-1]==="/"&&(Rl=!0)}return t.coerceId(decodeURIComponent(e))}function es(e,t){n.reliesOnPrototype=!0;let r=t.hasContent;return n;function n(s,i,o){let c,l,u,d;if(r?(o?(d=i,o=o[Fe]||o):i?typeof s=="object"&&s&&(!Array.isArray(s)||typeof s[0]=="object")?(d=s,c=d[this.primaryKey]??null,o=i[Fe]||i):d=i:(d=s,s=void 0,c=d[ze]??d[this.primaryKey]),c===null&&(u=!0)):i?o=i[Fe]||i:s&&typeof s=="object"&&!Array.isArray(s)&&(o=s),c===void 0)if(typeof s=="object"&&s){if(l=s,typeof(c=s.url)=="string"){let f=c.indexOf("?");if(f>-1){let T=this.parseQuery(c.slice(f+1));l?T&&(l=Object.assign(T,l)):l=T,c=c.slice(0,f)}let h=this.parsePath(c,o,l);h?.id!==void 0?(h.query&&(l?l=Object.assign(h.query,l):l=h.query),u=h.isCollection,c=h.id):c=h}else if(s[Symbol.iterator]){c=[],u=!0;for(let f of s){if(typeof f=="object"&&f)break;c.push(f)}c.length===0?c=null:(c.length===1&&(c=c[0]),l.slice&&(l=l.slice(c.length,l.length),l.length===0&&(l=null,u=!1)))}c===void 0&&(c=s.id??null,c==null&&(u=!0))}else c=s,l=new ol(c),c==null&&(u=!0);o||(o={});let _;if(l?.ensureLoaded!=null||l?.async||u?(_={...t},l?.ensureLoaded!=null&&(_.ensureLoaded=l.ensureLoaded),l?.async&&(_.async=l.async),u&&(_.isCollection=!0)):_=t,o.transaction){let f=this.getResource(c,o,_);return f.then?f.then(E):E(f)}else return Dt(o,()=>{let f=this.getResource(c,o,_);return f.then?f.then(E):E(f)},_);function E(f){if(o.authorize){o.authorize=!1;let h=t.type==="read"?f.allowRead(o.user,l,o):t.type==="update"?f.doesExist?.()===!1?f.allowCreate(o.user,d,o):f.allowUpdate(o.user,d,o):t.type==="create"?f.allowCreate(o.user,d,o):f.allowDelete(o.user,l,o);if(h?.then)return h.then(T=>{if(!T)throw new HT(o.user);return typeof d?.then=="function"?d.then(m=>e(f,l,o,m)):e(f,l,o,d)});if(!h)throw new HT(o.user)}return typeof d?.then=="function"?d.then(h=>e(f,l,o,h)):e(f,l,o,d)}a(E,"authorizeActionOnResource")}}function ts(e,t){let r=new RW.ClientError(`The ${e.constructor.name} does not have a ${t} method implemented`,405);r.allow=[],r.method=t;for(let n of["get","put","post","delete","query","move","copy"])typeof e[n]=="function"&&r.allow.push(n);throw r}function yw(e,t,r){let n=e[ve];if(n){let s=e[_r];return i=>{let o,c;return e.hasOwnProperty(i)&&typeof(o=e[i])!="function"?o:s&&i in s?s[i]:(c=t?.[i])?c(e,r):n[i]}}else return t?s=>{let i=t[s];return i?i(e,r):e[s]}:s=>e[s]}function kT(e,t){let r=t?.propertyResolvers,n=t[Fe],s;if(typeof e=="string")return a(function o(c){return c.then?c.then(o):Array.isArray(c)?c.map(o):yw(c,r,n)(e)},"transform");if(typeof e=="object"){if(e.asArray)return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(c);let u=[],d=i(yw(l,r,n));for(let _ of e)u.push(d(_));return u},"transform");let o=e.forceNulls;return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(E=>E&&typeof E=="object"?c(E):E);let u={},d=i(yw(l,r,n)),_;for(let E of e){let f=d(E);f===void 0&&o&&(f=null),f?.then?(_||(_=[]),_.push(f.then(h=>u[E.name||E]=h))):u[E.name||E]=f}return _?Promise.all(_).then(()=>u):u},"transform")}else throw new Error("Invalid select argument type "+typeof e);function i(o){return c=>{if(typeof c=="string")return o(c);if(typeof c=="object")if(c.name){s||(s={});let l=s[c.name];if(!l){let d=r[c.name]?.definition?.tableClass;l=s[c.name]=kT(c.select||c,d)}let u=o(c.name);return l(u)}else return o(c);else return c}}a(i,"handleProperty")}var gW,AW,RW,Fe,ze,ci,ve,YSe,Lr,HT,Rl,xT,Vs=Ie(()=>{gW=require("crypto");Ll();AW=L(fi()),RW=L(_e());_p();Sc();_E();Fe=Symbol.for("context"),ze=Symbol.for("primary-key"),ci=Symbol("is-collection"),ve=Symbol("stored-record"),YSe={json:"application/json",cbor:"application/cbor",msgpack:"application/x-msgpack",csv:"text/csv"},Lr=class{static{a(this,"Resource")}static transactions;constructor(t,r){this[ze]=t;let n=r?.[Fe];this[Fe]=n!==void 0?n:r||null}static get=es(function(t,r,n,s){let i=t.get?.(r);if(i?.then)return i.then(o);return o(i);function o(c){let l;if((l=r?.select)&&c!=null&&!c.selectApplied){let u=kT(l,t.constructor);return typeof c?.map=="function"?c.map(u):u(c)}return c}},{type:"read",letItLinger:!0,ensureLoaded:!0,async:!0});static put=es(function(t,r,n,s){if(Array.isArray(s)&&t[ci]){let i=[],o=n.authorize;for(let c of s){let l=t.constructor,u=l.getResource(c[l.primaryKey],n,{async:!0});u.then?i.push(u.then(d=>d.put(c,n))):i.push(u.put(c,n))}return Promise.all(i)}return t.put?t.put(s,r):ts(t,"put")},{hasContent:!0,type:"update"});static patch=es(function(t,r,n,s){return t.patch?t.patch(s,r):ts(t,"patch")},{hasContent:!0,type:"update"});static delete=es(function(t,r,n,s){return t.delete?t.delete(r):ts(t,"delete")},{hasContent:!1,type:"delete"});static getNewId(){return(0,gW.randomUUID)()}static create(t,r,n){let s;return t==null?s=r?.[this.primaryKey]??this.getNewId():Array.isArray(t)&&typeof t[0]!="object"?s=r?.[this.primaryKey]??[...t,this.getNewId()]:typeof t!="object"?s=r?.[this.primaryKey]??[t,this.getNewId()]:(s=t?.[this.primaryKey]??this.getNewId(),n=r||{},r=t),n||(n={}),Dt(n,()=>{let i=new this(s,n),o=i.update?i.update(r,!0):ts(i,"update");return n.newLocation=s,n.createdResource=!0,o?.then?o.then(()=>i):i})}static invalidate=es(function(t,r,n,s){return t.invalidate?t.invalidate(r):ts(t,"delete")},{hasContent:!1,type:"update"});static post=es(function(t,r,n,s){return t[ze]!=null&&t.update?.(),t.post(s,r)},{hasContent:!0,type:"create"});static connect=es(function(t,r,n,s){return t.connect?t.connect(s,r):ts(t,"connect")},{hasContent:!0,type:"read"});static subscribe=es(function(t,r,n,s){return t.subscribe?t.subscribe(r):ts(t,"subscribe")},{type:"read"});static publish=es(function(t,r,n,s){return t[ze]!=null&&t.update?.(),t.publish?t.publish(s,r):ts(t,"publish")},{hasContent:!0,type:"create"});static search=es(function(t,r,n,s){let i=t.search?t.search(r):ts(t,"search"),o=n.select;if(o&&n.hasOwnProperty("select")&&i!=null&&!i.selectApplied){let c=kT(o,t.constructor);return i.map(c)}return i},{type:"read"});static query=es(function(t,r,n,s){return t.search?t.search(s,r):ts(t,"search")},{hasContent:!0,type:"read"});static copy=es(function(t,r,n,s){return t.copy?t.copy(s,r):ts(t,"copy")},{hasContent:!0,type:"create"});static move=es(function(t,r,n,s){return t.move?t.move(s,r):ts(t,"move")},{hasContent:!0,type:"delete"});async post(t){if(this[ci])return(await this.constructor.create(this[ze],t,this[Fe]))[ze];ts(this,"post")}static isCollection(t){return t?.[ci]}static coerceId(t){return t}static parseQuery(t){return IS(t)}static parsePath(t,r,n){let s=t.indexOf(".");if(s>-1){let o=t.slice(s+1);t=t.slice(0,s);let c=r?.headers&&YSe[o];if(c)r.requestedContentType=c;else if(n)n.property=o;else return{query:{property:o},id:TW(t,this),isCollection:Rl}}let i=TW(t,this);return Rl?{id:i,isCollection:!0}:i}static getResource(t,r,n){let s,i=r[Fe],o;typeof r.isCollection=="boolean"&&r.hasOwnProperty("isCollection")?o=r.isCollection:o=n?.isCollection;let c=o&&this.Collection||this;if(i||(i=i===void 0?r:{}),i.transaction){let l;if(i.resourceCache?l=i.resourceCache:l=i.resourceCache=[],l.asMap){let u=l.asMap.get(t);if(s=u?.find(d=>d.constructor===c),s)return s;u||l.asMap.set(t,u=[]),u.push(s=new c(t,i))}else{if(s=l.find(u=>u[ze]===t&&u.constructor===c),s)return s;if(l.push(s=new c(t,i)),l.length>10){let u=new Map;for(let d of l){let _=d[ze],E=u.get(_);E?E.push(d):u.set(_,[d])}i.resourceCache.length=0,i.resourceCache.asMap=u}}}else s=new c(t,i);return o&&(s[ci]=!0),s}subscribe(t){return new Mn}connect(t){return t?.subscribe!==!1?this.subscribe?.(t):new Mn}allowRead(t){return t?.role.permission.super_user}allowUpdate(t){return t?.role.permission.super_user}allowCreate(t){return t?.role.permission.super_user}allowDelete(t){return t?.role.permission.super_user}getId(){return this[ze]}getContext(){return this[Fe]}};Lr.prototype[Fe]=null;(0,AW._assignPackageExport)("Resource",Lr);a(WSe,"snake_case");HT=class extends Error{static{a(this,"AccessError")}constructor(t){t?(super("Unauthorized access to resource"),this.statusCode=403):(super("Must login"),this.statusCode=401)}};a(TW,"pathToId");xT=class extends Array{static{a(this,"MultiPartId")}toString(){return this.join("/")}};a(es,"transactional");a(ts,"missingMethod");a(yw,"selectFromObject");a(kT,"transformForSelect")});var FO={};je(FO,{EVICTED:()=>ba,INVALIDATED:()=>Ns,coerceType:()=>GT,makeTable:()=>VT,setServerUtilities:()=>rTe,updateResource:()=>qT});function VT(e){let{primaryKey:t,indices:r,tableId:n,tableName:s,primaryStore:i,databasePath:o,databaseName:c,auditStore:l,schemaDefined:u,dbisDB:d,sealed:_,splitSegments:E,replicate:f}=e,{expirationMS:h,evictionMS:T,audit:m,trackDeletes:g}=e,{attributes:S}=e;S||(S=[]);let y=Jg(i,n,l),I,U,H={},X=Promise.resolve(),Y,V,ne;for(let v of S)(v.assignCreatedTime||v.name==="__createdtime__")&&(Y=v),(v.assignUpdatedTime||v.name==="__updatedtime__")&&(V=v),v.expiresAt&&(ne=v),v.isPrimaryKey&&(H=v);let Q,de=[],j=[],ae=1,Oe=2,Ne={},Me={},Gr=864e5,Dd,Fa,wn,Pd=!1,Nl,Uw=new Map,jE=new Map,vt,Ga,qa=Od.get(Us.CONFIG_PARAMS.REPLICATION_DATABASES);if(Array.isArray(qa)){for(let v of qa)if(v.name===c&&v.replicateTo>=0){Ga=v.replicateTo;break}}let vs=i.getRange({start:!1,end:!1}).constructor,Bs=10,zE=6;m&&ie();class Ve extends Lr{static name=s;static primaryStore=i;static auditStore=l;static primaryKey=t;static tableName=s;static tableId=n;static indices=r;static audit=m;static databasePath=o;static databaseName=c;static attributes=S;static replicate=f;static sealed=_;static splitSegments=E??!0;static createdTimeProperty=Y;static updatedTimeProperty=V;static propertyResolvers;static userResolvers={};static sources=[];static get expirationMS(){return h}static dbisDB=d;static schemaDefined=u;static sourcedFrom(p,A){if(A&&(this.sourceOptions=A,(A.expiration||A.eviction||A.scanInterval)&&this.setTTLExpiration(A)),A?.intermediateSource)p.intermediateSource=!0,this.sources.unshift(p);else{if(this.sources.some(O=>!O.intermediateSource)){if(this.sources.some(O=>O.name===p.name))return;throw new Error("Can not have multiple canonical (non-intermediate) sources")}this.sources.push(p)}U=U||p.get&&(!p.get.reliesOnPrototype||p.prototype.get),I=I||p.load;let w=a(O=>{let B=this.sources;if(B=B.filter(k=>k.intermediateSource&&k[O]&&(!k[O].reliesOnPrototype||k.prototype[O])),B.length>0)if(B.length===1){let k=B[0];return(C,F,x)=>{if(C?.source!==k)return k[O](F,x,C)}}else return(k,C,F)=>{let x=[];for(let q of B){if(k?.source===q)break;x.push(q[O](C,F,k))}return Promise.all(x)}},"getApplyToIntermediateSource"),R=this.sources[this.sources.length-1];R.intermediateSource&&(R={});let b=a(O=>{if(R[O]&&(!R[O].reliesOnPrototype||R.prototype[O]))return(B,k,C)=>{if(!B?.source)return R[O](k,C,B)}},"getApplyToCanonicalSource");Ne={put:b("put"),patch:b("patch"),delete:b("delete"),publish:b("publish")},Me={put:w("put"),patch:w("patch"),delete:w("delete"),publish:w("publish"),invalidate:w("invalidate")};let D=R.shouldRevalidateEvents;return(async()=>{let O=!1,B,k=a(async(C,F)=>{let x=C.value,q=C.table?We[c][C.table]:Ve;if(c===Us.SYSTEM_SCHEMA_NAME&&(C.table===Us.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME||C.table===Us.SYSTEM_TABLE_NAMES.USER_TABLE_NAME)&&(O=!0),C.id===void 0&&(C.id=x[q.primaryKey],C.id===void 0))throw new Error("Replication message without an id "+JSON.stringify(C));C.source=p;let ee={residencyId:tt(C.residencyList),isNotification:!0,ensureLoaded:!1,nodeId:C.nodeId},G=await q.getResource(C.id,F,ee);switch(C.type){case"put":return D?G._writeInvalidate(ee):G._writeUpdate(x,!0,ee);case"patch":return D?G._writeInvalidate(ee):G._writeUpdate(x,!1,ee);case"delete":return G._writeDelete(ee);case"publish":return G._writePublish(x,ee);case"invalidate":return G._writeInvalidate(ee);case"relocate":return G._writeRelocate(ee);default:qe.default.error?.("Unknown operation",C.type,C.id)}},"writeUpdate");try{let C=p.subscribe;C&&g==null&&(g=!0);let F={crossThreads:!1,inTransactionUpdates:!0,supportsTransactions:!0,omitCurrent:!0},x=p.subscribeOnThisThread?p.subscribeOnThisThread((0,yl.getWorkerIndex)(),F):(0,yl.getWorkerIndex)()===0,q=C&&x&&await p.subscribe?.(F);if(q){let ee;for await(let G of q)try{if(!(G.type==="transaction"?G.writes[0]:G)){qe.default.error?.("Bad subscription event",G);continue}if(G.source=p,G.type==="end_txn"){if(ee?.resolve(),G.localTime&&B!==G.localTime){if(G.remoteNodeIds?.length>0){let Ae=[Symbol.for("seq"),G.remoteNodeIds[0]],re=d.get(Ae),K=re?.nodes;K||(K=[]);for(let Be of G.remoteNodeIds.slice(1)){let we=K.find(ce=>ce.id===Be);K=K.filter(ce=>ce.id!==Be||ce===we),we||(we={id:Be,seqId:0},K.push(we)),we.seqId=Math.max(re?.seqId??1,G.localTime),Be===ee?.nodeId&&(we.lastTxnTime=G.timestamp)}let ge=Math.max(re?.seqId??1,G.localTime);qe.default.trace?.("Received txn",c,ge,G.localTime,G.remoteNodeIds),d.put(Ae,{seqId:ge,nodes:K})}B=G.localTime}G.onCommit&&ee?.committed.then(G.onCommit);continue}if(ee)if(G.beginTxn)ee.resolve();else{ee.write_promises.push(k(G,ee));continue}!G.timestamp&&G.version&&(G.timestamp=G.version);let Ee=Dt(G,()=>{if(G.type==="transaction"){let Ae=[];for(let re of G.writes)try{Ae.push(k(re,G))}catch(K){throw K.message+=" writing "+JSON.stringify(re)+" of event "+JSON.stringify(G),K}return Promise.all(Ae)}else if(G.type==="define_schema"){let Ae=this.attributes.slice(0),re;for(let K of G.attributes)Ae.find(ge=>ge.name===K.name)||(Ae.push(K),re=!0);re&&(Et({table:s,database:c,attributes:Ae,origin:"cluster"}),GE.signalSchemaChange(new qE.SchemaEventMsg(process.pid,Us.OPERATIONS_ENUM.CREATE_TABLE,c,s)))}else return G.beginTxn?(ee=G,ee.write_promises=[k(G,G)],new Promise(Ae=>{ee.resolve=()=>Ae(Promise.all(ee.write_promises))})):k(G,G)});ee&&(ee.committed=Ee),O&&Ee&&!Ee?.waitingForUserChange&&(Ee.then(()=>GE.signalUserChange(new qE.UserEventMsg(process.pid))),Ee.waitingForUserChange=!0),G.onCommit&&(Ee?Ee.then(G.onCommit):G.onCommit())}catch(Re){qe.default.error?.("error in subscription handler",Re)}}}catch(C){qe.default.error?.(C)}})(),this}static get isCaching(){return U}static get shouldRevalidateEvents(){return this.prototype.get!==Ve.prototype.get}static getResource(p,A,w){let R=super.getResource(p,A,w);if(p!=null){ji(p);try{if(R.hasOwnProperty(ve))return R;if(typeof p=="object"&&p&&!Array.isArray(p))throw new Error(`Invalid id ${JSON.stringify(p)}`);let b=!w?.async||i.cache?.get?.(p),D=Ir(A),O=D.getReadTxn();if(O?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");return Va(p,A,{transaction:O,ensureLoaded:w?.ensureLoaded},b,B=>{if(B?qT(R,B):R[ve]=null,A.onlyIfCached&&A.noCacheStore){if(!R.doesExist())throw new Nr.ServerError("Entry is not cached",504)}else if(w?.ensureLoaded){let k=Ld(p,B,A,R);if(k)return D?.disregardReadTxn(),R[bw]=!0,Nw(k,C=>(qT(R,C),R))}return R})}catch(b){throw b.message.includes("Unable to serialize object")&&(b.message+=": "+JSON.stringify(p)),b}}return R}ensureLoaded(){let p=Ld(this[ze],this[Fr],this[Fe]);if(p)return this[bw]=!0,Nw(p,A=>{this[Fr]=A,this[ve]=A.value,this[kE]=A.version})}static getNewId(){let p=H?.type;if(p==="String"||p==="ID")return super.getNewId();if(!vt){let b=i.getEntry(Symbol.for("id_allocation")),D=b?.value,O;if(D&&D.nodeName===server.hostname&&(!sTe(i)||D.pid===process.pid)){let B=D.start,k=D.end;O=B;for(let C of i.getKeys({start:k,end:B,limit:1,reverse:!0}))O=C}else D=R(b?.version??null),O=D.start;vt=new BigInt64Array([BigInt(O)+1n]),vt=new BigInt64Array(i.getUserSharedBuffer("id",vt.buffer)),vt.maxSafeId=D.end}let A=Number(Atomics.add(vt,0,1n)),w=p==="Int"?512:1048576;if(A+w>=vt.maxSafeId){let b=a(D=>{vt.maxSafeId=A+(p==="Int"?1023:4194303);let O=(p==="Int"?Math.pow(2,31):Math.pow(2,49))-1,B=D?void 0:i.useReadTransaction(),k=Number(vt[0]);for(let x of i.getKeys({start:k+1,end:O,limit:1,transaction:B}))O=x;B?.done();let{value:C,version:F}=i.getEntry(Symbol.for("id_allocation"));if(vt.maxSafeId<O){if(C.end>vt.maxSafeId-100)return;qe.default.info?.("New id allocation",A,vt.maxSafeId,F),i.put(Symbol.for("id_allocation"),{start:C.start,end:vt.maxSafeId,nodeName:server.hostname,pid:process.pid},Date.now(),F)}else{qe.default.warn?.(`Id conflict detected, starting new id allocation range, attempting to allocate to ${vt.maxSafeId}, but id of ${O} detected`);let x=R(F);x.alreadyUpdated||Atomics.store(vt,0,BigInt(x.start+1)),vt.maxSafeId=x.end}},"updateEnd");A+w===vt.maxSafeId?setImmediate(b):A+100>=vt.maxSafeId&&(qe.default.warn?.(`Synchronous id allocation required on table ${s}${p=="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`),i.transactionSync(()=>b(!0)))}return A;function R(b){let D=(p==="Int"?Math.pow(2,31):Math.pow(2,49))-1,O=D/4,B,k,C=!1,F,x;do{F=Math.floor(Math.random()*D),x={start:F,end:F+(p==="Int"?1024:4194304),nodeName:server.hostname,pid:process.pid},B=0;for(let q of i.getKeys({start:F,limit:1,reverse:!0}))B=q;k=D;for(let q of i.getKeys({start:F+1,end:D,limit:1}))k=q;O*=.875,O<1e3&&!C&&(C=!0,qe.default.error?.(`Id allocation in table ${s} is very dense, limited safe range of numbers to allocate ids in${p==="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`,F,B,k,O))}while(!(O<k-F&&(O<F-B||B===0)));return i.transactionSync(()=>{let q=i.getEntry(Symbol.for("id_allocation"));return(q?.version??null)==b?(qe.default.info?.("Allocated new id range",x),i.put(Symbol.for("id_allocation"),x,Date.now()),x):(qe.default.debug?.("Looks like ids were already allocated"),{alreadyUpdated:!0,...q.value})})}}static setTTLExpiration(p){if(typeof p=="number")h=p*1e3,T||(T=0);else if(p&&typeof p=="object")h=p.expiration*1e3,T=(p.eviction||0)*1e3,Gr=p.scanInterval*1e3;else throw new Error("Invalid expiration value type");if(h<0)throw new Error("Expiration can not be negative");Gr=Gr||(h+T)/4,xo()}static getResidencyRecord(p){return d.get([Symbol.for("residency_by_id"),p])}static setResidency(p){Ve.getResidency=p}static setResidencyById(p){Ve.getResidencyById=p}static getResidency(p,A,w){if(Ve.getResidencyById)return Ve.getResidencyById(p[t]);let R=Ga;if(A.replicateTo!=null){if(Array.isArray(A.replicateTo))return A.replicateTo.includes(server.hostname)?A.replicateTo:[server.hostname,...A.replicateTo];A.replicateTo>=0&&(R=A.replicateTo)}if(R>=0&&server.nodes){let b=[server.hostname];if(w)b.push(...w.slice(0,R));else{let D=server.nodes.map(k=>k.name),O=Math.floor(D.length*Math.random());b.push(...D.slice(O,O+R));let B=O+R-D.length;B>0&&b.push(...D.slice(0,B))}return b}}static enableAuditing(p=!0){m=p,p&&ie(),Ve.audit=p}static coerceId(p){return p===""?null:GT(p,H)}static async dropTable(){if(delete We[c][s],c===o){for(let p of S)d.remove(Ve.tableName+"/"+p.name),r[p.name]?.drop();d.remove(Ve.tableName+"/"),i.drop(),await d.committed}else console.log("legacy dropTable"),await i.close(),await fs.remove(data_path),await fs.remove(data_path===standard_path?data_path+MDB_LOCK_FILE_SUFFIX:path.join(path.dirname(data_path),MDB_LEGACY_LOCK_FILE_NAME));GE.signalSchemaChange(new qE.SchemaEventMsg(process.pid,Us.OPERATIONS_ENUM.DROP_TABLE,c,s))}get(p){if(typeof p=="string")return this.getProperty(p);if(this[ci])return this.search(p);if(this[ze]===null){if(p?.conditions)return this.search(p);let A=Ve.getRecordCount();return{recordCount:A.recordCount,estimatedRecordRange:A.estimatedRange,records:"./",name:s,database:c,auditSize:l?.getStats().entryCount,attributes:S}}if(p?.property)return this.getProperty(p.property);if(this.doesExist()||p?.ensureLoaded===!1||this[Fe]?.returnNonexistent)return this}allowRead(p,A){let w=Ka(p);if(w?.read){if(w.isSuperUser)return!0;let R=w.attribute_permissions,b=A?.select;if(R?.length>0||Pd&&b){if(A||(A={}),b){let D=R?.length>0&&Ow(R,"read");A.select=b.map(O=>{let B=O.name||O;if(!D||D[B]){let k=wn[B]?.definition?.tableClass;if(k){if(O.name||(O={name:O}),!k.prototype.allowRead.call(null,p,O))return!1;if(!O.select)return O.name}return O}}).filter(Boolean)}else A.select=R.filter(D=>D.read&&!wn[D.attribute_name]).map(D=>D.attribute_name);return A}else return!0}}allowUpdate(p,A){let w=Ka(p);if(w?.update){let R=w.attribute_permissions;if(R?.length>0){let b=Ow(R,"update");for(let D in A)if(!b[D])return!1;for(let D of R){let O=D.attribute_name;!D.update&&!(O in A)&&(A[O]=this.getProperty(O))}}return Ya(this[Fe])}}allowCreate(p,A){if(this[ci]){let w=Ka(p);if(w?.insert){let R=w.attribute_permissions;if(R?.length>0){let b=Ow(R,"insert");for(let D in A)if(!b[D])return!1;return Ya(this[Fe])}else return Ya(this[Fe])}}else return this.allowUpdate(p,{})}allowDelete(p){return Ka(p)?.delete&&Ya(this[Fe])}update(p,A){if(!Ir(this[Fe]))throw new Error("Can not update a table resource outside of a transaction");if(p===!1)return this;let R;return typeof p=="object"&&p&&(A?(Object.isFrozen(p)&&(p={...p}),this[ve]={},this[_r]=p):(R=this[_r],R&&(p=Object.assign(R,p)),this[_r]=R=p)),this._writeUpdate(this[_r],A),this}addTo(p,A){if(typeof A=="number"||typeof A=="bigint")this[xE]===bW?this.set(p,(+this.getProperty(p)||0)+A):(this[xE]||this.update(),this.set(p,new vT(A)));else throw new Error("Can not add a non-numeric value")}subtractFrom(p,A){if(typeof A=="number")return this.addTo(p,-A);throw new Error("Can not subtract a non-numeric value")}getMetadata(){return this[Fr]}invalidate(){this._writeInvalidate()}_writeInvalidate(p){let A=this[Fe],w=this[ze];ji(w),Ir(this[Fe]).addWrite({key:w,store:i,invalidated:!0,entry:this[Fr],before:Ne.invalidate?.bind(this,A,w),beforeIntermediate:Me.invalidate?.bind(this,A,w),commit:a((b,D)=>{if(di(b,D,p?.nodeId)<=0)return;let O=null;for(let B in r)O||(O={}),O[B]=this.getProperty(B);qe.default.trace?.(`Invalidating entry id: ${w}, timestamp: ${new Date(b).toISOString()}`),y(w,O,this[Fr],b,Ns,m,{user:A?.user,residencyId:p?.residencyId,nodeId:p?.nodeId},"invalidate")},"commit")})}_writeRelocate(p){let A=this[Fe],w=this[ze];ji(w),Ir(this[Fe]).addWrite({key:w,store:i,invalidated:!0,entry:this[Fr],before:Ne.relocate?.bind(this,A,w),beforeIntermediate:Me.relocate?.bind(this,A,w),commit:a((b,D)=>{if(di(b,D,p?.nodeId)<=0)return;let O=Ve.getResidencyRecord(p.residencyId),B=0,k=null,C=D?.value;if(O&&!O.includes(server.hostname)){for(let F in r)k||(k={}),k[F]=C(F);B=Ns}else k=C;qe.default.trace?.(`Relocating entry id: ${w}, timestamp: ${new Date(b).toISOString()}`),y(w,k,this[Fr],b,B,m,{user:A.user,residencyId:p.residencyId,nodeId:p.nodeId,expiresAt:p.expiresAt},"relocate",!1,null)},"commit")})}static _recordRelocate(p,A){let w={previousResidency:this.getResidencyRecord(p.residencyId),isRelocation:!0},R=this.getResidency(A.value,w),b;if(R){if(!Array.isArray(R))throw new Error("Residency must be an array, but was: "+R);if(!R.includes(server.hostname))return;b=tt(R)}let O=y(p.key,A.value,p,p.version,0,!0,{residencyId:b,expiresAt:A.expiresAt},"relocate",!1,null)}static evict(p,A,w){let R=this.Source,b;if(!((U||m)&&(!A||(b=i.getEntry(p),!b||!A)||b.version!==w))){if(U){if(i.hasLock(p,b.version))return;let D;for(let O in r)D||(D={}),D[O]=A[O];if(D)return y(p,D,b,w,ba,null,null,null,!0)}return i.ifVersion(p,w,()=>{$a(p,A,null)}),m?y(p,null,b,w,ba,null,null,null,!0):i.remove(p,w)}}lock(){throw new Error("Not yet implemented")}static operation(p,A){return p.table||=s,p.schema||=c,LW.operation(p,A)}put(p){this.update(p,!0)}patch(p){this.update(p,!1)}_writeUpdate(p,A,w){let R=this[Fe],b=Ir(R),D=this[ze];ji(D);let O=this[Fr];this[xE]=A?bW:ZSe;let B={key:D,store:i,entry:O,nodeName:R?.nodeName,validate:a(k=>{p||(p=this[_r]),A||p&&MT(this[_r]===p?this:p)?R?.source||(b.checkOverloaded(),this.validate(p,!A),V&&(p[V.name]=V.type==="Date"?new Date(k):V.type==="String"?new Date(k).toISOString():k),A&&(t&&p[t]!==D&&(p[t]=D),Y&&(O?.value?p[Y.name]=O?.value[Y.name]:p[Y.name]=Y.type==="Date"?new Date(k):Y.type==="String"?new Date(k).toISOString():k),p=Al(p))):b.removeWrite(B)},"validate"),before:A?Ne.put?()=>Ne.put(R,D,p):null:Ne.patch?()=>Ne.patch(R,D,p):Ne.put?()=>Ne.put(R,D,Al(this)):null,beforeIntermediate:A?Me.put?()=>Me.put(R,D,p):null:Me.patch?()=>Me.patch(R,D,p):Me.put?()=>Me.put(R,D,Al(this)):null,commit:a((k,C,F)=>{if(F){if(R&&C?.version>(R.lastModified||0)&&(R.lastModified=C.version),this[Fr]=C,C?.value?.[ve])throw new Error("Can not assign a record to a record, check for circular references");A||(this[ve]=C?.value??null)}this[_r]=void 0,this[kE]=k;let x=C?.value,q=p;this[xE]=0;let ee=di(k,C,w?.nodeId),G;if(ee<=0)if(m){let K=C.localTime,ge=C.version;qe.default.trace?.("Applying CRDT update to record with id: ",D,"applying later update:",ge);let Be=[];for(;K>k||ge>=k&&K>0;){let we=l.get(K);if(!we)break;let ce=xt(we);if(ge=ce.version,ge>=k){if(ge===k){if(ee=di(k,{version:ge,localTime:K},w?.nodeId),ee===0)return;if(ee>0)continue}if(ce.type==="patch")Be.push(ce),G=p;else if(ce.type==="put"||ce.type==="delete")return}K=ce.previousLocalTime}Be.sort((we,ce)=>we.version-ce.version);for(let we of Be){let ce=we.getValue(i);if(q=PT(q,ce,A),qe.default.debug?.("Rebuilding update with future patch:",q),!q)return}}else{if(A)return;q=PT(q,x,A),qe.default.debug?.("Rebuilding update without audit:",q)}let Re;if(A?Re=q:(this[ve]=x,Re=Al(this,q)),this[ve]=Re,Re?.[ve])throw new Error("Can not assign a record to a record, check for circular references");let Ee;if(w?.residencyId!=null)Ee=w.residencyId;else{O?.residencyId&&(R.previousResidency=Ve.getResidencyRecord(O.residencyId));let K=Ve.getResidency(Re,R);if(K){if(!Array.isArray(K))throw new Error("Residency must be an array, got: "+K);K.includes(server.hostname)||K.push(server.hostname)}Ee=tt(K)}A||(G=p);let Ae=R?.expiresAt??(h?h+Date.now():-1);qe.default.trace?.(`Saving record with id: ${D}, timestamp: ${new Date(k).toISOString()}${Ae?", expires at: "+new Date(Ae).toISOString():""}${C?", replaces entry from: "+new Date(C.version).toISOString():", new entry"}`,Re),$a(D,x,Re);let re=A?"put":"patch";y(D,Re,C,k,0,m,{user:R?.user,residencyId:Ee,expiresAt:Ae,nodeId:w?.nodeId,originatingOperation:R?.originatingOperation},re,!1,G),R.expiresAt&&xo()},"commit")};b.addWrite(B)}async delete(p){if(typeof p=="string")return this.deleteProperty(p);if(this[ci]){for await(let A of this.search(p))(await Ve.getResource(A[t],this.getContext(),{ensureLoaded:!1}))._writeDelete(p);return}return this[ve]?this._writeDelete(p):!1}_writeDelete(p){let A=Ir(this[Fe]),w=this[ze];ji(w);let R=this[Fe];return A.addWrite({key:w,store:i,resource:this,nodeName:R?.nodeName,before:Ne.delete?.bind(this,R,w),beforeIntermediate:Me.delete?.bind(this,R,w),commit:a((b,D,O)=>{let B=D?.value;O&&(R&&D?.version>(R.lastModified||0)&&(R.lastModified=D.version),qT(this,D)),!(di(b,D,p?.nodeId)<=0)&&($a(this[ze],B),qe.default.trace?.(`Deleting record with id: ${w}, txn timestamp: ${new Date(b).toISOString()}`),m||g?(y(w,null,this[Fr],b,0,m,{user:R?.user,nodeId:p?.nodeId},"delete"),m||xo()):i.remove(this[ze]))},"commit")}),!0}search(p){let A=this[Fe],w=Ir(A);if(!p)throw new Error("No query provided");let R=p.conditions;R?R.length===void 0&&(R=R[Symbol.iterator]?Array.from(R):[R]):R=Array.isArray(p)?p:p[Symbol.iterator]?Array.from(p):[],this[ze]&&(R=[{attribute:null,comparator:Array.isArray(this[ze])?"prefix":"starts_with",value:this[ze]}].concat(R));let b,D={};function O(K,ge){let Be;switch(ge){case"and":case void 0:if(K.length<1)throw new Error('An "and" operator requires at least one condition');Be=!0;break;case"or":if(K.length<2)throw new Error('An "or" operator requires at least two conditions');break;default:throw new Error("Invalid operator "+ge)}for(let we of K){if(we.conditions){we.conditions=O(we.conditions,we.operator);continue}let ce=we[0]??we.attribute,Ye=ce==null?H:Bi(S,ce);if(Ye)(Ye.type||CN[we.comparator])&&(we[1]===void 0?we.value=k(we.value,Ye):we[1]=k(we[1],Ye));else if(ce!=null)throw(0,Nr.handleHDBError)(new Error,`${ce} is not a defined attribute`,404);if(we.chainedConditions)if(we.chainedConditions.length===1&&(!we.operator||we.operator=="and")){let rt=we.chainedConditions[0],Ze,st;if(rt.comparator==="gt"||rt.comparator==="greater_than"||rt.comparator==="ge"||rt.comparator==="greater_than_equal"?(Ze=we,st=rt):(Ze=rt,st=we),Ze.comparator!=="lt"&&Ze.comparator!=="less_than"&&Ze.comparator!=="le"&&Ze.comparator!=="less_than_equal")throw new Error("Invalid chained condition, only less than and greater than conditions can be chained together");let Bt=st.comparator==="ge"||st.comparator==="greater_than_equal",ko=Ze.comparator==="le"||Ze.comparator==="less_than_equal";we.comparator=(Bt?"ge":"gt")+(ko?"le":"lt"),we.value=[st.value,Ze.value]}else throw new Error("Multiple chained conditions are not currently supported")}return K}a(O,"prepareConditions");function B(K,ge){if(p.enforceExecutionOrder)return K;for(let Be of K)Be.conditions&&(Be.conditions=B(Be.conditions,Be.operator));return K.length>1&&ge!=="or"?(0,DW.sortBy)(K,NS(Ve)):K}a(B,"orderConditions");function k(K,ge){return Array.isArray(K)?K.map(Be=>GT(Be,ge)):GT(K,ge)}a(k,"coerceTypedValues");let C=p.operator;(R.length>0||C)&&(R=O(R,C));let F=typeof p.sort=="object"&&p.sort,x;if(F&&C!=="or"){let K=F.attribute;if(K==null)throw new Nr.ClientError("Sort requires an attribute");if(b=R.find(ge=>sd(ge.attribute)===sd(K)),!b){let ge=Bi(S,K);if(!ge)throw(0,Nr.handleHDBError)(new Error,`${Array.isArray(K)?K.join("."):K} is not a defined attribute`,404);if(ge.indexed)b={attribute:K,comparator:"sort"},R.push(b);else if(R.length===0&&!p.allowFullScan)throw(0,Nr.handleHDBError)(new Error,`${Array.isArray(K)?K.join("."):K} is not indexed and not combined with any other conditions`,404)}b&&(b.descending=!!F.descending)}R=B(R,C),F&&(b&&R[0]===b?F.next&&(x={dbOrderedAttribute:F.attribute,attribute:F.next.attribute,descending:F.next.descending,next:F.next.next}):(b&&R.splice(R.indexOf(b),1),x=F));let q=p.select;if(R.length===0&&(R=[{attribute:t,comparator:"greater_than",value:!0}]),p.explain)return{conditions:R,operator:C,postOrdering:x,selectApplied:!!q};let ee=w.useReadTxn(),G=DN(R,C,Ve,ee,p,A,(K,ge)=>Md(K,q,A,ee,ge),D),Re=p.ensureLoaded!==!1;x||(G=re(G));let Ee=Ve.transformEntryForSelect(q,A,ee,D,Re,!0),Ae=Ve.transformToOrderedSelect(G,q,x,ee,A,Ee);function re(K){return p.offset||p.limit!==void 0?K.slice(p.offset,p.limit!==void 0?(p.offset||0)+p.limit:void 0):K}return a(re,"applyOffset"),x&&(Ae=re(Ae)),Ae.onDone=()=>{Ae.onDone=null,w.doneReadTxn()},Ae.selectApplied=!0,Ae.getColumns=()=>{if(q){let K=[];for(let ge of q)ge==="*"?K.push(...S.map(Be=>Be.name)):K.push(ge.name||ge);return K}return S.filter(K=>!K.computed&&!K.relationship).map(K=>K.name)},Ae}static transformToOrderedSelect(p,A,w,R,b,D){let O=new vs;if(w){p=Md(p,A,R,b,null);let B;O.iterate=function(){let C,F=p[Symbol.asyncIterator]?p[Symbol.asyncIterator]():p[Symbol.iterator](),x,q=w.dbOrderedAttribute,ee,G,Re=!0;function Ee(re){let K=re.next&&Ee(re.next),ge=re.descending;return(Be,we)=>{let ce=Il(Be,re.attribute,R),Ye=Il(we,re.attribute,R),rt=ge?(0,bl.compareKeys)(Ye,ce):(0,bl.compareKeys)(ce,Ye);return rt===0?K?.(Be,we)||0:rt}}a(Ee,"createComparator");let Ae=Ee(w);return{async next(){let re;if(C)if(re=C.next(),re.done){if(x)return O.onDone&&O.onDone(),re}else return{value:await D.call(this,re.value)};B=[],ee&&B.push(ee);do if(re=await F.next(),re.done){if(x=!0,B.length)break;return O.onDone&&O.onDone(),re}else{let K=re.value;if(K?.then&&(K=await K),q){let ge=Il(K,q,R);if(Re)Re=!1,G=ge;else if(ge!==G){G=ge,ee=K;break}}B.push(K)}while(!0);return w.isGrouped,B.sort(Ae),C=B[Symbol.iterator](),re=C.next(),re.done?(O.onDone&&O.onDone(),re):{value:await D.call(this,re.value)}},return(){O.onDone&&O.onDone(),F.return()},throw(){O.onDone&&O.onDone(),F.throw()}}};let k=a(C=>{if(typeof A=="object"&&Array.isArray(C.attribute))for(let F=0;F<A.length;F++){let x=A[F],q;if(x.name===C.attribute[0]){for(q=x.sort||(x.sort={});q.next;)q=q.next;q.attribute=C.attribute.slice(1),q.descending=C.descending}else x===C.attribute[0]&&(A[F]=q={name:x,sort:{attribute:C.attribute.slice(1),descending:C.descending}})}C.next&&k(C.next)},"applySortingOnSelect");k(w)}else O.iterate=(p[Symbol.asyncIterator]||p[Symbol.iterator]).bind(p),O=O.map(function(B){try{let k=D.call(this,B);return typeof k?.catch=="function"?k.catch(C=>{throw C.partialObject={[t]:B.key},C}):k}catch(k){throw k.partialObject={[t]:B.key},k}});return O}static transformEntryForSelect(p,A,w,R,b,D){if(p&&(p===t||p?.length===1&&p[0]===t&&Array.isArray(p))){let C=a(F=>(A?.transaction?.stale&&(A.transaction.stale=!1),F?.key??F),"transform");return p===t?C:p.asArray?F=>[C(F)]:F=>({[t]:C(F)})}let O;b&&U&&!(typeof p=="string"?[p]:p)?.every(C=>{let F;return typeof C=="object"?F=C.name:F=C,r[F]||F===t})&&(O=!0);let B,k=a(function(C){let F;if(A?.transaction?.stale&&(A.transaction.stale=!1),C!=null){if(F=C.value||C.deref?.()?.value,!F&&(C.key===void 0||C.deref)||C.metadataFlags&Ns){if(C.metadataFlags&Ns&&A.replicateFrom===!1&&D&&C.residencyId)return Ha.SKIP;if(C=Va(C.key??C,A,{transaction:w,lazy:p?.length<4,ensureLoaded:b},this?.isSync,x=>x),C?.then)return C.then(k.bind(this));F=C?.value}if(O&&C?.metadataFlags&(Ns|ba)||C?.expiresAt!=null&&C?.expiresAt<Date.now()){if(A.onlyIfCached&&A.noCacheStore)return{[t]:C.key,message:"This entry has expired"};let x=Ld(C.key??C,C,A);if(x?.then)return x.then(k)}}if(F==null)return D?Ha.SKIP:F;if(p&&!(p[0]==="*"&&p.length===1)){let x,q=a((G,Re)=>{let Ee;typeof G=="object"?Ee=G.name:Ee=G;let Ae=wn?.[Ee],re;if(Ae){let K=R?.[Ee];if(K)if(K.hasMappings){let Be=Ae.from?F[Ae.from]:sd(C.key);re=K.get(Be),re||(re=[])}else re=K.fromRecord?.(F);else re=Ae(F,A,C);let ge=a(Be=>{if(Be&&typeof Be=="object"){let we=Ae.definition?.tableClass||Ve;B||(B={});let ce=B[Ee]||(B[Ee]=we.transformEntryForSelect(Ee===G?null:G.select||(Array.isArray(G)?G:null),A,w,K,b));if(Array.isArray(Be)){let Ye=[],rt=we.transformToOrderedSelect(Be,G.select,typeof G.sort=="object"&&G.sort,A,w,ce)[this.isSync?Symbol.iterator:Symbol.asyncIterator](),Ze=a(Bt=>{for(;!Bt.done;){if(Bt?.then)return Bt.then(Ze);Ye.push(Bt.value),Bt=rt.next()}Re(Ye,Ee)},"nextValue"),st=Ze(rt.next());st&&(x||(x=[]),x.push(st));return}else if(Be=ce.call(this,Be),Be?.then){x||(x=[]),x.push(Be.then(Ye=>Re(Ye,Ee)));return}}Re(Be,Ee)},"handleResolvedValue");re?.then?(x||(x=[]),x.push(re.then(ge))):ge(re);return}else re=F[Ee],re&&typeof re=="object"&&Ee!==G&&(re=Ve.transformEntryForSelect(G.select||G,A,w,null)({value:re}));Re(re,Ee)},"selectAttribute"),ee;if(typeof p=="string")q(p,G=>{ee=G});else if(Array.isArray(p))if(p.asArray)ee=[],p.forEach((G,Re)=>{G==="*"?p[Re]=F:q(G,Ee=>ee[Re]=Ee)});else{ee={};let G=p.forceNulls;for(let Re of p)if(Re==="*")for(let Ee in F)ee[Ee]=F[Ee];else q(Re,(Ee,Ae)=>{Ee===void 0&&G&&(Ee=null),ee[Ae]=Ee})}else throw new Nr.ClientError("Invalid select"+p);return x?Promise.all(x).then(()=>ee):ee}return F},"transform");return k}async subscribe(p){if(!l)throw new Error("Can not subscribe to a table without an audit log");m||Et({table:s,database:c,schemaDefined:u,attributes:S,audit:!0}),p||(p={});let A=!p.rawEvents,w=[],R=this,b=py(Ve,this[ze]??null,function(O,B,k,C){try{let F=B.getValue?.(i,A),x=B.type;if(!F&&x==="patch"&&A){let ee=i.getEntry(O);ee?.version===B.version?F=ee.value:F=B.getValue?.(i,!0,k),x="put"}let q={id:O,localTime:k,value:F,version:B.version,type:x,beginTxn:C};w?w.push(q):this.send(q)}catch(F){qe.default.error?.(F)}},p.startTime||0,p),D=(async()=>{this[ci]&&(b.includeDescendants=!0,p.onlyChildren&&(b.onlyChildren=!0)),p.supportsTransactions&&(b.supportsTransactions=!0);let O=this[ze],B=p.previousCount;B>1e3&&(B=1e3);let k=p.startTime;if(this[ci]){if(k){if(B)throw new Nr.ClientError("startTime and previousCount can not be combined for a table level subscription");for(let{key:C,value:F}of l.getRange({start:k,exclusiveStart:!0,snapshot:!1})){let x=xt(F);if(x.tableId!==n)continue;let q=x.recordId;if(O==null||wW(O,q)){let ee=x.getValue(i,A,C);if(b.send({id:q,localTime:C,value:ee,version:x.version,type:x.type}),b.queue?.length>NW&&await b.waitForDrain()===!1)return}b.startTime=C}}else if(B){let C=[];for(let{key:F,value:x}of l.getRange({start:"z",end:!1,reverse:!0}))try{let q=xt(x);if(q.tableId!==n)continue;let ee=q.recordId;if(O==null||wW(O,ee)){let G=q.getValue(i,A,F);if(C.push({id:ee,localTime:F,value:G,version:q.version,type:q.type}),--B<=0)break}}catch(q){qe.default.error("Error getting history entry",F,q)}for(let F=C.length;F>0;)b.send(C[--F]);C[0]&&(b.startTime=C[0].localTime)}else if(!p.omitCurrent){for(let{key:C,value:F,version:x,localTime:q}of i.getRange({start:O??!1,end:O==null?void 0:[O,bl.MAXIMUM_KEY],versions:!0,snapshot:!1}))if(F&&(b.send({id:C,localTime:q,value:F,version:x,type:"put"}),b.queue?.length>NW&&await b.waitForDrain()===!1))return}}else{B&&!k&&(k=0);let C=this[Fr]?.localTime;if(C===Qg&&(i.cache?.delete(O),this[Fr]=i.getEntry(O),qe.default.trace?.("re-retrieved record",C,this[Fr]?.localTime),C=this[Fr]?.localTime),qe.default.trace?.("Subscription from",k,"from",O,C),k<C){let F=[],x=C;do{let q=l.get(x);if(q){p.omitCurrent=!0;let ee=xt(q),G=ee.getValue(i,A,x);A&&(ee.type="put"),F.push({id:O,value:G,localTime:x,...ee}),x=ee.previousLocalTime}else break;B&&B--}while(x>k&&B!==0);for(let q=F.length;q>0;)b.send(F[--q]);b.startTime=C}!p.omitCurrent&&this.doesExist()&&b.send({id:O,localTime:C,value:this[ve],version:this[kE],type:"put"})}for(let C of w)b.send(C);w=null})();return p.listener&&b.on("data",p.listener),b}static subscribeOnThisThread(p,A){return p===0||A?.crossThreads===!1}doesExist(){return!!(this[ve]||this[xE])}publish(p,A){this._writePublish(p,A)}_writePublish(p,A){let w=Ir(this[Fe]),R=this[ze]||null;R!=null&&ji(R);let b=this[Fe];w.addWrite({key:R,store:i,entry:this[Fr],nodeName:b?.nodeName,validate:a(()=>{b?.source||(w.checkOverloaded(),this.validate(p))},"validate"),before:Ne.publish?.bind(this,b,R,p),beforeIntermediate:Me.publish?.bind(this,b,R,p),commit:a((D,O,B)=>{O===void 0&&g&&!m&&xo(),qe.default.trace?.(`Publishing message to id: ${R}, timestamp: ${new Date(D).toISOString()}`),y(R,O?.value??null,O,O?.version||D,0,!0,{user:b?.user,residencyId:A?.residencyId,expiresAt:b?.expiresAt,nodeId:A?.nodeId},"message",!1,p)},"commit")})}validate(p,A){let w,R=a((b,D,O)=>{if(D.type&&b!=null)if(A&&b.__op__&&(b=b.value),D.properties){typeof b!="object"&&(w||(w=[])).push(`Value ${li(b)} in property ${O} must be an object${D.type?" ("+D.type+")":""}`);let B=D.properties;for(let k=0,C=B.length;k<C;k++){let F=B[k],x=R(b[F.name],F,O+"."+F.name);x&&(b[F.name]=x)}if(D.sealed&&b!=null&&typeof b=="object")for(let k in b)B.find(C=>C.name===k)||(w||(w=[])).push(`Property ${k} is not allowed within object in property ${O}`)}else switch(D.type){case"Int":(typeof b!="number"||b>>0!==b)&&(w||(w=[])).push(`Value ${li(b)} in property ${O} must be an integer (from -2147483648 to 2147483647)`);break;case"Long":(typeof b!="number"||!(Math.floor(b)===b&&Math.abs(b)<=9007199254740992))&&(w||(w=[])).push(`Value ${li(b)} in property ${O} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof b!="number"&&(w||(w=[])).push(`Value ${li(b)} in property ${O} must be a number`);break;case"ID":typeof b=="string"||b?.length>0&&b.every?.(B=>typeof B=="string")||(w||(w=[])).push(`Value ${li(b)} in property ${O} must be a string, or an array of strings`);break;case"String":typeof b!="string"&&(w||(w=[])).push(`Value ${li(b)} in property ${O} must be a string`);break;case"Boolean":typeof b!="boolean"&&(w||(w=[])).push(`Value ${li(b)} in property ${O} must be a boolean`);break;case"Date":if(!(b instanceof Date)){if(typeof b=="string"||typeof b=="number")return new Date(b);(w||(w=[])).push(`Value ${li(b)} in property ${O} must be a Date`)}break;case"BigInt":if(typeof b!="bigint"){if(typeof b=="string"||typeof b=="number")return BigInt(b);(w||(w=[])).push(`Value ${li(b)} in property ${O} must be a bigint`)}break;case"Bytes":b instanceof Uint8Array||(w||(w=[])).push(`Value ${li(b)} in property ${O} must be a Buffer or Uint8Array`);break;case"array":if(Array.isArray(b)){if(D.elements)for(let B=0,k=b.length;B<k;B++){let C=b[B],F=R(C,D.elements,O+"[*]");F&&(b[B]=F)}}else(w||(w=[])).push(`Value ${li(b)} in property ${O} must be a Buffer or Uint8Array`);break}D.nullable===!1&&b==null&&(w||(w=[])).push(`Property ${O} is required (and not does not allow null values)`)},"validateValue");for(let b=0,D=S.length;b<D;b++){let O=S[b];if(!(O.relationship||O.computed)&&(!A||O.name in p)){let B=R(p[O.name],O,O.name);B&&(p[O.name]=B)}}if(_)for(let b in p)S.find(D=>D.name===b)||(w||(w=[])).push(`Property ${b} is not allowed`);if(w)throw new Nr.ClientError(w.join(". "))}getUpdatedTime(){return this[kE]}wasLoadedFromSource(){return U?!!this[bw]:void 0}static async addAttributes(p){let A=S.slice(0);for(let w of p){if(!w.name)throw new Nr.ClientError("Attribute name is required");if(w.name.match(/[`/]/))throw new Nr.ClientError("Attribute names cannot include backticks or forward slashes");(0,PW.validateAttribute)(w.name),A.push(w)}return Et({table:s,database:c,schemaDefined:u,attributes:A}),Ve.indexingOperation}static async removeAttributes(p){let A=S.filter(w=>!p.includes(w.name));return Et({table:s,database:c,schemaDefined:u,attributes:A}),Ve.indexingOperation}static getSize(){let p=i.getStats();return(p.treeBranchPageCount+p.treeLeafPageCount+p.overflowPages)*p.pageSize}static getAuditSize(){let p=l?.getStats();return p&&(p.treeBranchPageCount+p.treeLeafPageCount+p.overflowPages)*p.pageSize}static getRecordCount(p){let A=i.getStats().entryCount,w=1e3/2,R=performance.now(),b=Math.floor(A/2),D=p?.exactCount,O=0,B=0,k;for(let{value:C}of i.getRange({start:!0,lazy:!0}))if(C!=null&&O++,B++,!D&&B<b&&performance.now()-R>w){k=B;break}if(k){let C=O;O=0;for(let{value:re}of i.getRange({start:"\uFFFF",reverse:!0,lazy:!0,limit:k}))re!=null&&O++;let F=k*2,x=(O+C)/F,q=Math.pow((O-C+1)/k/2,2)+x*(1-x)/F,ee=Math.max(Math.sqrt(q)*A,1),G=Math.round(x*A),Re=Math.max(G-1.96*ee,O+C),Ee=Math.min(G+1.96*ee,A),Ae=Math.pow(10,Math.round(Math.log10(ee)));return Ae>G&&(Ae=Ae/10),O=Math.round(G/Ae)*Ae,{recordCount:O,estimatedRange:[Math.round(Re),Math.round(Ee)]}}return{recordCount:O}}static updatedAttributes(){wn=this.propertyResolvers={$id:a((p,A,w)=>({value:w.key}),"$id"),$updatedtime:a((p,A,w)=>w.version,"$updatedtime"),$record:a((p,A,w)=>w?{value:p}:p,"$record")};for(let p of this.attributes){p.resolve=null;let A=p.relationship,w=p.computed;if(A)if(p.indexed&&console.error("A relationship property can not be directly indexed, (but you may want to index the foreign key attribute)"),w&&console.error("A relationship property is already computed and can not be combined with a computed function (the relationship will be given precedence)"),Pd=!0,A.to)p.elements?.definition?(wn[p.name]=p.resolve=(R,b,D)=>{let O=R[A.from?A.from:t],B=p.elements.definition.tableClass;return D?nd({attribute:A.to,value:O},Ir(b).getReadTxn(),!1,B,!1).asArray:B.search([{attribute:A.to,value:O}],b).asArray},p.set=()=>{throw new Error("Setting a one-to-many relationship property is not supported")},p.resolve.definition=p.elements.definition,A.from&&(p.resolve.from=A.from)):console.error(`The one-to-many/many-to-many relationship property "${p.name}" in table "${s}" must have an array type referencing a table as the elements`);else if(A.from){let R=p.definition||p.elements?.definition;R?(wn[p.name]=p.resolve=(b,D,O)=>{let B=b[A.from];if(B!==void 0){if(p.elements){let k,C=B?.map(F=>{let x=O?R.tableClass.primaryStore.getEntry(F,{transaction:Ir(D).getReadTxn()}):R.tableClass.get(F,D);return x?.then&&(k=!0),x});return A.filterMissing?k?Promise.all(C).then(F=>F.filter(CW)):C.filter(CW):k?Promise.all(C):C}return O?R.tableClass.primaryStore.getEntry(B,{transaction:Ir(D).getReadTxn()}):R.tableClass.get(B,D)}},p.set=(b,D)=>{if(Array.isArray(D)){let O=D.map(B=>B[ze]||B[R.tableClass.primaryKey]);b[A.from]=O}else{let O=D[ze]||D[R.tableClass.primaryKey];b[A.from]=O}},p.resolve.definition=p.definition||p.elements?.definition,p.resolve.from=A.from):console.error(`The relationship property "${p.name}" in table "${s}" must be a type that references a table`)}else console.error(`The relationship directive on "${p.name}" in table "${s}" must use either "from" or "to" arguments`);else w&&(typeof w.from=="function"&&this.setComputedAttribute(p.name,w.from),wn[p.name]=p.resolve=(R,b,D)=>{let O=typeof w.from=="string"?R[w.from]:R,B=this.userResolvers[p.name];if(B)return B(O,b,D);qe.default.warn(`Computed attribute "${p.name}" does not have a function assigned to it. Please use setComputedAttribute('${p.name}', resolver) to assign a resolver function.`),this.userResolvers[p.name]=()=>{}})}BT(this,this)}static setComputedAttribute(p,A){let w=Bi(S,p);if(!w){console.error(`The attribute "${p}" does not exist in the table "${s}"`);return}if(!w.computed){console.error(`The attribute "${p}" is not defined as computed in the table "${s}"`);return}this.userResolvers[p]=A}static async deleteHistory(p=0,A=!1){let w;for(let{key:R,value:b}of l.getRange({start:0,end:p}))await bd(),xt(b).tableId===n&&(w=wT(l,R,b));if(A)for(let{key:R,value:b,localTime:D}of i.getRange({start:0,versions:!0}))await bd(),b===null&&D<p&&(w=i.remove(R));await w}static async*getHistory(p=0,A=1/0){for(let{key:w,value:R}of l.getRange({start:p||1,end:A})){await bd();let b=xt(R);b.tableId===n&&(yield{id:b.recordId,localTime:w,version:b.version,type:b.type,value:b.getValue(i,!0,w),user:b.user,operation:b.originatingOperation})}}static async getHistoryOfRecord(p){let A=[];if(p==null)throw new Error("An id is required");let w=i.getEntry(p);if(!w)return A;let R=w.localTime;if(!R)throw new Error("The entry does not have a local audit time");let b=0;do{await bd();let D=l.get(R);if(D){let O=xt(D);A.push({id:O.recordId,localTime:R,version:O.version,type:O.type,value:O.getValue(i,!0,R),user:O.user}),R=O.previousLocalTime}else break}while(b<1e3&&R);return A.reverse()}static cleanup(){Q?.remove()}}Ve.updatedAttributes();let ss=Ve.prototype;return ss[XSe]=!0,h&&Ve.setTTLExpiration(h/1e3),ne&&Se(),Ve;function $a(v,p,A){let w;for(let R in r){let b=r[R],D=b.isIndexing,O=wn[R],B=A&&(O?O(A):A[R]),k=p&&(O?O(p):p[R]);if(B===k&&!D)continue;w=!0;let C=b.indexNulls,F=(0,FE.getIndexedValues)(B,C),x=(0,FE.getIndexedValues)(k,C);if(x?.length>0){let q=new Set(x);if(F=F?F.filter(ee=>{if(q.has(ee))q.delete(ee);else return!0}):[],x=Array.from(q),(x.length>0||F.length>0)&&yW){let ee=x.concat(F).map(G=>({key:G,value:v}));b.prefetch(ee,IW)}for(let ee=0,G=x.length;ee<G;ee++)b.remove(x[ee],v)}else F?.length>0&&yW&&b.prefetch(F.map(q=>({key:q,value:v})),IW);if(F)for(let q=0,ee=F.length;q<ee;q++)b.put(F[q],v)}return w}a($a,"updateIndices");function ji(v){switch(typeof v){case"number":return!0;case"string":if(v.length<659)return!0;if(v.length>OW)throw new Error("Primary key size is too large: "+v.length);break;case"object":if(v===null)throw new Error("Invalid primary key of null");break;case"bigint":if(v<2n**64n&&v>-(2n**64n))return!0;break;default:throw new Error("Invalid primary key type: "+typeof v)}if((0,bl.writeKey)(v,eTe,0)>OW)throw new Error("Primary key size is too large: "+v.length);return!0}a(ji,"checkValidId");function Va(v,p,A,w,R){if(Ve.getResidencyById&&A.ensureLoaded&&p?.replicateFrom!==!1){let D=Ve.getResidencyById(v);if(D&&!D.includes(server.hostname)&&I)return I({key:v,residency:D}).then(R)}let b=a(()=>{if(p?.transaction?.stale&&(p.transaction.stale=!1),A.transaction?.isDone)return R(null,v);let D=i.getEntry(v,A);return D?.residencyId&&D.metadataFlags&Ns&&I&&A.ensureLoaded&&p?.replicateFrom!==!1?I(D).then(O=>R(O,v)):(D&&p&&(D?.version>(p.lastModified||0)&&(p.lastModified=D.version),D?.localTime&&!p.lastRefreshed&&(p.lastRefreshed=D.localTime)),R(D,v))},"whenPrefetched");return w?b():ae>0?(ae--,b()):new Promise((D,O)=>{ae===0?(ae--,i.prefetch([v],()=>{B(),k()})):(de.push(v),j.push(k),de.length>zE&&(ae--,B()));function B(){if(de.length>0){let C=j;i.prefetch(de,()=>{ae===-1?B():ae++;for(let F of C)F()}),de=[],j=[],Oe>2&&Oe--}else ae=Oe,Oe<Bs&&Oe++}a(B,"prefetch");function k(){try{D(b())}catch(C){O(C)}}a(k,"load")})}a(Va,"loadLocalRecord");function Ka(v){if(!v?.role)return;let p=v.role.permission;if(p.super_user)return tTe;let A=p[c],w,R=A?.tables;if(R)return R[s];if(c==="data"&&(w=p[s])&&!w.tables)return w}a(Ka,"getTablePermissions");function Ld(v,p,A,w){if(U){let R=!1;if(A.noCache?R=!0:(p?(!p.value||p.metadataFlags&(Ns|ba)||p.expiresAt!=null&&p.expiresAt<Date.now())&&(R=!0):R=!0,qn(!R,"cache-hit",s)),R){let b=Ud(v,p,A).then(D=>(D?.value?.[ve]&&qe.default.error?.("Can not assign a record with a record property"),A&&(D?.version>(A.lastModified||0)&&(A.lastModified=D.version),A.lastRefreshed=Date.now()),D));if(A?.onlyIfCached||p?.value&&w?.allowStaleWhileRevalidate?.(p,v)){if(b.catch(D=>qe.default.warn?.(D)),A?.onlyIfCached&&!w.doesExist())throw new Nr.ServerError("Entry is not cached",504);return}else return b}}else if(p?.value&&p.expiresAt!=null&&p.expiresAt<Date.now())return Ve.evict(p.key,p.value,p.version),p.value=null,{then(R){return R(p)}}}a(Ld,"ensureLoadedFromSource");function Ir(v){let p=v?.transaction;if(p){if(!p.lmdbDb)return p.lmdbDb=i,p;do{if(p.lmdbDb?.path===i.path)return p;let A=p.next;if(!A)return p=p.next=new mc,p.lmdbDb=i,p;p=A}while(!0)}else return new cp}a(Ir,"txnForContext");function Il(v,p,A){if(!v)return;let w=v.value||i.getEntry(v.key)?.value;if(typeof p=="object"){let b=wn,D=w;for(let O=0,B=p.length;O<B;O++){let k=p[O],C=b?.[k];D=C&&D?C(D,A,!0)?.value:D?.[k],b=C?.definition?.tableClass?.propertyResolvers}return D}let R=wn[p];return R?R(w,A):w[p]}a(Il,"getAttributeValue");function Md(v,p,A,w,R){let b=R?.length,D={transaction:w,lazy:b>0||typeof p=="string"||p?.length<4,alwaysPrefetch:!0},O;function B(k,C){let F=k?.value;if(!F)return Ha.SKIP;for(let x=0;x<b;x++)if(!O?.includes(x)&&!R[x](F,k))return Ha.SKIP;return C!==void 0&&(k.key=C),k}if(a(B,"processEntry"),b>0||!v.hasEntries){let k=v.map(C=>{if(O=null,typeof C=="object"&&C?.key!==void 0)return b>0?B(C):C;if(C==null)return Ha.SKIP;for(let F=0;F<b;F++){let q=R[F].idFilter;if(q){if(!q(C))return Ha.SKIP;O||(O=[]),O.push(F)}}return Va(C,A,D,!1,B)});return Array.isArray(v)&&(k=k.filter(C=>C!==Ha.SKIP)),k.hasEntries=!0,k}return v}a(Md,"transformToEntries");function di(v,p,A=server.replication?.getThisNodeId(l)){if(v<=p?.version){if(p?.version===v&&A!==void 0){let w=server.replication?.exportIdMapping(l),R=p.localTime,b=R&&l.get(R);if(b){let D,O,B=xt(b);for(let k in w)w[k]===A&&(D=k),w[k]===B.nodeId&&(O=k);if(D>O)return 1;if(D===O)return 0}}return-1}return 1}a(di,"precedesExistingVersion");async function Ud(v,p,A){let w=p?.metadataFlags,R=p?.version,b,D;if(!i.attemptLock(v,R,()=>{clearTimeout(D);let C=i.getEntry(v);!C||!C.value||C.metadataFlags&(Ns|ba)?b(Ud(v,i.getEntry(v),A)):b(C)}))return new Promise(C=>{b=C,D=setTimeout(()=>{i.unlock(v,R)},JSe)});let O=p?.value,B={requestContext:A,replacingRecord:O,replacingEntry:p,replacingVersion:R,noCacheStore:!1,source:null,resourceCache:A?.resourceCache},k=A?.responseHeaders;return new Promise((C,F)=>{let x;Nw(Dt(B,async q=>{let ee=performance.now(),G,Re,Ee;try{for(let ge of Ve.sources)if(ge.get&&(!ge.get.reliesOnPrototype||ge.prototype.get)){if(ge.available?.(p)===!1)continue;if(B.source=ge,G=await ge.get(v,B),G)break}Ee=w&Ns;let re=B.lastModified||Ee&&R;Re=Ee||re>R||!O,re||(re=(0,FE.getNextMonotonicTime)());let K=performance.now()-ee;if(pr(K,"cache-resolution",s,null,"success"),k&&Bm(k,"Server-Timing",`cache-resolve;dur=${K.toFixed(2)}`,!0),q.timestamp=re,h&&B.expiresAt==null&&(B.expiresAt=Date.now()+h),G){if(typeof G!="object")throw new Error("Only objects can be cached and stored in tables");if(G.status>0&&G.headers)if(G.status>=300)if(G.status===304)G=O,re=R;else throw new Nr.ServerError(G.body||"Error from source",G.status);else G=G.body;typeof G.toJSON=="function"&&(G=G.toJSON()),t&&G[t]!==v&&(G[t]=v)}x=!0,C({key:v,version:re,value:G})}catch(re){re.message+=` while resolving record ${v} for ${s}`,O&&((re.code==="ECONNRESET"||re.code==="ECONNREFUSED"||re.code==="EAI_AGAIN")&&!A?.mustRevalidate||A?.staleIfError&&(re.statusCode===500||re.statusCode===502||re.statusCode===503||re.statusCode===504))?(C({key:v,version:R,value:O}),qe.default.trace?.(re.message,"(returned stale record)")):F(re);let K=performance.now()-ee;pr(K,"cache-resolution",s,null,"fail"),k&&Bm(k,"Server-Timing",`cache-resolve;dur=${K.toFixed(2)}`,!0),B.transaction.abort();return}if(A?.noCacheStore||B.noCacheStore){B.transaction.abort();return}Ir(B).addWrite({key:v,store:i,entry:p,nodeName:"source",commit:a((re,K)=>{if(K?.version!==R)return;let ge=$a(v,O,G);G?(Me.put?.(B,v,G),qe.default.trace?.(`Writing resolved record from source with id: ${v}, timestamp: ${new Date(re).toISOString()}`),y(v,G,K,re,0,m&&Re||null,{user:B?.user,expiresAt:B.expiresAt},"put",!!Ee)):K&&(Me.delete?.(B,v),qe.default.trace?.(`Deleting resolved record from source with id: ${v}, timestamp: ${new Date(re).toISOString()}`),m||g?y(v,null,K,re,0,m&&Re||null,{user:B?.user},"delete",!!Ee):i.remove(v,R))},"commit")})}),()=>{i.unlock(v,R)},q=>{i.unlock(v,R),x&&qe.default.error?.("Error committing cache update",q)})})}a(Ud,"getFromSource");function Ya(v){if(!v||v.user?.role?.permission?.super_user)return!0;if(v.replicateTo)throw new Nr.ClientError("Can not specify replication parameters without super user permissions",403);if(v.replicatedConfirmation)throw new Nr.ClientError("Can not specify replication confirmation without super user permissions",403);return!0}a(Ya,"checkContextPermissions");function xo(){if(Gr!==Dd&&(Dd=Gr,(0,yl.getWorkerIndex)()===(0,yl.getWorkerCount)()-1)){if(Fa&&clearTimeout(Fa),!Gr)return;let v=new Date;v.setMonth(0),v.setDate(1),v.setHours(0),v.setMinutes(0),v.setSeconds(0);let p=Math.ceil((Date.now()-v.getTime())/Gr)*Gr+v.getTime(),A=a(w=>{qe.default.trace?.(`Scheduled next cleanup scan at ${new Date(w)}ms`),Fa=setTimeout(()=>X=X.then(async()=>{if(A(Math.max(w+Gr,Date.now())),i.rootStore.status!=="open"){clearTimeout(Fa);return}let R=50,b=new Array(R),D=0;qe.default.info?.(`Starting cleanup scan for ${s}`);try{let O=0;for(let{key:B,value:k,version:C,expiresAt:F}of i.getRange({start:!1,snapshot:!1,versions:!0,lazy:!0})){let x;k===null&&!m&&C+QSe<Date.now()?x=i.remove(B,C):F!=null&&F+T<Date.now()&&(x=Ve.evict(B,k,C),O++),x&&(await b[D],b[D]=x.catch(q=>{qe.default.error?.("Cleanup error",q)}),++D>=R&&(D=0)),await bd()}qe.default.info?.(`Finished cleanup scan for ${s}, evicted ${O} entries`)}catch(O){qe.default.warn?.(`Error in cleanup scan for ${s}:`,O)}}),Math.min(w-Date.now(),2147483647)).unref()},"startNextTimer");A(p)}}a(xo,"scheduleCleanup");function ie(){Q=l?.addDeleteRemovalCallback(n,v=>{let p=i.getEntry(v);p?.value===null&&i.remove(v,p.version)})}a(ie,"addDeleteRemoval");function Se(){(0,yl.getWorkerIndex)()===0&&setInterval(async()=>{if(!Nl){Nl=!0;try{let v=ne.name,p=r[v];if(!p)throw new Error(`expiresAt attribute ${ne} must be indexed`);for(let A of p.getRange({start:!0,values:!1,end:Date.now(),snapshot:!1})){for(let w of p.getValues(A)){let R=i.getEntry(w);R?.value?R.value[v]<Date.now()&&Ve.evict(w,R.value,R.version):i.ifVersion(w,R?.version,()=>p.remove(A,w))}await bd()}}catch(v){qe.default.error?.("Error in evicting old records",v)}finally{Nl=!1}}},zSe).unref()}a(Se,"runRecordExpirationEviction");function tt(v){if(v){let p=v.join(","),A=d.get([Symbol.for("residency_by_set"),p]);return A||(d.put([Symbol.for("residency_by_set"),p],A=Math.floor(Math.random()*2147483647)),d.put([Symbol.for("residency_by_id"),A],v),A)}}a(tt,"getResidencyId")}function Ow(e,t){let r=e.attr_object||(e.attr_object={}),n=r[t];if(n)return n;n=r[t]=Object.create(null);for(let s of e)n[s.attribute_name]=s[t];return n}function IW(){}function rTe(e){LW=e}function GT(e,t){let r=t?.type;if(e===null)return e;if(e===""&&r&&r!=="String"&&r!=="Any")return null;try{switch(r){case"Int":case"Long":if(e[0]==="$")return FT(parseInt(e.slice(1),36));if(e==="null")return null;if(!/^-?[0-9]+$/.test(e)&&!(e instanceof Date))throw new SyntaxError;return FT(+e);case"Float":return e==="null"?null:FT(+e);case"BigInt":return e==="null"?null:BigInt(e);case"Boolean":return e==="true"?!0:e==="false"?!1:e;case"Date":if(isNaN(e)){if(e==="null")return null;nTe.test(e)||(e+="Z");let n=new Date(e);return FT(n.getTime()),n}return new Date(+e);case void 0:case"Any":return(0,$T.autoCast)(e);default:return e}}catch(n){throw n.message=`Invalid value for attribute ${t.name}: "${e}", expecting ${r}`,n.statusCode=400,n}}function FT(e){if(isNaN(e))throw new SyntaxError;return e}function wW(e,t){if(e==null)return!0;if(!Array.isArray(t))return e===t||t.startsWith?.(e);if(Array.isArray(e)){let r=e.length;if(e[r-1]===null&&r--,t.length>=r){for(let n=0;n<r;n++)if(t[n]!==e[n])return!1;return!0}return!1}else if(t[0]===e)return!0}function Nw(e,t,r){return e?.then?e.then(t,r):t(e)}function qT(e,t){e[Fr]=t,e[ve]=t?.value??null,e[kE]=t?.version}function CW(e){return e!=null}function li(e){try{return JSON.stringify(e)}catch{return e}}function sTe(e){let t=process.pid;return e.env.readerList().slice(1).some(r=>+r.match(/\d+/)?.[0]!=t)}var Us,Ha,FE,DW,PW,Od,Nr,GE,qE,qe,bl,yl,$T,jSe,LW,zSe,QSe,yW,JSe,kE,XSe,Fr,xE,bW,ZSe,bw,Ns,ba,eTe,OW,NW,tTe,zMe,nTe,bd,$f=Ie(()=>{Us=L(M()),Ha=require("lmdb"),FE=L(cn()),DW=require("lodash"),PW=L(Zd());Vs();lp();Od=L(se());my();Nr=L(_e()),GE=L(no()),qE=L(qs());Pe();_E();qe=L(Oc());_p();Sc();bl=require("ordered-binary"),yl=L(dt());Ji();$T=L(te());vl();Ni();CT();Bf();jSe=new Uint8Array(9);jSe[8]=192;zSe=6e4,QSe=864e5;Od.initSync();yW=Od.get(Us.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),JSe=1e4,kE=Symbol.for("version"),XSe=Symbol.for("incremental-update"),Fr=Symbol("entry"),xE=Symbol("is-saving"),bW=1,ZSe=2,bw=Symbol("loaded-from-source"),Ns=1,ba=8,eTe=Buffer.allocUnsafeSlow(8192),OW=1978,NW=100,tTe={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},zMe=(0,$T.convertToMS)(Od.get(Us.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;a(VT,"makeTable");a(Ow,"attributesAsObject");a(IW,"noop");a(rTe,"setServerUtilities");nTe=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;a(GT,"coerceType");a(FT,"rejectNaN");a(wW,"isDescendantId");bd=a(()=>new Promise(setImmediate),"rest");a(Nw,"when");a(qT,"updateResource");a(CW,"exists");a(li,"stringify");a(sTe,"hasOtherProcesses")});var lt={};je(lt,{database:()=>Ql,databases:()=>We,dropDatabase:()=>xR,dropTableMeta:()=>lTe,getDatabases:()=>ut,getDefaultCompression:()=>Lm,getTables:()=>iTe,onRemovedDB:()=>of,onUpdatedTable:()=>Lc,readMetaDb:()=>$E,resetDatabases:()=>ku,table:()=>Et,tables:()=>jn});function iTe(){return jT||ut(),jn||{}}function ut(){if(jT)return We;jT=!0,wd=new Map;let e=(0,er.getHdbBasePath)()&&(0,Ut.join)((0,er.getHdbBasePath)(),yr.DATABASES_DIR_NAME),t=(0,er.get)(yr.CONFIG_PARAMS.DATABASES)||{};if(process.env.SCHEMAS_DATA_PATH&&(t.data={path:process.env.SCHEMAS_DATA_PATH}),e=process.env.STORAGE_PATH||(0,er.get)(yr.CONFIG_PARAMS.STORAGE_PATH)||e&&((0,rs.existsSync)(e)?e:(0,Ut.join)((0,er.getHdbBasePath)(),yr.LEGACY_DATABASES_DIR_NAME)),!e)return;if((0,rs.existsSync)(e))for(let n of(0,rs.readdirSync)(e,{withFileTypes:!0})){let s=(0,Ut.basename)(n.name,".mdb");n.isFile()&&(0,Ut.extname)(n.name).toLowerCase()===".mdb"&&!t[s]?.path&&$E((0,Ut.join)(e,n.name),null,s)}if((0,rs.existsSync)((0,Id.getBaseSchemaPath)())){for(let n of(0,rs.readdirSync)((0,Id.getBaseSchemaPath)(),{withFileTypes:!0}))if(!n.isFile()){let s=(0,Ut.join)((0,Id.getBaseSchemaPath)(),n.name),i=(0,Ut.join)((0,Id.getTransactionAuditStoreBasePath)(),n.name);for(let o of(0,rs.readdirSync)(s,{withFileTypes:!0}))if(o.isFile()&&(0,Ut.extname)(o.name).toLowerCase()===".mdb"){let c=(0,Ut.join)(i,o.name);$E((0,Ut.join)(s,o.name),(0,Ut.basename)(o.name,".mdb"),n.name,c,!0)}}}if(t)for(let n in t){let s=t[n],i=s.path;if((0,rs.existsSync)(i))for(let c of(0,rs.readdirSync)(i,{withFileTypes:!0}))c.isFile()&&(0,Ut.extname)(c.name).toLowerCase()===".mdb"&&$E((0,Ut.join)(i,c.name),(0,Ut.basename)(c.name,".mdb"),n);let o=s.tables;if(o)for(let c in o){let l=o[c],u=(0,Ut.join)(l.path,(0,Ut.basename)(c+".mdb"));(0,rs.existsSync)(u)&&$E(u,c,n,null,!0)}}for(let n in We){let s=wd.get(n);if(s){let i=We[n];n.includes("delete")&&Vt.trace(`defined tables ${Array.from(s.keys())}`);for(let o in i)s.has(o)||(Vt.trace(`delete table class ${o}`),delete i[o])}else if(delete We[n],n==="data"){for(let i in jn)delete jn[i];delete jn[zT]}}let r=["hdb_temp","hdb_certificate","hdb_analytics","hdb_raw_analytics","hdb_session_will","hdb_job","hdb_license","hdb_info"];if(We.system)for(let n of r)We.system[n]&&(We.system[n].replicate=!1);return wd=null,We}function ku(){jT=!1;for(let[,e]of xa)e.needsDeletion=!0;ut();for(let[e,t]of xa)t.needsDeletion&&!e.endsWith("system.mdb")&&(t.close(),xa.delete(e),delete We[t.databaseName],KE.forEach(r=>r(t.databaseName)));return We}function $E(e,t,r=Cw,n,s){let i=new Iw.default(e,!1);try{let o=xa.get(e);o?o.needsDeletion=!1:(o=(0,Cd.open)(i),xa.set(e,o));let c=new Ol.default(!1),l=o.dbisDb||(o.dbisDb=o.openDB(KT.INTERNAL_DBIS_NAME,c)),u=o.auditStore;u||(n?(0,rs.existsSync)(n)&&(i.path=n,u=(0,Cd.open)(i),u.isLegacy=!0):u=IT(o));let d=BW(r),_=d[zT],E=new Map;for(let{key:f,value:h}of l.getRange({start:!1})){let[T,m]=f.toString().split("/");m===""?m=h.name:m||(m=T,T=t,h.name||(h.name=m,h.indexed=!h.is_hash_attribute)),_?.add(T);let g=E.get(T);g||E.set(T,g={attributes:[]}),(m==null||h.is_hash_attribute)&&(g.primary=h),m!=null&&g.attributes.push(h),Object.defineProperty(h,"key",{value:f,configurable:!0})}for(let[f,h]of E){let{attributes:T,primary:m}=h;if(!m){for(let j of T)if(j.is_hash_attribute||j.isPrimaryKey){m=j;break}if(!m){Vt.warn(`Unable to find a primary key attribute on table ${f}, with attributes: ${JSON.stringify(T)}`);continue}}let g=d[f],S={},y=[],I,U,H=typeof m.audit=="boolean"?m.audit:(0,er.get)(yr.CONFIG_PARAMS.LOGGING_AUDITLOG),X=m.trackDeletes,Y=m.expiration,V=m.eviction,ne=m.sealed,Q=m.splitSegments,de=m.replicate;if(g)S=g.indices,y=g.attributes,g.schemaVersion++;else{I=m.tableId,I?I>=(l.get(Nd)||0)&&(l.putSync(Nd,I+1),Vt.info(`Updating next table id (it was out of sync) to ${I+1} for ${f}`)):(m.tableId=I=l.get(Nd),I||(I=1),Vt.debug("Table {table_name} missing an id, assigning {table_id}"),l.putSync(Nd,I+1),l.putSync(m.key,m));let j=new Ol.default(!m.is_hash_attribute,m.is_hash_attribute);if(j.compression=m.compression,j.compression){let ae=(0,er.get)(yr.CONFIG_PARAMS.STORAGE_COMPRESSION_THRESHOLD)||vW;j.compression.threshold=ae}U=Nh(o.openDB(m.key,j)),o.databaseName=r,U.rootStore=o,U.tableId=I}for(let j of T){j.attribute=j.name;try{if(!j.is_hash_attribute&&(j.indexed||j.attribute&&!j.name)){if(!S[j.name]){let Oe=new Ol.default(!j.is_hash_attribute,j.is_hash_attribute);S[j.name]=o.openDB(j.key,Oe),S[j.name].indexNulls=j.indexNulls}let ae=y.find(Oe=>Oe.name===j.name);ae?y.splice(y.indexOf(ae),1,j):y.push(j)}}catch(ae){Vt.error("Error trying to update attribute",j,y,S,ae)}}if(!g){g=HW(d,f,VT({primaryStore:U,auditStore:u,audit:H,sealed:ne,splitSegments:Q,replicate:de,expirationMS:Y&&Y*1e3,evictionMS:V&&V*1e3,trackDeletes:X,tableName:f,tableId:I,primaryKey:m.name,databasePath:s?r+"/"+f:r,databaseName:r,indices:S,attributes:T,schemaDefined:m.schemaDefined,dbisDB:l})),g.schemaVersion=1;for(let j of VE)j(g)}}return o}catch(o){throw o.message+=` opening database ${e}`,o}}function BW(e){let t=We[e];if(t||(e==="data"?t=We[e]=jn:e==="system"?Object.defineProperty(We,"system",{value:t=Object.create(null),configurable:!0}):t=We[e]=Object.create(null)),wd&&!wd.has(e)){let r=new Set;t[zT]=r,wd.set(e,r)}return t}function HW(e,t,r){return e[t]=r,r}function Ql({database:e,table:t}){e||(e=Cw),ut();let r=BW(e),n=(0,Ut.join)((0,er.getHdbBasePath)(),yr.DATABASES_DIR_NAME),s=(0,er.get)(yr.CONFIG_PARAMS.DATABASES)||{};process.env.SCHEMAS_DATA_PATH&&(s.data={path:process.env.SCHEMAS_DATA_PATH});let i=t&&s[e]?.tables?.[t]?.path;n=i||s[e]?.path||process.env.STORAGE_PATH||(0,er.get)(yr.CONFIG_PARAMS.STORAGE_PATH)||((0,rs.existsSync)(n)?n:(0,Ut.join)((0,er.getHdbBasePath)(),yr.LEGACY_DATABASES_DIR_NAME));let o=(0,Ut.join)(n,(i?t:e)+".mdb"),c=xa.get(o);if(!c||c.status==="closed"){let l=new Iw.default(o,!1);c=(0,Cd.open)(l),xa.set(o,c)}return c.auditStore||(c.auditStore=IT(c)),c}async function xR(e){if(!We[e])throw new Error("Schema does not exist");let t=We[e],r;for(let n in t)r=t[n].primaryStore.rootStore,xa.delete(r.path),r.status==="open"&&(await r.close(),await YE.remove(r.path));if(r||(r=Ql({database:e,table:null}),r.status==="open"&&(await r.close(),await YE.remove(r.path))),e==="data"){for(let n in jn)delete jn[n];delete jn[zT]}delete We[e],KE.forEach(n=>n(e))}function Et(e){let{table:t,database:r,expiration:n,eviction:s,scanInterval:i,attributes:o,audit:c,sealed:l,splitSegments:u,replicate:d,trackDeletes:_,schemaDefined:E,origin:f}=e;r||(r=Cw);let h=Ql({database:r,table:t}),T=We[r];Vt.trace(`Defining ${t} in ${r}`);let m=T?.[t];if(h.status==="closed")throw new Error(`Can not use a closed data store for ${t}`);let g,S,y;E==null&&(E=!0);let I=new Ol.default(!1);for(let Q of o)Q.attribute&&!Q.name?(Q.name=Q.attribute,Q.indexed=!0):Q.attribute=Q.name,Q.expiresAt&&(Q.indexed=!0);let U,H;if(m){if(g=m.primaryKey,m.primaryStore.rootStore.status==="closed")throw new Error(`Can not use a closed data store from ${t} class`);u==null&&(u=m.splitSegments),m.attributes.splice(0,m.attributes.length,...o)}else{let Q=h.auditStore;S=o.find(Oe=>Oe.isPrimaryKey)||{},g=S.name,S.is_hash_attribute=S.isPrimaryKey=!0,S.schemaDefined=E,S.compression=Lm(),_&&(S.trackDeletes=!0),c=S.audit=typeof c=="boolean"?c:(0,er.get)(yr.CONFIG_PARAMS.LOGGING_AUDITLOG),n&&(S.expiration=n),s&&(S.eviction=s),S.splitSegments=!1,typeof l=="boolean"&&(S.sealed=l),typeof d=="boolean"&&(S.replicate=d),f&&(S.origins?S.origins.includes(f)||S.origins.push(f):S.origins=[f]),Vt.trace(`${t} table loading, opening primary store`);let de=new Ol.default(!1,!0);de.compression=S.compression;let j=t+"/";if(y=h.dbisDb=h.openDB(KT.INTERNAL_DBIS_NAME,I),ne(),y.get(j))return H&&H(),ku(),Et(e);let ae=Nh(h.openDB(j,de));h.databaseName=r,ae.rootStore=h,ae.tableId=y.get(Nd),Vt.trace(`Assigning new table id ${ae.tableId} for ${t}`),ae.tableId||(ae.tableId=1),y.put(Nd,ae.tableId+1),S.tableId=ae.tableId,m=HW(T,t,VT({primaryStore:ae,auditStore:Q,audit:c,sealed:l,splitSegments:u,replicate:d,trackDeletes:_,expirationMS:n&&n*1e3,evictionMS:s&&s*1e3,primaryKey:g,tableName:t,tableId:ae.tableId,databasePath:r,databaseName:r,indices:{},attributes:o,schemaDefined:E,dbisDB:y})),m.schemaVersion=1,U=!0,y.put(j,S)}let X=m.indices;y=y||(h.dbisDb=h.openDB(KT.INTERNAL_DBIS_NAME,I)),m.dbisDB=y;let Y=[];for(let{key:Q,value:de}of y.getRange({start:!0})){let[j,ae]=Q.toString().split("/");if(ae===""&&(ae=de.name),ae){if(j!==t)continue}else continue;let Oe=o.find(Me=>Me.name===ae),Ne=!Oe?.indexed&&de.indexed&&!de.isPrimaryKey;if((!Oe||Ne)&&(ne(),U=!0,Oe||y.remove(Q),Ne)){let Me=m.indices[j];Me&&Y.push(Me)}}let V=[];try{for(let Q of o||[]){if((Q.relationship||Q.computed)&&(U=!0,Q.relationship))continue;let de=t+"/"+(Q.name||"");Object.defineProperty(Q,"key",{value:de,configurable:!0});let j=y.get(de);if(Q.isPrimaryKey){if(j=j||y.get(de=t+"/")||{},c!==void 0&&c!==m.audit||l!==void 0&&l!==m.sealed||d!==void 0&&d!==m.replicate||(+n||void 0)!==(+j.expiration||void 0)||(+s||void 0)!==(+j.eviction||void 0)){let Oe={...j};typeof c=="boolean"&&(c&&m.enableAuditing(c),Oe.audit=c),n&&(Oe.expiration=+n),s&&(Oe.eviction=+s),l!==void 0&&(Oe.sealed=l),d!==void 0&&(Oe.replicate=d),U=!0,ne(),y.put(de,Oe)}continue}j?.attribute&&!j.name&&(j.indexed=!0);let ae=!j||j.type!==Q.type||j.indexed!==Q.indexed||j.nullable!==Q.nullable||j.version!==Q.version||JSON.stringify(j.properties)!==JSON.stringify(Q.properties)||JSON.stringify(j.elements)!==JSON.stringify(Q.elements);if(Q.indexed){let Oe=new Ol.default(!0,!1),Ne=h.openDB(de,Oe);(ae||j.indexingPID&&j.indexingPID!==process.pid||j.restartNumber<WE.workerData?.restartNumber)&&(U=!0,ne(),j=y.get(de),(ae||j.indexingPID&&j.indexingPID!==process.pid||j.restartNumber<WE.workerData?.restartNumber)&&(U=!0,Q.indexNulls===void 0&&(Q.indexNulls=!0),m.primaryStore.getStats().entryCount>0&&(Q.lastIndexedKey=j?.lastIndexedKey??void 0,Q.indexingPID=process.pid,Ne.isIndexing=!0,Object.defineProperty(Q,"dbi",{value:Ne}),V.push(Q))),y.put(de,Q)),j?.indexNulls&&Q.indexNulls===void 0&&(Q.indexNulls=!0),Ne.indexNulls=Q.indexNulls,X[Q.name]=Ne}else ae&&(U=!0,ne(),y.put(de,Q))}}finally{H&&H()}if(U&&(m.schemaVersion++,m.updatedAttributes()),Vt.trace(`${t} table loading, running index`),V.length>0||Y.length>0?m.indexingOperation=cTe(m,V,Y):U&&YT.signalSchemaChange(new WT.SchemaEventMsg(process.pid,"schema-change",m.databaseName,m.tableName)),m.origin=f,U)for(let Q of VE)Q(m,f!=="cluster");return(n||s||i)&&m.setTTLExpiration({expiration:n,eviction:s,scanInterval:i}),Vt.trace(`${t} table loaded`),m;function ne(){H||h.transactionSync(()=>({then(Q){H=Q}}))}a(ne,"startTxn")}async function cTe(e,t,r){try{Vt.info(`Indexing ${e.tableName} attributes`,t);let n=e.schemaVersion;await YT.signalSchemaChange(new WT.SchemaEventMsg(process.pid,"schema-change",e.databaseName,e.tableName));let s;for(let u of r)s=u.drop();let i,o={},c=0,l=t.length;if(await new Promise(u=>setImmediate(u)),l>0){let u;for(let _ of t)(0,Cd.compareKeys)(_.lastIndexedKey,u)<0&&(u=_.lastIndexedKey),_.lastIndexedKey==null&&_.dbi.clearAsync();let d=0;for(let{key:_,value:E,version:f}of e.primaryStore.getRange({start:u,lazy:l<4,versions:!0,snapshot:!1}))if(E){if(d++,s=e.primaryStore.ifVersion(_,f,()=>{for(let h=0;h<l;h++){let T=t[h],m=T.name;try{let g=T.resolve,S=E&&(g?g(E):E[m]),y=(0,MW.getIndexedValues)(S);if(y)for(let I=0,U=y.length;I<U;I++)T.dbi.put(y[I],_)}catch(g){o[m]||(o[m]=!0,Vt.error(`Error indexing attribute ${m}`,g))}}}),s.then(()=>d--,h=>{d--,Vt.error(h)}),WE.workerData&&WE.workerData.restartNumber!==UW.restartNumber&&(i=!0),++c%100===0||i){for(let h of t)h.lastIndexedKey=_,e.dbisDB.put(h.key,h);if(i)return}d>oTe?await s:d>aTe&&await new Promise(h=>setImmediate(h))}for(let _ of t)delete _.lastIndexedKey,delete _.indexingPID,_.dbi.isIndexing=!1,s=e.dbisDB.put(_.key,_)}await s,await YT.signalSchemaChange(new WT.SchemaEventMsg(process.pid,"indexing-finished",e.databaseName,e.tableName)),Vt.info(`Finished indexing ${e.tableName} attributes`,t)}catch(n){Vt.error("Error in indexing",n)}}function lTe({table:e,database:t}){let r=Ql({database:t,table:e}),n=[],s=r.dbisDb;for(let i of s.getKeys({start:e+"/",end:e+"0"}))n.push(s.remove(i));return Promise.all(n)}function Lc(e){return VE.push(e),{remove(){let t=VE.indexOf(e);t>-1&&VE.splice(t,1)}}}function of(e){return KE.push(e),{remove(){let t=KE.indexOf(e);t>-1&&KE.splice(t,1)}}}function Lm(){let e=(0,er.get)(yr.CONFIG_PARAMS.STORAGE_COMPRESSION),t=(0,er.get)(yr.CONFIG_PARAMS.STORAGE_COMPRESSION_DICTIONARY),r=(0,er.get)(yr.CONFIG_PARAMS.STORAGE_COMPRESSION_THRESHOLD)||vW,n={startingOffset:32};return t&&(n.dictionary=YE.readFileSync(t)),r&&(n.threshold=r),e&&n}var er,KT,Cd,Ut,rs,Id,Ol,Iw,yr,YE,ww,MW,YT,WT,WE,Vt,UW,Cw,zT,vW,jn,We,Nd,VE,KE,jT,xa,wd,oTe,aTe,Pe=Ie(()=>{er=L(se()),KT=L(Ht()),Cd=require("lmdb"),Ut=require("path"),rs=require("fs"),Id=L(gt());$f();Ol=L(c_()),Iw=L(l_()),yr=L(M()),YE=L(require("fs-extra")),ww=L(fi()),MW=L(cn()),YT=L(no()),WT=L(qs()),WE=require("worker_threads"),Vt=L(W()),UW=L(dt());Ji();vl();Cw="data",zT=Symbol("defined-tables"),vW=((0,er.get)(yr.CONFIG_PARAMS.STORAGE_PAGESIZE)||4096)-60;(0,er.initSync)();jn=Object.create(null),We=Object.create(null);(0,ww._assignPackageExport)("databases",We);(0,ww._assignPackageExport)("tables",jn);Nd=Symbol.for("next-table-id"),VE=[],KE=[],xa=new Map;a(iTe,"getTables");a(ut,"getDatabases");a(ku,"resetDatabases");a($E,"readMetaDb");a(BW,"ensureDB");a(HW,"setTable");a(Ql,"database");a(xR,"dropDatabase");a(Et,"table");oTe=1e3,aTe=10;a(cTe,"runIndexing");a(lTe,"dropTableMeta");a(Lc,"onUpdatedTable");a(of,"onRemovedDB");a(Lm,"getDefaultCompression")});var te=N((sUe,JW)=>{"use strict";var ka=require("path"),qW=require("fs-extra"),In=W(),xW=require("fs-extra"),QT=require("os"),uTe=require("net"),dTe=require("recursive-iterator"),Kt=M(),_Te=hg(),kW=require("papaparse"),JT=require("moment"),{inspect:fTe}=require("util"),FW=require("is-number"),nUe=require("lodash"),ETe=require("minimist"),hTe=require("https"),pTe=require("http"),{hdb_errors:XT}=_e(),mTe=/^((\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d:[0-5]\d\.\d+([+-][0-2]\d:[0-5]\d|Z))|(\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d:[0-5]\d([+-][0-2]\d:[0-5]\d|Z))|(\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d([+-][0-2]\d:[0-5]\d|Z)))$/,$W=require("util").promisify(setTimeout),STe=100,TTe=5,gTe="",ATe=4,GW={true:!0,TRUE:!0,FALSE:!1,false:!1,undefined:null,null:null,NULL:null,NaN:NaN};JW.exports={isEmpty:ns,isEmptyOrZeroLength:Wi,arrayHasEmptyValues:bTe,arrayHasEmptyOrZeroLengthValues:OTe,buildFolderPath:NTe,isBoolean:VW,errorizeMessage:RTe,stripFileExtension:wTe,autoCast:CTe,autoCastJSON:KW,autoCastJSONDeep:Pw,removeDir:DTe,compareVersions:PTe,isCompatibleDataVersion:LTe,escapeRawValue:MTe,unescapeValue:UTe,stringifyProps:vTe,timeoutPromise:HTe,isClusterOperation:kTe,getClusterUser:GTe,checkGlobalSchemaTable:FTe,getHomeDir:WW,getPropsFilePath:BTe,promisifyPapaParse:qTe,removeBOM:jW,createEventPromise:$Te,checkProcessRunning:VTe,checkSchemaTableExist:KTe,checkSchemaExists:zW,checkTableExists:QW,getStartOfTomorrowInSeconds:YTe,getLimitKey:WTe,isObject:ITe,isNotEmptyAndHasValue:yTe,autoCasterIsNumberCheck:YW,backtickASTSchemaItems:jTe,isPortTaken:xTe,createForkArgs:zTe,autoCastBoolean:QTe,async_set_timeout:$W,getTableHashAttribute:JTe,doesSchemaExist:XTe,doesTableExist:ZTe,stringifyObj:ege,ms_to_time:tge,changeExtension:rge,getEnvCliRootPath:Lw,noBootFile:nge,httpRequest:sge,transformReq:ige,convertToMS:oge,PACKAGE_ROOT:Kt.PACKAGE_ROOT};function RTe(e){return e instanceof Error?e:new Error(e)}a(RTe,"errorizeMessage");function ns(e){return e==null}a(ns,"isEmpty");function yTe(e){return!ns(e)&&(e||e===0||e===""||VW(e))}a(yTe,"isNotEmptyAndHasValue");function Wi(e){return ns(e)||e.length===0||e.size===0}a(Wi,"isEmptyOrZeroLength");function bTe(e){if(ns(e))return!0;for(let t=0;t<e.length;t++)if(ns(e[t]))return!0;return!1}a(bTe,"arrayHasEmptyValues");function OTe(e){if(Wi(e))return!0;for(let t=0;t<e.length;t++)if(Wi(e[t]))return!0;return!1}a(OTe,"arrayHasEmptyOrZeroLengthValues");function NTe(...e){try{return e.join(ka.sep)}catch{console.error(e)}}a(NTe,"buildFolderPath");function VW(e){return ns(e)?!1:e===!0||e===!1}a(VW,"isBoolean");function ITe(e){return ns(e)?!1:typeof e=="object"}a(ITe,"isObject");function wTe(e){return Wi(e)?gTe:e.slice(0,-ATe)}a(wTe,"stripFileExtension");function CTe(e){return ns(e)||e===""||typeof e!="string"?e:GW[e]!==void 0?GW[e]:YW(e)===!0?Number(e):mTe.test(e)?new Date(e):e}a(CTe,"autoCast");function KW(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}a(KW,"autoCastJSON");function Pw(e){if(e&&typeof e=="object"){if(Array.isArray(e))for(let t=0,r=e.length;t<r;t++){let n=e[t],s=Pw(n);s!==n&&(e[t]=s)}else for(let t in e){let r=e[t],n=Pw(r);n!==r&&(e[t]=n)}return e}else return KW(e)}a(Pw,"autoCastJSONDeep");function YW(e){if(e.startsWith("0.")&&FW(e))return!0;let t=e.toUpperCase().includes("E");return!!((e!=="0"&&e.startsWith("0"))===!1&&t===!1&&FW(e))}a(YW,"autoCasterIsNumberCheck");async function DTe(e){if(Wi(e))throw new Error(`Directory path: ${e} does not exist`);try{await xW.emptyDir(e),await xW.remove(e)}catch(t){throw In.error(`Error removing files in ${e} -- ${t}`),t}}a(DTe,"removeDir");function PTe(e,t){if(Wi(e)){In.info("Invalid current version sent as parameter.");return}if(Wi(t)){In.info("Invalid upgrade version sent as parameter.");return}let r,n=/(\.0+)+$/,s=e.version?e.version:e,i=t.version?t.version:t,o=s.replace(n,"").split("."),c=i.replace(n,"").split("."),l=Math.min(o.length,c.length);for(let u=0;u<l;u++)if(r=parseInt(o[u],10)-parseInt(c[u],10),r)return r;return o.length-c.length}a(PTe,"compareVersions");function LTe(e,t,r=!1){let n=e.toString().split("."),s=t.toString().split(".");return n[0]===s[0]&&(!r||n[1]===s[1])}a(LTe,"isCompatibleDataVersion");function MTe(e){if(ns(e))return e;let t=String(e);return t==="."?Kt.UNICODE_PERIOD:t===".."?Kt.UNICODE_PERIOD+Kt.UNICODE_PERIOD:t.replace(Kt.FORWARD_SLASH_REGEX,Kt.UNICODE_FORWARD_SLASH)}a(MTe,"escapeRawValue");function UTe(e){if(ns(e))return e;let t=String(e);return t===Kt.UNICODE_PERIOD?".":t===Kt.UNICODE_PERIOD+Kt.UNICODE_PERIOD?"..":String(e).replace(Kt.ESCAPED_FORWARD_SLASH_REGEX,"/")}a(UTe,"unescapeValue");function vTe(e,t){if(ns(e))return In.info("Properties object is null"),"";let r="";return e.each(function(n,s){try{if(t&&t[n]){let i=t[n];for(let o of i)r+=";"+o+QT.EOL}!Wi(n)&&n[0]===";"?r+=" "+n+s+QT.EOL:Wi(n)||(r+=n+"="+s+QT.EOL)}catch{In.error(`Found bad property during upgrade with key ${n} and value: ${s}`)}}),r}a(vTe,"stringifyProps");function WW(){let e;try{e=QT.homedir()}catch{e=process.env.HOME}return e}a(WW,"getHomeDir");function BTe(){let e=ka.join(WW(),Kt.HDB_HOME_DIR_NAME,Kt.BOOT_PROPS_FILE_NAME);return qW.existsSync(e)||(e=ka.join(__dirname,"../","hdb_boot_properties.file")),e}a(BTe,"getPropsFilePath");function HTe(e,t){let r,n;return n=new Promise(function(s){r=setTimeout(function(){s(t)},e)}),{promise:n,cancel:a(function(){clearTimeout(r)},"cancel")}}a(HTe,"timeoutPromise");async function xTe(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let n=uTe.createServer().once("error",s=>{s.code==="EADDRINUSE"?t(!0):r(s)}).once("listening",()=>n.once("close",()=>t(!1)).close()).listen(e)})}a(xTe,"isPortTaken");function kTe(e){try{return Kt.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){In.error(`Error checking operation against cluster ops ${t}`)}return!1}a(kTe,"isClusterOperation");function FTe(e,t){let r=(Pe(),oe(lt)).getDatabases();if(!r[e])return XT.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e);if(!r[e][t])return XT.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(FTe,"checkGlobalSchemaTable");function GTe(e,t){if(ns(t)){In.warn("No CLUSTERING_USER defined, clustering disabled");return}if(ns(e)||Wi(e)){In.warn("No users to search.");return}let r;try{let n=e.get(t);n&&n.role.permission.cluster_user===!0&&n.active===!0&&(r=n)}catch(n){In.error(`unable to find cluster_user due to: ${n.message}`);return}if(r===void 0){In.warn(`CLUSTERING_USER: ${t} not found or is not active.`);return}return r}a(GTe,"getClusterUser");function qTe(){kW.parsePromise=function(e,t,r){return new Promise(function(n,s){kW.parse(e,{header:!0,transformHeader:jW,chunk:t.bind(null,s),skipEmptyLines:!0,transform:r,dynamicTyping:!1,error:s,complete:n})})}}a(qTe,"promisifyPapaParse");function jW(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}a(jW,"removeBOM");function $Te(e,t,r){return new Promise(n=>{t.once(e,s=>{let i=r;In.info(`Got cluster status event response: ${fTe(s)}`);try{i.cancel()}catch{In.error("Error trying to cancel timeout.")}n(s)})})}a($Te,"createEventPromise");async function VTe(e){let t=!0,r=0;do await $W(STe*r++),(await _Te.findPs(e)).length>0&&(t=!1);while(t&&r<TTe);if(t)throw new Error(`process ${e} was not started`)}a(VTe,"checkProcessRunning");function KTe(e,t){let r=zW(e);if(r)return r;let n=QW(e,t);if(n)return n}a(KTe,"checkSchemaTableExist");function zW(e){let{getDatabases:t}=(Pe(),oe(lt));if(!t()[e])return XT.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(zW,"checkSchemaExists");function QW(e,t){let{getDatabases:r}=(Pe(),oe(lt));if(!r()[e][t])return XT.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(QW,"checkTableExists");function YTe(){let e=JT().utc().add(1,Kt.MOMENT_DAYS_TAG).startOf(Kt.MOMENT_DAYS_TAG).unix(),t=JT().utc().unix();return e-t}a(YTe,"getStartOfTomorrowInSeconds");function WTe(){return JT().utc().format("DD-MM-YYYY")}a(WTe,"getLimitKey");function jTe(e){try{let t=new dTe(e);for(let{node:r}of t)r&&(r.columnid&&typeof r.columnid!="string"&&(r.columnid=r.columnid.toString()),r.columnid&&!r.columnid.startsWith("`")&&(r.columnid_orig=r.columnid,r.columnid=`\`${r.columnid}\``),r.tableid&&!r.tableid.startsWith("`")&&(r.tableid_orig=r.tableid,r.tableid=`\`${r.tableid}\``),r.databaseid&&!r.databaseid.startsWith("`")&&(r.databaseid_orig=r.databaseid,r.databaseid=`\`${r.databaseid}\``),r.as&&typeof r.as=="string"&&!r.as.startsWith("[")&&(r.as_orig=r.as,r.as=`\`${r.as}\``))}catch(t){In.error("Got an error back ticking items."),In.error(t)}}a(jTe,"backtickASTSchemaItems");function zTe(e){return[e]}a(zTe,"createForkArgs");function QTe(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(QTe,"autoCastBoolean");function JTe(e,t){let{getDatabases:r}=(Pe(),oe(lt)),n=r()[e]?.[t];return n?.primaryKey||n?.hash_attribute}a(JTe,"getTableHashAttribute");function XTe(e){let{getDatabases:t}=(Pe(),oe(lt));return t()[e]!==void 0}a(XTe,"doesSchemaExist");function ZTe(e,t){let{getDatabases:r}=(Pe(),oe(lt));return r()[e]?.[t]!==void 0}a(ZTe,"doesTableExist");function ege(e){try{return JSON.stringify(e)}catch{return e}}a(ege,"stringifyObj");function tge(e){let t=JT.duration(e),r=t.seconds()>0?t.seconds()+"s":"",n=t.minutes()>0?t.minutes()+"m ":"",s=t.hours()>0?t.hours()+"h ":"",i=t.days()>0?t.days()+"d ":"";return(t.years()>0?t.years()+"y ":"")+i+s+n+r}a(tge,"ms_to_time");function rge(e,t){let r=ka.basename(e,ka.extname(e));return ka.join(ka.dirname(e),r+t)}a(rge,"changeExtension");function Lw(){if(process.env[Kt.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return process.env[Kt.CONFIG_PARAMS.ROOTPATH.toUpperCase()];let e=ETe(process.argv);if(e[Kt.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return e[Kt.CONFIG_PARAMS.ROOTPATH.toUpperCase()]}a(Lw,"getEnvCliRootPath");var Dw;function nge(){if(Dw)return Dw;let e=Lw();if(Lw()&&qW.pathExistsSync(ka.join(e,Kt.HDB_CONFIG_FILE)))return Dw=!0,!0}a(nge,"noBootFile");function sge(e,t){let r;return e.protocol==="http:"?r=pTe:r=hTe,new Promise((n,s)=>{let i=r.request(e,o=>{o.setEncoding("utf8"),o.body="",o.on("data",c=>{o.body+=c}),o.on("end",()=>{n(o)})});i.on("error",o=>{s(o)}),i.write(t instanceof Buffer?t:JSON.stringify(t)),i.end()})}a(sge,"httpRequest");function ige(e){if(!e.schema&&!e.database){e.schema=Kt.DEFAULT_DATABASE_NAME;return}e.database&&(e.schema=e.database)}a(ige,"transformReq");function oge(e){let t=0;if(typeof e=="number"&&(t=e),typeof e=="string")switch(t=parseFloat(e),e.slice(-1)){case"M":t*=86400*30;break;case"D":case"d":t*=86400;break;case"H":case"h":t*=3600;break;case"m":t*=60;break}return t*1e3}a(oge,"convertToMS")});var ZW=N((aUe,XW)=>{"use strict";var Mw=M(),age=te(),cge=Di(),ui=W(),lge=Sm(),uge=mf(),oUe=xu(),dge=ls(),_ge=Rf(),fge=require("semver/functions/gte"),Ege=3e4,hge=7;XW.exports=pge;async function pge(){try{ui.notify("Starting update nodes. This process will attempt to update any node connections the need to be reestablished after a 4.0.0 upgrade"),await dge.setSchemaDataToGlobalAsync();let e=await cge.getAllNodeRecords(),t=[];for(let r=0,n=e.length;r<n;r++){let s=e[r];s.system_info.hdb_version===Mw.PRE_4_0_0_VERSION&&t.push(mge(s))}await Promise.allSettled(t),ui.notify("Shutting down 4.0.0 clustering upgrade process")}catch(e){throw ui.error(e),e}}a(pge,"updateAllNodes");async function mge(e){try{let{name:t,subscriptions:r}=e;ui.notify("Running 4.0.0 update on node:",t);let n=!1,s=0;for(;s<hge;){let i=[];if(await lge.buildNodeStatus(e,i),ui.trace("Received status:",i[0].status,"from node:",t),i[0].status==="open"&&fge(i[0].system_info.hdb_version,"4.0.0")){ui.notify("Received open status from node:",t,"calling add node");let o={operation:Mw.OPERATIONS_ENUM.ADD_NODE,node_name:t,subscriptions:r};await uge(o,!0),ui.notify("Successfully added node",t),n=!0;break}s=(Date.now()-e.__updatedtime__)/(1e3*60*60*24),ui.trace("Update node has been running for",s,"days. Calling node status again for node:",t),await age.async_set_timeout(Ege)}n||(ui.error("4.0.0 node update was unable to update connection to node:",t),ui.error("Removing following node record from hdb_nodes",e),await _ge({operation:Mw.OPERATIONS_ENUM.REMOVE_NODE,node_name:t}))}catch(t){throw ui.error(t),t}}a(mge,"updateNode")});var Sge=ZW();(async()=>{try{await Sge()}catch(e){console.error("Error launching 4.0.0 node update"),console.error(e),process.exit(1)}})();
|
|
133
|
+
`)}a(kK,"defaultNotFound")});var LK={};je(LK,{startHTTPThreads:()=>lme,startSocketServer:()=>$I,updateWorkerIdleness:()=>nY});async function lme(e=2,t){try{if(t)GI(0,1,!0);else{let{loadRootComponents:r}=nT();if(e===0)return(0,Ds.setMainIsWorker)(!0),await xI().startServers(),Promise.resolve([]);await r()}rY();for(let r=0;r<e;r++)GI(r,e);return Promise.all(tY)}finally{(0,Ds.threadsHaveStarted)()}}function rY(){let e=(0,ZK.checkMemoryLimit)();e&&!process.env.DEV_MODE&&(console.error(e),FI=setInterval(()=>{oT.notify(e)},cme).unref())}function GI(e,t=1,r){if(kI++,(0,Ds.startWorker)("server/threads/threadServer.js",{name:md.THREAD_TYPES.HTTP,workerIndex:e,threadCount:t,async onStarted(n){let s=new Promise((o,c)=>{function l(u){u.type===md.CLUSTER_MESSAGE_TYPE_ENUM.CHILD_STARTED&&(n.removeListener("message",l),o(n))}a(l,"onMessage"),n.on("message",l),n.on("error",c)});tY.push(s),await s,fd.push(n),n.expectedIdle=1,n.lastIdle=0,n.requests=1,n.on("message",o=>{if(o.requestId){let c=iT.get(o.requestId);c&&c(o)}}),n.on("exit",i),n.on("shutdown",i);function i(){let o=fd.indexOf(n);o>-1&&fd.splice(o,1)}if(a(i,"removeWorker"),Ed){let o=Ed;Ed=[];for(let c of o)eY[c.localPort](null,c)}}}),r){let n=setInterval(()=>{qI?qI=!1:(clearInterval(n),console.log("shut down dynamic thread due to inactivity"),(0,Ds.shutdownWorkers)(),kI=0,setTimeout(()=>{global.gc?.()},5e3))},1e4)}}function $I(e=0,t){if(typeof e=="string")try{(0,aT.existsSync)(e)&&(0,aT.unlinkSync)(e)}catch{}let r;t?t==="ip"?r=ume:r=dme(t):r=VI;let n=(0,hd.createServer)({allowHalfOpen:!0,pauseOnConnect:!r.readsData}).listen(e);if(n._handle){n._handle.onconnection=eY[e]=function(i,o){r.readsData||(o.reading=!1,o.readStop()),qI=!0,r(o,(c,l)=>{if(!c){if(QK){let d=o._socket||new hd.Socket({handle:o,writable:!0,readable:!0});QK.deliverSocket(d,e,l),d.resume()}else kI>0?(Ed.length===0&&setTimeout(()=>{Ed.length>0&&console.warn("Incoming sockets/requests have been queued for workers to start, and no workers have handled them. Check to make sure an error is not preventing workers from starting")},1e4).unref(),o.localPort=e,Ed.push(o)):(console.log("start up a dynamic thread to handle request"),GI(0));pr(!1,"socket-routed");return}c.requests++;let u=o.fd;if(u>=0)c.postMessage({port:e,fd:u,data:l});else{let d=o._socket||new hd.Socket({handle:o,writable:!0,readable:!0});Eme(d,c,e)}pr(!0,"socket-routed")})};let s=Xl();oT.info(`HarperDB ${s.version} Server running on port ${e}`)}return n.on("error",s=>{console.error("Error in socket server",s)}),process.env._UNREF_SERVER&&n.unref(),n}function VI(e,t){let r,n=0;for(let s of fd){if(s.threadId===-1)continue;let i=s.expectedIdle/s.requests;if(i>n)r=s;else if(n>=sT)return sT=i,t(r);n=i}sT=0,t(r)}function ume(e,t){let r={};e.getpeername(r);let n=r.address,s=pd.get(n),i=Date.now();if(s&&s.worker.threadId!==-1)return s.lastUsed=i,t(s.worker);VI(e,o=>{pd.set(n,{worker:o,lastUsed:i}),t(o)})}function dme(e){let t=new RegExp(`${e}:\\s*(.+)`,"i");return r.readsData=!0,r;function r(n,s){let i=new hd.Socket({handle:n,readable:!0,writable:!0});n._socket=i,i.on("data",o=>{n.readStop();let l=o.toString("latin1").match(t)?.[1],u=pd.get(l),d=Date.now();if(u&&u.worker.threadId!==-1)return u.lastUsed=d,s(u.worker);VI(n,_=>{pd.set(l,{worker:_,lastUsed:d}),s(_,o)})})}a(r,"findByHeaderAffinity")}function nY(){sT=0;for(let e of fd)e.expectedIdle=e.recentELU.idle+_me,e.requests=1;fd.sort((e,t)=>e.expectedIdle>t.expectedIdle?-1:1)}function Eme(e,t,r){let n=fme++;t.postMessage({port:r,requestId:n,event:"connection"}),e.on("data",s=>{let i=s.toString("latin1");t.postMessage({port:r,requestId:n,data:i,event:"data"})}).on("close",s=>{t.postMessage({port:r,requestId:n,event:"close",hadError:s})}).on("error",s=>{t.postMessage({port:r,requestId:n,event:"error",error:s})}).on("drain",s=>{t.postMessage({port:r,requestId:n,event:"drain",error:s})}).on("end",()=>{t.postMessage({port:r,requestId:n,event:"end"})}).resume(),iT.set(n,s=>{s.event=="data"&&e.write(Buffer.from(s.data,"latin1")),s.event=="end"&&(e.end(s.data&&Buffer.from(s.data,"latin1")),iT.delete(n)),s.event=="destroy"&&(e.destroy(),iT.delete(n))})}var Ds,hd,md,oT,aT,XK,ZK,fd,Ed,eY,QK,kI,tY,FI,cme,qI,sT,JK,pd,_me,iT,fme,wI=Ie(()=>{Ds=L(dt()),hd=require("net"),md=L(M()),oT=L(W()),aT=require("fs");Ni();XK=require("worker_threads"),ZK=L(_c()),fd=[],Ed=[],eY=[],kI=0,tY=[];XK.isMainThread&&(process.on("uncaughtException",e=>{e.code!=="ECONNRESET"&&e.message!=="write EIO"&&console.error("uncaughtException",e)}),(0,Ds.onMessageFromWorkers)(e=>{e.type===md.ITC_EVENT_TYPES.RESTART&&FI&&(clearInterval(FI),rY())}));cme=6e5;a(lme,"startHTTPThreads");a(rY,"licenseWarning");a(GI,"startHTTPWorker");a($I,"startSocketServer");sT=0;a(VI,"findMostIdleWorker");JK=36e5,pd=new Map;a(ume,"findByRemoteAddressAffinity");a(dme,"makeFindByHeaderAffinity");setInterval(()=>{let e=Date.now();for(let[t,r]of pd)r.lastUsed+JK<e&&pd.delete(t)},JK).unref();_me=1e3;a(nY,"updateWorkerIdleness");(0,Ds.setMonitorListener)(nY);iT=new Map,fme=1;a(Eme,"proxySocket")});var aY=N(($Le,oY)=>{"use strict";var hme=require("cluster"),ml=se();ml.initSync();var iY=M(),xLe=require("util"),Ho=W(),kLe=require("fs"),pme=require("fastify"),FLe=Xl(),mme=require("@fastify/cors"),Sme=require("@fastify/compress"),Tme=require("@fastify/static"),gme=FN(),Ame=require("path"),{PACKAGE_ROOT:Rme}=M(),yme=ls(),bme=te(),Ome=xn(),Nme=_c(),{server:Ime}=(qr(),oe(Ja)),{node_request_key:GLe}=(vS(),oe(JN)),{authHandler:wme,handlePostRequest:Cme,serverErrorHandler:Dme,reqBodyValidationHandler:Pme}=LS(),qLe=require("net"),{registerContentHandlers:Lme}=(zc(),oe($$)),Mme=6e4,Ume=1024*1024*1024,vme="TRUE",{CONFIG_PARAMS:DE}=iY,Sd;oY.exports={hdbServer:sY,start:sY};async function sY(e){try{Ho.debug("In Fastify server"+process.cwd()),Ho.debug(`Running with NODE_ENV set as: ${process.env.NODE_ENV}`),Ho.debug(`HarperDB server process ${process.pid} starting up.`),global.clustering_on=!1,global.isMaster=hme.isMaster,await Bme();let t=e.securePort>0;Sd=Hme(t),await Sd.ready(),e||(e={}),e.isOperationsServer=!0;try{Ime.http(Sd.server,e),Sd.server.closeIdleConnections||await Sd.listen({port:0,host:"::"})}catch(r){throw Sd.close(),Ho.error(r),Ho.error("Error configuring operations server"),r}}catch(t){console.error(`Failed to build server on ${process.pid}`,t),Ho.fatal(t),process.exit(1)}}a(sY,"operationsServer");async function Bme(){Ho.trace("Configuring HarperDB process."),yme.setSchemaDataToGlobal(),await Ome.setUsersToGlobal(),await Nme.getLicense()}a(Bme,"setUp");function Hme(e){Ho.debug(`HarperDB process starting to build ${e?"HTTPS":"HTTP"} server.`);let t=xme(e),r=pme(t);r.server.headersTimeout=Fme(),r.setErrorHandler(Dme);let n=kme();n&&r.register(mme,n),r.register(function(i,o,c){i.setNotFoundHandler(function(l,u){r.server.emit("unhandled",l.raw,u.raw)}),c()}),r.register(gme),r.register(Sme),r.register(Tme,{root:Ame.join(Rme,"studio/build-local")}),Lme(r);let s=ml.get(iY.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON);return r.get("/",function(i,o){return!bme.isEmpty(s)&&s.toString().toLowerCase()==="true"?o.sendFile("index.html"):o.sendFile("running.html")}),r.post("/",{preValidation:[Pme,wme],config:{isOperation:!0}},async function(i,o){return i.body?.operation?.startsWith("restart")&&o.header("Connection","close"),Cme(i,o)}),r.get("/health",()=>"HarperDB is running."),Ho.debug(`HarperDB process starting up ${e?"HTTPS":"HTTP"} server listener.`),r}a(Hme,"buildServer");function xme(e){let t=ml.get(DE.OPERATIONSAPI_NETWORK_TIMEOUT),r=ml.get(DE.OPERATIONSAPI_NETWORK_KEEPALIVETIMEOUT);return{bodyLimit:Ume,connectionTimeout:t,keepAliveTimeout:r,forceCloseConnections:!0,return503OnClosing:!1,https:e}}a(xme,"getServerOptions");function kme(){let e=ml.get(DE.OPERATIONSAPI_NETWORK_CORS),t=ml.get(DE.OPERATIONSAPI_NETWORK_CORSACCESSLIST),r;return e&&(e===!0||e.toUpperCase()===vme)&&(r={origin:!0,allowedHeaders:["Content-Type","Authorization","Accept"],credentials:!1},t&&t.length>0&&t[0]!==null&&t[0]!=="*"&&(r.origin=(n,s)=>s(null,t.indexOf(n)!==-1))),r}a(kme,"getCORSOpts");function Fme(){return ml.get(DE.OPERATIONSAPI_NETWORK_HEADERSTIMEOUT)??Mme}a(Fme,"getHeaderTimeoutConfig")});var QI={};je(QI,{disableNATS:()=>qme,publishToStream:()=>uT,setNATSReplicator:()=>KI,setPublishToStream:()=>$me,setSubscription:()=>zI,start:()=>Gme});function Gme(){PE.default.get(LE.default.CONFIG_PARAMS.CLUSTERING_ENABLED)&&Kme()}function qme(e=!0){_Y=e}function $me(e,t){uT=e,zI=t}function Kme(){if(_Y||process.env._DISABLE_NATS)return;let e=ut(),t=Object.keys(e);t.push("system");for(let r of t){let n=e[r];for(let s in n){let i=n[s];KI(s,r,i)}}Lc((r,n)=>{KI(r.tableName,r.databaseName,r),n&&EY(r)}),!cY&&(cY=!0)}function KI(e,t,r){if(t==="system"&&Yme.includes(e))return;if(!r)return console.error(`Attempt to replicate non-existent table ${e} from database ${t}`);if(r.sources.some(s=>s?.isNATSReplicator))return;r.sourcedFrom(class extends Lr{static{a(this,"NATSReplicator")}put(i){return n(this.getContext()).addWrite(t,{operation:"put",table:e,id:this[ze],record:i})}delete(){return n(this.getContext()).addWrite(t,{operation:"delete",table:e,id:this[ze]})}publish(i){return n(this.getContext()).addWrite(t,{operation:"publish",table:e,id:this[ze],record:i})}patch(i){return n(this.getContext()).addWrite(t,{operation:"patch",table:e,id:this[ze],record:i})}invalidate(){n(this.getContext()).addWrite(t,{operation:"invalidate",table:e,id:this[ze]})}static defineSchema(i){EY(i)}static subscribe(){let i=new Mn;return zI(t,e,i),i}static subscribeOnThisThread(i){return i<(PE.default.get(LE.default.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)??Vme)}static isEqual(i){return i.isNATSReplicator}static isNATSReplicator=!0;static shouldReceiveInvalidations=!0},{intermediateSource:!0});function n(s){let i=s?.transaction?.nats;if(!i)if(s?.transaction){s.transaction.nats=i=new cT(s.transaction,s);let o=s.transaction;for(;o.next;)o=o.next;o.next=s.transaction.nats,i.user=s.user,i.context=s}else i=fY;return i}a(n,"getNATSTransaction")}function EY(e){let t=PE.default.get(LE.default.CONFIG_PARAMS.CLUSTERING_NODENAME);uT(`${WI.SUBJECT_PREFIXES.TXN}.${e.databaseName}.${e.tableName}`,(0,jI.createNatsTableStreamName)(e.databaseName,e.tableName),void 0,{operation:"define_schema",schema:e.databaseName,table:e.tableName,attributes:e.attributes,__origin:{timestamp:Date.now(),node_name:t}})}var lY,WI,jI,uY,dY,PE,LE,lT,_Y,uT,zI,Vme,fY,cY,Yme,cT,YI,hY=Ie(()=>{Pe();Vs();lY=L(mr()),WI=L(Ct()),jI=L(to());Ll();uY=L(ey()),dY=L(cn()),PE=L(se()),LE=L(M()),lT=L(W());a(Gme,"start");a(qme,"disableNATS");uT=lY.publishToStream,zI=uY.setSubscription;a($me,"setPublishToStream");Vme=2;a(Kme,"assignReplicationSource");Yme=["hdb_job","hdb_analytics","hdb_raw_analytics","hdb_info","hdb_license"];a(KI,"setNATSReplicator");a(EY,"publishSchema");cT=class{constructor(t,r){this.transaction=t;this.options=r}static{a(this,"NATSTransaction")}user;writes_by_db=new Map;addWrite(t,r){r.expiresAt=this.context?.expiresAt;let n=this.writes_by_db.get(t);n||this.writes_by_db.set(t,n=[]),n.push(r)}commit({timestamp:t}){let r=PE.default.get(LE.default.CONFIG_PARAMS.CLUSTERING_NODENAME),n=[];for(let[s,i]of this.writes_by_db){let o=[],c=[],l,u;for(let d of i){let _=d.table,E=d.operation=="put"?"upsert":d.operation;l||(lT.trace(`Sending transaction event ${E}`),u=l={operation:E,schema:s,table:_,__origin:{user:this.user?.username,timestamp:t,node_name:r}},l.hash_values=c,E!=="delete"&&E!=="invalidate"&&(l.records=o)),l.table===_&&l.operation===E?(o.push(d.record),c.push(d.id)):u=u.next={operation:E,table:_,id:d.id,record:d.record},d.expiresAt&&(u.expiresAt=d.expiresAt)}l&&n.push(uT(`${WI.SUBJECT_PREFIXES.TXN}.${s}.${l.table}`,(0,jI.createNatsTableStreamName)(s,l.table),void 0,l)?.catch(d=>{throw lT.error("An error has occurred trying to replicate transaction",l,d),d.statusCode=504,d}))}return Promise.all(n)}},YI=class extends cT{static{a(this,"ImmmediateNATSTransaction")}constructor(){super({get timestamp(){return(0,dY.getNextMonotonicTime)()}})}addWrite(t,r){super.addWrite(t,r),this.commit({})}};fY=new YI});async function gY({clientId:e,user:t,clean:r,will:n,keepalive:s}){let i;if(e&&!r){let o=await JI.get(e,{returnNonexistent:!0});i=new ew(e,t,o),o&&(i.sessionWasPresent=!0)}else{if(e){let o=await JI.get(e);o&&o.delete()}i=new _T(e,t)}return n&&(n.id=e,n.user={username:t?.username},ME.put(n)),s&&(i.keepalive=s,i.receivedPacket()),i}function XI(){return dT++,dT>65500&&(dT=1),dT}function ZI(e,t,r){let{topic:n,retain:s}=e;e.data=t,e.async=!0,r.authorize=!0;let i=wi.getMatch(n,"mqtt");if(!i)throw new Error(`Can not publish to topic ${n} as it does not exist, no resource has been defined to handle this topic`);e.url=i.relativeURL;let o=i.Resource;return Dt(r,()=>s?t===void 0?o.delete(e,r):o.put(e,e.data,r):o.publish(e,e.data,r))}var mY,Ua,SY,TY,pY,JI,ME,dT,_T,ew,AY=Ie(()=>{Pe();su();mY=L(cn()),Ua=L(W());Sc();SY=L(dt()),TY=L(xI());qr();pY=100,JI=Et({database:"system",table:"hdb_durable_session",attributes:[{name:"id",isPrimaryKey:!0},{name:"subscriptions",type:"array",elements:{attributes:[{name:"topic"},{name:"qos"},{name:"startTime"},{name:"acks"}]}}]}),ME=Et({database:"system",table:"hdb_session_will",attributes:[{name:"id",isPrimaryKey:!0},{name:"topic",type:"string"},{name:"data"},{name:"qos",type:"number"},{name:"retain",type:"boolean"},{name:"user",type:"any"}]});(0,SY.getWorkerIndex)()===0&&(async()=>{await TY.when_components_loaded,await new Promise(e=>setTimeout(e,2e3));for await(let e of ME.search({})){let t=e.data,r={...e};r.user?.username&&(r.user=await it.getUser(r.user.username));try{await ZI(r,t,r)}catch{(0,Ua.warn)("Failed to publish will",t)}ME.delete(e.id)}})();a(gY,"getSession");dT=1;a(XI,"getNextMessageId");_T=class{static{a(this,"SubscriptionsSession")}listener;sessionId;user;request;socket;subscriptions=[];awaitingAcks;sessionWasPresent;keepalive;keepaliveTimer;constructor(t,r){this.sessionId=t,this.user=r}async addSubscription(t,r,n){let{topic:s,rh:i,startTime:o}=t,c=s.indexOf("?"),l,u;if(c>-1?(l=s.slice(c),u=s.slice(0,c)):u=s,!u)throw new Error("No topic provided");if(u.indexOf(".")>-1)throw new Error("Dots are not allowed in topic names");let d=this.subscriptions.find(g=>g.topic===s),_;d?(_=i>0,d.end(),this.subscriptions.splice(this.subscriptions.indexOf(d),1)):_=i===2;let E={search:l,async:!0,user:this.user,startTime:o,omitCurrent:_,url:""};o&&(0,Ua.trace)("Resuming subscription from",s,"from",o);let f=wi.getMatch(u,"mqtt");if(!f){let g=new Error(`The topic ${s} does not exist, no resource has been defined to handle this topic`);throw g.statusCode=404,g}if(E.url=f.relativeURL,E.url.indexOf("+")>-1||E.url.indexOf("#")>-1){let g=E.url.slice(1);if(g.indexOf("#")>-1&&g.indexOf("#")!==g.length-1)throw new Error("Multi-level wildcards can only be used at the end of a topic");if(E.isCollection=!0,g.indexOf("+")===g.length-1)E.onlyChildren=!0,E.url="/"+g.slice(0,g.length-1);else{let S=g.split("/"),y;for(let H=0;H<S.length;H++)if(S[H].indexOf("+")>-1)if(S[H]==="+")y=!0;else throw new Error("Single-level wildcards can only be used as a topic level (between or after slashes)");if(n&&y)throw new Error("Filters can not be combined");let I=!0;S[S.length-1]==="#"&&(S.length--,I=!1),y&&(n=a(H=>{let X=H.id;if(!Array.isArray(X)||I&&X.length!==S.length)return!1;for(let Y=0;Y<S.length;Y++)if(S[Y]!=="+"&&S[Y]!==X[Y])return!1;return!0},"filter"));let U=S.indexOf("+");E.url="/"+(U>-1?S.slice(0,U):S).concat("").join("/")}}let h=f.path,T=f.Resource,m=await Dt(E,async()=>{let g=this.createContext();g.topic=s,g.retainHandling=i;let S=await T.subscribe(E,g);if(!S)return;if(!S[Symbol.asyncIterator])throw new Error(`Subscription is not (async) iterable for topic ${s}`);let y=(async()=>{for await(let I of S)try{let U;if(I.type&&I.type!=="put"&&I.type!=="delete"&&I.type!=="message"&&I.type!=="patch"||n&&!n(I))continue;r?(I.topic=s,U=this.needsAcknowledge(I)):(I.acknowledge?.(),U=XI());let H=I.id;if(Array.isArray(H)&&(H=nu(H)),H==null&&(H=""),await this.listener(h+"/"+H,I.value,U,t)===!1)break;this.awaitingAcks?.size>pY?await new Promise(Y=>setTimeout(Y,this.awaitingAcks.size-pY)):await new Promise(setImmediate)}catch(U){(0,Ua.warn)(U)}})();return S});if(m)return m.topic=s,m.qos=t.qos,this.subscriptions.push(m),m}resume(){}needsAcknowledge(t){let r=XI();return t.acknowledge&&(this.awaitingAcks||(this.awaitingAcks=new Map),this.awaitingAcks.set(r,{acknowledge:t.acknowledge})),r}acknowledge(t){let r=this.awaitingAcks?.get(t);r&&(this.awaitingAcks.delete(t),r.acknowledge())}async removeSubscription(t){let r=this.subscriptions.find(n=>n.topic===t);if(r)return r.end(),this.subscriptions.splice(this.subscriptions.indexOf(r),1),!0}async publish(t,r){return ZI(t,r,this.createContext())}createContext(){let t={session:this,socket:this.socket,user:this.user,authorize:!0};return this.request&&(t.request=this.request,t.url=this.request.url,t.headers=this.request.headers),t}setListener(t){this.listener=t}disconnect(t){this.keepaliveTimer&&clearTimeout(this.keepaliveTimer);let r=this.createContext();Dt(r,async()=>{try{if(!t){let n=await ME.get(this.sessionId);n?.doesExist()&&await ZI(n,n.data,r)}}finally{await ME.delete(this.sessionId)}}).catch(n=>{(0,Ua.warn)(`Error publishing MQTT will for ${this.sessionId}`,n)});for(let n of this.subscriptions)n.end();this.subscriptions=[]}receivedPacket(){this.keepalive&&(clearTimeout(this.keepaliveTimer),this.keepaliveTimer=setTimeout(()=>{this.socket?.destroy?this.socket.destroy(new Error("Keepalive timeout")):this.socket?.terminate()},this.keepalive*1500))}};a(ZI,"publish");ew=class extends _T{static{a(this,"DurableSubscriptionsSession")}sessionRecord;constructor(t,r,n){super(t,r),this.sessionRecord=n||{id:t,subscriptions:[]}}async resume(){for(let t of this.sessionRecord.subscriptions||[])await this.resumeSubscription({omitCurrent:!0,topic:t.topic,qos:t.qos,startTime:t.startTime},!0,t.acks?r=>!t.acks.includes(r.localTime):null)}resumeSubscription(t,r,n){return super.addSubscription(t,r,n)}needsAcknowledge(t){this.awaitingAcks||(this.awaitingAcks=new Map);let r=XI(),n={topic:t.topic,timestamp:t.localTime};return t.acknowledge&&(n.acknowledge=t.acknowledge),this.awaitingAcks.set(r,n),r}acknowledge(t){let r=this.awaitingAcks?.get(t);if(!r)return;this.awaitingAcks?.delete(t),r.acknowledge?.();let n=r.topic;for(let[,s]of this.awaitingAcks)if(s.topic===n&&s.timestamp<r.timestamp){for(let i of this.sessionRecord.subscriptions)if(i.topic===n){i.acks||(i.acks=[]),i.acks.push(r.timestamp),(0,Ua.trace)("Received ack",n,r.timestamp),this.sessionRecord.update();return}}for(let s of this.sessionRecord.subscriptions)s.topic===n&&(s.startTime=r.timestamp);this.sessionRecord.update()}async addSubscription(t,r){await this.resumeSubscription(t,r);let{qos:n,startTime:s}=t;return n>0&&!s&&this.saveSubscriptions(),t.qos}removeSubscription(t){let r=this.subscriptions.find(s=>s.topic===t),n=super.removeSubscription(t);return r.qos>0&&this.saveSubscriptions(),n}saveSubscriptions(){this.sessionRecord.subscriptions=this.subscriptions.map(t=>{let r=t.startTime;return r||(r=t.startTime=(0,mY.getNextMonotonicTime)()),(0,Ua.trace)("Added durable subscription",t.topic,r),{qos:t.qos,topic:t.topic,startTime:r}}),JI.put(this.sessionRecord)}}});var rw={};je(rw,{bypassAuth:()=>Wme,start:()=>jme});function Wme(){NY=!0}function jme({server:e,port:t,network:r,webSocket:n,securePort:s,requireAuthentication:i}){e.mqtt||(e.mqtt={requireAuthentication:i,sessions:new Set,events:new OY.EventEmitter},e.mqtt.events.on("error",()=>{}));let o=e.mqtt,c=[],l=r?.mtls;return n&&(c=e.ws((u,d,_,E)=>{if(d.headers.get("sec-websocket-protocol")!=="mqtt")return E(u,d,_);o.events.emit("connection",u),dr.debug?.("Received WebSocket connection for MQTT from",u._socket.remoteAddress);let{onMessage:f,onClose:h}=yY(u,T=>{u.send(T)},d,Promise.resolve(_).then(()=>d?.user),o);u.on("message",f),u.on("close",h),u.on("error",T=>{dr.info?.("WebSocket error",T)})},{...n})),(t||s)&&c.push(e.socket(async u=>{let d;if(o.events.emit("connection",u),dr.debug?.(`Received ${u.getCertificate?"SSL":"TCP"} connection for MQTT from ${u.remoteAddress}`),l){if(u.authorized)try{let f=l.user;if(f!==null){(f===void 0||f==="Common Name"||f==="CN")&&(f=u.getPeerCertificate().subject.CN);try{d=await e.getUser(f,null,null),(0,Td.get)(kr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&ET.notify?.({username:d?.username,status:kr.AUTH_AUDIT_STATUS.SUCCESS,type:kr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"MQTT mTLS",remote_address:u.remoteAddress})}catch(h){throw(0,Td.get)(kr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&ET.error?.({username:f,status:kr.AUTH_AUDIT_STATUS.FAILURE,type:kr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"mqtt",remote_address:u.remoteAddress}),h}}else dr.debug?.("MQTT mTLS authorized connection (mTLS did not authorize a user)","from",u.remoteAddress)}catch(f){o.events.emit("error",f,u),dr.error?.(f)}else if(l.required)return dr.info?.(`Unauthorized connection attempt, no authorized client certificate provided, error: ${u.authorizationError}`),u.end()}!d&&NY&&u.remoteAddress.includes("127.0.0.1")&&(d=await(0,bY.getSuperUser)(),dr.debug?.("Auto-authorizing local connection",d?.username));let{onMessage:_,onClose:E}=yY(u,f=>u.write(f),null,d,o);u.on("data",_),u.on("close",E),u.on("error",f=>{dr.info?.("Socket error",f)})},{port:t,securePort:s,mtls:l})),c}function yY(e,t,r,n,s){RY||(RY=!0,F_(_=>{fT>0&&_.push({metric:"mqtt-connections",connections:fT,byThread:!0})}));let i;fT++;let o,c={protocolVersion:4},l=(0,hT.parser)({protocolVersion:5});function u(_){l.parse(_)}a(u,"onMessage");function d(){fT--,i||(i=!0,o?.disconnect?.(),s.events.emit("disconnected",o,e),s.sessions.delete(o),qn(!1,"connection","mqtt","disconnect"),dr.debug?.("MQTT connection was closed",e.remoteAddress))}return a(d,"onClose"),l.on("packet",async _=>{n?.then&&(n=await n);let E=_.cmd;if(o)o.then&&await o;else if(E!=="connect"){dr.info?.("Received packet before connection was established, closing connection"),e?.destroy?e.destroy():e?.terminate();return}let f=_.topic,h=f?.indexOf("/",1),T=h>0?f.slice(0,h):f;pr(_.length,"bytes-received",T,g(_),"mqtt");try{switch(o?.receivedPacket?.(),E){case"connect":if(c.protocolVersion=_.protocolVersion,_.username)try{n=await it.getUser(_.username,_.password.toString(),r),(0,Td.get)(kr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGSUCCESSFUL)&&ET.notify?.({username:n?.username,status:kr.AUTH_AUDIT_STATUS.SUCCESS,type:kr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"MQTT",remote_address:e.remoteAddress})}catch(V){return(0,Td.get)(kr.CONFIG_PARAMS.LOGGING_AUDITAUTHEVENTS_LOGFAILED)&&ET.error?.({username:_.username,status:kr.AUTH_AUDIT_STATUS.FAILURE,type:kr.AUTH_AUDIT_TYPES.AUTHENTICATION,auth_strategy:"mqtt",remote_address:e.remoteAddress}),s.events.emit("auth-failed",_,e,V),qn(!1,"connection","mqtt","connect"),m({cmd:"connack",reasonCode:4,returnCode:134})}if(!n&&s.requireAuthentication)return s.events.emit("auth-failed",_,e),qn(!1,"connection","mqtt","connect"),m({cmd:"connack",reasonCode:4,returnCode:134});try{if(s.authorizeClient?.(_,n),_.will){let V=e.deserialize||(e.deserialize=bo(r?.headers.get?.("content-type")));_.will.data=_.will.payload?.length>0?V(_.will.payload):void 0,delete _.will.payload}o=gY({user:n,..._}),o=await o,o.socket=e,r&&(o.request=r),s.sessions.add(o)}catch(V){return dr.error?.(V),s.events.emit("auth-failed",_,e,V),qn(!1,"connection","mqtt","connect"),m({cmd:"connack",reasonCode:V.code||5,returnCode:V.code||128})}s.events.emit("connected",o,e),qn(!0,"connection","mqtt","connect"),m({cmd:"connack",sessionPresent:o.sessionWasPresent,reasonCode:0,returnCode:0}),o.setListener((V,ne,Q,de)=>{try{if(i)throw new Error("Session disconnected while trying to send message to",V);let j=V.indexOf("/",1),ae=j>0?V.slice(0,j):V;m({cmd:"publish",topic:V,payload:S(ne),messageId:Q||Math.floor(Math.random()*1e8),qos:de.qos},ae);let Oe=e._socket??e;return Oe.writableNeedDrain?new Promise(Ne=>Oe.once("drain",Ne)):!Oe.closed}catch(j){return dr.error?.(j),o?.disconnect(),s.sessions.delete(o),!1}}),o.sessionWasPresent&&await o.resume();break;case"subscribe":let y=[];for(let V of _.subscriptions){let ne;try{let Q=await o.addSubscription(V,V.qos>=1);ne=Q?Q.qos||0:c.protocolVersion<5?128:143}catch(Q){s.events.emit("error",Q,e,V,o),Q.statusCode?Q.statusCode===500?dr.warn?.(Q):dr.info?.(Q):dr.error?.(Q),ne=c.protocolVersion<5?128:Q.statusCode===403?135:Q.statusCode===404?143:128}y.push(ne)}await o.committed,m({cmd:"suback",granted:y,messageId:_.messageId});break;case"unsubscribe":{let V=[];for(let ne of _.unsubscriptions)V.push(o.removeSubscription(ne)?0:17);m({cmd:"unsuback",granted:V,messageId:_.messageId});break}case"pubrel":m({cmd:"pubcomp",messageId:_.messageId,reasonCode:0});return;case"publish":let I=_.qos===2?"pubrec":"puback",U=e.deserialize||(e.deserialize=bo(r?.headers.get?.("content-type"))),X=(_.payload?.length||0)>0?U(_.payload):void 0,Y;try{Y=await o.publish(_,X)}catch(V){s.events.emit("error",V,e,_,o),dr.warn?.(V),_.qos>0&&m({cmd:I,messageId:_.messageId,reasonCode:128},_.topic);break}_.qos>0&&m({cmd:I,messageId:_.messageId,reasonCode:Y===!1?144:0},_.topic);break;case"pubrec":m({cmd:"pubrel",messageId:_.messageId,reasonCode:0});break;case"pubcomp":case"puback":o.acknowledge(_.messageId);break;case"pingreq":m({cmd:"pingresp"});break;case"disconnect":i=!0,o?.disconnect(!0),s.events.emit("disconnected",o,e),s.sessions.delete(o),qn(!0,"connection","mqtt","disconnect"),dr.debug?.("Received disconnect command, closing MQTT session",e.remoteAddress),e.close?e.close():e.end();break}}catch(y){s.events.emit("error",y,e,_,o),dr.error?.(y),m({cmd:"disconnect"})}function m(y,I){let U=(0,hT.generate)(y,c);t(U),pr(U.length,"bytes-sent",I,g(y),"mqtt")}a(m,"sendPacket");function g(y){return y.qos>0?y.cmd+",qos="+y.qos:y.cmd}a(g,"packetMethodName");function S(y){return jc(y,r)}a(S,"serialize")}),l.on("error",_=>{dr.warn("MQTT parsing error, closing connection:",_.message),e?.destroy?e.destroy():e?.terminate()}),{onMessage:u,onClose:d}}var hT,bY,Td,kr,tw,OY,ET,dr,NY,RY,fT,IY=Ie(()=>{hT=require("mqtt-packet");AY();bY=L(xn());zc();Ni();qr();Td=L(se()),kr=L(M()),tw=L(Oc()),OY=require("events"),ET=(0,tw.loggerWithTag)("auth-event"),dr=(0,tw.loggerWithTag)("mqtt"),NY=(0,Td.get)(kr.CONFIG_PARAMS.AUTHENTICATION_AUTHORIZELOCAL)??process.env.DEV_MODE;a(Wme,"bypassAuth");a(jme,"start");fT=0;a(yY,"onSocket")});var Qf={};je(Qf,{component_errors:()=>Ad,getComponentName:()=>Zme,loadComponent:()=>ST,loadComponentDirectories:()=>UY,setErrorReporter:()=>Xme});function UY(e,t){t&&(sw=t),e&&(iw=e);let r=[];if((0,Nt.existsSync)(nw)){let s=(0,Nt.readdirSync)(nw,{withFileTypes:!0});for(let i of s){if(!i.isDirectory()&&!i.isSymbolicLink())continue;let o=i.name,c=(0,Ot.join)(nw,o);r.push(ST(c,sw,"hdb",!1))}}let n=process.env.RUN_HDB_APP;return n&&r.push(ST(n,sw,n,!1,null,!!process.env.DEV_MODE)),Promise.all(r).then(()=>{MY=!0})}function Xme(e){UE=e}async function ST(e,t,r,n,s,i){let o=(0,Nt.realpathSync)(e);if(pT.has(o))return pT.get(o);pT.set(o,!0),s&&(iw=s);try{let c;n&&(Ad=new Map);let l=(0,Ot.join)(e,n?"harperdb-config.yaml":"config.yaml");(0,Nt.existsSync)(l)?c=n?(0,TT.getConfigObj)():(0,CY.parseDocument)((0,Nt.readFileSync)(l,"utf8")).toJSON():c=ow;let u=(0,Ot.join)(e,"node_modules","harperdb");try{Sl.isMainThread&&(n||(0,Nt.existsSync)(u)&&(0,Nt.realpathSync)(yd.PACKAGE_ROOT)!==(0,Nt.realpathSync)(u))&&((0,Nt.rmSync)(u,{recursive:!0,force:!0}),(0,Nt.existsSync)((0,Ot.join)(e,"node_modules"))||(0,Nt.mkdirSync)((0,Ot.join)(e,"node_modules")),(0,Nt.symlinkSync)(yd.PACKAGE_ROOT,u,"dir"))}catch(E){gd.default.error("Error symlinking harperdb module",E)}let d=mT,_=n;for(let E in c){mT=E;let f=c[E];if(Ad.set(n?E:(0,Ot.basename)(e),!1),!f)continue;let h,T=f.package;try{if(T){let I=e,U;for(;!(0,Nt.existsSync)(U=(0,Ot.join)(I,"node_modules",E));)if(I=(0,Ot.dirname)(I),I.length<(0,LY.getHdbBasePath)().length){U=null;break}if(U)h=await ST(U,t,r,!1),_=!0;else throw new Error(`Unable to find package ${E}:${T}`)}else h=Jme[E];if(!h)continue;let m=a(I=>(I.origin=r,Et(I)),"ensureTable"),g=f.network||(f.port||f.securePort)&&f,S=g?.securePort||g?.https&&g.port,y=!g?.https&&g?.port;if(Sl.isMainThread&&(h=await h.startOnMainThread?.({server:it,ensureTable:m,port:y,securePort:S,resources:t,...f})||h,n&&g))for(let I of[y,S])try{if(+I&&!wY.includes(I)){let U=aw.get(yd.CONFIG_PARAMS.HTTP_SESSIONAFFINITY);U&&gd.default.warn("Session affinity is not recommended and may cause memory leaks"),(U||!US)&&(wY.push(I),$I(I,U))}}catch(U){console.error("Error listening on socket",I,U,E)}if(t.isWorker&&(h=await h.start?.({server:it,ensureTable:m,port:y,securePort:S,resources:t,...f})||h),iw.set(h,!0),(h.handleFile||h.handleDirectory||h.setupFile||h.setupDirectory)&&f.files!=null){if(f.files.includes(".."))throw(0,PY.handleHDBError)("Can not reference parent directories");let I=(0,Ot.join)(e,f.files).replace(/\\/g,"/"),U=I.indexOf("/*");if(U>-1&&f.files!==ow[E]?.files&&!(0,Nt.existsSync)(I.slice(0,U)))throw new Error(`The path '${I.slice(0,U)}' does not exist and cannot be used as the base of the resolved 'files' path value '${f.files}'`);let H=(0,Ot.basename)(e),X=f.path||"/";X=X.startsWith("/")?X:X.startsWith("./")?"/"+H+X.slice(2):X==="."?"/"+H:"/"+H+"/"+X;let Y,V,ne;if(f.root){let de=f.root;de.startsWith("/")&&(de=de.slice(1)),de.endsWith("/")&&(de=de.slice(0,-1)),de+="/",V=(0,Ot.join)(e,de)}else(ne=I.indexOf("/*"))>-1?(V=I.slice(0,ne+1),Y=(0,Ot.relative)(e,V)):f.files.indexOf("/")>-1&&(V=I.slice(0,I.lastIndexOf("/")+1),Y=(0,Ot.relative)(e,V));let Q=!1;if(Sl.isMainThread&&h.setupDirectory&&(Q=await h.setupDirectory?.(X,V,t)),t.isWorker&&h.handleDirectory&&(Q=await h.handleDirectory?.(X,V,t)),Q){_=!0;continue}for(let de of await(0,DY.default)(I,{onlyFiles:!1,objectMode:!0})){let{path:j,dirent:ae}=de;_=!0;let Oe=(0,Ot.relative)(e,j).replace(/\\/g,"/");if(Y)if(Oe.startsWith(Y))Oe=Oe.slice(Y.length+1);else throw new Error(`The root path '${f.root}' does not reference a valid part of the file path '${Oe}'.The root path should be used to indicate the relative path/part of the file path for determining the exported web path.`);let Ne=X+(X.endsWith("/")?"":"/")+Oe;try{if(ae.isFile()){let Me=await Qme(j);Sl.isMainThread&&await h.setupFile?.(Me,Ne,j,t),t.isWorker&&await h.handleFile?.(Me,Ne,j,t)}else Sl.isMainThread&&await h.setupDirectory?.(Ne,j,t),t.isWorker&&await h.handleDirectory?.(Ne,j,t)}catch(Me){Me.message=`Could not load ${ae.isFile()?"file":"directory"} '${j}'${f.module?" using '"+f.module+"'":""} for application '${e}' due to: ${Me.message}`,UE?.(Me),((0,Rd.getWorkerIndex)()===0?console:gd.default).error(Me),t.set(f.path||"/",new ea(Me)),Ad.set(n?E:(0,Ot.basename)(e),Me.message)}}}}catch(m){m.message=`Could not load component '${E}' for application '${(0,Ot.basename)(e)}' due to: ${m.message}`,UE?.(m),((0,Rd.getWorkerIndex)()===0?console:gd.default).error(m),t.set(f.path||"/",new ea(m),null,!0),Ad.set(n?E:(0,Ot.basename)(e),m.message)}}if(mT=d,Sl.isMainThread&&!MY&&i&&(0,Rd.watchDir)(e,async()=>UY()),c.extensionModule){let E=await bS((0,Ot.join)(e,c.extensionModule));return pT.set(o,E),E}if(!_&&t.isWorker){let E=`${e} did not load any modules, resources, or files, is this a valid component?`;UE?.(new Error(E)),((0,Rd.getWorkerIndex)()===0?console:gd.default).error(E),Ad.set((0,Ot.basename)(e),E)}}catch(c){console.error(`Could not load application directory ${e}`,c),c.message=`Could not load application due to ${c.message}`,UE?.(c),t.set("",new ea(c))}}var Nt,Ot,Sl,CY,aw,yd,DY,Rd,gd,PY,LY,zme,TT,Qme,nw,iw,MY,sw,Ad,Jme,ow,wY,pT,UE,mT,Zme,Jf=Ie(()=>{Nt=require("fs"),Ot=require("path"),Sl=require("worker_threads"),CY=require("yaml"),aw=L(se()),yd=L(M());ND();Z$();nV();aV();cV();RV();t1();a1();DY=L(require("fast-glob")),Rd=L(dt()),gd=L(W());bN();qr();PY=L(_e());Pe();wI();LY=L(se()),zme=L(aY());km();hY();us();IY();TT=L(wt());vS();fy();({readFile:Qme}=Nt.promises),nw=(0,TT.resolvePath)(aw.get(yd.CONFIG_PARAMS.COMPONENTSROOT)),iw=new Map,Ad=new Map;a(UY,"loadComponentDirectories");Jme={REST:CS,rest:CS,graphql:RN,graphqlSchema:Pg,roles:yN,jsResource:NN,fastifyRoutes:YN,login:wN,static:WN,operationsApi:zme,customFunctions:{},http:{},clustering:QI,replication:ca,authentication:Hf,mqtt:rw},ow={rest:!0,graphql:!0,graphqlSchema:{files:"*.graphql"},roles:{files:"roles.yaml"},jsResource:{files:"resources.js"},fastifyRoutes:{files:"routes/*.js",path:"."}};Object.defineProperty(ow,"static",{value:{files:"web/**"}});wY=[],pT=new Map;a(Xme,"setErrorReporter");Zme=a(()=>mT,"getComponentName");a(ST,"loadComponent")});var nT=N((mMe,BY)=>{var{isMainThread:vY}=require("worker_threads"),{getTables:eSe,getDatabases:hMe,table:pMe}=(Pe(),oe(lt)),{loadComponentDirectories:tSe,loadComponent:rSe}=(Jf(),oe(Qf)),{resetResources:nSe}=(su(),oe(sB)),sSe=SO(),iSe=wt(),{dirname:oSe}=require("path"),{getConnection:aSe}=mr(),cSe=se(),{CONFIG_PARAMS:lSe}=M(),{loadCertificates:uSe}=Xs(),cw=new Map;async function dSe(e=!1){!vY&&cSe.get(lSe.CLUSTERING_ENABLED)&&aSe();try{vY&&await sSe()}catch(n){console.error(n)}let t=nSe();eSe(),t.isWorker=e,await uSe(),await rSe(oSe(iSe.getConfigFilePath()),t,"hdb",!0,cw),await tSe(cw,t);let r=[];for(let[n]of cw)n.ready&&r.push(n.ready());r.length>0&&await Promise.all(r)}a(dSe,"loadRootComponents");BY.exports.loadRootComponents=dSe});var dt=N((TMe,ai)=>{"use strict";var{Worker:_Se,MessageChannel:fSe,parentPort:Vi,isMainThread:fw,threadId:ESe,workerData:Ki}=require("worker_threads"),{PACKAGE_ROOT:hSe}=M(),{join:FY,isAbsolute:pSe,extname:mSe}=require("path"),{server:GY}=(qr(),oe(Ja)),{watch:SSe,readdir:TSe}=require("fs/promises"),{totalmem:HY}=require("os"),vE=M(),qY=se(),Yi=W(),{randomBytes:gSe}=require("crypto"),{_assignPackageExport:ASe}=fi(),RSe=M(),xY=1024*1024,va=[],Ps=[],ySe=50,Ew=1e4,bSe="restart",$Y="request_thread_info",VY="resource_report",KY="thread_info",YY="added-port",OSe="ack",lw;ASe("threads",Ps);ai.exports={startWorker:uw,restartWorkers:pw,shutdownWorkers:DSe,workers:va,setMonitorListener:xSe,onMessageFromWorkers:PSe,onMessageByType:ZY,broadcast:MSe,broadcastWithAcknowledgement:vSe,setChildListenerByType:CSe,getWorkerIndex:WY,getWorkerCount:jY,getTicketKeys:QY,setMainIsWorker:ISe,setTerminateTimeout:NSe,restartNumber:Ki?.restartNumber||1};Ps.onMessageByType=ZY;Ps.sendToThread=function(e,t){if(!t?.type)throw new Error("A message with a type must be provided");let r=Ps.find(n=>n.threadId===e);if(r)return r.postMessage(t),!0};ai.exports.whenThreadsStarted=new Promise(e=>{ai.exports.threadsHaveStarted=e});var hw;function NSe(e){Ew=e}a(NSe,"setTerminateTimeout");function WY(){return Ki?Ki.workerIndex:hw?0:void 0}a(WY,"getWorkerIndex");function jY(){return Ki?Ki.workerCount:hw?1:void 0}a(jY,"getWorkerCount");function ISe(e){hw=e,ai.exports.threadsHaveStarted()}a(ISe,"setMainIsWorker");var zY=1,gT;function QY(){return gT||(gT=fw?gSe(48):Ki.ticketKeys,gT)}a(QY,"getTicketKeys");Object.defineProperty(GY,"workerIndex",{get(){return WY()}});Object.defineProperty(GY,"workerCount",{get(){return jY()}});var JY={[$Y](e,t){BSe(t)},[VY](e,t){HSe(t,e)}};function uw(e,t={}){let r=process.constrainedMemory?.()||HY();r=Math.min(r,HY(),2e4*xY);let n=qY.get(vE.CONFIG_PARAMS.THREADS_MAXHEAPMEMORY)??Math.max(Math.floor(r/xY/(10+(t.threadCount||1)/4)),512),s=Math.min(Math.max(n>>6,16),64),i=[],o=[];for(let l of Ps){let u=new fSe;u.existingPort=l,i.push(u),o.push(u.port2)}mSe(e)||(e+=".js");let c=new _Se(pSe(e)?e:FY(hSe,e),{resourceLimits:{maxOldGenerationSizeMb:n,maxYoungGenerationSizeMb:s},execArgv:["--enable-source-maps"],argv:process.argv.slice(2),workerData:{addPorts:o,addThreadIds:i.map(l=>l.existingPort.threadId),workerIndex:t.workerIndex,workerCount:zY=t.threadCount,name:t.name,restartNumber:ai.exports.restartNumber,ticketKeys:QY()},transferList:o,...t});for(let{port1:l,existingPort:u}of i)u.postMessage({type:YY,port:l,threadId:c.threadId},[l]);return RT(c,!0),c.unexpectedRestarts=t.unexpectedRestarts||0,c.startCopy=()=>uw(e,t),c.on("error",l=>{Yi.error(`Worker index ${t.workerIndex} error:`,l)}),c.on("exit",l=>{va.splice(va.indexOf(c),1),!c.wasShutdown&&t.autoRestart!==!1&&(c.unexpectedRestarts<ySe?(t.unexpectedRestarts=c.unexpectedRestarts+1,uw(e,t)):Yi.error(`Thread has been restarted ${c.restarts} times and will not be restarted`))}),c.on("message",l=>{JY[l.type]?.(l,c)}),va.push(c),FSe(),t.onStarted&&t.onStarted(c),c.name=t.name,c}a(uw,"startWorker");var wSe=[vE.THREAD_TYPES.HTTP];async function pw(e=null,t=Math.max(zY>3,1),r=!0){if(fw){if(r){let{loadRootComponents:o}=nT();await o()}ai.exports.restartNumber++,t<1&&(t=t*va.length);let n=[],s=[];for(let o of va.slice(0)){if(e&&o.name!==e||o.wasShutdown)continue;Yi.trace("sending shutdown request to ",o.threadId),o.postMessage({restartNumber:ai.exports.restartNumber,type:vE.ITC_EVENT_TYPES.SHUTDOWN}),o.wasShutdown=!0,o.emit("shutdown",{});let c=wSe.indexOf(o.name)>-1,l=new Promise(u=>{let d=setTimeout(()=>{Yi.warn("Thread did not voluntarily terminate, terminating from the outside",o.threadId),o.terminate()},Ew*2).unref();o.on("exit",()=>{clearTimeout(d),n.splice(n.indexOf(l)),!c&&r&&o.startCopy(),u()})});if(n.push(l),c&&r){let u=o.startCopy(),d=new Promise(_=>{let E=a(f=>{f.type===RSe.ITC_EVENT_TYPES.CHILD_STARTED&&(Yi.trace("Worker has started",u.threadId),_(),s.splice(s.indexOf(d)),u.off("message",E))},"startListener");Yi.trace("Waiting for worker to start",u.threadId),u.on("message",E)});s.push(d),n.length>=t&&await Promise.race(n),s.length>=t&&await Promise.race(s)}}await Promise.all(n),await Promise.all(s);let{restartService:i}=qu();r&&(e==="http"||!e)&&qY.get(vE.CONFIG_PARAMS.CLUSTERING_ENABLED)&&await i({service:"clustering"})}else Vi.postMessage({type:bSe,workerType:e})}a(pw,"restartWorkers");function CSe(e,t){JY[e]=t}a(CSe,"setChildListenerByType");function DSe(e){return pw(e,1/0,!1)}a(DSe,"shutdownWorkers");var XY=[];function PSe(e){XY.push(e)}a(PSe,"onMessageFromWorkers");var dw=new Map;function ZY(e,t){let r=dw.get(e);r||dw.set(e,r=[]),r.push(t)}a(ZY,"onMessageByType");var LSe=10;async function MSe(e,t){let r=0;for(let n of Ps)try{n.postMessage(e),r++>LSe&&(r=0,await new Promise(setImmediate))}catch(s){Yi.error("Unable to send message to worker",s)}t&&tW(e,null)}a(MSe,"broadcast");var AT=new Map,USe=1;function vSe(e){return new Promise(t=>{let r=0;for(let n of Ps)try{let s=USe++,i=a(()=>{AT.delete(s),--r===0&&t(),n!==Vi&&--n.refCount===0&&n.unref()},"ack_handler");i.port=n,n.ref(),n.refCount=(n.refCount||0)+1,AT.set(e.requestId=s,i),n.hasAckCloseListener||(n.hasAckCloseListener=!0,n.on(n.close?"close":"exit",()=>{for(let[,o]of AT)o.port===n&&o()})),n.postMessage(e),r++}catch(s){Yi.error("Unable to send message to worker",s)}r===0&&t()})}a(vSe,"broadcastWithAcknowledgement");function BSe(e){e.postMessage({type:KY,workers:eW()})}a(BSe,"sendThreadInfo");function eW(){let e=Date.now();return va.map(t=>({threadId:t.threadId,name:t.name,heapTotal:t.resources?.heapTotal,heapUsed:t.resources?.heapUsed,externalMemory:t.resources?.external,arrayBuffers:t.resources?.arrayBuffers,sinceLastUpdate:e-t.resources?.updated,...t.recentELU}))}a(eW,"getChildWorkerInfo");function HSe(e,t){e.resources=t,e.resources.updated=Date.now()}a(HSe,"recordResourceReport");var _w;function xSe(e){_w=e}a(xSe,"setMonitorListener");var kSe=1e3,kY=!1;function FSe(){kY||(kY=!0,setInterval(()=>{for(let e of va){let t=e.performance.eventLoopUtilization(),r;e.lastTotalELU?r=e.performance.eventLoopUtilization(t,e.lastTotalELU):r=t,e.lastTotalELU=t,e.recentELU=r}_w&&_w()},kSe).unref())}a(FSe,"startMonitoring");var GSe=1e3;if(Vi&&Ki?.addPorts){RT(Vi);for(let e=0,t=Ki.addPorts.length;e<t;e++){let r=Ki.addPorts[e];r.threadId=Ki.addThreadIds[e],RT(r)}setInterval(()=>{let e=process.memoryUsage();Vi.postMessage({type:VY,heapTotal:e.heapTotal,heapUsed:e.heapUsed,external:e.external,arrayBuffers:e.arrayBuffers})},GSe).unref(),lw=a(()=>new Promise((e,t)=>{Vi.on("message",r),Vi.postMessage({type:$Y});function r(n){n.type===KY&&(Vi.off("message",r),e(n.workers))}a(r,"receiveThreadInfo")}),"getThreadInfo")}else lw=eW;ai.exports.getThreadInfo=lw;function RT(e,t){Ps.push(e),e.on("message",r=>{if(r.type===YY)r.port.threadId=r.threadId,RT(r.port);else if(r.type===OSe){let n=AT.get(r.id);n&&n()}else tW(r,e)}).on("close",()=>{Ps.splice(Ps.indexOf(e),1)}).on("exit",()=>{Ps.splice(Ps.indexOf(e),1)}),t?e.refCount=100:e.unref()}a(RT,"addPort");function tW(e,t){for(let n of XY)n(e,t);let r=dw.get(e.type);if(r)for(let n of r)try{n(e,t)}catch(s){Yi.error(s)}}a(tW,"notifyMessageListeners");if(fw){let e,t,r=new Set,n=a(async(s,i)=>{i&&(e=i);for(let o of await TSe(s,{withFileTypes:!0}))o.isDirectory()&&o.name!=="node_modules"&&n(FY(s,o.name));try{for await(let{filename:o}of SSe(s,{persistent:!1}))r.add(o),t&&clearTimeout(t),t=setTimeout(async()=>{e&&await e(),await pw(),console.log("Reloaded HarperDB components, changed files:",Array.from(r)),r.clear()},100)}catch(o){console.warn("Error trying to watch component directory",s,o)}},"watch_dir");ai.exports.watchDir=n,process.env.WATCH_DIR&&n(process.env.WATCH_DIR)}else Vi.on("message",async e=>{let{type:t}=e;t===vE.ITC_EVENT_TYPES.SHUTDOWN&&(ai.exports.restartNumber=e.restartNumber,Vi.unref(),setTimeout(()=>{Yi.warn("Thread did not voluntarily terminate",ESe),process.exit(0)},Ew).unref())})});var uv={};je(uv,{AUDIT_STORE_OPTIONS:()=>Pf,Decoder:()=>Pc,HAS_CURRENT_RESIDENCY_ID:()=>rc,HAS_EXPIRATION_EXTENDED_TYPE:()=>a_,HAS_ORIGINATING_OPERATION:()=>o_,HAS_PREVIOUS_RESIDENCY_ID:()=>nc,REMOTE_SEQUENCE_UPDATE:()=>Kp,createAuditEntry:()=>Ul,getLastRemoved:()=>Yy,openAuditStore:()=>IT,readAuditEntry:()=>xt,removeAuditEntry:()=>wT,setAuditRetention:()=>$Se,transactionKeyEncoder:()=>dW});function IT(e){let t=e.auditStore=e.openDB(mw.AUDIT_STORE_NAME,{create:!1,...Pf});t||(t=e.auditStore=e.openDB(mw.AUDIT_STORE_NAME,Pf),nW(t,1)),t.rootStore=e;let r=[];t.addDeleteRemovalCallback=function(i,o){return r[i]=o,t.deleteCallbacks=r,{remove(){delete r[i]}}};let n=null;function s(i=yT){clearTimeout(n),n=setTimeout(async()=>{if(t.rootStore.status==="closed"||t.rootStore.status==="closing")return;let o=0,c,l;try{for(let{key:u,value:d}of t.getRange({start:1,snapshot:!1,end:Date.now()-Sw}))if(c=wT(t,u,d),l=u,await new Promise(setImmediate),++o>=qSe){i=10;break}await c}finally{o===0?i=Math.min(i<<1,Sw/10):nW(t,l),s(i)}},i).unref()}if(a(s,"scheduleAuditCleanup"),t.scheduleAuditCleanup=s,(0,HE.getWorkerIndex)()===(0,HE.getWorkerCount)()-1&&s(yT),(0,HE.getWorkerIndex)()===0&&!rW)for(let i of t.getKeys({reverse:!0,limit:1}))i>Date.now()&&(rW=!0,NT.error("The current time is before the last recorded entry in the audit log. Time reversal can undermine the integrity of data tracking and certificate validation and the time must be corrected."));return t}function wT(e,t,r){if((VSe(r)&15)===Tw){let n=xt(r),s=n.tableId;e.deleteCallbacks?.[s]?.(n.recordId)}return e.remove(t)}function nW(e,t){gw[0]=t,e.put(Symbol.for("last-removed"),_W)}function Yy(e){let t=e.get(Symbol.for("last-removed"));if(t)return _W.set(t),gw[0]}function $Se(e,t=yT){Sw=e,yT=t}function Ul(e,t,r,n,s,i,o,c,l,u,d,_,E){let f=fW[o];if(!f)throw new Error(`Invalid audit entry type ${o}`);let h=1;if(n&&(n>1?Ba.setFloat64(0,n):Ls.set(jg),h=9),l){if(l&16761087)throw new Error("Illegal extended type");h++}g(s),g(t),m(r),Ba.setFloat64(h,e),h+=8,l&rc&&g(u),l&nc&&g(d),l&a_&&(Ba.setFloat64(h,_),h+=8),l&o_&&g(EW[E]),i?m(i):Ls[h++]=0,l?Ba.setUint16(n?8:0,f|l|32768):Ls[n?8:0]=f;let T=Ls.subarray(0,h);if(c)return Buffer.concat([T,c]);return T;function m(S){let y=h;h+=1,h=(0,Tl.writeKey)(S,Ls,h);let I=h-y-1;I>127?I>16383?(NT.error("Key or username was too large for audit entry",S),h=y+1,Ls[y]=0):(Ls.copyWithin(y+2,y+1,h),Ba.setUint16(y,I|32768),h++):Ls[y]=I}function g(S){S<128?Ls[h++]=S:S<16384?(Ba.setUint16(h,S|32768),h+=2):S<1056964608?(Ba.setUint32(h,S|3221225472),h+=4):(Ls[h]=255,Ba.setUint32(h+1,S),h+=5)}}function VSe(e){let t=0;e[0]==66&&(t=8);let r=e[t];if(r<128)return r;let n=e.dataView||(e.dataView=new Pc(e.buffer,e.byteOffset,e.byteLength));return n.position=t,n.readInt()}function xt(e,t=0,r=void 0){try{let n=e.dataView||(e.dataView=new Pc(e.buffer,e.byteOffset,e.byteLength));n.position=t;let s;e[n.position]==66&&(s=n.readFloat64());let i=n.readInt(),o=n.readInt(),c=n.readInt(),l=n.readInt(),u=n.position,d=n.position+=l,_=n.readFloat64(),E,f,h,T;if(i&rc&&(E=n.readInt()),i&nc&&(f=n.readInt()),i&a_&&(h=n.readFloat64()),i&o_){let S=n.readInt();T=EW[S]}l=n.readInt();let m=n.position,g=n.position+=l;return{type:fW[i&7],tableId:c,nodeId:o,get recordId(){return(0,Tl.readKey)(e,u,d)},getBinaryRecordId(){return e.subarray(u,d)},version:_,previousLocalTime:s,get user(){return g>m?(0,Tl.readKey)(e,m,g):void 0},get encoded(){return t?e.subarray(t,r):e},getValue(S,y,I){if(i&bT||i&BE&&!y)return S.decoder.decode(e.subarray(n.position,r));if(i&BE&&I)return Aw(S.getEntry(this.recordId),I,S)},getBinaryValue(){return i&(bT|BE)?e.subarray(n.position,r):void 0},extendedType:i,residencyId:E,previousResidencyId:f,expiresAt:h,originatingOperation:T}}catch(n){return NT.error("Reading audit entry error",n,e),{}}}var Tl,OT,mw,lW,HE,uW,NT,Ls,Ba,dW,Pf,Sw,qSe,gw,_W,yT,rW,bT,BE,sW,Tw,iW,oW,aW,cW,Kp,rc,nc,o_,a_,fW,EW,Pc,Ji=Ie(()=>{Tl=require("ordered-binary"),OT=L(se()),mw=L(Ht()),lW=L(M()),HE=L(dt()),uW=L(te());vl();NT=L(W());CT();(0,OT.initSync)();Ls=Buffer.alloc(2816),Ba=new DataView(Ls.buffer,Ls.byteOffset,2816),dW={writeKey(e,t,r){return e===i_?(t.set(i_,r),r+8):typeof e=="number"?((t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).setFloat64(r,e),r+8):(0,Tl.writeKey)(e,t,r)},readKey(e,t,r){return e[t]===66?(e.dataView||(e.dataView=new DataView(e.buffer,e.byteOffset,e.byteLength))).getFloat64(t):(0,Tl.readKey)(e,t,r)}},Pf={encoding:"binary",keyEncoder:dW},Sw=(0,uW.convertToMS)((0,OT.get)(lW.CONFIG_PARAMS.LOGGING_AUDITRETENTION))||86400*3,qSe=1e3,gw=new Float64Array(1),_W=new Uint8Array(gw.buffer),yT=1e4,rW=!1;a(IT,"openAuditStore");a(wT,"removeAuditEntry");a(nW,"updateLastRemoved");a(Yy,"getLastRemoved");a($Se,"setAuditRetention");bT=16,BE=32,sW=1,Tw=2,iW=3,oW=4,aW=5,cW=6,Kp=11,rc=512,nc=1024,o_=2048,a_=4096,fW={put:sW|bT,[sW]:"put",delete:Tw,[Tw]:"delete",message:iW|bT,[iW]:"message",invalidate:oW|BE,[oW]:"invalidate",patch:aW|BE,[aW]:"patch",relocate:cW,[cW]:"relocate"},EW={insert:1,update:2,upsert:3,1:"insert",2:"update",3:"upsert"};a(Ul,"createAuditEntry");a(VSe,"readAction");a(xt,"readAuditEntry");Pc=class extends DataView{static{a(this,"Decoder")}position=0;readInt(){let t;return t=this.getUint8(this.position++),t>=128?t>=192?t===255?(t=this.getUint32(this.position),this.position+=4,t):(t=this.getUint32(this.position-1)&1073741823,this.position+=3,t):(t=this.getUint16(this.position-1)&32767,this.position++,t):t}readFloat64(){try{let t=this.getFloat64(this.position);return this.position+=8,t}catch(t){throw t.message=`Error reading float64: ${t.message} at position ${this.position}`,t}}}});var Rw={};je(Rw,{add:()=>DT,applyReverse:()=>hW,getRecordAtTime:()=>Aw,rebuildUpdateBefore:()=>PT});function DT(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n+BigInt(r.value):isNaN(e[t])?e[t]=r.value:e[t]=n+r.value}function PT(e,t,r){let n=null;for(let s in e)if(s in t){let i=t[s];if(i?.__op__){let o=e[s];if(o?.__op__)if(o.__op__===i.__op__)n||(n={}),n[s]=o;else throw new Error("Can not merge updates with different operations");else n||(n={}),n[s]=o,DT(n,s,i)}else r&&(n||(n={}),n[s]=i)}else n||(n={}),n[s]=e[s];return n}function hW(e,t){for(let r in t){let n=t[r];if(n?.__op__){let s=KSe[n.__op__]?.reverse;if(s)s(e,r,{value:n.value});else throw new Error(`Unsupported operation ${n.__op__}`)}else e[r]=pW}}function Aw(e,t,r){let n=r.rootStore.auditStore,s={...e.value},i=e.localTime;for(;i>t;){let l=n.get(i),u=xt(l);switch(u.type){case"put":s=u.getValue(r);break;case"patch":hW(s,u.getValue(r));break;case"delete":s=null}i=u.previousLocalTime}let o={},c=0;for(let l in s)s[l]===pW&&(o[l]=!0,c++);for(;c>0&&i>0;){let l=n.get(i),u=xt(l),d;switch(u.type){case"put":d=u.getValue(r);break;case"patch":d=u.getValue(r);break}for(let _ in d)o[_]&&(s[_]=d[_],o[_]=!1,c--);i=u.previousLocalTime}if(c>0)for(let l in o)s[l]=null;return s}var KSe,pW,CT=Ie(()=>{Ji();a(DT,"add");DT.reverse=function(e,t,r){let n=e[t];typeof n=="bigint"?e[t]=n-BigInt(r.value):isNaN(e[t])||(e[t]=n-r.value)};KSe={add:DT};a(PT,"rebuildUpdateBefore");a(hW,"applyReverse");pW={};a(Aw,"getRecordAtTime")});function Zn(e){return e[_r]||(e[_r]=Object.create(null))}function BT(e,t){let r=e.prototype,n={},s=t.attributes||t.properties||[];for(let o of s){let c=o.name,l,u;if(o.resolve)u={get(){return o.resolve(this,this[Fe])},set(d){return o.set(this,d)},configurable:!0};else{switch(o.type){case"String":l=a(function(d){if(!(typeof d=="string"||d==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a string, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"ID":l=a(function(d){if(!(typeof d=="string"||d?.length>0&&d.every?.(_=>typeof _=="string")||d==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a string, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"Float":case"Number":l=a(function(d){let _=d?.__op__?d.value:d;if(!(typeof _=="number"||d==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a number, attempt to assign ${_}`);Zn(this)[c]=d},"set");break;case"Int":l=a(function(d){let _=d?.__op__?d.value:d;if(!(_>>0===_||d==null&&o.nullable!==!1))if(typeof _=="number"&&Math.abs((_>>0)-_)<=1)_=Math.round(_),d?.__op__?d.value=_:d=_;else throw new Ms.ClientError(`${c} must be an integer between -2147483648 and 2147483647, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"Long":l=a(function(d){let _=d?.__op__?d.value:d;if(!(Math.round(_)===d&&Math.abs(_)<=9007199254740992||d==null&&o.nullable!==!1))if(typeof _=="number"&&Math.abs(_)<=9007199254740992)_=Math.round(_),d?.__op__?d.value=_:d=_;else throw new Ms.ClientError(`${c} must be an integer between -9007199254740992 and 9007199254740992, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"BigInt":l=a(function(d){let _=d?.__op__?d.value:d;if(!(typeof _=="bigint"||d==null&&o.nullable!==!1))if(typeof _=="string"||typeof _=="number")_=BigInt(_),d?.__op__?d.value=_:d=_;else throw new Ms.ClientError(`${c} must be a number, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"Boolean":l=a(function(d){if(!(typeof d=="boolean"||d==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a boolean, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"Date":l=a(function(d){if(!(d instanceof Date||d==null&&o.nullable!==!1))if(typeof d=="string"||typeof d=="number")d=new Date(d);else throw new Ms.ClientError(`${c} must be a Date, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"Bytes":l=a(function(d){if(!(d instanceof Uint8Array||d==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be a Buffer or Uint8Array, attempt to assign ${d}`);Zn(this)[c]=d},"set");break;case"Any":case void 0:l=a(function(d){Zn(this)[c]=d},"set");break;default:l=a(function(d){if(!(typeof d=="object"||d==null&&o.nullable!==!1))throw new Ms.ClientError(`${c} must be an object, attempt to assign ${d}`);Zn(this)[c]=d},"set")}u={get(){let d=this[_r];if(d&&c in d){let E=d[c];if(E?.__op__){let f=this[ve]?.[c];return E.update(f)}return E}let _=this[ve]?.[c];if(_&&typeof _=="object"){let E=SW(_,o);if(E)return d||(d=this[_r]=Object.create(null)),d[c]=E}return _},set:l,enumerable:!0,configurable:!0}}u.get.isAttribute=!0,n[c]=u,(!(c in r)||Object.getOwnPropertyDescriptor(r,c)?.get?.isAttribute)&&Object.defineProperty(r,c,u)}i("getProperty",function(o){let c=n[o];if(c)return c.get.call(this);let l=this[_r];return l?.[o]!==void 0?l[o]:this[ve]?.[o]}),i("set",function(o,c){let l=n[o];if(l)return l.set.call(this,c);if(t.sealed)throw new Ms.ClientError("Can not add a property to a sealed table schema");Zn(this)[o]=c}),i("deleteProperty",function(o){Zn(this)[o]=void 0}),i("toJSON",function(){let o=this[_r],c;for(let u in o){c||(c={...this[ve]});let d=o[u];if(d?.__op__){let _=c[u];d=d.update(_)}c[u]=d}return Object.keys(this).length>0&&(c||(c={...this[ve]}),Object.assign(c,this)),c||this[ve]}),r.get||i("get",r.getProperty),r.delete||i("delete",r.deleteProperty);function i(o,c){Object.defineProperty(r,o,{value:c,configurable:!0})}a(i,"setMethod")}function SW(e,t){let r;switch(e.constructor){case Object:return t?((r=t.TrackedObject)||(t.TrackedObject=r=class{static{a(this,"TrackedObject")}constructor(s){if(s?.[ve])throw new Error("Can not track an already tracked object, check for circular references");this[ve]=s}},BT(r,t)),new r(e)):new LT(e);case Array:let n=new UT(e.length);n[ve]=e;for(let s=0,i=e.length;s<i;s++){let o=e[s];o&&typeof o=="object"&&(o=SW(o,t?.elements)),n[s]=o}return n;default:return e}}function dp(e){let t=e[_r],r;for(let s in t){r||(r={...e[ve]});let i=t[s];if(i&&typeof i=="object")if(i.__op__){let o=r[s];i=i.update(o)}else i=dp(i);r[s]=i}return Object.keys(e).length>0&&(r||(r={...e[ve]}),Object.assign(r,e)),r||e[ve]}function Al(e,t=e[_r]){let r;if(mW.call(e,ve)&&e.constructor===Array&&!Object.isFrozen(e)){r=e;for(let n=0,s=e.length;n<s;n++){let i=e[n];if(i&&typeof i=="object"){let o=Al(i);o!==i&&r===e&&(r=e.slice(0)),i=o}r[n]=i}return Object.freeze(r)}for(let n in t){r||(r={...e[ve]});let s=t[n];if(s&&typeof s=="object")if(s.__op__){let i=Rw[s?.__op__];if(i)i(r,n,s);else throw new Error("Invalid CRDT operation "+s.__op__);continue}else s=Al(s);r[n]=s}return r?Object.freeze(r):mW.call(e,ve)?e[ve]:e}function MT(e){let t=e[ve];if(t===void 0)return!0;if(e.constructor===Array){if(!t||e[gl]||e.length!==t.length)return!0;for(let r=0,n=e.length;r<n;r++){let s=t[r],i=e[r];if(s&&i?.[ve]===s){if(MT(i))return!0}else return!0}}else{let r=e[_r];if(r&&!t)return!0;for(let n in r){let s=r[n];if(s&&typeof s=="object"){let i=t[n];if(i&&s[ve]===i){if(MT(s))return!0}else return!0}else return!0}}return!1}var Ms,_r,LT,mW,gl,UT,vT,_p=Ie(()=>{Vs();Ms=L(_e());CT();_r=Symbol("own-data");a(Zn,"getChanges");a(BT,"assignTrackedAccessors");a(SW,"trackObject");LT=class{static{a(this,"GenericTrackedObject")}constructor(t){if(t?.[ve])throw new Error("Can not track an already tracked object, check for circular references");this[ve]=t}};BT(LT,{});a(dp,"collapseData");mW=Object.prototype.hasOwnProperty;a(Al,"updateAndFreeze");a(MT,"hasChanges");gl=Symbol.for("has-array-changes"),UT=class extends Array{static{a(this,"TrackedArray")}[gl];constructor(t){super(t)}splice(...t){return this[gl]=!0,super.splice(...t)}push(...t){return this[gl]=!0,super.push(...t)}pop(){return this[gl]=!0,super.pop()}unshift(...t){return this[gl]=!0,super.unshift(...t)}shift(){return this[gl]=!0,super.shift()}};UT.prototype.constructor=Array;vT=class{constructor(t){this.value=t}static{a(this,"Addition")}__op__="add";update(t){return(+t||0)+this.value}}});var _R={};je(_R,{CONTEXT:()=>Fe,ID_PROPERTY:()=>ze,IS_COLLECTION:()=>ci,MultiPartId:()=>xT,RECORD_PROPERTY:()=>ve,Resource:()=>Lr,snake_case:()=>WSe,transformForSelect:()=>kT});function WSe(e){return e[0].toLowerCase()+e.slice(1).replace(/[a-z][A-Z][a-z]/g,t=>t[0]+"_"+t.slice(1))}function TW(e,t){if(Rl=!1,e==="")return null;if(e=e.slice(1),t.splitSegments){if(e.indexOf("/")===-1)return e===""?(Rl=!0,null):t.coerceId(decodeURIComponent(e));let r=e.split("/"),n=new xT;for(let s=0;s<r.length;s++){let i=r[s];if(!i&&s===r.length-1){Rl=!0;break}n[s]=t.coerceId(decodeURIComponent(i))}return n}else{if(e==="")return Rl=!0,null;e[e.length-1]==="/"&&(Rl=!0)}return t.coerceId(decodeURIComponent(e))}function es(e,t){n.reliesOnPrototype=!0;let r=t.hasContent;return n;function n(s,i,o){let c,l,u,d;if(r?(o?(d=i,o=o[Fe]||o):i?typeof s=="object"&&s&&(!Array.isArray(s)||typeof s[0]=="object")?(d=s,c=d[this.primaryKey]??null,o=i[Fe]||i):d=i:(d=s,s=void 0,c=d[ze]??d[this.primaryKey]),c===null&&(u=!0)):i?o=i[Fe]||i:s&&typeof s=="object"&&!Array.isArray(s)&&(o=s),c===void 0)if(typeof s=="object"&&s){if(l=s,typeof(c=s.url)=="string"){let f=c.indexOf("?");if(f>-1){let T=this.parseQuery(c.slice(f+1));l?T&&(l=Object.assign(T,l)):l=T,c=c.slice(0,f)}let h=this.parsePath(c,o,l);h?.id!==void 0?(h.query&&(l?l=Object.assign(h.query,l):l=h.query),u=h.isCollection,c=h.id):c=h}else if(s[Symbol.iterator]){c=[],u=!0;for(let f of s){if(typeof f=="object"&&f)break;c.push(f)}c.length===0?c=null:(c.length===1&&(c=c[0]),l.slice&&(l=l.slice(c.length,l.length),l.length===0&&(l=null,u=!1)))}c===void 0&&(c=s.id??null,c==null&&(u=!0))}else c=s,l=new ol(c),c==null&&(u=!0);o||(o={});let _;if(l?.ensureLoaded!=null||l?.async||u?(_={...t},l?.ensureLoaded!=null&&(_.ensureLoaded=l.ensureLoaded),l?.async&&(_.async=l.async),u&&(_.isCollection=!0)):_=t,o.transaction){let f=this.getResource(c,o,_);return f.then?f.then(E):E(f)}else return Dt(o,()=>{let f=this.getResource(c,o,_);return f.then?f.then(E):E(f)},_);function E(f){if(o.authorize){o.authorize=!1;let h=t.type==="read"?f.allowRead(o.user,l,o):t.type==="update"?f.doesExist?.()===!1?f.allowCreate(o.user,d,o):f.allowUpdate(o.user,d,o):t.type==="create"?f.allowCreate(o.user,d,o):f.allowDelete(o.user,l,o);if(h?.then)return h.then(T=>{if(!T)throw new HT(o.user);return typeof d?.then=="function"?d.then(m=>e(f,l,o,m)):e(f,l,o,d)});if(!h)throw new HT(o.user)}return typeof d?.then=="function"?d.then(h=>e(f,l,o,h)):e(f,l,o,d)}a(E,"authorizeActionOnResource")}}function ts(e,t){let r=new RW.ClientError(`The ${e.constructor.name} does not have a ${t} method implemented`,405);r.allow=[],r.method=t;for(let n of["get","put","post","delete","query","move","copy"])typeof e[n]=="function"&&r.allow.push(n);throw r}function yw(e,t,r){let n=e[ve];if(n){let s=e[_r];return i=>{let o,c;return e.hasOwnProperty(i)&&typeof(o=e[i])!="function"?o:s&&i in s?s[i]:(c=t?.[i])?c(e,r):n[i]}}else return t?s=>{let i=t[s];return i?i(e,r):e[s]}:s=>e[s]}function kT(e,t){let r=t?.propertyResolvers,n=t[Fe],s;if(typeof e=="string")return a(function o(c){return c.then?c.then(o):Array.isArray(c)?c.map(o):yw(c,r,n)(e)},"transform");if(typeof e=="object"){if(e.asArray)return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(c);let u=[],d=i(yw(l,r,n));for(let _ of e)u.push(d(_));return u},"transform");let o=e.forceNulls;return a(function c(l){if(l.then)return l.then(c);if(Array.isArray(l))return l.map(E=>E&&typeof E=="object"?c(E):E);let u={},d=i(yw(l,r,n)),_;for(let E of e){let f=d(E);f===void 0&&o&&(f=null),f?.then?(_||(_=[]),_.push(f.then(h=>u[E.name||E]=h))):u[E.name||E]=f}return _?Promise.all(_).then(()=>u):u},"transform")}else throw new Error("Invalid select argument type "+typeof e);function i(o){return c=>{if(typeof c=="string")return o(c);if(typeof c=="object")if(c.name){s||(s={});let l=s[c.name];if(!l){let d=r[c.name]?.definition?.tableClass;l=s[c.name]=kT(c.select||c,d)}let u=o(c.name);return l(u)}else return o(c);else return c}}a(i,"handleProperty")}var gW,AW,RW,Fe,ze,ci,ve,YSe,Lr,HT,Rl,xT,Vs=Ie(()=>{gW=require("crypto");Ll();AW=L(fi()),RW=L(_e());_p();Sc();_E();Fe=Symbol.for("context"),ze=Symbol.for("primary-key"),ci=Symbol("is-collection"),ve=Symbol("stored-record"),YSe={json:"application/json",cbor:"application/cbor",msgpack:"application/x-msgpack",csv:"text/csv"},Lr=class{static{a(this,"Resource")}static transactions;constructor(t,r){this[ze]=t;let n=r?.[Fe];this[Fe]=n!==void 0?n:r||null}static get=es(function(t,r,n,s){let i=t.get?.(r);if(i?.then)return i.then(o);return o(i);function o(c){let l;if((l=r?.select)&&c!=null&&!c.selectApplied){let u=kT(l,t.constructor);return typeof c?.map=="function"?c.map(u):u(c)}return c}},{type:"read",letItLinger:!0,ensureLoaded:!0,async:!0});static put=es(function(t,r,n,s){if(Array.isArray(s)&&t[ci]){let i=[],o=n.authorize;for(let c of s){let l=t.constructor,u=l.getResource(c[l.primaryKey],n,{async:!0});u.then?i.push(u.then(d=>d.put(c,n))):i.push(u.put(c,n))}return Promise.all(i)}return t.put?t.put(s,r):ts(t,"put")},{hasContent:!0,type:"update"});static patch=es(function(t,r,n,s){return t.patch?t.patch(s,r):ts(t,"patch")},{hasContent:!0,type:"update"});static delete=es(function(t,r,n,s){return t.delete?t.delete(r):ts(t,"delete")},{hasContent:!1,type:"delete"});static getNewId(){return(0,gW.randomUUID)()}static create(t,r,n){let s;return t==null?s=r?.[this.primaryKey]??this.getNewId():Array.isArray(t)&&typeof t[0]!="object"?s=r?.[this.primaryKey]??[...t,this.getNewId()]:typeof t!="object"?s=r?.[this.primaryKey]??[t,this.getNewId()]:(s=t?.[this.primaryKey]??this.getNewId(),n=r||{},r=t),n||(n={}),Dt(n,()=>{let i=new this(s,n),o=i.update?i.update(r,!0):ts(i,"update");return n.newLocation=s,n.createdResource=!0,o?.then?o.then(()=>i):i})}static invalidate=es(function(t,r,n,s){return t.invalidate?t.invalidate(r):ts(t,"delete")},{hasContent:!1,type:"update"});static post=es(function(t,r,n,s){return t[ze]!=null&&t.update?.(),t.post(s,r)},{hasContent:!0,type:"create"});static connect=es(function(t,r,n,s){return t.connect?t.connect(s,r):ts(t,"connect")},{hasContent:!0,type:"read"});static subscribe=es(function(t,r,n,s){return t.subscribe?t.subscribe(r):ts(t,"subscribe")},{type:"read"});static publish=es(function(t,r,n,s){return t[ze]!=null&&t.update?.(),t.publish?t.publish(s,r):ts(t,"publish")},{hasContent:!0,type:"create"});static search=es(function(t,r,n,s){let i=t.search?t.search(r):ts(t,"search"),o=n.select;if(o&&n.hasOwnProperty("select")&&i!=null&&!i.selectApplied){let c=kT(o,t.constructor);return i.map(c)}return i},{type:"read"});static query=es(function(t,r,n,s){return t.search?t.search(s,r):ts(t,"search")},{hasContent:!0,type:"read"});static copy=es(function(t,r,n,s){return t.copy?t.copy(s,r):ts(t,"copy")},{hasContent:!0,type:"create"});static move=es(function(t,r,n,s){return t.move?t.move(s,r):ts(t,"move")},{hasContent:!0,type:"delete"});async post(t){if(this[ci])return(await this.constructor.create(this[ze],t,this[Fe]))[ze];ts(this,"post")}static isCollection(t){return t?.[ci]}static coerceId(t){return t}static parseQuery(t){return IS(t)}static parsePath(t,r,n){let s=t.indexOf(".");if(s>-1){let o=t.slice(s+1);t=t.slice(0,s);let c=r?.headers&&YSe[o];if(c)r.requestedContentType=c;else if(n)n.property=o;else return{query:{property:o},id:TW(t,this),isCollection:Rl}}let i=TW(t,this);return Rl?{id:i,isCollection:!0}:i}static getResource(t,r,n){let s,i=r[Fe],o;typeof r.isCollection=="boolean"&&r.hasOwnProperty("isCollection")?o=r.isCollection:o=n?.isCollection;let c=o&&this.Collection||this;if(i||(i=i===void 0?r:{}),i.transaction){let l;if(i.resourceCache?l=i.resourceCache:l=i.resourceCache=[],l.asMap){let u=l.asMap.get(t);if(s=u?.find(d=>d.constructor===c),s)return s;u||l.asMap.set(t,u=[]),u.push(s=new c(t,i))}else{if(s=l.find(u=>u[ze]===t&&u.constructor===c),s)return s;if(l.push(s=new c(t,i)),l.length>10){let u=new Map;for(let d of l){let _=d[ze],E=u.get(_);E?E.push(d):u.set(_,[d])}i.resourceCache.length=0,i.resourceCache.asMap=u}}}else s=new c(t,i);return o&&(s[ci]=!0),s}subscribe(t){return new Mn}connect(t){return t?.subscribe!==!1?this.subscribe?.(t):new Mn}allowRead(t){return t?.role.permission.super_user}allowUpdate(t){return t?.role.permission.super_user}allowCreate(t){return t?.role.permission.super_user}allowDelete(t){return t?.role.permission.super_user}getId(){return this[ze]}getContext(){return this[Fe]}};Lr.prototype[Fe]=null;(0,AW._assignPackageExport)("Resource",Lr);a(WSe,"snake_case");HT=class extends Error{static{a(this,"AccessError")}constructor(t){t?(super("Unauthorized access to resource"),this.statusCode=403):(super("Must login"),this.statusCode=401)}};a(TW,"pathToId");xT=class extends Array{static{a(this,"MultiPartId")}toString(){return this.join("/")}};a(es,"transactional");a(ts,"missingMethod");a(yw,"selectFromObject");a(kT,"transformForSelect")});var FO={};je(FO,{EVICTED:()=>ba,INVALIDATED:()=>Ns,coerceType:()=>GT,makeTable:()=>VT,setServerUtilities:()=>rTe,updateResource:()=>qT});function VT(e){let{primaryKey:t,indices:r,tableId:n,tableName:s,primaryStore:i,databasePath:o,databaseName:c,auditStore:l,schemaDefined:u,dbisDB:d,sealed:_,splitSegments:E,replicate:f}=e,{expirationMS:h,evictionMS:T,audit:m,trackDeletes:g}=e,{attributes:S}=e;S||(S=[]);let y=Jg(i,n,l),I,U,H={},X=Promise.resolve(),Y,V,ne;for(let v of S)(v.assignCreatedTime||v.name==="__createdtime__")&&(Y=v),(v.assignUpdatedTime||v.name==="__updatedtime__")&&(V=v),v.expiresAt&&(ne=v),v.isPrimaryKey&&(H=v);let Q,de=[],j=[],ae=1,Oe=2,Ne={},Me={},Gr=864e5,Dd,Fa,wn,Pd=!1,Nl,Uw=new Map,jE=new Map,vt,Ga,qa=Od.get(Us.CONFIG_PARAMS.REPLICATION_DATABASES);if(Array.isArray(qa)){for(let v of qa)if(v.name===c&&v.replicateTo>=0){Ga=v.replicateTo;break}}let vs=i.getRange({start:!1,end:!1}).constructor,Bs=10,zE=6;m&&ie();class Ve extends Lr{static name=s;static primaryStore=i;static auditStore=l;static primaryKey=t;static tableName=s;static tableId=n;static indices=r;static audit=m;static databasePath=o;static databaseName=c;static attributes=S;static replicate=f;static sealed=_;static splitSegments=E??!0;static createdTimeProperty=Y;static updatedTimeProperty=V;static propertyResolvers;static userResolvers={};static sources=[];static get expirationMS(){return h}static dbisDB=d;static schemaDefined=u;static sourcedFrom(p,A){if(A&&(this.sourceOptions=A,(A.expiration||A.eviction||A.scanInterval)&&this.setTTLExpiration(A)),A?.intermediateSource)p.intermediateSource=!0,this.sources.unshift(p);else{if(this.sources.some(O=>!O.intermediateSource)){if(this.sources.some(O=>O.name===p.name))return;throw new Error("Can not have multiple canonical (non-intermediate) sources")}this.sources.push(p)}U=U||p.get&&(!p.get.reliesOnPrototype||p.prototype.get),I=I||p.load;let w=a(O=>{let B=this.sources;if(B=B.filter(k=>k.intermediateSource&&k[O]&&(!k[O].reliesOnPrototype||k.prototype[O])),B.length>0)if(B.length===1){let k=B[0];return(C,F,x)=>{if(C?.source!==k)return k[O](F,x,C)}}else return(k,C,F)=>{let x=[];for(let q of B){if(k?.source===q)break;x.push(q[O](C,F,k))}return Promise.all(x)}},"getApplyToIntermediateSource"),R=this.sources[this.sources.length-1];R.intermediateSource&&(R={});let b=a(O=>{if(R[O]&&(!R[O].reliesOnPrototype||R.prototype[O]))return(B,k,C)=>{if(!B?.source)return R[O](k,C,B)}},"getApplyToCanonicalSource");Ne={put:b("put"),patch:b("patch"),delete:b("delete"),publish:b("publish")},Me={put:w("put"),patch:w("patch"),delete:w("delete"),publish:w("publish"),invalidate:w("invalidate")};let D=R.shouldRevalidateEvents;return(async()=>{let O=!1,B,k=a(async(C,F)=>{let x=C.value,q=C.table?We[c][C.table]:Ve;if(c===Us.SYSTEM_SCHEMA_NAME&&(C.table===Us.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME||C.table===Us.SYSTEM_TABLE_NAMES.USER_TABLE_NAME)&&(O=!0),C.id===void 0&&(C.id=x[q.primaryKey],C.id===void 0))throw new Error("Replication message without an id "+JSON.stringify(C));C.source=p;let ee={residencyId:tt(C.residencyList),isNotification:!0,ensureLoaded:!1,nodeId:C.nodeId},G=await q.getResource(C.id,F,ee);switch(C.type){case"put":return D?G._writeInvalidate(ee):G._writeUpdate(x,!0,ee);case"patch":return D?G._writeInvalidate(ee):G._writeUpdate(x,!1,ee);case"delete":return G._writeDelete(ee);case"publish":return G._writePublish(x,ee);case"invalidate":return G._writeInvalidate(ee);case"relocate":return G._writeRelocate(ee);default:qe.default.error?.("Unknown operation",C.type,C.id)}},"writeUpdate");try{let C=p.subscribe;C&&g==null&&(g=!0);let F={crossThreads:!1,inTransactionUpdates:!0,supportsTransactions:!0,omitCurrent:!0},x=p.subscribeOnThisThread?p.subscribeOnThisThread((0,yl.getWorkerIndex)(),F):(0,yl.getWorkerIndex)()===0,q=C&&x&&await p.subscribe?.(F);if(q){let ee;for await(let G of q)try{if(!(G.type==="transaction"?G.writes[0]:G)){qe.default.error?.("Bad subscription event",G);continue}if(G.source=p,G.type==="end_txn"){if(ee?.resolve(),G.localTime&&B!==G.localTime){if(G.remoteNodeIds?.length>0){let Ae=[Symbol.for("seq"),G.remoteNodeIds[0]],re=d.get(Ae),K=re?.nodes;K||(K=[]);for(let Be of G.remoteNodeIds.slice(1)){let we=K.find(ce=>ce.id===Be);K=K.filter(ce=>ce.id!==Be||ce===we),we||(we={id:Be,seqId:0},K.push(we)),we.seqId=Math.max(re?.seqId??1,G.localTime),Be===ee?.nodeId&&(we.lastTxnTime=G.timestamp)}let ge=Math.max(re?.seqId??1,G.localTime);qe.default.trace?.("Received txn",c,ge,G.localTime,G.remoteNodeIds),d.put(Ae,{seqId:ge,nodes:K})}B=G.localTime}G.onCommit&&ee?.committed.then(G.onCommit);continue}if(ee)if(G.beginTxn)ee.resolve();else{ee.write_promises.push(k(G,ee));continue}!G.timestamp&&G.version&&(G.timestamp=G.version);let Ee=Dt(G,()=>{if(G.type==="transaction"){let Ae=[];for(let re of G.writes)try{Ae.push(k(re,G))}catch(K){throw K.message+=" writing "+JSON.stringify(re)+" of event "+JSON.stringify(G),K}return Promise.all(Ae)}else if(G.type==="define_schema"){let Ae=this.attributes.slice(0),re;for(let K of G.attributes)Ae.find(ge=>ge.name===K.name)||(Ae.push(K),re=!0);re&&(Et({table:s,database:c,attributes:Ae,origin:"cluster"}),GE.signalSchemaChange(new qE.SchemaEventMsg(process.pid,Us.OPERATIONS_ENUM.CREATE_TABLE,c,s)))}else return G.beginTxn?(ee=G,ee.write_promises=[k(G,G)],new Promise(Ae=>{ee.resolve=()=>Ae(Promise.all(ee.write_promises))})):k(G,G)});ee&&(ee.committed=Ee),O&&Ee&&!Ee?.waitingForUserChange&&(Ee.then(()=>GE.signalUserChange(new qE.UserEventMsg(process.pid))),Ee.waitingForUserChange=!0),G.onCommit&&(Ee?Ee.then(G.onCommit):G.onCommit())}catch(Re){qe.default.error?.("error in subscription handler",Re)}}}catch(C){qe.default.error?.(C)}})(),this}static get isCaching(){return U}static get shouldRevalidateEvents(){return this.prototype.get!==Ve.prototype.get}static getResource(p,A,w){let R=super.getResource(p,A,w);if(p!=null){ji(p);try{if(R.hasOwnProperty(ve))return R;if(typeof p=="object"&&p&&!Array.isArray(p))throw new Error(`Invalid id ${JSON.stringify(p)}`);let b=!w?.async||i.cache?.get?.(p),D=Ir(A),O=D.getReadTxn();if(O?.isDone)throw new Error("You can not read from a transaction that has already been committed/aborted");return Va(p,A,{transaction:O,ensureLoaded:w?.ensureLoaded},b,B=>{if(B?qT(R,B):R[ve]=null,A.onlyIfCached&&A.noCacheStore){if(!R.doesExist())throw new Nr.ServerError("Entry is not cached",504)}else if(w?.ensureLoaded){let k=Ld(p,B,A,R);if(k)return D?.disregardReadTxn(),R[bw]=!0,Nw(k,C=>(qT(R,C),R))}return R})}catch(b){throw b.message.includes("Unable to serialize object")&&(b.message+=": "+JSON.stringify(p)),b}}return R}ensureLoaded(){let p=Ld(this[ze],this[Fr],this[Fe]);if(p)return this[bw]=!0,Nw(p,A=>{this[Fr]=A,this[ve]=A.value,this[kE]=A.version})}static getNewId(){let p=H?.type;if(p==="String"||p==="ID")return super.getNewId();if(!vt){let b=i.getEntry(Symbol.for("id_allocation")),D=b?.value,O;if(D&&D.nodeName===server.hostname&&(!sTe(i)||D.pid===process.pid)){let B=D.start,k=D.end;O=B;for(let C of i.getKeys({start:k,end:B,limit:1,reverse:!0}))O=C}else D=R(b?.version??null),O=D.start;vt=new BigInt64Array([BigInt(O)+1n]),vt=new BigInt64Array(i.getUserSharedBuffer("id",vt.buffer)),vt.maxSafeId=D.end}let A=Number(Atomics.add(vt,0,1n)),w=p==="Int"?512:1048576;if(A+w>=vt.maxSafeId){let b=a(D=>{vt.maxSafeId=A+(p==="Int"?1023:4194303);let O=(p==="Int"?Math.pow(2,31):Math.pow(2,49))-1,B=D?void 0:i.useReadTransaction(),k=Number(vt[0]);for(let x of i.getKeys({start:k+1,end:O,limit:1,transaction:B}))O=x;B?.done();let{value:C,version:F}=i.getEntry(Symbol.for("id_allocation"));if(vt.maxSafeId<O){if(C.end>vt.maxSafeId-100)return;qe.default.info?.("New id allocation",A,vt.maxSafeId,F),i.put(Symbol.for("id_allocation"),{start:C.start,end:vt.maxSafeId,nodeName:server.hostname,pid:process.pid},Date.now(),F)}else{qe.default.warn?.(`Id conflict detected, starting new id allocation range, attempting to allocate to ${vt.maxSafeId}, but id of ${O} detected`);let x=R(F);x.alreadyUpdated||Atomics.store(vt,0,BigInt(x.start+1)),vt.maxSafeId=x.end}},"updateEnd");A+w===vt.maxSafeId?setImmediate(b):A+100>=vt.maxSafeId&&(qe.default.warn?.(`Synchronous id allocation required on table ${s}${p=="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`),i.transactionSync(()=>b(!0)))}return A;function R(b){let D=(p==="Int"?Math.pow(2,31):Math.pow(2,49))-1,O=D/4,B,k,C=!1,F,x;do{F=Math.floor(Math.random()*D),x={start:F,end:F+(p==="Int"?1024:4194304),nodeName:server.hostname,pid:process.pid},B=0;for(let q of i.getKeys({start:F,limit:1,reverse:!0}))B=q;k=D;for(let q of i.getKeys({start:F+1,end:D,limit:1}))k=q;O*=.875,O<1e3&&!C&&(C=!0,qe.default.error?.(`Id allocation in table ${s} is very dense, limited safe range of numbers to allocate ids in${p==="Int"?", it is highly recommended that you use Long or Float as the type for auto-incremented primary keys":""}`,F,B,k,O))}while(!(O<k-F&&(O<F-B||B===0)));return i.transactionSync(()=>{let q=i.getEntry(Symbol.for("id_allocation"));return(q?.version??null)==b?(qe.default.info?.("Allocated new id range",x),i.put(Symbol.for("id_allocation"),x,Date.now()),x):(qe.default.debug?.("Looks like ids were already allocated"),{alreadyUpdated:!0,...q.value})})}}static setTTLExpiration(p){if(typeof p=="number")h=p*1e3,T||(T=0);else if(p&&typeof p=="object")h=p.expiration*1e3,T=(p.eviction||0)*1e3,Gr=p.scanInterval*1e3;else throw new Error("Invalid expiration value type");if(h<0)throw new Error("Expiration can not be negative");Gr=Gr||(h+T)/4,xo()}static getResidencyRecord(p){return d.get([Symbol.for("residency_by_id"),p])}static setResidency(p){Ve.getResidency=p}static setResidencyById(p){Ve.getResidencyById=p}static getResidency(p,A,w){if(Ve.getResidencyById)return Ve.getResidencyById(p[t]);let R=Ga;if(A.replicateTo!=null){if(Array.isArray(A.replicateTo))return A.replicateTo.includes(server.hostname)?A.replicateTo:[server.hostname,...A.replicateTo];A.replicateTo>=0&&(R=A.replicateTo)}if(R>=0&&server.nodes){let b=[server.hostname];if(w)b.push(...w.slice(0,R));else{let D=server.nodes.map(k=>k.name),O=Math.floor(D.length*Math.random());b.push(...D.slice(O,O+R));let B=O+R-D.length;B>0&&b.push(...D.slice(0,B))}return b}}static enableAuditing(p=!0){m=p,p&&ie(),Ve.audit=p}static coerceId(p){return p===""?null:GT(p,H)}static async dropTable(){if(delete We[c][s],c===o){for(let p of S)d.remove(Ve.tableName+"/"+p.name),r[p.name]?.drop();d.remove(Ve.tableName+"/"),i.drop(),await d.committed}else console.log("legacy dropTable"),await i.close(),await fs.remove(data_path),await fs.remove(data_path===standard_path?data_path+MDB_LOCK_FILE_SUFFIX:path.join(path.dirname(data_path),MDB_LEGACY_LOCK_FILE_NAME));GE.signalSchemaChange(new qE.SchemaEventMsg(process.pid,Us.OPERATIONS_ENUM.DROP_TABLE,c,s))}get(p){if(typeof p=="string")return this.getProperty(p);if(this[ci])return this.search(p);if(this[ze]===null){if(p?.conditions)return this.search(p);let A=Ve.getRecordCount();return{recordCount:A.recordCount,estimatedRecordRange:A.estimatedRange,records:"./",name:s,database:c,auditSize:l?.getStats().entryCount,attributes:S}}if(p?.property)return this.getProperty(p.property);if(this.doesExist()||p?.ensureLoaded===!1||this[Fe]?.returnNonexistent)return this}allowRead(p,A){let w=Ka(p);if(w?.read){if(w.isSuperUser)return!0;let R=w.attribute_permissions,b=A?.select;if(R?.length>0||Pd&&b){if(A||(A={}),b){let D=R?.length>0&&Ow(R,"read");A.select=b.map(O=>{let B=O.name||O;if(!D||D[B]){let k=wn[B]?.definition?.tableClass;if(k){if(O.name||(O={name:O}),!k.prototype.allowRead.call(null,p,O))return!1;if(!O.select)return O.name}return O}}).filter(Boolean)}else A.select=R.filter(D=>D.read&&!wn[D.attribute_name]).map(D=>D.attribute_name);return A}else return!0}}allowUpdate(p,A){let w=Ka(p);if(w?.update){let R=w.attribute_permissions;if(R?.length>0){let b=Ow(R,"update");for(let D in A)if(!b[D])return!1;for(let D of R){let O=D.attribute_name;!D.update&&!(O in A)&&(A[O]=this.getProperty(O))}}return Ya(this[Fe])}}allowCreate(p,A){if(this[ci]){let w=Ka(p);if(w?.insert){let R=w.attribute_permissions;if(R?.length>0){let b=Ow(R,"insert");for(let D in A)if(!b[D])return!1;return Ya(this[Fe])}else return Ya(this[Fe])}}else return this.allowUpdate(p,{})}allowDelete(p){return Ka(p)?.delete&&Ya(this[Fe])}update(p,A){if(!Ir(this[Fe]))throw new Error("Can not update a table resource outside of a transaction");if(p===!1)return this;let R;return typeof p=="object"&&p&&(A?(Object.isFrozen(p)&&(p={...p}),this[ve]={},this[_r]=p):(R=this[_r],R&&(p=Object.assign(R,p)),this[_r]=R=p)),this._writeUpdate(this[_r],A),this}addTo(p,A){if(typeof A=="number"||typeof A=="bigint")this[xE]===bW?this.set(p,(+this.getProperty(p)||0)+A):(this[xE]||this.update(),this.set(p,new vT(A)));else throw new Error("Can not add a non-numeric value")}subtractFrom(p,A){if(typeof A=="number")return this.addTo(p,-A);throw new Error("Can not subtract a non-numeric value")}getMetadata(){return this[Fr]}invalidate(){this._writeInvalidate()}_writeInvalidate(p){let A=this[Fe],w=this[ze];ji(w),Ir(this[Fe]).addWrite({key:w,store:i,invalidated:!0,entry:this[Fr],before:Ne.invalidate?.bind(this,A,w),beforeIntermediate:Me.invalidate?.bind(this,A,w),commit:a((b,D)=>{if(di(b,D,p?.nodeId)<=0)return;let O=null;for(let B in r)O||(O={}),O[B]=this.getProperty(B);qe.default.trace?.(`Invalidating entry id: ${w}, timestamp: ${new Date(b).toISOString()}`),y(w,O,this[Fr],b,Ns,m,{user:A?.user,residencyId:p?.residencyId,nodeId:p?.nodeId},"invalidate")},"commit")})}_writeRelocate(p){let A=this[Fe],w=this[ze];ji(w),Ir(this[Fe]).addWrite({key:w,store:i,invalidated:!0,entry:this[Fr],before:Ne.relocate?.bind(this,A,w),beforeIntermediate:Me.relocate?.bind(this,A,w),commit:a((b,D)=>{if(di(b,D,p?.nodeId)<=0)return;let O=Ve.getResidencyRecord(p.residencyId),B=0,k=null,C=D?.value;if(O&&!O.includes(server.hostname)){for(let F in r)k||(k={}),k[F]=C(F);B=Ns}else k=C;qe.default.trace?.(`Relocating entry id: ${w}, timestamp: ${new Date(b).toISOString()}`),y(w,k,this[Fr],b,B,m,{user:A.user,residencyId:p.residencyId,nodeId:p.nodeId,expiresAt:p.expiresAt},"relocate",!1,null)},"commit")})}static _recordRelocate(p,A){let w={previousResidency:this.getResidencyRecord(p.residencyId),isRelocation:!0},R=this.getResidency(A.value,w),b;if(R){if(!Array.isArray(R))throw new Error("Residency must be an array, but was: "+R);if(!R.includes(server.hostname))return;b=tt(R)}let O=y(p.key,A.value,p,p.version,0,!0,{residencyId:b,expiresAt:A.expiresAt},"relocate",!1,null)}static evict(p,A,w){let R=this.Source,b;if(!((U||m)&&(!A||(b=i.getEntry(p),!b||!A)||b.version!==w))){if(U){if(i.hasLock(p,b.version))return;let D;for(let O in r)D||(D={}),D[O]=A[O];if(D)return y(p,D,b,w,ba,null,null,null,!0)}return i.ifVersion(p,w,()=>{$a(p,A,null)}),m?y(p,null,b,w,ba,null,null,null,!0):i.remove(p,w)}}lock(){throw new Error("Not yet implemented")}static operation(p,A){return p.table||=s,p.schema||=c,LW.operation(p,A)}put(p){this.update(p,!0)}patch(p){this.update(p,!1)}_writeUpdate(p,A,w){let R=this[Fe],b=Ir(R),D=this[ze];ji(D);let O=this[Fr];this[xE]=A?bW:ZSe;let B={key:D,store:i,entry:O,nodeName:R?.nodeName,validate:a(k=>{p||(p=this[_r]),A||p&&MT(this[_r]===p?this:p)?R?.source||(b.checkOverloaded(),this.validate(p,!A),V&&(p[V.name]=V.type==="Date"?new Date(k):V.type==="String"?new Date(k).toISOString():k),A&&(t&&p[t]!==D&&(p[t]=D),Y&&(O?.value?p[Y.name]=O?.value[Y.name]:p[Y.name]=Y.type==="Date"?new Date(k):Y.type==="String"?new Date(k).toISOString():k),p=Al(p))):b.removeWrite(B)},"validate"),before:A?Ne.put?()=>Ne.put(R,D,p):null:Ne.patch?()=>Ne.patch(R,D,p):Ne.put?()=>Ne.put(R,D,Al(this)):null,beforeIntermediate:A?Me.put?()=>Me.put(R,D,p):null:Me.patch?()=>Me.patch(R,D,p):Me.put?()=>Me.put(R,D,Al(this)):null,commit:a((k,C,F)=>{if(F){if(R&&C?.version>(R.lastModified||0)&&(R.lastModified=C.version),this[Fr]=C,C?.value?.[ve])throw new Error("Can not assign a record to a record, check for circular references");A||(this[ve]=C?.value??null)}this[_r]=void 0,this[kE]=k;let x=C?.value,q=p;this[xE]=0;let ee=di(k,C,w?.nodeId),G;if(ee<=0)if(m){let K=C.localTime,ge=C.version;qe.default.trace?.("Applying CRDT update to record with id: ",D,"applying later update:",ge);let Be=[];for(;K>k||ge>=k&&K>0;){let we=l.get(K);if(!we)break;let ce=xt(we);if(ge=ce.version,ge>=k){if(ge===k){if(ee=di(k,{version:ge,localTime:K},w?.nodeId),ee===0)return;if(ee>0)continue}if(ce.type==="patch")Be.push(ce),G=p;else if(ce.type==="put"||ce.type==="delete")return}K=ce.previousLocalTime}Be.sort((we,ce)=>we.version-ce.version);for(let we of Be){let ce=we.getValue(i);if(q=PT(q,ce,A),qe.default.debug?.("Rebuilding update with future patch:",q),!q)return}}else{if(A)return;q=PT(q,x,A),qe.default.debug?.("Rebuilding update without audit:",q)}let Re;if(A?Re=q:(this[ve]=x,Re=Al(this,q)),this[ve]=Re,Re?.[ve])throw new Error("Can not assign a record to a record, check for circular references");let Ee;if(w?.residencyId!=null)Ee=w.residencyId;else{O?.residencyId&&(R.previousResidency=Ve.getResidencyRecord(O.residencyId));let K=Ve.getResidency(Re,R);if(K){if(!Array.isArray(K))throw new Error("Residency must be an array, got: "+K);K.includes(server.hostname)||K.push(server.hostname)}Ee=tt(K)}A||(G=p);let Ae=R?.expiresAt??(h?h+Date.now():-1);qe.default.trace?.(`Saving record with id: ${D}, timestamp: ${new Date(k).toISOString()}${Ae?", expires at: "+new Date(Ae).toISOString():""}${C?", replaces entry from: "+new Date(C.version).toISOString():", new entry"}`,Re),$a(D,x,Re);let re=A?"put":"patch";y(D,Re,C,k,0,m,{user:R?.user,residencyId:Ee,expiresAt:Ae,nodeId:w?.nodeId,originatingOperation:R?.originatingOperation},re,!1,G),R.expiresAt&&xo()},"commit")};b.addWrite(B)}async delete(p){if(typeof p=="string")return this.deleteProperty(p);if(this[ci]){for await(let A of this.search(p))(await Ve.getResource(A[t],this.getContext(),{ensureLoaded:!1}))._writeDelete(p);return}return this[ve]?this._writeDelete(p):!1}_writeDelete(p){let A=Ir(this[Fe]),w=this[ze];ji(w);let R=this[Fe];return A.addWrite({key:w,store:i,resource:this,nodeName:R?.nodeName,before:Ne.delete?.bind(this,R,w),beforeIntermediate:Me.delete?.bind(this,R,w),commit:a((b,D,O)=>{let B=D?.value;O&&(R&&D?.version>(R.lastModified||0)&&(R.lastModified=D.version),qT(this,D)),!(di(b,D,p?.nodeId)<=0)&&($a(this[ze],B),qe.default.trace?.(`Deleting record with id: ${w}, txn timestamp: ${new Date(b).toISOString()}`),m||g?(y(w,null,this[Fr],b,0,m,{user:R?.user,nodeId:p?.nodeId},"delete"),m||xo()):i.remove(this[ze]))},"commit")}),!0}search(p){let A=this[Fe],w=Ir(A);if(!p)throw new Error("No query provided");let R=p.conditions;R?R.length===void 0&&(R=R[Symbol.iterator]?Array.from(R):[R]):R=Array.isArray(p)?p:p[Symbol.iterator]?Array.from(p):[],this[ze]&&(R=[{attribute:null,comparator:Array.isArray(this[ze])?"prefix":"starts_with",value:this[ze]}].concat(R));let b,D={};function O(K,ge){let Be;switch(ge){case"and":case void 0:if(K.length<1)throw new Error('An "and" operator requires at least one condition');Be=!0;break;case"or":if(K.length<2)throw new Error('An "or" operator requires at least two conditions');break;default:throw new Error("Invalid operator "+ge)}for(let we of K){if(we.conditions){we.conditions=O(we.conditions,we.operator);continue}let ce=we[0]??we.attribute,Ye=ce==null?H:Bi(S,ce);if(Ye)(Ye.type||CN[we.comparator])&&(we[1]===void 0?we.value=k(we.value,Ye):we[1]=k(we[1],Ye));else if(ce!=null)throw(0,Nr.handleHDBError)(new Error,`${ce} is not a defined attribute`,404);if(we.chainedConditions)if(we.chainedConditions.length===1&&(!we.operator||we.operator=="and")){let rt=we.chainedConditions[0],Ze,st;if(rt.comparator==="gt"||rt.comparator==="greater_than"||rt.comparator==="ge"||rt.comparator==="greater_than_equal"?(Ze=we,st=rt):(Ze=rt,st=we),Ze.comparator!=="lt"&&Ze.comparator!=="less_than"&&Ze.comparator!=="le"&&Ze.comparator!=="less_than_equal")throw new Error("Invalid chained condition, only less than and greater than conditions can be chained together");let Bt=st.comparator==="ge"||st.comparator==="greater_than_equal",ko=Ze.comparator==="le"||Ze.comparator==="less_than_equal";we.comparator=(Bt?"ge":"gt")+(ko?"le":"lt"),we.value=[st.value,Ze.value]}else throw new Error("Multiple chained conditions are not currently supported")}return K}a(O,"prepareConditions");function B(K,ge){if(p.enforceExecutionOrder)return K;for(let Be of K)Be.conditions&&(Be.conditions=B(Be.conditions,Be.operator));return K.length>1&&ge!=="or"?(0,DW.sortBy)(K,NS(Ve)):K}a(B,"orderConditions");function k(K,ge){return Array.isArray(K)?K.map(Be=>GT(Be,ge)):GT(K,ge)}a(k,"coerceTypedValues");let C=p.operator;(R.length>0||C)&&(R=O(R,C));let F=typeof p.sort=="object"&&p.sort,x;if(F&&C!=="or"){let K=F.attribute;if(K==null)throw new Nr.ClientError("Sort requires an attribute");if(b=R.find(ge=>sd(ge.attribute)===sd(K)),!b){let ge=Bi(S,K);if(!ge)throw(0,Nr.handleHDBError)(new Error,`${Array.isArray(K)?K.join("."):K} is not a defined attribute`,404);if(ge.indexed)b={attribute:K,comparator:"sort"},R.push(b);else if(R.length===0&&!p.allowFullScan)throw(0,Nr.handleHDBError)(new Error,`${Array.isArray(K)?K.join("."):K} is not indexed and not combined with any other conditions`,404)}b&&(b.descending=!!F.descending)}R=B(R,C),F&&(b&&R[0]===b?F.next&&(x={dbOrderedAttribute:F.attribute,attribute:F.next.attribute,descending:F.next.descending,next:F.next.next}):(b&&R.splice(R.indexOf(b),1),x=F));let q=p.select;if(R.length===0&&(R=[{attribute:t,comparator:"greater_than",value:!0}]),p.explain)return{conditions:R,operator:C,postOrdering:x,selectApplied:!!q};let ee=w.useReadTxn(),G=DN(R,C,Ve,ee,p,A,(K,ge)=>Md(K,q,A,ee,ge),D),Re=p.ensureLoaded!==!1;x||(G=re(G));let Ee=Ve.transformEntryForSelect(q,A,ee,D,Re,!0),Ae=Ve.transformToOrderedSelect(G,q,x,ee,A,Ee);function re(K){return p.offset||p.limit!==void 0?K.slice(p.offset,p.limit!==void 0?(p.offset||0)+p.limit:void 0):K}return a(re,"applyOffset"),x&&(Ae=re(Ae)),Ae.onDone=()=>{Ae.onDone=null,w.doneReadTxn()},Ae.selectApplied=!0,Ae.getColumns=()=>{if(q){let K=[];for(let ge of q)ge==="*"?K.push(...S.map(Be=>Be.name)):K.push(ge.name||ge);return K}return S.filter(K=>!K.computed&&!K.relationship).map(K=>K.name)},Ae}static transformToOrderedSelect(p,A,w,R,b,D){let O=new vs;if(w){p=Md(p,A,R,b,null);let B;O.iterate=function(){let C,F=p[Symbol.asyncIterator]?p[Symbol.asyncIterator]():p[Symbol.iterator](),x,q=w.dbOrderedAttribute,ee,G,Re=!0;function Ee(re){let K=re.next&&Ee(re.next),ge=re.descending;return(Be,we)=>{let ce=Il(Be,re.attribute,R),Ye=Il(we,re.attribute,R),rt=ge?(0,bl.compareKeys)(Ye,ce):(0,bl.compareKeys)(ce,Ye);return rt===0?K?.(Be,we)||0:rt}}a(Ee,"createComparator");let Ae=Ee(w);return{async next(){let re;if(C)if(re=C.next(),re.done){if(x)return O.onDone&&O.onDone(),re}else return{value:await D.call(this,re.value)};B=[],ee&&B.push(ee);do if(re=await F.next(),re.done){if(x=!0,B.length)break;return O.onDone&&O.onDone(),re}else{let K=re.value;if(K?.then&&(K=await K),q){let ge=Il(K,q,R);if(Re)Re=!1,G=ge;else if(ge!==G){G=ge,ee=K;break}}B.push(K)}while(!0);return w.isGrouped,B.sort(Ae),C=B[Symbol.iterator](),re=C.next(),re.done?(O.onDone&&O.onDone(),re):{value:await D.call(this,re.value)}},return(){O.onDone&&O.onDone(),F.return()},throw(){O.onDone&&O.onDone(),F.throw()}}};let k=a(C=>{if(typeof A=="object"&&Array.isArray(C.attribute))for(let F=0;F<A.length;F++){let x=A[F],q;if(x.name===C.attribute[0]){for(q=x.sort||(x.sort={});q.next;)q=q.next;q.attribute=C.attribute.slice(1),q.descending=C.descending}else x===C.attribute[0]&&(A[F]=q={name:x,sort:{attribute:C.attribute.slice(1),descending:C.descending}})}C.next&&k(C.next)},"applySortingOnSelect");k(w)}else O.iterate=(p[Symbol.asyncIterator]||p[Symbol.iterator]).bind(p),O=O.map(function(B){try{let k=D.call(this,B);return typeof k?.catch=="function"?k.catch(C=>{throw C.partialObject={[t]:B.key},C}):k}catch(k){throw k.partialObject={[t]:B.key},k}});return O}static transformEntryForSelect(p,A,w,R,b,D){if(p&&(p===t||p?.length===1&&p[0]===t&&Array.isArray(p))){let C=a(F=>(A?.transaction?.stale&&(A.transaction.stale=!1),F?.key??F),"transform");return p===t?C:p.asArray?F=>[C(F)]:F=>({[t]:C(F)})}let O;b&&U&&!(typeof p=="string"?[p]:p)?.every(C=>{let F;return typeof C=="object"?F=C.name:F=C,r[F]||F===t})&&(O=!0);let B,k=a(function(C){let F;if(A?.transaction?.stale&&(A.transaction.stale=!1),C!=null){if(F=C.value||C.deref?.()?.value,!F&&(C.key===void 0||C.deref)||C.metadataFlags&Ns){if(C.metadataFlags&Ns&&A.replicateFrom===!1&&D&&C.residencyId)return Ha.SKIP;if(C=Va(C.key??C,A,{transaction:w,lazy:p?.length<4,ensureLoaded:b},this?.isSync,x=>x),C?.then)return C.then(k.bind(this));F=C?.value}if(O&&C?.metadataFlags&(Ns|ba)||C?.expiresAt!=null&&C?.expiresAt<Date.now()){if(A.onlyIfCached&&A.noCacheStore)return{[t]:C.key,message:"This entry has expired"};let x=Ld(C.key??C,C,A);if(x?.then)return x.then(k)}}if(F==null)return D?Ha.SKIP:F;if(p&&!(p[0]==="*"&&p.length===1)){let x,q=a((G,Re)=>{let Ee;typeof G=="object"?Ee=G.name:Ee=G;let Ae=wn?.[Ee],re;if(Ae){let K=R?.[Ee];if(K)if(K.hasMappings){let Be=Ae.from?F[Ae.from]:sd(C.key);re=K.get(Be),re||(re=[])}else re=K.fromRecord?.(F);else re=Ae(F,A,C);let ge=a(Be=>{if(Be&&typeof Be=="object"){let we=Ae.definition?.tableClass||Ve;B||(B={});let ce=B[Ee]||(B[Ee]=we.transformEntryForSelect(Ee===G?null:G.select||(Array.isArray(G)?G:null),A,w,K,b));if(Array.isArray(Be)){let Ye=[],rt=we.transformToOrderedSelect(Be,G.select,typeof G.sort=="object"&&G.sort,A,w,ce)[this.isSync?Symbol.iterator:Symbol.asyncIterator](),Ze=a(Bt=>{for(;!Bt.done;){if(Bt?.then)return Bt.then(Ze);Ye.push(Bt.value),Bt=rt.next()}Re(Ye,Ee)},"nextValue"),st=Ze(rt.next());st&&(x||(x=[]),x.push(st));return}else if(Be=ce.call(this,Be),Be?.then){x||(x=[]),x.push(Be.then(Ye=>Re(Ye,Ee)));return}}Re(Be,Ee)},"handleResolvedValue");re?.then?(x||(x=[]),x.push(re.then(ge))):ge(re);return}else re=F[Ee],re&&typeof re=="object"&&Ee!==G&&(re=Ve.transformEntryForSelect(G.select||G,A,w,null)({value:re}));Re(re,Ee)},"selectAttribute"),ee;if(typeof p=="string")q(p,G=>{ee=G});else if(Array.isArray(p))if(p.asArray)ee=[],p.forEach((G,Re)=>{G==="*"?p[Re]=F:q(G,Ee=>ee[Re]=Ee)});else{ee={};let G=p.forceNulls;for(let Re of p)if(Re==="*")for(let Ee in F)ee[Ee]=F[Ee];else q(Re,(Ee,Ae)=>{Ee===void 0&&G&&(Ee=null),ee[Ae]=Ee})}else throw new Nr.ClientError("Invalid select"+p);return x?Promise.all(x).then(()=>ee):ee}return F},"transform");return k}async subscribe(p){if(!l)throw new Error("Can not subscribe to a table without an audit log");m||Et({table:s,database:c,schemaDefined:u,attributes:S,audit:!0}),p||(p={});let A=!p.rawEvents,w=[],R=this,b=py(Ve,this[ze]??null,function(O,B,k,C){try{let F=B.getValue?.(i,A),x=B.type;if(!F&&x==="patch"&&A){let ee=i.getEntry(O);ee?.version===B.version?F=ee.value:F=B.getValue?.(i,!0,k),x="put"}let q={id:O,localTime:k,value:F,version:B.version,type:x,beginTxn:C};w?w.push(q):this.send(q)}catch(F){qe.default.error?.(F)}},p.startTime||0,p),D=(async()=>{this[ci]&&(b.includeDescendants=!0,p.onlyChildren&&(b.onlyChildren=!0)),p.supportsTransactions&&(b.supportsTransactions=!0);let O=this[ze],B=p.previousCount;B>1e3&&(B=1e3);let k=p.startTime;if(this[ci]){if(k){if(B)throw new Nr.ClientError("startTime and previousCount can not be combined for a table level subscription");for(let{key:C,value:F}of l.getRange({start:k,exclusiveStart:!0,snapshot:!1})){let x=xt(F);if(x.tableId!==n)continue;let q=x.recordId;if(O==null||wW(O,q)){let ee=x.getValue(i,A,C);if(b.send({id:q,localTime:C,value:ee,version:x.version,type:x.type}),b.queue?.length>NW&&await b.waitForDrain()===!1)return}b.startTime=C}}else if(B){let C=[];for(let{key:F,value:x}of l.getRange({start:"z",end:!1,reverse:!0}))try{let q=xt(x);if(q.tableId!==n)continue;let ee=q.recordId;if(O==null||wW(O,ee)){let G=q.getValue(i,A,F);if(C.push({id:ee,localTime:F,value:G,version:q.version,type:q.type}),--B<=0)break}}catch(q){qe.default.error("Error getting history entry",F,q)}for(let F=C.length;F>0;)b.send(C[--F]);C[0]&&(b.startTime=C[0].localTime)}else if(!p.omitCurrent){for(let{key:C,value:F,version:x,localTime:q}of i.getRange({start:O??!1,end:O==null?void 0:[O,bl.MAXIMUM_KEY],versions:!0,snapshot:!1}))if(F&&(b.send({id:C,localTime:q,value:F,version:x,type:"put"}),b.queue?.length>NW&&await b.waitForDrain()===!1))return}}else{B&&!k&&(k=0);let C=this[Fr]?.localTime;if(C===Qg&&(i.cache?.delete(O),this[Fr]=i.getEntry(O),qe.default.trace?.("re-retrieved record",C,this[Fr]?.localTime),C=this[Fr]?.localTime),qe.default.trace?.("Subscription from",k,"from",O,C),k<C){let F=[],x=C;do{let q=l.get(x);if(q){p.omitCurrent=!0;let ee=xt(q),G=ee.getValue(i,A,x);A&&(ee.type="put"),F.push({id:O,value:G,localTime:x,...ee}),x=ee.previousLocalTime}else break;B&&B--}while(x>k&&B!==0);for(let q=F.length;q>0;)b.send(F[--q]);b.startTime=C}!p.omitCurrent&&this.doesExist()&&b.send({id:O,localTime:C,value:this[ve],version:this[kE],type:"put"})}for(let C of w)b.send(C);w=null})();return p.listener&&b.on("data",p.listener),b}static subscribeOnThisThread(p,A){return p===0||A?.crossThreads===!1}doesExist(){return!!(this[ve]||this[xE])}publish(p,A){this._writePublish(p,A)}_writePublish(p,A){let w=Ir(this[Fe]),R=this[ze]||null;R!=null&&ji(R);let b=this[Fe];w.addWrite({key:R,store:i,entry:this[Fr],nodeName:b?.nodeName,validate:a(()=>{b?.source||(w.checkOverloaded(),this.validate(p))},"validate"),before:Ne.publish?.bind(this,b,R,p),beforeIntermediate:Me.publish?.bind(this,b,R,p),commit:a((D,O,B)=>{O===void 0&&g&&!m&&xo(),qe.default.trace?.(`Publishing message to id: ${R}, timestamp: ${new Date(D).toISOString()}`),y(R,O?.value??null,O,O?.version||D,0,!0,{user:b?.user,residencyId:A?.residencyId,expiresAt:b?.expiresAt,nodeId:A?.nodeId},"message",!1,p)},"commit")})}validate(p,A){let w,R=a((b,D,O)=>{if(D.type&&b!=null)if(A&&b.__op__&&(b=b.value),D.properties){typeof b!="object"&&(w||(w=[])).push(`Value ${li(b)} in property ${O} must be an object${D.type?" ("+D.type+")":""}`);let B=D.properties;for(let k=0,C=B.length;k<C;k++){let F=B[k],x=R(b[F.name],F,O+"."+F.name);x&&(b[F.name]=x)}if(D.sealed&&b!=null&&typeof b=="object")for(let k in b)B.find(C=>C.name===k)||(w||(w=[])).push(`Property ${k} is not allowed within object in property ${O}`)}else switch(D.type){case"Int":(typeof b!="number"||b>>0!==b)&&(w||(w=[])).push(`Value ${li(b)} in property ${O} must be an integer (from -2147483648 to 2147483647)`);break;case"Long":(typeof b!="number"||!(Math.floor(b)===b&&Math.abs(b)<=9007199254740992))&&(w||(w=[])).push(`Value ${li(b)} in property ${O} must be an integer (from -9007199254740992 to 9007199254740992)`);break;case"Float":typeof b!="number"&&(w||(w=[])).push(`Value ${li(b)} in property ${O} must be a number`);break;case"ID":typeof b=="string"||b?.length>0&&b.every?.(B=>typeof B=="string")||(w||(w=[])).push(`Value ${li(b)} in property ${O} must be a string, or an array of strings`);break;case"String":typeof b!="string"&&(w||(w=[])).push(`Value ${li(b)} in property ${O} must be a string`);break;case"Boolean":typeof b!="boolean"&&(w||(w=[])).push(`Value ${li(b)} in property ${O} must be a boolean`);break;case"Date":if(!(b instanceof Date)){if(typeof b=="string"||typeof b=="number")return new Date(b);(w||(w=[])).push(`Value ${li(b)} in property ${O} must be a Date`)}break;case"BigInt":if(typeof b!="bigint"){if(typeof b=="string"||typeof b=="number")return BigInt(b);(w||(w=[])).push(`Value ${li(b)} in property ${O} must be a bigint`)}break;case"Bytes":b instanceof Uint8Array||(w||(w=[])).push(`Value ${li(b)} in property ${O} must be a Buffer or Uint8Array`);break;case"array":if(Array.isArray(b)){if(D.elements)for(let B=0,k=b.length;B<k;B++){let C=b[B],F=R(C,D.elements,O+"[*]");F&&(b[B]=F)}}else(w||(w=[])).push(`Value ${li(b)} in property ${O} must be a Buffer or Uint8Array`);break}D.nullable===!1&&b==null&&(w||(w=[])).push(`Property ${O} is required (and not does not allow null values)`)},"validateValue");for(let b=0,D=S.length;b<D;b++){let O=S[b];if(!(O.relationship||O.computed)&&(!A||O.name in p)){let B=R(p[O.name],O,O.name);B&&(p[O.name]=B)}}if(_)for(let b in p)S.find(D=>D.name===b)||(w||(w=[])).push(`Property ${b} is not allowed`);if(w)throw new Nr.ClientError(w.join(". "))}getUpdatedTime(){return this[kE]}wasLoadedFromSource(){return U?!!this[bw]:void 0}static async addAttributes(p){let A=S.slice(0);for(let w of p){if(!w.name)throw new Nr.ClientError("Attribute name is required");if(w.name.match(/[`/]/))throw new Nr.ClientError("Attribute names cannot include backticks or forward slashes");(0,PW.validateAttribute)(w.name),A.push(w)}return Et({table:s,database:c,schemaDefined:u,attributes:A}),Ve.indexingOperation}static async removeAttributes(p){let A=S.filter(w=>!p.includes(w.name));return Et({table:s,database:c,schemaDefined:u,attributes:A}),Ve.indexingOperation}static getSize(){let p=i.getStats();return(p.treeBranchPageCount+p.treeLeafPageCount+p.overflowPages)*p.pageSize}static getAuditSize(){let p=l?.getStats();return p&&(p.treeBranchPageCount+p.treeLeafPageCount+p.overflowPages)*p.pageSize}static getRecordCount(p){let A=i.getStats().entryCount,w=1e3/2,R=performance.now(),b=Math.floor(A/2),D=p?.exactCount,O=0,B=0,k;for(let{value:C}of i.getRange({start:!0,lazy:!0}))if(C!=null&&O++,B++,!D&&B<b&&performance.now()-R>w){k=B;break}if(k){let C=O;O=0;for(let{value:re}of i.getRange({start:"\uFFFF",reverse:!0,lazy:!0,limit:k}))re!=null&&O++;let F=k*2,x=(O+C)/F,q=Math.pow((O-C+1)/k/2,2)+x*(1-x)/F,ee=Math.max(Math.sqrt(q)*A,1),G=Math.round(x*A),Re=Math.max(G-1.96*ee,O+C),Ee=Math.min(G+1.96*ee,A),Ae=Math.pow(10,Math.round(Math.log10(ee)));return Ae>G&&(Ae=Ae/10),O=Math.round(G/Ae)*Ae,{recordCount:O,estimatedRange:[Math.round(Re),Math.round(Ee)]}}return{recordCount:O}}static updatedAttributes(){wn=this.propertyResolvers={$id:a((p,A,w)=>({value:w.key}),"$id"),$updatedtime:a((p,A,w)=>w.version,"$updatedtime"),$record:a((p,A,w)=>w?{value:p}:p,"$record")};for(let p of this.attributes){p.resolve=null;let A=p.relationship,w=p.computed;if(A)if(p.indexed&&console.error("A relationship property can not be directly indexed, (but you may want to index the foreign key attribute)"),w&&console.error("A relationship property is already computed and can not be combined with a computed function (the relationship will be given precedence)"),Pd=!0,A.to)p.elements?.definition?(wn[p.name]=p.resolve=(R,b,D)=>{let O=R[A.from?A.from:t],B=p.elements.definition.tableClass;return D?nd({attribute:A.to,value:O},Ir(b).getReadTxn(),!1,B,!1).asArray:B.search([{attribute:A.to,value:O}],b).asArray},p.set=()=>{throw new Error("Setting a one-to-many relationship property is not supported")},p.resolve.definition=p.elements.definition,A.from&&(p.resolve.from=A.from)):console.error(`The one-to-many/many-to-many relationship property "${p.name}" in table "${s}" must have an array type referencing a table as the elements`);else if(A.from){let R=p.definition||p.elements?.definition;R?(wn[p.name]=p.resolve=(b,D,O)=>{let B=b[A.from];if(B!==void 0){if(p.elements){let k,C=B?.map(F=>{let x=O?R.tableClass.primaryStore.getEntry(F,{transaction:Ir(D).getReadTxn()}):R.tableClass.get(F,D);return x?.then&&(k=!0),x});return A.filterMissing?k?Promise.all(C).then(F=>F.filter(CW)):C.filter(CW):k?Promise.all(C):C}return O?R.tableClass.primaryStore.getEntry(B,{transaction:Ir(D).getReadTxn()}):R.tableClass.get(B,D)}},p.set=(b,D)=>{if(Array.isArray(D)){let O=D.map(B=>B[ze]||B[R.tableClass.primaryKey]);b[A.from]=O}else{let O=D[ze]||D[R.tableClass.primaryKey];b[A.from]=O}},p.resolve.definition=p.definition||p.elements?.definition,p.resolve.from=A.from):console.error(`The relationship property "${p.name}" in table "${s}" must be a type that references a table`)}else console.error(`The relationship directive on "${p.name}" in table "${s}" must use either "from" or "to" arguments`);else w&&(typeof w.from=="function"&&this.setComputedAttribute(p.name,w.from),wn[p.name]=p.resolve=(R,b,D)=>{let O=typeof w.from=="string"?R[w.from]:R,B=this.userResolvers[p.name];if(B)return B(O,b,D);qe.default.warn(`Computed attribute "${p.name}" does not have a function assigned to it. Please use setComputedAttribute('${p.name}', resolver) to assign a resolver function.`),this.userResolvers[p.name]=()=>{}})}BT(this,this)}static setComputedAttribute(p,A){let w=Bi(S,p);if(!w){console.error(`The attribute "${p}" does not exist in the table "${s}"`);return}if(!w.computed){console.error(`The attribute "${p}" is not defined as computed in the table "${s}"`);return}this.userResolvers[p]=A}static async deleteHistory(p=0,A=!1){let w;for(let{key:R,value:b}of l.getRange({start:0,end:p}))await bd(),xt(b).tableId===n&&(w=wT(l,R,b));if(A)for(let{key:R,value:b,localTime:D}of i.getRange({start:0,versions:!0}))await bd(),b===null&&D<p&&(w=i.remove(R));await w}static async*getHistory(p=0,A=1/0){for(let{key:w,value:R}of l.getRange({start:p||1,end:A})){await bd();let b=xt(R);b.tableId===n&&(yield{id:b.recordId,localTime:w,version:b.version,type:b.type,value:b.getValue(i,!0,w),user:b.user,operation:b.originatingOperation})}}static async getHistoryOfRecord(p){let A=[];if(p==null)throw new Error("An id is required");let w=i.getEntry(p);if(!w)return A;let R=w.localTime;if(!R)throw new Error("The entry does not have a local audit time");let b=0;do{await bd();let D=l.get(R);if(D){let O=xt(D);A.push({id:O.recordId,localTime:R,version:O.version,type:O.type,value:O.getValue(i,!0,R),user:O.user}),R=O.previousLocalTime}else break}while(b<1e3&&R);return A.reverse()}static cleanup(){Q?.remove()}}Ve.updatedAttributes();let ss=Ve.prototype;return ss[XSe]=!0,h&&Ve.setTTLExpiration(h/1e3),ne&&Se(),Ve;function $a(v,p,A){let w;for(let R in r){let b=r[R],D=b.isIndexing,O=wn[R],B=A&&(O?O(A):A[R]),k=p&&(O?O(p):p[R]);if(B===k&&!D)continue;w=!0;let C=b.indexNulls,F=(0,FE.getIndexedValues)(B,C),x=(0,FE.getIndexedValues)(k,C);if(x?.length>0){let q=new Set(x);if(F=F?F.filter(ee=>{if(q.has(ee))q.delete(ee);else return!0}):[],x=Array.from(q),(x.length>0||F.length>0)&&yW){let ee=x.concat(F).map(G=>({key:G,value:v}));b.prefetch(ee,IW)}for(let ee=0,G=x.length;ee<G;ee++)b.remove(x[ee],v)}else F?.length>0&&yW&&b.prefetch(F.map(q=>({key:q,value:v})),IW);if(F)for(let q=0,ee=F.length;q<ee;q++)b.put(F[q],v)}return w}a($a,"updateIndices");function ji(v){switch(typeof v){case"number":return!0;case"string":if(v.length<659)return!0;if(v.length>OW)throw new Error("Primary key size is too large: "+v.length);break;case"object":if(v===null)throw new Error("Invalid primary key of null");break;case"bigint":if(v<2n**64n&&v>-(2n**64n))return!0;break;default:throw new Error("Invalid primary key type: "+typeof v)}if((0,bl.writeKey)(v,eTe,0)>OW)throw new Error("Primary key size is too large: "+v.length);return!0}a(ji,"checkValidId");function Va(v,p,A,w,R){if(Ve.getResidencyById&&A.ensureLoaded&&p?.replicateFrom!==!1){let D=Ve.getResidencyById(v);if(D&&!D.includes(server.hostname)&&I)return I({key:v,residency:D}).then(R)}let b=a(()=>{if(p?.transaction?.stale&&(p.transaction.stale=!1),A.transaction?.isDone)return R(null,v);let D=i.getEntry(v,A);return D?.residencyId&&D.metadataFlags&Ns&&I&&A.ensureLoaded&&p?.replicateFrom!==!1?I(D).then(O=>R(O,v)):(D&&p&&(D?.version>(p.lastModified||0)&&(p.lastModified=D.version),D?.localTime&&!p.lastRefreshed&&(p.lastRefreshed=D.localTime)),R(D,v))},"whenPrefetched");return w?b():ae>0?(ae--,b()):new Promise((D,O)=>{ae===0?(ae--,i.prefetch([v],()=>{B(),k()})):(de.push(v),j.push(k),de.length>zE&&(ae--,B()));function B(){if(de.length>0){let C=j;i.prefetch(de,()=>{ae===-1?B():ae++;for(let F of C)F()}),de=[],j=[],Oe>2&&Oe--}else ae=Oe,Oe<Bs&&Oe++}a(B,"prefetch");function k(){try{D(b())}catch(C){O(C)}}a(k,"load")})}a(Va,"loadLocalRecord");function Ka(v){if(!v?.role)return;let p=v.role.permission;if(p.super_user)return tTe;let A=p[c],w,R=A?.tables;if(R)return R[s];if(c==="data"&&(w=p[s])&&!w.tables)return w}a(Ka,"getTablePermissions");function Ld(v,p,A,w){if(U){let R=!1;if(A.noCache?R=!0:(p?(!p.value||p.metadataFlags&(Ns|ba)||p.expiresAt!=null&&p.expiresAt<Date.now())&&(R=!0):R=!0,qn(!R,"cache-hit",s)),R){let b=Ud(v,p,A).then(D=>(D?.value?.[ve]&&qe.default.error?.("Can not assign a record with a record property"),A&&(D?.version>(A.lastModified||0)&&(A.lastModified=D.version),A.lastRefreshed=Date.now()),D));if(A?.onlyIfCached||p?.value&&w?.allowStaleWhileRevalidate?.(p,v)){if(b.catch(D=>qe.default.warn?.(D)),A?.onlyIfCached&&!w.doesExist())throw new Nr.ServerError("Entry is not cached",504);return}else return b}}else if(p?.value&&p.expiresAt!=null&&p.expiresAt<Date.now())return Ve.evict(p.key,p.value,p.version),p.value=null,{then(R){return R(p)}}}a(Ld,"ensureLoadedFromSource");function Ir(v){let p=v?.transaction;if(p){if(!p.lmdbDb)return p.lmdbDb=i,p;do{if(p.lmdbDb?.path===i.path)return p;let A=p.next;if(!A)return p=p.next=new mc,p.lmdbDb=i,p;p=A}while(!0)}else return new cp}a(Ir,"txnForContext");function Il(v,p,A){if(!v)return;let w=v.value||i.getEntry(v.key)?.value;if(typeof p=="object"){let b=wn,D=w;for(let O=0,B=p.length;O<B;O++){let k=p[O],C=b?.[k];D=C&&D?C(D,A,!0)?.value:D?.[k],b=C?.definition?.tableClass?.propertyResolvers}return D}let R=wn[p];return R?R(w,A):w[p]}a(Il,"getAttributeValue");function Md(v,p,A,w,R){let b=R?.length,D={transaction:w,lazy:b>0||typeof p=="string"||p?.length<4,alwaysPrefetch:!0},O;function B(k,C){let F=k?.value;if(!F)return Ha.SKIP;for(let x=0;x<b;x++)if(!O?.includes(x)&&!R[x](F,k))return Ha.SKIP;return C!==void 0&&(k.key=C),k}if(a(B,"processEntry"),b>0||!v.hasEntries){let k=v.map(C=>{if(O=null,typeof C=="object"&&C?.key!==void 0)return b>0?B(C):C;if(C==null)return Ha.SKIP;for(let F=0;F<b;F++){let q=R[F].idFilter;if(q){if(!q(C))return Ha.SKIP;O||(O=[]),O.push(F)}}return Va(C,A,D,!1,B)});return Array.isArray(v)&&(k=k.filter(C=>C!==Ha.SKIP)),k.hasEntries=!0,k}return v}a(Md,"transformToEntries");function di(v,p,A=server.replication?.getThisNodeId(l)){if(v<=p?.version){if(p?.version===v&&A!==void 0){let w=server.replication?.exportIdMapping(l),R=p.localTime,b=R&&l.get(R);if(b){let D,O,B=xt(b);for(let k in w)w[k]===A&&(D=k),w[k]===B.nodeId&&(O=k);if(D>O)return 1;if(D===O)return 0}}return-1}return 1}a(di,"precedesExistingVersion");async function Ud(v,p,A){let w=p?.metadataFlags,R=p?.version,b,D;if(!i.attemptLock(v,R,()=>{clearTimeout(D);let C=i.getEntry(v);!C||!C.value||C.metadataFlags&(Ns|ba)?b(Ud(v,i.getEntry(v),A)):b(C)}))return new Promise(C=>{b=C,D=setTimeout(()=>{i.unlock(v,R)},JSe)});let O=p?.value,B={requestContext:A,replacingRecord:O,replacingEntry:p,replacingVersion:R,noCacheStore:!1,source:null,resourceCache:A?.resourceCache},k=A?.responseHeaders;return new Promise((C,F)=>{let x;Nw(Dt(B,async q=>{let ee=performance.now(),G,Re,Ee;try{for(let ge of Ve.sources)if(ge.get&&(!ge.get.reliesOnPrototype||ge.prototype.get)){if(ge.available?.(p)===!1)continue;if(B.source=ge,G=await ge.get(v,B),G)break}Ee=w&Ns;let re=B.lastModified||Ee&&R;Re=Ee||re>R||!O,re||(re=(0,FE.getNextMonotonicTime)());let K=performance.now()-ee;if(pr(K,"cache-resolution",s,null,"success"),k&&Bm(k,"Server-Timing",`cache-resolve;dur=${K.toFixed(2)}`,!0),q.timestamp=re,h&&B.expiresAt==null&&(B.expiresAt=Date.now()+h),G){if(typeof G!="object")throw new Error("Only objects can be cached and stored in tables");if(G.status>0&&G.headers)if(G.status>=300)if(G.status===304)G=O,re=R;else throw new Nr.ServerError(G.body||"Error from source",G.status);else G=G.body;typeof G.toJSON=="function"&&(G=G.toJSON()),t&&G[t]!==v&&(G[t]=v)}x=!0,C({key:v,version:re,value:G})}catch(re){re.message+=` while resolving record ${v} for ${s}`,O&&((re.code==="ECONNRESET"||re.code==="ECONNREFUSED"||re.code==="EAI_AGAIN")&&!A?.mustRevalidate||A?.staleIfError&&(re.statusCode===500||re.statusCode===502||re.statusCode===503||re.statusCode===504))?(C({key:v,version:R,value:O}),qe.default.trace?.(re.message,"(returned stale record)")):F(re);let K=performance.now()-ee;pr(K,"cache-resolution",s,null,"fail"),k&&Bm(k,"Server-Timing",`cache-resolve;dur=${K.toFixed(2)}`,!0),B.transaction.abort();return}if(A?.noCacheStore||B.noCacheStore){B.transaction.abort();return}Ir(B).addWrite({key:v,store:i,entry:p,nodeName:"source",commit:a((re,K)=>{if(K?.version!==R)return;let ge=$a(v,O,G);G?(Me.put?.(B,v,G),qe.default.trace?.(`Writing resolved record from source with id: ${v}, timestamp: ${new Date(re).toISOString()}`),y(v,G,K,re,0,m&&Re||null,{user:B?.user,expiresAt:B.expiresAt},"put",!!Ee)):K&&(Me.delete?.(B,v),qe.default.trace?.(`Deleting resolved record from source with id: ${v}, timestamp: ${new Date(re).toISOString()}`),m||g?y(v,null,K,re,0,m&&Re||null,{user:B?.user},"delete",!!Ee):i.remove(v,R))},"commit")})}),()=>{i.unlock(v,R)},q=>{i.unlock(v,R),x&&qe.default.error?.("Error committing cache update",q)})})}a(Ud,"getFromSource");function Ya(v){if(!v||v.user?.role?.permission?.super_user)return!0;if(v.replicateTo)throw new Nr.ClientError("Can not specify replication parameters without super user permissions",403);if(v.replicatedConfirmation)throw new Nr.ClientError("Can not specify replication confirmation without super user permissions",403);return!0}a(Ya,"checkContextPermissions");function xo(){if(Gr!==Dd&&(Dd=Gr,(0,yl.getWorkerIndex)()===(0,yl.getWorkerCount)()-1)){if(Fa&&clearTimeout(Fa),!Gr)return;let v=new Date;v.setMonth(0),v.setDate(1),v.setHours(0),v.setMinutes(0),v.setSeconds(0);let p=Math.ceil((Date.now()-v.getTime())/Gr)*Gr+v.getTime(),A=a(w=>{qe.default.trace?.(`Scheduled next cleanup scan at ${new Date(w)}ms`),Fa=setTimeout(()=>X=X.then(async()=>{if(A(Math.max(w+Gr,Date.now())),i.rootStore.status!=="open"){clearTimeout(Fa);return}let R=50,b=new Array(R),D=0;qe.default.info?.(`Starting cleanup scan for ${s}`);try{let O=0;for(let{key:B,value:k,version:C,expiresAt:F}of i.getRange({start:!1,snapshot:!1,versions:!0,lazy:!0})){let x;k===null&&!m&&C+QSe<Date.now()?x=i.remove(B,C):F!=null&&F+T<Date.now()&&(x=Ve.evict(B,k,C),O++),x&&(await b[D],b[D]=x.catch(q=>{qe.default.error?.("Cleanup error",q)}),++D>=R&&(D=0)),await bd()}qe.default.info?.(`Finished cleanup scan for ${s}, evicted ${O} entries`)}catch(O){qe.default.warn?.(`Error in cleanup scan for ${s}:`,O)}}),Math.min(w-Date.now(),2147483647)).unref()},"startNextTimer");A(p)}}a(xo,"scheduleCleanup");function ie(){Q=l?.addDeleteRemovalCallback(n,v=>{let p=i.getEntry(v);p?.value===null&&i.remove(v,p.version)})}a(ie,"addDeleteRemoval");function Se(){(0,yl.getWorkerIndex)()===0&&setInterval(async()=>{if(!Nl){Nl=!0;try{let v=ne.name,p=r[v];if(!p)throw new Error(`expiresAt attribute ${ne} must be indexed`);for(let A of p.getRange({start:!0,values:!1,end:Date.now(),snapshot:!1})){for(let w of p.getValues(A)){let R=i.getEntry(w);R?.value?R.value[v]<Date.now()&&Ve.evict(w,R.value,R.version):i.ifVersion(w,R?.version,()=>p.remove(A,w))}await bd()}}catch(v){qe.default.error?.("Error in evicting old records",v)}finally{Nl=!1}}},zSe).unref()}a(Se,"runRecordExpirationEviction");function tt(v){if(v){let p=v.join(","),A=d.get([Symbol.for("residency_by_set"),p]);return A||(d.put([Symbol.for("residency_by_set"),p],A=Math.floor(Math.random()*2147483647)),d.put([Symbol.for("residency_by_id"),A],v),A)}}a(tt,"getResidencyId")}function Ow(e,t){let r=e.attr_object||(e.attr_object={}),n=r[t];if(n)return n;n=r[t]=Object.create(null);for(let s of e)n[s.attribute_name]=s[t];return n}function IW(){}function rTe(e){LW=e}function GT(e,t){let r=t?.type;if(e===null)return e;if(e===""&&r&&r!=="String"&&r!=="Any")return null;try{switch(r){case"Int":case"Long":if(e[0]==="$")return FT(parseInt(e.slice(1),36));if(e==="null")return null;if(!/^-?[0-9]+$/.test(e)&&!(e instanceof Date))throw new SyntaxError;return FT(+e);case"Float":return e==="null"?null:FT(+e);case"BigInt":return e==="null"?null:BigInt(e);case"Boolean":return e==="true"?!0:e==="false"?!1:e;case"Date":if(isNaN(e)){if(e==="null")return null;nTe.test(e)||(e+="Z");let n=new Date(e);return FT(n.getTime()),n}return new Date(+e);case void 0:case"Any":return(0,$T.autoCast)(e);default:return e}}catch(n){throw n.message=`Invalid value for attribute ${t.name}: "${e}", expecting ${r}`,n.statusCode=400,n}}function FT(e){if(isNaN(e))throw new SyntaxError;return e}function wW(e,t){if(e==null)return!0;if(!Array.isArray(t))return e===t||t.startsWith?.(e);if(Array.isArray(e)){let r=e.length;if(e[r-1]===null&&r--,t.length>=r){for(let n=0;n<r;n++)if(t[n]!==e[n])return!1;return!0}return!1}else if(t[0]===e)return!0}function Nw(e,t,r){return e?.then?e.then(t,r):t(e)}function qT(e,t){e[Fr]=t,e[ve]=t?.value??null,e[kE]=t?.version}function CW(e){return e!=null}function li(e){try{return JSON.stringify(e)}catch{return e}}function sTe(e){let t=process.pid;return e.env.readerList().slice(1).some(r=>+r.match(/\d+/)?.[0]!=t)}var Us,Ha,FE,DW,PW,Od,Nr,GE,qE,qe,bl,yl,$T,jSe,LW,zSe,QSe,yW,JSe,kE,XSe,Fr,xE,bW,ZSe,bw,Ns,ba,eTe,OW,NW,tTe,zMe,nTe,bd,$f=Ie(()=>{Us=L(M()),Ha=require("lmdb"),FE=L(cn()),DW=require("lodash"),PW=L(Zd());Vs();lp();Od=L(se());my();Nr=L(_e()),GE=L(no()),qE=L(qs());Pe();_E();qe=L(Oc());_p();Sc();bl=require("ordered-binary"),yl=L(dt());Ji();$T=L(te());vl();Ni();CT();Bf();jSe=new Uint8Array(9);jSe[8]=192;zSe=6e4,QSe=864e5;Od.initSync();yW=Od.get(Us.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),JSe=1e4,kE=Symbol.for("version"),XSe=Symbol.for("incremental-update"),Fr=Symbol("entry"),xE=Symbol("is-saving"),bW=1,ZSe=2,bw=Symbol("loaded-from-source"),Ns=1,ba=8,eTe=Buffer.allocUnsafeSlow(8192),OW=1978,NW=100,tTe={read:!0,insert:!0,update:!0,delete:!0,isSuperUser:!0},zMe=(0,$T.convertToMS)(Od.get(Us.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE))||864e5;a(VT,"makeTable");a(Ow,"attributesAsObject");a(IW,"noop");a(rTe,"setServerUtilities");nTe=/[+-][0-9]{2}:[0-9]{2}|[a-zA-Z]$/;a(GT,"coerceType");a(FT,"rejectNaN");a(wW,"isDescendantId");bd=a(()=>new Promise(setImmediate),"rest");a(Nw,"when");a(qT,"updateResource");a(CW,"exists");a(li,"stringify");a(sTe,"hasOtherProcesses")});var lt={};je(lt,{database:()=>Ql,databases:()=>We,dropDatabase:()=>xR,dropTableMeta:()=>lTe,getDatabases:()=>ut,getDefaultCompression:()=>Lm,getTables:()=>iTe,onRemovedDB:()=>of,onUpdatedTable:()=>Lc,readMetaDb:()=>$E,resetDatabases:()=>ku,table:()=>Et,tables:()=>jn});function iTe(){return jT||ut(),jn||{}}function ut(){if(jT)return We;jT=!0,wd=new Map;let e=(0,er.getHdbBasePath)()&&(0,Ut.join)((0,er.getHdbBasePath)(),yr.DATABASES_DIR_NAME),t=(0,er.get)(yr.CONFIG_PARAMS.DATABASES)||{};if(process.env.SCHEMAS_DATA_PATH&&(t.data={path:process.env.SCHEMAS_DATA_PATH}),e=process.env.STORAGE_PATH||(0,er.get)(yr.CONFIG_PARAMS.STORAGE_PATH)||e&&((0,rs.existsSync)(e)?e:(0,Ut.join)((0,er.getHdbBasePath)(),yr.LEGACY_DATABASES_DIR_NAME)),!e)return;if((0,rs.existsSync)(e))for(let n of(0,rs.readdirSync)(e,{withFileTypes:!0})){let s=(0,Ut.basename)(n.name,".mdb");n.isFile()&&(0,Ut.extname)(n.name).toLowerCase()===".mdb"&&!t[s]?.path&&$E((0,Ut.join)(e,n.name),null,s)}if((0,rs.existsSync)((0,Id.getBaseSchemaPath)())){for(let n of(0,rs.readdirSync)((0,Id.getBaseSchemaPath)(),{withFileTypes:!0}))if(!n.isFile()){let s=(0,Ut.join)((0,Id.getBaseSchemaPath)(),n.name),i=(0,Ut.join)((0,Id.getTransactionAuditStoreBasePath)(),n.name);for(let o of(0,rs.readdirSync)(s,{withFileTypes:!0}))if(o.isFile()&&(0,Ut.extname)(o.name).toLowerCase()===".mdb"){let c=(0,Ut.join)(i,o.name);$E((0,Ut.join)(s,o.name),(0,Ut.basename)(o.name,".mdb"),n.name,c,!0)}}}if(t)for(let n in t){let s=t[n],i=s.path;if((0,rs.existsSync)(i))for(let c of(0,rs.readdirSync)(i,{withFileTypes:!0}))c.isFile()&&(0,Ut.extname)(c.name).toLowerCase()===".mdb"&&$E((0,Ut.join)(i,c.name),(0,Ut.basename)(c.name,".mdb"),n);let o=s.tables;if(o)for(let c in o){let l=o[c],u=(0,Ut.join)(l.path,(0,Ut.basename)(c+".mdb"));(0,rs.existsSync)(u)&&$E(u,c,n,null,!0)}}for(let n in We){let s=wd.get(n);if(s){let i=We[n];n.includes("delete")&&Vt.trace(`defined tables ${Array.from(s.keys())}`);for(let o in i)s.has(o)||(Vt.trace(`delete table class ${o}`),delete i[o])}else if(delete We[n],n==="data"){for(let i in jn)delete jn[i];delete jn[zT]}}let r=["hdb_temp","hdb_certificate","hdb_analytics","hdb_raw_analytics","hdb_session_will","hdb_job","hdb_license","hdb_info"];if(We.system)for(let n of r)We.system[n]&&(We.system[n].replicate=!1);return wd=null,We}function ku(){jT=!1;for(let[,e]of xa)e.needsDeletion=!0;ut();for(let[e,t]of xa)t.needsDeletion&&!e.endsWith("system.mdb")&&(t.close(),xa.delete(e),delete We[t.databaseName],KE.forEach(r=>r(t.databaseName)));return We}function $E(e,t,r=Cw,n,s){let i=new Iw.default(e,!1);try{let o=xa.get(e);o?o.needsDeletion=!1:(o=(0,Cd.open)(i),xa.set(e,o));let c=new Ol.default(!1),l=o.dbisDb||(o.dbisDb=o.openDB(KT.INTERNAL_DBIS_NAME,c)),u=o.auditStore;u||(n?(0,rs.existsSync)(n)&&(i.path=n,u=(0,Cd.open)(i),u.isLegacy=!0):u=IT(o));let d=BW(r),_=d[zT],E=new Map;for(let{key:f,value:h}of l.getRange({start:!1})){let[T,m]=f.toString().split("/");m===""?m=h.name:m||(m=T,T=t,h.name||(h.name=m,h.indexed=!h.is_hash_attribute)),_?.add(T);let g=E.get(T);g||E.set(T,g={attributes:[]}),(m==null||h.is_hash_attribute)&&(g.primary=h),m!=null&&g.attributes.push(h),Object.defineProperty(h,"key",{value:f,configurable:!0})}for(let[f,h]of E){let{attributes:T,primary:m}=h;if(!m){for(let j of T)if(j.is_hash_attribute||j.isPrimaryKey){m=j;break}if(!m){Vt.warn(`Unable to find a primary key attribute on table ${f}, with attributes: ${JSON.stringify(T)}`);continue}}let g=d[f],S={},y=[],I,U,H=typeof m.audit=="boolean"?m.audit:(0,er.get)(yr.CONFIG_PARAMS.LOGGING_AUDITLOG),X=m.trackDeletes,Y=m.expiration,V=m.eviction,ne=m.sealed,Q=m.splitSegments,de=m.replicate;if(g)S=g.indices,y=g.attributes,g.schemaVersion++;else{I=m.tableId,I?I>=(l.get(Nd)||0)&&(l.putSync(Nd,I+1),Vt.info(`Updating next table id (it was out of sync) to ${I+1} for ${f}`)):(m.tableId=I=l.get(Nd),I||(I=1),Vt.debug("Table {table_name} missing an id, assigning {table_id}"),l.putSync(Nd,I+1),l.putSync(m.key,m));let j=new Ol.default(!m.is_hash_attribute,m.is_hash_attribute);if(j.compression=m.compression,j.compression){let ae=(0,er.get)(yr.CONFIG_PARAMS.STORAGE_COMPRESSION_THRESHOLD)||vW;j.compression.threshold=ae}U=Nh(o.openDB(m.key,j)),o.databaseName=r,U.rootStore=o,U.tableId=I}for(let j of T){j.attribute=j.name;try{if(!j.is_hash_attribute&&(j.indexed||j.attribute&&!j.name)){if(!S[j.name]){let Oe=new Ol.default(!j.is_hash_attribute,j.is_hash_attribute);S[j.name]=o.openDB(j.key,Oe),S[j.name].indexNulls=j.indexNulls}let ae=y.find(Oe=>Oe.name===j.name);ae?y.splice(y.indexOf(ae),1,j):y.push(j)}}catch(ae){Vt.error("Error trying to update attribute",j,y,S,ae)}}if(!g){g=HW(d,f,VT({primaryStore:U,auditStore:u,audit:H,sealed:ne,splitSegments:Q,replicate:de,expirationMS:Y&&Y*1e3,evictionMS:V&&V*1e3,trackDeletes:X,tableName:f,tableId:I,primaryKey:m.name,databasePath:s?r+"/"+f:r,databaseName:r,indices:S,attributes:T,schemaDefined:m.schemaDefined,dbisDB:l})),g.schemaVersion=1;for(let j of VE)j(g)}}return o}catch(o){throw o.message+=` opening database ${e}`,o}}function BW(e){let t=We[e];if(t||(e==="data"?t=We[e]=jn:e==="system"?Object.defineProperty(We,"system",{value:t=Object.create(null),configurable:!0}):t=We[e]=Object.create(null)),wd&&!wd.has(e)){let r=new Set;t[zT]=r,wd.set(e,r)}return t}function HW(e,t,r){return e[t]=r,r}function Ql({database:e,table:t}){e||(e=Cw),ut();let r=BW(e),n=(0,Ut.join)((0,er.getHdbBasePath)(),yr.DATABASES_DIR_NAME),s=(0,er.get)(yr.CONFIG_PARAMS.DATABASES)||{};process.env.SCHEMAS_DATA_PATH&&(s.data={path:process.env.SCHEMAS_DATA_PATH});let i=t&&s[e]?.tables?.[t]?.path;n=i||s[e]?.path||process.env.STORAGE_PATH||(0,er.get)(yr.CONFIG_PARAMS.STORAGE_PATH)||((0,rs.existsSync)(n)?n:(0,Ut.join)((0,er.getHdbBasePath)(),yr.LEGACY_DATABASES_DIR_NAME));let o=(0,Ut.join)(n,(i?t:e)+".mdb"),c=xa.get(o);if(!c||c.status==="closed"){let l=new Iw.default(o,!1);c=(0,Cd.open)(l),xa.set(o,c)}return c.auditStore||(c.auditStore=IT(c)),c}async function xR(e){if(!We[e])throw new Error("Schema does not exist");let t=We[e],r;for(let n in t)r=t[n].primaryStore.rootStore,xa.delete(r.path),r.status==="open"&&(await r.close(),await YE.remove(r.path));if(r||(r=Ql({database:e,table:null}),r.status==="open"&&(await r.close(),await YE.remove(r.path))),e==="data"){for(let n in jn)delete jn[n];delete jn[zT]}delete We[e],KE.forEach(n=>n(e))}function Et(e){let{table:t,database:r,expiration:n,eviction:s,scanInterval:i,attributes:o,audit:c,sealed:l,splitSegments:u,replicate:d,trackDeletes:_,schemaDefined:E,origin:f}=e;r||(r=Cw);let h=Ql({database:r,table:t}),T=We[r];Vt.trace(`Defining ${t} in ${r}`);let m=T?.[t];if(h.status==="closed")throw new Error(`Can not use a closed data store for ${t}`);let g,S,y;E==null&&(E=!0);let I=new Ol.default(!1);for(let Q of o)Q.attribute&&!Q.name?(Q.name=Q.attribute,Q.indexed=!0):Q.attribute=Q.name,Q.expiresAt&&(Q.indexed=!0);let U,H;if(m){if(g=m.primaryKey,m.primaryStore.rootStore.status==="closed")throw new Error(`Can not use a closed data store from ${t} class`);u==null&&(u=m.splitSegments),m.attributes.splice(0,m.attributes.length,...o)}else{let Q=h.auditStore;S=o.find(Oe=>Oe.isPrimaryKey)||{},g=S.name,S.is_hash_attribute=S.isPrimaryKey=!0,S.schemaDefined=E,S.compression=Lm(),_&&(S.trackDeletes=!0),c=S.audit=typeof c=="boolean"?c:(0,er.get)(yr.CONFIG_PARAMS.LOGGING_AUDITLOG),n&&(S.expiration=n),s&&(S.eviction=s),S.splitSegments=!1,typeof l=="boolean"&&(S.sealed=l),typeof d=="boolean"&&(S.replicate=d),f&&(S.origins?S.origins.includes(f)||S.origins.push(f):S.origins=[f]),Vt.trace(`${t} table loading, opening primary store`);let de=new Ol.default(!1,!0);de.compression=S.compression;let j=t+"/";if(y=h.dbisDb=h.openDB(KT.INTERNAL_DBIS_NAME,I),ne(),y.get(j))return H&&H(),ku(),Et(e);let ae=Nh(h.openDB(j,de));h.databaseName=r,ae.rootStore=h,ae.tableId=y.get(Nd),Vt.trace(`Assigning new table id ${ae.tableId} for ${t}`),ae.tableId||(ae.tableId=1),y.put(Nd,ae.tableId+1),S.tableId=ae.tableId,m=HW(T,t,VT({primaryStore:ae,auditStore:Q,audit:c,sealed:l,splitSegments:u,replicate:d,trackDeletes:_,expirationMS:n&&n*1e3,evictionMS:s&&s*1e3,primaryKey:g,tableName:t,tableId:ae.tableId,databasePath:r,databaseName:r,indices:{},attributes:o,schemaDefined:E,dbisDB:y})),m.schemaVersion=1,U=!0,y.put(j,S)}let X=m.indices;y=y||(h.dbisDb=h.openDB(KT.INTERNAL_DBIS_NAME,I)),m.dbisDB=y;let Y=[];for(let{key:Q,value:de}of y.getRange({start:!0})){let[j,ae]=Q.toString().split("/");if(ae===""&&(ae=de.name),ae){if(j!==t)continue}else continue;let Oe=o.find(Me=>Me.name===ae),Ne=!Oe?.indexed&&de.indexed&&!de.isPrimaryKey;if((!Oe||Ne)&&(ne(),U=!0,Oe||y.remove(Q),Ne)){let Me=m.indices[j];Me&&Y.push(Me)}}let V=[];try{for(let Q of o||[]){if((Q.relationship||Q.computed)&&(U=!0,Q.relationship))continue;let de=t+"/"+(Q.name||"");Object.defineProperty(Q,"key",{value:de,configurable:!0});let j=y.get(de);if(Q.isPrimaryKey){if(j=j||y.get(de=t+"/")||{},c!==void 0&&c!==m.audit||l!==void 0&&l!==m.sealed||d!==void 0&&d!==m.replicate||(+n||void 0)!==(+j.expiration||void 0)||(+s||void 0)!==(+j.eviction||void 0)){let Oe={...j};typeof c=="boolean"&&(c&&m.enableAuditing(c),Oe.audit=c),n&&(Oe.expiration=+n),s&&(Oe.eviction=+s),l!==void 0&&(Oe.sealed=l),d!==void 0&&(Oe.replicate=d),U=!0,ne(),y.put(de,Oe)}continue}j?.attribute&&!j.name&&(j.indexed=!0);let ae=!j||j.type!==Q.type||j.indexed!==Q.indexed||j.nullable!==Q.nullable||j.version!==Q.version||JSON.stringify(j.properties)!==JSON.stringify(Q.properties)||JSON.stringify(j.elements)!==JSON.stringify(Q.elements);if(Q.indexed){let Oe=new Ol.default(!0,!1),Ne=h.openDB(de,Oe);(ae||j.indexingPID&&j.indexingPID!==process.pid||j.restartNumber<WE.workerData?.restartNumber)&&(U=!0,ne(),j=y.get(de),(ae||j.indexingPID&&j.indexingPID!==process.pid||j.restartNumber<WE.workerData?.restartNumber)&&(U=!0,Q.indexNulls===void 0&&(Q.indexNulls=!0),m.primaryStore.getStats().entryCount>0&&(Q.lastIndexedKey=j?.lastIndexedKey??void 0,Q.indexingPID=process.pid,Ne.isIndexing=!0,Object.defineProperty(Q,"dbi",{value:Ne}),V.push(Q))),y.put(de,Q)),j?.indexNulls&&Q.indexNulls===void 0&&(Q.indexNulls=!0),Ne.indexNulls=Q.indexNulls,X[Q.name]=Ne}else ae&&(U=!0,ne(),y.put(de,Q))}}finally{H&&H()}if(U&&(m.schemaVersion++,m.updatedAttributes()),Vt.trace(`${t} table loading, running index`),V.length>0||Y.length>0?m.indexingOperation=cTe(m,V,Y):U&&YT.signalSchemaChange(new WT.SchemaEventMsg(process.pid,"schema-change",m.databaseName,m.tableName)),m.origin=f,U)for(let Q of VE)Q(m,f!=="cluster");return(n||s||i)&&m.setTTLExpiration({expiration:n,eviction:s,scanInterval:i}),Vt.trace(`${t} table loaded`),m;function ne(){H||h.transactionSync(()=>({then(Q){H=Q}}))}a(ne,"startTxn")}async function cTe(e,t,r){try{Vt.info(`Indexing ${e.tableName} attributes`,t);let n=e.schemaVersion;await YT.signalSchemaChange(new WT.SchemaEventMsg(process.pid,"schema-change",e.databaseName,e.tableName));let s;for(let u of r)s=u.drop();let i,o={},c=0,l=t.length;if(await new Promise(u=>setImmediate(u)),l>0){let u;for(let _ of t)(0,Cd.compareKeys)(_.lastIndexedKey,u)<0&&(u=_.lastIndexedKey),_.lastIndexedKey==null&&_.dbi.clearAsync();let d=0;for(let{key:_,value:E,version:f}of e.primaryStore.getRange({start:u,lazy:l<4,versions:!0,snapshot:!1}))if(E){if(d++,s=e.primaryStore.ifVersion(_,f,()=>{for(let h=0;h<l;h++){let T=t[h],m=T.name;try{let g=T.resolve,S=E&&(g?g(E):E[m]),y=(0,MW.getIndexedValues)(S);if(y)for(let I=0,U=y.length;I<U;I++)T.dbi.put(y[I],_)}catch(g){o[m]||(o[m]=!0,Vt.error(`Error indexing attribute ${m}`,g))}}}),s.then(()=>d--,h=>{d--,Vt.error(h)}),WE.workerData&&WE.workerData.restartNumber!==UW.restartNumber&&(i=!0),++c%100===0||i){for(let h of t)h.lastIndexedKey=_,e.dbisDB.put(h.key,h);if(i)return}d>oTe?await s:d>aTe&&await new Promise(h=>setImmediate(h))}for(let _ of t)delete _.lastIndexedKey,delete _.indexingPID,_.dbi.isIndexing=!1,s=e.dbisDB.put(_.key,_)}await s,await YT.signalSchemaChange(new WT.SchemaEventMsg(process.pid,"indexing-finished",e.databaseName,e.tableName)),Vt.info(`Finished indexing ${e.tableName} attributes`,t)}catch(n){Vt.error("Error in indexing",n)}}function lTe({table:e,database:t}){let r=Ql({database:t,table:e}),n=[],s=r.dbisDb;for(let i of s.getKeys({start:e+"/",end:e+"0"}))n.push(s.remove(i));return Promise.all(n)}function Lc(e){return VE.push(e),{remove(){let t=VE.indexOf(e);t>-1&&VE.splice(t,1)}}}function of(e){return KE.push(e),{remove(){let t=KE.indexOf(e);t>-1&&KE.splice(t,1)}}}function Lm(){let e=(0,er.get)(yr.CONFIG_PARAMS.STORAGE_COMPRESSION),t=(0,er.get)(yr.CONFIG_PARAMS.STORAGE_COMPRESSION_DICTIONARY),r=(0,er.get)(yr.CONFIG_PARAMS.STORAGE_COMPRESSION_THRESHOLD)||vW,n={startingOffset:32};return t&&(n.dictionary=YE.readFileSync(t)),r&&(n.threshold=r),e&&n}var er,KT,Cd,Ut,rs,Id,Ol,Iw,yr,YE,ww,MW,YT,WT,WE,Vt,UW,Cw,zT,vW,jn,We,Nd,VE,KE,jT,xa,wd,oTe,aTe,Pe=Ie(()=>{er=L(se()),KT=L(Ht()),Cd=require("lmdb"),Ut=require("path"),rs=require("fs"),Id=L(gt());$f();Ol=L(c_()),Iw=L(l_()),yr=L(M()),YE=L(require("fs-extra")),ww=L(fi()),MW=L(cn()),YT=L(no()),WT=L(qs()),WE=require("worker_threads"),Vt=L(W()),UW=L(dt());Ji();vl();Cw="data",zT=Symbol("defined-tables"),vW=((0,er.get)(yr.CONFIG_PARAMS.STORAGE_PAGESIZE)||4096)-60;(0,er.initSync)();jn=Object.create(null),We=Object.create(null);(0,ww._assignPackageExport)("databases",We);(0,ww._assignPackageExport)("tables",jn);Nd=Symbol.for("next-table-id"),VE=[],KE=[],xa=new Map;a(iTe,"getTables");a(ut,"getDatabases");a(ku,"resetDatabases");a($E,"readMetaDb");a(BW,"ensureDB");a(HW,"setTable");a(Ql,"database");a(xR,"dropDatabase");a(Et,"table");oTe=1e3,aTe=10;a(cTe,"runIndexing");a(lTe,"dropTableMeta");a(Lc,"onUpdatedTable");a(of,"onRemovedDB");a(Lm,"getDefaultCompression")});var te=N((sUe,JW)=>{"use strict";var ka=require("path"),qW=require("fs-extra"),In=W(),xW=require("fs-extra"),QT=require("os"),uTe=require("net"),dTe=require("recursive-iterator"),Kt=M(),_Te=hg(),kW=require("papaparse"),JT=require("moment"),{inspect:fTe}=require("util"),FW=require("is-number"),nUe=require("lodash"),ETe=require("minimist"),hTe=require("https"),pTe=require("http"),{hdb_errors:XT}=_e(),mTe=/^((\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d:[0-5]\d\.\d+([+-][0-2]\d:[0-5]\d|Z))|(\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d:[0-5]\d([+-][0-2]\d:[0-5]\d|Z))|(\d{4}-[01]\d-[0-3]\dT[0-2]\d:[0-5]\d([+-][0-2]\d:[0-5]\d|Z)))$/,$W=require("util").promisify(setTimeout),STe=100,TTe=5,gTe="",ATe=4,GW={true:!0,TRUE:!0,FALSE:!1,false:!1,undefined:null,null:null,NULL:null,NaN:NaN};JW.exports={isEmpty:ns,isEmptyOrZeroLength:Wi,arrayHasEmptyValues:bTe,arrayHasEmptyOrZeroLengthValues:OTe,buildFolderPath:NTe,isBoolean:VW,errorizeMessage:RTe,stripFileExtension:wTe,autoCast:CTe,autoCastJSON:KW,autoCastJSONDeep:Pw,removeDir:DTe,compareVersions:PTe,isCompatibleDataVersion:LTe,escapeRawValue:MTe,unescapeValue:UTe,stringifyProps:vTe,timeoutPromise:HTe,isClusterOperation:kTe,getClusterUser:GTe,checkGlobalSchemaTable:FTe,getHomeDir:WW,getPropsFilePath:BTe,promisifyPapaParse:qTe,removeBOM:jW,createEventPromise:$Te,checkProcessRunning:VTe,checkSchemaTableExist:KTe,checkSchemaExists:zW,checkTableExists:QW,getStartOfTomorrowInSeconds:YTe,getLimitKey:WTe,isObject:ITe,isNotEmptyAndHasValue:yTe,autoCasterIsNumberCheck:YW,backtickASTSchemaItems:jTe,isPortTaken:xTe,createForkArgs:zTe,autoCastBoolean:QTe,async_set_timeout:$W,getTableHashAttribute:JTe,doesSchemaExist:XTe,doesTableExist:ZTe,stringifyObj:ege,ms_to_time:tge,changeExtension:rge,getEnvCliRootPath:Lw,noBootFile:nge,httpRequest:sge,transformReq:ige,convertToMS:oge,PACKAGE_ROOT:Kt.PACKAGE_ROOT};function RTe(e){return e instanceof Error?e:new Error(e)}a(RTe,"errorizeMessage");function ns(e){return e==null}a(ns,"isEmpty");function yTe(e){return!ns(e)&&(e||e===0||e===""||VW(e))}a(yTe,"isNotEmptyAndHasValue");function Wi(e){return ns(e)||e.length===0||e.size===0}a(Wi,"isEmptyOrZeroLength");function bTe(e){if(ns(e))return!0;for(let t=0;t<e.length;t++)if(ns(e[t]))return!0;return!1}a(bTe,"arrayHasEmptyValues");function OTe(e){if(Wi(e))return!0;for(let t=0;t<e.length;t++)if(Wi(e[t]))return!0;return!1}a(OTe,"arrayHasEmptyOrZeroLengthValues");function NTe(...e){try{return e.join(ka.sep)}catch{console.error(e)}}a(NTe,"buildFolderPath");function VW(e){return ns(e)?!1:e===!0||e===!1}a(VW,"isBoolean");function ITe(e){return ns(e)?!1:typeof e=="object"}a(ITe,"isObject");function wTe(e){return Wi(e)?gTe:e.slice(0,-ATe)}a(wTe,"stripFileExtension");function CTe(e){return ns(e)||e===""||typeof e!="string"?e:GW[e]!==void 0?GW[e]:YW(e)===!0?Number(e):mTe.test(e)?new Date(e):e}a(CTe,"autoCast");function KW(e){if(typeof e=="string"&&(e.startsWith("{")&&e.endsWith("}")||e.startsWith("[")&&e.endsWith("]")))try{return JSON.parse(e)}catch{}return e}a(KW,"autoCastJSON");function Pw(e){if(e&&typeof e=="object"){if(Array.isArray(e))for(let t=0,r=e.length;t<r;t++){let n=e[t],s=Pw(n);s!==n&&(e[t]=s)}else for(let t in e){let r=e[t],n=Pw(r);n!==r&&(e[t]=n)}return e}else return KW(e)}a(Pw,"autoCastJSONDeep");function YW(e){if(e.startsWith("0.")&&FW(e))return!0;let t=e.toUpperCase().includes("E");return!!((e!=="0"&&e.startsWith("0"))===!1&&t===!1&&FW(e))}a(YW,"autoCasterIsNumberCheck");async function DTe(e){if(Wi(e))throw new Error(`Directory path: ${e} does not exist`);try{await xW.emptyDir(e),await xW.remove(e)}catch(t){throw In.error(`Error removing files in ${e} -- ${t}`),t}}a(DTe,"removeDir");function PTe(e,t){if(Wi(e)){In.info("Invalid current version sent as parameter.");return}if(Wi(t)){In.info("Invalid upgrade version sent as parameter.");return}let r,n=/(\.0+)+$/,s=e.version?e.version:e,i=t.version?t.version:t,o=s.replace(n,"").split("."),c=i.replace(n,"").split("."),l=Math.min(o.length,c.length);for(let u=0;u<l;u++)if(r=parseInt(o[u],10)-parseInt(c[u],10),r)return r;return o.length-c.length}a(PTe,"compareVersions");function LTe(e,t,r=!1){let n=e.toString().split("."),s=t.toString().split(".");return n[0]===s[0]&&(!r||n[1]===s[1])}a(LTe,"isCompatibleDataVersion");function MTe(e){if(ns(e))return e;let t=String(e);return t==="."?Kt.UNICODE_PERIOD:t===".."?Kt.UNICODE_PERIOD+Kt.UNICODE_PERIOD:t.replace(Kt.FORWARD_SLASH_REGEX,Kt.UNICODE_FORWARD_SLASH)}a(MTe,"escapeRawValue");function UTe(e){if(ns(e))return e;let t=String(e);return t===Kt.UNICODE_PERIOD?".":t===Kt.UNICODE_PERIOD+Kt.UNICODE_PERIOD?"..":String(e).replace(Kt.ESCAPED_FORWARD_SLASH_REGEX,"/")}a(UTe,"unescapeValue");function vTe(e,t){if(ns(e))return In.info("Properties object is null"),"";let r="";return e.each(function(n,s){try{if(t&&t[n]){let i=t[n];for(let o of i)r+=";"+o+QT.EOL}!Wi(n)&&n[0]===";"?r+=" "+n+s+QT.EOL:Wi(n)||(r+=n+"="+s+QT.EOL)}catch{In.error(`Found bad property during upgrade with key ${n} and value: ${s}`)}}),r}a(vTe,"stringifyProps");function WW(){let e;try{e=QT.homedir()}catch{e=process.env.HOME}return e}a(WW,"getHomeDir");function BTe(){let e=ka.join(WW(),Kt.HDB_HOME_DIR_NAME,Kt.BOOT_PROPS_FILE_NAME);return qW.existsSync(e)||(e=ka.join(__dirname,"../","hdb_boot_properties.file")),e}a(BTe,"getPropsFilePath");function HTe(e,t){let r,n;return n=new Promise(function(s){r=setTimeout(function(){s(t)},e)}),{promise:n,cancel:a(function(){clearTimeout(r)},"cancel")}}a(HTe,"timeoutPromise");async function xTe(e){if(!e)throw new Error("Invalid port passed as parameter");return new Promise((t,r)=>{let n=uTe.createServer().once("error",s=>{s.code==="EADDRINUSE"?t(!0):r(s)}).once("listening",()=>n.once("close",()=>t(!1)).close()).listen(e)})}a(xTe,"isPortTaken");function kTe(e){try{return Kt.CLUSTER_OPERATIONS[e.toLowerCase()]!==void 0}catch(t){In.error(`Error checking operation against cluster ops ${t}`)}return!1}a(kTe,"isClusterOperation");function FTe(e,t){let r=(Pe(),oe(lt)).getDatabases();if(!r[e])return XT.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e);if(!r[e][t])return XT.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(FTe,"checkGlobalSchemaTable");function GTe(e,t){if(ns(t)){In.warn("No CLUSTERING_USER defined, clustering disabled");return}if(ns(e)||Wi(e)){In.warn("No users to search.");return}let r;try{let n=e.get(t);n&&n.role.permission.cluster_user===!0&&n.active===!0&&(r=n)}catch(n){In.error(`unable to find cluster_user due to: ${n.message}`);return}if(r===void 0){In.warn(`CLUSTERING_USER: ${t} not found or is not active.`);return}return r}a(GTe,"getClusterUser");function qTe(){kW.parsePromise=function(e,t,r){return new Promise(function(n,s){kW.parse(e,{header:!0,transformHeader:jW,chunk:t.bind(null,s),skipEmptyLines:!0,transform:r,dynamicTyping:!1,error:s,complete:n})})}}a(qTe,"promisifyPapaParse");function jW(e){if(typeof e!="string")throw new TypeError(`Expected a string, got ${typeof e}`);return e.charCodeAt(0)===65279?e.slice(1):e}a(jW,"removeBOM");function $Te(e,t,r){return new Promise(n=>{t.once(e,s=>{let i=r;In.info(`Got cluster status event response: ${fTe(s)}`);try{i.cancel()}catch{In.error("Error trying to cancel timeout.")}n(s)})})}a($Te,"createEventPromise");async function VTe(e){let t=!0,r=0;do await $W(STe*r++),(await _Te.findPs(e)).length>0&&(t=!1);while(t&&r<TTe);if(t)throw new Error(`process ${e} was not started`)}a(VTe,"checkProcessRunning");function KTe(e,t){let r=zW(e);if(r)return r;let n=QW(e,t);if(n)return n}a(KTe,"checkSchemaTableExist");function zW(e){let{getDatabases:t}=(Pe(),oe(lt));if(!t()[e])return XT.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(zW,"checkSchemaExists");function QW(e,t){let{getDatabases:r}=(Pe(),oe(lt));if(!r()[e][t])return XT.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(QW,"checkTableExists");function YTe(){let e=JT().utc().add(1,Kt.MOMENT_DAYS_TAG).startOf(Kt.MOMENT_DAYS_TAG).unix(),t=JT().utc().unix();return e-t}a(YTe,"getStartOfTomorrowInSeconds");function WTe(){return JT().utc().format("DD-MM-YYYY")}a(WTe,"getLimitKey");function jTe(e){try{let t=new dTe(e);for(let{node:r}of t)r&&(r.columnid&&typeof r.columnid!="string"&&(r.columnid=r.columnid.toString()),r.columnid&&!r.columnid.startsWith("`")&&(r.columnid_orig=r.columnid,r.columnid=`\`${r.columnid}\``),r.tableid&&!r.tableid.startsWith("`")&&(r.tableid_orig=r.tableid,r.tableid=`\`${r.tableid}\``),r.databaseid&&!r.databaseid.startsWith("`")&&(r.databaseid_orig=r.databaseid,r.databaseid=`\`${r.databaseid}\``),r.as&&typeof r.as=="string"&&!r.as.startsWith("[")&&(r.as_orig=r.as,r.as=`\`${r.as}\``))}catch(t){In.error("Got an error back ticking items."),In.error(t)}}a(jTe,"backtickASTSchemaItems");function zTe(e){return[e]}a(zTe,"createForkArgs");function QTe(e){return e===!0||typeof e=="string"&&e.toLowerCase()==="true"}a(QTe,"autoCastBoolean");function JTe(e,t){let{getDatabases:r}=(Pe(),oe(lt)),n=r()[e]?.[t];return n?.primaryKey||n?.hash_attribute}a(JTe,"getTableHashAttribute");function XTe(e){let{getDatabases:t}=(Pe(),oe(lt));return t()[e]!==void 0}a(XTe,"doesSchemaExist");function ZTe(e,t){let{getDatabases:r}=(Pe(),oe(lt));return r()[e]?.[t]!==void 0}a(ZTe,"doesTableExist");function ege(e){try{return JSON.stringify(e)}catch{return e}}a(ege,"stringifyObj");function tge(e){let t=JT.duration(e),r=t.seconds()>0?t.seconds()+"s":"",n=t.minutes()>0?t.minutes()+"m ":"",s=t.hours()>0?t.hours()+"h ":"",i=t.days()>0?t.days()+"d ":"";return(t.years()>0?t.years()+"y ":"")+i+s+n+r}a(tge,"ms_to_time");function rge(e,t){let r=ka.basename(e,ka.extname(e));return ka.join(ka.dirname(e),r+t)}a(rge,"changeExtension");function Lw(){if(process.env[Kt.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return process.env[Kt.CONFIG_PARAMS.ROOTPATH.toUpperCase()];let e=ETe(process.argv);if(e[Kt.CONFIG_PARAMS.ROOTPATH.toUpperCase()])return e[Kt.CONFIG_PARAMS.ROOTPATH.toUpperCase()]}a(Lw,"getEnvCliRootPath");var Dw;function nge(){if(Dw)return Dw;let e=Lw();if(Lw()&&qW.pathExistsSync(ka.join(e,Kt.HDB_CONFIG_FILE)))return Dw=!0,!0}a(nge,"noBootFile");function sge(e,t){let r;return e.protocol==="http:"?r=pTe:r=hTe,new Promise((n,s)=>{let i=r.request(e,o=>{o.setEncoding("utf8"),o.body="",o.on("data",c=>{o.body+=c}),o.on("end",()=>{n(o)})});i.on("error",o=>{s(o)}),i.write(t instanceof Buffer?t:JSON.stringify(t)),i.end()})}a(sge,"httpRequest");function ige(e){if(!e.schema&&!e.database){e.schema=Kt.DEFAULT_DATABASE_NAME;return}e.database&&(e.schema=e.database)}a(ige,"transformReq");function oge(e){let t=0;if(typeof e=="number"&&(t=e),typeof e=="string")switch(t=parseFloat(e),e.slice(-1)){case"M":t*=86400*30;break;case"D":case"d":t*=86400;break;case"H":case"h":t*=3600;break;case"m":t*=60;break}return t*1e3}a(oge,"convertToMS")});var ZW=N((aUe,XW)=>{"use strict";var Mw=M(),age=te(),cge=Di(),ui=W(),lge=Sm(),uge=mf(),oUe=xu(),dge=ls(),_ge=Rf(),fge=require("semver/functions/gte"),Ege=3e4,hge=7;XW.exports=pge;async function pge(){try{ui.notify("Starting update nodes. This process will attempt to update any node connections the need to be reestablished after a 4.0.0 upgrade"),await dge.setSchemaDataToGlobalAsync();let e=await cge.getAllNodeRecords(),t=[];for(let r=0,n=e.length;r<n;r++){let s=e[r];s.system_info.hdb_version===Mw.PRE_4_0_0_VERSION&&t.push(mge(s))}await Promise.allSettled(t),ui.notify("Shutting down 4.0.0 clustering upgrade process")}catch(e){throw ui.error(e),e}}a(pge,"updateAllNodes");async function mge(e){try{let{name:t,subscriptions:r}=e;ui.notify("Running 4.0.0 update on node:",t);let n=!1,s=0;for(;s<hge;){let i=[];if(await lge.buildNodeStatus(e,i),ui.trace("Received status:",i[0].status,"from node:",t),i[0].status==="open"&&fge(i[0].system_info.hdb_version,"4.0.0")){ui.notify("Received open status from node:",t,"calling add node");let o={operation:Mw.OPERATIONS_ENUM.ADD_NODE,node_name:t,subscriptions:r};await uge(o,!0),ui.notify("Successfully added node",t),n=!0;break}s=(Date.now()-e.__updatedtime__)/(1e3*60*60*24),ui.trace("Update node has been running for",s,"days. Calling node status again for node:",t),await age.async_set_timeout(Ege)}n||(ui.error("4.0.0 node update was unable to update connection to node:",t),ui.error("Removing following node record from hdb_nodes",e),await _ge({operation:Mw.OPERATIONS_ENUM.REMOVE_NODE,node_name:t}))}catch(t){throw ui.error(t),t}}a(mge,"updateNode")});var Sge=ZW();(async()=>{try{await Sge()}catch(e){console.error("Error launching 4.0.0 node update"),console.error(e),process.exit(1)}})();
|