harperdb 4.3.40 → 4.3.41
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 +1 -1
- package/bin/lite.js +1 -1
- package/launchServiceScripts/launchInstallNATSServer.js +1 -1
- package/launchServiceScripts/launchNatsIngestService.js +1 -1
- package/launchServiceScripts/launchNatsReplyService.js +1 -1
- package/launchServiceScripts/launchUpdateNodes4-0-0.js +1 -1
- package/npm-shrinkwrap.json +30 -30
- package/package.json +2 -2
- package/server/jobs/jobProcess.js +1 -1
- package/server/threads/threadServer.js +1 -1
- package/studio/build-local/asset-manifest.json +2 -2
- package/studio/build-local/index.html +1 -1
- package/studio/build-local/static/js/{main.6fe75e34.js → main.870bbedf.js} +2 -2
- package/utility/scripts/restartHdb.js +1 -1
- /package/studio/build-local/static/js/{main.6fe75e34.js.LICENSE.txt → main.870bbedf.js.LICENSE.txt} +0 -0
|
@@ -6,7 +6,7 @@ Caused by:`));else if(typeof _=="object")try{n+=JSON.stringify(_)}catch{n+="Obje
|
|
|
6
6
|
`).slice(1)){s=s.trim();let[i]=s.split(" ",1),o=s.slice(i.length+1).trim();t[i]===void 0&&(t[i]={}),t[i][r]=o}}))}catch(r){throw r}return Object.entries(t).filter(([,r])=>r.comm&&r.args&&r.ppid&&r.uid&&r["%cpu"]&&r["%mem"]&&r.args.includes(e)).map(([r,n])=>({pid:Number.parseInt(r,10),name:Dk.basename(n.comm),cmd:n.args,ppid:Number.parseInt(n.ppid,10),uid:Number.parseInt(n.uid,10),cpu:Number.parseFloat(n["%cpu"]),memory:Number.parseFloat(n["%mem"])}))}a(Uk,"findPs")});var dt=g((Foe,MO)=>{"use strict";var vk="__dbis__",Bk="__txns__",Hk="__environment_name__",xk="__dbi_defintion__",Gk={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"},Fk=["__createdtime__","__updatedtime__"],qk="\uFFFF",LO={TIMESTAMP:"timestamp",HASH_VALUE:"hash_value",USER_NAME:"user_name"},kk=Object.values(LO);MO.exports={AUDIT_STORE_NAME:Bk,INTERNAL_DBIS_NAME:vk,DBI_DEFINITION_NAME:xk,SEARCH_TYPES:Gk,TIMESTAMP_NAMES:Fk,MAX_SEARCH_KEY_LENGTH:256,ENVIRONMENT_NAME_KEY:Hk,TRANSACTIONS_DBI_NAMES_ENUM:LO,TRANSACTIONS_DBIS:kk,OVERFLOW_MARKER:qk}});var vr=g((qoe,qO)=>{"use strict";var PO=U(),UO=dt(),vO={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},BO=a(e=>`${e} Check logs and try again.`,"CHECK_LOGS_WRAPPER"),HO={500:BO("There was an error processing your request."),400:"Invalid request"},Vk=HO[vO.INTERNAL_SERVER_ERROR],$k={OP_NOT_SUPPORTED_FOR_FS:e=>`${e} is not available for this instance because it uses the File System data store.`,MISSING_VALUE:e=>`${e} is missing.`,INVALID_VALUE:e=>`${e} is invalid.`,NOT_FOUND:e=>`${e} not found.`},Yk={CONFIG_VALIDATION:e=>`HarperDB config file validation error: ${e}`},Kk={DEFAULT_BULK_LOAD_ERR:"There was an error during your bulk load into HarperDB.",DOWNLOAD_FILE_ERR:e=>`There was an error downloading '${e}'.`,INSERT_JSON_ERR:"There was an error inserting the downloaded JSON data.",INSERT_CSV_ERR:"There was an error inserting the downloaded CSV data.",INVALID_ACTION_PARAM_ERR:e=>`Bulk load operation failed - ${e} is not a valid 'action' parameter`,INVALID_FILE_EXT_ERR:e=>`Error selecting correct parser - valid file type not found in json - ${e}`,MAX_FILE_SIZE_ERR:(e,t)=>`File size is ${e} bytes, which exceeded the maximum size allowed of: ${t} bytes`,PAPA_PARSE_ERR:"There was an error parsing the downloaded CSV data.",S3_DOWNLOAD_ERR:e=>`There was an error downloading '${e}' from AWS.`,WRITE_TEMP_FILE_ERR:"Error writing temporary file to storage"},Wk={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 ${UO.INTERNAL_DBIS_NAME}`,CANNOT_DROP_INTERNAL_DBIS_NAME:`cannot drop a dbi named ${UO.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"},Qk={ATTR_NAME_LENGTH_ERR:e=>`transaction aborted due to attribute name ${e} being too long. Attribute names cannot be longer than ${PO.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE} bytes.`,ATTR_NAME_NULLISH_ERR:"transaction aborted due to record(s) with an attribute name that is null, undefined or empty string",HASH_VAL_LENGTH_ERR:`transaction aborted due to record(s) with a hash value that exceeds ${PO.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"},xO={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"},zk={DEFAULT_INVALID_REQUEST:"Invalid request",OP_AUTH_PERMS_ERROR:"This operation is not authorized due to role restrictions and/or invalid database items",OP_IS_SU_ONLY:e=>`Operation '${e}' is restricted to 'super_user' roles`,OP_NOT_FOUND:e=>`Operation '${e}' not found`,SYSTEM_TIMESTAMP_PERMS_ERR:"Internal timestamp attributes - '__createdtime_' and '__updatedtime__' - cannot be inserted to or updated by HDB users.",UNKNOWN_OP_AUTH_ERROR:(e,t,r)=>`There was an error authorizing ${e} op on table '${t}.${r}'`,USER_HAS_NO_PERMS:e=>`User ${e} has no role or permissions. Please assign the user a valid role.`,DROP_SYSTEM:"The 'system' database, tables and records are used internally by HarperDB and cannot be updated or removed."},Jk={ATTR_PERM_MISSING:(e,t)=>`${e.toUpperCase()} attribute permission missing for '${t}'`,ATTR_PERM_MISSING_NAME:"Permission object in 'attribute_permission' missing an 'attribute_name'",ATTR_PERM_NOT_BOOLEAN:(e,t)=>`${e.toUpperCase()} attribute permission for '${t}' must be a boolean`,ATTR_PERMS_ARRAY_MISSING:"Missing 'attribute_permissions' array",ATTR_PERMS_NOT_ARRAY:"Value for 'attribute_permissions' must be an array",INVALID_ATTRIBUTE_IN_PERMS:e=>`Invalid attribute '${e}' in 'attribute_permissions'`,INVALID_PERM_KEY:e=>`Invalid table permission key value '${e}'`,INVALID_ATTR_PERM_KEY:e=>`Invalid attribute permission key value '${e}'`,INVALID_ROLE_JSON_KEYS:e=>`Invalid ${e.length>1?"keys":"key"} in JSON body - '${e.join("', '")}'`,MISMATCHED_TABLE_ATTR_PERMS:e=>`You have a conflict with TABLE permissions for '${e}' being false and ATTRIBUTE permissions being true`,OUTDATED_PERMS_TRANSLATION_ERROR:"This instance was recently upgraded and uses our new role permissions structure. Please login to this instance in HarperDB Studio, go to 'Roles', and click 'Update Role Permission' for all standard roles to migrate them to the new structure.",ROLE_ALREADY_EXISTS:e=>`A role with name '${e}' already exists`,ROLE_NOT_FOUND:"Role not found",ROLE_PERMS_ERROR:"Errors in the role permissions JSON provided",SCHEMA_PERM_ERROR:e=>`Your role does not have permission to view database metadata for '${e}'`,SCHEMA_TABLE_PERM_ERROR:(e,t)=>`Your role does not have permission to view database.table metadata for '${e}.${t}'`,SU_ROLE_MISSING_ERROR:"Missing 'super_user' key/value in permission set",SU_CU_ROLE_BOOLEAN_ERROR:e=>`Value for '${e}' permission must be a boolean`,STRUCTURE_USER_ROLE_TYPE_ERROR:e=>`Value for '${e}' permission must be a boolean or Array`,SU_CU_ROLE_NO_PERMS_ALLOWED:e=>`Roles with '${e}' set to true cannot have other permissions set.`,SU_CU_ROLE_COMBINED_ERROR:"Roles cannot have both 'super_user' and 'cluster_user' values included in their permissions set.",TABLE_PERM_MISSING:e=>`Missing table ${e.toUpperCase()} permission`,TABLE_PERM_NOT_BOOLEAN:e=>`Table ${e.toUpperCase()} permission must be a boolean`},Xk={ATTR_NOT_FOUND:(e,t,r)=>`Attribute '${r}' does not exist on '${e}.${t}'`,ATTR_EXISTS_ERR:(e,t,r)=>`Attribute '${r}' already exists in ${e}.${t}'`,DESCRIBE_ALL_ERR:"There was an error during describeAll. Please check the logs and try again.",INVALID_TABLE_ERR:e=>`Invalid table ${JSON.stringify(e)}`,SCHEMA_NOT_FOUND:e=>`database '${e}' does not exist`,SCHEMA_EXISTS_ERR:e=>`database '${e}' already exists`,TABLE_EXISTS_ERR:(e,t)=>`Table '${t}' already exists in '${e}'`,SCHEMA_REQUIRED_ERR:"database is required",TABLE_NOT_FOUND:(e,t)=>`Table '${e}.${t}' does not exist`,TABLE_REQUIRED_ERR:"table is required"},jk={OUTER_JOIN_TRANSLATION_ERROR:"There was an error translating the final SQL outer join data."},Zk={ALTER_USER_DUP_ROLES:e=>`Update failed. There are duplicates for the '${e}' role which is not allowed. Update your roles and try again.`,ALTER_USER_ROLE_NOT_FOUND:e=>`Update failed. Requested '${e}' role not found.`,DUP_ROLES_FOUND:e=>`Multiple ${e} roles found. Roles must have unique 'role' value. Please update and try again.`,ROLE_NAME_NOT_FOUND:e=>`${e} role not found`,USER_ALREADY_EXISTS:e=>`User ${e} already exists`,USER_NOT_EXIST:e=>`User ${e} does not exist`},GO={INVALID_DATE:"Invalid date, must be in ISO-8601 format (YYYY-MM-DD).",SEARCH_CONDITIONS_INVALID_SORT_ATTRIBUTE:e=>`invalid sort attribute '${e}', the attribute must either be the table's hash attribute or an attribute used in conditions.`},FO={INVALID_ITC_DATA_TYPE:"Invalid ITC event data type, must be an object",MISSING_TYPE:"ITC event missing 'type'",MISSING_MSG:"ITC event missing 'message'",MISSING_ORIGIN:"ITC event message missing 'originator' property",INVALID_EVENT:e=>`ITC server received invalid event type: ${e}`},eV={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."},tV={CLUSTERING_NOT_ENABLED:"Clustering must be enabled to perform this operation."},rV={...xO,...Kk,...$k,...zk,...Jk,...Xk,...jk,...Zk,...Qk,...GO,...FO,...eV,...tV,...Yk};qO.exports={CHECK_LOGS_WRAPPER:BO,HDB_ERROR_MSGS:rV,DEFAULT_ERROR_MSGS:HO,DEFAULT_ERROR_RESP:Vk,HTTP_STATUS_CODES:vO,LMDB_ERRORS_ENUM:Wk,AUTHENTICATION_ERROR_MSGS:xO,VALIDATION_ERROR_MSGS:GO,ITC_ERRORS:FO}});var se=g((Voe,$O)=>{"use strict";var ko=vr(),nV=K(),sV=U(),c_=class extends Error{static{a(this,"HdbError")}constructor(t,r,n,s,i){super(),Error.captureStackTrace(this,kO),this.statusCode=n||ko.HTTP_STATUS_CODES.INTERNAL_SERVER_ERROR,this.http_resp_msg=r||(ko.DEFAULT_ERROR_MSGS[n]?ko.DEFAULT_ERROR_MSGS[n]:ko.DEFAULT_ERROR_MSGS[ko.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&&nV[s](i)}},xh=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}},Gh=class extends Error{static{a(this,"ServerError")}constructor(t,r){super(t),this.statusCode=r||500}};function kO(e,t,r,n=sV.LOG_LEVELS.ERROR,s=null,i=!1){if(VO(e))return e;let o=new c_(e,t,r,n,s);return i&&delete o.stack,o}a(kO,"handleHDBError");function VO(e){return e.__proto__.constructor.name===c_.name}a(VO,"isHDBError");$O.exports={isHDBError:VO,handleHDBError:kO,ClientError:xh,ServerError:Gh,hdb_errors:ko}});var KO=g((Yoe,YO)=>{"use strict";var iV={key:"-----BEGIN RSA PRIVATE KEY-----\rMIIEowIBAAKCAQEArBFJQRfFiJku/KwhV1Ssp7cX61vvuKmd4Rp6A9jB2QLgx8nj\r/+Xhp2hPRkISnOA8BuAxr4dMD9syGJwX4kNy9mbZ5Q0fWZCiEGBpVcU1J+k+N5K4\rSuZ2SqgxeN2IN2RLzt3GyQY4imcdHgNv7aHoXUrEwBx0MeYEw3IIDXtrYKCR2D8I\rvWBfwMUgWa24G8lpWILWA5hd9srRz9NxlAiHSjhbgT7B0xruEpHRCHSyKjvaIJVt\rWBR+amejYsAKVrD/hgrqjsA1123Y6++YqvU6vwg64xhS2kz5r3dkNKhvwbWgpZdI\rIaRvsiB77f4kLGo0vi8RFgJ1ZRjGg3RRK2w1LQIDAQABAoIBAQCEOmh78EOpnGZC\rYBjjHrvrysVD5gvLcfVUtl8Ls7gMB60re1eOIF+PoZZCHKZnDd6zPfiQtj1adg0C\rYnnsM/8VoaZS4gm0b3RLd3ubIQifWhuo40RissY2yxfxlPSH9LhZCY8ojnJG0cTL\resK579E8WCfopjUY33XLqEbN7Ylv39J+DSqInjqV3efJZUa+HqUJ98VxxzodcKMD\rP3bwUU4gHoSSp4pAsOFH5sQhaIWH1IcNjrAwpee2cJQuh4G157RRIuuUpagtaEG/\rXJIiAyBguJyu3JQFnIBQF01N5+omJgXYJ1L0m54543/iIRThmF3zDCDgCyUzmOk+\rH6As9fv1AoGBANOpOtOZLSAScjGsgJamT3ceJ2wCa86g2j8Oxu8lJUmUp5s3tA0v\rBFW5O3S4KR1EXwkLMBUMrfFM8YvzHWxsXBI6XV8azGLvyqPHxr65OhmpGYkGZMXu\rn9okgjkqlewnY2I073gvyK7ppX51UL5y9fF1vlsk+UlW+Rgx/vMHbdcjAoGBANAc\rxRUsxs4QJpbS4zD3JOkHjr24a97TrS3kCybAHUMpR2NrEHPZw9zex0/aphOJUHfL\rIMkOZdpfDqMfxWy4FAEmqBEMkO2SB+h0Wp4P+qp81ax4vGFiB0cD3wtixr11U1tt\rlZ/ZTdv4VDpDFNK1KaplhTDeyuCjeYfS3/GJia9vAoGAcOsAgjBevZR5rXx84WH6\rVO8WUu37u7FenXNxt9VWTinrPMh72uixZFY8nOk+rely1e1NCn3IMko9Ns9NbDFm\r8SaH95vhXArXTYbfxZIlp9jp0YtCqcHDL+p4Oq04bFMbFyJseu7rHj1x18QYfnHw\rOY/6LL/N6k1m+Hx7qgXVmIcCgYB/w0nTCBw84XlvWqSTqQaF8VfWbWP79mP5KmkW\rLxdH5g2noVEGbohqDnK6OXd/wusdwByukiJBf94Skyy25AOT+VFwthA7aU1ljhkb\rtJ+lDuJ28eBkwLPLCzthWBC+u0qjdJFJAzVjd/7tjcU43nNn4s90AzL12iaAFhvZ\rwyA+DQKBgGc/4cdyGJ3YkcA8150gQBawgJZ7q8V1JND87ggWA8wnK3cHn7rMZQl2\r3emDp9HEFXFex5dbGDDqZFAoesZCDxjknIn9oNfW4PvaWS8q7b6ZKLZG1p03Pu7/\rtYaD0kPbo0kysfFT/co+NgHbdykvIyboomfGdNLTUjYuy6lpwpvs\r-----END RSA PRIVATE KEY-----\r".replace(/\r/g,`\r
|
|
7
7
|
`),cert:"-----BEGIN CERTIFICATE-----\rMIIDXDCCAkSgAwIBAgIFNTE4MzQwDQYJKoZIhvcNAQELBQAwXTEXMBUGA1UEAxMO\rSGFycGVyREIsIEluYy4xCzAJBgNVBAYTAlVTMQswCQYDVQQIEwJDTzEPMA0GA1UE\rBxMGRGVudmVyMRcwFQYDVQQKEw5IYXJwZXJEQiwgSW5jLjAeFw0yMjAzMTEyMzAz\rNDlaFw0yNzAzMTAyMzAzNDlaMF0xFzAVBgNVBAMTDkhhcnBlckRCLCBJbmMuMQsw\rCQYDVQQGEwJVUzELMAkGA1UECBMCQ08xDzANBgNVBAcTBkRlbnZlcjEXMBUGA1UE\rChMOSGFycGVyREIsIEluYy4wggEiMA0GCSqGSIb3DQEBAQUAA4IBDwAwggEKAoIB\rAQCsEUlBF8WImS78rCFXVKyntxfrW++4qZ3hGnoD2MHZAuDHyeP/5eGnaE9GQhKc\r4DwG4DGvh0wP2zIYnBfiQ3L2ZtnlDR9ZkKIQYGlVxTUn6T43krhK5nZKqDF43Yg3\rZEvO3cbJBjiKZx0eA2/toehdSsTAHHQx5gTDcggNe2tgoJHYPwi9YF/AxSBZrbgb\ryWlYgtYDmF32ytHP03GUCIdKOFuBPsHTGu4SkdEIdLIqO9oglW1YFH5qZ6NiwApW\rsP+GCuqOwDXXbdjr75iq9Tq/CDrjGFLaTPmvd2Q0qG/BtaCll0ghpG+yIHvt/iQs\rajS+LxEWAnVlGMaDdFErbDUtAgMBAAGjIzAhMA8GA1UdEwEB/wQFMAMBAf8wDgYD\rVR0PAQH/BAQDAgIEMA0GCSqGSIb3DQEBCwUAA4IBAQASR4YW/rPK7PNArHVe9zzM\rb0rKNX/2T9/0nybRhmE/+hdlSgliTAeebmwkUS2APckmekYt/q2ZY2NS65Fo/jjp\rG8TJrtcF4h+ylVqUp0ZXQLFtIsr7r2JZA7hJ6njW6G4DHSZ0gxtECLi4CBlTjzm5\rNmnmIDObvGRTuqmcdAZmXeObbta/He2XIzietukPAYX062pNM+G5XT5UM1eG/Vlp\rN86vjhpyI+ffKy+C60SJqxmKM3ydgN7oLscE7+2wLPN25XqN4W99OwGsp5dTdu/f\r5lPtFayXdJ55e/sNQKmGN+UGLrL05c2MWgjb8U/LFilnupUianceoeSERZmVjzKX\r-----END CERTIFICATE-----\r".replace(/\r/g,`\r
|
|
8
8
|
`)},oV="certificate.pem",aV="privateKey.pem",cV="ca.pem";YO.exports={CERTIFICATE_VALUES:iV,CERTIFICATE_PEM_NAME:oV,PRIVATEKEY_PEM_NAME:aV,CA_PEM_NAME:cV}});var st=g((Koe,WO)=>{"use strict";var dr=require("validate.js");dr.validators.type=function(e,t,r,n){return e===null||typeof e>"u"||dr.validators.type.checks[t](e)?null:` must be a '${t}' value`};dr.validators.type.checks={Object:function(e){return dr.isObject(e)&&!dr.isArray(e)},Array:dr.isArray,Integer:dr.isInteger,Number:dr.isNumber,String:dr.isString,Date:dr.isDate,Boolean:function(e){return typeof e=="boolean"}};dr.validators.hasValidFileExt=function(e,t){return dr.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};WO.exports={validateObject:lV,validateObjectAsync:uV,validateBySchema:_V};function lV(e,t){if(!e||!t)return new Error("validateObject parameters were null");let r=dr(e,t,{format:"flat"});return r?new Error(r):null}a(lV,"validateObject");async function uV(e,t){if(!e||!t)return new Error("validateObject parameters were null");try{await dr.async(e,t,{format:"flat"})}catch(r){let n=r.join(",");return new Error(n)}return null}a(uV,"validateObjectAsync");function _V(e,t){let r=t.validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}});if(r.error)return new Error(r.error.message)}a(_V,"validateBySchema")});var Fh=g((zoe,ZO)=>{"use strict";var XO=require("fs-extra"),ae=require("joi"),dV=require("os"),{boolean:be,string:Zt,number:je,array:l_}=ae.types(),{totalmem:QO}=require("os"),Hi=require("path"),fV=K(),u_=J(),Qoe=KO(),zO=U(),EV=st(),JO="log",hV="components",mV="Invalid logging.rotation.maxSize unit. Available units are G, M or K",pV="Invalid logging.rotation.interval unit. Available units are D, H or M (minutes)",SV="Invalid logging.rotation.maxSize value. Value should be a number followed by unit e.g. '10M'",TV="Invalid logging.rotation.interval value. Value should be a number followed by unit e.g. '10D'",gV="rootPath config parameter is undefined",RV="clustering.enabled config parameter is undefined",xi=je.min(0).required(),__=l_.items({host:Zt.required(),port:xi}).empty(null),zn,jO=!1;ZO.exports={configValidator:AV,routesValidator:wV,route_constraints:__};function AV(e,t=!1){if(jO=t,zn=e.rootPath,u_.isEmpty(zn))throw gV;let r=be.required(),n=je.min(0).max(1e3).empty(null).default(IV),s=Zt.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path").empty(null).default(Tc),i=Zt.optional().empty(null),o=Zt.pattern(/^[^\s.,*>]+$/).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >"}).empty(null).required(),c=ae.string().empty(null).default(Tc),l=ae.custom(bV).empty(null).default(Tc),_=e.clustering?.enabled;if(u_.isEmpty(_))throw RV;let u=ae.object({certificate:i,certificateAuthority:i,privateKey:i}),d;return _===!0?d=ae.object({enabled:r,hubServer:ae.object({cluster:ae.object({name:ae.required().empty(null),network:ae.object({port:xi,routes:__}).required()}).required(),leafNodes:ae.object({network:ae.object({port:xi}).required()}).required(),network:ae.object({port:xi}).required()}).required(),leafServer:ae.object({network:ae.object({port:xi,routes:__}).required(),streams:ae.object({maxAge:je.min(120).allow(null).optional(),maxBytes:je.min(1).allow(null).optional(),maxMsgs:je.min(1).allow(null).optional(),path:c}).required()}).required(),logLevel:ae.valid("error","warn","info","debug","trace"),nodeName:o,republishMessages:be.optional(),databaseLevel:be.optional(),tls:ae.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:be.required(),verify:be.optional()}),user:Zt.optional().empty(null)}).required():d=ae.object({enabled:r,tls:ae.object({certificate:i,certificateAuthority:i,privateKey:i,insecure:be.required()})}).required(),ae.object({authentication:ae.object({authorizeLocal:be,cacheTTL:je.required(),enableSessions:be}),analytics:ae.object({aggregatePeriod:je}),componentsRoot:s.optional(),clustering:d,localStudio:ae.object({enabled:r}).required(),logging:ae.object({auditAuthEvents:ae.object({logFailed:be,logSuccessful:be}),file:be.required(),level:ae.valid("notify","fatal","error","warn","info","debug","trace"),rotation:ae.object({enabled:be.optional(),compress:be.optional(),interval:Zt.custom(NV).optional().empty(null),maxSize:Zt.custom(yV).optional().empty(null),path:Zt.optional().empty(null).default(Tc)}).required(),root:s,stdStreams:be.required(),auditLog:be.required()}).required(),operationsApi:ae.object({network:ae.object({cors:be.optional(),corsAccessList:l_.optional(),headersTimeout:je.min(1).optional(),keepAliveTimeout:je.min(1).optional(),port:je.optional().empty(null),domainSocket:ae.optional().empty("hdb/operations-server").default(Tc),securePort:je.optional().empty(null),timeout:je.min(1).optional()}).optional(),tls:ae.alternatives([ae.array().items(u),u])}).required(),rootPath:Zt.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path").required(),mqtt:ae.object({network:ae.object({port:xi,securePort:xi,mtls:ae.alternatives([be.optional(),ae.object({user:Zt.optional(),certificateAuthority:i,required:be.optional()})])}).required(),webSocket:be.optional(),requireAuthentication:be.optional()}),http:ae.object({compressionThreshold:je.optional(),cors:be.optional(),corsAccessList:l_.optional(),headersTimeout:je.min(1).optional(),port:je.min(0).optional().empty(null),securePort:je.min(0).optional().empty(null),maxHeaderSize:je.optional(),mtls:ae.alternatives([be.optional(),ae.object({user:Zt.optional(),certificateAuthority:i,required:be.optional()})]),threadRange:ae.alternatives([l_.optional(),Zt.optional()])}).required(),threads:ae.alternatives(n.optional(),ae.object({count:n.optional(),debug:ae.alternatives(be.optional(),ae.object({startingPort:je.min(1).optional(),host:Zt.optional(),waitForDebugger:be.optional()})),maxHeapMemory:je.min(0).optional()})),storage:ae.object({writeAsync:be.required(),overlappingSync:be.optional(),caching:be.optional(),compression:ae.alternatives([be.optional(),ae.object({dictionary:Zt.optional(),threshold:je.optional()})]),compactOnStart:be.optional(),compactOnStartKeepBackup:be.optional(),noReadAhead:be.optional(),path:l,prefetchWrites:be.optional(),maxFreeSpaceToLoad:je.optional(),maxFreeSpaceToRetain:je.optional()}).required(),ignoreScripts:be.optional(),tls:ae.alternatives([ae.array().items(u),u])}).validate(e,{allowUnknown:!0,abortEarly:!1,errors:{wrap:{label:"'"}}})}a(AV,"configValidator");function OV(e){return jO||XO.existsSync(e)?null:`Specified path ${e} does not exist.`}a(OV,"doesPathExist");function bV(e,t){ae.assert(e,Zt.pattern(/^[\\\/]$|([\\\/][a-zA-Z_0-9\:-]+)+$/,"directory path"));let r=OV(e);if(r)return t.message(r)}a(bV,"validatePath");function yV(e,t){let r=e.slice(-1);if(r!=="G"&&r!=="M"&&r!=="K")return t.message(mV);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(SV):e}a(yV,"validateRotationMaxSize");function NV(e,t){let r=e.slice(-1);if(r!=="D"&&r!=="H"&&r!=="M")return t.message(pV);let n=e.slice(0,-1);return isNaN(parseInt(n))?t.message(TV):e}a(NV,"validateRotationInterval");function IV(e,t){let r=t.state.path.join("."),n=dV.cpus().length,s=n-1;s<=2&&(s=2);let i=process.constrainedMemory?.()||QO();return i=Math.round(Math.min(i,QO())/1e6),s=Math.max(Math.min(s,Math.round((i-750)/300)),1),fV.info(`Detected ${n} cores and ${i}MB on this machine, defaulting ${r} to ${s}`),s}a(IV,"setDefaultThreads");function Tc(e,t){let r=t.state.path.join(".");if(!u_.isEmpty(t.original)&&r!=="operationsApi.network.domainSocket")return t.original;if(u_.isEmpty(zn))throw new Error(`Error setting default root for: ${r}. HDB root is not defined`);switch(r){case"componentsRoot":return Hi.join(zn,hV);case"logging.root":return Hi.join(zn,JO);case"clustering.leafServer.streams.path":return Hi.join(zn,"clustering","leaf");case"storage.path":let n=Hi.join(zn,zO.LEGACY_DATABASES_DIR_NAME);return XO.existsSync(n)?n:Hi.join(zn,zO.DATABASES_DIR_NAME);case"logging.rotation.path":return Hi.join(zn,JO);case"operationsApi.network.domainSocket":return r==null?null:Hi.join(zn,"operations-server");default:throw new Error(`Error setting default root for config parameter: ${r}. Unrecognized config parameter`)}}a(Tc,"setDefaultRoot");function wV(e){let t=ae.object({routes:__});return EV.validateBySchema({routes:e},t)}a(wV,"routesValidator")});var Gi={};qe(Gi,{server:()=>it});var eb,it,fr=Re(()=>{eb=require("../../index"),it={};(0,eb._assignPackageExport)("server",it)});var hr=g((joe,lb)=>{"use strict";var Hr=U(),Bt=J(),Nt=K(),{configValidator:CV,routesValidator:tb}=Fh(),Er=require("fs-extra"),DV=require("yaml"),Nn=require("path"),LV=require("is-number"),nb=require("properties-reader"),MV=require("lodash"),{handleHDBError:PV}=se(),{HTTP_STATUS_CODES:UV,HDB_ERROR_MSGS:d_}=vr(),Xoe=require("minimist"),{server:vV}=(fr(),ie(Gi)),{DATABASES_PARAM_CONFIG:gc,CONFIG_PARAMS:Br,CONFIG_PARAM_MAP:In}=Hr,BV="Unable to get config value because config is uninitialized",HV="Config successfully initialized",xV="Error backing up config file",GV="Empty parameter sent to getConfigValue",sb=Nn.join(Hr.PACKAGE_ROOT,"config","yaml",Hr.HDB_DEFAULT_CONFIG_FILE),FV="Configuration successfully set. You must restart HarperDB for new config settings to take effect.",rb={logging_rotation_retain:"logging.rotation.retain",logging_rotation_rotate:"logging.rotation.rotate",logging_rotation_rotateinterval:"logging.rotation.rotateInterval",logging_rotation_rotatemodule:"logging.rotation.rotateModule",logging_rotation_timezone:"logging.rotation.timezone",logging_rotation_workerinterval:"logging.rotation.workerInterval"},f_,It,E_;lb.exports={createConfigFile:qV,getDefaultConfig:kV,getConfigValue:ob,initConfig:kh,flattenConfig:Vo,updateConfigValue:ab,updateConfigObject:$V,getConfiguration:WV,setConfiguration:QV,readConfigFile:$h,getClusteringRoutes:zV,initOldConfig:cb,getConfigFromFile:JV,getConfigFilePath:Fi,addConfig:XV,deleteConfigFromFile:jV,getConfigObj:ZV};function qV(e,t=!1){let r=Zs(sb);f_=Vo(r.toJSON());let n;for(let c in e){let l=In[c.toLowerCase()];if(l===Br.DATABASES){Array.isArray(e[c])?n=e[c]:n=Object.keys(e[c]).map(_=>({[_]:e[c][_]}));continue}if(!l&&(c.endsWith("_package")||c.endsWith("_port"))&&(l=c),l!==void 0){let _=l.split("_"),u=qh(l,e[c]);l==="rootPath"&&u?.endsWith("/")&&(u=u.slice(0,-1));try{r.setIn([..._],u)}catch(d){Nt.error(d)}}}n&&ib(r,n),Vh(r,t);let s=r.toJSON();It=Vo(s);let i=r.getIn(["rootPath"]),o=Nn.join(i,Hr.HDB_CONFIG_FILE);Er.createFileSync(o),Er.writeFileSync(o,String(r)),Nt.trace(`Config file written to ${o}`)}a(qV,"createConfigFile");function ib(e,t){let r;try{try{r=JSON.parse(t)}catch(n){if(!Bt.isObject(t))throw n;r=t}for(let n of r){let s=Object.keys(n)[0];if(n[s].hasOwnProperty(gc.TABLES))for(let i in n[s][gc.TABLES])for(let o in n[s][gc.TABLES][i]){let c=n[s][gc.TABLES][i][o],l=[Br.DATABASES,s,gc.TABLES,i,o];e.hasIn(l)?e.setIn(l,c):e.addIn(l,c)}else for(let i in n[s]){let o=n[s][i],c=[Br.DATABASES,s,i];e.hasIn(c)?e.setIn(c,o):e.addIn(c,o)}}}catch(n){Nt.error("Error parsing schemas CLI/env config arguments",n)}}a(ib,"setSchemasConfig");function kV(e){if(f_===void 0){let r=Zs(sb);f_=Vo(r.toJSON())}let t=In[e.toLowerCase()];if(t!==void 0)return f_[t.toLowerCase()]}a(kV,"getDefaultConfig");function ob(e){if(e==null){Nt.error(GV);return}if(It===void 0){Nt.trace(BV);return}let t=In[e.toLowerCase()];if(t!==void 0)return It[t.toLowerCase()]}a(ob,"getConfigValue");function Fi(e=Bt.getPropsFilePath()){let t=Bt.getEnvCliRootPath();return t?Nn.join(t,Hr.HDB_CONFIG_FILE):nb(e).get(Hr.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY)}a(Fi,"getConfigFilePath");function kh(e=!1){if(It===void 0||e){let t;if(!Bt.noBootFile()){t=Bt.getPropsFilePath();try{Er.accessSync(t,Er.constants.F_OK|Er.constants.R_OK)}catch(i){throw Nt.error(i),new Error(`HarperDB properties file at path ${t} does not exist`)}}let r=Fi(t),n;if(r.includes("config/settings.js"))try{cb(r);return}catch(i){if(i.code!==Hr.NODE_ERROR_CODES.ENOENT)throw i}try{n=Zs(r)}catch(i){if(i.code===Hr.NODE_ERROR_CODES.ENOENT){Nt.trace(`HarperDB config file not found at ${r}.
|
|
9
|
-
This can occur during early stages of install where the config file has not yet been created`);return}else throw Nt.error(i),new Error(`Error reading HarperDB config file at ${r}`)}VV(n,r),Vh(n);let s=n.toJSON();if(vV.config=s,It=Vo(s),It.logging_rotation_rotate)for(let i in rb)It[i]&&Nt.error(`Config ${rb[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);Nt.trace(HV)}}a(kh,"initConfig");function VV(e,t){let r=e.getIn(["rootPath"]),n=!1;e.hasIn(["storage","path"])||(e.setIn(["storage","path"],Nn.join(r,"database")),n=!0),e.hasIn(["clustering","leafServer","streams","path"])||(e.setIn(["clustering","leafServer","streams","path"],Nn.join(r,"clustering","leaf")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],Nn.join(r,"log")),n=!0),e.hasIn(["clustering","tls","verify"])||(e.setIn(["clustering","tls","verify"],!0),n=!0),e.hasIn(["authentication"])||(e.addIn(["authentication"],{cacheTTL:3e4,enableSessions:!0,operationTokenTimeout:e.getIn(["operationsApi","authentication","operationTokenTimeout"])??"1d",refreshTokenTimeout:e.getIn(["operationsApi","authentication","refreshTokenTimeout"])??"30d"}),n=!0),e.hasIn(["analytics"])||(e.addIn(["analytics"],{aggregatePeriod:60}),n=!0),n&&(Nt.trace("Updating config file with missing config params"),Er.writeFileSync(t,String(e)))}a(VV,"checkForUpdatedConfig");function Vh(e,t=!1){let r=e.toJSON();r.componentsRoot=r.componentsRoot??r?.customFunctions?.root,r?.http?.threads&&(r.threads=r?.http?.threads);let n=CV(r,t);if(n.error)throw d_.CONFIG_VALIDATION(n.error.message);typeof n.value.threads=="object"?e.setIn(["threads","count"],n.value.threads.count):e.setIn(["threads"],n.value.threads),e.setIn(["componentsRoot"],n.value.componentsRoot),e.setIn(["logging","root"],n.value.logging.root),e.setIn(["storage","path"],n.value.storage.path),e.setIn(["logging","rotation","path"],n.value.logging.rotation.path),e.setIn(["clustering","leafServer","streams","path"],n.value.clustering.leafServer.streams?.path),e.setIn(["operationsApi","network","domainSocket"],n.value?.operationsApi?.network?.domainSocket)}a(Vh,"validateConfig");function $V(e,t){It===void 0&&(It={});let r=In[e.toLowerCase()];if(r===void 0){Nt.trace(`Unable to update config object because config param '${e}' does not exist`);return}It[r.toLowerCase()]=t}a($V,"updateConfigObject");function ab(e,t,r=void 0,n=!1,s=!1,i=!1){It===void 0&&kh();let o=ob(In.hdb_root),c=Nn.join(o,Hr.HDB_CONFIG_FILE),l=Zs(c),_;if(r===void 0&&e.toLowerCase()===Br.DATABASES)_=t;else if(r===void 0){let E;if(i)E=e;else if(E=In[e.toLowerCase()],E===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let f=E.split("_"),h=qh(E,t);l.setIn([...f],h)}else for(let E in r){let f=In[E.toLowerCase()];if(f===Br.HTTP_SECUREPORT&&r[E]===It[Br.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),f===Br.OPERATIONSAPI_NETWORK_SECUREPORT&&r[E]===It[Br.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&l.setIn(["operationsApi","network","port"],null),f===Br.DATABASES){_=r[E];continue}if(f?.startsWith("threads_")){let h=l.getIn(["threads"]);h>=0&&(l.deleteIn(["threads"]),l.setIn(["threads","count"],h))}if(!f&&(E.endsWith("_package")||E.endsWith("_port"))&&(f=E),f!==void 0){let h=f.split("_"),p=Hr.LEGACY_CONFIG_PARAMS[E.toUpperCase()];p&&p.startsWith("customFunctions")&&l.hasIn(p.split("_"))&&(f=p,h=p.split("_"));let S=qh(f,r[E]);f==="rootPath"&&S?.endsWith("/")&&(S=S.slice(0,-1));try{h.length>1&&typeof l.getIn(h.slice(0,-1))=="boolean"&&l.deleteIn(h.slice(0,-1)),l.setIn([...h],S)}catch(T){Nt.error(T)}}}_&&ib(l,_),Vh(l);let u=l.getIn(["rootPath"]),d=Nn.join(u,Hr.HDB_CONFIG_FILE);n===!0&&YV(c,u),Er.writeFileSync(d,String(l)),s&&(It=Vo(l.toJSON())),Nt.trace(`Config parameter: ${e} updated with value: ${t}`)}a(ab,"updateConfigValue");function YV(e,t){try{let r=Nn.join(t,"backup",`${Hr.HDB_CONFIG_FILE}.bak`);Er.copySync(e,r),Nt.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){Nt.error(xV),Nt.error(r)}}a(YV,"backupConfigFile");var KV=["databases"];function Vo(e){return e.http&&Object.assign(e.http,e?.customFunctions?.network),e?.operationsApi?.network&&(e.operationsApi.network=Object.assign({},e.http,e.operationsApi.network)),e?.operationsApi&&(e.operationsApi.tls=Object.assign({},e.tls,e.operationsApi.tls)),E_=e,r(e);function r(n){let s={};for(let i in n)if(n.hasOwnProperty(i)){if(typeof n[i]=="object"&&n[i]!==null&&!Array.isArray(n[i])&&!KV.includes(i)){let o=r(n[i]);for(let c in o){if(!o.hasOwnProperty(c))continue;c!=="package"&&(i=i.toLowerCase());let l=i+"_"+c;!Br[l.toUpperCase()]&&In[l]&&(s[In[l].toLowerCase()]=o[c]),s[l]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(Vo,"flattenConfig");function qh(e,t){if(e===Br.CLUSTERING_NODENAME||e===Br.CLUSTERING_USER){if(t==null)return t;if(!isNaN(t))return t.toString();if(typeof t=="string"&&t.toLowerCase()==="true"||typeof t=="string"&&t.toLowerCase()==="false")return t}else{if(LV(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||Bt.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 Bt.autoCast(t)}a(qh,"castConfigValue");function WV(){let e=Bt.getPropsFilePath(),t=Fi(e);return Zs(t).toJSON()}a(WV,"getConfiguration");async function QV(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return ab(void 0,void 0,s,!0),FV}catch(i){throw typeof i=="string"||i instanceof String?PV(i,i,UV.BAD_REQUEST,void 0,void 0,!0):i}}a(QV,"setConfiguration");function $h(){let e=Bt.getPropsFilePath();try{Er.accessSync(e,Er.constants.F_OK|Er.constants.R_OK)}catch(n){if(!Bt.noBootFile())throw Nt.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=Fi(e);return Zs(t).toJSON()}a($h,"readConfigFile");function Zs(e){return DV.parseDocument(Er.readFileSync(e,"utf8"),{simpleKeys:!0})}a(Zs,"parseYamlDoc");function zV(){let e=$h(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=Bt.isEmptyOrZeroLength(t)?[]:t;let r=tb(t);if(r)throw d_.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=Bt.isEmptyOrZeroLength(n)?[]:n;let s=tb(n);if(s)throw d_.CONFIG_VALIDATION(s.message);if(!Bt.isEmptyOrZeroLength(n)&&!Bt.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!Bt.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw d_.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(zV,"getClusteringRoutes");function cb(e){let t=nb(e);It={};for(let r in In){let n=t.get(r.toUpperCase());if(Bt.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=In[r].toLowerCase();s===Br.LOGGING_ROOT?It[s]=Nn.dirname(n):It[s]=n}return It}a(cb,"initOldConfig");function JV(e){let t=$h();return MV.get(t,e.replaceAll("_","."))}a(JV,"getConfigFromFile");async function XV(e,t){let r=Zs(Fi());r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),await Er.writeFile(Fi(),String(r))}a(XV,"addConfig");function jV(e){let t=Fi(Bt.getPropsFilePath()),r=Zs(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=Nn.join(n,Hr.HDB_CONFIG_FILE);Er.writeFileSync(s,String(r))}a(jV,"deleteConfigFromFile");function ZV(){return E_||(kh(),E_)}a(ZV,"getConfigObj")});var ne=g((eae,Eb)=>{"use strict";var Yh=require("fs-extra"),qi=require("path"),ub=require("os"),e$=require("properties-reader"),Ac=K(),Rc=J(),de=U(),h_=hr(),t$="Error initializing environment manager",m_="BOOT_PROPS_FILE_PATH",_b=!1,r$={[de.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[de.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[de.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},gs={};Eb.exports={BOOT_PROPS_FILE_PATH:m_,getHdbBasePath:n$,setHdbBasePath:s$,get:db,initSync:o$,setProperty:Me,initTestEnvironment:c$,setCloneVar:a$};function n$(){return gs[de.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(n$,"getHdbBasePath");function s$(e){gs[de.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(s$,"setHdbBasePath");function db(e){let t=h_.getConfigValue(e);return t===void 0?gs[e]:t}a(db,"get");function Me(e,t){r$[e]&&(gs[e]=t),h_.updateConfigObject(e,t)}a(Me,"setProperty");function i$(){let e;try{e=Rc.getPropsFilePath(),Yh.accessSync(e,Yh.constants.F_OK|Yh.constants.R_OK),_b=!0;let t=e$(e);return gs[de.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(de.HDB_SETTINGS_NAMES.INSTALL_USER),gs[de.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(de.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),gs[m_]=e,!0}catch{return Ac.trace(`Environment manager found no properties file at ${e}`),!1}}a(i$,"doesPropFileExist");function o$(e=!1){try{(_b||i$()||Rc.noBootFile())&&!fb&&(h_.initConfig(e),gs[de.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=h_.getConfigValue(de.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){Ac.error(t$),Ac.error(t),console.error(t),process.exit(1)}}a(o$,"initSync");var fb=!1;function a$(e){fb=e}a(a$,"setCloneVar");function c$(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=qi.join(__dirname,"../../","unitTests");gs[m_]=qi.join(l,"hdb_boot_properties.file"),Me(de.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,qi.join(l,"settings.test")),Me(de.HDB_SETTINGS_NAMES.INSTALL_USER,ub.userInfo()?ub.userInfo().username:void 0),Me(de.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),Me(de.HDB_SETTINGS_NAMES.LOG_PATH_KEY,qi.join(l,"envDir","log")),Me(de.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),Me(de.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),Me(de.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),Me(de.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,qi.join(l,"envDir")),Me(de.CONFIG_PARAMS.STORAGE_PATH,qi.join(l,"envDir")),s&&(Me(de.CONFIG_PARAMS.HTTP_SECUREPORT,db(de.CONFIG_PARAMS.HTTP_PORT)),Me(de.CONFIG_PARAMS.HTTP_PORT,null)),Me(de.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,!!s),Me(de.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),Me(de.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,Rc.isEmpty(i)?!1:i),Me(de.CONFIG_PARAMS.HTTP_CORS,Rc.isEmpty(i)?!1:i),Me(de.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),Me(de.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),Me(de.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),Me(de.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),Me(de.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,qi.resolve(__dirname,"../../unitTests/server/fastifyRoutes/custom_functions")),Me(de.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,Rc.isEmpty(c)?!1:c),o&&(Me("CORS_ACCESSLIST",o),Me(de.CONFIG_PARAMS.HTTP_CORSACCESSLIST,o)),n&&(Me(de.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,n),Me(de.CONFIG_PARAMS.HTTP_TIMEOUT,n)),t&&(Me(de.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),Me(de.CONFIG_PARAMS.HTTP_KEEPALIVETIMEOUT,t)),r&&(Me(de.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),Me(de.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${m_}. Please check your boot props and settings files`;Ac.fatal(r),Ac.error(t)}}a(c$,"initTestEnvironment")});var ze=g((rae,Rb)=>{"use strict";var Ic=U(),l$=J(),mr=ne(),wc=require("path"),u$=require("minimist"),hb=require("fs-extra"),mb=require("lodash");mr.initSync();var{CONFIG_PARAMS:ei,DATABASES_PARAM_CONFIG:Oc,SYSTEM_SCHEMA_NAME:p_}=Ic,bc,yc,Nc;function pb(){if(bc!==void 0)return bc;if(mr.getHdbBasePath()!==void 0)return bc=mr.get(ei.STORAGE_PATH)||wc.join(mr.getHdbBasePath(),Ic.DATABASES_DIR_NAME),bc}a(pb,"getBaseSchemaPath");function Sb(){if(yc!==void 0)return yc;if(mr.getHdbBasePath()!==void 0)return yc=gb(p_),yc}a(Sb,"getSystemSchemaPath");function Tb(){if(Nc!==void 0)return Nc;if(mr.getHdbBasePath()!==void 0)return Nc=mr.get(Ic.CONFIG_PARAMS.STORAGE_AUDIT_PATH)||wc.join(mr.getHdbBasePath(),Ic.TRANSACTIONS_DIR_NAME),Nc}a(Tb,"getTransactionAuditStoreBasePath");function _$(e,t){let r=mr.get(ei.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||wc.join(Tb(),e.toString())}a(_$,"getTransactionAuditStorePath");function gb(e,t){e=e.toString(),t=t&&t.toString();let r=mr.get(Ic.CONFIG_PARAMS.DATABASES)?.[e];return t&&r?.tables?.[t]?.path||r?.path||wc.join(pb(),e)}a(gb,"getSchemaPath");function d$(e,t){e=e.toString(),t=t.toString();let r=process.env;Object.assign(r,u$(process.argv));let n=r[ei.DATABASES.toUpperCase()];if(n){let i;try{i=JSON.parse(n)}catch(o){if(!l$.isObject(n))throw o;i=n}for(let o of i){let c=o[p_];if(!c)continue;let l=mr.get(ei.DATABASES);l=l??{};let _=c?.tables?.[t]?.[Oc.PATH];if(_)return mb.set(l,[p_,Oc.TABLES,t,Oc.PATH],_),mr.setProperty(ei.DATABASES,l),_;let u=c?.[Oc.PATH];if(u)return mb.set(l,[p_,Oc.PATH],u),mr.setProperty(ei.DATABASES,l),u}}let s=r[ei.STORAGE_PATH.toUpperCase()];if(s){if(!hb.pathExistsSync(s))throw new Error(s+" does not exist");let i=wc.join(s,e);return hb.mkdirsSync(i),mr.setProperty(ei.STORAGE_PATH,s),i}return Sb()}a(d$,"initSystemSchemaPaths");function f$(){bc=void 0,yc=void 0,Nc=void 0}a(f$,"resetPaths");Rb.exports={getBaseSchemaPath:pb,getSystemSchemaPath:Sb,getTransactionAuditStorePath:_$,getTransactionAuditStoreBasePath:Tb,getSchemaPath:gb,initSystemSchemaPaths:d$,resetPaths:f$}});var xr=g((oae,Nb)=>{"use strict";var E$=vr().LMDB_ERRORS_ENUM,sae=require("lmdb"),h$=dt(),iae=require("buffer").Buffer,{OVERFLOW_MARKER:Ab,MAX_SEARCH_KEY_LENGTH:S_}=h$,Ob=["number","string","symbol","boolean","bigint"];function m$(e){if(e=e?.primaryStore||e,!e)throw new Error(E$.ENV_REQUIRED)}a(m$,"validateEnv");function p$(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(p$,"stringifyData");function S$(e){return e instanceof Date?e.valueOf():e}a(S$,"convertKeyValueToWrite");function T$(e,t){if(e===null)return t?[null]:void 0;if(e===void 0)return;if(Ob.includes(typeof e))return e.length>S_?[e.slice(0,S_)+Ab]:[e];let r;if(Array.isArray(e)){r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n];if(Ob.includes(typeof i))i.length>S_?r.push(i.slice(0,S_)+Ab):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(T$,"getIndexedValues");var T_=0,bb=0;function yb(){bb=Date.now()-performance.now()}a(yb,"adjustStartTime");yb();var g$=6e4;setInterval(yb,g$).unref();function R$(){let e=performance.now()+bb;return e>T_?(T_=e,e):(T_+=488e-6,T_)}a(R$,"getNextMonotonicTime");Nb.exports={validateEnv:m$,stringifyData:p$,convertKeyValueToWrite:S$,getNextMonotonicTime:R$,getIndexedValues:T$}});var Cc=g((cae,Ib)=>{"use strict";var A$=U().OPERATIONS_ENUM,Kh=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i=void 0){this.operation=A$.INSERT,this.schema=t,this.table=r,this.hash_attribute=n,this.records=s,this.__origin=i}};Ib.exports=Kh});var Dc=g((_ae,Lb)=>{"use strict";var uae=Cc(),g_=U(),Wh=J(),wb=K(),O$=require("uuid"),{handleHDBError:R_,hdb_errors:b$}=se(),{HDB_ERROR_MSGS:A_,HTTP_STATUS_CODES:O_}=b$;Lb.exports=Cb;function Cb(e,t,r){for(let s=0;s<t.length;s++)Db(t[s]);let{records:n}=e;for(let s=0;s<n.length;s++){let i=n[s];y$(i,r,e.operation)}}a(Cb,"processRows");Cb.validateAttribute=Db;function Db(e){if(Buffer.byteLength(String(e))>g_.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw R_(new Error,A_.ATTR_NAME_LENGTH_ERR(e),O_.BAD_REQUEST,void 0,void 0,!0);if(Wh.isEmptyOrZeroLength(e)||Wh.isEmpty(e.trim()))throw R_(new Error,A_.ATTR_NAME_NULLISH_ERR,O_.BAD_REQUEST,void 0,void 0,!0)}a(Db,"validateAttribute");function y$(e,t,r){if(!e.hasOwnProperty(t)||Wh.isEmptyOrZeroLength(e[t])){if(r===g_.OPERATIONS_ENUM.INSERT||r===g_.OPERATIONS_ENUM.UPSERT){e[t]=O$.v4();return}throw wb.error("Update transaction aborted due to record with no hash value:",e),R_(new Error,A_.RECORD_MISSING_HASH_ERR,O_.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>g_.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw wb.error(e),R_(new Error,A_.HASH_VAL_LENGTH_ERR,O_.BAD_REQUEST,void 0,void 0,!0)}a(y$,"validateHash")});var Mb,wn,Qh,Lc=Re(()=>{Mb=require("events"),wn=class extends Mb.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;drainCloseListener;currentDrainResolver;[Symbol.asyncIterator](){let t=new Qh;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)}},Qh=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 Xh={};qe(Xh,{loadGQLSchema:()=>w$,start:()=>Jh,startOnMainThread:()=>I$});function Jh({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r,n,s,i){let{parse:o,Source:c,Kind:l,NamedTypeNode:_,StringValueNode:u}=await import("graphql"),d=o(new c(r.toString(),s)),E=new Map,f=[],h;for(let S of d.definitions)switch(S.kind){case l.OBJECT_TYPE_DEFINITION:let v=function(P){if(P.kind==="NonNullType"){let Q=v(P.type);return Q.nullable=!1,Q}if(P.kind==="ListType")return{type:"array",elements:v(P.type)};let M={type:P.name?.value};return Object.defineProperty(M,"location",{value:P.loc.startToken}),M};a(v,"getProperty");let T=S.name.value,A=[],N={table:null,database:null,properties:A};E.set(T,N);for(let P of S.directives){if(P.name.value==="table"){for(let q of P.arguments)N[q.name.value]=q.value.value;N.schema&&(N.database=N.schema),N.table||(N.table=T),N.audit&&(N.audit=N.audit!=="false"),N.attributes=N.properties,f.push(N)}if(P.name.value==="sealed"&&(N.sealed=!0),P.name.value==="export"){N.export=!0;for(let q of P.arguments)q.name.value==="name"&&(N.export={name:q.value.value})}}let b=!1;for(let P of S.fields){let q=v(P.type);q.name=P.name.value,A.push(q);for(let M of P.directives)if(M.name.value==="primaryKey")b?console.warn("Can not define two attributes as a primary key"):(q.isPrimaryKey=!0,b=!0);else if(M.name.value==="indexed")q.indexed=!0;else if(M.name.value==="relationship"){let Q={};for(let z of M.arguments)Q[z.name.value]=z.value.value;q.relationship=Q}else if(M.name.value==="createdTime")q.assignCreatedTime=!0;else if(M.name.value==="updatedTime")q.assignUpdatedTime=!0;else if(M.name.value==="expiresAt")q.expiresAt=!0;else if(M.name.value==="allow"){let Q=q.authorizedRoles=[];for(let z of M.arguments)z.name.value==="role"&&Q.push(z.value.value)}}N.type=T,T==="Query"&&(h=N)}function p(S){let T=E.get(S.type);T?(Object.defineProperty(S,"properties",{value:T.properties}),Object.defineProperty(S,"definition",{value:T})):S.type==="array"?p(S.elements):N$.includes(S.type)||(0,Pb.getWorkerIndex)()===0&&console.error(`The type ${S.type} is unknown at line ${S.location.line}, column ${S.location.column}, in ${s}`)}a(p,"connectPropertyType");for(let S of E.values())for(let T of S.properties)p(T);for(let S of f)S.tableClass=e(S),S.export&&(S.export.name===""?i.set((0,zh.dirname)(n),S.tableClass):i.set((0,zh.dirname)(n)+"/"+(S.export.name||S.type),S.tableClass))}}var zh,Pb,N$,I$,w$,Ub=Re(()=>{zh=require("path");Ae();Pb=x(ot()),N$=["ID","Int","Float","Long","String","Boolean","Date","Bytes","Any","BigInt"];a(Jh,"start");I$=Jh,w$=Jh({ensureTable:ft}).handleFile});async function b_(e){let t=(0,Hb.pathToFileURL)(e).toString();return C$?(Mc||(Mc=D$(M$)),(await(await Mc).import(t)).namespace):import(t)}async function D$(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),Mc=new Compartment({console,Math,Date,fetch:L$,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,Bb.extname)(r)||(r+=".js"),r)},importHook:async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){Object.assign(s,{Resource:Yt,tables:Gr,databases:at})}};let n=await(0,vb.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)}}),Mc}function L$(e,t){let r=typeof e=="string"||e.url;if(new URL(r).protocol!="https")throw new Error("Only https is allowed in fetch");return fetch(e,t)}function M$(){return{Resource:Yt,tables:Gr}}var vb,Bb,Hb,C$,Mc,jh=Re(()=>{an();Ae();vb=require("fs/promises"),Bb=require("path"),Hb=require("url"),C$=!1;a(b_,"secureImport");a(D$,"getCompartment");a(L$,"secureOnlyFetch");a(M$,"getGlobalVars")});var em={};qe(em,{handleFile:()=>P$});async function P$(e,t,r,n){let s=new Map,i=await b_(r);c(i.default)&&n.set((0,Zh.dirname)(t),i.default),o(i,(0,Zh.dirname)(t));function o(l,_){for(let u in l){let d=l[u];c(d)?n.set(_+"/"+u,d):typeof d=="object"&&o(d,_+"/"+u)}}a(o,"recurseForResources");function c(l){return typeof l=="function"&&(l.get||l.put||l.post||l.delete)}return a(c,"isResource"),s}var Zh,xb=Re(()=>{jh();Zh=require("path");a(P$,"handleFile")});var rm={};qe(rm,{start:()=>U$});function U$({resources:e}){e.set("login",tm),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var tm,Gb=Re(()=>{an();a(U$,"start");tm=class extends Yt{static{a(this,"Login")}static async get(t,r,n){}static async post(t,r,n){let{username:s,password:i,redirect:o}=r;return{data:await n.login(s,i)}}}});var Kb={};qe(Kb,{parse:()=>sm,streamAsJSON:()=>Pc,stringify:()=>ki});function Pc(e){return new nm({value:e})}function Fb(e){return console.error(e),JSON.stringify(e.toString())}function qb(e,t,r){return e?.then?r?e.then(t,r):e.then(t):t(e)}function ki(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===$b)return Yb(e);if(t.resolution)return t.resolution.then(()=>ki(e));throw t}}function Yb(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+=Yb(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+ki(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function sm(e){return H$.test(e)?v$.parse(e):JSON.parse(e)}var kb,Vb,v$,B$,$b,nm,H$,im=Re(()=>{kb=require("stream"),Vb=x(require("json-bigint-fixes")),v$=(0,Vb.default)({useNativeBigInt:!0}),B$=1e4,$b={};BigInt.prototype.toJSON=function(){throw $b};a(Pc,"streamAsJSON");nm=class extends kb.Readable{static{a(this,"JSONStream")}constructor(t){super(t),this.buffer=[],this.bufferSize=0,this.iterator=this.serialize(t.value,!0),this.activeIterators=[]}*serialize(t){if(t&&typeof t=="object"){let r=t[Symbol.asyncIterator],n=t[Symbol.iterator];if((n||r)&&!t.then){yield"[";let s=!0;if((r||n)&&!(t instanceof Array)){let i=r?t[Symbol.asyncIterator]():t[Symbol.iterator]();this.activeIterators.push(i);let o;for(;;)if(o=i.next(),o.then&&(yield o.then(c=>(o=c,""))),o.done){this.activeIterators.splice(this.activeIterators.indexOf(i),1),yield"]";return}else s?s=!1:yield",",yield*this.serialize(o.value)}for(let i of t)s?s=!1:yield",",yield*this.serialize(i);yield"]";return}if(t.then)try{yield t.then(s=>this.serialize(s),Fb)}catch(s){yield Fb(s)}else yield ki(t)}else yield ki(t)}_read(){if(!this._amReading){if(this._amReading=!0,this.done)return this.push(null);qb(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>B$?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 qb(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(Fb,"handleError");a(qb,"when");a(ki,"stringify");a(Yb,"jsStringify");H$=/[[,:]\s*-?\d{16,}/;a(sm,"parse")});var iy=g((Iae,sy)=>{"use strict";var om=require("recursive-iterator"),x$=require("alasql"),am=require("clone"),Wb=J(),{handleHDBError:Qb,hdb_errors:G$}=se(),{HDB_ERROR_MSGS:zb,HTTP_STATUS_CODES:Jb}=G$,{getDatabases:F$}=(Ae(),ie(ke)),q$=["DISTINCT_ARRAY"],Xb=Symbol("validateTables"),cm=Symbol("validateTable"),Nae=Symbol("getAllColumns"),jb=Symbol("validateAllColumns"),y_=Symbol("findColumn"),Zb=Symbol("validateOrderBy"),Uc=Symbol("validateSegment"),lm=Symbol("validateColumn"),ey=Symbol("setColumnsForTable"),ty=Symbol("checkColumnsForAsterisk"),ry=Symbol("validateGroupBy"),ny=Symbol("hasColumns"),um=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[Xb](),this[ty](),this[jb]()}[Xb](){if(this[ny]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[cm](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[cm](t.table)})}}[ny](){let t=!1,r=new om(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[cm](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=F$();if(!r[t.databaseid])throw Qb(new Error,zb.SCHEMA_NOT_FOUND(t.databaseid),Jb.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw Qb(new Error,zb.TABLE_NOT_FOUND(t.databaseid,t.tableid),Jb.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=am(s);i.table=am(t),this.attributes.push(i)})}[y_](t){return this.attributes.filter(r=>t.tableid?(r.table.as===t.tableid||r.table.tableid===t.tableid)&&r.attribute===t.columnid:r.attribute===t.columnid)}[ty](){let t=new om(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[ey](r.tableid)}[ey](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new x$.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[jb](){this[Uc](this.statement.columns,!1),this[Uc](this.statement.joins,!1),this[Uc](this.statement.where,!1),this[ry](this.statement.group,!1),this[Uc](this.statement.order,!0)}[Uc](t,r){if(!t)return;let n=new om(t),s=[];for(let{node:i,path:o}of n)!Wb.isEmpty(i)&&!Wb.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[Zb](i):s.push(this[lm](i)));return s}[ry](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&q$.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=am(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[y_](n)[0];s&&r.push(s)}}}),this.statement.group.forEach(n=>{let s=null;if(!n.columnid)r.forEach((i,o)=>{if(i.toString()===n.toString()){s=i,r.splice(o,1);return}});else{let i=this[y_](n);if(!i||i.length===0)throw`unknown column '${n.toString()}' in group by`;if(i.length>1)throw`ambiguously defined column '${n.toString()}' in group by`;r.forEach((o,c)=>{if(o.attribute===i[0].attribute&&o.table.tableid===i[0].table.tableid){s=o,r.splice(c,1);return}})}if(!s)throw`group by column '${n.toString()}' must be in select`}),r.length>0)throw`select column '${r[0].attribute?r[0].attribute:r[0].toString()}' must be in group by`}[Zb](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[lm](t)}[lm](t){let r=this[y_](t),n=(t.tableid?t.tableid+".":"")+t.columnid;if(r.length===0)throw`unknown column ${n}`;if(r.length>1)throw`ambiguous column reference ${n}`;return r[0]}};sy.exports=um});var ay=g((Cae,oy)=>{"use strict";var _m=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")}};oy.exports=_m});var ly=g((Lae,cy)=>{"use strict";var dm=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};cy.exports=dm});var fy={};qe(fy,{HAS_EXPIRATION:()=>Tm,LAST_TIMESTAMP_PLACEHOLDER:()=>Hc,LOCAL_TIMESTAMP:()=>k$,METADATA:()=>vc,NO_TIMESTAMP:()=>Em,PENDING_LOCAL_TIME:()=>gm,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>Sm,RecordEncoder:()=>pm,TIMESTAMP_ASSIGN_LAST:()=>$$,TIMESTAMP_ASSIGN_NEW:()=>_y,TIMESTAMP_ASSIGN_PREVIOUS:()=>dy,TIMESTAMP_PLACEHOLDER:()=>N_,TIMESTAMP_RECORD_PREVIOUS:()=>hm,getUpdateRecord:()=>Rm,handleLocalTimeForGets:()=>D_});function K$(){return Bc[0]=Bc[0]^64,V$.getFloat64(0)}function D_(e){let t=e.getEntry;e.readCount=0,e.cachePuts=!1,e.getEntry=function(i,o){e.readCount++;let c=t.call(this,i,o),l=c?.value,_=l?.[vc];return _>=0&&(c.metadataFlags=_,c.localTime=l.localTime,c.value=l.value,l.expiresAt>0&&(c.expiresAt=l.expiresAt)),c&&(c.key=i),c};let r=e.get;e.get=function(i,o){let c=r.call(this,i,o);return c?.[vc]>=0?c.value:c};let n=e.getRange;e.getRange=function(i){let o=n.call(this,i);return i.valuesForKey?o.map(c=>c?.value):i.values===!1||i.onlyCount?o:o.map(c=>{let l=c.value,_=l[vc];return _>=0&&(c.metadataFlags=_,c.localTime=l.localTime,c.value=l.value,l.expiresAt>0&&(c.expiresAt=l.expiresAt)),c})};let s=e.useReadTransaction();if(s.done(),!s.done.isTracked){let i=s.constructor,o=s.use,c=s.done;i.prototype.use=function(){this.timerTracked||(this.timerTracked=!0,Vi.push(new WeakRef(this))),o.call(this)},i.prototype.done=function(){if(c.call(this),this.isDone)for(let l=0;l<Vi.length;l++){let _=Vi[l].deref();(!_||_.isDone||_.isCommitted)&&Vi.splice(l--,1)}},i.prototype.done.isTracked=!0}return e}function Rm(e,t,r){return function(n,s,i,o,c=-1,l,_,u,d="put",E,f){if(E||l==null?$o=i?.localTime?hm|dy:Em:$o=l?i?.localTime?hm|16384:_y|16384:Em,u>0&&(c|=Tm),w_=c,mm=u,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let h={version:o,instructedWrite:$o>0},p;try{E&&(h.ifVersion=p=i?.version??null);let S=e.put(n,s,h);if(l){let T=_?.user?.username;if(f&&(I_=e.encoder.encode(f)),E&&i?.localTime){let A=i?.localTime,N=r.get(A);if(N){let b=Ht(N).previousLocalTime;return r.put(A,C_(o,t,n,b,T,d,I_),{ifVersion:p}),S}}r.put(Hc,C_(o,t,n,i?.localTime?1:0,T,d,I_),{append:d!=="invalidate",instructedWrite:!0,ifVersion:p})}return S}catch(S){throw S.message+=" id: "+n+" options: "+h,S}}}var uy,fm,N_,Hc,Sm,k$,vc,Bc,V$,Em,_y,$$,dy,hm,Tm,gm,Y$,I_,$o,w_,mm,pm,Vi,xc=Re(()=>{uy=require("msgpackr");ti();fm=x(K()),N_=new Uint8Array([1,1,1,1,4,64,0,0]),Hc=new Uint8Array([1,1,1,1,1,0,0,0]),Sm=new Uint8Array([1,1,1,1,3,64,0,0]),k$=Symbol("local-timestamp"),vc=Symbol("metadata"),Bc=new Uint8Array(8),V$=new DataView(Bc.buffer,0,8),Em=0,_y=0,$$=1,dy=3,hm=4,Tm=16,gm=1,$o=0,w_=-1,mm=0,pm=class extends uy.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(n,s){if($o||w_>=0){let i=0,o=$o;o&&(i+=8,$o=0);let c=w_,l=mm;c>=0&&(i+=2,w_=-1,l&&(i+=8,mm=0));let _=Y$=r.call(this,n,s|2048|i);I_=_.subarray((_.start||0)+i,_.end);let u=_.start||0;return o&&(N_[4]=o,N_[5]=o>>8,_.set(N_,u),u+=8),c>=0&&(_[u++]=c,_[u++]=0,l&&(_.dataView||(_.dataView=new DataView(_.buffer,_.byteOffset,_.byteLength))).setFloat64(u,l)),_}else return r.call(this,n,s)}}decode(t,r){let n=r?.start||0,s=r>-1?r:r?.end||t.length,i=t[n],o=0;try{if(i<32&&s>2){let c=n,l;if(i===2){if(t.copy)t.copy(Bc,0,c),c+=8;else for(let d=0;d<8;d++)Bc[d]=t[c++];l=K$(),i=t[c]}let _;i<32&&(o=i,c+=2,o&Tm&&(_=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8));let u=super.decode(t.subarray(c,s),s-c);return{localTime:l,value:u,[vc]:o,expiresAt:_}}return super.decode(t,r)}catch(c){throw c.message+=", data: "+t.slice(0,40).toString("hex"),c}}};a(K$,"getTimestamp");a(D_,"handleLocalTimeForGets");Vi=[];setInterval(()=>{for(let e=0;e<Vi.length;e++){let t=Vi[e].deref();!t||t.isDone||t.isCommitted?Vi.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(fm.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):fm.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(Rm,"getUpdateRecord")});var Gc=g((Bae,hy)=>{"use strict";var Ey=ne(),W$=U(),{RecordEncoder:Q$}=(xc(),ie(fy)),vae=require("fs");Ey.initSync();var z$=Ey.get(W$.CONFIG_PARAMS.STORAGE_CACHING)!==!1,Am=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=z$&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:Q$})}};hy.exports=Am});var Fc=g((xae,my)=>{"use strict";var Fr=ne(),cn=U();Fr.initSync();var L_=class{static{a(this,"OpenEnvironmentObject")}constructor(t,r=!1){this.path=t,this.mapSize=1073741824,this.maxDbs=1e4,this.maxReaders=2048,this.sharedStructuresKey=Symbol.for("structures"),this.readOnly=r,this.trackMetrics=!0,this.eventTurnBatching=!1,this.noSync=Fr.get(cn.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Fr.get(cn.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Fr.get(cn.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Fr.get(cn.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Fr.get(cn.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Fr.get(cn.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Fr.get(cn.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Fr.get(cn.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Fr.get(cn.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Fr.get(cn.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Fr.get(cn.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Fr.get(cn.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};my.exports=L_;L_.MAX_DBS=1e4});var We=g((Fae,Ny)=>{"use strict";var bm=require("lmdb"),Cn=require("fs-extra"),qr=require("path"),M_=xr(),Ty=K(),pr=vr().LMDB_ERRORS_ENUM,P_=ly(),ym=Gc(),gy=Fc(),ri=dt(),py=U(),{table:J$,resetDatabases:X$}=(Ae(),ie(ke)),Sy=ne(),Dn=ri.INTERNAL_DBIS_NAME,Ry=ri.DBI_DEFINITION_NAME,j$="data.mdb",Z$="lock.mdb",qc=".mdb",e1="-lock",Om=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=ln(t,r),this.key_type=this.dbi[ri.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[ri.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new bm.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function U_(e,t){if(e===void 0)throw new Error(pr.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(pr.ENV_NAME_REQUIRED)}a(U_,"pathEnvNameValidation");async function Nm(e,t,r=!0){try{await Cn.access(e)}catch(n){throw n.code==="ENOENT"?new Error(pr.INVALID_BASE_PATH):n}try{let n=qr.join(e,t+qc);return await Cn.access(n,Cn.constants.R_OK|Cn.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await Cn.access(qr.join(e,t,j$),Cn.constants.R_OK|Cn.constants.F_OK),qr.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(pr.INVALID_ENVIRONMENT)}else throw new Error(pr.INVALID_ENVIRONMENT);throw n}}a(Nm,"validateEnvironmentPath");function v_(e,t){if(M_.validateEnv(e),t===void 0)throw new Error(pr.DBI_NAME_REQUIRED)}a(v_,"validateEnvDBIName");async function t1(e,t,r=!1,n=!1){U_(e,t);let s=qr.basename(e);t=t.toString();let i=Sy.get(py.CONFIG_PARAMS.DATABASES);i||Sy.setProperty(py.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await Nm(e,t,n),Ay(e,t,r)}catch(o){if(o.message===pr.INVALID_ENVIRONMENT){let c=qr.join(e,t);await Cn.mkdirp(n?c:e);let l=new gy(n?c:c+qc,!1),_=bm.open(l);_.dbis=Object.create(null);let u=new ym(!1);_.openDB(Dn,u),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let d=Im(e,t,r);return _[ri.ENVIRONMENT_NAME_KEY]=d,global.lmdb_map[d]=_,_}throw o}}a(t1,"createEnvironment");async function r1(e,t,r,n=!0){U_(e,t),t=t.toString();let s=qr.join(e,t);return J$({table:t,database:qr.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(r1,"copyEnvironment");async function Ay(e,t,r=!1){U_(e,t),t=t.toString();let n=Im(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 Nm(e,t),i=qr.join(e,t+qc),o=s!=i,c=new gy(s,o),l=bm.open(c);l.dbis=Object.create(null);let _=by(l);for(let u=0;u<_.length;u++)ln(l,_[u]);return l[ri.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(Ay,"openEnvironment");async function n1(e,t,r=!1){U_(e,t),t=t.toString();let n=qr.join(e,t+qc),s=await Nm(e,t);if(global.lmdb_map!==void 0){let i=Im(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await Oy(o),delete global.lmdb_map[i]}}await Cn.remove(s),await Cn.remove(s===n?s+e1:qr.join(qr.dirname(s),Z$))}a(n1,"deleteEnvironment");async function Oy(e){M_.validateEnv(e);let t=e[ri.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(Oy,"closeEnvironment");function Im(e,t,r=!1){let s=`${qr.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(Im,"getCachedEnvironmentName");function s1(e){M_.validateEnv(e);let t=Object.create(null),r=ln(e,Dn);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==Dn)try{t[n]=Object.assign(new P_,s)}catch{Ty.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(s1,"listDBIDefinitions");function by(e){M_.validateEnv(e);let t=[],r=ln(e,Dn);for(let{key:n}of r.getRange({start:!1}))n!==Dn&&t.push(n);return t}a(by,"listDBIs");function i1(e,t){let n=ln(e,Dn).getEntry(t),s=new P_;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{Ty.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(i1,"getDBIDefinition");function yy(e,t,r,n=!r){if(v_(e,t),t=t.toString(),t===Dn)throw new Error(pr.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return ln(e,t)}catch(s){if(s.message===pr.DBI_DOES_NOT_EXIST){let i=new ym(r,n===!0),o=e.openDB(t,i),c=new P_(r===!0,n);return o[Ry]=c,ln(e,Dn).putSync(t,c),e.dbis[t]=o,o}throw s}}a(yy,"createDBI");function ln(e,t){if(v_(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==Dn?r=i1(e,t):r=new P_,r===void 0)throw new Error(pr.DBI_DOES_NOT_EXIST);let n;try{let s=new ym(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(pr.DBI_DOES_NOT_EXIST):s}return n[Ry]=r,e.dbis[t]=n,n}a(ln,"openDBI");function o1(e,t){v_(e,t),t=t.toString();let r=ln(e,t),n=r.getStats();return r[ri.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(o1,"statDBI");async function a1(e,t){try{let r=qr.join(e,t+qc);return(await Cn.stat(r)).size}catch{throw new Error(pr.INVALID_ENVIRONMENT)}}a(a1,"environmentDataSize");function c1(e,t){if(v_(e,t),t=t.toString(),t===Dn)throw new Error(pr.CANNOT_DROP_INTERNAL_DBIS_NAME);ln(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],ln(e,Dn).removeSync(t)}a(c1,"dropDBI");function l1(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{ln(e,i)}catch(o){if(o.message===pr.DBI_DOES_NOT_EXIST)yy(e,i,i!==t,i===t),n=!0;else throw o}}n&&X$()}a(l1,"initializeDBIs");Ny.exports={openDBI:ln,openEnvironment:Ay,createEnvironment:t1,listDBIs:by,listDBIDefinitions:s1,createDBI:yy,dropDBI:c1,statDBI:o1,deleteEnvironment:n1,initializeDBIs:l1,TransactionCursor:Om,environmentDataSize:a1,copyEnvironment:r1,closeEnvironment:Oy}});var wy=g((kae,Iy)=>{"use strict";var wm=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};Iy.exports=wm});var Dy=g(($ae,Cy)=>{"use strict";var Cm=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}};Cy.exports=Cm});var My=g((Kae,Ly)=>{"use strict";var Dm=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};Ly.exports=Dm});var Yo=g((Xae,vy)=>{"use strict";var u1=We(),_1=wy(),d1=Dy(),f1=My(),Jn=xr(),kc=vr().LMDB_ERRORS_ENUM,E1=dt(),Rs=U(),h1=J(),m1=require("uuid"),Qae=require("lmdb"),{handleHDBError:p1,hdb_errors:S1}=se(),{OVERFLOW_MARKER:zae,MAX_SEARCH_KEY_LENGTH:Jae}=E1,Py=ne();Py.initSync();var B_=Py.get(Rs.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),Lm=Rs.TIME_STAMP_NAMES_ENUM.CREATED_TIME,$i=Rs.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function T1(e,t,r,n,s=Jn.getNextMonotonicTime()){vm(e,t,r,n),Mm(e,t,r);let i=new _1,o=[],c=[];for(let l=0;l<n.length;l++){let _=n[l];Uy(_,!0,s);let u=g1(e,t,r,_),d=_[t];o.push(u),c.push(d)}return Pm(o,c,n,i,s)}a(T1,"insertRecords");function g1(e,t,r,n){let s=n[t];return e.dbis[t].ifNoExists(s,()=>{for(let i=0;i<r.length;i++){let o=r[i];if(o===t||n.hasOwnProperty(o)===!1)continue;let c=n[o];if(typeof c=="function"){let u=c([[{}]]);Array.isArray(u)&&(c=u[0][Rs.FUNC_VAL],n[o]=c)}let l=Jn.getIndexedValues(c),_=e.dbis[o];if(l){B_&&_.prefetch(l.map(u=>({key:u,value:s})),H_);for(let u=0,d=l.length;u<d;u++)_.put(l[u],s)}}B_&&e.dbis[t].prefetch([s],H_),e.dbis[t].put(s,n,n[$i])})}a(g1,"insertRecord");function R1(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(R1,"removeSkippedRecords");function Uy(e,t,r){let n=r>0;(n||!Number.isInteger(e[$i]))&&(e[$i]=r||(r=Jn.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[Lm]))&&(e[Lm]=r||Jn.getNextMonotonicTime()):delete e[Lm]}a(Uy,"setTimestamps");function Mm(e,t,r){r.indexOf(Rs.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(Rs.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(Rs.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(Rs.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),u1.initializeDBIs(e,t,r)}a(Mm,"initializeTransaction");async function A1(e,t,r,n,s=Jn.getNextMonotonicTime()){vm(e,t,r,n),Mm(e,t,r);let i=new d1,o=[],c=[],l=[];for(let _=0;_<n.length;_++){let u=n[_],d=u[t],E;try{E=Um(e,t,u,d,i,!0,s)}catch{i.skipped_hashes.push(d),o.push(_);continue}c.push(E),l.push(d)}return Pm(c,l,n,i,s,o)}a(A1,"updateRecords");async function O1(e,t,r,n,s=Jn.getNextMonotonicTime()){try{vm(e,t,r,n)}catch(l){throw p1(l,l.message,S1.HTTP_STATUS_CODES.BAD_REQUEST)}Mm(e,t,r);let i=new f1,o=[],c=[];for(let l=0;l<n.length;l++){let _=n[l],u;h1.isEmpty(_[t])?(u=m1.v4(),_[t]=u):u=_[t];let d=Um(e,t,_,u,i,!1,s);o.push(d),c.push(u)}return Pm(o,c,n,i,s)}a(O1,"upsertRecords");async function Pm(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||Jn.getNextMonotonicTime(),R1(r,i),n}a(Pm,"finalizeWrite");function Um(e,t,r,n,s,i=!1,o){let c=e.dbis[t],l=c.getEntry(n),_=l?.value,u=_;if(!_){if(i)return!1;_={}}if(Uy(r,!u,o),Number.isInteger(r[$i])&&_[$i]>r[$i])return!1;u&&s.original_records.push(_);let d,E=a(()=>{for(let h in r){if(!r.hasOwnProperty(h)||h===t)continue;let p=r[h],S=e.dbis[h];if(S===void 0)continue;let T=_[h];if(typeof p=="function"){let N=p([[_]]);Array.isArray(N)&&(p=N[0][Rs.FUNC_VAL],r[h]=p)}if(p===T)continue;let A=Jn.getIndexedValues(T);if(A){B_&&S.prefetch(A.map(N=>({key:N,value:n})),H_);for(let N=0,b=A.length;N<b;N++)S.remove(A[N],n)}if(A=Jn.getIndexedValues(p),A){B_&&S.prefetch(A.map(N=>({key:N,value:n})),H_);for(let N=0,b=A.length;N<b;N++)S.put(A[N],n)}}let f=Object.assign({},_,r);c.put(n,f,f[$i])},"do_put");return l?d=c.ifVersion(n,l.version,E):d=c.ifNoExists(n,E),d.then(f=>f?!0:Um(e,t,r,n,s,i,o))}a(Um,"updateUpsertRecord");function b1(e,t,r){if(Jn.validateEnv(e),t===void 0)throw new Error(kc.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(kc.WRITE_ATTRIBUTES_REQUIRED):new Error(kc.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(b1,"validateBasic");function vm(e,t,r,n){if(b1(e,t,r),!Array.isArray(n))throw n===void 0?new Error(kc.RECORDS_REQUIRED):new Error(kc.RECORDS_MUST_BE_ARRAY)}a(vm,"validateWrite");function H_(){}a(H_,"noop");vy.exports={insertRecords:T1,updateRecords:A1,upsertRecords:O1}});var Yi=g((Zae,y1)=>{y1.exports={hdb_table:{hash_attribute:"id",name:"hdb_table",schema:"system",residence:["*"],attributes:[{attribute:"id"},{attribute:"name"},{attribute:"hash_attribute"},{attribute:"schema"},{attribute:"residence"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_attribute:{hash_attribute:"id",name:"hdb_attribute",schema:"system",residence:["*"],attributes:[{attribute:"id"},{attribute:"schema"},{attribute:"table"},{attribute:"attribute"},{attribute:"schema_table"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_schema:{hash_attribute:"name",name:"hdb_schema",schema:"system",residence:["*"],attributes:[{attribute:"name"},{attribute:"createddate"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_user:{hash_attribute:"username",name:"hdb_user",schema:"system",residence:["*"],attributes:[{attribute:"username"},{attribute:"password"},{attribute:"role"},{attribute:"active"},{attribute:"hash"},{attribute:"refresh_token"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_role:{hash_attribute:"id",name:"hdb_role",schema:"system",attributes:[{attribute:"id"},{attribute:"role"},{attribute:"permission"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}],residence:["*"]},hdb_job:{hash_attribute:"id",name:"hdb_job",schema:"system",attributes:[{attribute:"id"},{attribute:"user"},{attribute:"type"},{attribute:"status"},{attribute:"start_datetime"},{attribute:"end_datetime"},{attribute:"message"},{attribute:"created_datetime"},{attribute:"request"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_license:{hash_attribute:"license_key",name:"hdb_license",schema:"system",attributes:[{attribute:"license_key"},{attribute:"company"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_info:{hash_attribute:"info_id",name:"hdb_info",schema:"system",attributes:[{attribute:"info_id"},{attribute:"data_version_num"},{attribute:"hdb_version_num"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_nodes:{hash_attribute:"name",name:"hdb_nodes",schema:"system",attributes:[{attribute:"name"},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_analytics:{hash_attribute:"id",name:"hdb_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]},hdb_raw_analytics:{hash_attribute:"id",name:"hdb_raw_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{attribute:"time"},{attribute:"metrics"}]},hdb_temp:{hash_attribute:"id",name:"hdb_temp",schema:"system",attributes:[{attribute:"id"}]},hdb_durable_session:{hash_attribute:"id",name:"hdb_durable_session",schema:"system",attributes:[{attribute:"id"}]},hdb_session_will:{hash_attribute:"id",name:"hdb_session_will",schema:"system",attributes:[{attribute:"id"}]}}});var jn=g((ece,xy)=>{"use strict";var Hy=J(),By=U(),Ko=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Xn=require("joi"),ni={schema_format:{pattern:Ko,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},N1=Xn.alternatives(Xn.string().min(1).max(ni.schema_length.maximum).pattern(Ko).messages({"string.pattern.base":"{:#label} "+ni.schema_format.message}),Xn.number(),Xn.array()).required(),I1=Xn.alternatives(Xn.string().min(1).max(ni.schema_length.maximum).pattern(Ko).messages({"string.pattern.base":"{:#label} "+ni.schema_format.message}),Xn.number()),w1=Xn.alternatives(Xn.string().min(1).max(ni.schema_length.maximum).pattern(Ko).messages({"string.pattern.base":"{:#label} "+ni.schema_format.message}),Xn.number()).required();function C1(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>ni.schema_length.maximum?`'${e}' maximum of 250 characters`:Ko.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(C1,"checkValidTable");function D1(e,t){return Hy.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(D1,"validateSchemaExists");function L1(e,t){let r=t.state.ancestors[0].schema;return Hy.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(L1,"validateTableExists");function M1(e,t){return e.toLowerCase()===By.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${By.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(M1,"validateSchemaName");xy.exports={common_validators:ni,schema_regex:Ko,hdb_schema_table:N1,validateSchemaExists:D1,validateTableExists:L1,validateSchemaName:M1,checkValidTable:C1,hdb_database:I1,hdb_table:w1}});var x_=g((rce,Gy)=>{var{common_validators:Zn}=jn(),$c=st(),Vc="is required",Tt={database:{presence:!1,format:Zn.schema_format,length:Zn.schema_length},schema:{presence:!1,format:Zn.schema_format,length:Zn.schema_length},table:{presence:!0,format:Zn.schema_format,length:Zn.schema_length},attribute:{presence:!0,format:Zn.schema_format,length:Zn.schema_length},hash_attribute:{presence:!0,format:Zn.schema_format,length:Zn.schema_length}};function Yc(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(Yc,"makeAttributesStrings");function P1(e){return e=Yc(e),Tt.table.presence=!1,Tt.attribute.presence=!1,Tt.hash_attribute.presence=!1,$c.validateObject(e,Tt)}a(P1,"schema_object");function U1(e){return e=Yc(e),Tt.table.presence={message:Vc},Tt.attribute.presence=!1,Tt.hash_attribute.presence=!1,$c.validateObject(e,Tt)}a(U1,"table_object");function v1(e){return e=Yc(e),Tt.table.presence={message:Vc},Tt.attribute.presence=!1,$c.validateObject(e,Tt)}a(v1,"create_table_object");function B1(e){return e=Yc(e),Tt.table.presence={message:Vc},Tt.attribute.presence={message:Vc},Tt.hash_attribute.presence=!1,$c.validateObject(e,Tt)}a(B1,"attribute_object");function H1(e){return e=Yc(e),Tt.table.presence={message:Vc},Tt.attribute.presence=!1,Tt.hash_attribute.presence=!1,$c.validateObject(e,Tt)}a(H1,"describe_table");function x1(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(x1,"validateTableResidence");Gy.exports={schema_object:P1,create_table_object:v1,table_object:U1,attribute_object:B1,describe_table:H1,validateTableResidence:x1}});var qy=g((sce,Fy)=>{"use strict";var G1=require("uuid"),Bm=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||G1.v4(),this.schema_table=`${this.schema}.${this.table}`}};Fy.exports=Bm});var G_=g((oce,ky)=>{"use strict";var F1=qy(),Hm=class extends F1{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}};ky.exports=Hm});var $y=g((cce,Vy)=>{"use strict";Vy.exports=k1;var q1="inserted";function k1(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===q1?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(k1,"returnObject")});var F_=g((uce,zy)=>{"use strict";var V1=U(),xm=We(),$1=Yo(),{getSystemSchemaPath:Y1,getSchemaPath:K1}=ze(),W1=Yi(),Q1=x_(),z1=G_(),J1=$y(),{handleHDBError:Yy,hdb_errors:Wy}=se(),Ky=J(),{HTTP_STATUS_CODES:X1}=Wy,Gm=W1.hdb_attribute,Qy=[];for(let e=0;e<Gm.attributes.length;e++)Qy.push(Gm.attributes[e].attribute);var j1="inserted";zy.exports=Z1;async function Z1(e){let t=Q1.attribute_object(e);if(t)throw Yy(new Error,t.message,Wy.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=!e.skip_table_check&&Ky.checkGlobalSchemaTable(e.schema,e.table);if(r)throw Yy(new Error,r,X1.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=Ky.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 z1(e.schema,e.table,e.attribute,e.id);try{let i=await xm.openEnvironment(K1(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}`);xm.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await xm.openEnvironment(Y1(),V1.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await $1.insertRecords(o,Gm.hash_attribute,Qy,[s]);return J1(j1,c,{records:[s]},l)}catch(i){throw i}}a(Z1,"lmdbCreateAttribute")});var qm=g((dce,Xy)=>{var{hdb_table:eY,hdb_database:Jy}=jn(),tY=st(),Fm=require("joi"),rY={undefined:"undefined",null:"null"},nY=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||rY[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"),sY=Fm.object({database:Jy,schema:Jy,table:eY,records:Fm.array().items(Fm.object().custom(nY)).required()});Xy.exports=function(e){return tY.validateBySchema(e,sY)}});var Kc=g((hce,Zy)=>{"use strict";var As=J(),jy=K(),Ece=qm(),{getDatabases:iY}=(Ae(),ie(ke)),{ClientError:Ki}=se();Zy.exports=oY;function oY(e){if(As.isEmpty(e))throw new Ki("invalid update parameters defined.");if(As.isEmptyOrZeroLength(e.schema))throw new Ki("invalid schema specified.");if(As.isEmptyOrZeroLength(e.table))throw new Ki("invalid table specified.");if(!Array.isArray(e.records))throw new Ki("records must be an array");let t=iY()[e.schema]?.[e.table];if(As.isEmpty(t))throw new Ki(`could not retrieve schema:${e.schema} and table ${e.table}`);let r=t.primaryKey,n=new Set,s={},i=!1;return e.operation==="update"&&(i=!0),e.records.forEach(o=>{if(i&&As.isEmptyOrZeroLength(o[r]))throw jy.error("a valid hash attribute must be provided with update record:",o),new Ki("a valid hash attribute must be provided with update record, check log for more info");if(!As.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw jy.error(`a valid hash value must be provided with ${e.operation} record:`,o),new Ki(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!As.isEmpty(o[r])&&o[r]!==""&&n.has(As.autoCast(o[r]))&&(o.skip=!0),n.add(As.autoCast(o[r]));for(let c in o)s[c]=1}),s[r]=1,{schema_table:t,hashes:Array.from(n),attributes:Object.keys(s)}}a(oY,"insertUpdateValidate")});var tN=g((pce,eN)=>{"use strict";var km=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};eN.exports=km});var sN=g((Tce,nN)=>{"use strict";var Vm=We(),aY=K(),rN=vr().LMDB_ERRORS_ENUM;nN.exports=cY;async function cY(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 Vm.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==rN.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await Vm.closeEnvironment(global.lmdb_map[n]),await Vm.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==rN.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){aY.error(t)}}a(cY,"cleanLMDBMap")});var Os=g((Rce,cN)=>{"use strict";var Wc=require("crypto"),lY=ne(),{CONFIG_PARAMS:uY}=U(),oN="aes-256-cbc",_Y=32,dY=16,$m=64,aN=32,fY=$m+aN,iN=new Map;cN.exports={encrypt:EY,decrypt:hY,createNatsTableStreamName:mY};function EY(e){let t=Wc.randomBytes(_Y),r=Wc.randomBytes(dY),n=Wc.createCipheriv(oN,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(EY,"encrypt");function hY(e){let t=e.substr(0,$m),r=e.substr($m,aN),n=e.substr(fY,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=Wc.createDecipheriv(oN,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(hY,"decrypt");function mY(e,t){let r=lY.get(uY.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=iN.get(r);return n||(n=Wc.createHash("md5").update(r).digest("hex"),iN.set(r,n)),n}a(mY,"createNatsTableStreamName")});var si=g((bce,uN)=>{"use strict";var Oce=kr(),Qc=K(),lN=x_(),pY=Os(),q_=J(),{handleHDBError:k_,hdb_errors:SY}=se(),{HDB_ERROR_MSGS:V_,HTTP_STATUS_CODES:Ym}=SY,TY=ne();TY.initSync();var{getDatabases:Km}=(Ae(),ie(ke)),gY=require("fs-extra");uN.exports={describeAll:RY,describeTable:$_,describeSchema:AY};async function RY(e={}){try{let t=q_.isEmptyOrZeroLength(e),r=!!e.bypass_auth,n,s;!t&&!r&&(n=e.hdb_user?.role?.permission,s=n?.super_user||n?.cluster_user);let i=Km(),o={},c={},l=[],_=e?.exact_count;for(let d in i){o[d]=!0,!t&&!s&&!r&&(c[d]=e.hdb_user?.role?.permission[d]?.describe);let E=i[d];for(let f in E)try{let h;if(t||s||r)h=await $_({schema:d,table:f,exact_count:_});else if(n&&n[d].describe&&n[d].tables[f].describe){let p=n[d].tables[f].attribute_permissions;h=await $_({schema:d,table:f,exact_count:_},p)}h&&l.push(h)}catch(h){Qc.error(h)}}let u={};for(let d in l)t||s||r?(u[l[d].schema]==null&&(u[l[d].schema]={}),u[l[d].schema][l[d].name]=l[d],o[l[d].schema]&&delete o[l[d].schema]):c[l[d].schema]&&(u[l[d].schema]==null&&(u[l[d].schema]={}),u[l[d].schema][l[d].name]=l[d],o[l[d].schema]&&delete o[l[d].schema]);for(let d in o)t||s||r?u[d]={}:c[d]&&(u[d]={});return u}catch(t){return Qc.error("Got an error in describeAll"),Qc.error(t),k_(new Error,V_.DESCRIBE_ALL_ERR)}}a(RY,"describeAll");async function $_(e,t){q_.transformReq(e);let{schema:r,table:n}=e;r=r?.toString(),n=n?.toString();let s=t;e.hdb_user&&!e.hdb_user?.role?.permission?.super_user&&(s=e.hdb_user?.role?.permission[r]?.tables[n]?.attribute_permissions);let i=lN.describe_table(e);if(i)throw i;let c=Km()[r];if(!c)throw k_(new Error,V_.SCHEMA_NOT_FOUND(e.schema),Ym.NOT_FOUND);let l=c[n];if(!l)throw k_(new Error,V_.TABLE_NOT_FOUND(e.schema,e.table),Ym.NOT_FOUND);function _(f){u.push(Object.assign({},{attribute:f.attribute,type:f.type,elements:f.elements?.type,indexed:f.indexed,is_primary_key:f.isPrimaryKey,assigned_created_time:f.assignCreatedTime,assigned_updated_time:f.assignUpdatedTime,nullable:f.nullable,properties:f.properties?f.properties.map(h=>({type:h.type,name:h.name})):void 0}))}a(_,"pushAtt");let u=[];if(s){let f={};s.forEach(h=>{h.describe&&(f[h.attribute_name]=!0)}),l.attributes.forEach(h=>{f[h.name]&&_(h)})}else l.attributes?.forEach(f=>_(f));let d;try{d=(await gY.stat(l.primaryStore.env.path)).size}catch(f){Qc.warn("unable to get database size",f)}let E={schema:r,name:l.tableName,hash_attribute:l.attributes.find(f=>f.isPrimaryKey||f.is_hash_attribute)?.name,audit:l.audit,schema_defined:l.schemaDefined,attributes:u,db_size:d};E.clustering_stream_name=pY.createNatsTableStreamName(E.schema,E.name);try{let f=l.getRecordCount({exactCount:e.exact_count==="true"});E.record_count=f.recordCount,E.estimated_record_range=f.estimatedRange;let h=l.auditStore;if(h)for(let p of h.getKeys({reverse:!0,limit:1}))E.last_updated_record=p[0];if(!E.last_updated_record&&l.indices.__updatedtime__)for(let p of l.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))E.last_updated_record=p}catch(f){Qc.warn(`unable to stat table dbi due to ${f}`)}return E}a($_,"descTable");async function AY(e){q_.transformReq(e);let t=lN.schema_object(e);if(t)throw t;let r;e.hdb_user&&!e.hdb_user?.role?.permission?.super_user&&(r=e.hdb_user?.role?.permission[e.schema]);let n=e.schema.toString(),i=Km()[n];if(!i)throw k_(new Error,V_.SCHEMA_NOT_FOUND(e.schema),Ym.NOT_FOUND);let o={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),q_.isEmpty(l)||l.describe){let _=await $_({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);_&&(o[_.name]=_)}}return o}a(AY,"describeSchema")});var ii=g((wce,hN)=>{var OY=Yi(),{callbackify:dN,promisify:bY}=require("util"),{getDatabases:fN}=(Ae(),ie(ke));hN.exports={setSchemaDataToGlobal:_N,getTableSchema:yY,getSystemSchema:NY,setSchemaDataToGlobalAsync:bY(_N)};var EN=si(),Nce=dN(EN.describeAll),Ice=dN(EN.describeTable);function _N(e){global.hdb_schema=fN(),e&&e()}a(_N,"setSchemaDataToGlobal");function yY(e,t,r){let n=fN()[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(yY,"getTableSchema");function NY(){return OY}a(NY,"getSystemSchema")});var un=g((Dce,TN)=>{"use strict";var K_=qm(),Kt=J(),IY=require("util"),W_=Ln(),wY=ii(),mN=K(),{handleHDBError:Wi,hdb_errors:CY}=se(),{HTTP_STATUS_CODES:Qi}=CY,DY=IY.promisify(wY.getTableSchema),LY="updated",pN="inserted",SN="upserted";TN.exports={insert:PY,update:UY,upsert:vY,validation:MY,flush:BY};async function MY(e){if(Kt.isEmpty(e))throw new Error("invalid update parameters defined.");if(Kt.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if(Kt.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await DY(e.schema,e.table),r=K_(e);if(r)throw r;if(!Array.isArray(e.records))throw new Error("records must be an array");let n=t.hash_attribute,s=new Set,i={},o=!1;return e.operation==="update"&&(o=!0),e.records.forEach(c=>{if(o&&Kt.isEmptyOrZeroLength(c[n]))throw mN.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(!Kt.isEmptyOrZeroLength(c[n])&&(c[n]==="null"||c[n]==="undefined"))throw mN.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[n]}" is not a valid hash attribute value`);!Kt.isEmpty(c[n])&&c[n]!==""&&s.has(Kt.autoCast(c[n]))&&(c.skip=!0),s.add(Kt.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(MY,"validation");async function PY(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=K_(e);if(t)throw Wi(new Error,t.message,Qi.BAD_REQUEST);Kt.transformReq(e);let r=Kt.checkSchemaTableExist(e.schema,e.table);if(r)throw Wi(new Error,r,Qi.BAD_REQUEST);let n=await W_.createRecords(e);return Y_(pN,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(PY,"insertData");async function UY(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=K_(e);if(t)throw Wi(new Error,t.message,Qi.BAD_REQUEST);Kt.transformReq(e);let r=Kt.checkSchemaTableExist(e.schema,e.table);if(r)throw Wi(new Error,r,Qi.BAD_REQUEST);let n=await W_.updateRecords(e);return Kt.isEmpty(n.existing_rows)?Y_(LY,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):Y_(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(UY,"updateData");async function vY(e){if(e.operation!=="upsert")throw Wi(new Error,"invalid operation, must be upsert",Qi.INTERNAL_SERVER_ERROR);let t=K_(e);if(t)throw Wi(new Error,t.message,Qi.BAD_REQUEST);Kt.transformReq(e);let r=Kt.checkSchemaTableExist(e.schema,e.table);if(r)throw Wi(new Error,r,Qi.BAD_REQUEST);let n=await W_.upsertRecords(e);return Y_(SN,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(vY,"upsertData");function Y_(e,t,r,n,s,i){let o={message:`${e} ${t.length} of ${t.length+n.length} records`,new_attributes:s,txn_time:i};return e===pN?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===SN?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(Y_,"returnObject");function BY(e){return Kt.transformReq(e),W_.flush(e.schema,e.table)}a(BY,"flush")});var Qm=g((Mce,AN)=>{var HY=st(),Wm=require("joi"),{hdb_table:xY,hdb_database:gN}=jn(),RN={schema:gN,database:gN,table:xY},GY={date:Wm.date().iso().required()},FY={timestamp:Wm.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};AN.exports=function(e,t){let r=t==="timestamp"?{...RN,...FY}:{...RN,...GY},n=Wm.object(r);return HY.validateBySchema(e,n)}});var yN=g((Pce,bN)=>{var qY=st(),zm=require("joi"),{hdb_table:kY,hdb_database:ON}=jn(),VY=zm.object({schema:ON,database:ON,table:kY,hash_values:zm.array().required(),ids:zm.array()});bN.exports=function(e){return qY.validateBySchema(e,VY)}});var IN=g((Uce,NN)=>{"use strict";var Jm=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}},Xm=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}},jm=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};NN.exports={InsertObject:Jm,NoSQLSeachObject:Xm,DeleteResponseObject:jm}});var Xi=g((Bce,MN)=>{"use strict";var CN=Qm(),$Y=yN(),zi=J(),wN=require("moment"),DN=K(),{promisify:YY,callbackify:KY}=require("util"),Ji=U(),WY=ii(),Zm=YY(WY.getTableSchema),ep=Ln(),{DeleteResponseObject:QY}=IN(),{handleHDBError:oi,hdb_errors:zY}=se(),{HDB_ERROR_MSGS:Q_,HTTP_STATUS_CODES:ai}=zY,JY="records successfully deleted",XY=KY(LN);MN.exports={delete:XY,deleteRecord:LN,deleteFilesBefore:jY,deleteAuditLogsBefore:ZY};async function jY(e){let t=CN(e,"date");if(t)throw oi(t,t.message,ai.BAD_REQUEST,void 0,void 0,!0);if(zi.transformReq(e),!wN(e.date,wN.ISO_8601).isValid())throw oi(new Error,Q_.INVALID_DATE,ai.BAD_REQUEST,Ji.LOG_LEVELS.ERROR,Q_.INVALID_DATE,!0);let n=zi.checkSchemaTableExist(e.schema,e.table);if(n)throw oi(new Error,n,ai.NOT_FOUND,Ji.LOG_LEVELS.ERROR,n,!0);let s=await ep.deleteRecordsBefore(e);if(await Zm(e.schema,e.table),DN.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(jY,"deleteFilesBefore");async function ZY(e){let t=CN(e,"timestamp");if(t)throw oi(t,t.message,ai.BAD_REQUEST,void 0,void 0,!0);if(zi.transformReq(e),isNaN(e.timestamp))throw oi(new Error,Q_.INVALID_VALUE("Timestamp"),ai.BAD_REQUEST,Ji.LOG_LEVELS.ERROR,Q_.INVALID_VALUE("Timestamp"),!0);let r=zi.checkSchemaTableExist(e.schema,e.table);if(r)throw oi(new Error,r,ai.NOT_FOUND,Ji.LOG_LEVELS.ERROR,r,!0);let n=await ep.deleteAuditLogsBefore(e);return await Zm(e.schema,e.table),DN.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(ZY,"deleteAuditLogsBefore");async function LN(e){e.ids&&(e.hash_values=e.ids);let t=$Y(e);if(t)throw oi(t,t.message,ai.BAD_REQUEST,void 0,void 0,!0);zi.transformReq(e);let r=zi.checkSchemaTableExist(e.schema,e.table);if(r)throw oi(new Error,r,ai.NOT_FOUND,Ji.LOG_LEVELS.ERROR,r,!0);try{await Zm(e.schema,e.table);let n=await ep.deleteRecords(e);return zi.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${JY}`),n}catch(n){if(n.message===Ji.SEARCH_NOT_FOUND_MESSAGE){let s=new QY;return s.message=Ji.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(LN,"deleteRecord")});var z_=g((xce,vN)=>{var eK=require("crypto"),PN=9;function tK(e){let t=nK(PN),r=UN(e+t);return t+r}a(tK,"createHash");function rK(e,t){let r=e?.substr(0,PN),n=r+UN(t+r);return e===n}a(rK,"validateHash");function nK(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(nK,"generateSalt");function UN(e){return eK.createHash("md5").update(e).digest("hex")}a(UN,"md5");vN.exports={hash:tK,validate:rK}});var HN=g((Fce,BN)=>{var tp=st(),er={username:{presence:!0,format:"[\\w\\-\\_]+",exclusion:{within:["system"],message:"You cannot create tables within the system schema"}},password:{presence:!0},role:{presence:!0,format:"[\\w\\-\\_]+"},active:{presence:!0,inclusion:{within:[!0,!1],message:"must be a boolean"}}};function sK(e){return er.password.presence=!0,er.username.presence=!0,er.role.presence=!0,er.active.presence=!0,tp.validateObject(e,er)}a(sK,"addUserValidation");function iK(e){return er.password.presence=!1,er.username.presence=!0,er.role.presence=!1,er.active.presence=!1,tp.validateObject(e,er)}a(iK,"alterUserValidation");function oK(e){return er.password.presence=!1,er.username.presence=!0,er.role.presence=!1,er.active.presence=!1,tp.validateObject(e,er)}a(oK,"dropUserValidation");BN.exports={addUserValidation:sK,alterUserValidation:iK,dropUserValidation:oK}});var ct=g((Vce,GN)=>{"use strict";var{platform:kce}=require("os"),aK="nats-server.zip",rp="nats-server",cK=process.platform==="win32"?`${rp}.exe`:rp,lK=/^[^\s.,*>]+$/,xN="__request__",uK=a(e=>`${e}.${xN}`,"REQUEST_SUBJECT"),_K={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},dK={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},fK={HUB:"hub.pid",LEAF:"leaf.pid"},EK={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},hK={SUCCESS:"success",ERROR:"error"},mK={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},pK={TXN:"txn",MSGID:"msgid"},Wo={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},SK={[Wo.ERR]:1,[Wo.WRN]:2,[Wo.INF]:3,[Wo.DBG]:4,[Wo.TRC]:5},TK={debug:"-D",trace:"-DVV"};GN.exports={NATS_SERVER_ZIP:aK,NATS_SERVER_NAME:rp,NATS_BINARY_NAME:cK,PID_FILES:fK,NATS_CONFIG_FILES:dK,SERVER_SUFFIX:EK,NATS_TERM_CONSTRAINTS_RX:lK,REQUEST_SUFFIX:xN,UPDATE_REMOTE_RESPONSE_STATUSES:hK,CLUSTER_STATUS_STATUSES:mK,REQUEST_SUBJECT:uK,SUBJECT_PREFIXES:pK,MSG_HEADERS:_K,LOG_LEVELS:Wo,LOG_LEVEL_FLAGS:TK,LOG_LEVEL_HIERARCHY:SK}});var qN=g((Yce,FN)=>{"use strict";var J_=U(),X_=class{static{a(this,"BaseLicense")}constructor(t=0,r=J_.RAM_ALLOCATION_ENUM.DEFAULT,n=J_.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},np=class extends X_{static{a(this,"ExtendedLicense")}constructor(t=0,r=J_.RAM_ALLOCATION_ENUM.DEFAULT,n=J_.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};FN.exports={BaseLicense:X_,ExtendedLicense:np}});var ji=g((Wce,WN)=>{"use strict";var zo=require("fs-extra"),VN=z_(),$N=require("crypto"),gK=require("moment"),RK=require("uuid").v4,tr=K(),ip=require("path"),AK=J(),ci=U(),{totalmem:kN}=require("os"),OK=qN().ExtendedLicense,Qo="invalid license key format",bK="061183",yK="mofi25",NK="aes-256-cbc",IK=16,wK=32,YN=ne();YN.initSync();var sp;WN.exports={validateLicense:KN,generateFingerPrint:DK,licenseSearch:cp,getLicense:PK,checkMemoryLimit:UK};function op(){return ip.join(YN.getHdbBasePath(),ci.LICENSE_KEY_DIR_NAME,ci.LICENSE_FILE_NAME)}a(op,"getLicenseDirPath");function CK(){let e=op();return ip.join(e,ci.LICENSE_FILE_NAME)}a(CK,"getLicenseFilePath");function ap(){let e=op();return ip.join(e,ci.REG_KEY_FILE_NAME)}a(ap,"getFingerPrintFilePath");async function DK(){let e=ap();try{return await zo.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await LK();throw tr.error(`Error writing fingerprint file to ${e}`),tr.error(t),new Error("There was an error generating the fingerprint")}}a(DK,"generateFingerPrint");async function LK(){let e=RK(),t=VN.hash(e),r=ap();try{await zo.mkdirp(op()),await zo.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw tr.error(`Error writing fingerprint file to ${r}`),tr.error(n),new Error("There was an error generating the fingerprint")}return t}a(LK,"writeFingerprint");function KN(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:ci.RAM_ALLOCATION_ENUM.DEFAULT,version:ci.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return tr.error("empty license key passed to validate."),r;let n=ap(),s=!1;try{s=zo.statSync(n)}catch(i){tr.error(i)}if(s){let i;try{i=zo.readFileSync(n,"utf8")}catch{tr.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(yK),c=o[1];c=Buffer.concat([Buffer.from(c)],IK);let l=Buffer.concat([Buffer.from(i)],wK),_=$N.createDecipheriv(NK,l,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let u=null;try{u=_.update(o[0],"hex","utf8"),u.trim(),u+=_.final("utf8")}catch{let f=MK(o[0],i);if(f)u=f;else throw r.valid_license=!1,r.valid_machine=!1,console.error(Qo),tr.error(Qo),new Error(Qo)}let d;if(isNaN(u))try{d=JSON.parse(u),r.version=d.version,r.exp_date=d.exp_date,isNaN(r.exp_date)&&(r.exp_date=new Date(r.exp_date).getTime()),d.ram_allocation&&(r.ram_allocation=d.ram_allocation)}catch{throw console.error(Qo),tr.error(Qo),new Error(Qo)}else r.exp_date=u;r.exp_date<gK().valueOf()&&(r.valid_date=!1),VN.validate(o[1],`${bK}${i}${t}`)||(r.valid_license=!1)}else r.valid_license=!1,r.valid_machine=!1;return r.valid_license&&r.valid_machine&&r.valid_date||tr.error("Invalid licence"),r}a(KN,"validateLicense");function MK(e,t){try{let r=$N.createDecipher("aes192",t),n=r.update(e,"hex","utf8");return n.trim(),n+=r.final("utf8"),n}catch{tr.warn("Check old license failed")}}a(MK,"checkOldLicense");function cp(){let e=new OK,t=[];try{t=zo.readFileSync(CK(),"utf-8").split(ci.NEW_LINE)}catch(r){r.code==="ENOENT"?tr.info("no license file found"):tr.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if(AK.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=KN(s.license_key,s.company);i.valid_machine===!0&&i.valid_date===!0&&i.valid_machine===!0&&(e.exp_date=i.exp_date>e.exp_date?i.exp_date:e.exp_date,e.ram_allocation=i.ram_allocation,e.enterprise=!0)}catch(s){tr.error("There was an error parsing the license string."),tr.error(s),e.ram_allocation=ci.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return sp=e,e}a(cp,"licenseSearch");async function PK(){return sp||await cp(),sp}a(PK,"getLicense");function UK(){let e=cp().ram_allocation,t=process.constrainedMemory?.()||kN();if(t=Math.round(Math.min(t,kN())/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(UK,"checkMemoryLimit")});var _n=g((jce,lI)=>{"use strict";var XN="username is required",jN="nothing to update, must supply active, role or password to update",ZN="password cannot be an empty string",eI="If role is specified, it cannot be empty.",tI="active must be true or false";lI.exports={addUser:VK,alterUser:$K,dropUser:KK,getSuperUser:JK,userInfo:WK,listUsers:Z_,listUsersExternal:QK,setUsersToGlobal:Xo,findAndValidateUser:aI,getClusterUser:XK,USERNAME_REQUIRED:XN,ALTERUSER_NOTHING_TO_UPDATE:jN,EMPTY_PASSWORD:ZN,EMPTY_ROLE:eI,ACTIVE_BOOLEAN:tI};var rI=un(),vK=Xi(),_p=z_(),nI=HN(),sI=kr(),dp=bs(),Vr=J(),iI=require("validate.js"),Oe=K(),{promisify:BK}=require("util"),fp=Os(),QN=U(),zN=ct(),HK=hr(),zce=ne(),Jce=ji(),xK=Yi(),{table:Xce}=(Ae(),ie(ke)),{handleHDBError:es,hdb_errors:GK}=se(),{HTTP_STATUS_CODES:ts,AUTHENTICATION_ERROR_MSGS:lp,HDB_ERROR_MSGS:Jo}=GK,{UserEventMsg:Ep}=Mn(),up=require("lodash"),{server:hp}=(fr(),ie(Gi)),FK=K();hp.getUser=(e,t)=>aI(e,t,t!=null);var oI={username:!0,active:!0,role:!0,password:!0},JN=new Map,j_=sI.searchByValue,qK=sI.searchByHash,kK=BK(vK.delete);async function VK(e){let t=iI.cleanAttributes(e,oI),r=nI.addUserValidation(t);if(r)throw es(new Error,r.message,ts.BAD_REQUEST,void 0,void 0,!0);let n={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["id","permission","role"]},s;try{s=await j_(n),s=s&&Array.from(s)}catch(l){throw Oe.error("There was an error searching for a role in add user"),Oe.error(l),l}if(!s||s.length<1)throw es(new Error,Jo.ROLE_NAME_NOT_FOUND(t.role),ts.NOT_FOUND,void 0,void 0,!0);if(s.length>1)throw es(new Error,Jo.DUP_ROLES_FOUND(t.role),ts.CONFLICT,void 0,void 0,!0);s[0].permission.cluster_user===!0&&(t.hash=fp.encrypt(t.password)),t.password=_p.hash(t.password),t.role=s[0].id;let i={operation:"insert",schema:"system",table:"hdb_user",records:[t]},o;try{o=await rI.insert(i)}catch(l){throw Oe.error("There was an error searching for a user."),Oe.error(l),l}Oe.debug(o);try{await Xo()}catch(l){throw Oe.error("Got an error setting users to global"),Oe.error(l),l}if(o.skipped_hashes.length===1)throw es(new Error,Jo.USER_ALREADY_EXISTS(t.username),ts.CONFLICT,void 0,void 0,!0);let c=Object.assign({},t);return c.role=s[0],dp.signalUserChange(new Ep(process.pid)),`${c.username} successfully added`}a(VK,"addUser");async function $K(e){let t=iI.cleanAttributes(e,oI);if(Vr.isEmptyOrZeroLength(t.username))throw new Error(XN);if(Vr.isEmptyOrZeroLength(t.password)&&Vr.isEmptyOrZeroLength(t.role)&&Vr.isEmptyOrZeroLength(t.active))throw new Error(jN);if(!Vr.isEmpty(t.password)&&Vr.isEmptyOrZeroLength(t.password.trim()))throw new Error(ZN);if(!Vr.isEmpty(t.active)&&!Vr.isBoolean(t.active))throw new Error(tI);let r=YK(t.username);if(!Vr.isEmpty(t.password)&&!Vr.isEmptyOrZeroLength(t.password.trim())&&(r&&(t.hash=fp.encrypt(t.password)),t.password=_p.hash(t.password)),t.role==="")throw new Error(eI);if(t.role){let i={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]},o;try{o=Array.from(await j_(i)||[])}catch(c){throw Oe.error("Got an error searching for a role."),Oe.error(c),c}if(!o||o.length===0){let c=Jo.ALTER_USER_ROLE_NOT_FOUND(t.role);throw Oe.error(c),es(new Error,c,ts.NOT_FOUND,void 0,void 0,!0)}if(o.length>1){let c=Jo.ALTER_USER_DUP_ROLES(t.role);throw Oe.error(c),es(new Error,c,ts.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 rI.update(n)}catch(i){throw Oe.error("Error during update."),Oe.error(i),i}try{await Xo()}catch(i){throw Oe.error("Got an error setting users to global"),Oe.error(i),i}return dp.signalUserChange(new Ep(process.pid)),s}a($K,"alterUser");function YK(e){let t=!1,r=global.hdb_users.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(YK,"isClusterUser");async function KK(e){try{let t=nI.dropUserValidation(e);if(t)throw new Error(t);let r={table:"hdb_user",schema:"system",hash_values:[e.username]};if(Vr.isEmpty(global.hdb_users.get(e.username)))throw es(new Error,Jo.USER_NOT_EXIST(e.username),ts.NOT_FOUND,void 0,void 0,!0);let n;try{n=await kK(r)}catch(s){throw Oe.error("Got an error deleting a user."),Oe.error(s),s}Oe.debug(n);try{await Xo()}catch(s){throw Oe.error("Got an error setting users to global."),Oe.error(s),s}return dp.signalUserChange(new Ep(process.pid)),`${e.username} successfully deleted`}catch(t){throw t}}a(KK,"dropUser");async function WK(e){let t={};try{if(!e||!e.hdb_user)return"There was no user info in the body";t=up.cloneDeep(e.hdb_user);let r={schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]},n;try{n=await qK(r)}catch(s){throw Oe.error("Got an error searching for a role."),Oe.error(s),s}t.role=n[0],delete t.password,delete t.refresh_token,delete t.hash}catch(r){throw Oe.error(r),r}return t}a(WK,"userInfo");async function QK(){let e;try{e=await Z_()}catch(t){throw Oe.error("Got an error listing users."),Oe.error(t),t}try{e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token})}catch{throw new Error("there was an error massaging the user data")}return[...e.values()]}a(QK,"listUsersExternal");async function Z_(){try{let e={schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]},t;try{t=await j_(e)}catch(o){throw Oe.error("Got an error searching for roles."),Oe.error(o),o}let r={};for(let o of t)r[o.id]=up.cloneDeep(o);if(Object.keys(r).length===0)return null;let n={schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]},s;try{s=await j_(n)}catch(o){throw Oe.error("Got an error searching for users."),Oe.error(o),o}let i=new Map;for(let o of s)o=up.cloneDeep(o),o.role=r[o.role],zK(o.role),i.set(o.username,o);return i}catch(e){throw Oe.error("got an error listing users"),Oe.error(e),Vr.errorizeMessage(e)}return null}a(Z_,"listUsers");function zK(e){try{if(!e){Oe.error("invalid user role found.");return}e.permission.system||(e.permission.system={}),e.permission.system.tables||(e.permission.system.tables={});for(let t of Object.keys(xK)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}catch(t){Oe.error("Got an error trying to set system permissions."),Oe.error(t)}}a(zK,"appendSystemTablesToRole");async function Xo(){try{let e=await Z_();global.hdb_users=e}catch(e){throw Oe.error(e),e}}a(Xo,"setUsersToGlobal");async function aI(e,t,r=!0){global.hdb_users||await Xo();let n=global.hdb_users.get(e);if(!n){if(!r)return{username:e};throw es(new Error,lp.GENERIC_AUTH_FAIL,ts.UNAUTHORIZED,void 0,void 0,!0)}if(n&&!n.active)throw es(new Error,lp.USER_INACTIVE,ts.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(JN.get(t)===n.password)return s;if(_p.validate(n.password,t))JN.set(t,n.password);else throw es(new Error,lp.GENERIC_AUTH_FAIL,ts.UNAUTHORIZED,void 0,void 0,!0)}return s}a(aI,"findAndValidateUser");async function JK(){global.hdb_users||await Xo();for(let[,e]of global.hdb_users)if(e.role.role==="super_user")return e}a(JK,"getSuperUser");async function XK(){let e=await Z_(),t=HK.getConfigFromFile(QN.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!Vr.isEmpty(r)&&r?.role?.role===QN.ROLE_TYPES_ENUM.CLUSTER_USER)return r.decrypt_hash=fp.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+zN.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+zN.SERVER_SUFFIX.ADMIN,r}a(XK,"getClusterUser");var cI=[];hp.invalidateUser=function(e){for(let t of cI)try{t(e)}catch(r){FK.error("Error invalidating user",r)}};hp.onInvalidatedUser=function(e){cI.push(e)}});var Jc=g((rle,fI)=>{"use strict";var Zi=K(),$r=U(),jK=sN(),ele=ii(),tle=si(),ZK=_n(),{validateEvent:uI}=Mn(),zc=Ln(),eW=require("process"),{resetDatabases:tW}=(Ae(),ie(ke)),rW={[$r.ITC_EVENT_TYPES.SCHEMA]:nW,[$r.ITC_EVENT_TYPES.USER]:dI};async function nW(e){let t=uI(e);if(t){Zi.error(t);return}Zi.trace("ITC schemaHandler received schema event:",e),await jK(e.message),await sW(e.message)}a(nW,"schemaHandler");async function sW(e){try{zc.resetReadTxn($r.SYSTEM_SCHEMA_NAME,$r.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),zc.resetReadTxn($r.SYSTEM_SCHEMA_NAME,$r.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),zc.resetReadTxn($r.SYSTEM_SCHEMA_NAME,$r.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=tW();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){Zi.error(t)}}a(sW,"syncSchemaMetadata");var _I=[];async function dI(e){try{try{zc.resetReadTxn($r.SYSTEM_SCHEMA_NAME,$r.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),zc.resetReadTxn($r.SYSTEM_SCHEMA_NAME,$r.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){Zi.warn(r)}let t=uI(e);if(t){Zi.error(t);return}Zi.trace(`ITC userHandler ${$r.HDB_ITC_CLIENT_PREFIX}${eW.pid} received user event:`,e),await ZK.setUsersToGlobal();for(let r of _I)r()}catch(t){Zi.error(t)}}a(dI,"userHandler");dI.addListener=function(e){_I.push(e)};fI.exports=rW});var Mn=g((cle,hI)=>{"use strict";var sle=K(),mp=J(),iW=U(),{ITC_ERRORS:Xc}=vr(),{parentPort:ile,threadId:oW,isMainThread:aW,workerData:ole}=require("worker_threads"),{onMessageFromWorkers:cW,broadcast:ale,broadcastWithAcknowledgement:lW}=ot();hI.exports={sendItcEvent:uW,validateEvent:EI,SchemaEventMsg:_W,UserEventMsg:dW};var ed;cW(async(e,t)=>{ed=ed||Jc(),EI(e),ed[e.type]&&await ed[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function uW(e){return!aW&&e.message&&(e.message.originator=oW),lW(e)}a(uW,"sendItcEvent");function EI(e){if(typeof e!="object")return Xc.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||mp.isEmpty(e.type))return Xc.MISSING_TYPE;if(!e.hasOwnProperty("message")||mp.isEmpty(e.message))return Xc.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||mp.isEmpty(e.message.originator))return Xc.MISSING_ORIGIN;if(iW.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return Xc.INVALID_EVENT(e.type)}a(EI,"validateEvent");function _W(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(_W,"SchemaEventMsg");function dW(e){this.originator=e}a(dW,"UserEventMsg")});var bs=g((_le,TI)=>{"use strict";var mI=U(),ule=J(),td=K(),pI=tN(),jo,{sendItcEvent:SI}=Mn();function fW(e){try{td.trace("signalSchemaChange called with message:",e),jo=jo||Jc();let t=new pI(mI.ITC_EVENT_TYPES.SCHEMA,e);return jo.schema(t),SI(t)}catch(t){td.error(t)}}a(fW,"signalSchemaChange");function EW(e){try{td.trace("signalUserChange called with message:",e),jo=jo||Jc();let t=new pI(mI.ITC_EVENT_TYPES.USER,e);return jo.user(t),SI(t)}catch(t){td.error(t)}}a(EW,"signalUserChange");TI.exports={signalSchemaChange:fW,signalUserChange:EW}});var rd=g((fle,RI)=>{"use strict";var gI=J(),hW=U(),mW=K(),pW=F_(),SW=G_(),TW=bs(),{SchemaEventMsg:gW}=Mn(),RW="already exists in";RI.exports=AW;async function AW(e,t,r){if(gI.isEmptyOrZeroLength(r))return r;let n=[];gI.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 OW(e,t.schema,t.name,i)})),s}a(AW,"lmdbCheckForNewAttributes");async function OW(e,t,r,n){let s=new SW(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await bW(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(RW))mW.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(OW,"createNewAttribute");async function bW(e){let t;return t=await pW(e),TW.signalSchemaChange(new gW(process.pid,hW.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(bW,"createAttribute")});var Zo=g((hle,AI)=>{"use strict";var pp=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}};AI.exports=pp});var bI=g((ple,OI)=>{"use strict";var yW=Zo(),NW=U().OPERATIONS_ENUM,Sp=class extends yW{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(NW.INSERT,r,n,s,i),this.records=t}};OI.exports=Sp});var NI=g((Tle,yI)=>{"use strict";var IW=Zo(),wW=U().OPERATIONS_ENUM,Tp=class extends IW{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(wW.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};yI.exports=Tp});var wI=g((Rle,II)=>{"use strict";var CW=Zo(),DW=U().OPERATIONS_ENUM,gp=class extends CW{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(DW.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};II.exports=gp});var DI=g((Ole,CI)=>{"use strict";var LW=Zo(),MW=U().OPERATIONS_ENUM,Rp=class extends LW{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(MW.DELETE,n,s,t,i),this.original_records=r}};CI.exports=Rp});var jc=g((Nle,UI)=>{"use strict";var yle=require("path"),LI=We(),PW=bI(),UW=NI(),vW=wI(),BW=DI(),ea=dt(),MI=J(),{CONFIG_PARAMS:HW}=U(),PI=ne();PI.initSync();var nd=U().OPERATIONS_ENUM,{getTransactionAuditStorePath:xW}=ze();UI.exports=GW;async function GW(e,t){if(PI.get(HW.LOGGING_AUDITLOG)===!1)return;let r=xW(e.schema,e.table),n=await LI.openEnvironment(r,e.table,!0),s=FW(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){LI.initializeDBIs(n,ea.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,ea.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[ea.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[ea.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),MI.isEmpty(s.user_name)||n.dbis[ea.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[ea.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(GW,"writeTransaction");function FW(e,t){let r=MI.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===nd.INSERT)return new PW(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===nd.UPDATE)return new UW(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===nd.UPSERT)return new vW(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===nd.DELETE)return new BW(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(FW,"createTransactionObject")});var Ap=g((Cle,vI)=>{"use strict";var qW=Kc(),wle=Cc(),Zc=U(),kW=Dc(),VW=Yo().insertRecords,$W=We(),YW=K(),KW=rd(),{getSchemaPath:WW}=ze(),QW=jc();vI.exports=zW;async function zW(e){try{let{schema_table:t,attributes:r}=qW(e);kW(e,r,t.hash_attribute),e.schema!==Zc.SYSTEM_SCHEMA_NAME&&(r.includes(Zc.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(Zc.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(Zc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(Zc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await KW(e.hdb_auth_header,t,r),s=WW(e.schema,e.table),i=await $W.openEnvironment(s,e.table),o=await VW(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await QW(e,o)}catch(c){YW.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(zW,"lmdbCreateRecords")});var xI=g((Lle,HI)=>{"use strict";var BI=U(),JW=Ap(),XW=Cc(),jW=require("fs-extra"),{getSchemaPath:ZW}=ze();HI.exports=eQ;async function eQ(e){let t=[{name:e.schema,createddate:Date.now()}],r=new XW(BI.SYSTEM_SCHEMA_NAME,BI.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await JW(r),await jW.mkdirp(ZW(e.schema))}a(eQ,"lmdbCreateSchema")});var FI=g((Ple,GI)=>{"use strict";var Op=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}};GI.exports=Op});var $I=g((xle,VI)=>{"use strict";var qI=We(),bp=xr(),yp=vr().LMDB_ERRORS_ENUM,tQ=dt(),kI=K(),vle=J(),rQ=require("lmdb"),nQ=FI(),sQ=U(),{OVERFLOW_MARKER:Ble,MAX_SEARCH_KEY_LENGTH:Hle}=tQ,iQ=sQ.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function oQ(e,t,r,n){if(bp.validateEnv(e),t===void 0)throw new Error(yp.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(yp.IDS_REQUIRED):new Error(yp.IDS_MUST_BE_ITERABLE);try{let s=qI.listDBIs(e);qI.initializeDBIs(e,t,s);let i=new nQ,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[iQ]>n){i.skipped.push(o);continue}let p=e.dbis[t].ifVersion(o,rQ.IF_EXISTS,()=>{e.dbis[t].remove(o);for(let S=0;S<s.length;S++){let T=s[S];if(!h.hasOwnProperty(T)||T===t)continue;let A=e.dbis[T],N=h[T];if(N!=null)try{let b=bp.getIndexedValues(N);if(b)for(let v=0,P=b.length;v<P;v++)A.remove(b[v],o)}catch{kI.warn(`cannot delete from attribute: ${T}, ${N}:${o}`)}}});c.push(p),l.push(o),i.original_records.push(h)}catch(h){kI.warn(h),i.skipped.push(o)}let _=[],u=await Promise.all(c);for(let E=0,f=u.length;E<f;E++)u[E]===!0?i.deleted.push(l[E]):(i.skipped.push(l[E]),_.push(E));let d=0;for(let E=0;E<_.length;E++){let f=_[E];i.original_records.splice(f-d,1),d++}return i.txn_time=bp.getNextMonotonicTime(),i}catch(s){throw s}}a(oQ,"deleteRecords");VI.exports={deleteRecords:oQ}});var el=g((Fle,KI)=>{"use strict";var ta=J(),aQ=$I(),cQ=We(),{getSchemaPath:lQ}=ze(),uQ=jc(),_Q=K();KI.exports=dQ;async function dQ(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(ta.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(ta.isEmptyOrZeroLength(e.hash_values)&&!ta.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];ta.isEmpty(l)||e.hash_values.push(l)}}if(ta.isEmptyOrZeroLength(e.hash_values))return YI([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(ta.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=lQ(e.schema,e.table),i=await cQ.openEnvironment(s,e.table),o=await aQ.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await uQ(e,o)}catch(c){_Q.error(`unable to write transaction due to ${c.message}`)}return YI(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(dQ,"lmdbDeleteRecords");function YI(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(YI,"createDeleteResponse")});var Ip=g((Vle,WI)=>{"use strict";var fQ=U(),kle=xr();function Np(e,t){let r=Object.create(null);if(t.length===1&&fQ.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(Np,"parseRow");function EQ(e,t,r,n){let s=Np(r,e);n.push(s)}a(EQ,"searchAll");function hQ(e,t,r,n){let s=Np(r,e);n[t]=s}a(hQ,"searchAllToMap");function mQ(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(mQ,"iterateDBI");function eo(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(eo,"pushResults");function pQ(e,t,r,n,s,i){t.toString().endsWith(e)&&eo(t,r,n,s,i)}a(pQ,"endsWith");function SQ(e,t,r,n,s,i){t.toString().includes(e)&&eo(t,r,n,s,i)}a(SQ,"contains");function TQ(e,t,r,n,s,i){t>e&&eo(t,r,n,s,i)}a(TQ,"greaterThanCompare");function gQ(e,t,r,n,s,i){t>=e&&eo(t,r,n,s,i)}a(gQ,"greaterThanEqualCompare");function RQ(e,t,r,n,s,i){t<e&&eo(t,r,n,s,i)}a(RQ,"lessThanCompare");function AQ(e,t,r,n,s,i){t<=e&&eo(t,r,n,s,i)}a(AQ,"lessThanEqualCompare");WI.exports={parseRow:Np,searchAll:EQ,searchAllToMap:hQ,iterateDBI:mQ,endsWith:pQ,contains:SQ,greaterThanCompare:TQ,greaterThanEqualCompare:gQ,lessThanCompare:RQ,lessThanEqualCompare:AQ,pushResults:eo}});var ra=g((Qle,ew)=>{"use strict";var li=We(),Yle=K(),Yr=xr(),sd=dt(),Et=vr().LMDB_ERRORS_ENUM,Kle=J(),OQ=U(),id=Ip(),{parseRow:bQ}=id,Wle=require("lmdb"),{OVERFLOW_MARKER:QI,MAX_SEARCH_KEY_LENGTH:yQ}=sd;function zI(e,t,r,n=!1,s=void 0,i=void 0){return to(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(zI,"iterateFullIndex");function tl(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,_=!1){return to(e,t,r,(u,d,E,f)=>{let A={transaction:u,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!l:!_,exclusiveStart:i===!0?_:l};return f===r?(A.values=!1,d.getRange(A).map(N=>({value:N}))):d.getRange(A)})}a(tl,"iterateRangeBetween");function to(e,t,r,n){let s=e.database||e,i=li.openDBI(s,r);i[sd.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&li.openDBI(s,t);let o;e.database?o=e:(o=e.useReadTransaction(),o.database=e);let c=n(o,i,s,t);return c.transaction=o,e.database||(c.onDone=()=>{o.done()}),c}a(to,"setupTransaction");function JI(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(QI)){if(!s)if(r)s=li.openDBI(e,r);else{let l=li.listDBIs(e);for(let _=0,u=l.length;_<u&&(s=li.openDBI(e,l[_]),!s[sd.DBI_DEFINITION_NAME].is_hash_attribute);_++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(JI,"getOverflowCheck");function NQ(e,t,r,n=!1,s=void 0,i=void 0){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);return to(e,t,t,(o,c,l)=>(od(r),r=rl(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(_=>bQ(_.value,r))))}a(NQ,"searchAll");function IQ(e,t,r,n=!1,s=void 0,i=void 0){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);od(r),r=rl(e.database||e,r);let o=new Map;for(let{key:c,value:l}of zI(e,t,t,n,s,i))o.set(c,id.parseRow(l,r));return o}a(IQ,"searchAllToMap");function wQ(e,t,r=!1,n=void 0,s=void 0){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=zI(e,void 0,t,r,n,s),c=o.transaction,l=JI(c.database,c,void 0,t);for(let{key:_,value:u}of o){let d=l(_,u);i[d]===void 0&&(i[d]=[]),i[d].push(u)}return i}a(wQ,"iterateDBI");function CQ(e,t){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);return li.statDBI(e,t).entryCount}a(CQ,"countAll");function DQ(e,t,r,n,s=!1,i=void 0,o=void 0){return ui(e,r,n),to(e,t,r,(c,l,_,u)=>(n=Yr.convertKeyValueToWrite(n),u===r?l.get(n,{transaction:c,lazy:!0})===void 0?[]:[{key:n,value:n}]:l.getValues(n,{transaction:c,reverse:s,limit:i,offset:o}).map(d=>({key:n,value:d}))))}a(DQ,"equals");function LQ(e,t,r){return ui(e,t,r),li.openDBI(e,t).getValuesCount(r)}a(LQ,"count");function MQ(e,t,r,n,s=!1,i=void 0,o=void 0){return ui(e,r,n),to(e,null,r,(c,l)=>{n=Yr.convertKeyValueToWrite(n);let _=!0;typeof n=="number"&&(_=!1);let u;if(s===!0){let d;for(let E of l.getKeys({transaction:c,start:n}))if(!E.startsWith(n)){d=E;break}return d!==void 0&&(Number.isInteger(o)?o++:i++),u=l.getRange({transaction:c,start:d,end:void 0,reverse:s,limit:i,offset:o}).map(E=>{let{key:f}=E;if(f!==d){if(f.toString().startsWith(n))return E;if(_===!0)return u.DONE}}),u.filter(E=>E)}else return u=l.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(d=>{if(d.key.toString().startsWith(n))return d;if(_===!0)return u.DONE}),_?u:u.filter(d=>d)})}a(MQ,"startsWith");function PQ(e,t,r,n,s=!1,i=void 0,o=void 0){return XI(e,t,r,n,s,i,o,!0)}a(PQ,"endsWith");function XI(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return ui(e,r,n),to(e,null,r,(l,_,u,d)=>{let E=JI(u,l,d,r);return o=Number.isInteger(o)?o:0,_.getKeys({transaction:l,end:s?!1:void 0,reverse:s}).flatMap(f=>{let h=f.toString();return h.endsWith(QI)?_.getValues(f,{transaction:l}).map(p=>{let S=E(f,p);if(c?S.endsWith(n):S.includes(n))return{key:S,value:p}}).filter(p=>p):(c?h.endsWith(n):h.includes(n))?_[sd.DBI_DEFINITION_NAME].is_hash_attribute?{key:f,value:f}:_.getValues(f,{transaction:l}).map(p=>({key:f,value:p})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a(XI,"contains");function UQ(e,t,r,n,s=!1,i=void 0,o=void 0){ui(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),tl(e,t,r,n,l,s,i,o,!0,!1)}a(UQ,"greaterThan");function vQ(e,t,r,n,s=!1,i=void 0,o=void 0){ui(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),tl(e,t,r,n,l,s,i,o,!1,!1)}a(vQ,"greaterThanEqual");function BQ(e,t,r,n,s=!1,i=void 0,o=void 0){ui(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),tl(e,t,r,l,n,s,i,o,!1,!0)}a(BQ,"lessThan");function HQ(e,t,r,n,s=!1,i=void 0,o=void 0){ui(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),tl(e,t,r,l,n,s,i,o,!1,!1)}a(HQ,"lessThanEqual");function xQ(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(Yr.validateEnv(e),r===void 0)throw new Error(Et.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(Et.START_VALUE_REQUIRED);if(s===void 0)throw new Error(Et.END_VALUE_REQUIRED);if(n=Yr.convertKeyValueToWrite(n),s=Yr.convertKeyValueToWrite(s),n>s)throw new Error(Et.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return tl(e,t,r,n,s,i,o,c)}a(xQ,"between");function GQ(e,t,r,n){Yr.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);if(od(r),r=rl(s,r),n===void 0)throw new Error(Et.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=id.parseRow(c,r)),o}a(GQ,"searchByHash");function FQ(e,t,r){Yr.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Et.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(FQ,"checkHashExists");function qQ(e,t,r,n,s=[]){return ZI(e,t,r,n,s),jI(e,t,r,n,s).map(i=>i[1])}a(qQ,"batchSearchByHash");function kQ(e,t,r,n,s=[]){ZI(e,t,r,n,s);let i=new Map;for(let[o,c]of jI(e,t,r,n,s))i.set(o,c);return i}a(kQ,"batchSearchByHashToMap");function jI(e,t,r,n,s=[]){return to(e,t,t,(i,o,c)=>{r=rl(c,r);let l=r.length<3;return n.map(_=>{let u=c.dbis[t].get(_,{transaction:i,lazy:l});if(u)return[_,id.parseRow(u,r)];s.push(_)}).filter(_=>_)})}a(jI,"batchHashSearch");function ZI(e,t,r,n,s){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);if(od(r),n==null)throw new Error(Et.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(Et.IDS_MUST_BE_ITERABLE)}a(ZI,"initializeBatchSearchByHash");function od(e){if(!Array.isArray(e))throw e===void 0?new Error(Et.FETCH_ATTRIBUTES_REQUIRED):new Error(Et.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(od,"validateFetchAttributes");function ui(e,t,r){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Et.SEARCH_VALUE_REQUIRED);if(r?.length>yQ)throw new Error(Et.SEARCH_VALUE_TOO_LARGE)}a(ui,"validateComparisonFunctions");function rl(e,t){return t.length===1&&OQ.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=li.listDBIs(e)),t}a(rl,"setGetWholeRowAttributes");ew.exports={searchAll:NQ,searchAllToMap:IQ,count:LQ,countAll:CQ,equals:DQ,startsWith:MQ,endsWith:PQ,contains:XI,searchByHash:GQ,setGetWholeRowAttributes:rl,batchSearchByHash:qQ,batchSearchByHashToMap:kQ,checkHashExists:FQ,iterateDBI:wQ,greaterThan:UQ,greaterThanEqual:vQ,lessThan:BQ,lessThanEqual:HQ,between:xQ}});var na=g((Jle,iw)=>{var tw=require("lodash"),rw=st(),he=require("joi"),VQ=J(),{hdb_schema_table:nl,checkValidTable:nw,hdb_table:sw,hdb_database:ad}=jn(),{handleHDBError:$Q,hdb_errors:YQ}=se(),{getDatabases:KQ}=(Ae(),ie(ke)),{HTTP_STATUS_CODES:WQ}=YQ,QQ=he.object({database:ad,schema:ad,table:sw,search_attribute:nl,search_value:he.any().required(),get_attributes:he.array().min(1).items(he.alternatives(nl,he.object())).optional(),desc:he.bool(),limit:he.number().integer().min(1),offset:he.number().integer().min(0)}),zQ=he.object({database:ad,schema:ad,table:sw,operator:he.string().valid("and","or").default("and").lowercase(),offset:he.number().integer().min(0),limit:he.number().integer().min(1),get_attributes:he.array().min(1).items(he.alternatives(nl,he.object())).optional(),sort:he.object({attribute:he.alternatives(nl,he.array().min(1)),descending:he.bool().optional()}).optional(),conditions:he.array().min(1).items(he.alternatives(he.object({operator:he.string().valid("and","or").default("and").lowercase(),conditions:he.array()}),he.object({search_attribute:he.alternatives(nl,he.array().min(1)),search_type:he.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:he.when("search_type",{switch:[{is:"equals",then:he.any()},{is:"between",then:he.array().items(he.alternatives([he.string(),he.number()])).length(2)}],otherwise:he.alternatives(he.string(),he.number())}).required()}))).required()});iw.exports=function(e,t){let r=null;switch(t){case"value":r=rw.validateBySchema(e,QQ);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(nw("database",e.schema)),i(nw("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=rw.validateBySchema(e,zQ);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=VQ.checkGlobalSchemaTable(e.schema,e.table);if(s)return $Q(new Error,s,WQ.NOT_FOUND);let o=KQ()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let l=a(u=>{for(let d=0,E=u.conditions.length;d<E;d++){let f=u.conditions[d];f.conditions?l(f):c.push(f.search_attribute)}},"addConditions");t==="conditions"&&l(e);let _=tw.filter(c,u=>u!=="*"&&!u.startsWith?.("$")&&u.attribute!=="*"&&!Array.isArray(u)&&!u.name&&!tw.some(o,d=>d===u||d.attribute===u||d.attribute===u.attribute));if(_&&_.length>0){let u=_.join(", ");return u=u.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${u}'`)}}return r}});var wp=g((jle,ow)=>{"use strict";var JQ=We(),XQ=na(),{getSchemaPath:jQ}=ze();ow.exports=ZQ;function ZQ(e){let t=XQ(e,"hashes");if(t)throw t;let r=jQ(e.schema,e.table);return JQ.openEnvironment(r,e.table)}a(ZQ,"initialize")});var Cp=g((eue,aw)=>{"use strict";var ez=ra(),tz=wp();aw.exports=rz;async function rz(e){let t=await tz(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return ez.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(rz,"lmdbGetDataByHash")});var sa=g((rue,cw)=>{"use strict";var Dp=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};cw.exports=Dp});var uw=g((iue,lw)=>{"use strict";var sue=sa(),nz=ra(),sz=wp();lw.exports=iz;async function iz(e){let t=await sz(e),r=global.hdb_schema[e.schema][e.table];return nz.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(iz,"lmdbSearchByHash")});var rs=g((aue,_w)=>{"use strict";var Lp=class{static{a(this,"SearchObject")}constructor(t,r,n,s,i,o,c,l=!1,_=void 0,u=void 0){this.schema=t,this.table=r,this.search_attribute=n,this.search_value=s,this.hash_attribute=i,this.get_attributes=o,this.end_value=c,this.reverse=l,this.limit=_,this.offset=u}};_w.exports=Lp});var cd=g((lue,pw)=>{"use strict";var rr=ra(),oz=We(),az=J(),me=dt(),ro=U(),cz=Yi(),dw=vr().LMDB_ERRORS_ENUM,{getSchemaPath:lz}=ze(),ys=ro.SEARCH_WILDCARDS;async function uz(e,t,r){let n;e.schema===ro.SYSTEM_SCHEMA_NAME?n=cz[e.table]:n=global.hdb_schema[e.schema][e.table];let s=mw(e,n.hash_attribute,r,t);return Ew(e,s,n.hash_attribute,r)}a(uz,"prepSearch");async function Ew(e,t,r,n){let s=lz(e.schema,e.table),i=await oz.openEnvironment(s,e.table),o=hw(i,e,t,r),c=o.transaction||i;if([me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,me.SEARCH_TYPES.SEARCH_ALL,me.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(_z(e,r)===!1){let u=e.search_attribute;if(u===r)return n?fw(o,()=>!0):o.map(E=>({[r]:E.key}));let d=a(E=>({[r]:E.value,[u]:E.key}),"toObject");return n?fw(o,d):o.map(d)}let _=e.search_attribute===r?o.map(u=>u.key):o.map(u=>u.value);return n===!0?rr.batchSearchByHashToMap(c,r,e.get_attributes,_):rr.batchSearchByHash(c,r,e.get_attributes,_)}a(Ew,"executeSearch");function hw(e,t,r,n){let s,i=n;t.get_attributes.indexOf(n)<0&&(i=void 0);let{reverse:o,limit:c,offset:l}=t;switch(o=typeof o=="boolean"?o:!1,c=Number.isInteger(c)?c:void 0,l=Number.isInteger(l)?l:void 0,r){case me.SEARCH_TYPES.EQUALS:s=rr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.CONTAINS:s=rr.contains(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.ENDS_WITH:case me.SEARCH_TYPES._ENDS_WITH:s=rr.endsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.STARTS_WITH:case me.SEARCH_TYPES._STARTS_WITH:s=rr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return rr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return rr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case me.SEARCH_TYPES.SEARCH_ALL:return rr.searchAll(e,n,t.get_attributes,o,c,l);case me.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return rr.searchAllToMap(e,n,t.get_attributes,o,c,l);case me.SEARCH_TYPES.BETWEEN:s=rr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,l);break;case me.SEARCH_TYPES.GREATER_THAN:case me.SEARCH_TYPES._GREATER_THAN:s=rr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.GREATER_THAN_EQUAL:case me.SEARCH_TYPES._GREATER_THAN_EQUAL:s=rr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.LESS_THAN:case me.SEARCH_TYPES._LESS_THAN:s=rr.lessThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.LESS_THAN_EQUAL:case me.SEARCH_TYPES._LESS_THAN_EQUAL:s=rr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;default:return Object.create(null)}return s}a(hw,"searchByType");function fw(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(fw,"createMapFromIterable");function _z(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(_z,"checkToFetchMore");function mw(e,t,r,n){if(az.isEmpty(n)){let s=e.search_value;typeof s=="object"?s=JSON.stringify(s):s=s.toString();let i=s.charAt(0),o=s.charAt(s.length-1),c=!1;if(e.search_attribute===t&&(c=!0),ys.indexOf(s)>-1)return r===!0?me.SEARCH_TYPES.SEARCH_ALL_TO_MAP:me.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(ys[0])<0&&s.indexOf(ys[1])<0)return c===!0?r===!0?me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:me.SEARCH_TYPES.EQUALS;if(ys.indexOf(i)>=0&&ys.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),me.SEARCH_TYPES.CONTAINS;if(ys.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),me.SEARCH_TYPES.ENDS_WITH;if(ys.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),me.SEARCH_TYPES.STARTS_WITH;if(s.includes(ys[0])||s.includes(ys[1]))return me.SEARCH_TYPES.EQUALS;throw new Error(dw.UNKNOWN_SEARCH_TYPE)}else switch(n){case ro.VALUE_SEARCH_COMPARATORS.BETWEEN:return me.SEARCH_TYPES.BETWEEN;case ro.VALUE_SEARCH_COMPARATORS.GREATER:return me.SEARCH_TYPES.GREATER_THAN;case ro.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return me.SEARCH_TYPES.GREATER_THAN_EQUAL;case ro.VALUE_SEARCH_COMPARATORS.LESS:return me.SEARCH_TYPES.LESS_THAN;case ro.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return me.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(dw.UNKNOWN_SEARCH_TYPE)}}a(mw,"createSearchTypeFromSearchObject");pw.exports={executeSearch:Ew,createSearchTypeFromSearchObject:mw,prepSearch:uz,searchByType:hw}});var Tw=g((due,Sw)=>{"use strict";var _ue=rs(),dz=na(),fz=J(),Ez=U(),hz=cd();Sw.exports=mz;function mz(e,t){if(!fz.isEmpty(t)&&Ez.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=dz(e,"value");if(n)throw n;return hz.prepSearch(e,t,!0)}a(mz,"lmdbGetDataByValue")});var sl=g((hue,gw)=>{"use strict";var Eue=rs(),pz=na(),Sz=J(),Tz=U(),gz=cd();gw.exports=Rz;async function Rz(e,t){if(!Sz.isEmpty(t)&&Tz.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=pz(e,"value");if(n)throw n;return gz.prepSearch(e,t,!1)}a(Rz,"lmdbSearchByValue")});var Aw=g((Sue,Rw)=>{"use strict";var pue=dt(),Mp=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}},Pp=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},Up=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};Rw.exports={SearchByConditionsObject:Mp,SearchCondition:Pp,SortAttribute:Up}});var Iw=g((Aue,Nw)=>{"use strict";var gue=Aw().SearchByConditionsObject,Az=rs(),Oz=na(),vp=ra(),ld=dt(),{Resource:Rue}=(an(),ie(Bp)),yw=cd(),bz=Ip(),yz=require("lodash"),{getSchemaPath:Nz}=ze(),Ow=We(),{handleHDBError:Iz,hdb_errors:wz}=se(),{HTTP_STATUS_CODES:Cz}=wz,Dz=1e8;Nw.exports=Lz;async function Lz(e){let t=Oz(e,"conditions");if(t)throw Iz(t,t.message,Cz.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=Nz(e.schema,e.table),n=await Ow.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let _ of e.conditions)Ow.openDBI(n,_.search_attribute);let i=yz.sortBy(e.conditions,_=>{if(_.estimated_count===void 0){let u=_.search_type;u===ld.SEARCH_TYPES.EQUALS?_.estimated_count=vp.count(n,_.search_attribute,_.search_value):u===ld.SEARCH_TYPES.CONTAINS||u===ld.SEARCH_TYPES.ENDS_WITH?_.estimated_count=1/0:_.estimated_count=Dz}return _.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await bw(o,e,i[0],s.hash_attribute),l;if(!e.operator||e.operator.toLowerCase()==="and"){let _=n.dbis[s.hash_attribute],u=i.slice(1).map(yw.filterByType),d=u.length,E=vp.setGetWholeRowAttributes(n,e.get_attributes);l=c.map(f=>_.get(f,{transaction:o,lazy:!0})),d>0&&(l=l.filter(f=>{for(let h=0;h<d;h++)if(!u[h](f))return!1;return!0})),(e.offset||e.limit!==void 0)&&(l=l.slice(e.offset,e.limit!==void 0?(e.offset||0)+e.limit:void 0)),l=l.map(f=>bz.parseRow(f,E))}else{for(let d=1;d<i.length;d++){let E=i[d],f=await bw(o,e,E,s.hash_attribute);c=c.concat(f)}let _=new Set,u=e.offset||0;c=c.filter(d=>_.has(d)?!1:(_.add(d),!0)).slice(u,e.limit&&e.limit+u),l=vp.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(Lz,"lmdbSearchByConditions");async function bw(e,t,r,n){let s=new Az(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===ld.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,yw.searchByType(e,s,i,n).map(o=>o.value)}a(bw,"executeConditionSearch")});var il=g((bue,ww)=>{"use strict";var Mz=U().OPERATIONS_ENUM,Hp=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=Mz.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};ww.exports=Hp});var xp=g((Nue,Bw)=>{"use strict";var Mw=rs(),Pw=il(),Uw=sl(),vw=el(),Sr=U(),Cw=J(),Dw=We(),{getTransactionAuditStorePath:Pz,getSchemaPath:Uz}=ze(),Lw=K();Bw.exports=vz;async function vz(e){try{if(Cw.isEmpty(global.hdb_schema[e.schema])||Cw.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await Bz(e),await Hz(e);let t=Uz(e.schema,e.table);try{await Dw.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")Lw.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=Pz(e.schema,e.table);await Dw.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")Lw.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(vz,"lmdbDropTable");async function Bz(e){let t=new Mw(Sr.SYSTEM_SCHEMA_NAME,Sr.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await Uw(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 Pw(Sr.SYSTEM_SCHEMA_NAME,Sr.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await vw(s)}a(Bz,"deleteAttributesFromSystem");async function Hz(e){let t=new Mw(Sr.SYSTEM_SCHEMA_NAME,Sr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await Uw(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 Pw(Sr.SYSTEM_SCHEMA_NAME,Sr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await vw(s)}catch(i){throw i}}a(Hz,"dropTableFromSystem")});var xw=g((wue,Hw)=>{"use strict";var xz=require("fs-extra"),Gz=rs(),Fz=sa(),qz=il(),kz=xp(),Vz=el(),$z=Cp(),Yz=sl(),Ns=U(),{getSchemaPath:Kz}=ze(),{handleHDBError:Wz,hdb_errors:Qz}=se(),{HDB_ERROR_MSGS:zz,HTTP_STATUS_CODES:Jz}=Qz;Hw.exports=Xz;async function Xz(e){let t;try{t=await jz(e.schema);let r=new Gz(Ns.SYSTEM_SCHEMA_NAME,Ns.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Ns.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[Ns.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await Yz(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await kz(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new qz(Ns.SYSTEM_SCHEMA_NAME,Ns.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await Vz(s);let i=Kz(t);await xz.remove(i)}catch(r){throw r}}a(Xz,"lmdbDropSchema");async function jz(e){let t=new Fz(Ns.SYSTEM_SCHEMA_NAME,Ns.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[Ns.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await $z(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw Wz(new Error,zz.SCHEMA_NOT_FOUND(e),Jz.NOT_FOUND,void 0,void 0,!0);return n}a(jz,"validateDropSchema")});var Fp=g((Due,Gw)=>{"use strict";var Gp=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};Gw.exports=Gp});var qw=g((Pue,Fw)=>{"use strict";var Zz=require("fs-extra"),ud=We(),{getTransactionAuditStorePath:e2}=ze(),qp=dt(),Mue=Fp();Fw.exports=t2;async function t2(e){let t;try{let r=e2(e.schema,e.table);await Zz.mkdirp(r),t=await ud.createEnvironment(r,e.table,!0)}catch(r){throw r.message=`unable to create transactions audit environment for ${e.schema}.${e.table} due to: ${r.message}`,r}try{ud.createDBI(t,qp.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),ud.createDBI(t,qp.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),ud.createDBI(t,qp.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(t2,"createTransactionsAuditEnvironment")});var Yw=g((vue,$w)=>{"use strict";var kp=U(),kw=We(),r2=Yo(),{getSystemSchemaPath:n2,getSchemaPath:s2}=ze(),i2=Yi(),o2=F_(),Vp=G_(),a2=K(),c2=qw(),Yp=i2.hdb_table,Vw=[];for(let e=0;e<Yp.attributes.length;e++)Vw.push(Yp.attributes[e].attribute);$w.exports=l2;async function l2(e,t){let r=s2(t.schema,t.table),n=new Vp(t.schema,t.table,kp.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new Vp(t.schema,t.table,kp.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new Vp(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await kw.createEnvironment(r,t.table),e!==void 0){let o=await kw.openEnvironment(n2(),kp.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await r2.insertRecords(o,Yp.hash_attribute,Vw,[e]),n.skip_table_check=!0,s.skip_table_check=!0,i.skip_table_check=!0,await $p(n),await $p(s),await $p(i)}await c2(t)}catch(o){throw o}}a(l2,"lmdbCreateTable");async function $p(e){try{await o2(e)}catch(t){a2.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a($p,"createAttribute")});var Ww=g((Hue,Kw)=>{"use strict";var u2=Kc(),_2=Dc(),d2=rd(),ol=U(),f2=Yo().updateRecords,E2=We(),{getSchemaPath:h2}=ze(),m2=jc(),p2=K();Kw.exports=S2;async function S2(e){try{let{schema_table:t,attributes:r}=u2(e);_2(e,r,t.hash_attribute),e.schema!==ol.SYSTEM_SCHEMA_NAME&&(r.includes(ol.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(ol.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(ol.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(ol.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await d2(e.hdb_auth_header,t,r),s=h2(e.schema,e.table),i=await E2.openEnvironment(s,e.table),o=await f2(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await m2(e,o)}catch(c){p2.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(S2,"lmdbUpdateRecords")});var zw=g((Gue,Qw)=>{"use strict";var T2=U().OPERATIONS_ENUM,Kp=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=T2.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};Qw.exports=Kp});var Xw=g((kue,Jw)=>{"use strict";var que=zw(),g2=Kc(),R2=Dc(),A2=rd(),al=U(),O2=Yo().upsertRecords,b2=We(),{getSchemaPath:y2}=ze(),N2=jc(),I2=K(),{handleHDBError:w2,hdb_errors:C2}=se();Jw.exports=D2;async function D2(e){let t;try{t=g2(e)}catch(l){throw w2(l,l.message,C2.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;R2(e,n,r.hash_attribute),e.schema!==al.SYSTEM_SCHEMA_NAME&&(n.includes(al.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(al.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(al.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(al.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await A2(e.hdb_auth_header,r,n),i=y2(e.schema,e.table),o=await b2.openEnvironment(i,e.table),c=await O2(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await N2(e,c)}catch(l){I2.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(D2,"lmdbUpsertRecords")});var Zw=g(($ue,jw)=>{"use strict";var Wp=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};jw.exports=Wp});var tC=g((Kue,eC)=>{"use strict";var Qp=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}};eC.exports=Qp});var sC=g((zue,nC)=>{"use strict";var zp=We(),{getTransactionAuditStorePath:L2}=ze(),Que=Zw(),cl=dt(),M2=J(),rC=tC(),P2=require("util").promisify,U2=P2(setTimeout),v2=1e4,B2=100;nC.exports=H2;async function H2(e){let t=L2(e.schema,e.table),r=await zp.openEnvironment(t,e.table,!0),n=zp.listDBIs(r);zp.initializeDBIs(r,cl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new rC;do s=await x2(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 U2(B2);while(s.transactions_deleted>0);return i}a(H2,"deleteAuditLogsBefore");async function x2(e,t){let r=new rC;try{let n=e.dbis[cl.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[cl.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];M2.isEmpty(c)||(s=e.dbis[cl.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[cl.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>v2)break}return await s,r}catch(n){throw n}}a(x2,"deleteTransactions")});var oC=g((Xue,iC)=>{"use strict";var Jp=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};iC.exports=Jp});var cC=g((e_e,aC)=>{"use strict";var G2=rs(),F2=il(),Zue=oC(),ns=U(),q2=J(),Xp=We(),k2=Yi(),V2=sl(),$2=el(),{getSchemaPath:Y2}=ze();aC.exports=K2;async function K2(e,t=!0){let r;e.schema===ns.SYSTEM_SCHEMA_NAME?r=k2[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await Q2(e),s=Y2(e.schema,e.table),i=await Xp.openEnvironment(s,e.table);return t===!0&&await W2(e,i,r.hash_attribute),Xp.dropDBI(i,e.attribute),n}a(K2,"lmdbDropAttribute");async function W2(e,t,r){let n=Xp.openDBI(t,r),s,i=e.attribute;for(let{key:o,value:c,version:l}of n.getRange({start:!1,versions:!0})){let _={};for(let u in c)u!==i&&(_[u]=c[u]);s=t.dbis[r].put(o,_,l)}await s}a(W2,"removeAttributeFromAllObjects");async function Q2(e){let t=new G2(ns.SYSTEM_SCHEMA_NAME,ns.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,ns.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[ns.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,ns.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await V2(t)).filter(o=>o[ns.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(q2.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[ns.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new F2(ns.SYSTEM_SCHEMA_NAME,ns.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return $2(i)}a(Q2,"dropAttributeFromSystem")});var EC=g((n_e,fC)=>{"use strict";var jp=We(),ia=dt(),r_e=xr(),Zp=U(),lC=J(),{getTransactionAuditStorePath:z2}=ze(),J2=ra(),_d=Zo(),X2=K();fC.exports=j2;async function j2(e){let t=z2(e.schema,e.table),r=await jp.openEnvironment(t,e.table,!0),n=jp.listDBIs(r);jp.initializeDBIs(r,ia.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case Zp.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return uC(r,e.search_values);case Zp.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,eJ(r,e.search_values,s);case Zp.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return Z2(r,e.search_values);default:return uC(r)}}a(j2,"readAuditLog");function uC(e,t=[0,Date.now()]){lC.isEmpty(t[0])&&(t[0]=0),lC.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[ia.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],n;for(let s of r.getKeys({start:t[1]}))if(s!==t[1]){n=s;break}return r.getRange({start:t[0],end:n}).map(({value:s})=>Object.assign(new _d,s))}a(uC,"searchTransactionsByTimestamp");function Z2(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[ia.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,dC(e,i))}return Object.fromEntries(r)}a(Z2,"searchTransactionsByUsername");function eJ(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let _=t[c],u=J2.equals(e,ia.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,ia.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,_);for(let{value:d}of u){let E=Number(d);n.has(E)?n.get(E).push(_.toString()):n.set(E,[_.toString()])}}let s=Array.from(n.keys()),i=dC(e,s),o=new Map;for(let c=0;c<i.length;c++){let l=i[c],_=l.timestamp,u=n.get(_);_C(l,"records",r,u,o),_C(l,"original_records",r,u,o)}return Object.fromEntries(o)}a(eJ,"searchTransactionsByHashValues");function _C(e,t,r,n,s){let i=e.timestamp;if(e[t])for(let o=0;o<e[t].length;o++){let c=e[t][o],l=c[r].toString();if(n.indexOf(l)>=0)if(s.has(l)){let _=s.get(l),u=_[_.length-1];if(u.timestamp===i)u[t]=[c];else{let d=new _d(e.operation,e.user_name,i,void 0);d[t]=[c],_.push(d)}}else{let _=new _d(e.operation,e.user_name,i,void 0);_[t]=[c],s.set(l,[_])}}}a(_C,"loopRecords");function dC(e,t){let r=[];try{let n=e.dbis[ia.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP];for(let s=0;s<t.length;s++)try{let i=n.get(t[s]);if(i){let o=Object.assign(new _d,i);r.push(o)}}catch(i){X2.warn(i)}return r}catch(n){throw n}}a(dC,"batchSearchTransactions")});var mC=g((a_e,hC)=>{"use strict";var{getSchemaPath:i_e}=ze(),o_e=We(),{database:tJ}=(Ae(),ie(ke));hC.exports={writeTransaction:rJ};async function rJ(e,t,r){return tJ({database:e,table:t}).transaction(r)}a(rJ,"writeTransaction")});var gC=g((l_e,TC)=>{"use strict";var{getSchemaPath:pC}=ze(),SC=We();TC.exports={flush:nJ,resetReadTxn:sJ};async function nJ(e,t){return(await SC.openEnvironment(pC(e,t),t.toString())).flushed}a(nJ,"flush");async function sJ(e,t){try{(await SC.openEnvironment(pC(e,t),t.toString())).resetReadTxn()}catch{}}a(sJ,"resetReadTxn")});var bC=g((__e,OC)=>{"use strict";var{Readable:iJ}=require("stream"),{getDatabases:oJ}=(Ae(),ie(ke)),{readSync:aJ,openSync:cJ,createReadStream:RC}=require("fs"),{open:lJ}=require("lmdb"),AC=Gc(),uJ=Fc(),{AUDIT_STORE_OPTIONS:_J}=(ti(),ie(yC)),{INTERNAL_DBIS_NAME:dJ,AUDIT_STORE_NAME:fJ}=dt();OC.exports=hJ;var eS=32768,EJ=100;async function hJ(e){let t=e.database||e.schema||"data",r=oJ()[t],n=new Date().toISOString(),s=e.tables||e.table&&[e.table];if(s){let _=r[s[0]];if(!_)throw new Error(`Can not find table ${s[0]}`);let u=_.dbisDB,d=lJ({noSync:!0,maxDbs:uJ.MAX_DBS}),E,f=d.openDB(dJ,new AC(!1)),h=u.useReadTransaction(),p=0,S=a(async function(A,N){N.encoding="binary",N.encoder=void 0;let b=d.openDB(A,N),v=u.openDB(A,N);for(let{key:P,version:q,value:M}of v.getRange({start:null,transaction:h,versions:v.useVersions}))E=b.put(P,M,q),p++%EJ===0&&(await new Promise(Q=>setTimeout(Q,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:A,value:N}of u.getRange({transaction:h,start:!1}))if(s.some(b=>A.startsWith?.(b+"/"))){f.put(A,N);let[,b]=A.split("/"),v=!b,P=new AC(!v,v);await S(A,P)}e.include_audit&&await S(fJ,Object.assign({},_J)),await E;let T=RC(d.path);return T.headers=l(),T.on("close",()=>{h.done(),d.close()}),T}let o=r[Object.keys(r)[0]].primaryStore,c=cJ(o.path);return o.transaction(()=>{let _=Buffer.alloc(eS);aJ(c,_,0,eS),o.resetReadTxn();let u=o.useReadTransaction();u.renew();let d=RC(null,{fd:c,start:eS}),E=new iJ.from(async function*(){yield _;for await(let f of d)u.openTimer&&(u.openTimer=0),yield f;u.done()}());return E.headers=l(),E});function l(){let _=new Map;return _.set("content-type","application/octet-stream"),_.set("content-disposition",`attachment; filename="${t}"`),_.set("date",n),_}}a(hJ,"getBackup")});var wC=g((f_e,IC)=>{"use strict";var mJ=K(),{handleHDBError:pJ}=se(),SJ=ay(),TJ=F_(),gJ=Ap(),RJ=xI(),AJ=el(),OJ=Cp(),bJ=uw(),yJ=Tw(),NJ=sl(),IJ=Iw(),wJ=xw(),CJ=Yw(),DJ=Ww(),LJ=Xw(),MJ=sC(),PJ=xp(),UJ=cC(),vJ=EC(),BJ=mC(),NC=gC(),HJ=bC(),tS=class extends SJ{static{a(this,"LMDBBridge")}async searchByConditions(t){return IJ(t)}async getDataByHash(t){return await OJ(t)}async searchByHash(t){return await bJ(t)}async getDataByValue(t,r){return await yJ(t,r)}async searchByValue(t){return await NJ(t)}async createSchema(t){return await RJ(t)}async dropSchema(t){return await wJ(t)}async createTable(t,r){return await CJ(t,r)}async dropTable(t){return await PJ(t)}async createAttribute(t){return await TJ(t)}async createRecords(t){return await gJ(t)}async updateRecords(t){return await DJ(t)}async upsertRecords(t){try{return await LJ(t)}catch(r){throw pJ(r,null,null,mJ.ERR,r)}}async deleteRecords(t){return await AJ(t)}async dropAttribute(t){return await UJ(t)}async deleteAuditLogsBefore(t){return await MJ(t)}async readAuditLog(t){return await vJ(t)}writeTransaction(t,r,n){return BJ.writeTransaction(t,r,n)}flush(t,r){return NC.flush(t,r)}resetReadTxn(t,r){return NC.resetReadTxn(t,r)}getBackup(t){return HJ(t)}};IC.exports=tS});function qJ(){FJ=setInterval(function(){for(let e of rS)if(e.stale){let t=e[ye]?.url;MC.error(`Transaction was open too long and has been aborted, from table: ${e.lmdbDb?.name+(t?" path: "+t:"")}`),e.abort()}else e.stale=!0},GJ).unref()}var nS,LC,MC,PC,UC,vC,CC,rS,xJ,ll,DC,no,dd,GJ,FJ,sS=Re(()=>{nS=x(xr()),LC=x(se()),MC=x(K());an();PC=x(ne()),UC=x(U()),vC=x(J()),CC=100,rS=new Set,xJ=(0,vC.convertToMS)(PC.get(UC.CONFIG_PARAMS.STORAGE_MAXTRANSACTIONQUEUETIME))||45e3,no=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),rS.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(rS.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(ll&&!this.overloadChecked&&performance.now()-DC>xJ)throw new LC.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,nS.getNextMonotonicTime)()),t.timestamp||(t.timestamp=r);let n=t.retries||0;if(this.validated<this.writes.length)try{let d=this.validated;this.validated=this.writes.length;for(let f=d;f<this.validated;f++)this.writes[f]?.validate?.(this.timestamp);let E;for(let f=d;f<this.validated;f++){let h=this.writes[f];h&&(h.before||h.beforeIntermediate)&&(E=!0)}if(E)return(async()=>{try{for(let f=0;f<2;f++){let h;for(let p=d;p<this.validated;p++){let S=this.writes[p];if(!S)continue;let T=S[f===0?"before":"beforeIntermediate"];if(T){let A=T();h?h.push?h.push(A):h=[h,A]:h=A}}h&&await(h.push?Promise.all(h):h)}}catch(f){throw this.abort(),f}return this.commit(t)})()}catch(d){throw this.abort(),d}n||this.doneReadTxn(),this.open=t?.letItLinger?2:0;let s,i=[],o=0;this.writes=this.writes.filter(d=>d);let c=a(d=>{d.commit(r,d.entry,n)},"doWrite"),l=a(()=>{let d=this.writes[o++];if(d)if(d.key){n>0&&(d.entry=d.store.getEntry(d.key));let E=d.store.ifVersion(d.key,d.entry?.version??null,l);s=s||E}else l();else for(let E of this.writes)c(E)},"nextCondition"),_=this.lmdbDb;if(this.writes.length>0&&(_?.retryRisk&&(_.retryRisk*=.99),this.writes.length+(_?.retryRisk||0)<CC>>n?l():s=this.writes[0].store.transaction(()=>{for(let d of this.writes)d.entry=d.store.getEntry(d.key),c(d);return!0})),s)return ll||(ll=s,DC=performance.now(),ll.then(()=>{ll=null})),s.then(d=>d?(this.next&&i.push(this.next.commit(t)),t?.flush&&i.push(this.writes[0].store.flushed),this.writes=[],this.next=null,Promise.all(i).then(()=>({txnTime:r}))):(_&&(_.retryRisk=(_.retryRisk||0)+CC/2),t?t.retries=n+1:t={retries:1},this.commit(t)));let u={txnTime:r};if(this.next){let d=this.next?.commit(t);if(d?.then)return d?.then(E=>({txnTime:r,next:E}));u.next=d}return u}abort(){for(;this.readTxnsUsed>0;)this.doneReadTxn();this.open=0,this.writes=[]}},dd=class extends no{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,nS.getNextMonotonicTime)())}getReadTxn(){}},GJ=3e4;a(qJ,"startMonitoringTxns");qJ()});function Ze(e,t,r){if(!t)t=e,e={};else if(!e)e={};else if(e?.transaction?.open===1&&typeof t=="function")return t(e.transaction);if(typeof t!="function")throw new Error("Callback function must be provided to transaction");let n=e.transaction=new no;e.timestamp&&(n.timestamp=e.timestamp),n[ye]=e,e.resourceCache||(e.resourceCache=[]);let s;try{if(s=t(n),s?.then)return s.then(i,o)}catch(c){o(c)}return i(s);function i(c){let l=n.commit({letItLinger:r?.letItLinger});return l.then?l.then(()=>c):c}function o(c){throw n.abort({}),c}}var BC,so=Re(()=>{BC=require("../../index");an();sS();a(Ze,"transaction");(0,BC._assignPackageExport)("transaction",Ze);Ze.commit=function(e){let t=(e[ye]||e)?.transaction;if(!t)throw new Error("No active transaction is available to commit");return t.commit()};Ze.abort=function(e){let t=(e[ye]||e)?.transaction;if(!t)throw new Error("No active transaction is available to abort");return t.abort()}});var $C={};qe($C,{ResourceBridge:()=>aS});function cS({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 xC(e,t){let r=ss(e),n=cS(e,r);if(!r)throw new Pn.ClientError(`Table ${e.table} not found`);let s;n&&r.attributes.length-n.length>2&&n.length<5&&(s=!0);let i={user:e.hdb_user,onlyIfCached:e.onlyIfCached,noCacheStore:e.noCacheStore,noCache:e.noCache},o;Ze(i,()=>new Promise(_=>o=_));let c=e.ids||e.hash_values,l=0;return{[Symbol.asyncIterator](){return{async next(){if(l<c.length){let _=c[l++],u;try{u=await r.get({id:_,lazy:s,select:n},i),u=u&&Ed(u)}catch(d){u={message:d.toString()}}return t?{value:{key:_,value:u}}:{value:u}}else return o(),{done:!0}},return(_){return o(),{value:_,done:!0}},throw(_){return o(),{done:!0}}}}}}function ss(e){let t=e.database||e.schema||VJ,r=Tr()[t];if(!r)throw(0,Pn.handleHDBError)(new Error,kJ.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function GC(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*FC(e,t,r){let n;for await(let s of e.getHistory(t,r)){let i=s.type;i==="put"&&(i="upsert");let{id:o,version:c,value:l}=s;n?.timestamp===c?(n.hash_values.push(o),n.records.push(l)):(n&&(yield n),n={operation:i,user_name:s.user,timestamp:c,hash_values:[o],records:[l]})}n&&(yield n)}var qC,fd,Pn,kC,Un,iS,oS,VC,kJ,VJ,$J,YJ,HC,aS,YC=Re(()=>{"use strict";qC=x(wC()),fd=x(na()),Pn=x(se());Ae();kC=x(Kc()),Un=x(U()),iS=x(bs()),oS=x(Mn()),VC=x(J());so();hd();({HDB_ERROR_MSGS:kJ}=Pn.hdb_errors),VJ="data",$J=1e4,YJ=10,aS=class extends qC.default{static{a(this,"ResourceBridge")}constructor(t){super(t),HC=this}async searchByConditions(t){t.select!==void 0&&(t.get_attributes=t.select);for(let o of t.conditions||[])o?.attribute!==void 0&&(o.search_attribute=o.attribute),o?.comparator!==void 0&&(o.search_type=o.comparator),o?.value!==void 0&&(o.search_value=o.value);let r=(0,fd.default)(t,"conditions");if(r)throw(0,Pn.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=ss(t);if(!n)throw new Pn.ClientError(`Table ${t.table} not found`);let s=t.conditions.map(i);function i(o){return o.conditions?(o.conditions=o.conditions.map(i),o):{attribute:o.search_attribute??o.attribute,comparator:o.search_type??o.comparator,value:o.search_value!==void 0?o.search_value:o.value}}return a(i,"mapCondition"),n.search({conditions:s,operator:t.operator?t.operator.toLowerCase():void 0,limit:t.limit,offset:t.offset,reverse:t.reverse,select:cS(t,n),sort:t.sort,allowFullScan:!0},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache})}async createTable(t,r){let n=r.attributes,s=!!n,i=r.primary_key||r.hash_attribute;if(n)for(let o of n)o.is_primary_key?(o.isPrimaryKey=!0,delete o.is_primary_key):o.name===i&&i&&(o.isPrimaryKey=!0);else{if(!i)throw new Pn.ClientError("A primary key must be specified with a `primary_key` property or with `attributes`");n=[{name:i,isPrimaryKey:!0},{name:"__createdtime__",indexed:!0},{name:"__updatedtime__",indexed:!0}]}ft({database:r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration})}async createAttribute(t){return await ss(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=ss(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=a((o,c,l)=>(c=Object.assign({},c),delete c[n],r.primaryStore.ifVersion(o,l,()=>r.primaryStore.put(o,c,l)).then(_=>{if(!_){let{value:u,version:d}=r.primaryStore.getEntry(o);return i(o,u,d)}})),"deleteRecord");for(let{key:o,value:c,version:l}of r.primaryStore.getRange({start:!0,versions:!0}))s=i(o,c,l),await new Promise(_=>setImmediate(_));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){ss(t).dropTable()}createSchema(t){return oa({database:t.schema,table:null}),iS.signalSchemaChange(new oS.SchemaEventMsg(process.pid,Un.OPERATIONS_ENUM.CREATE_SCHEMA,t.schema))}async dropSchema(t){await lS(t.schema),iS.signalSchemaChange(new oS.SchemaEventMsg(process.pid,Un.OPERATIONS_ENUM.DROP_SCHEMA,t.schema))}async updateRecords(t){return t.requires_existing=!0,this.upsertRecords(t)}async createRecords(t){return t.requires_no_existing=!0,HC.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,kC.default)(t),s,i=Tr()[t.schema][t.table],o={user:t.hdb_user,expiresAt:t.expiresAt};return Ze(o,async c=>{if(!i.schemaDefined){s=[];for(let u of n)i.attributes.find(E=>E.name==u)||s.push(u);s.length>0&&await i.addAttributes(s.map(u=>({name:u,indexed:!0})))}let l=[],_=[];for(let u of t.records){let d=u[i.primaryKey],E=d!=null&&await i.get(d,o);if(t.requires_existing&&!E||t.requires_no_existing&&E){_.push(u[i.primaryKey]);continue}E&&(E=Ed(E));for(let f in u)if(Object.prototype.hasOwnProperty.call(u,f)){let h=u[f];if(typeof h=="function")try{let p=h([[E]]);Array.isArray(p)&&(h=p[0].func_val,u[f]=h)}catch(p){throw p.message+="Trying to set key "+f+" on object"+JSON.stringify(u),p}}if(E)for(let f in E)Object.prototype.hasOwnProperty.call(u,f)||(u[f]=E[f]);await(d==null?i.create(u,o):i.put(u,o)),l.push(u[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:l,new_attributes:s,skipped_hashes:_}})}async deleteRecords(t){let r=Tr()[t.schema][t.table],n={user:t.hdb_user};return Ze(n,async s=>{let i=t.hash_values||t.records.map(l=>l[r.primaryKey]),o=[],c=[];for(let l of i)await r.delete(l,n)?o.push(l):c.push(l);return GC(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=Tr()[t.schema][t.table];if(!r.createdTimeProperty)throw new Pn.ClientError("Table must have a '__createdtime__' attribute or @createdTime timestamp defined to perform this operation");let n=await r.search({conditions:[{attribute:r.createdTimeProperty.name,value:Date.parse(t.date),comparator:Un.VALUE_SEARCH_COMPARATORS.LESS}]}),s=!1,i=[],o=[],c=0,l=[],_=a(async()=>{let u=await this.deleteRecords({schema:t.schema,table:t.table,hash_values:l});i.push(...u.deleted_hashes),o.push(...u.skipped_hashes),await(0,VC.async_set_timeout)(YJ),l=[],s=!0},"chunkDelete");for await(let u of n)l.push(u[r.primaryKey]),c++,c%$J===0&&await _();return l.length>0&&await _(),s?GC(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,fd.default)(t,"hashes");if(r)throw r;return xC(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of xC(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&Un.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r]===void 0)throw new Error(`Value search comparator - ${r} - is not valid`);t.select!==void 0&&(t.get_attributes=t.select),t.attribute!==void 0&&(t.search_attribute=condition.attribute),t.value!==void 0&&(t.search_value=condition.value);let n=(0,fd.default)(t,"value");if(n)throw n;let s=ss(t);if(!s)throw new Pn.ClientError(`Table ${t.table} not found`);let i=t.search_value;i.includes?.("*")&&(i.startsWith("*")?i.endsWith("*")?i!=="*"&&(r="contains",i=i.slice(1,-1)):(r="ends_with",i=i.slice(1)):i.endsWith("*")&&(r="starts_with",i=i.slice(0,-1))),r===Un.VALUE_SEARCH_COMPARATORS.BETWEEN&&(i=[i,t.end_value]);let o=i==="*"?[]:[{attribute:t.search_attribute,value:i,comparator:r}];return s.search({conditions:o,allowFullScan:!0,limit:t.limit,offset:t.offset,reverse:t.reverse,sort:t.sort,select:cS(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache})}async getDataByValue(t,r){let n=new Map,s=ss(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){ss({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return ss(t).deleteHistory(t.timestamp,t.cleanup_deleted_records)}async readAuditLog(t){let r=ss(t),n={};switch(t.search_type){case Un.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:for(let i of t.search_values)n[i]=(await r.getHistoryOfRecord(i)).map(o=>{let c=o.type;return c==="put"&&(c="upsert"),{operation:c,timestamp:o.version,user_name:o.user,hash_values:[i],records:[o.value]}});return n;case Un.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:let s=t.search_values;for await(let i of FC(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return FC(r,t.search_values?.[0],t.search_values?.[1])}}};a(cS,"getSelect");a(xC,"getRecords");a(ss,"getTable");a(GC,"createDeleteResponse");a(FC,"groupRecordsInHistory")});var Ln=g((w_e,KC)=>{"use strict";var{ResourceBridge:KJ}=(YC(),ie($C)),WJ=ne();WJ.initSync();var md;function QJ(){return md||(md=new KJ,md)}a(QJ,"getBridge");KC.exports=QJ()});var JC=g((D_e,zC)=>{"use strict";var WC=require("lodash"),ul=require("mathjs"),zJ=require("jsonata"),QC=J();zC.exports={distinct_array:e=>Array.isArray(e)&&e.length>1?WC.uniqWith(e,WC.isEqual):e,searchJSON:JJ,mad:_l.bind(null,ul.mad),mean:_l.bind(null,ul.mean),mode:_l.bind(null,ul.mode),prod:_l.bind(null,ul.prod),median:_l.bind(null,ul.median)};function _l(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(_l,"aggregateFunction");function JJ(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(QC.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),QC.isEmpty(this.__ala__.res[r])){let n=zJ(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(JJ,"searchJSON")});var jC=g((M_e,XC)=>{"use strict";var gt=require("moment"),uS="YYYY-MM-DDTHH:mm:ss.SSSZZ";gt.suppressDeprecationWarnings=!0;XC.exports={current_date:()=>gt().utc().format("YYYY-MM-DD"),current_time:()=>gt().utc().format("HH:mm:ss.SSS"),extract:(e,t)=>{switch(t.toLowerCase()){case"year":return gt(e).utc().format("YYYY");case"month":return gt(e).utc().format("MM");case"day":return gt(e).utc().format("DD");case"hour":return gt(e).utc().format("HH");case"minute":return gt(e).utc().format("mm");case"second":return gt(e).utc().format("ss");case"millisecond":return gt(e).utc().format("SSS");default:break}},date:e=>gt(e).utc().format(uS),date_format:(e,t)=>gt(e).utc().format(t),date_add:(e,t,r)=>gt(e).utc().add(t,r).valueOf(),date_sub:(e,t,r)=>gt(e).utc().subtract(t,r).valueOf(),date_diff:(e,t,r)=>{let n=gt(e).utc(),s=gt(t).utc();return r?n.diff(s,r,!0):n.diff(s)},now:()=>gt().utc().valueOf(),get_server_time:()=>gt().format(uS),offset_utc:(e,t)=>gt(e).utc().utcOffset(t).format(uS)}});var rD=g((P_e,tD)=>{"use strict";var XJ=require("@turf/area"),jJ=require("@turf/length"),ZJ=require("@turf/circle"),e4=require("@turf/difference"),t4=require("@turf/distance"),r4=require("@turf/boolean-contains"),n4=require("@turf/boolean-equal"),s4=require("@turf/boolean-disjoint"),i4=require("@turf/helpers"),ZC=U(),Te=J(),Is=K();tD.exports={geoArea:o4,geoLength:a4,geoCircle:c4,geoDifference:l4,geoDistance:eD,geoNear:u4,geoContains:_4,geoEqual:d4,geoCrosses:f4,geoConvert:E4};function o4(e){if(Te.isEmpty(e))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e));try{return XJ.default(e)}catch(t){return Is.trace(t,e),NaN}}a(o4,"geoArea");function a4(e,t){if(Te.isEmpty(e))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e));try{return jJ.default(e,{units:t||"kilometers"})}catch(r){return Is.trace(r,e),NaN}}a(a4,"geoLength");function c4(e,t,r){if(Te.isEmpty(e))return NaN;if(Te.isEmpty(t))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e));try{return ZJ.default(e,t,{units:r||"kilometers"})}catch(n){return Is.trace(n,e,t),NaN}}a(c4,"geoCircle");function l4(e,t){if(Te.isEmpty(e))return NaN;if(Te.isEmpty(t))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return e4(e,t)}catch(r){return Is.trace(r,e,t),NaN}}a(l4,"geoDifference");function eD(e,t,r){if(Te.isEmpty(e))return NaN;if(Te.isEmpty(t))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return t4.default(e,t,{units:r||"kilometers"})}catch(n){return Is.trace(n,e,t),NaN}}a(eD,"geoDistance");function u4(e,t,r,n){if(Te.isEmpty(e)||Te.isEmpty(t))return!1;if(Te.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t)),isNaN(r))throw new Error("distance must be a number");try{return eD(e,t,n)<=r}catch(s){return Is.trace(s,e,t),!1}}a(u4,"geoNear");function _4(e,t){if(Te.isEmpty(e)||Te.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return r4.default(e,t)}catch(r){return Is.trace(r,e,t),!1}}a(_4,"geoContains");function d4(e,t){if(Te.isEmpty(e)||Te.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return n4.default(e,t)}catch(r){return Is.trace(r,e,t),!1}}a(d4,"geoEqual");function f4(e,t){if(Te.isEmpty(e)||Te.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return!s4.default(e,t)}catch(r){return Is.trace(r,e,t),!1}}a(f4,"geoCrosses");function E4(e,t,r){if(Te.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if(Te.isEmpty(t))throw new Error("geo_type is required");if(Te.isEmpty(ZC.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(ZC.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Te.autoCastJSON(e)),i4[t](e,r)}a(E4,"geoConvert")});var pd=g((v_e,nD)=>{var io=JC(),Kr=jC(),is=rD();nD.exports=e=>{e.aggr.mad=e.aggr.MAD=io.mad,e.aggr.mean=e.aggr.MEAN=io.mean,e.aggr.mode=e.aggr.MODE=io.mode,e.aggr.prod=e.aggr.PROD=io.prod,e.aggr.median=e.aggr.MEDIAN=io.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=io.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=io.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=Kr.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Kr.current_time,e.fn.extract=e.fn.EXTRACT=Kr.extract,e.fn.date=e.fn.DATE=Kr.date,e.fn.date_format=e.fn.DATE_FORMAT=Kr.date_format,e.fn.date_add=e.fn.DATE_ADD=Kr.date_add,e.fn.date_sub=e.fn.DATE_SUB=Kr.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Kr.date_diff,e.fn.now=e.fn.NOW=Kr.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Kr.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Kr.get_server_time,e.fn.getdate=e.fn.GETDATE=Kr.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Kr.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=is.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=is.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=is.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=is.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=is.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=is.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=is.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=is.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=is.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=is.geoNear}});var aD=g((B_e,oD)=>{"use strict";var dl=require("lodash"),gr=require("alasql");gr.options.cache=!1;var h4=pd(),sD=require("clone"),Sd=require("recursive-iterator"),fe=K(),Le=J(),aa=Ln(),m4=U(),{hdb_errors:p4}=se(),{getDatabases:iD}=(Ae(),ie(ke)),S4="IS NULL",vn="There was a problem performing this search. Please check the logs and try again.";h4(gr);var _S=class{static{a(this,"SQLSearch")}constructor(t,r){if(Le.isEmpty(t))throw fe.error("AST statement for SQL select process cannot be empty"),"statement cannot be null";this.statement=t,this.columns={},this.all_table_attributes=r,this.fetch_attributes=[],this.exact_search_values={},this.comparator_search_values={},this.tables=[],this.data={},this.has_aggregator=!1,this.has_ordinal=!1,this.has_outer_join=!1,this._getColumns(),this._getTables(),this._conditionsToFetchAttributeValues(),this._setAliasesForColumns(),Le.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!Le.isEmptyOrZeroLength(n))return fe.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw fe.error("Error thrown from checkEmptySQL in SQLSearch class method search."),fe.error(n),new Error(vn)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw fe.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),fe.error(n),new Error(vn)}if(Object.keys(this.data).length===0)return fe.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw fe.error("Error thrown from processJoins in SQLSearch class method search."),fe.error(n),new Error(vn)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw fe.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),fe.error(n),new Error(vn)}try{return t=await this._finalSQL(),t}catch(n){throw fe.error("Error thrown from finalSQL in SQLSearch class method search."),fe.error(n),new Error(vn)}}_getColumns(){let t=new Sd(this.statement);for(let{node:r,path:n}of t)r&&r.columnid&&(this.columns[n[0]]||(this.columns[n[0]]=[]),this.columns[n[0]].push(sD(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=dl.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=iD()[r.databaseid][r.tableid].primaryKey,this.data[n].__merged_data={},this.data[n].__merged_attributes=[],this.data[n].__merged_attr_map={}})}_conditionsToFetchAttributeValues(){if(Le.isEmpty(this.statement.where)){fe.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new Sd(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!Le.isEmpty(r)&&r.right)if(Le.isNotEmptyAndHasValue(r.right.value)){let n=Le.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new gr.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=Le.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new gr.yy.LogicValue({value:i}):n instanceof gr.yy.StringValue&&Le.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new gr.yy.NumValue({value:i}))});if(t){fe.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new Sd(this.statement.where))if(r&&r.left&&r.right&&(r.left.columnid||r.right.value)&&r.op){let n=new Set,s=r.left.columnid?r.left:r.right,i=this._findColumn(s);if(!i)continue;let o=[i.table.databaseid,i.table.tableid,i.attribute].join("/");if(!Le.isEmpty(m4.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(Le.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(Le.isEmptyOrZeroLength(r.left.columnid)||Le.isEmptyOrZeroLength(r.right.value)){this.comparator_search_values[o].ignore=!0,this.comparator_search_values[o].comparators=[];continue}this.comparator_search_values[o].comparators.push({attribute:r.left.columnid,operation:r.op,search_value:r.right.value})}continue}if(Le.isEmpty(this.exact_search_values[o])&&(this.exact_search_values[o]={ignore:!1,values:new Set}),!this.exact_search_values[o].ignore){let c=!1;switch(r.op){case"=":!Le.isEmpty(r.right.value)||!Le.isEmpty(r.left.value)?n.add(Le.isEmpty(r.right.value)?r.left.value:r.right.value):c=!0;break;case"IN":let l=Array.isArray(r.right)?r.right:r.left;for(let _=0;_<l.length;_++)if(l[_].value)n.add(l[_].value);else{c=!0;break}break;default:c=!0;break}this.exact_search_values[o].ignore=c,c?this.exact_search_values[o].values=new Set:this.exact_search_values[o].values=new Set([...this.exact_search_values[o].values,...n])}}}_setAliasesForColumns(){if(Le.isEmptyOrZeroLength(this.all_table_attributes)&&Le.isEmptyOrZeroLength(this.statement.from)&&Le.isEmptyOrZeroLength(this.columns.columns))return;let t=[],r={};this.statement.columns.forEach((n,s)=>{if(n.columnid==="*"){t.push(s);return}if(n.aggregatorid&&(this.has_aggregator=!0),!n.aggregatorid&&!n.funcid)if(n.as_orig=n.as?n.as:n.columnid,this.statement.joins)if(r[n.as_orig]>=0){let i=r[n.as_orig]+1;n.as=`[${n.as_orig+i}]`,r[n.as_orig]=i}else n.as=`[${n.as_orig}]`,r[n.as_orig]=0;else n.as=`[${n.as_orig}]`;!n.aggregatorid&&n.funcid&&n.args&&(n.as_orig=n.as?n.as:n.toString().replace(/'/g,'"'),n.as=`[${n.as_orig}]`),n.aggregatorid&&n.expression.columnid!=="*"&&(n.as_orig=n.as?n.as:n.expression.tableid?`${n.aggregatorid}(${n.expression.tableid}.${n.expression.columnid})`:`${n.aggregatorid}(${n.expression.columnid})`,n.as=`[${n.as_orig}]`)}),this.statement.columns.length>1&&t.length>0&&dl.pullAt(this.statement.columns,t)}_findColumn(t){let r=this.all_table_attributes.filter(n=>{if(t.columnid_orig&&t.tableid_orig)return(n.table.as===t.tableid_orig||n.table.tableid===t.tableid_orig)&&n.attribute===t.columnid_orig;if(t.tableid)return(n.table.as===t.tableid||n.table.tableid===t.tableid)&&n.attribute===t.columnid;let s=t.columnid_orig?t.columnid_orig:t.columnid;return n.attribute===s});if(Le.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);Le.isEmptyOrZeroLength(n)||(r=this.all_table_attributes.filter(s=>s.attribute===n[0].columnid&&n[0].tableid&&n[0].tableid===(s.table.as?s.table.as:s.table.tableid)))}return r[0]}async _checkEmptySQL(){let t=[];if(Le.isEmptyOrZeroLength(this.all_table_attributes)&&!Le.isEmptyOrZeroLength(this.columns.columns))return t;if(Le.isEmptyOrZeroLength(this.all_table_attributes)&&Le.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await gr.promise(r)}catch(r){throw fe.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),fe.error(r),new Error("There was a problem with the SQL statement")}return t}_addFetchColumns(t){t&&t.length>0&&t.forEach(r=>{let n=this._findColumn(r);n&&this.fetch_attributes.push(sD(n))})}_addColumnToMergedAttributes(t,r){this.data[t].__merged_attributes.push(r),this.data[t].__merged_attr_map[r]=this.data[t].__merged_attributes.length-1}_setMergedHashAttribute(t,r){this.data[t].__merged_data[r].splice(0,1,r)}_updateMergedAttribute(t,r,n,s){let i=this.data[t].__merged_attr_map[n];this.data[t].__merged_data[r].splice(i,1,s)}async _getFetchAttributeValues(){if(Le.isEmptyOrZeroLength(Object.keys(this.columns)))return[];this._addFetchColumns(this.columns.joins);let t=null;try{t=this.statement.where?this.statement.where.toString():""}catch{throw new Error("Could not generate proper where clause")}this.columns.where&&this._addFetchColumns(this.columns.where);let r=this._isSimpleSelect();if(r?this._addFetchColumns(this.columns.columns):(!this.columns.where&&this.fetch_attributes.length===0)|t.indexOf(S4)>-1&&this.tables.forEach(s=>{let i={columnid:iD()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=dl.uniqBy(this.fetch_attributes,s=>[s.table.databaseid,s.table.as?s.table.as:s.table.tableid,s.attribute].join()),r)return await this._simpleSQLQuery();let n=this.fetch_attributes.reduce((s,i)=>{let o=`${i.table.databaseid}_${i.table.as?i.table.as:i.table.tableid}`,c=this.data[o].__hash_name;return s[o]||(s[o]=[],s[o].push(null),this._addColumnToMergedAttributes(o,c)),i.attribute!==c&&(s[o].push(null),this._addColumnToMergedAttributes(o,i.attribute)),s},{});for(let s of this.fetch_attributes){let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`,o=this.data[i].__hash_name,c={schema:s.table.databaseid,table:s.table.tableid,get_attributes:[s.attribute]},l=!1,_=[s.table.databaseid,s.table.tableid,s.attribute].join("/");if(s.attribute===o&&(l=!0),!Le.isEmpty(this.exact_search_values[_])&&!this.exact_search_values[_].ignore&&!Le.isEmptyOrZeroLength(this.exact_search_values[_].values))if(l)try{c.hash_values=Array.from(this.exact_search_values[_].values);let u=await aa.getDataByHash(c);for(let d of c.hash_values)u.get(d)&&!this.data[i].__merged_data[d]&&(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d))}catch(u){throw fe.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),fe.error(u),new Error(vn)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[_].values).map(async u=>{let d=Object.assign({},c);d.search_value=u;let E=await aa.getDataByValue(d);for(let[f,h]of E)this.data[i].__merged_data[f]?this._updateMergedAttribute(i,f,s.attribute,h[s.attribute]):(this.data[i].__merged_data[f]=[...n[i]],this._updateMergedAttribute(i,f,s.attribute,h[s.attribute]),this._setMergedHashAttribute(i,f))}))}catch(u){throw fe.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),fe.error(u),new Error(vn)}else if(!Le.isEmpty(this.comparator_search_values[_])&&!this.comparator_search_values[_].ignore&&!Le.isEmptyOrZeroLength(this.comparator_search_values[_].comparators))try{let u=this.comparator_search_values[_].comparators;for(let d=0,E=u.length;d<E;d++){let f=u[d];c.search_attribute=f.attribute,c.search_value=f.search_value;let h=await aa.getDataByValue(c,f.operation);if(l)for(let[p]of h)this.data[i].__merged_data[p]||(this.data[i].__merged_data[p]=[...n[i]],this._setMergedHashAttribute(i,p));else for(let[p,S]of h)this.data[i].__merged_data[p]?this._updateMergedAttribute(i,p,s.attribute,S[s.attribute]):(this.data[i].__merged_data[p]=[...n[i]],this._updateMergedAttribute(i,p,s.attribute,S[s.attribute]),this._setMergedHashAttribute(i,p))}}catch(u){throw fe.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),fe.error(u),new Error(vn)}else try{c.search_attribute=s.attribute,c.search_value="*";let u=await aa.getDataByValue(c);if(l)for(let[d]of u)this.data[i].__merged_data[d]||(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d));else for(let[d,E]of u)this.data[i].__merged_data[d]?this._updateMergedAttribute(i,d,s.attribute,E[s.attribute]):(this.data[i].__merged_data[d]=[...n[i]],this._updateMergedAttribute(i,d,s.attribute,E[s.attribute]),this._setMergedHashAttribute(i,d))}catch(u){throw fe.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),fe.error(u),new Error(vn)}}}_isSimpleSelect(){let t=!0;return Object.keys(this.statement).length!==2||!this.statement.columns||!this.statement.from||this.statement.from.length!==1?(t=!1,t):(this.statement.columns.forEach(r=>{r instanceof gr.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 gr.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new gr.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 gr.yy.FuncValue:new gr.yy.Column;t.initial_select_column=Object.assign(s,n)}})}_addNonAggregatorsToFetchColumns(){let r=this.statement.order.filter(n=>!n.is_aggregator&&!n.is_ordinal).map(n=>n.is_func?{columnid:n.initial_select_column.args.filter(i=>!!i.columnid_orig)[0].columnid_orig}:{columnid:n.expression.columnid_orig});this._addFetchColumns(r)}async _processJoins(){let t=[],r=[],n=this.statement.from[0],s=[n],i=["? "+(n.as?" AS "+n.as:n.tableid)];t.push(Object.values(this.data[`${n.databaseid_orig}_${n.as?n.as_orig:n.tableid_orig}`].__merged_data)),this.statement.joins&&this.statement.joins.forEach(f=>{f.joinmode&&f.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(f.table);let h=f.joinmode+" JOIN ? AS "+(f.as?f.as:f.table.tableid);f.on&&(h+=" ON "+f.on.toString()),i.push(h),t.push(Object.values(this.data[`${f.table.databaseid_orig}_${f.table.as?f.table.as_orig:f.table.tableid_orig}`].__merged_data))});let o=[],c={};s.forEach(f=>{let h=this.data[`${f.databaseid_orig}_${f.as?f.as_orig:f.tableid_orig}`].__hash_name,p=f.as?f.as_orig:f.tableid_orig;o.push({key:`'${p}.${h}'`,schema:f.databaseid_orig,table:f.as?f.as_orig:f.tableid_orig,keys:new Set}),r.push(`${f.as?f.as:f.tableid}.\`${h}\` AS "${p}.${h}"`),c[f.as?f.as_orig:f.tableid_orig]=this.data[`${f.databaseid_orig}_${f.as?f.as_orig:f.tableid_orig}`].__merged_attributes});let l=this.statement.where?"WHERE "+this.statement.where:"";l=l.replace(/NOT\(NULL\)/g,"NOT NULL");let _="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(_="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(f=>{f.is_func?r.push(f.initial_select_column.toString()):f.initial_select_column.tableid?r.push(`${f.initial_select_column.tableid}.${f.initial_select_column.columnid} AS ${f.expression.columnid}`):r.push(`${f.initial_select_column.columnid} AS ${f.expression.columnid}`)}));let u="",d="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(u=this.statement.limit?"LIMIT "+this.statement.limit:"",d=this.statement.offset?"OFFSET "+this.statement.offset:"");let E=[];try{let f=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${l} ${_} ${u} ${d}`,h=this._convertColumnsToIndexes(f,s);E=await gr.promise(h,t),t=null}catch(f){throw fe.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),fe.error(f),new Error("There was a problem processing the data.")}if(E&&E.length>0){for(let f=0,h=E.length;f<h;f++){let p=E[f];o.forEach(S=>{p[S.key]!==null&&p[S.key]!==void 0&&S.keys.add(p[S.key])})}o.forEach(f=>{let h=Object.keys(this.data[`${f.schema}_${f.table}`].__merged_data),p=dl.difference(h,[...f.keys].map(S=>S.toString()));for(let S=0,T=p.length;S<T;S++){let A=p[S];delete this.data[`${f.schema}_${f.table}`].__merged_data[A]}})}return{existing_attributes:c,joined_length:E?E.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new Sd(this.columns);for(let{node:i}of s)if(i&&i.columnid){let o=this._findColumn(i);if(o){let c=o.table.as?o.table.as:o.table.tableid;(!t[c]||t[c].indexOf(o.attribute)<0)&&n.push(o)}}n=dl.uniqBy(n,i=>[i.table.databaseid,i.table.as?i.table.as:i.table.tableid,i.attribute].join());try{await this._getData(n)}catch(i){throw fe.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),fe.error(i),new Error(vn)}}async _getData(t){try{let r=t.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]?n[i].columns.push(s.attribute):n[i]={schema:s.table.databaseid,table:s.table.tableid,columns:[s.attribute]},n},{});for(let n in r){let s=r[n],i=this.data[n].__merged_data,o=[];for(let u in i)o.push(i[u][0]);this.data[n].__merged_attributes.push(...s.columns);let c={schema:s.schema,table:s.table,hash_values:o,get_attributes:s.columns},l=await aa.getDataByHash(c),_=s.columns.length;for(let u=0,d=o.length;u<d;u++){let E=o[u],f=l.get(E);for(let h=0;h<_;h++){let p=s.columns[h],S=f[p]===void 0?null:f[p];this.data[n].__merged_data[E].push(S)}}}}catch(r){throw fe.error("Error thrown from getDataByHash function in SQLSearch class method getData."),fe.error(r),r}}async _finalSQL(){let t=[],r=this.statement.from[0];t.push(Object.values(this.data[`${r.databaseid_orig}_${r.as?r.as_orig:r.tableid_orig}`].__merged_data)),r.as=r.as?r.as:r.tableid,r.databaseid="",r.tableid="?",this.statement.joins&&this.statement.joins.forEach(s=>{s.as=s.as?s.as:s.table.tableid,t.push(Object.values(this.data[`${s.table.databaseid_orig}_${s.table.as?s.table.as_orig:s.table.tableid_orig}`].__merged_data)),s.table.databaseid="",s.table.tableid="?"}),this.statement.order&&this.statement.order.forEach(s=>{if(s.is_ordinal)return;this.statement.columns.filter(o=>{let c=o.aggregatorid?o.expression:o,l=o.aggregatorid?o.as_orig:c.as_orig;return s.expression.tableid?c.columnid_orig===s.expression.columnid_orig&&c.tableid_orig===s.expression.tableid_orig:c.columnid_orig===s.expression.columnid_orig||s.expression.columnid_orig===l}).length===0&&(s.expression.columnid=s.initial_select_column.columnid)}),!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&this.statement.limit&&!this.statement.joins&&(delete this.statement.limit,delete this.statement.offset);let n;try{let s=this._buildSQL();fe.trace(`Final SQL: ${s}`),n=await gr.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),fe.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw fe.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),fe.error(s),new Error("There was a problem running the generated sql.")}return n}_translateUndefinedValues(t){try{let r=[];for(let n of t){let s=Object.create(null);Object.keys(n).forEach(i=>{n[i]===void 0?s[i]=null:s[i]=n[i]}),r.push(s)}return r}catch(r){return fe.error(p4.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),fe.trace(r.stack),t}}_buildSQL(t=!0){let r=this.statement.toString();return r=r.replace(/NOT\(NULL\)/g,"NOT NULL"),this.statement.columns.forEach(n=>{if(n.funcid&&n.as){let s=n.toString().replace(" AS "+n.as,"");r=r.replace(n.toString(),s)}}),t===!0?this._convertColumnsToIndexes(r,this.tables):r}_convertColumnsToIndexes(t,r){let n=t,s={};r.forEach(i=>{i.databaseid_orig?s[`${i.databaseid_orig}_${i.as?i.as_orig:i.tableid_orig}`]=i.as?i.as:i.tableid:s[`${i.databaseid}_${i.as?i.as:i.tableid}`]=`\`${i.as?i.as:i.tableid}\``});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=s[i],_=new RegExp(`${l}.\`${o}\``,"g"),u=`${l}.[${c}]`;n=n.replace(_,u)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=new RegExp(`\`${o}\``,"g"),_=`[${c}]`;n=n.replace(l,_)});return n}async _simpleSQLQuery(){let t=this.statement.columns.reduce((n,s)=>(s.as_orig&&s.as_orig!=s.columnid_orig?n[s.columnid_orig]=s.as_orig:n[s.columnid_orig]||(n[s.columnid_orig]=s.columnid_orig),n),{}),r=this.fetch_attributes.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]||(n[i]={}),n[i][t[s.attribute]]=null,n},{});for(let n of this.fetch_attributes){let s=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`,i={schema:n.table.databaseid,table:n.table.tableid,get_attributes:[n.attribute]};try{i.search_attribute=n.attribute,i.search_value="*";let o=await aa.getDataByValue(i);for(let[c,l]of o)this.data[s].__merged_data[c]||(l[n.attribute]===void 0&&(l[n.attribute]=null),this.data[s].__merged_data[c]=Object.assign({},r[s])),this.data[s].__merged_data[c][t[n.attribute]]=l[n.attribute]??null}catch(o){throw fe.error("There was an error when processing this SQL operation. Check your logs"),fe.error(o),new Error(vn)}}return Object.values(Object.values(this.data)[0].__merged_data)}};oD.exports=_S});var kr=g((x_e,cD)=>{"use strict";var T4=iy();cD.exports={searchByConditions:R4,searchByHash:A4,searchByValue:O4,search:b4};var dS=Ln(),{transformReq:fS}=J(),g4=aD();async function R4(e){return fS(e),dS.searchByConditions(e)}a(R4,"searchByConditions");async function A4(e){fS(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of dS.searchByHash(e))r&&t.push(r);return t}a(A4,"searchByHash");async function O4(e){fS(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of dS.searchByValue(e))t.push(r);return t}a(O4,"searchByValue");function b4(e,t){try{let r=new T4(e);r.validate(),new g4(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(b4,"search")});var Td=g((F_e,lD)=>{"use strict";var y4=Ln();lD.exports={writeTransaction:N4};function N4(e,t,r){return y4.writeTransaction(e,t,r)}a(N4,"writeTransaction")});var fD=g((V_e,dD)=>{"use strict";var I4=kr(),w4=ii(),uD=K(),C4=un(),k_e=Td(),D4=require("clone"),hS=require("alasql"),L4=pd(),_D=require("util"),M4=_D.promisify(w4.getTableSchema),P4=_D.promisify(I4.search),U4=U(),ES=J();L4(hS);dD.exports={update:B4};var v4="There was a problem performing this update. Please check the logs and try again.";async function B4({statement:e,hdb_user:t}){let r=await M4(e.table.databaseid,e.table.tableid),n=H4(e.columns);ES.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=D4(s),c=ES.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,_=hS.parse(l).statements[0],u=await P4(_),d=x4(n,u);return G4(o,d,t)}a(B4,"update");function H4(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=hS.compile(`SELECT ${r.expression.toString()} AS [${U4.FUNC_VAL}] FROM ?`)}),t}catch(t){throw uD.error(t),new Error(v4)}}a(H4,"createUpdateRecord");function x4(e,t){return ES.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(x4,"buildUpdateRecords");async function G4(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await C4.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){uD.error(`Error delete new_attributes from update response: ${i}`)}return s}a(G4,"updateRecords")});var hD=g((W_e,ED)=>{var F4=require("alasql"),q4=kr(),k4=K(),V4=Ln(),pS=require("util"),mS=J(),$4=U(),Y4=ii(),Y_e=Td(),K_e=un(),K4="record",W4="successfully deleted",Q4=pS.callbackify(j4),z4=pS.promisify(q4.search),J4=pS.promisify(Y4.getTableSchema);ED.exports={convertDelete:Q4};function X4(e){return`${e.deleted_hashes.length} ${K4}${e.deleted_hashes.length===1?"":"s"} ${W4}`}a(X4,"generateReturnMessage");async function j4({statement:e,hdb_user:t}){let r=await J4(e.table.databaseid,e.table.tableid);mS.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=mS.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=F4.parse(o).statements[0],l={operation:$4.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await z4(c);let _=await V4.deleteRecords(l);return mS.isEmptyOrZeroLength(_.message)&&(_.message=X4(_)),delete _.txn_time,_}catch(_){throw k4.error(_),_.hdb_code?_.message:_}}a(j4,"convertDelete")});var gD=g((z_e,TD)=>{"use strict";var Z4=si(),{hdb_errors:mD}=se(),{getDatabases:pD}=(Ae(),ie(ke));TD.exports={checkSchemaExists:SD,checkSchemaTableExists:e3,schema_describe:Z4};async function SD(e){if(!pD()[e])return mD.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(SD,"checkSchemaExists");async function e3(e,t){let r=await SD(e);if(r)return r;if(!pD()[e][t])return mD.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(e3,"checkSchemaTableExists")});var fl=g((X_e,t3)=>{t3.exports={name:"harperdb",version:"4.3.40",description:"HarperDB is a distributed database, caching service, streaming broker, and application development platform focused on performance and ease of use.",keywords:["database","nosql","api","distributed","broker","mqtt","real-time","enterprise","Fastify","NATS","HarperDB","Harper","clustering","replication","REST","WebSockets","decentralized","server-sent events","document store"],main:"harperdb.js",bin:{harperdb:"./bin/harperdb.js"},engines:{"minimum-node":"16.0.0","go-lang":"1.21.7","nats-server":"2.10.11"},exports:{".":"./index.js"},homepage:"https://www.harperdb.io/",bugs:"support@harperdb.io",author:{name:"HarperDB",email:"support@harperdb.io"},license:"SEE LICENSE IN LICENSE",scripts:{submodules:"git submodule update --init --recursive",build:"eslint -c ./.eslintbuild bin/ dataLayer/ security/ server/ sqlTranslator/ upgrade/ utility/ validation/",pretty:"eslint --fix bin/ dataLayer/ security/ server/ sqlTranslator/ upgrade/ utility/ validation/","cover:test":"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && nyc --no-clean --reporter=lcovonly npm run test:apitests && nyc --no-clean --reporter=lcovonly npm run test:resources && nyc --no-clean --reporter=lcovonly npm run test:logging && nyc --no-clean --reporter=lcovonly npm run test:upgrade && nyc --no-clean --reporter=lcovonly npm run test:nats && nyc --no-clean --reporter=lcovonly npm run test:cfserver && nyc --no-clean --reporter=lcovonly npm run test:hdbserver && nyc --no-clean --reporter=lcovonly npm run test:bin && nyc --no-clean --reporter=lcovonly npm run test:main && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license",test:"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && npm run test:apitests && npm run test:resources && npm run test:logging && npm run test:upgrade && npm run test:nats && npm run test:cfserver && npm run test:hdbserver && npm run test:bin && npm run test:main && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license","test:resources":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/resources/**/*.js' --config '../unitTests/.mocharc.json'","test:bin":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/bin/**/*.js' --config '../unitTests/.mocharc.json'","test:main":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --config '../unitTests/.mocharc-main.json'","test:lmdbbridge":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --config '../unitTests/.mocharc.json'","test:lmdbutility":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --config '../unitTests/.mocharc.json'","test:hdbserver":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --config '../unitTests/.mocharc.json'","test:cfserver":"npm run submodules && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/fastifyRoutes/customFunctionsServer-test.js' --config '../unitTests/.mocharc.json'","test:nats":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json'","test:upgrade":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --config '../unitTests/.mocharc.json'","test:apitests":"pm2 kill && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/apiTests/**/*-test.mjs' --config '../unitTests/.mocharc.json'","test:logging":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/logging/*.js' --config '../unitTests/.mocharc.json'","test:ci":" cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --retries 3 --config '../unitTests/.mocharc-main.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/customFunctions/customFunctionsServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter","hdb-check":"./utility/devops/hdb-check.sh","download-prebuilds":"node ./utility/devops/build/download-prebuilds.js",prebuild:"date",postinstall:"node ./launchServiceScripts/launchInstallNATSServer.js",build_nats_dependency:"node ./utility/devops/nats/builder.js",coverage:"nyc --reporter=lcov npm test"},dependencies:{"@aws-sdk/client-s3":"3.635.0","@aws-sdk/lib-storage":"3.635.0","@endo/static-module-record":"^1.0.4","@fastify/autoload":"5.7.1","@fastify/compress":"~6.5.0","@fastify/cors":"~8.5.0","@fastify/static":"~6.12.0","@turf/area":"6.5.0","@turf/boolean-contains":"6.5.0","@turf/boolean-disjoint":"6.5.0","@turf/boolean-equal":"6.5.0","@turf/circle":"6.5.0","@turf/difference":"6.5.0","@turf/distance":"6.5.0","@turf/helpers":"6.5.0","@turf/length":"6.5.0",alasql:"4.1.10","cbor-x":"1.5.8",chalk:"4.1.2","cli-progress":"3.12.0",clone:"2.1.2","fast-glob":"3.3.2",fastify:"~4.26.2","fastify-plugin":"~4.5.1","fs-extra":"11.2.0",graphql:"^16.8.1","human-readable-ids":"1.0.4",inquirer:"8.2.6","is-number":"7.0.0",joi:"17.12.2","json-bigint-fixes":"1.1.0",json2csv:"5.0.7",jsonata:"1.8.7",jsonwebtoken:"9.0.2",lmdb:"3.2.3",lodash:"4.17.21",mathjs:"11.12.0",minimist:"1.2.8",mkcert:"1.5.1",moment:"2.30.1","mqtt-packet":"~8.2.1",msgpackr:"1.11.2",nats:"2.19.0",needle:"3.3.1","node-stream-zip":"1.15.0","node-unix-socket":"0.2.5","normalize-path":"^3.0.0",ora:"5.4.1","ordered-binary":"1.5.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:"^0.18.0","serve-static":"1.15.0",ses:"1.1.0","stream-chain":"2.2.5","stream-json":"1.8.0",systeminformation:"5.22.9","tar-fs":"2.1.1",ulidx:"0.5.0",uuid:"9.0.1","validate.js":"0.13.1",ws:"8.17.1",yaml:"2.4.1"},devDependencies:{"@tsconfig/node16":"^1.0.3","@types/node":"latest","@typescript-eslint/eslint-plugin":"^5.55.0","@typescript-eslint/parser":"^5.55.0",axios:"1.6.8",chai:"4.4.1","chai-integer":"0.1.0",esbuild:"^0.20.2",eslint:"8.22.0","eslint-config-prettier":"8.3.0","eslint-plugin-prettier":"3.4.1","eslint-plugin-radar":"0.2.1",eventsource:"^2.0.2","hook-std":"3.0.0","intercept-stdout":"0.1.2",mocha:"^10.3.0","mocha-teamcity-reporter":"3.0.0","mock-require":"3.0.3","mock-stdin":"1.0.0",mqtt:"~4.3.8",newman:"5.3.2","newman-reporter-html":"1.0.5","newman-reporter-htmlextra":"1.22.11","newman-reporter-teamcity":"0.1.12","node-fetch":"2.6.7",nyc:"15.1.0",prettier:"2.8.4",rewire:"5.0.0",rimraf:"3.0.2",sinon:"10.0.0","sinon-chai":"3.7.0","source-map-support":"^0.5.21",typescript:"^5.4.2","why-is-node-still-running":"^1.0.0"},overrides:{"eslint-plugin-radar":{eslint:"8.22.0"},alasql:{xlsx:"0.18.5"}},optionalDependencies:{bufferutil:"^4.0.7","utf-8-validate":"^5.0.10"}}});var Sl={};qe(Sl,{addAnalyticsListener:()=>pl,recordAction:()=>nr,recordActionBinary:()=>Wr,setAnalyticsEnabled:()=>r3});function r3(e){CD=e}function nr(e,t,r,n,s){if(!CD)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=Ad.get(i);if(o)if(typeof e=="number"){let c=o.values,l=c.index++;if(l>=c.length){let _=c;o.values=c=new Float32Array(l*2),c.set(_),c.index=l+1}c[l]=e,o.total+=e}else if(typeof e=="boolean")e&&o.total++,o.count++;else if(typeof e=="function")o.count++;else throw new TypeError("Invalid metric value type "+typeof e);else{if(typeof e=="number")o={total:e,values:new Float32Array(4)},o.values.index=1,o.values[0]=e,o.total=e;else if(typeof e=="boolean")o={},o.total=e?1:0,o.count=1;else if(typeof e=="function")o={},o.count=1,o.callback=e;else throw new TypeError("Invalid metric value type "+typeof e);o.description={metric:t,path:r,method:n,type:s},Ad.set(i,o)}gd||n3()}function Wr(e,t,r,n,s){nr(!!e,t,r,n,s)}function pl(e){MD.push(e)}function n3(){gd=performance.now(),setTimeout(async()=>{let e=performance.now()-gd;gd=0;let t=[],r={time:Date.now(),period:e,threadId:oo.threadId,metrics:t};for(let[s,i]of Ad){if(i.values){let o=i.values.subarray(0,i.values.index);o.sort();let c=o.length,l=0,_=[],u;for(let d of PD){let E=Math.floor(c*d),f=o[E-1];if(E>l){let h=E-l;if(f===u){let p=_[_.length-1];typeof p=="number"?_[_.length-1]={value:p,count:1+h}:p.count+=h}else _.push(h>1?{value:f,count:h}:f),u=f;l=E}}t.push(Object.assign(i.description,{mean:i.total/c,distribution:_,count:c}))}else i.callback?t.push(Object.assign(i.description,i.callback(i))):t.push(Object.assign(i.description,{total:i.total,count:i.count}));await UD()}let n=process.memoryUsage();t.push({metric:"memory",threadId:oo.threadId,byThread:!0,...n});for(let s of MD)s(t);Ad=new Map,oo.parentPort?oo.parentPort.postMessage({type:LD,report:r}):HD({report:r})},DD).unref()}async function s3(e,t=6e4){let r=gS(),n=vD(),s=new Promise(p=>{let S=performance.now();setImmediate(()=>{let T=performance.now();T-S>5e3&&(0,El.warn)("Unusually high event queue latency on the main thread of "+Math.round(T-S)+"ms"),S=performance.now()}),n.primaryStore.prefetch([1],()=>{let T=performance.now();T-S>5e3&&(0,El.warn)("Unusually high task queue latency on the main thread of "+Math.round(T-S)+"ms"),p(T-S)})}),i;for(let p of n.primaryStore.getRange({start:1/0,end:!1,reverse:!0}))if(p.value?.time){i=p.value.time;break}if(Date.now()-t<i)return;let o,c=new Map,l=new Map,_=[],u;for(let{key:p,value:S}of r.primaryStore.getRange({start:i||!1,exclusiveStart:!0,end:1/0})){if(!S)continue;if(o){if(p>o+t)break}else o=p;u=p;let{metrics:T,threadId:A}=S;for(let N of T||[]){let{path:b,method:v,type:P,metric:q,count:M,total:Q,distribution:z,threads:j,...oe}=N;M||(M=1);let le=q+(b?"-"+b:"");v!==void 0&&(le+="-"+v),P!==void 0&&(le+="-"+P);let ue=c.get(le);if(ue){if(ue.threads){let Ne=ue.threads[A];if(Ne)ue=Ne;else{ue.threads[A]=Object.assign({},oe);continue}}ue.count||(ue.count=1);let Be=ue.count;for(let Ne in oe){let He=oe[Ne];typeof He=="number"&&(ue[Ne]=(ue[Ne]*Be+He*M)/(Be+M))}ue.count+=M,Q>=0&&(ue.total+=Q,ue.ratio=ue.total/ue.count)}else ue=Object.assign({period:t},N),delete ue.distribution,c.set(le,ue),ue.byThread&&(ue.threads=[],ue.threads[A]=Object.assign({},oe),_.push(ue));if(z){z=z.map(Ne=>typeof Ne=="number"?{value:Ne,count:1}:Ne);let Be=l.get(le);Be?Be.push(...z):l.set(le,z)}}await UD()}for(let p of _){let{path:S,method:T,type:A,metric:N,count:b,total:v,distribution:P,threads:q,...M}=p;q=q.filter(Q=>Q);for(let Q in M){if(typeof p[Q]!="number")continue;let z=0;for(let j of q){let oe=j[Q];typeof oe=="number"&&(z+=oe)}p[Q]=z}p.count=q.length,delete p.threads,delete p.byThread}for(let[p,S]of l){let T=c.get(p);S.sort((Ne,He)=>Ne.value>He.value?1:-1);let A=T.count-1,N=[],b=0,v=0,P;for(let Ne of PD){let He=A*Ne;for(;b<He;)P=S[v++],b+=P.count,v===1&&b--;let zu=S[v>1?v-2:0];P||(P=S[0]),N.push(P.value-(P.value-zu.value)*(b-He)/P.count)}let[q,M,Q,z,j,oe,le,ue,Be]=N;Object.assign(T,{p1:q,p10:M,p25:Q,median:z,p75:j,p90:oe,p95:le,p99:ue,p999:Be})}let d;for(let[p,S]of c)S.id=(0,Rd.getNextMonotonicTime)(),S.time=u,n.primaryStore.put(S.id,S,{append:!0}).then(T=>{T||n.primaryStore.put(S.id,S)}),d=!0;let E=Date.now(),{idle:f,active:h}=performance.eventLoopUtilization();if(d||h*10>f){let p=(0,Rd.getNextMonotonicTime)(),S={id:p,metric:"main-thread-utilization",idle:f-RD,active:h-AD,taskQueueLatency:await s,time:E,...process.memoryUsage()};n.primaryStore.put(p,S,{append:!0}).then(T=>{T||n.primaryStore.put(p,S)})}RD=f,AD=h}async function OD(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function gS(){return bD||(bD=ft({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function vD(){return yD||(yD=ft({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function a3(){BD=!0;let e=(0,ml.get)(TS.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await s3(DD,e),await OD(gS(),i3),await OD(vD(),o3)},Math.min(e/2,2147483647)).unref()}function HD(e,t){let r=e.report;r.threadId=t?.threadId||oo.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(ND+=n.mean*n.count);r.totalBytesProcessed=ND,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(ID.get(t))}),ID.set(t,t.performance.eventLoopUtilization())),r.id=(0,Rd.getNextMonotonicTime)(),gS().primaryStore.put(r.id,r),BD||a3(),c3&&(xD=u3(r))}async function u3(e){if(await xD,!_i){let r=(0,hl.dirname)((0,El.getLogFilePath)());try{_i=await(0,SS.open)((0,hl.join)(r,"analytics.log"),"r+")}catch{_i=await(0,SS.open)((0,hl.join)(r,"analytics.log"),"w+")}}let t=(await _i.stat()).size;if(t>l3){let r=Buffer.alloc(t);await _i.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await _i.write(r,{position:0}),await _i.truncate(r.length),t=r.length}await _i.write(JSON.stringify(e)+`
|
|
9
|
+
This can occur during early stages of install where the config file has not yet been created`);return}else throw Nt.error(i),new Error(`Error reading HarperDB config file at ${r}`)}VV(n,r),Vh(n);let s=n.toJSON();if(vV.config=s,It=Vo(s),It.logging_rotation_rotate)for(let i in rb)It[i]&&Nt.error(`Config ${rb[i]} has been deprecated. Please check https://docs.harperdb.io/docs/ for further details.`);Nt.trace(HV)}}a(kh,"initConfig");function VV(e,t){let r=e.getIn(["rootPath"]),n=!1;e.hasIn(["storage","path"])||(e.setIn(["storage","path"],Nn.join(r,"database")),n=!0),e.hasIn(["clustering","leafServer","streams","path"])||(e.setIn(["clustering","leafServer","streams","path"],Nn.join(r,"clustering","leaf")),n=!0),e.hasIn(["logging","rotation","path"])||(e.setIn(["logging","rotation","path"],Nn.join(r,"log")),n=!0),e.hasIn(["clustering","tls","verify"])||(e.setIn(["clustering","tls","verify"],!0),n=!0),e.hasIn(["authentication"])||(e.addIn(["authentication"],{cacheTTL:3e4,enableSessions:!0,operationTokenTimeout:e.getIn(["operationsApi","authentication","operationTokenTimeout"])??"1d",refreshTokenTimeout:e.getIn(["operationsApi","authentication","refreshTokenTimeout"])??"30d"}),n=!0),e.hasIn(["analytics"])||(e.addIn(["analytics"],{aggregatePeriod:60}),n=!0),n&&(Nt.trace("Updating config file with missing config params"),Er.writeFileSync(t,String(e)))}a(VV,"checkForUpdatedConfig");function Vh(e,t=!1){let r=e.toJSON();r.componentsRoot=r.componentsRoot??r?.customFunctions?.root,r?.http?.threads&&(r.threads=r?.http?.threads);let n=CV(r,t);if(n.error)throw d_.CONFIG_VALIDATION(n.error.message);typeof n.value.threads=="object"?e.setIn(["threads","count"],n.value.threads.count):e.setIn(["threads"],n.value.threads),e.setIn(["componentsRoot"],n.value.componentsRoot),e.setIn(["logging","root"],n.value.logging.root),e.setIn(["storage","path"],n.value.storage.path),e.setIn(["logging","rotation","path"],n.value.logging.rotation.path),e.setIn(["clustering","leafServer","streams","path"],n.value.clustering.leafServer.streams?.path),e.setIn(["operationsApi","network","domainSocket"],n.value?.operationsApi?.network?.domainSocket)}a(Vh,"validateConfig");function $V(e,t){It===void 0&&(It={});let r=In[e.toLowerCase()];if(r===void 0){Nt.trace(`Unable to update config object because config param '${e}' does not exist`);return}It[r.toLowerCase()]=t}a($V,"updateConfigObject");function ab(e,t,r=void 0,n=!1,s=!1,i=!1){It===void 0&&kh();let o=ob(In.hdb_root),c=Nn.join(o,Hr.HDB_CONFIG_FILE),l=Zs(c),_;if(r===void 0&&e.toLowerCase()===Br.DATABASES)_=t;else if(r===void 0){let E;if(i)E=e;else if(E=In[e.toLowerCase()],E===void 0)throw new Error(`Unable to update config, unrecognized config parameter: ${e}`);let f=E.split("_"),h=qh(E,t);l.setIn([...f],h)}else for(let E in r){let f=In[E.toLowerCase()];if(f===Br.HTTP_SECUREPORT&&r[E]===It[Br.HTTP_PORT]?.toString()&&l.setIn(["http","port"],null),f===Br.OPERATIONSAPI_NETWORK_SECUREPORT&&r[E]===It[Br.OPERATIONSAPI_NETWORK_PORT.toLowerCase()]?.toString()&&l.setIn(["operationsApi","network","port"],null),f===Br.DATABASES){_=r[E];continue}if(f?.startsWith("threads_")){let h=l.getIn(["threads"]);h>=0&&(l.deleteIn(["threads"]),l.setIn(["threads","count"],h))}if(!f&&(E.endsWith("_package")||E.endsWith("_port"))&&(f=E),f!==void 0){let h=f.split("_"),p=Hr.LEGACY_CONFIG_PARAMS[E.toUpperCase()];p&&p.startsWith("customFunctions")&&l.hasIn(p.split("_"))&&(f=p,h=p.split("_"));let S=qh(f,r[E]);f==="rootPath"&&S?.endsWith("/")&&(S=S.slice(0,-1));try{h.length>1&&typeof l.getIn(h.slice(0,-1))=="boolean"&&l.deleteIn(h.slice(0,-1)),l.setIn([...h],S)}catch(T){Nt.error(T)}}}_&&ib(l,_),Vh(l);let u=l.getIn(["rootPath"]),d=Nn.join(u,Hr.HDB_CONFIG_FILE);n===!0&&YV(c,u),Er.writeFileSync(d,String(l)),s&&(It=Vo(l.toJSON())),Nt.trace(`Config parameter: ${e} updated with value: ${t}`)}a(ab,"updateConfigValue");function YV(e,t){try{let r=Nn.join(t,"backup",`${Hr.HDB_CONFIG_FILE}.bak`);Er.copySync(e,r),Nt.trace(`Config file: ${e} backed up to: ${r}`)}catch(r){Nt.error(xV),Nt.error(r)}}a(YV,"backupConfigFile");var KV=["databases"];function Vo(e){return e.http&&Object.assign(e.http,e?.customFunctions?.network),e?.operationsApi?.network&&(e.operationsApi.network=Object.assign({},e.http,e.operationsApi.network)),e?.operationsApi&&(e.operationsApi.tls=Object.assign({},e.tls,e.operationsApi.tls)),E_=e,r(e);function r(n){let s={};for(let i in n)if(n.hasOwnProperty(i)){if(typeof n[i]=="object"&&n[i]!==null&&!Array.isArray(n[i])&&!KV.includes(i)){let o=r(n[i]);for(let c in o){if(!o.hasOwnProperty(c))continue;c!=="package"&&(i=i.toLowerCase());let l=i+"_"+c;!Br[l.toUpperCase()]&&In[l]&&(s[In[l].toLowerCase()]=o[c]),s[l]=o[c]}}n[i]!==void 0&&(s[i.toLowerCase()]=n[i])}return s}a(r,"squashObj")}a(Vo,"flattenConfig");function qh(e,t){if(e===Br.CLUSTERING_NODENAME||e===Br.CLUSTERING_USER){if(t==null)return t;if(!isNaN(t))return t.toString();if(typeof t=="string"&&t.toLowerCase()==="true"||typeof t=="string"&&t.toLowerCase()==="false")return t}else{if(LV(t))return parseFloat(t);if(t===!0||t===!1||Array.isArray(t)||Bt.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 Bt.autoCast(t)}a(qh,"castConfigValue");function WV(){let e=Bt.getPropsFilePath(),t=Fi(e);return Zs(t).toJSON()}a(WV,"getConfiguration");async function QV(e){let{operation:t,hdb_user:r,hdb_auth_header:n,...s}=e;try{return ab(void 0,void 0,s,!0),FV}catch(i){throw typeof i=="string"||i instanceof String?PV(i,i,UV.BAD_REQUEST,void 0,void 0,!0):i}}a(QV,"setConfiguration");function $h(){let e=Bt.getPropsFilePath();try{Er.accessSync(e,Er.constants.F_OK|Er.constants.R_OK)}catch(n){if(!Bt.noBootFile())throw Nt.error(n),new Error(`HarperDB properties file at path ${e} does not exist`)}let t=Fi(e);return Zs(t).toJSON()}a($h,"readConfigFile");function Zs(e){return DV.parseDocument(Er.readFileSync(e,"utf8"),{simpleKeys:!0})}a(Zs,"parseYamlDoc");function zV(){let e=$h(),t=e?.clustering?.hubServer?.cluster?.network?.routes;t=Bt.isEmptyOrZeroLength(t)?[]:t;let r=tb(t);if(r)throw d_.CONFIG_VALIDATION(r.message);let n=e?.clustering?.leafServer?.network?.routes;n=Bt.isEmptyOrZeroLength(n)?[]:n;let s=tb(n);if(s)throw d_.CONFIG_VALIDATION(s.message);if(!Bt.isEmptyOrZeroLength(n)&&!Bt.isEmptyOrZeroLength(t)){let i=t.filter(o=>n.some(c=>c.host===o.host&&c.port===o.port));if(!Bt.isEmptyOrZeroLength(i)){let o=`Duplicate hub and leaf routes found ${JSON.stringify(i)}`;throw d_.CONFIG_VALIDATION(o)}}return{hub_routes:t,leaf_routes:n}}a(zV,"getClusteringRoutes");function cb(e){let t=nb(e);It={};for(let r in In){let n=t.get(r.toUpperCase());if(Bt.isEmpty(n)||typeof n=="string"&&n.trim().length===0)continue;let s=In[r].toLowerCase();s===Br.LOGGING_ROOT?It[s]=Nn.dirname(n):It[s]=n}return It}a(cb,"initOldConfig");function JV(e){let t=$h();return MV.get(t,e.replaceAll("_","."))}a(JV,"getConfigFromFile");async function XV(e,t){let r=Zs(Fi());r.hasIn([e])?r.setIn([e],t):r.addIn([e],t),await Er.writeFile(Fi(),String(r))}a(XV,"addConfig");function jV(e){let t=Fi(Bt.getPropsFilePath()),r=Zs(t);r.deleteIn(e);let n=r.getIn(["rootPath"]),s=Nn.join(n,Hr.HDB_CONFIG_FILE);Er.writeFileSync(s,String(r))}a(jV,"deleteConfigFromFile");function ZV(){return E_||(kh(),E_)}a(ZV,"getConfigObj")});var ne=g((eae,Eb)=>{"use strict";var Yh=require("fs-extra"),qi=require("path"),ub=require("os"),e$=require("properties-reader"),Ac=K(),Rc=J(),de=U(),h_=hr(),t$="Error initializing environment manager",m_="BOOT_PROPS_FILE_PATH",_b=!1,r$={[de.HDB_SETTINGS_NAMES.INSTALL_USER]:!0,[de.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]:!0,[de.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]:!0,BOOT_PROPS_FILE_PATH:!0},gs={};Eb.exports={BOOT_PROPS_FILE_PATH:m_,getHdbBasePath:n$,setHdbBasePath:s$,get:db,initSync:o$,setProperty:Me,initTestEnvironment:c$,setCloneVar:a$};function n$(){return gs[de.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]}a(n$,"getHdbBasePath");function s$(e){gs[de.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=e}a(s$,"setHdbBasePath");function db(e){let t=h_.getConfigValue(e);return t===void 0?gs[e]:t}a(db,"get");function Me(e,t){r$[e]&&(gs[e]=t),h_.updateConfigObject(e,t)}a(Me,"setProperty");function i$(){let e;try{e=Rc.getPropsFilePath(),Yh.accessSync(e,Yh.constants.F_OK|Yh.constants.R_OK),_b=!0;let t=e$(e);return gs[de.HDB_SETTINGS_NAMES.INSTALL_USER]=t.get(de.HDB_SETTINGS_NAMES.INSTALL_USER),gs[de.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY]=t.get(de.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY),gs[m_]=e,!0}catch{return Ac.trace(`Environment manager found no properties file at ${e}`),!1}}a(i$,"doesPropFileExist");function o$(e=!1){try{(_b||i$()||Rc.noBootFile())&&!fb&&(h_.initConfig(e),gs[de.HDB_SETTINGS_NAMES.HDB_ROOT_KEY]=h_.getConfigValue(de.HDB_SETTINGS_NAMES.HDB_ROOT_KEY))}catch(t){Ac.error(t$),Ac.error(t),console.error(t),process.exit(1)}}a(o$,"initSync");var fb=!1;function a$(e){fb=e}a(a$,"setCloneVar");function c$(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=qi.join(__dirname,"../../","unitTests");gs[m_]=qi.join(l,"hdb_boot_properties.file"),Me(de.HDB_SETTINGS_NAMES.SETTINGS_PATH_KEY,qi.join(l,"settings.test")),Me(de.HDB_SETTINGS_NAMES.INSTALL_USER,ub.userInfo()?ub.userInfo().username:void 0),Me(de.HDB_SETTINGS_NAMES.LOG_LEVEL_KEY,"debug"),Me(de.HDB_SETTINGS_NAMES.LOG_PATH_KEY,qi.join(l,"envDir","log")),Me(de.HDB_SETTINGS_NAMES.LOG_DAILY_ROTATE_KEY,!1),Me(de.HDB_SETTINGS_NAMES.CLUSTERING_ENABLED_KEY,!0),Me(de.HDB_SETTINGS_NAMES.CLUSTERING_NODE_NAME_KEY,"1231412de213"),Me(de.HDB_SETTINGS_NAMES.HDB_ROOT_KEY,qi.join(l,"envDir")),Me(de.CONFIG_PARAMS.STORAGE_PATH,qi.join(l,"envDir")),s&&(Me(de.CONFIG_PARAMS.HTTP_SECUREPORT,db(de.CONFIG_PARAMS.HTTP_PORT)),Me(de.CONFIG_PARAMS.HTTP_PORT,null)),Me(de.CONFIG_PARAMS.CUSTOMFUNCTIONS_NETWORK_HTTPS,!!s),Me(de.HDB_SETTINGS_NAMES.SERVER_PORT_KEY,9925),Me(de.HDB_SETTINGS_NAMES.CORS_ENABLED_KEY,Rc.isEmpty(i)?!1:i),Me(de.CONFIG_PARAMS.HTTP_CORS,Rc.isEmpty(i)?!1:i),Me(de.HDB_SETTINGS_NAMES.MAX_CUSTOM_FUNCTION_PROCESSES,2),Me(de.HDB_SETTINGS_NAMES.MAX_HDB_PROCESSES,4),Me(de.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_PORT_KEY,9926),Me(de.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_ENABLED_KEY,!0),Me(de.HDB_SETTINGS_NAMES.CUSTOM_FUNCTIONS_DIRECTORY_KEY,qi.resolve(__dirname,"../../unitTests/server/fastifyRoutes/custom_functions")),Me(de.HDB_SETTINGS_NAMES.LOCAL_STUDIO_ON,Rc.isEmpty(c)?!1:c),o&&(Me("CORS_ACCESSLIST",o),Me(de.CONFIG_PARAMS.HTTP_CORSACCESSLIST,o)),n&&(Me(de.HDB_SETTINGS_NAMES.SERVER_TIMEOUT_KEY,n),Me(de.CONFIG_PARAMS.HTTP_TIMEOUT,n)),t&&(Me(de.HDB_SETTINGS_NAMES.SERVER_KEEP_ALIVE_TIMEOUT_KEY,t),Me(de.CONFIG_PARAMS.HTTP_KEEPALIVETIMEOUT,t)),r&&(Me(de.HDB_SETTINGS_NAMES.SERVER_HEADERS_TIMEOUT_KEY,r),Me(de.CONFIG_PARAMS.HTTP_HEADERSTIMEOUT,r))}catch(t){let r=`Error reading in HDB environment variables from path ${m_}. Please check your boot props and settings files`;Ac.fatal(r),Ac.error(t)}}a(c$,"initTestEnvironment")});var ze=g((rae,Rb)=>{"use strict";var Ic=U(),l$=J(),mr=ne(),wc=require("path"),u$=require("minimist"),hb=require("fs-extra"),mb=require("lodash");mr.initSync();var{CONFIG_PARAMS:ei,DATABASES_PARAM_CONFIG:Oc,SYSTEM_SCHEMA_NAME:p_}=Ic,bc,yc,Nc;function pb(){if(bc!==void 0)return bc;if(mr.getHdbBasePath()!==void 0)return bc=mr.get(ei.STORAGE_PATH)||wc.join(mr.getHdbBasePath(),Ic.DATABASES_DIR_NAME),bc}a(pb,"getBaseSchemaPath");function Sb(){if(yc!==void 0)return yc;if(mr.getHdbBasePath()!==void 0)return yc=gb(p_),yc}a(Sb,"getSystemSchemaPath");function Tb(){if(Nc!==void 0)return Nc;if(mr.getHdbBasePath()!==void 0)return Nc=mr.get(Ic.CONFIG_PARAMS.STORAGE_AUDIT_PATH)||wc.join(mr.getHdbBasePath(),Ic.TRANSACTIONS_DIR_NAME),Nc}a(Tb,"getTransactionAuditStoreBasePath");function _$(e,t){let r=mr.get(ei.DATABASES)?.[e];return t&&r?.tables?.[t]?.auditPath||r?.auditPath||wc.join(Tb(),e.toString())}a(_$,"getTransactionAuditStorePath");function gb(e,t){e=e.toString(),t=t&&t.toString();let r=mr.get(Ic.CONFIG_PARAMS.DATABASES)?.[e];return t&&r?.tables?.[t]?.path||r?.path||wc.join(pb(),e)}a(gb,"getSchemaPath");function d$(e,t){e=e.toString(),t=t.toString();let r=process.env;Object.assign(r,u$(process.argv));let n=r[ei.DATABASES.toUpperCase()];if(n){let i;try{i=JSON.parse(n)}catch(o){if(!l$.isObject(n))throw o;i=n}for(let o of i){let c=o[p_];if(!c)continue;let l=mr.get(ei.DATABASES);l=l??{};let _=c?.tables?.[t]?.[Oc.PATH];if(_)return mb.set(l,[p_,Oc.TABLES,t,Oc.PATH],_),mr.setProperty(ei.DATABASES,l),_;let u=c?.[Oc.PATH];if(u)return mb.set(l,[p_,Oc.PATH],u),mr.setProperty(ei.DATABASES,l),u}}let s=r[ei.STORAGE_PATH.toUpperCase()];if(s){if(!hb.pathExistsSync(s))throw new Error(s+" does not exist");let i=wc.join(s,e);return hb.mkdirsSync(i),mr.setProperty(ei.STORAGE_PATH,s),i}return Sb()}a(d$,"initSystemSchemaPaths");function f$(){bc=void 0,yc=void 0,Nc=void 0}a(f$,"resetPaths");Rb.exports={getBaseSchemaPath:pb,getSystemSchemaPath:Sb,getTransactionAuditStorePath:_$,getTransactionAuditStoreBasePath:Tb,getSchemaPath:gb,initSystemSchemaPaths:d$,resetPaths:f$}});var xr=g((oae,Nb)=>{"use strict";var E$=vr().LMDB_ERRORS_ENUM,sae=require("lmdb"),h$=dt(),iae=require("buffer").Buffer,{OVERFLOW_MARKER:Ab,MAX_SEARCH_KEY_LENGTH:S_}=h$,Ob=["number","string","symbol","boolean","bigint"];function m$(e){if(e=e?.primaryStore||e,!e)throw new Error(E$.ENV_REQUIRED)}a(m$,"validateEnv");function p$(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(p$,"stringifyData");function S$(e){return e instanceof Date?e.valueOf():e}a(S$,"convertKeyValueToWrite");function T$(e,t){if(e===null)return t?[null]:void 0;if(e===void 0)return;if(Ob.includes(typeof e))return e.length>S_?[e.slice(0,S_)+Ab]:[e];let r;if(Array.isArray(e)){r=[];for(let n=0,s=e.length;n<s;n++){let i=e[n];if(Ob.includes(typeof i))i.length>S_?r.push(i.slice(0,S_)+Ab):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(T$,"getIndexedValues");var T_=0,bb=0;function yb(){bb=Date.now()-performance.now()}a(yb,"adjustStartTime");yb();var g$=6e4;setInterval(yb,g$).unref();function R$(){let e=performance.now()+bb;return e>T_?(T_=e,e):(T_+=488e-6,T_)}a(R$,"getNextMonotonicTime");Nb.exports={validateEnv:m$,stringifyData:p$,convertKeyValueToWrite:S$,getNextMonotonicTime:R$,getIndexedValues:T$}});var Cc=g((cae,Ib)=>{"use strict";var A$=U().OPERATIONS_ENUM,Kh=class{static{a(this,"InsertObject")}constructor(t,r,n,s,i=void 0){this.operation=A$.INSERT,this.schema=t,this.table=r,this.hash_attribute=n,this.records=s,this.__origin=i}};Ib.exports=Kh});var Dc=g((_ae,Lb)=>{"use strict";var uae=Cc(),g_=U(),Wh=J(),wb=K(),O$=require("uuid"),{handleHDBError:R_,hdb_errors:b$}=se(),{HDB_ERROR_MSGS:A_,HTTP_STATUS_CODES:O_}=b$;Lb.exports=Cb;function Cb(e,t,r){for(let s=0;s<t.length;s++)Db(t[s]);let{records:n}=e;for(let s=0;s<n.length;s++){let i=n[s];y$(i,r,e.operation)}}a(Cb,"processRows");Cb.validateAttribute=Db;function Db(e){if(Buffer.byteLength(String(e))>g_.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw R_(new Error,A_.ATTR_NAME_LENGTH_ERR(e),O_.BAD_REQUEST,void 0,void 0,!0);if(Wh.isEmptyOrZeroLength(e)||Wh.isEmpty(e.trim()))throw R_(new Error,A_.ATTR_NAME_NULLISH_ERR,O_.BAD_REQUEST,void 0,void 0,!0)}a(Db,"validateAttribute");function y$(e,t,r){if(!e.hasOwnProperty(t)||Wh.isEmptyOrZeroLength(e[t])){if(r===g_.OPERATIONS_ENUM.INSERT||r===g_.OPERATIONS_ENUM.UPSERT){e[t]=O$.v4();return}throw wb.error("Update transaction aborted due to record with no hash value:",e),R_(new Error,A_.RECORD_MISSING_HASH_ERR,O_.BAD_REQUEST,void 0,void 0,!0)}if(Buffer.byteLength(String(e[t]))>g_.INSERT_MODULE_ENUM.MAX_CHARACTER_SIZE)throw wb.error(e),R_(new Error,A_.HASH_VAL_LENGTH_ERR,O_.BAD_REQUEST,void 0,void 0,!0)}a(y$,"validateHash")});var Mb,wn,Qh,Lc=Re(()=>{Mb=require("events"),wn=class extends Mb.EventEmitter{static{a(this,"IterableEventQueue")}resolveNext;queue;hasDataListeners;drainCloseListener;currentDrainResolver;[Symbol.asyncIterator](){let t=new Qh;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)}},Qh=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 Xh={};qe(Xh,{loadGQLSchema:()=>w$,start:()=>Jh,startOnMainThread:()=>I$});function Jh({ensureTable:e}){return{handleFile:t,setupFile:t};async function t(r,n,s,i){let{parse:o,Source:c,Kind:l,NamedTypeNode:_,StringValueNode:u}=await import("graphql"),d=o(new c(r.toString(),s)),E=new Map,f=[],h;for(let S of d.definitions)switch(S.kind){case l.OBJECT_TYPE_DEFINITION:let v=function(P){if(P.kind==="NonNullType"){let Q=v(P.type);return Q.nullable=!1,Q}if(P.kind==="ListType")return{type:"array",elements:v(P.type)};let M={type:P.name?.value};return Object.defineProperty(M,"location",{value:P.loc.startToken}),M};a(v,"getProperty");let T=S.name.value,A=[],N={table:null,database:null,properties:A};E.set(T,N);for(let P of S.directives){if(P.name.value==="table"){for(let q of P.arguments)N[q.name.value]=q.value.value;N.schema&&(N.database=N.schema),N.table||(N.table=T),N.audit&&(N.audit=N.audit!=="false"),N.attributes=N.properties,f.push(N)}if(P.name.value==="sealed"&&(N.sealed=!0),P.name.value==="export"){N.export=!0;for(let q of P.arguments)q.name.value==="name"&&(N.export={name:q.value.value})}}let b=!1;for(let P of S.fields){let q=v(P.type);q.name=P.name.value,A.push(q);for(let M of P.directives)if(M.name.value==="primaryKey")b?console.warn("Can not define two attributes as a primary key"):(q.isPrimaryKey=!0,b=!0);else if(M.name.value==="indexed")q.indexed=!0;else if(M.name.value==="relationship"){let Q={};for(let z of M.arguments)Q[z.name.value]=z.value.value;q.relationship=Q}else if(M.name.value==="createdTime")q.assignCreatedTime=!0;else if(M.name.value==="updatedTime")q.assignUpdatedTime=!0;else if(M.name.value==="expiresAt")q.expiresAt=!0;else if(M.name.value==="allow"){let Q=q.authorizedRoles=[];for(let z of M.arguments)z.name.value==="role"&&Q.push(z.value.value)}}N.type=T,T==="Query"&&(h=N)}function p(S){let T=E.get(S.type);T?(Object.defineProperty(S,"properties",{value:T.properties}),Object.defineProperty(S,"definition",{value:T})):S.type==="array"?p(S.elements):N$.includes(S.type)||(0,Pb.getWorkerIndex)()===0&&console.error(`The type ${S.type} is unknown at line ${S.location.line}, column ${S.location.column}, in ${s}`)}a(p,"connectPropertyType");for(let S of E.values())for(let T of S.properties)p(T);for(let S of f)S.tableClass=e(S),S.export&&(S.export.name===""?i.set((0,zh.dirname)(n),S.tableClass):i.set((0,zh.dirname)(n)+"/"+(S.export.name||S.type),S.tableClass))}}var zh,Pb,N$,I$,w$,Ub=Re(()=>{zh=require("path");Ae();Pb=x(ot()),N$=["ID","Int","Float","Long","String","Boolean","Date","Bytes","Any","BigInt"];a(Jh,"start");I$=Jh,w$=Jh({ensureTable:ft}).handleFile});async function b_(e){let t=(0,Hb.pathToFileURL)(e).toString();return C$?(Mc||(Mc=D$(M$)),(await(await Mc).import(t)).namespace):import(t)}async function D$(e){let{StaticModuleRecord:t}=await import("@endo/static-module-record");return require("ses"),lockdown({domainTaming:"unsafe",consoleTaming:"unsafe",errorTaming:"unsafe",errorTrapping:"none",stackFiltering:"verbose"}),Mc=new Compartment({console,Math,Date,fetch:L$,...e()},{},{name:"h-dapp",resolveHook(r,n){return r==="harperdb"?"harperdb":(r=new URL(r,n).toString(),(0,Bb.extname)(r)||(r+=".js"),r)},importHook:async r=>{if(r==="harperdb")return{imports:[],exports:["Resource","tables","databases"],execute(s){Object.assign(s,{Resource:Yt,tables:Gr,databases:at})}};let n=await(0,vb.readFile)(new URL(r),{encoding:"utf-8"});return new t(n,r)}}),Mc}function L$(e,t){let r=typeof e=="string"||e.url;if(new URL(r).protocol!="https")throw new Error("Only https is allowed in fetch");return fetch(e,t)}function M$(){return{Resource:Yt,tables:Gr}}var vb,Bb,Hb,C$,Mc,jh=Re(()=>{an();Ae();vb=require("fs/promises"),Bb=require("path"),Hb=require("url"),C$=!1;a(b_,"secureImport");a(D$,"getCompartment");a(L$,"secureOnlyFetch");a(M$,"getGlobalVars")});var em={};qe(em,{handleFile:()=>P$});async function P$(e,t,r,n){let s=new Map,i=await b_(r);c(i.default)&&n.set((0,Zh.dirname)(t),i.default),o(i,(0,Zh.dirname)(t));function o(l,_){for(let u in l){let d=l[u];c(d)?n.set(_+"/"+u,d):typeof d=="object"&&o(d,_+"/"+u)}}a(o,"recurseForResources");function c(l){return typeof l=="function"&&(l.get||l.put||l.post||l.delete)}return a(c,"isResource"),s}var Zh,xb=Re(()=>{jh();Zh=require("path");a(P$,"handleFile")});var rm={};qe(rm,{start:()=>U$});function U$({resources:e}){e.set("login",tm),e.loginPath=t=>"/login?redirect="+encodeURIComponent(t.url)}var tm,Gb=Re(()=>{an();a(U$,"start");tm=class extends Yt{static{a(this,"Login")}static async get(t,r,n){}static async post(t,r,n){let{username:s,password:i,redirect:o}=r;return{data:await n.login(s,i)}}}});var Kb={};qe(Kb,{parse:()=>sm,streamAsJSON:()=>Pc,stringify:()=>ki});function Pc(e){return new nm({value:e})}function Fb(e){return console.error(e),JSON.stringify(e.toString())}function qb(e,t,r){return e?.then?r?e.then(t,r):e.then(t):t(e)}function ki(e){try{return JSON.stringify(e)??"null"}catch(t){if(t===$b)return Yb(e);if(t.resolution)return t.resolution.then(()=>ki(e));throw t}}function Yb(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+=Yb(e[n]);return r+"]"}else{r="{";let n=!0;for(let s in e)n?n=!1:r+=",",r+=JSON.stringify(s)+":"+ki(e[s]);return r+"}"}}else{if(t==="string")return JSON.stringify(e);if(t==="undefined")return"null"}return e.toString()}function sm(e){return H$.test(e)?v$.parse(e):JSON.parse(e)}var kb,Vb,v$,B$,$b,nm,H$,im=Re(()=>{kb=require("stream"),Vb=x(require("json-bigint-fixes")),v$=(0,Vb.default)({useNativeBigInt:!0}),B$=1e4,$b={};BigInt.prototype.toJSON=function(){throw $b};a(Pc,"streamAsJSON");nm=class extends kb.Readable{static{a(this,"JSONStream")}constructor(t){super(t),this.buffer=[],this.bufferSize=0,this.iterator=this.serialize(t.value,!0),this.activeIterators=[]}*serialize(t){if(t&&typeof t=="object"){let r=t[Symbol.asyncIterator],n=t[Symbol.iterator];if((n||r)&&!t.then){yield"[";let s=!0;if((r||n)&&!(t instanceof Array)){let i=r?t[Symbol.asyncIterator]():t[Symbol.iterator]();this.activeIterators.push(i);let o;for(;;)if(o=i.next(),o.then&&(yield o.then(c=>(o=c,""))),o.done){this.activeIterators.splice(this.activeIterators.indexOf(i),1),yield"]";return}else s?s=!1:yield",",yield*this.serialize(o.value)}for(let i of t)s?s=!1:yield",",yield*this.serialize(i);yield"]";return}if(t.then)try{yield t.then(s=>this.serialize(s),Fb)}catch(s){yield Fb(s)}else yield ki(t)}else yield ki(t)}_read(){if(!this._amReading){if(this._amReading=!0,this.done)return this.push(null);qb(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>B$?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 qb(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(Fb,"handleError");a(qb,"when");a(ki,"stringify");a(Yb,"jsStringify");H$=/[[,:]\s*-?\d{16,}/;a(sm,"parse")});var iy=g((Iae,sy)=>{"use strict";var om=require("recursive-iterator"),x$=require("alasql"),am=require("clone"),Wb=J(),{handleHDBError:Qb,hdb_errors:G$}=se(),{HDB_ERROR_MSGS:zb,HTTP_STATUS_CODES:Jb}=G$,{getDatabases:F$}=(Ae(),ie(ke)),q$=["DISTINCT_ARRAY"],Xb=Symbol("validateTables"),cm=Symbol("validateTable"),Nae=Symbol("getAllColumns"),jb=Symbol("validateAllColumns"),y_=Symbol("findColumn"),Zb=Symbol("validateOrderBy"),Uc=Symbol("validateSegment"),lm=Symbol("validateColumn"),ey=Symbol("setColumnsForTable"),ty=Symbol("checkColumnsForAsterisk"),ry=Symbol("validateGroupBy"),ny=Symbol("hasColumns"),um=class{static{a(this,"SelectValidator")}constructor(t){this.statement=t,this.attributes=[]}validate(){if(!this.statement)throw new Error("invalid sql statement");this[Xb](),this[ty](),this[jb]()}[Xb](){if(this[ny]()){if(!this.statement.from||this.statement.from.length===0)throw"no from clause";this.statement.from.forEach(t=>{this[cm](t)}),this.statement.joins&&this.statement.joins.forEach(t=>{t.table.as=t.as,this[cm](t.table)})}}[ny](){let t=!1,r=new om(this.statement);for(let{node:n,path:s}of r)if(n&&n.columnid){t=!0;break}return t}[cm](t){if(!t.databaseid)throw`schema not defined for table ${t.tableid}`;let r=F$();if(!r[t.databaseid])throw Qb(new Error,zb.SCHEMA_NOT_FOUND(t.databaseid),Jb.NOT_FOUND);if(!r[t.databaseid][t.tableid])throw Qb(new Error,zb.TABLE_NOT_FOUND(t.databaseid,t.tableid),Jb.NOT_FOUND);r[t.databaseid][t.tableid].attributes.forEach(s=>{let i=am(s);i.table=am(t),this.attributes.push(i)})}[y_](t){return this.attributes.filter(r=>t.tableid?(r.table.as===t.tableid||r.table.tableid===t.tableid)&&r.attribute===t.columnid:r.attribute===t.columnid)}[ty](){let t=new om(this.statement.columns);for(let{node:r,path:n}of t)r&&r.columnid==="*"&&n.indexOf("expression")<0&&this[ey](r.tableid)}[ey](t){this.attributes.forEach(r=>{(!t||t&&(r.table.tableid===t||r.table.as===t))&&!r.relation&&this.statement.columns.push(new x$.yy.Column({columnid:r.attribute,tableid:r.table.as?r.table.as:r.table.tableid}))})}[jb](){this[Uc](this.statement.columns,!1),this[Uc](this.statement.joins,!1),this[Uc](this.statement.where,!1),this[ry](this.statement.group,!1),this[Uc](this.statement.order,!0)}[Uc](t,r){if(!t)return;let n=new om(t),s=[];for(let{node:i,path:o}of n)!Wb.isEmpty(i)&&!Wb.isEmpty(i.columnid)&&i.columnid!=="*"&&(r?this[Zb](i):s.push(this[lm](i)));return s}[ry](t){if(!t)return;let r=[];if(this.statement.columns.forEach(n=>{if(!(n.funcid&&q$.indexOf(n.funcid.toUpperCase())>=0)){if(!n.aggregatorid&&!n.columnid){let s=am(n);delete s.as,r.push(s)}else if(n.columnid){let s=this[y_](n)[0];s&&r.push(s)}}}),this.statement.group.forEach(n=>{let s=null;if(!n.columnid)r.forEach((i,o)=>{if(i.toString()===n.toString()){s=i,r.splice(o,1);return}});else{let i=this[y_](n);if(!i||i.length===0)throw`unknown column '${n.toString()}' in group by`;if(i.length>1)throw`ambiguously defined column '${n.toString()}' in group by`;r.forEach((o,c)=>{if(o.attribute===i[0].attribute&&o.table.tableid===i[0].table.tableid){s=o,r.splice(c,1);return}})}if(!s)throw`group by column '${n.toString()}' must be in select`}),r.length>0)throw`select column '${r[0].attribute?r[0].attribute:r[0].toString()}' must be in group by`}[Zb](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[lm](t)}[lm](t){let r=this[y_](t),n=(t.tableid?t.tableid+".":"")+t.columnid;if(r.length===0)throw`unknown column ${n}`;if(r.length>1)throw`ambiguous column reference ${n}`;return r[0]}};sy.exports=um});var ay=g((Cae,oy)=>{"use strict";var _m=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")}};oy.exports=_m});var ly=g((Lae,cy)=>{"use strict";var dm=class{static{a(this,"DBIDefinition")}constructor(t=!1,r=!1){this.dup_sort=t,this.is_hash_attribute=r,this.useVersions=r}};cy.exports=dm});var fy={};qe(fy,{HAS_EXPIRATION:()=>Tm,LAST_TIMESTAMP_PLACEHOLDER:()=>Hc,LOCAL_TIMESTAMP:()=>k$,METADATA:()=>vc,NO_TIMESTAMP:()=>Em,PENDING_LOCAL_TIME:()=>gm,PREVIOUS_TIMESTAMP_PLACEHOLDER:()=>Sm,RecordEncoder:()=>pm,TIMESTAMP_ASSIGN_LAST:()=>$$,TIMESTAMP_ASSIGN_NEW:()=>_y,TIMESTAMP_ASSIGN_PREVIOUS:()=>dy,TIMESTAMP_PLACEHOLDER:()=>N_,TIMESTAMP_RECORD_PREVIOUS:()=>hm,getUpdateRecord:()=>Rm,handleLocalTimeForGets:()=>D_});function K$(){return Bc[0]=Bc[0]^64,V$.getFloat64(0)}function D_(e){let t=e.getEntry;e.readCount=0,e.cachePuts=!1,e.getEntry=function(i,o){e.readCount++;let c=t.call(this,i,o),l=c?.value,_=l?.[vc];return _>=0&&(c.metadataFlags=_,c.localTime=l.localTime,c.value=l.value,l.expiresAt>0&&(c.expiresAt=l.expiresAt)),c&&(c.key=i),c};let r=e.get;e.get=function(i,o){let c=r.call(this,i,o);return c?.[vc]>=0?c.value:c};let n=e.getRange;e.getRange=function(i){let o=n.call(this,i);return i.valuesForKey?o.map(c=>c?.value):i.values===!1||i.onlyCount?o:o.map(c=>{let l=c.value,_=l[vc];return _>=0&&(c.metadataFlags=_,c.localTime=l.localTime,c.value=l.value,l.expiresAt>0&&(c.expiresAt=l.expiresAt)),c})};let s=e.useReadTransaction();if(s.done(),!s.done.isTracked){let i=s.constructor,o=s.use,c=s.done;i.prototype.use=function(){this.timerTracked||(this.timerTracked=!0,Vi.push(new WeakRef(this))),o.call(this)},i.prototype.done=function(){if(c.call(this),this.isDone)for(let l=0;l<Vi.length;l++){let _=Vi[l].deref();(!_||_.isDone||_.isCommitted)&&Vi.splice(l--,1)}},i.prototype.done.isTracked=!0}return e}function Rm(e,t,r){return function(n,s,i,o,c=-1,l,_,u,d="put",E,f){if(E||l==null?$o=i?.localTime?hm|dy:Em:$o=l?i?.localTime?hm|16384:_y|16384:Em,u>0&&(c|=Tm),w_=c,mm=u,i?.version===o&&l===!1)throw new Error("Must retain local time if version is not changed");let h={version:o,instructedWrite:$o>0},p;try{E&&(h.ifVersion=p=i?.version??null);let S=e.put(n,s,h);if(l){let T=_?.user?.username;if(f&&(I_=e.encoder.encode(f)),E&&i?.localTime){let A=i?.localTime,N=r.get(A);if(N){let b=Ht(N).previousLocalTime;return r.put(A,C_(o,t,n,b,T,d,I_),{ifVersion:p}),S}}r.put(Hc,C_(o,t,n,i?.localTime?1:0,T,d,I_),{append:d!=="invalidate",instructedWrite:!0,ifVersion:p})}return S}catch(S){throw S.message+=" id: "+n+" options: "+h,S}}}var uy,fm,N_,Hc,Sm,k$,vc,Bc,V$,Em,_y,$$,dy,hm,Tm,gm,Y$,I_,$o,w_,mm,pm,Vi,xc=Re(()=>{uy=require("msgpackr");ti();fm=x(K()),N_=new Uint8Array([1,1,1,1,4,64,0,0]),Hc=new Uint8Array([1,1,1,1,1,0,0,0]),Sm=new Uint8Array([1,1,1,1,3,64,0,0]),k$=Symbol("local-timestamp"),vc=Symbol("metadata"),Bc=new Uint8Array(8),V$=new DataView(Bc.buffer,0,8),Em=0,_y=0,$$=1,dy=3,hm=4,Tm=16,gm=1,$o=0,w_=-1,mm=0,pm=class extends uy.Encoder{static{a(this,"RecordEncoder")}constructor(t){t.useBigIntExtension=!0,super(t);let r=this.encode;this.encode=function(n,s){if($o||w_>=0){let i=0,o=$o;o&&(i+=8,$o=0);let c=w_,l=mm;c>=0&&(i+=2,w_=-1,l&&(i+=8,mm=0));let _=Y$=r.call(this,n,s|2048|i);I_=_.subarray((_.start||0)+i,_.end);let u=_.start||0;return o&&(N_[4]=o,N_[5]=o>>8,_.set(N_,u),u+=8),c>=0&&(_[u++]=c,_[u++]=0,l&&(_.dataView||(_.dataView=new DataView(_.buffer,_.byteOffset,_.byteLength))).setFloat64(u,l)),_}else return r.call(this,n,s)}}decode(t,r){let n=r?.start||0,s=r>-1?r:r?.end||t.length,i=t[n],o=0;try{if(i<32&&s>2){let c=n,l;if(i===2){if(t.copy)t.copy(Bc,0,c),c+=8;else for(let d=0;d<8;d++)Bc[d]=t[c++];l=K$(),i=t[c]}let _;i<32&&(o=i,c+=2,o&Tm&&(_=(t.dataView||(t.dataView=new DataView(t.buffer,t.byteOffset,t.byteLength))).getFloat64(c),c+=8));let u=super.decode(t.subarray(c,s),s-c);return{localTime:l,value:u,[vc]:o,expiresAt:_}}return super.decode(t,r)}catch(c){throw c.message+=", data: "+t.slice(0,40).toString("hex"),c}}};a(K$,"getTimestamp");a(D_,"handleLocalTimeForGets");Vi=[];setInterval(()=>{for(let e=0;e<Vi.length;e++){let t=Vi[e].deref();!t||t.isDone||t.isCommitted?Vi.splice(e--,1):t.notCurrent&&(t.openTimer?(t.openTimer>3&&(t.openTimer>60?(fm.error("Read transaction detected that has been open too long (over 15 minutes), ending transaction",t),t.done()):fm.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(Rm,"getUpdateRecord")});var Gc=g((Bae,hy)=>{"use strict";var Ey=ne(),W$=U(),{RecordEncoder:Q$}=(xc(),ie(fy)),vae=require("fs");Ey.initSync();var z$=Ey.get(W$.CONFIG_PARAMS.STORAGE_CACHING)!==!1,Am=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=z$&&{validated:!0},this.randomAccessStructure=!0,this.freezeData=!0,this.encoder={Encoder:Q$})}};hy.exports=Am});var Fc=g((xae,my)=>{"use strict";var Fr=ne(),cn=U();Fr.initSync();var L_=class{static{a(this,"OpenEnvironmentObject")}constructor(t,r=!1){this.path=t,this.mapSize=1073741824,this.maxDbs=1e4,this.maxReaders=2048,this.sharedStructuresKey=Symbol.for("structures"),this.readOnly=r,this.trackMetrics=!0,this.eventTurnBatching=!1,this.noSync=Fr.get(cn.CONFIG_PARAMS.STORAGE_WRITEASYNC)===!0||Fr.get(cn.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="true"||Fr.get(cn.CONFIG_PARAMS.STORAGE_WRITEASYNC)==="TRUE",Fr.get(cn.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)!==void 0&&(this.overlappingSync=Fr.get(cn.CONFIG_PARAMS.STORAGE_OVERLAPPINGSYNC)),Fr.get(cn.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)&&(this.maxFreeSpaceToLoad=Fr.get(cn.CONFIG_PARAMS.STORAGE_MAXFREESPACETOLOAD)),Fr.get(cn.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)&&(this.maxFreeSpaceToRetain=Fr.get(cn.CONFIG_PARAMS.STORAGE_MAXFREESPACETORETAIN)),Fr.get(cn.CONFIG_PARAMS.STORAGE_PAGESIZE)&&(this.pageSize=Fr.get(cn.CONFIG_PARAMS.STORAGE_PAGESIZE)),this.noReadAhead=Fr.get(cn.CONFIG_PARAMS.STORAGE_NOREADAHEAD)}};my.exports=L_;L_.MAX_DBS=1e4});var We=g((Fae,Ny)=>{"use strict";var bm=require("lmdb"),Cn=require("fs-extra"),qr=require("path"),M_=xr(),Ty=K(),pr=vr().LMDB_ERRORS_ENUM,P_=ly(),ym=Gc(),gy=Fc(),ri=dt(),py=U(),{table:J$,resetDatabases:X$}=(Ae(),ie(ke)),Sy=ne(),Dn=ri.INTERNAL_DBIS_NAME,Ry=ri.DBI_DEFINITION_NAME,j$="data.mdb",Z$="lock.mdb",qc=".mdb",e1="-lock",Om=class{static{a(this,"TransactionCursor")}constructor(t,r,n=!1){this.dbi=ln(t,r),this.key_type=this.dbi[ri.DBI_DEFINITION_NAME].key_type,this.is_hash_attribute=this.dbi[ri.DBI_DEFINITION_NAME].is_hash_attribute,this.txn=t.beginTxn({readOnly:n===!1}),this.cursor=new bm.Cursor(this.txn,this.dbi)}close(){this.cursor.close(),this.txn.abort()}commit(){this.cursor.close(),this.txn.commit()}};function U_(e,t){if(e===void 0)throw new Error(pr.BASE_PATH_REQUIRED);if(t===void 0)throw new Error(pr.ENV_NAME_REQUIRED)}a(U_,"pathEnvNameValidation");async function Nm(e,t,r=!0){try{await Cn.access(e)}catch(n){throw n.code==="ENOENT"?new Error(pr.INVALID_BASE_PATH):n}try{let n=qr.join(e,t+qc);return await Cn.access(n,Cn.constants.R_OK|Cn.constants.F_OK),n}catch(n){if(n.code==="ENOENT")if(r)try{return await Cn.access(qr.join(e,t,j$),Cn.constants.R_OK|Cn.constants.F_OK),qr.join(e,t)}catch(s){if(s.code==="ENOENT")throw new Error(pr.INVALID_ENVIRONMENT)}else throw new Error(pr.INVALID_ENVIRONMENT);throw n}}a(Nm,"validateEnvironmentPath");function v_(e,t){if(M_.validateEnv(e),t===void 0)throw new Error(pr.DBI_NAME_REQUIRED)}a(v_,"validateEnvDBIName");async function t1(e,t,r=!1,n=!1){U_(e,t);let s=qr.basename(e);t=t.toString();let i=Sy.get(py.CONFIG_PARAMS.DATABASES);i||Sy.setProperty(py.CONFIG_PARAMS.DATABASES,i={}),i[s]||(i[s]={}),i[s].path=e;try{return await Nm(e,t,n),Ay(e,t,r)}catch(o){if(o.message===pr.INVALID_ENVIRONMENT){let c=qr.join(e,t);await Cn.mkdirp(n?c:e);let l=new gy(n?c:c+qc,!1),_=bm.open(l);_.dbis=Object.create(null);let u=new ym(!1);_.openDB(Dn,u),global.lmdb_map===void 0&&(global.lmdb_map=Object.create(null));let d=Im(e,t,r);return _[ri.ENVIRONMENT_NAME_KEY]=d,global.lmdb_map[d]=_,_}throw o}}a(t1,"createEnvironment");async function r1(e,t,r,n=!0){U_(e,t),t=t.toString();let s=qr.join(e,t);return J$({table:t,database:qr.parse(e).name,path:s,attributes:[{name:"id",isPrimaryKey:!0}]})}a(r1,"copyEnvironment");async function Ay(e,t,r=!1){U_(e,t),t=t.toString();let n=Im(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 Nm(e,t),i=qr.join(e,t+qc),o=s!=i,c=new gy(s,o),l=bm.open(c);l.dbis=Object.create(null);let _=by(l);for(let u=0;u<_.length;u++)ln(l,_[u]);return l[ri.ENVIRONMENT_NAME_KEY]=n,global.lmdb_map[n]=l,l}a(Ay,"openEnvironment");async function n1(e,t,r=!1){U_(e,t),t=t.toString();let n=qr.join(e,t+qc),s=await Nm(e,t);if(global.lmdb_map!==void 0){let i=Im(e,t,r);if(global.lmdb_map[i]){let o=global.lmdb_map[i];await Oy(o),delete global.lmdb_map[i]}}await Cn.remove(s),await Cn.remove(s===n?s+e1:qr.join(qr.dirname(s),Z$))}a(n1,"deleteEnvironment");async function Oy(e){M_.validateEnv(e);let t=e[ri.ENVIRONMENT_NAME_KEY];await e.close(),t!==void 0&&global.lmdb_map!==void 0&&delete global.lmdb_map[t]}a(Oy,"closeEnvironment");function Im(e,t,r=!1){let s=`${qr.basename(e)}.${t}`;return r===!0&&(s=`txn.${s}`),s}a(Im,"getCachedEnvironmentName");function s1(e){M_.validateEnv(e);let t=Object.create(null),r=ln(e,Dn);for(let{key:n,value:s}of r.getRange({start:!1}))if(n!==Dn)try{t[n]=Object.assign(new P_,s)}catch{Ty.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return t}a(s1,"listDBIDefinitions");function by(e){M_.validateEnv(e);let t=[],r=ln(e,Dn);for(let{key:n}of r.getRange({start:!1}))n!==Dn&&t.push(n);return t}a(by,"listDBIs");function i1(e,t){let n=ln(e,Dn).getEntry(t),s=new P_;if(n!==void 0){try{s=Object.assign(s,n.value)}catch{Ty.warn(`an internal error occurred: unable to parse DBI Definition for ${n}`)}return s}}a(i1,"getDBIDefinition");function yy(e,t,r,n=!r){if(v_(e,t),t=t.toString(),t===Dn)throw new Error(pr.CANNOT_CREATE_INTERNAL_DBIS_NAME);try{return ln(e,t)}catch(s){if(s.message===pr.DBI_DOES_NOT_EXIST){let i=new ym(r,n===!0),o=e.openDB(t,i),c=new P_(r===!0,n);return o[Ry]=c,ln(e,Dn).putSync(t,c),e.dbis[t]=o,o}throw s}}a(yy,"createDBI");function ln(e,t){if(v_(e,t),t=t.toString(),e.dbis[t]!==void 0)return e.dbis[t];let r;if(t!==Dn?r=i1(e,t):r=new P_,r===void 0)throw new Error(pr.DBI_DOES_NOT_EXIST);let n;try{let s=new ym(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(pr.DBI_DOES_NOT_EXIST):s}return n[Ry]=r,e.dbis[t]=n,n}a(ln,"openDBI");function o1(e,t){v_(e,t),t=t.toString();let r=ln(e,t),n=r.getStats();return r[ri.DBI_DEFINITION_NAME].is_hash_attribute&&n.entryCount>0&&n.entryCount--,n}a(o1,"statDBI");async function a1(e,t){try{let r=qr.join(e,t+qc);return(await Cn.stat(r)).size}catch{throw new Error(pr.INVALID_ENVIRONMENT)}}a(a1,"environmentDataSize");function c1(e,t){if(v_(e,t),t=t.toString(),t===Dn)throw new Error(pr.CANNOT_DROP_INTERNAL_DBIS_NAME);ln(e,t).dropSync(),e.dbis!==void 0&&delete e.dbis[t],ln(e,Dn).removeSync(t)}a(c1,"dropDBI");function l1(e,t,r){let n;for(let s=0;s<r.length;s++){let i=r[s];if(!e.dbis[i])try{ln(e,i)}catch(o){if(o.message===pr.DBI_DOES_NOT_EXIST)yy(e,i,i!==t,i===t),n=!0;else throw o}}n&&X$()}a(l1,"initializeDBIs");Ny.exports={openDBI:ln,openEnvironment:Ay,createEnvironment:t1,listDBIs:by,listDBIDefinitions:s1,createDBI:yy,dropDBI:c1,statDBI:o1,deleteEnvironment:n1,initializeDBIs:l1,TransactionCursor:Om,environmentDataSize:a1,copyEnvironment:r1,closeEnvironment:Oy}});var wy=g((kae,Iy)=>{"use strict";var wm=class{static{a(this,"InsertRecordsResponseObject")}constructor(t=[],r=[],n=void 0){this.written_hashes=t,this.skipped_hashes=r,this.txn_time=n}};Iy.exports=wm});var Dy=g(($ae,Cy)=>{"use strict";var Cm=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}};Cy.exports=Cm});var My=g((Kae,Ly)=>{"use strict";var Dm=class{static{a(this,"UpsertRecordsResponseObject")}constructor(t=[],r=void 0,n=[]){this.written_hashes=t,this.txn_time=r,this.original_records=n}};Ly.exports=Dm});var Yo=g((Xae,vy)=>{"use strict";var u1=We(),_1=wy(),d1=Dy(),f1=My(),Jn=xr(),kc=vr().LMDB_ERRORS_ENUM,E1=dt(),Rs=U(),h1=J(),m1=require("uuid"),Qae=require("lmdb"),{handleHDBError:p1,hdb_errors:S1}=se(),{OVERFLOW_MARKER:zae,MAX_SEARCH_KEY_LENGTH:Jae}=E1,Py=ne();Py.initSync();var B_=Py.get(Rs.CONFIG_PARAMS.STORAGE_PREFETCHWRITES),Lm=Rs.TIME_STAMP_NAMES_ENUM.CREATED_TIME,$i=Rs.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function T1(e,t,r,n,s=Jn.getNextMonotonicTime()){vm(e,t,r,n),Mm(e,t,r);let i=new _1,o=[],c=[];for(let l=0;l<n.length;l++){let _=n[l];Uy(_,!0,s);let u=g1(e,t,r,_),d=_[t];o.push(u),c.push(d)}return Pm(o,c,n,i,s)}a(T1,"insertRecords");function g1(e,t,r,n){let s=n[t];return e.dbis[t].ifNoExists(s,()=>{for(let i=0;i<r.length;i++){let o=r[i];if(o===t||n.hasOwnProperty(o)===!1)continue;let c=n[o];if(typeof c=="function"){let u=c([[{}]]);Array.isArray(u)&&(c=u[0][Rs.FUNC_VAL],n[o]=c)}let l=Jn.getIndexedValues(c),_=e.dbis[o];if(l){B_&&_.prefetch(l.map(u=>({key:u,value:s})),H_);for(let u=0,d=l.length;u<d;u++)_.put(l[u],s)}}B_&&e.dbis[t].prefetch([s],H_),e.dbis[t].put(s,n,n[$i])})}a(g1,"insertRecord");function R1(e,t=[]){let r=0;for(let n=0;n<t.length;n++){let s=t[n];e.splice(s-r,1),r++}}a(R1,"removeSkippedRecords");function Uy(e,t,r){let n=r>0;(n||!Number.isInteger(e[$i]))&&(e[$i]=r||(r=Jn.getNextMonotonicTime())),t===!0?(n||!Number.isInteger(e[Lm]))&&(e[Lm]=r||Jn.getNextMonotonicTime()):delete e[Lm]}a(Uy,"setTimestamps");function Mm(e,t,r){r.indexOf(Rs.TIME_STAMP_NAMES_ENUM.CREATED_TIME)<0&&r.push(Rs.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.indexOf(Rs.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)<0&&r.push(Rs.TIME_STAMP_NAMES_ENUM.UPDATED_TIME),u1.initializeDBIs(e,t,r)}a(Mm,"initializeTransaction");async function A1(e,t,r,n,s=Jn.getNextMonotonicTime()){vm(e,t,r,n),Mm(e,t,r);let i=new d1,o=[],c=[],l=[];for(let _=0;_<n.length;_++){let u=n[_],d=u[t],E;try{E=Um(e,t,u,d,i,!0,s)}catch{i.skipped_hashes.push(d),o.push(_);continue}c.push(E),l.push(d)}return Pm(c,l,n,i,s,o)}a(A1,"updateRecords");async function O1(e,t,r,n,s=Jn.getNextMonotonicTime()){try{vm(e,t,r,n)}catch(l){throw p1(l,l.message,S1.HTTP_STATUS_CODES.BAD_REQUEST)}Mm(e,t,r);let i=new f1,o=[],c=[];for(let l=0;l<n.length;l++){let _=n[l],u;h1.isEmpty(_[t])?(u=m1.v4(),_[t]=u):u=_[t];let d=Um(e,t,_,u,i,!1,s);o.push(d),c.push(u)}return Pm(o,c,n,i,s)}a(O1,"upsertRecords");async function Pm(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||Jn.getNextMonotonicTime(),R1(r,i),n}a(Pm,"finalizeWrite");function Um(e,t,r,n,s,i=!1,o){let c=e.dbis[t],l=c.getEntry(n),_=l?.value,u=_;if(!_){if(i)return!1;_={}}if(Uy(r,!u,o),Number.isInteger(r[$i])&&_[$i]>r[$i])return!1;u&&s.original_records.push(_);let d,E=a(()=>{for(let h in r){if(!r.hasOwnProperty(h)||h===t)continue;let p=r[h],S=e.dbis[h];if(S===void 0)continue;let T=_[h];if(typeof p=="function"){let N=p([[_]]);Array.isArray(N)&&(p=N[0][Rs.FUNC_VAL],r[h]=p)}if(p===T)continue;let A=Jn.getIndexedValues(T);if(A){B_&&S.prefetch(A.map(N=>({key:N,value:n})),H_);for(let N=0,b=A.length;N<b;N++)S.remove(A[N],n)}if(A=Jn.getIndexedValues(p),A){B_&&S.prefetch(A.map(N=>({key:N,value:n})),H_);for(let N=0,b=A.length;N<b;N++)S.put(A[N],n)}}let f=Object.assign({},_,r);c.put(n,f,f[$i])},"do_put");return l?d=c.ifVersion(n,l.version,E):d=c.ifNoExists(n,E),d.then(f=>f?!0:Um(e,t,r,n,s,i,o))}a(Um,"updateUpsertRecord");function b1(e,t,r){if(Jn.validateEnv(e),t===void 0)throw new Error(kc.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(kc.WRITE_ATTRIBUTES_REQUIRED):new Error(kc.WRITE_ATTRIBUTES_MUST_BE_ARRAY)}a(b1,"validateBasic");function vm(e,t,r,n){if(b1(e,t,r),!Array.isArray(n))throw n===void 0?new Error(kc.RECORDS_REQUIRED):new Error(kc.RECORDS_MUST_BE_ARRAY)}a(vm,"validateWrite");function H_(){}a(H_,"noop");vy.exports={insertRecords:T1,updateRecords:A1,upsertRecords:O1}});var Yi=g((Zae,y1)=>{y1.exports={hdb_table:{hash_attribute:"id",name:"hdb_table",schema:"system",residence:["*"],attributes:[{attribute:"id"},{attribute:"name"},{attribute:"hash_attribute"},{attribute:"schema"},{attribute:"residence"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_attribute:{hash_attribute:"id",name:"hdb_attribute",schema:"system",residence:["*"],attributes:[{attribute:"id"},{attribute:"schema"},{attribute:"table"},{attribute:"attribute"},{attribute:"schema_table"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_schema:{hash_attribute:"name",name:"hdb_schema",schema:"system",residence:["*"],attributes:[{attribute:"name"},{attribute:"createddate"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_user:{hash_attribute:"username",name:"hdb_user",schema:"system",residence:["*"],attributes:[{attribute:"username"},{attribute:"password"},{attribute:"role"},{attribute:"active"},{attribute:"hash"},{attribute:"refresh_token"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_role:{hash_attribute:"id",name:"hdb_role",schema:"system",attributes:[{attribute:"id"},{attribute:"role"},{attribute:"permission"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}],residence:["*"]},hdb_job:{hash_attribute:"id",name:"hdb_job",schema:"system",attributes:[{attribute:"id"},{attribute:"user"},{attribute:"type"},{attribute:"status"},{attribute:"start_datetime"},{attribute:"end_datetime"},{attribute:"message"},{attribute:"created_datetime"},{attribute:"request"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_license:{hash_attribute:"license_key",name:"hdb_license",schema:"system",attributes:[{attribute:"license_key"},{attribute:"company"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_info:{hash_attribute:"info_id",name:"hdb_info",schema:"system",attributes:[{attribute:"info_id"},{attribute:"data_version_num"},{attribute:"hdb_version_num"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_nodes:{hash_attribute:"name",name:"hdb_nodes",schema:"system",attributes:[{attribute:"name"},{attribute:"subscriptions"},{attribute:"system_info"},{attribute:"__createdtime__"},{attribute:"__updatedtime__"}]},hdb_analytics:{hash_attribute:"id",name:"hdb_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]},hdb_raw_analytics:{hash_attribute:"id",name:"hdb_raw_analytics",schema:"system",audit:!1,attributes:[{attribute:"id"},{attribute:"time"},{attribute:"metrics"}]},hdb_temp:{hash_attribute:"id",name:"hdb_temp",schema:"system",attributes:[{attribute:"id"}]},hdb_durable_session:{hash_attribute:"id",name:"hdb_durable_session",schema:"system",attributes:[{attribute:"id"}]},hdb_session_will:{hash_attribute:"id",name:"hdb_session_will",schema:"system",attributes:[{attribute:"id"}]}}});var jn=g((ece,xy)=>{"use strict";var Hy=J(),By=U(),Ko=/^[\x20-\x2E|\x30-\x5F|\x61-\x7E]*$/,Xn=require("joi"),ni={schema_format:{pattern:Ko,message:"names cannot include backticks or forward slashes"},schema_length:{minimum:1,maximum:250,tooLong:"cannot exceed 250 characters"}},N1=Xn.alternatives(Xn.string().min(1).max(ni.schema_length.maximum).pattern(Ko).messages({"string.pattern.base":"{:#label} "+ni.schema_format.message}),Xn.number(),Xn.array()).required(),I1=Xn.alternatives(Xn.string().min(1).max(ni.schema_length.maximum).pattern(Ko).messages({"string.pattern.base":"{:#label} "+ni.schema_format.message}),Xn.number()),w1=Xn.alternatives(Xn.string().min(1).max(ni.schema_length.maximum).pattern(Ko).messages({"string.pattern.base":"{:#label} "+ni.schema_format.message}),Xn.number()).required();function C1(e,t){return t?typeof t!="string"?`'${e}' must be a string`:t.length?t.length>ni.schema_length.maximum?`'${e}' maximum of 250 characters`:Ko.test(t)?"":`'${e}' has illegal characters`:`'${e}' must be at least one character`:`'${e}' is required`}a(C1,"checkValidTable");function D1(e,t){return Hy.doesSchemaExist(e)?e:t.message(`Database '${e}' does not exist`)}a(D1,"validateSchemaExists");function L1(e,t){let r=t.state.ancestors[0].schema;return Hy.doesTableExist(r,e)?e:t.message(`Table '${e}' does not exist`)}a(L1,"validateTableExists");function M1(e,t){return e.toLowerCase()===By.SYSTEM_SCHEMA_NAME?t.message(`'subscriptions[${t.state.path[1]}]' invalid database name, '${By.SYSTEM_SCHEMA_NAME}' name is reserved`):e}a(M1,"validateSchemaName");xy.exports={common_validators:ni,schema_regex:Ko,hdb_schema_table:N1,validateSchemaExists:D1,validateTableExists:L1,validateSchemaName:M1,checkValidTable:C1,hdb_database:I1,hdb_table:w1}});var x_=g((rce,Gy)=>{var{common_validators:Zn}=jn(),$c=st(),Vc="is required",Tt={database:{presence:!1,format:Zn.schema_format,length:Zn.schema_length},schema:{presence:!1,format:Zn.schema_format,length:Zn.schema_length},table:{presence:!0,format:Zn.schema_format,length:Zn.schema_length},attribute:{presence:!0,format:Zn.schema_format,length:Zn.schema_length},hash_attribute:{presence:!0,format:Zn.schema_format,length:Zn.schema_length}};function Yc(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(Yc,"makeAttributesStrings");function P1(e){return e=Yc(e),Tt.table.presence=!1,Tt.attribute.presence=!1,Tt.hash_attribute.presence=!1,$c.validateObject(e,Tt)}a(P1,"schema_object");function U1(e){return e=Yc(e),Tt.table.presence={message:Vc},Tt.attribute.presence=!1,Tt.hash_attribute.presence=!1,$c.validateObject(e,Tt)}a(U1,"table_object");function v1(e){return e=Yc(e),Tt.table.presence={message:Vc},Tt.attribute.presence=!1,$c.validateObject(e,Tt)}a(v1,"create_table_object");function B1(e){return e=Yc(e),Tt.table.presence={message:Vc},Tt.attribute.presence={message:Vc},Tt.hash_attribute.presence=!1,$c.validateObject(e,Tt)}a(B1,"attribute_object");function H1(e){return e=Yc(e),Tt.table.presence={message:Vc},Tt.attribute.presence=!1,Tt.hash_attribute.presence=!1,$c.validateObject(e,Tt)}a(H1,"describe_table");function x1(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(x1,"validateTableResidence");Gy.exports={schema_object:P1,create_table_object:v1,table_object:U1,attribute_object:B1,describe_table:H1,validateTableResidence:x1}});var qy=g((sce,Fy)=>{"use strict";var G1=require("uuid"),Bm=class{static{a(this,"CreateAttributeObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.attribute=n,this.id=s||G1.v4(),this.schema_table=`${this.schema}.${this.table}`}};Fy.exports=Bm});var G_=g((oce,ky)=>{"use strict";var F1=qy(),Hm=class extends F1{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}};ky.exports=Hm});var $y=g((cce,Vy)=>{"use strict";Vy.exports=k1;var q1="inserted";function k1(e,t,r,n){let s={message:`${e} ${t.length} of ${r.records.length} records`,skipped_hashes:n};return e===q1?(s.inserted_hashes=t,s):(s.update_hashes=t,s)}a(k1,"returnObject")});var F_=g((uce,zy)=>{"use strict";var V1=U(),xm=We(),$1=Yo(),{getSystemSchemaPath:Y1,getSchemaPath:K1}=ze(),W1=Yi(),Q1=x_(),z1=G_(),J1=$y(),{handleHDBError:Yy,hdb_errors:Wy}=se(),Ky=J(),{HTTP_STATUS_CODES:X1}=Wy,Gm=W1.hdb_attribute,Qy=[];for(let e=0;e<Gm.attributes.length;e++)Qy.push(Gm.attributes[e].attribute);var j1="inserted";zy.exports=Z1;async function Z1(e){let t=Q1.attribute_object(e);if(t)throw Yy(new Error,t.message,Wy.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=!e.skip_table_check&&Ky.checkGlobalSchemaTable(e.schema,e.table);if(r)throw Yy(new Error,r,X1.NOT_FOUND);e.is_hash_attribute=e.is_hash_attribute=="true",e.dup_sort=Ky.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 z1(e.schema,e.table,e.attribute,e.id);try{let i=await xm.openEnvironment(K1(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}`);xm.createDBI(i,e.attribute,e.dup_sort,e.is_hash_attribute);let o=await xm.openEnvironment(Y1(),V1.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),{written_hashes:c,skipped_hashes:l}=await $1.insertRecords(o,Gm.hash_attribute,Qy,[s]);return J1(j1,c,{records:[s]},l)}catch(i){throw i}}a(Z1,"lmdbCreateAttribute")});var qm=g((dce,Xy)=>{var{hdb_table:eY,hdb_database:Jy}=jn(),tY=st(),Fm=require("joi"),rY={undefined:"undefined",null:"null"},nY=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||rY[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"),sY=Fm.object({database:Jy,schema:Jy,table:eY,records:Fm.array().items(Fm.object().custom(nY)).required()});Xy.exports=function(e){return tY.validateBySchema(e,sY)}});var Kc=g((hce,Zy)=>{"use strict";var As=J(),jy=K(),Ece=qm(),{getDatabases:iY}=(Ae(),ie(ke)),{ClientError:Ki}=se();Zy.exports=oY;function oY(e){if(As.isEmpty(e))throw new Ki("invalid update parameters defined.");if(As.isEmptyOrZeroLength(e.schema))throw new Ki("invalid schema specified.");if(As.isEmptyOrZeroLength(e.table))throw new Ki("invalid table specified.");if(!Array.isArray(e.records))throw new Ki("records must be an array");let t=iY()[e.schema]?.[e.table];if(As.isEmpty(t))throw new Ki(`could not retrieve schema:${e.schema} and table ${e.table}`);let r=t.primaryKey,n=new Set,s={},i=!1;return e.operation==="update"&&(i=!0),e.records.forEach(o=>{if(i&&As.isEmptyOrZeroLength(o[r]))throw jy.error("a valid hash attribute must be provided with update record:",o),new Ki("a valid hash attribute must be provided with update record, check log for more info");if(!As.isEmptyOrZeroLength(o[r])&&(o[r]==="null"||o[r]==="undefined"))throw jy.error(`a valid hash value must be provided with ${e.operation} record:`,o),new Ki(`Invalid hash value: '${o[r]}' is not a valid hash attribute value, check log for more info`);!As.isEmpty(o[r])&&o[r]!==""&&n.has(As.autoCast(o[r]))&&(o.skip=!0),n.add(As.autoCast(o[r]));for(let c in o)s[c]=1}),s[r]=1,{schema_table:t,hashes:Array.from(n),attributes:Object.keys(s)}}a(oY,"insertUpdateValidate")});var tN=g((pce,eN)=>{"use strict";var km=class{static{a(this,"ITCEventObject")}constructor(t,r){this.type=t,this.message=r}};eN.exports=km});var sN=g((Tce,nN)=>{"use strict";var Vm=We(),aY=K(),rN=vr().LMDB_ERRORS_ENUM;nN.exports=cY;async function cY(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 Vm.closeEnvironment(global.lmdb_map[o])}catch(c){if(c.message!==rN.ENV_REQUIRED)throw c}}break;case"drop_table":let n=`${e.schema}.${e.table}`,s=`txn.${n}`;try{await Vm.closeEnvironment(global.lmdb_map[n]),await Vm.closeEnvironment(global.lmdb_map[s])}catch(i){if(i.message!==rN.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){aY.error(t)}}a(cY,"cleanLMDBMap")});var Os=g((Rce,cN)=>{"use strict";var Wc=require("crypto"),lY=ne(),{CONFIG_PARAMS:uY}=U(),oN="aes-256-cbc",_Y=32,dY=16,$m=64,aN=32,fY=$m+aN,iN=new Map;cN.exports={encrypt:EY,decrypt:hY,createNatsTableStreamName:mY};function EY(e){let t=Wc.randomBytes(_Y),r=Wc.randomBytes(dY),n=Wc.createCipheriv(oN,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(EY,"encrypt");function hY(e){let t=e.substr(0,$m),r=e.substr($m,aN),n=e.substr(fY,e.length),s=Buffer.from(r,"hex"),i=Buffer.from(n,"hex"),o=Wc.createDecipheriv(oN,Buffer.from(t,"hex"),s),c=o.update(i);return c=Buffer.concat([c,o.final()]),c.toString()}a(hY,"decrypt");function mY(e,t){let r=lY.get(uY.CLUSTERING_DATABASELEVEL)?e:`${e}.${t}`,n=iN.get(r);return n||(n=Wc.createHash("md5").update(r).digest("hex"),iN.set(r,n)),n}a(mY,"createNatsTableStreamName")});var si=g((bce,uN)=>{"use strict";var Oce=kr(),Qc=K(),lN=x_(),pY=Os(),q_=J(),{handleHDBError:k_,hdb_errors:SY}=se(),{HDB_ERROR_MSGS:V_,HTTP_STATUS_CODES:Ym}=SY,TY=ne();TY.initSync();var{getDatabases:Km}=(Ae(),ie(ke)),gY=require("fs-extra");uN.exports={describeAll:RY,describeTable:$_,describeSchema:AY};async function RY(e={}){try{let t=q_.isEmptyOrZeroLength(e),r=!!e.bypass_auth,n,s;!t&&!r&&(n=e.hdb_user?.role?.permission,s=n?.super_user||n?.cluster_user);let i=Km(),o={},c={},l=[],_=e?.exact_count;for(let d in i){o[d]=!0,!t&&!s&&!r&&(c[d]=e.hdb_user?.role?.permission[d]?.describe);let E=i[d];for(let f in E)try{let h;if(t||s||r)h=await $_({schema:d,table:f,exact_count:_});else if(n&&n[d].describe&&n[d].tables[f].describe){let p=n[d].tables[f].attribute_permissions;h=await $_({schema:d,table:f,exact_count:_},p)}h&&l.push(h)}catch(h){Qc.error(h)}}let u={};for(let d in l)t||s||r?(u[l[d].schema]==null&&(u[l[d].schema]={}),u[l[d].schema][l[d].name]=l[d],o[l[d].schema]&&delete o[l[d].schema]):c[l[d].schema]&&(u[l[d].schema]==null&&(u[l[d].schema]={}),u[l[d].schema][l[d].name]=l[d],o[l[d].schema]&&delete o[l[d].schema]);for(let d in o)t||s||r?u[d]={}:c[d]&&(u[d]={});return u}catch(t){return Qc.error("Got an error in describeAll"),Qc.error(t),k_(new Error,V_.DESCRIBE_ALL_ERR)}}a(RY,"describeAll");async function $_(e,t){q_.transformReq(e);let{schema:r,table:n}=e;r=r?.toString(),n=n?.toString();let s=t;e.hdb_user&&!e.hdb_user?.role?.permission?.super_user&&(s=e.hdb_user?.role?.permission[r]?.tables[n]?.attribute_permissions);let i=lN.describe_table(e);if(i)throw i;let c=Km()[r];if(!c)throw k_(new Error,V_.SCHEMA_NOT_FOUND(e.schema),Ym.NOT_FOUND);let l=c[n];if(!l)throw k_(new Error,V_.TABLE_NOT_FOUND(e.schema,e.table),Ym.NOT_FOUND);function _(f){u.push(Object.assign({},{attribute:f.attribute,type:f.type,elements:f.elements?.type,indexed:f.indexed,is_primary_key:f.isPrimaryKey,assigned_created_time:f.assignCreatedTime,assigned_updated_time:f.assignUpdatedTime,nullable:f.nullable,properties:f.properties?f.properties.map(h=>({type:h.type,name:h.name})):void 0}))}a(_,"pushAtt");let u=[];if(s){let f={};s.forEach(h=>{h.describe&&(f[h.attribute_name]=!0)}),l.attributes.forEach(h=>{f[h.name]&&_(h)})}else l.attributes?.forEach(f=>_(f));let d;try{d=(await gY.stat(l.primaryStore.env.path)).size}catch(f){Qc.warn("unable to get database size",f)}let E={schema:r,name:l.tableName,hash_attribute:l.attributes.find(f=>f.isPrimaryKey||f.is_hash_attribute)?.name,audit:l.audit,schema_defined:l.schemaDefined,attributes:u,db_size:d};E.clustering_stream_name=pY.createNatsTableStreamName(E.schema,E.name);try{let f=l.getRecordCount({exactCount:e.exact_count==="true"});E.record_count=f.recordCount,E.estimated_record_range=f.estimatedRange;let h=l.auditStore;if(h)for(let p of h.getKeys({reverse:!0,limit:1}))E.last_updated_record=p[0];if(!E.last_updated_record&&l.indices.__updatedtime__)for(let p of l.indices.__updatedtime__.getKeys({reverse:!0,limit:1}))E.last_updated_record=p}catch(f){Qc.warn(`unable to stat table dbi due to ${f}`)}return E}a($_,"descTable");async function AY(e){q_.transformReq(e);let t=lN.schema_object(e);if(t)throw t;let r;e.hdb_user&&!e.hdb_user?.role?.permission?.super_user&&(r=e.hdb_user?.role?.permission[e.schema]);let n=e.schema.toString(),i=Km()[n];if(!i)throw k_(new Error,V_.SCHEMA_NOT_FOUND(e.schema),Ym.NOT_FOUND);let o={};for(let c in i){let l;if(r&&r.tables[c]&&(l=r.tables[c]),q_.isEmpty(l)||l.describe){let _=await $_({schema:e.schema,table:c,exact_count:e.exact_count},l?l.attribute_permissions:null);_&&(o[_.name]=_)}}return o}a(AY,"describeSchema")});var ii=g((wce,hN)=>{var OY=Yi(),{callbackify:dN,promisify:bY}=require("util"),{getDatabases:fN}=(Ae(),ie(ke));hN.exports={setSchemaDataToGlobal:_N,getTableSchema:yY,getSystemSchema:NY,setSchemaDataToGlobalAsync:bY(_N)};var EN=si(),Nce=dN(EN.describeAll),Ice=dN(EN.describeTable);function _N(e){global.hdb_schema=fN(),e&&e()}a(_N,"setSchemaDataToGlobal");function yY(e,t,r){let n=fN()[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(yY,"getTableSchema");function NY(){return OY}a(NY,"getSystemSchema")});var un=g((Dce,TN)=>{"use strict";var K_=qm(),Kt=J(),IY=require("util"),W_=Ln(),wY=ii(),mN=K(),{handleHDBError:Wi,hdb_errors:CY}=se(),{HTTP_STATUS_CODES:Qi}=CY,DY=IY.promisify(wY.getTableSchema),LY="updated",pN="inserted",SN="upserted";TN.exports={insert:PY,update:UY,upsert:vY,validation:MY,flush:BY};async function MY(e){if(Kt.isEmpty(e))throw new Error("invalid update parameters defined.");if(Kt.isEmptyOrZeroLength(e.schema))throw new Error("invalid database specified.");if(Kt.isEmptyOrZeroLength(e.table))throw new Error("invalid table specified.");let t=await DY(e.schema,e.table),r=K_(e);if(r)throw r;if(!Array.isArray(e.records))throw new Error("records must be an array");let n=t.hash_attribute,s=new Set,i={},o=!1;return e.operation==="update"&&(o=!0),e.records.forEach(c=>{if(o&&Kt.isEmptyOrZeroLength(c[n]))throw mN.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(!Kt.isEmptyOrZeroLength(c[n])&&(c[n]==="null"||c[n]==="undefined"))throw mN.error(`a valid hash value must be provided with ${e.operation} record:`,c),new Error(`"${c[n]}" is not a valid hash attribute value`);!Kt.isEmpty(c[n])&&c[n]!==""&&s.has(Kt.autoCast(c[n]))&&(c.skip=!0),s.add(Kt.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(MY,"validation");async function PY(e){if(e.operation!=="insert")throw new Error("invalid operation, must be insert");let t=K_(e);if(t)throw Wi(new Error,t.message,Qi.BAD_REQUEST);Kt.transformReq(e);let r=Kt.checkSchemaTableExist(e.schema,e.table);if(r)throw Wi(new Error,r,Qi.BAD_REQUEST);let n=await W_.createRecords(e);return Y_(pN,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time)}a(PY,"insertData");async function UY(e){if(e.operation!=="update")throw new Error("invalid operation, must be update");let t=K_(e);if(t)throw Wi(new Error,t.message,Qi.BAD_REQUEST);Kt.transformReq(e);let r=Kt.checkSchemaTableExist(e.schema,e.table);if(r)throw Wi(new Error,r,Qi.BAD_REQUEST);let n=await W_.updateRecords(e);return Kt.isEmpty(n.existing_rows)?Y_(LY,n.written_hashes,e,n.skipped_hashes,n.new_attributes,n.txn_time):Y_(n.update_action,[],e,n.hashes,void 0,n.txn_time)}a(UY,"updateData");async function vY(e){if(e.operation!=="upsert")throw Wi(new Error,"invalid operation, must be upsert",Qi.INTERNAL_SERVER_ERROR);let t=K_(e);if(t)throw Wi(new Error,t.message,Qi.BAD_REQUEST);Kt.transformReq(e);let r=Kt.checkSchemaTableExist(e.schema,e.table);if(r)throw Wi(new Error,r,Qi.BAD_REQUEST);let n=await W_.upsertRecords(e);return Y_(SN,n.written_hashes,e,[],n.new_attributes,n.txn_time)}a(vY,"upsertData");function Y_(e,t,r,n,s,i){let o={message:`${e} ${t.length} of ${t.length+n.length} records`,new_attributes:s,txn_time:i};return e===pN?(o.inserted_hashes=t,o.skipped_hashes=n,o):e===SN?(o.upserted_hashes=t,o):(o.update_hashes=t,o.skipped_hashes=n,o)}a(Y_,"returnObject");function BY(e){return Kt.transformReq(e),W_.flush(e.schema,e.table)}a(BY,"flush")});var Qm=g((Mce,AN)=>{var HY=st(),Wm=require("joi"),{hdb_table:xY,hdb_database:gN}=jn(),RN={schema:gN,database:gN,table:xY},GY={date:Wm.date().iso().required()},FY={timestamp:Wm.date().timestamp().required().messages({"date.format":"'timestamp' is invalid"})};AN.exports=function(e,t){let r=t==="timestamp"?{...RN,...FY}:{...RN,...GY},n=Wm.object(r);return HY.validateBySchema(e,n)}});var yN=g((Pce,bN)=>{var qY=st(),zm=require("joi"),{hdb_table:kY,hdb_database:ON}=jn(),VY=zm.object({schema:ON,database:ON,table:kY,hash_values:zm.array().required(),ids:zm.array()});bN.exports=function(e){return qY.validateBySchema(e,VY)}});var IN=g((Uce,NN)=>{"use strict";var Jm=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}},Xm=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}},jm=class{static{a(this,"DeleteResponseObject")}constructor(){this.message=void 0,this.deleted_hashes=[],this.skipped_hashes=[]}};NN.exports={InsertObject:Jm,NoSQLSeachObject:Xm,DeleteResponseObject:jm}});var Xi=g((Bce,MN)=>{"use strict";var CN=Qm(),$Y=yN(),zi=J(),wN=require("moment"),DN=K(),{promisify:YY,callbackify:KY}=require("util"),Ji=U(),WY=ii(),Zm=YY(WY.getTableSchema),ep=Ln(),{DeleteResponseObject:QY}=IN(),{handleHDBError:oi,hdb_errors:zY}=se(),{HDB_ERROR_MSGS:Q_,HTTP_STATUS_CODES:ai}=zY,JY="records successfully deleted",XY=KY(LN);MN.exports={delete:XY,deleteRecord:LN,deleteFilesBefore:jY,deleteAuditLogsBefore:ZY};async function jY(e){let t=CN(e,"date");if(t)throw oi(t,t.message,ai.BAD_REQUEST,void 0,void 0,!0);if(zi.transformReq(e),!wN(e.date,wN.ISO_8601).isValid())throw oi(new Error,Q_.INVALID_DATE,ai.BAD_REQUEST,Ji.LOG_LEVELS.ERROR,Q_.INVALID_DATE,!0);let n=zi.checkSchemaTableExist(e.schema,e.table);if(n)throw oi(new Error,n,ai.NOT_FOUND,Ji.LOG_LEVELS.ERROR,n,!0);let s=await ep.deleteRecordsBefore(e);if(await Zm(e.schema,e.table),DN.info(`Finished deleting files before ${e.date}`),s&&s.message)return s.message}a(jY,"deleteFilesBefore");async function ZY(e){let t=CN(e,"timestamp");if(t)throw oi(t,t.message,ai.BAD_REQUEST,void 0,void 0,!0);if(zi.transformReq(e),isNaN(e.timestamp))throw oi(new Error,Q_.INVALID_VALUE("Timestamp"),ai.BAD_REQUEST,Ji.LOG_LEVELS.ERROR,Q_.INVALID_VALUE("Timestamp"),!0);let r=zi.checkSchemaTableExist(e.schema,e.table);if(r)throw oi(new Error,r,ai.NOT_FOUND,Ji.LOG_LEVELS.ERROR,r,!0);let n=await ep.deleteAuditLogsBefore(e);return await Zm(e.schema,e.table),DN.info(`Finished deleting audit logs before ${e.timestamp}`),n}a(ZY,"deleteAuditLogsBefore");async function LN(e){e.ids&&(e.hash_values=e.ids);let t=$Y(e);if(t)throw oi(t,t.message,ai.BAD_REQUEST,void 0,void 0,!0);zi.transformReq(e);let r=zi.checkSchemaTableExist(e.schema,e.table);if(r)throw oi(new Error,r,ai.NOT_FOUND,Ji.LOG_LEVELS.ERROR,r,!0);try{await Zm(e.schema,e.table);let n=await ep.deleteRecords(e);return zi.isEmptyOrZeroLength(n.message)&&(n.message=`${n.deleted_hashes.length} of ${e.hash_values.length} ${JY}`),n}catch(n){if(n.message===Ji.SEARCH_NOT_FOUND_MESSAGE){let s=new QY;return s.message=Ji.SEARCH_NOT_FOUND_MESSAGE,s.skipped_hashes=e.hash_values.length,s.deleted_hashes=0,s}throw n}}a(LN,"deleteRecord")});var z_=g((xce,vN)=>{var eK=require("crypto"),PN=9;function tK(e){let t=nK(PN),r=UN(e+t);return t+r}a(tK,"createHash");function rK(e,t){let r=e?.substr(0,PN),n=r+UN(t+r);return e===n}a(rK,"validateHash");function nK(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(nK,"generateSalt");function UN(e){return eK.createHash("md5").update(e).digest("hex")}a(UN,"md5");vN.exports={hash:tK,validate:rK}});var HN=g((Fce,BN)=>{var tp=st(),er={username:{presence:!0,format:"[\\w\\-\\_]+",exclusion:{within:["system"],message:"You cannot create tables within the system schema"}},password:{presence:!0},role:{presence:!0,format:"[\\w\\-\\_]+"},active:{presence:!0,inclusion:{within:[!0,!1],message:"must be a boolean"}}};function sK(e){return er.password.presence=!0,er.username.presence=!0,er.role.presence=!0,er.active.presence=!0,tp.validateObject(e,er)}a(sK,"addUserValidation");function iK(e){return er.password.presence=!1,er.username.presence=!0,er.role.presence=!1,er.active.presence=!1,tp.validateObject(e,er)}a(iK,"alterUserValidation");function oK(e){return er.password.presence=!1,er.username.presence=!0,er.role.presence=!1,er.active.presence=!1,tp.validateObject(e,er)}a(oK,"dropUserValidation");BN.exports={addUserValidation:sK,alterUserValidation:iK,dropUserValidation:oK}});var ct=g((Vce,GN)=>{"use strict";var{platform:kce}=require("os"),aK="nats-server.zip",rp="nats-server",cK=process.platform==="win32"?`${rp}.exe`:rp,lK=/^[^\s.,*>]+$/,xN="__request__",uK=a(e=>`${e}.${xN}`,"REQUEST_SUBJECT"),_K={NATS_MSG_ID:"Nats-Msg-Id",ORIGIN:"origin",TRANSACTED_NODES:"transacted_nodes"},dK={HUB_SERVER:"hub.json",LEAF_SERVER:"leaf.json"},fK={HUB:"hub.pid",LEAF:"leaf.pid"},EK={HUB:"-hub",LEAF:"-leaf",ADMIN:"-admin"},hK={SUCCESS:"success",ERROR:"error"},mK={OPEN:"open",CLOSED:"closed",NO_RESPONDERS:"NoResponders",TIMEOUT:"Timeout"},pK={TXN:"txn",MSGID:"msgid"},Wo={ERR:"error",WRN:"warn",INF:"info",DBG:"debug",TRC:"trace"},SK={[Wo.ERR]:1,[Wo.WRN]:2,[Wo.INF]:3,[Wo.DBG]:4,[Wo.TRC]:5},TK={debug:"-D",trace:"-DVV"};GN.exports={NATS_SERVER_ZIP:aK,NATS_SERVER_NAME:rp,NATS_BINARY_NAME:cK,PID_FILES:fK,NATS_CONFIG_FILES:dK,SERVER_SUFFIX:EK,NATS_TERM_CONSTRAINTS_RX:lK,REQUEST_SUFFIX:xN,UPDATE_REMOTE_RESPONSE_STATUSES:hK,CLUSTER_STATUS_STATUSES:mK,REQUEST_SUBJECT:uK,SUBJECT_PREFIXES:pK,MSG_HEADERS:_K,LOG_LEVELS:Wo,LOG_LEVEL_FLAGS:TK,LOG_LEVEL_HIERARCHY:SK}});var qN=g((Yce,FN)=>{"use strict";var J_=U(),X_=class{static{a(this,"BaseLicense")}constructor(t=0,r=J_.RAM_ALLOCATION_ENUM.DEFAULT,n=J_.LICENSE_VALUES.VERSION_DEFAULT,s){this.exp_date=t,this.ram_allocation=r,this.version=n,this.fingerprint=s}},np=class extends X_{static{a(this,"ExtendedLicense")}constructor(t=0,r=J_.RAM_ALLOCATION_ENUM.DEFAULT,n=J_.LICENSE_VALUES.VERSION_DEFAULT,s,i=!1){super(t,r,n,s),this.enterprise=i}};FN.exports={BaseLicense:X_,ExtendedLicense:np}});var ji=g((Wce,WN)=>{"use strict";var zo=require("fs-extra"),VN=z_(),$N=require("crypto"),gK=require("moment"),RK=require("uuid").v4,tr=K(),ip=require("path"),AK=J(),ci=U(),{totalmem:kN}=require("os"),OK=qN().ExtendedLicense,Qo="invalid license key format",bK="061183",yK="mofi25",NK="aes-256-cbc",IK=16,wK=32,YN=ne();YN.initSync();var sp;WN.exports={validateLicense:KN,generateFingerPrint:DK,licenseSearch:cp,getLicense:PK,checkMemoryLimit:UK};function op(){return ip.join(YN.getHdbBasePath(),ci.LICENSE_KEY_DIR_NAME,ci.LICENSE_FILE_NAME)}a(op,"getLicenseDirPath");function CK(){let e=op();return ip.join(e,ci.LICENSE_FILE_NAME)}a(CK,"getLicenseFilePath");function ap(){let e=op();return ip.join(e,ci.REG_KEY_FILE_NAME)}a(ap,"getFingerPrintFilePath");async function DK(){let e=ap();try{return await zo.readFile(e,"utf8")}catch(t){if(t.code==="ENOENT")return await LK();throw tr.error(`Error writing fingerprint file to ${e}`),tr.error(t),new Error("There was an error generating the fingerprint")}}a(DK,"generateFingerPrint");async function LK(){let e=RK(),t=VN.hash(e),r=ap();try{await zo.mkdirp(op()),await zo.writeFile(r,t)}catch(n){if(n.code==="EEXIST")return t;throw tr.error(`Error writing fingerprint file to ${r}`),tr.error(n),new Error("There was an error generating the fingerprint")}return t}a(LK,"writeFingerprint");function KN(e,t){let r={valid_license:!1,valid_date:!1,valid_machine:!1,exp_date:null,ram_allocation:ci.RAM_ALLOCATION_ENUM.DEFAULT,version:ci.LICENSE_VALUES.VERSION_DEFAULT};if(!e)return tr.error("empty license key passed to validate."),r;let n=ap(),s=!1;try{s=zo.statSync(n)}catch(i){tr.error(i)}if(s){let i;try{i=zo.readFileSync(n,"utf8")}catch{tr.error("error validating this machine in the license"),r.valid_machine=!1;return}let o=e.split(yK),c=o[1];c=Buffer.concat([Buffer.from(c)],IK);let l=Buffer.concat([Buffer.from(i)],wK),_=$N.createDecipheriv(NK,l,c);r.valid_date=!0,r.valid_license=!0,r.valid_machine=!0;let u=null;try{u=_.update(o[0],"hex","utf8"),u.trim(),u+=_.final("utf8")}catch{let f=MK(o[0],i);if(f)u=f;else throw r.valid_license=!1,r.valid_machine=!1,console.error(Qo),tr.error(Qo),new Error(Qo)}let d;if(isNaN(u))try{d=JSON.parse(u),r.version=d.version,r.exp_date=d.exp_date,isNaN(r.exp_date)&&(r.exp_date=new Date(r.exp_date).getTime()),d.ram_allocation&&(r.ram_allocation=d.ram_allocation)}catch{throw console.error(Qo),tr.error(Qo),new Error(Qo)}else r.exp_date=u;r.exp_date<gK().valueOf()&&(r.valid_date=!1),VN.validate(o[1],`${bK}${i}${t}`)||(r.valid_license=!1)}else r.valid_license=!1,r.valid_machine=!1;return r.valid_license&&r.valid_machine&&r.valid_date||tr.error("Invalid licence"),r}a(KN,"validateLicense");function MK(e,t){try{let r=$N.createDecipher("aes192",t),n=r.update(e,"hex","utf8");return n.trim(),n+=r.final("utf8"),n}catch{tr.warn("Check old license failed")}}a(MK,"checkOldLicense");function cp(){let e=new OK,t=[];try{t=zo.readFileSync(CK(),"utf-8").split(ci.NEW_LINE)}catch(r){r.code==="ENOENT"?tr.info("no license file found"):tr.error(`could not search for licenses due to: '${r.message}`)}for(let r=0;r<t.length;++r){let n=t[r];try{if(AK.isEmptyOrZeroLength(n))continue;let s=JSON.parse(n),i=KN(s.license_key,s.company);i.valid_machine===!0&&i.valid_date===!0&&i.valid_machine===!0&&(e.exp_date=i.exp_date>e.exp_date?i.exp_date:e.exp_date,e.ram_allocation=i.ram_allocation,e.enterprise=!0)}catch(s){tr.error("There was an error parsing the license string."),tr.error(s),e.ram_allocation=ci.RAM_ALLOCATION_ENUM.DEFAULT,e.enterprise=!1}}return sp=e,e}a(cp,"licenseSearch");async function PK(){return sp||await cp(),sp}a(PK,"getLicense");function UK(){let e=cp().ram_allocation,t=process.constrainedMemory?.()||kN();if(t=Math.round(Math.min(t,kN())/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(UK,"checkMemoryLimit")});var _n=g((jce,lI)=>{"use strict";var XN="username is required",jN="nothing to update, must supply active, role or password to update",ZN="password cannot be an empty string",eI="If role is specified, it cannot be empty.",tI="active must be true or false";lI.exports={addUser:VK,alterUser:$K,dropUser:KK,getSuperUser:JK,userInfo:WK,listUsers:Z_,listUsersExternal:QK,setUsersToGlobal:Xo,findAndValidateUser:aI,getClusterUser:XK,USERNAME_REQUIRED:XN,ALTERUSER_NOTHING_TO_UPDATE:jN,EMPTY_PASSWORD:ZN,EMPTY_ROLE:eI,ACTIVE_BOOLEAN:tI};var rI=un(),vK=Xi(),_p=z_(),nI=HN(),sI=kr(),dp=bs(),Vr=J(),iI=require("validate.js"),Oe=K(),{promisify:BK}=require("util"),fp=Os(),QN=U(),zN=ct(),HK=hr(),zce=ne(),Jce=ji(),xK=Yi(),{table:Xce}=(Ae(),ie(ke)),{handleHDBError:es,hdb_errors:GK}=se(),{HTTP_STATUS_CODES:ts,AUTHENTICATION_ERROR_MSGS:lp,HDB_ERROR_MSGS:Jo}=GK,{UserEventMsg:Ep}=Mn(),up=require("lodash"),{server:hp}=(fr(),ie(Gi)),FK=K();hp.getUser=(e,t)=>aI(e,t,t!=null);var oI={username:!0,active:!0,role:!0,password:!0},JN=new Map,j_=sI.searchByValue,qK=sI.searchByHash,kK=BK(vK.delete);async function VK(e){let t=iI.cleanAttributes(e,oI),r=nI.addUserValidation(t);if(r)throw es(new Error,r.message,ts.BAD_REQUEST,void 0,void 0,!0);let n={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["id","permission","role"]},s;try{s=await j_(n),s=s&&Array.from(s)}catch(l){throw Oe.error("There was an error searching for a role in add user"),Oe.error(l),l}if(!s||s.length<1)throw es(new Error,Jo.ROLE_NAME_NOT_FOUND(t.role),ts.NOT_FOUND,void 0,void 0,!0);if(s.length>1)throw es(new Error,Jo.DUP_ROLES_FOUND(t.role),ts.CONFLICT,void 0,void 0,!0);s[0].permission.cluster_user===!0&&(t.hash=fp.encrypt(t.password)),t.password=_p.hash(t.password),t.role=s[0].id;let i={operation:"insert",schema:"system",table:"hdb_user",records:[t]},o;try{o=await rI.insert(i)}catch(l){throw Oe.error("There was an error searching for a user."),Oe.error(l),l}Oe.debug(o);try{await Xo()}catch(l){throw Oe.error("Got an error setting users to global"),Oe.error(l),l}if(o.skipped_hashes.length===1)throw es(new Error,Jo.USER_ALREADY_EXISTS(t.username),ts.CONFLICT,void 0,void 0,!0);let c=Object.assign({},t);return c.role=s[0],dp.signalUserChange(new Ep(process.pid)),`${c.username} successfully added`}a(VK,"addUser");async function $K(e){let t=iI.cleanAttributes(e,oI);if(Vr.isEmptyOrZeroLength(t.username))throw new Error(XN);if(Vr.isEmptyOrZeroLength(t.password)&&Vr.isEmptyOrZeroLength(t.role)&&Vr.isEmptyOrZeroLength(t.active))throw new Error(jN);if(!Vr.isEmpty(t.password)&&Vr.isEmptyOrZeroLength(t.password.trim()))throw new Error(ZN);if(!Vr.isEmpty(t.active)&&!Vr.isBoolean(t.active))throw new Error(tI);let r=YK(t.username);if(!Vr.isEmpty(t.password)&&!Vr.isEmptyOrZeroLength(t.password.trim())&&(r&&(t.hash=fp.encrypt(t.password)),t.password=_p.hash(t.password)),t.role==="")throw new Error(eI);if(t.role){let i={schema:"system",table:"hdb_role",search_attribute:"role",search_value:t.role,get_attributes:["*"]},o;try{o=Array.from(await j_(i)||[])}catch(c){throw Oe.error("Got an error searching for a role."),Oe.error(c),c}if(!o||o.length===0){let c=Jo.ALTER_USER_ROLE_NOT_FOUND(t.role);throw Oe.error(c),es(new Error,c,ts.NOT_FOUND,void 0,void 0,!0)}if(o.length>1){let c=Jo.ALTER_USER_DUP_ROLES(t.role);throw Oe.error(c),es(new Error,c,ts.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 rI.update(n)}catch(i){throw Oe.error("Error during update."),Oe.error(i),i}try{await Xo()}catch(i){throw Oe.error("Got an error setting users to global"),Oe.error(i),i}return dp.signalUserChange(new Ep(process.pid)),s}a($K,"alterUser");function YK(e){let t=!1,r=global.hdb_users.get(e);return r&&r.role.permission.cluster_user===!0&&(t=!0),t}a(YK,"isClusterUser");async function KK(e){try{let t=nI.dropUserValidation(e);if(t)throw new Error(t);let r={table:"hdb_user",schema:"system",hash_values:[e.username]};if(Vr.isEmpty(global.hdb_users.get(e.username)))throw es(new Error,Jo.USER_NOT_EXIST(e.username),ts.NOT_FOUND,void 0,void 0,!0);let n;try{n=await kK(r)}catch(s){throw Oe.error("Got an error deleting a user."),Oe.error(s),s}Oe.debug(n);try{await Xo()}catch(s){throw Oe.error("Got an error setting users to global."),Oe.error(s),s}return dp.signalUserChange(new Ep(process.pid)),`${e.username} successfully deleted`}catch(t){throw t}}a(KK,"dropUser");async function WK(e){let t={};try{if(!e||!e.hdb_user)return"There was no user info in the body";t=up.cloneDeep(e.hdb_user);let r={schema:"system",table:"hdb_role",hash_values:[t.role.id],get_attributes:["*"]},n;try{n=await qK(r)}catch(s){throw Oe.error("Got an error searching for a role."),Oe.error(s),s}t.role=n[0],delete t.password,delete t.refresh_token,delete t.hash}catch(r){throw Oe.error(r),r}return t}a(WK,"userInfo");async function QK(){let e;try{e=await Z_()}catch(t){throw Oe.error("Got an error listing users."),Oe.error(t),t}try{e.forEach(t=>{delete t.password,delete t.hash,delete t.refresh_token})}catch{throw new Error("there was an error massaging the user data")}return[...e.values()]}a(QK,"listUsersExternal");async function Z_(){try{let e={schema:"system",table:"hdb_role",search_value:"*",search_attribute:"role",get_attributes:["*"]},t;try{t=await j_(e)}catch(o){throw Oe.error("Got an error searching for roles."),Oe.error(o),o}let r={};for(let o of t)r[o.id]=up.cloneDeep(o);if(Object.keys(r).length===0)return null;let n={schema:"system",table:"hdb_user",search_value:"*",search_attribute:"username",get_attributes:["*"]},s;try{s=await j_(n)}catch(o){throw Oe.error("Got an error searching for users."),Oe.error(o),o}let i=new Map;for(let o of s)o=up.cloneDeep(o),o.role=r[o.role],zK(o.role),i.set(o.username,o);return i}catch(e){throw Oe.error("got an error listing users"),Oe.error(e),Vr.errorizeMessage(e)}return null}a(Z_,"listUsers");function zK(e){try{if(!e){Oe.error("invalid user role found.");return}e.permission.system||(e.permission.system={}),e.permission.system.tables||(e.permission.system.tables={});for(let t of Object.keys(xK)){let r={read:!!e.permission.super_user,insert:!1,update:!1,delete:!1,attribute_permissions:[]};e.permission.system.tables[t]=r}}catch(t){Oe.error("Got an error trying to set system permissions."),Oe.error(t)}}a(zK,"appendSystemTablesToRole");async function Xo(){try{let e=await Z_();global.hdb_users=e}catch(e){throw Oe.error(e),e}}a(Xo,"setUsersToGlobal");async function aI(e,t,r=!0){global.hdb_users||await Xo();let n=global.hdb_users.get(e);if(!n){if(!r)return{username:e};throw es(new Error,lp.GENERIC_AUTH_FAIL,ts.UNAUTHORIZED,void 0,void 0,!0)}if(n&&!n.active)throw es(new Error,lp.USER_INACTIVE,ts.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(JN.get(t)===n.password)return s;if(_p.validate(n.password,t))JN.set(t,n.password);else throw es(new Error,lp.GENERIC_AUTH_FAIL,ts.UNAUTHORIZED,void 0,void 0,!0)}return s}a(aI,"findAndValidateUser");async function JK(){global.hdb_users||await Xo();for(let[,e]of global.hdb_users)if(e.role.role==="super_user")return e}a(JK,"getSuperUser");async function XK(){let e=await Z_(),t=HK.getConfigFromFile(QN.CONFIG_PARAMS.CLUSTERING_USER),r=e.get(t);if(!Vr.isEmpty(r)&&r?.role?.role===QN.ROLE_TYPES_ENUM.CLUSTER_USER)return r.decrypt_hash=fp.decrypt(r.hash),r.uri_encoded_d_hash=encodeURIComponent(r.decrypt_hash),r.uri_encoded_name=encodeURIComponent(r.username),r.sys_name=r.username+zN.SERVER_SUFFIX.ADMIN,r.sys_name_encoded=r.uri_encoded_name+zN.SERVER_SUFFIX.ADMIN,r}a(XK,"getClusterUser");var cI=[];hp.invalidateUser=function(e){for(let t of cI)try{t(e)}catch(r){FK.error("Error invalidating user",r)}};hp.onInvalidatedUser=function(e){cI.push(e)}});var Jc=g((rle,fI)=>{"use strict";var Zi=K(),$r=U(),jK=sN(),ele=ii(),tle=si(),ZK=_n(),{validateEvent:uI}=Mn(),zc=Ln(),eW=require("process"),{resetDatabases:tW}=(Ae(),ie(ke)),rW={[$r.ITC_EVENT_TYPES.SCHEMA]:nW,[$r.ITC_EVENT_TYPES.USER]:dI};async function nW(e){let t=uI(e);if(t){Zi.error(t);return}Zi.trace("ITC schemaHandler received schema event:",e),await jK(e.message),await sW(e.message)}a(nW,"schemaHandler");async function sW(e){try{zc.resetReadTxn($r.SYSTEM_SCHEMA_NAME,$r.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME),zc.resetReadTxn($r.SYSTEM_SCHEMA_NAME,$r.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME),zc.resetReadTxn($r.SYSTEM_SCHEMA_NAME,$r.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME);let t=tW();e.table&&e.database&&await t[e.database][e.table].put(Symbol.for("write-verify"),null)}catch(t){Zi.error(t)}}a(sW,"syncSchemaMetadata");var _I=[];async function dI(e){try{try{zc.resetReadTxn($r.SYSTEM_SCHEMA_NAME,$r.SYSTEM_TABLE_NAMES.USER_TABLE_NAME),zc.resetReadTxn($r.SYSTEM_SCHEMA_NAME,$r.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME)}catch(r){Zi.warn(r)}let t=uI(e);if(t){Zi.error(t);return}Zi.trace(`ITC userHandler ${$r.HDB_ITC_CLIENT_PREFIX}${eW.pid} received user event:`,e),await ZK.setUsersToGlobal();for(let r of _I)r()}catch(t){Zi.error(t)}}a(dI,"userHandler");dI.addListener=function(e){_I.push(e)};fI.exports=rW});var Mn=g((cle,hI)=>{"use strict";var sle=K(),mp=J(),iW=U(),{ITC_ERRORS:Xc}=vr(),{parentPort:ile,threadId:oW,isMainThread:aW,workerData:ole}=require("worker_threads"),{onMessageFromWorkers:cW,broadcast:ale,broadcastWithAcknowledgement:lW}=ot();hI.exports={sendItcEvent:uW,validateEvent:EI,SchemaEventMsg:_W,UserEventMsg:dW};var ed;cW(async(e,t)=>{ed=ed||Jc(),EI(e),ed[e.type]&&await ed[e.type](e),e.requestId&&t&&t.postMessage({type:"ack",id:e.requestId})});function uW(e){return!aW&&e.message&&(e.message.originator=oW),lW(e)}a(uW,"sendItcEvent");function EI(e){if(typeof e!="object")return Xc.INVALID_ITC_DATA_TYPE;if(!e.hasOwnProperty("type")||mp.isEmpty(e.type))return Xc.MISSING_TYPE;if(!e.hasOwnProperty("message")||mp.isEmpty(e.message))return Xc.MISSING_MSG;if(!e.message.hasOwnProperty("originator")||mp.isEmpty(e.message.originator))return Xc.MISSING_ORIGIN;if(iW.ITC_EVENT_TYPES[e.type.toUpperCase()]===void 0)return Xc.INVALID_EVENT(e.type)}a(EI,"validateEvent");function _W(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(_W,"SchemaEventMsg");function dW(e){this.originator=e}a(dW,"UserEventMsg")});var bs=g((_le,TI)=>{"use strict";var mI=U(),ule=J(),td=K(),pI=tN(),jo,{sendItcEvent:SI}=Mn();function fW(e){try{td.trace("signalSchemaChange called with message:",e),jo=jo||Jc();let t=new pI(mI.ITC_EVENT_TYPES.SCHEMA,e);return jo.schema(t),SI(t)}catch(t){td.error(t)}}a(fW,"signalSchemaChange");function EW(e){try{td.trace("signalUserChange called with message:",e),jo=jo||Jc();let t=new pI(mI.ITC_EVENT_TYPES.USER,e);return jo.user(t),SI(t)}catch(t){td.error(t)}}a(EW,"signalUserChange");TI.exports={signalSchemaChange:fW,signalUserChange:EW}});var rd=g((fle,RI)=>{"use strict";var gI=J(),hW=U(),mW=K(),pW=F_(),SW=G_(),TW=bs(),{SchemaEventMsg:gW}=Mn(),RW="already exists in";RI.exports=AW;async function AW(e,t,r){if(gI.isEmptyOrZeroLength(r))return r;let n=[];gI.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 OW(e,t.schema,t.name,i)})),s}a(AW,"lmdbCheckForNewAttributes");async function OW(e,t,r,n){let s=new SW(t,r,n,void 0,!0);e&&(s.hdb_auth_header=e);try{await bW(s)}catch(i){if(typeof i=="object"&&i.message!==void 0&&i.message.includes(RW))mW.warn(`attribute ${t}.${r}.${n} already exists`);else throw i}}a(OW,"createNewAttribute");async function bW(e){let t;return t=await pW(e),TW.signalSchemaChange(new gW(process.pid,hW.OPERATIONS_ENUM.CREATE_ATTRIBUTE,e.schema,e.table,e.attribute)),t}a(bW,"createAttribute")});var Zo=g((hle,AI)=>{"use strict";var pp=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}};AI.exports=pp});var bI=g((ple,OI)=>{"use strict";var yW=Zo(),NW=U().OPERATIONS_ENUM,Sp=class extends yW{static{a(this,"LMDBInsertTransactionObject")}constructor(t,r,n,s,i=void 0){super(NW.INSERT,r,n,s,i),this.records=t}};OI.exports=Sp});var NI=g((Tle,yI)=>{"use strict";var IW=Zo(),wW=U().OPERATIONS_ENUM,Tp=class extends IW{static{a(this,"LMDBUpdateTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(wW.UPDATE,n,s,i,o),this.records=t,this.original_records=r}};yI.exports=Tp});var wI=g((Rle,II)=>{"use strict";var CW=Zo(),DW=U().OPERATIONS_ENUM,gp=class extends CW{static{a(this,"LMDBUpsertTransactionObject")}constructor(t,r,n,s,i,o=void 0){super(DW.UPSERT,n,s,i,o),this.records=t,this.original_records=r}};II.exports=gp});var DI=g((Ole,CI)=>{"use strict";var LW=Zo(),MW=U().OPERATIONS_ENUM,Rp=class extends LW{static{a(this,"LMDBDeleteTransactionObject")}constructor(t,r,n,s,i=void 0){super(MW.DELETE,n,s,t,i),this.original_records=r}};CI.exports=Rp});var jc=g((Nle,UI)=>{"use strict";var yle=require("path"),LI=We(),PW=bI(),UW=NI(),vW=wI(),BW=DI(),ea=dt(),MI=J(),{CONFIG_PARAMS:HW}=U(),PI=ne();PI.initSync();var nd=U().OPERATIONS_ENUM,{getTransactionAuditStorePath:xW}=ze();UI.exports=GW;async function GW(e,t){if(PI.get(HW.LOGGING_AUDITLOG)===!1)return;let r=xW(e.schema,e.table),n=await LI.openEnvironment(r,e.table,!0),s=FW(e,t);if(!(s===void 0||s.hash_values.length===0)&&n!==void 0){LI.initializeDBIs(n,ea.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,ea.TRANSACTIONS_DBIS);let i=s.timestamp;return await n.dbis[ea.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].ifNoExists(i,()=>{n.dbis[ea.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP].put(i,s),MI.isEmpty(s.user_name)||n.dbis[ea.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].put(s.user_name,i);for(let o=0;o<s.hash_values.length;o++)n.dbis[ea.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].put(s.hash_values[o],i)})}}a(GW,"writeTransaction");function FW(e,t){let r=MI.isEmpty(e.hdb_user)?void 0:e.hdb_user?.username;if(e.operation===nd.INSERT)return new PW(e.records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===nd.UPDATE)return new UW(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===nd.UPSERT)return new vW(e.records,t.original_records,r,t.txn_time,t.written_hashes,e.__origin);if(e.operation===nd.DELETE)return new BW(t.deleted,t.original_records,r,t.txn_time,e.__origin)}a(FW,"createTransactionObject")});var Ap=g((Cle,vI)=>{"use strict";var qW=Kc(),wle=Cc(),Zc=U(),kW=Dc(),VW=Yo().insertRecords,$W=We(),YW=K(),KW=rd(),{getSchemaPath:WW}=ze(),QW=jc();vI.exports=zW;async function zW(e){try{let{schema_table:t,attributes:r}=qW(e);kW(e,r,t.hash_attribute),e.schema!==Zc.SYSTEM_SCHEMA_NAME&&(r.includes(Zc.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(Zc.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(Zc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(Zc.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await KW(e.hdb_auth_header,t,r),s=WW(e.schema,e.table),i=await $W.openEnvironment(s,e.table),o=await VW(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await QW(e,o)}catch(c){YW.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(zW,"lmdbCreateRecords")});var xI=g((Lle,HI)=>{"use strict";var BI=U(),JW=Ap(),XW=Cc(),jW=require("fs-extra"),{getSchemaPath:ZW}=ze();HI.exports=eQ;async function eQ(e){let t=[{name:e.schema,createddate:Date.now()}],r=new XW(BI.SYSTEM_SCHEMA_NAME,BI.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,void 0,t);await JW(r),await jW.mkdirp(ZW(e.schema))}a(eQ,"lmdbCreateSchema")});var FI=g((Ple,GI)=>{"use strict";var Op=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}};GI.exports=Op});var $I=g((xle,VI)=>{"use strict";var qI=We(),bp=xr(),yp=vr().LMDB_ERRORS_ENUM,tQ=dt(),kI=K(),vle=J(),rQ=require("lmdb"),nQ=FI(),sQ=U(),{OVERFLOW_MARKER:Ble,MAX_SEARCH_KEY_LENGTH:Hle}=tQ,iQ=sQ.TIME_STAMP_NAMES_ENUM.UPDATED_TIME;async function oQ(e,t,r,n){if(bp.validateEnv(e),t===void 0)throw new Error(yp.HASH_ATTRIBUTE_REQUIRED);if(!Array.isArray(r))throw r===void 0?new Error(yp.IDS_REQUIRED):new Error(yp.IDS_MUST_BE_ITERABLE);try{let s=qI.listDBIs(e);qI.initializeDBIs(e,t,s);let i=new nQ,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[iQ]>n){i.skipped.push(o);continue}let p=e.dbis[t].ifVersion(o,rQ.IF_EXISTS,()=>{e.dbis[t].remove(o);for(let S=0;S<s.length;S++){let T=s[S];if(!h.hasOwnProperty(T)||T===t)continue;let A=e.dbis[T],N=h[T];if(N!=null)try{let b=bp.getIndexedValues(N);if(b)for(let v=0,P=b.length;v<P;v++)A.remove(b[v],o)}catch{kI.warn(`cannot delete from attribute: ${T}, ${N}:${o}`)}}});c.push(p),l.push(o),i.original_records.push(h)}catch(h){kI.warn(h),i.skipped.push(o)}let _=[],u=await Promise.all(c);for(let E=0,f=u.length;E<f;E++)u[E]===!0?i.deleted.push(l[E]):(i.skipped.push(l[E]),_.push(E));let d=0;for(let E=0;E<_.length;E++){let f=_[E];i.original_records.splice(f-d,1),d++}return i.txn_time=bp.getNextMonotonicTime(),i}catch(s){throw s}}a(oQ,"deleteRecords");VI.exports={deleteRecords:oQ}});var el=g((Fle,KI)=>{"use strict";var ta=J(),aQ=$I(),cQ=We(),{getSchemaPath:lQ}=ze(),uQ=jc(),_Q=K();KI.exports=dQ;async function dQ(e,t=!0){let n=global.hdb_schema[e.schema][e.table].hash_attribute;if(ta.isEmpty(n))throw new Error(`could not retrieve hash attribute for schema:${e.schema} and table ${e.table}`);try{if(ta.isEmptyOrZeroLength(e.hash_values)&&!ta.isEmptyOrZeroLength(e.records)){e.hash_values=[];for(let c=0;c<e.records.length;c++){let l=e.records[c][n];ta.isEmpty(l)||e.hash_values.push(l)}}if(ta.isEmptyOrZeroLength(e.hash_values))return YI([],[]);if(!Array.isArray(e.hash_values))throw new Error("hash_values must be an array");if(ta.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=lQ(e.schema,e.table),i=await cQ.openEnvironment(s,e.table),o=await aQ.deleteRecords(i,n,e.hash_values,e.__origin?.timestamp);try{t===!0&&await uQ(e,o)}catch(c){_Q.error(`unable to write transaction due to ${c.message}`)}return YI(o.deleted,o.skipped,o.txn_time)}catch(s){throw s}}a(dQ,"lmdbDeleteRecords");function YI(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(YI,"createDeleteResponse")});var Ip=g((Vle,WI)=>{"use strict";var fQ=U(),kle=xr();function Np(e,t){let r=Object.create(null);if(t.length===1&&fQ.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(Np,"parseRow");function EQ(e,t,r,n){let s=Np(r,e);n.push(s)}a(EQ,"searchAll");function hQ(e,t,r,n){let s=Np(r,e);n[t]=s}a(hQ,"searchAllToMap");function mQ(e,t,r){r[e]===void 0&&(r[e]=[]),r[e].push(t)}a(mQ,"iterateDBI");function eo(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(eo,"pushResults");function pQ(e,t,r,n,s,i){t.toString().endsWith(e)&&eo(t,r,n,s,i)}a(pQ,"endsWith");function SQ(e,t,r,n,s,i){t.toString().includes(e)&&eo(t,r,n,s,i)}a(SQ,"contains");function TQ(e,t,r,n,s,i){t>e&&eo(t,r,n,s,i)}a(TQ,"greaterThanCompare");function gQ(e,t,r,n,s,i){t>=e&&eo(t,r,n,s,i)}a(gQ,"greaterThanEqualCompare");function RQ(e,t,r,n,s,i){t<e&&eo(t,r,n,s,i)}a(RQ,"lessThanCompare");function AQ(e,t,r,n,s,i){t<=e&&eo(t,r,n,s,i)}a(AQ,"lessThanEqualCompare");WI.exports={parseRow:Np,searchAll:EQ,searchAllToMap:hQ,iterateDBI:mQ,endsWith:pQ,contains:SQ,greaterThanCompare:TQ,greaterThanEqualCompare:gQ,lessThanCompare:RQ,lessThanEqualCompare:AQ,pushResults:eo}});var ra=g((Qle,ew)=>{"use strict";var li=We(),Yle=K(),Yr=xr(),sd=dt(),Et=vr().LMDB_ERRORS_ENUM,Kle=J(),OQ=U(),id=Ip(),{parseRow:bQ}=id,Wle=require("lmdb"),{OVERFLOW_MARKER:QI,MAX_SEARCH_KEY_LENGTH:yQ}=sd;function zI(e,t,r,n=!1,s=void 0,i=void 0){return to(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(zI,"iterateFullIndex");function tl(e,t,r,n,s,i=!1,o=void 0,c=void 0,l=!1,_=!1){return to(e,t,r,(u,d,E,f)=>{let A={transaction:u,start:i===!0?s:n,end:i===!0?n:s,reverse:i,limit:o,offset:c,inclusiveEnd:i===!0?!l:!_,exclusiveStart:i===!0?_:l};return f===r?(A.values=!1,d.getRange(A).map(N=>({value:N}))):d.getRange(A)})}a(tl,"iterateRangeBetween");function to(e,t,r,n){let s=e.database||e,i=li.openDBI(s,r);i[sd.DBI_DEFINITION_NAME].is_hash_attribute?t=r:t&&li.openDBI(s,t);let o;e.database?o=e:(o=e.useReadTransaction(),o.database=e);let c=n(o,i,s,t);return c.transaction=o,e.database||(c.onDone=()=>{o.done()}),c}a(to,"setupTransaction");function JI(e,t,r,n){let s;return function(i,o){if(typeof i=="string"&&i.endsWith(QI)){if(!s)if(r)s=li.openDBI(e,r);else{let l=li.listDBIs(e);for(let _=0,u=l.length;_<u&&(s=li.openDBI(e,l[_]),!s[sd.DBI_DEFINITION_NAME].is_hash_attribute);_++);}i=s.get(o,{transaction:t,lazy:!0})[n]}return i}}a(JI,"getOverflowCheck");function NQ(e,t,r,n=!1,s=void 0,i=void 0){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);return to(e,t,t,(o,c,l)=>(od(r),r=rl(l,r),c.getRange({transaction:o,start:n?void 0:!1,end:n?!1:void 0,limit:s,offset:i,reverse:n}).map(_=>bQ(_.value,r))))}a(NQ,"searchAll");function IQ(e,t,r,n=!1,s=void 0,i=void 0){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);od(r),r=rl(e.database||e,r);let o=new Map;for(let{key:c,value:l}of zI(e,t,t,n,s,i))o.set(c,id.parseRow(l,r));return o}a(IQ,"searchAllToMap");function wQ(e,t,r=!1,n=void 0,s=void 0){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.ATTRIBUTE_REQUIRED);let i=Object.create(null),o=zI(e,void 0,t,r,n,s),c=o.transaction,l=JI(c.database,c,void 0,t);for(let{key:_,value:u}of o){let d=l(_,u);i[d]===void 0&&(i[d]=[]),i[d].push(u)}return i}a(wQ,"iterateDBI");function CQ(e,t){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);return li.statDBI(e,t).entryCount}a(CQ,"countAll");function DQ(e,t,r,n,s=!1,i=void 0,o=void 0){return ui(e,r,n),to(e,t,r,(c,l,_,u)=>(n=Yr.convertKeyValueToWrite(n),u===r?l.get(n,{transaction:c,lazy:!0})===void 0?[]:[{key:n,value:n}]:l.getValues(n,{transaction:c,reverse:s,limit:i,offset:o}).map(d=>({key:n,value:d}))))}a(DQ,"equals");function LQ(e,t,r){return ui(e,t,r),li.openDBI(e,t).getValuesCount(r)}a(LQ,"count");function MQ(e,t,r,n,s=!1,i=void 0,o=void 0){return ui(e,r,n),to(e,null,r,(c,l)=>{n=Yr.convertKeyValueToWrite(n);let _=!0;typeof n=="number"&&(_=!1);let u;if(s===!0){let d;for(let E of l.getKeys({transaction:c,start:n}))if(!E.startsWith(n)){d=E;break}return d!==void 0&&(Number.isInteger(o)?o++:i++),u=l.getRange({transaction:c,start:d,end:void 0,reverse:s,limit:i,offset:o}).map(E=>{let{key:f}=E;if(f!==d){if(f.toString().startsWith(n))return E;if(_===!0)return u.DONE}}),u.filter(E=>E)}else return u=l.getRange({transaction:c,start:n,reverse:s,limit:i,offset:o}).map(d=>{if(d.key.toString().startsWith(n))return d;if(_===!0)return u.DONE}),_?u:u.filter(d=>d)})}a(MQ,"startsWith");function PQ(e,t,r,n,s=!1,i=void 0,o=void 0){return XI(e,t,r,n,s,i,o,!0)}a(PQ,"endsWith");function XI(e,t,r,n,s=!1,i=void 0,o=void 0,c=!1){return ui(e,r,n),to(e,null,r,(l,_,u,d)=>{let E=JI(u,l,d,r);return o=Number.isInteger(o)?o:0,_.getKeys({transaction:l,end:s?!1:void 0,reverse:s}).flatMap(f=>{let h=f.toString();return h.endsWith(QI)?_.getValues(f,{transaction:l}).map(p=>{let S=E(f,p);if(c?S.endsWith(n):S.includes(n))return{key:S,value:p}}).filter(p=>p):(c?h.endsWith(n):h.includes(n))?_[sd.DBI_DEFINITION_NAME].is_hash_attribute?{key:f,value:f}:_.getValues(f,{transaction:l}).map(p=>({key:f,value:p})):[]}).slice(o,i===void 0?void 0:i+(o||0))})}a(XI,"contains");function UQ(e,t,r,n,s=!1,i=void 0,o=void 0){ui(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),tl(e,t,r,n,l,s,i,o,!0,!1)}a(UQ,"greaterThan");function vQ(e,t,r,n,s=!1,i=void 0,o=void 0){ui(e,r,n);let c=typeof n,l;return c==="string"?l="\uFFFF":c==="number"?l=1/0:c==="boolean"&&(l=!0),tl(e,t,r,n,l,s,i,o,!1,!1)}a(vQ,"greaterThanEqual");function BQ(e,t,r,n,s=!1,i=void 0,o=void 0){ui(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),tl(e,t,r,l,n,s,i,o,!1,!0)}a(BQ,"lessThan");function HQ(e,t,r,n,s=!1,i=void 0,o=void 0){ui(e,r,n);let c=typeof n,l;return c==="string"?l="\0":c==="number"?l=-1/0:c==="boolean"&&(l=!1),tl(e,t,r,l,n,s,i,o,!1,!1)}a(HQ,"lessThanEqual");function xQ(e,t,r,n,s,i=!1,o=void 0,c=void 0){if(Yr.validateEnv(e),r===void 0)throw new Error(Et.ATTRIBUTE_REQUIRED);if(n===void 0)throw new Error(Et.START_VALUE_REQUIRED);if(s===void 0)throw new Error(Et.END_VALUE_REQUIRED);if(n=Yr.convertKeyValueToWrite(n),s=Yr.convertKeyValueToWrite(s),n>s)throw new Error(Et.END_VALUE_MUST_BE_GREATER_THAN_START_VALUE);return tl(e,t,r,n,s,i,o,c)}a(xQ,"between");function GQ(e,t,r,n){Yr.validateEnv(e);let s=e.database||e,i=e.database?e:null;if(t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);if(od(r),r=rl(s,r),n===void 0)throw new Error(Et.ID_REQUIRED);let o=null,c=s.dbis[t].get(n,{transaction:i,lazy:r.length<3});return c&&(o=id.parseRow(c,r)),o}a(GQ,"searchByHash");function FQ(e,t,r){Yr.validateEnv(e);let n=e.database||e,s=e.database?e:null;if(t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Et.ID_REQUIRED);let i=!0;return n.dbis[t].get(r,{transaction:s,lazy:!0})===void 0&&(i=!1),i}a(FQ,"checkHashExists");function qQ(e,t,r,n,s=[]){return ZI(e,t,r,n,s),jI(e,t,r,n,s).map(i=>i[1])}a(qQ,"batchSearchByHash");function kQ(e,t,r,n,s=[]){ZI(e,t,r,n,s);let i=new Map;for(let[o,c]of jI(e,t,r,n,s))i.set(o,c);return i}a(kQ,"batchSearchByHashToMap");function jI(e,t,r,n,s=[]){return to(e,t,t,(i,o,c)=>{r=rl(c,r);let l=r.length<3;return n.map(_=>{let u=c.dbis[t].get(_,{transaction:i,lazy:l});if(u)return[_,id.parseRow(u,r)];s.push(_)}).filter(_=>_)})}a(jI,"batchHashSearch");function ZI(e,t,r,n,s){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.HASH_ATTRIBUTE_REQUIRED);if(od(r),n==null)throw new Error(Et.IDS_REQUIRED);if(!n[Symbol.iterator])throw new Error(Et.IDS_MUST_BE_ITERABLE)}a(ZI,"initializeBatchSearchByHash");function od(e){if(!Array.isArray(e))throw e===void 0?new Error(Et.FETCH_ATTRIBUTES_REQUIRED):new Error(Et.FETCH_ATTRIBUTES_MUST_BE_ARRAY)}a(od,"validateFetchAttributes");function ui(e,t,r){if(Yr.validateEnv(e),t===void 0)throw new Error(Et.ATTRIBUTE_REQUIRED);if(r===void 0)throw new Error(Et.SEARCH_VALUE_REQUIRED);if(r?.length>yQ)throw new Error(Et.SEARCH_VALUE_TOO_LARGE)}a(ui,"validateComparisonFunctions");function rl(e,t){return t.length===1&&OQ.SEARCH_WILDCARDS.indexOf(t[0])>=0&&(t=li.listDBIs(e)),t}a(rl,"setGetWholeRowAttributes");ew.exports={searchAll:NQ,searchAllToMap:IQ,count:LQ,countAll:CQ,equals:DQ,startsWith:MQ,endsWith:PQ,contains:XI,searchByHash:GQ,setGetWholeRowAttributes:rl,batchSearchByHash:qQ,batchSearchByHashToMap:kQ,checkHashExists:FQ,iterateDBI:wQ,greaterThan:UQ,greaterThanEqual:vQ,lessThan:BQ,lessThanEqual:HQ,between:xQ}});var na=g((Jle,iw)=>{var tw=require("lodash"),rw=st(),he=require("joi"),VQ=J(),{hdb_schema_table:nl,checkValidTable:nw,hdb_table:sw,hdb_database:ad}=jn(),{handleHDBError:$Q,hdb_errors:YQ}=se(),{getDatabases:KQ}=(Ae(),ie(ke)),{HTTP_STATUS_CODES:WQ}=YQ,QQ=he.object({database:ad,schema:ad,table:sw,search_attribute:nl,search_value:he.any().required(),get_attributes:he.array().min(1).items(he.alternatives(nl,he.object())).optional(),desc:he.bool(),limit:he.number().integer().min(1),offset:he.number().integer().min(0)}),zQ=he.object({database:ad,schema:ad,table:sw,operator:he.string().valid("and","or").default("and").lowercase(),offset:he.number().integer().min(0),limit:he.number().integer().min(1),get_attributes:he.array().min(1).items(he.alternatives(nl,he.object())).optional(),sort:he.object({attribute:he.alternatives(nl,he.array().min(1)),descending:he.bool().optional()}).optional(),conditions:he.array().min(1).items(he.alternatives(he.object({operator:he.string().valid("and","or").default("and").lowercase(),conditions:he.array()}),he.object({search_attribute:he.alternatives(nl,he.array().min(1)),search_type:he.string().valid("equals","contains","starts_with","ends_with","greater_than","greater_than_equal","less_than","less_than_equal","between","not_equal").optional(),search_value:he.when("search_type",{switch:[{is:"equals",then:he.any()},{is:"between",then:he.array().items(he.alternatives([he.string(),he.number()])).length(2)}],otherwise:he.alternatives(he.string(),he.number())}).required()}))).required()});iw.exports=function(e,t){let r=null;switch(t){case"value":r=rw.validateBySchema(e,QQ);break;case"hashes":let i=function(o){s?s+=". "+o:s=o};var n=i;a(i,"addError");let s;i(nw("database",e.schema)),i(nw("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=rw.validateBySchema(e,zQ);break;default:throw new Error(`Error validating search, unknown type: ${t}`)}if(!r&&e.schema!=="system"){let s=VQ.checkGlobalSchemaTable(e.schema,e.table);if(s)return $Q(new Error,s,WQ.NOT_FOUND);let o=KQ()[e.schema][e.table].attributes,c=e.get_attributes?[...e.get_attributes]:[];t==="value"&&c.push(e.search_attribute);let l=a(u=>{for(let d=0,E=u.conditions.length;d<E;d++){let f=u.conditions[d];f.conditions?l(f):c.push(f.search_attribute)}},"addConditions");t==="conditions"&&l(e);let _=tw.filter(c,u=>u!=="*"&&!u.startsWith?.("$")&&u.attribute!=="*"&&!Array.isArray(u)&&!u.name&&!tw.some(o,d=>d===u||d.attribute===u||d.attribute===u.attribute));if(_&&_.length>0){let u=_.join(", ");return u=u.replace(/,([^,]*)$/," and$1"),new Error(`unknown attribute '${u}'`)}}return r}});var wp=g((jle,ow)=>{"use strict";var JQ=We(),XQ=na(),{getSchemaPath:jQ}=ze();ow.exports=ZQ;function ZQ(e){let t=XQ(e,"hashes");if(t)throw t;let r=jQ(e.schema,e.table);return JQ.openEnvironment(r,e.table)}a(ZQ,"initialize")});var Cp=g((eue,aw)=>{"use strict";var ez=ra(),tz=wp();aw.exports=rz;async function rz(e){let t=await tz(e),r=t.useReadTransaction();r.database=t;let n=global.hdb_schema[e.schema][e.table];try{return ez.batchSearchByHashToMap(r,n.hash_attribute,e.get_attributes,e.hash_values)}finally{r.done()}}a(rz,"lmdbGetDataByHash")});var sa=g((rue,cw)=>{"use strict";var Dp=class{static{a(this,"SearchByHashObject")}constructor(t,r,n,s){this.schema=t,this.table=r,this.hash_values=n,this.get_attributes=s}};cw.exports=Dp});var uw=g((iue,lw)=>{"use strict";var sue=sa(),nz=ra(),sz=wp();lw.exports=iz;async function iz(e){let t=await sz(e),r=global.hdb_schema[e.schema][e.table];return nz.batchSearchByHash(t,r.hash_attribute,e.get_attributes,e.hash_values)}a(iz,"lmdbSearchByHash")});var rs=g((aue,_w)=>{"use strict";var Lp=class{static{a(this,"SearchObject")}constructor(t,r,n,s,i,o,c,l=!1,_=void 0,u=void 0){this.schema=t,this.table=r,this.search_attribute=n,this.search_value=s,this.hash_attribute=i,this.get_attributes=o,this.end_value=c,this.reverse=l,this.limit=_,this.offset=u}};_w.exports=Lp});var cd=g((lue,pw)=>{"use strict";var rr=ra(),oz=We(),az=J(),me=dt(),ro=U(),cz=Yi(),dw=vr().LMDB_ERRORS_ENUM,{getSchemaPath:lz}=ze(),ys=ro.SEARCH_WILDCARDS;async function uz(e,t,r){let n;e.schema===ro.SYSTEM_SCHEMA_NAME?n=cz[e.table]:n=global.hdb_schema[e.schema][e.table];let s=mw(e,n.hash_attribute,r,t);return Ew(e,s,n.hash_attribute,r)}a(uz,"prepSearch");async function Ew(e,t,r,n){let s=lz(e.schema,e.table),i=await oz.openEnvironment(s,e.table),o=hw(i,e,t,r),c=o.transaction||i;if([me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH,me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP,me.SEARCH_TYPES.SEARCH_ALL,me.SEARCH_TYPES.SEARCH_ALL_TO_MAP].indexOf(t)>=0)return o;if(_z(e,r)===!1){let u=e.search_attribute;if(u===r)return n?fw(o,()=>!0):o.map(E=>({[r]:E.key}));let d=a(E=>({[r]:E.value,[u]:E.key}),"toObject");return n?fw(o,d):o.map(d)}let _=e.search_attribute===r?o.map(u=>u.key):o.map(u=>u.value);return n===!0?rr.batchSearchByHashToMap(c,r,e.get_attributes,_):rr.batchSearchByHash(c,r,e.get_attributes,_)}a(Ew,"executeSearch");function hw(e,t,r,n){let s,i=n;t.get_attributes.indexOf(n)<0&&(i=void 0);let{reverse:o,limit:c,offset:l}=t;switch(o=typeof o=="boolean"?o:!1,c=Number.isInteger(c)?c:void 0,l=Number.isInteger(l)?l:void 0,r){case me.SEARCH_TYPES.EQUALS:s=rr.equals(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.CONTAINS:s=rr.contains(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.ENDS_WITH:case me.SEARCH_TYPES._ENDS_WITH:s=rr.endsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.STARTS_WITH:case me.SEARCH_TYPES._STARTS_WITH:s=rr.startsWith(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:return rr.batchSearchByHash(e,t.search_attribute,t.get_attributes,[t.search_value]);case me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:return rr.batchSearchByHashToMap(e,t.search_attribute,t.get_attributes,[t.search_value]);case me.SEARCH_TYPES.SEARCH_ALL:return rr.searchAll(e,n,t.get_attributes,o,c,l);case me.SEARCH_TYPES.SEARCH_ALL_TO_MAP:return rr.searchAllToMap(e,n,t.get_attributes,o,c,l);case me.SEARCH_TYPES.BETWEEN:s=rr.between(e,i,t.search_attribute,t.search_value,t.end_value,o,c,l);break;case me.SEARCH_TYPES.GREATER_THAN:case me.SEARCH_TYPES._GREATER_THAN:s=rr.greaterThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.GREATER_THAN_EQUAL:case me.SEARCH_TYPES._GREATER_THAN_EQUAL:s=rr.greaterThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.LESS_THAN:case me.SEARCH_TYPES._LESS_THAN:s=rr.lessThan(e,i,t.search_attribute,t.search_value,o,c,l);break;case me.SEARCH_TYPES.LESS_THAN_EQUAL:case me.SEARCH_TYPES._LESS_THAN_EQUAL:s=rr.lessThanEqual(e,i,t.search_attribute,t.search_value,o,c,l);break;default:return Object.create(null)}return s}a(hw,"searchByType");function fw(e,t){let r=new Map;for(let n of e)r.set(n.value,t(n));return r}a(fw,"createMapFromIterable");function _z(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(_z,"checkToFetchMore");function mw(e,t,r,n){if(az.isEmpty(n)){let s=e.search_value;typeof s=="object"?s=JSON.stringify(s):s=s.toString();let i=s.charAt(0),o=s.charAt(s.length-1),c=!1;if(e.search_attribute===t&&(c=!0),ys.indexOf(s)>-1)return r===!0?me.SEARCH_TYPES.SEARCH_ALL_TO_MAP:me.SEARCH_TYPES.SEARCH_ALL;if(s.indexOf(ys[0])<0&&s.indexOf(ys[1])<0)return c===!0?r===!0?me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH_TO_MAP:me.SEARCH_TYPES.BATCH_SEARCH_BY_HASH:me.SEARCH_TYPES.EQUALS;if(ys.indexOf(i)>=0&&ys.indexOf(o)>=0)return e.search_value=e.search_value.slice(1,-1),me.SEARCH_TYPES.CONTAINS;if(ys.indexOf(i)>=0)return e.search_value=e.search_value.substr(1),me.SEARCH_TYPES.ENDS_WITH;if(ys.indexOf(o)>=0)return e.search_value=e.search_value.slice(0,-1),me.SEARCH_TYPES.STARTS_WITH;if(s.includes(ys[0])||s.includes(ys[1]))return me.SEARCH_TYPES.EQUALS;throw new Error(dw.UNKNOWN_SEARCH_TYPE)}else switch(n){case ro.VALUE_SEARCH_COMPARATORS.BETWEEN:return me.SEARCH_TYPES.BETWEEN;case ro.VALUE_SEARCH_COMPARATORS.GREATER:return me.SEARCH_TYPES.GREATER_THAN;case ro.VALUE_SEARCH_COMPARATORS.GREATER_OR_EQ:return me.SEARCH_TYPES.GREATER_THAN_EQUAL;case ro.VALUE_SEARCH_COMPARATORS.LESS:return me.SEARCH_TYPES.LESS_THAN;case ro.VALUE_SEARCH_COMPARATORS.LESS_OR_EQ:return me.SEARCH_TYPES.LESS_THAN_EQUAL;default:throw new Error(dw.UNKNOWN_SEARCH_TYPE)}}a(mw,"createSearchTypeFromSearchObject");pw.exports={executeSearch:Ew,createSearchTypeFromSearchObject:mw,prepSearch:uz,searchByType:hw}});var Tw=g((due,Sw)=>{"use strict";var _ue=rs(),dz=na(),fz=J(),Ez=U(),hz=cd();Sw.exports=mz;function mz(e,t){if(!fz.isEmpty(t)&&Ez.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=dz(e,"value");if(n)throw n;return hz.prepSearch(e,t,!0)}a(mz,"lmdbGetDataByValue")});var sl=g((hue,gw)=>{"use strict";var Eue=rs(),pz=na(),Sz=J(),Tz=U(),gz=cd();gw.exports=Rz;async function Rz(e,t){if(!Sz.isEmpty(t)&&Tz.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[t]===void 0)throw new Error(`Value search comparator - ${t} - is not valid`);let n=pz(e,"value");if(n)throw n;return gz.prepSearch(e,t,!1)}a(Rz,"lmdbSearchByValue")});var Aw=g((Sue,Rw)=>{"use strict";var pue=dt(),Mp=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}},Pp=class{static{a(this,"SearchCondition")}constructor(t,r,n){this.search_attribute=t,this.search_type=r,this.search_value=n}},Up=class{static{a(this,"SortAttribute")}constructor(t,r){this.attribute=t,this.desc=r}};Rw.exports={SearchByConditionsObject:Mp,SearchCondition:Pp,SortAttribute:Up}});var Iw=g((Aue,Nw)=>{"use strict";var gue=Aw().SearchByConditionsObject,Az=rs(),Oz=na(),vp=ra(),ld=dt(),{Resource:Rue}=(an(),ie(Bp)),yw=cd(),bz=Ip(),yz=require("lodash"),{getSchemaPath:Nz}=ze(),Ow=We(),{handleHDBError:Iz,hdb_errors:wz}=se(),{HTTP_STATUS_CODES:Cz}=wz,Dz=1e8;Nw.exports=Lz;async function Lz(e){let t=Oz(e,"conditions");if(t)throw Iz(t,t.message,Cz.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=Nz(e.schema,e.table),n=await Ow.openEnvironment(r,e.table),s=global.hdb_schema[e.schema][e.table];for(let _ of e.conditions)Ow.openDBI(n,_.search_attribute);let i=yz.sortBy(e.conditions,_=>{if(_.estimated_count===void 0){let u=_.search_type;u===ld.SEARCH_TYPES.EQUALS?_.estimated_count=vp.count(n,_.search_attribute,_.search_value):u===ld.SEARCH_TYPES.CONTAINS||u===ld.SEARCH_TYPES.ENDS_WITH?_.estimated_count=1/0:_.estimated_count=Dz}return _.estimated_count}),o=n.useReadTransaction();o.database=n;let c=await bw(o,e,i[0],s.hash_attribute),l;if(!e.operator||e.operator.toLowerCase()==="and"){let _=n.dbis[s.hash_attribute],u=i.slice(1).map(yw.filterByType),d=u.length,E=vp.setGetWholeRowAttributes(n,e.get_attributes);l=c.map(f=>_.get(f,{transaction:o,lazy:!0})),d>0&&(l=l.filter(f=>{for(let h=0;h<d;h++)if(!u[h](f))return!1;return!0})),(e.offset||e.limit!==void 0)&&(l=l.slice(e.offset,e.limit!==void 0?(e.offset||0)+e.limit:void 0)),l=l.map(f=>bz.parseRow(f,E))}else{for(let d=1;d<i.length;d++){let E=i[d],f=await bw(o,e,E,s.hash_attribute);c=c.concat(f)}let _=new Set,u=e.offset||0;c=c.filter(d=>_.has(d)?!1:(_.add(d),!0)).slice(u,e.limit&&e.limit+u),l=vp.batchSearchByHash(o,s.hash_attribute,e.get_attributes,c)}return l.onDone=()=>{o.done()},l}a(Lz,"lmdbSearchByConditions");async function bw(e,t,r,n){let s=new Az(t.schema,t.table,void 0,void 0,n,t.get_attributes),i=r.search_type;return s.search_attribute=r.search_attribute,i===ld.SEARCH_TYPES.BETWEEN?(s.search_value=r.search_value[0],s.end_value=r.search_value[1]):s.search_value=r.search_value,yw.searchByType(e,s,i,n).map(o=>o.value)}a(bw,"executeConditionSearch")});var il=g((bue,ww)=>{"use strict";var Mz=U().OPERATIONS_ENUM,Hp=class{static{a(this,"DeleteObject")}constructor(t,r,n,s=void 0){this.operation=Mz.DELETE,this.schema=t,this.table=r,this.hash_values=n,this.__origin=s}};ww.exports=Hp});var xp=g((Nue,Bw)=>{"use strict";var Mw=rs(),Pw=il(),Uw=sl(),vw=el(),Sr=U(),Cw=J(),Dw=We(),{getTransactionAuditStorePath:Pz,getSchemaPath:Uz}=ze(),Lw=K();Bw.exports=vz;async function vz(e){try{if(Cw.isEmpty(global.hdb_schema[e.schema])||Cw.isEmpty(global.hdb_schema[e.schema][e.table]))throw new Error(`unknown schema:${e.schema} and table ${e.table}`);await Bz(e),await Hz(e);let t=Uz(e.schema,e.table);try{await Dw.deleteEnvironment(t,e.table)}catch(r){if(r.message==="invalid environment")Lw.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}try{let r=Pz(e.schema,e.table);await Dw.deleteEnvironment(r,e.table,!0)}catch(r){if(r.message==="invalid environment")Lw.warn(`cannot delete environment for ${e.schema}.${e.table}, environment not found`);else throw r}}catch(t){throw t}}a(vz,"lmdbDropTable");async function Bz(e){let t=new Mw(Sr.SYSTEM_SCHEMA_NAME,Sr.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r=Array.from(await Uw(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 Pw(Sr.SYSTEM_SCHEMA_NAME,Sr.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,n);await vw(s)}a(Bz,"deleteAttributesFromSystem");async function Hz(e){let t=new Mw(Sr.SYSTEM_SCHEMA_NAME,Sr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,e.table,void 0,[Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY,Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,Sr.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),r,n;try{r=Array.from(await Uw(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 Pw(Sr.SYSTEM_SCHEMA_NAME,Sr.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,[n.id]);try{await vw(s)}catch(i){throw i}}a(Hz,"dropTableFromSystem")});var xw=g((wue,Hw)=>{"use strict";var xz=require("fs-extra"),Gz=rs(),Fz=sa(),qz=il(),kz=xp(),Vz=el(),$z=Cp(),Yz=sl(),Ns=U(),{getSchemaPath:Kz}=ze(),{handleHDBError:Wz,hdb_errors:Qz}=se(),{HDB_ERROR_MSGS:zz,HTTP_STATUS_CODES:Jz}=Qz;Hw.exports=Xz;async function Xz(e){let t;try{t=await jz(e.schema);let r=new Gz(Ns.SYSTEM_SCHEMA_NAME,Ns.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME,Ns.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_KEY,t,void 0,[Ns.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),n=Array.from(await Yz(r));for(let o=0;o<n.length;o++){let c={schema:t,table:n[o].name};try{await kz(c)}catch(l){if(l.message!=="invalid environment")throw l}}let s=new qz(Ns.SYSTEM_SCHEMA_NAME,Ns.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[t]);await Vz(s);let i=Kz(t);await xz.remove(i)}catch(r){throw r}}a(Xz,"lmdbDropSchema");async function jz(e){let t=new Fz(Ns.SYSTEM_SCHEMA_NAME,Ns.SYSTEM_TABLE_NAMES.SCHEMA_TABLE_NAME,[e],[Ns.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_NAME_KEY]),r,n;try{r=Array.from(await $z(t))}catch(s){throw s}for(let[,s]of r)s.name===e&&(n=e);if(!n)throw Wz(new Error,zz.SCHEMA_NOT_FOUND(e),Jz.NOT_FOUND,void 0,void 0,!0);return n}a(jz,"validateDropSchema")});var Fp=g((Due,Gw)=>{"use strict";var Gp=class{static{a(this,"CreateTableObject")}constructor(t,r,n){this.schema=t,this.table=r,this.hash_attribute=n}};Gw.exports=Gp});var qw=g((Pue,Fw)=>{"use strict";var Zz=require("fs-extra"),ud=We(),{getTransactionAuditStorePath:e2}=ze(),qp=dt(),Mue=Fp();Fw.exports=t2;async function t2(e){let t;try{let r=e2(e.schema,e.table);await Zz.mkdirp(r),t=await ud.createEnvironment(r,e.table,!0)}catch(r){throw r.message=`unable to create transactions audit environment for ${e.schema}.${e.table} due to: ${r.message}`,r}try{ud.createDBI(t,qp.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,!1,!0),ud.createDBI(t,qp.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,!0,!1),ud.createDBI(t,qp.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(t2,"createTransactionsAuditEnvironment")});var Yw=g((vue,$w)=>{"use strict";var kp=U(),kw=We(),r2=Yo(),{getSystemSchemaPath:n2,getSchemaPath:s2}=ze(),i2=Yi(),o2=F_(),Vp=G_(),a2=K(),c2=qw(),Yp=i2.hdb_table,Vw=[];for(let e=0;e<Yp.attributes.length;e++)Vw.push(Yp.attributes[e].attribute);$w.exports=l2;async function l2(e,t){let r=s2(t.schema,t.table),n=new Vp(t.schema,t.table,kp.TIME_STAMP_NAMES_ENUM.CREATED_TIME,void 0,!0),s=new Vp(t.schema,t.table,kp.TIME_STAMP_NAMES_ENUM.UPDATED_TIME,void 0,!0),i=new Vp(t.schema,t.table,t.hash_attribute,void 0,!1,!0);try{if(await kw.createEnvironment(r,t.table),e!==void 0){let o=await kw.openEnvironment(n2(),kp.SYSTEM_TABLE_NAMES.TABLE_TABLE_NAME);await r2.insertRecords(o,Yp.hash_attribute,Vw,[e]),n.skip_table_check=!0,s.skip_table_check=!0,i.skip_table_check=!0,await $p(n),await $p(s),await $p(i)}await c2(t)}catch(o){throw o}}a(l2,"lmdbCreateTable");async function $p(e){try{await o2(e)}catch(t){a2.warn(`failed to create attribute ${e.attribute} due to ${t.message}`)}}a($p,"createAttribute")});var Ww=g((Hue,Kw)=>{"use strict";var u2=Kc(),_2=Dc(),d2=rd(),ol=U(),f2=Yo().updateRecords,E2=We(),{getSchemaPath:h2}=ze(),m2=jc(),p2=K();Kw.exports=S2;async function S2(e){try{let{schema_table:t,attributes:r}=u2(e);_2(e,r,t.hash_attribute),e.schema!==ol.SYSTEM_SCHEMA_NAME&&(r.includes(ol.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||r.push(ol.TIME_STAMP_NAMES_ENUM.CREATED_TIME),r.includes(ol.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||r.push(ol.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let n=await d2(e.hdb_auth_header,t,r),s=h2(e.schema,e.table),i=await E2.openEnvironment(s,e.table),o=await f2(i,t.hash_attribute,r,e.records,e.__origin?.timestamp);try{await m2(e,o)}catch(c){p2.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(S2,"lmdbUpdateRecords")});var zw=g((Gue,Qw)=>{"use strict";var T2=U().OPERATIONS_ENUM,Kp=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=T2.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};Qw.exports=Kp});var Xw=g((kue,Jw)=>{"use strict";var que=zw(),g2=Kc(),R2=Dc(),A2=rd(),al=U(),O2=Yo().upsertRecords,b2=We(),{getSchemaPath:y2}=ze(),N2=jc(),I2=K(),{handleHDBError:w2,hdb_errors:C2}=se();Jw.exports=D2;async function D2(e){let t;try{t=g2(e)}catch(l){throw w2(l,l.message,C2.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0)}let{schema_table:r,attributes:n}=t;R2(e,n,r.hash_attribute),e.schema!==al.SYSTEM_SCHEMA_NAME&&(n.includes(al.TIME_STAMP_NAMES_ENUM.CREATED_TIME)||n.push(al.TIME_STAMP_NAMES_ENUM.CREATED_TIME),n.includes(al.TIME_STAMP_NAMES_ENUM.UPDATED_TIME)||n.push(al.TIME_STAMP_NAMES_ENUM.UPDATED_TIME));let s=await A2(e.hdb_auth_header,r,n),i=y2(e.schema,e.table),o=await b2.openEnvironment(i,e.table),c=await O2(o,r.hash_attribute,n,e.records,e.__origin?.timestamp);try{await N2(e,c)}catch(l){I2.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(D2,"lmdbUpsertRecords")});var Zw=g(($ue,jw)=>{"use strict";var Wp=class{static{a(this,"DeleteBeforeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.timestamp=n}};jw.exports=Wp});var tC=g((Kue,eC)=>{"use strict";var Qp=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}};eC.exports=Qp});var sC=g((zue,nC)=>{"use strict";var zp=We(),{getTransactionAuditStorePath:L2}=ze(),Que=Zw(),cl=dt(),M2=J(),rC=tC(),P2=require("util").promisify,U2=P2(setTimeout),v2=1e4,B2=100;nC.exports=H2;async function H2(e){let t=L2(e.schema,e.table),r=await zp.openEnvironment(t,e.table,!0),n=zp.listDBIs(r);zp.initializeDBIs(r,cl.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s,i=new rC;do s=await x2(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 U2(B2);while(s.transactions_deleted>0);return i}a(H2,"deleteAuditLogsBefore");async function x2(e,t){let r=new rC;try{let n=e.dbis[cl.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[cl.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME];M2.isEmpty(c)||(s=e.dbis[cl.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].remove(c,i));for(let l=0;l<o.hash_values.length;l++)s=e.dbis[cl.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE].remove(o.hash_values[l],i);if(r.transactions_deleted++,r.end_timestamp=i,r.transactions_deleted>v2)break}return await s,r}catch(n){throw n}}a(x2,"deleteTransactions")});var oC=g((Xue,iC)=>{"use strict";var Jp=class{static{a(this,"DropAttributeObject")}constructor(t,r,n){this.schema=t,this.table=r,this.attribute=n}};iC.exports=Jp});var cC=g((e_e,aC)=>{"use strict";var G2=rs(),F2=il(),Zue=oC(),ns=U(),q2=J(),Xp=We(),k2=Yi(),V2=sl(),$2=el(),{getSchemaPath:Y2}=ze();aC.exports=K2;async function K2(e,t=!0){let r;e.schema===ns.SYSTEM_SCHEMA_NAME?r=k2[e.table]:r=global.hdb_schema[e.schema][e.table];let n=await Q2(e),s=Y2(e.schema,e.table),i=await Xp.openEnvironment(s,e.table);return t===!0&&await W2(e,i,r.hash_attribute),Xp.dropDBI(i,e.attribute),n}a(K2,"lmdbDropAttribute");async function W2(e,t,r){let n=Xp.openDBI(t,r),s,i=e.attribute;for(let{key:o,value:c,version:l}of n.getRange({start:!1,versions:!0})){let _={};for(let u in c)u!==i&&(_[u]=c[u]);s=t.dbis[r].put(o,_,l)}await s}a(W2,"removeAttributeFromAllObjects");async function Q2(e){let t=new G2(ns.SYSTEM_SCHEMA_NAME,ns.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,ns.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_SCHEMA_TABLE_KEY,`${e.schema}.${e.table}`,void 0,[ns.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY,ns.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]),n=Array.from(await V2(t)).filter(o=>o[ns.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ATTRIBUTE_KEY]===e.attribute);if(q2.isEmptyOrZeroLength(n))throw new Error(`Attribute '${e.attribute}' was not found in '${e.schema}.${e.table}'`);let s=n.map(o=>o[ns.SYSTEM_DEFAULT_ATTRIBUTE_NAMES.ATTR_ID_KEY]),i=new F2(ns.SYSTEM_SCHEMA_NAME,ns.SYSTEM_TABLE_NAMES.ATTRIBUTE_TABLE_NAME,s);return $2(i)}a(Q2,"dropAttributeFromSystem")});var EC=g((n_e,fC)=>{"use strict";var jp=We(),ia=dt(),r_e=xr(),Zp=U(),lC=J(),{getTransactionAuditStorePath:z2}=ze(),J2=ra(),_d=Zo(),X2=K();fC.exports=j2;async function j2(e){let t=z2(e.schema,e.table),r=await jp.openEnvironment(t,e.table,!0),n=jp.listDBIs(r);jp.initializeDBIs(r,ia.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,n);let s;switch(e.search_type){case Zp.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.TIMESTAMP:return uC(r,e.search_values);case Zp.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:return s=global.hdb_schema[e.schema][e.table].hash_attribute,eJ(r,e.search_values,s);case Zp.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:return Z2(r,e.search_values);default:return uC(r)}}a(j2,"readAuditLog");function uC(e,t=[0,Date.now()]){lC.isEmpty(t[0])&&(t[0]=0),lC.isEmpty(t[1])&&(t[1]=Date.now());let r=e.dbis[ia.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP],n;for(let s of r.getKeys({start:t[1]}))if(s!==t[1]){n=s;break}return r.getRange({start:t[0],end:n}).map(({value:s})=>Object.assign(new _d,s))}a(uC,"searchTransactionsByTimestamp");function Z2(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[ia.TRANSACTIONS_DBI_NAMES_ENUM.USER_NAME].getValues(s))i.push(o);r.set(s,dC(e,i))}return Object.fromEntries(r)}a(Z2,"searchTransactionsByUsername");function eJ(e,t,r){let n=new Map;for(let c=0,l=t.length;c<l;c++){let _=t[c],u=J2.equals(e,ia.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP,ia.TRANSACTIONS_DBI_NAMES_ENUM.HASH_VALUE,_);for(let{value:d}of u){let E=Number(d);n.has(E)?n.get(E).push(_.toString()):n.set(E,[_.toString()])}}let s=Array.from(n.keys()),i=dC(e,s),o=new Map;for(let c=0;c<i.length;c++){let l=i[c],_=l.timestamp,u=n.get(_);_C(l,"records",r,u,o),_C(l,"original_records",r,u,o)}return Object.fromEntries(o)}a(eJ,"searchTransactionsByHashValues");function _C(e,t,r,n,s){let i=e.timestamp;if(e[t])for(let o=0;o<e[t].length;o++){let c=e[t][o],l=c[r].toString();if(n.indexOf(l)>=0)if(s.has(l)){let _=s.get(l),u=_[_.length-1];if(u.timestamp===i)u[t]=[c];else{let d=new _d(e.operation,e.user_name,i,void 0);d[t]=[c],_.push(d)}}else{let _=new _d(e.operation,e.user_name,i,void 0);_[t]=[c],s.set(l,[_])}}}a(_C,"loopRecords");function dC(e,t){let r=[];try{let n=e.dbis[ia.TRANSACTIONS_DBI_NAMES_ENUM.TIMESTAMP];for(let s=0;s<t.length;s++)try{let i=n.get(t[s]);if(i){let o=Object.assign(new _d,i);r.push(o)}}catch(i){X2.warn(i)}return r}catch(n){throw n}}a(dC,"batchSearchTransactions")});var mC=g((a_e,hC)=>{"use strict";var{getSchemaPath:i_e}=ze(),o_e=We(),{database:tJ}=(Ae(),ie(ke));hC.exports={writeTransaction:rJ};async function rJ(e,t,r){return tJ({database:e,table:t}).transaction(r)}a(rJ,"writeTransaction")});var gC=g((l_e,TC)=>{"use strict";var{getSchemaPath:pC}=ze(),SC=We();TC.exports={flush:nJ,resetReadTxn:sJ};async function nJ(e,t){return(await SC.openEnvironment(pC(e,t),t.toString())).flushed}a(nJ,"flush");async function sJ(e,t){try{(await SC.openEnvironment(pC(e,t),t.toString())).resetReadTxn()}catch{}}a(sJ,"resetReadTxn")});var bC=g((__e,OC)=>{"use strict";var{Readable:iJ}=require("stream"),{getDatabases:oJ}=(Ae(),ie(ke)),{readSync:aJ,openSync:cJ,createReadStream:RC}=require("fs"),{open:lJ}=require("lmdb"),AC=Gc(),uJ=Fc(),{AUDIT_STORE_OPTIONS:_J}=(ti(),ie(yC)),{INTERNAL_DBIS_NAME:dJ,AUDIT_STORE_NAME:fJ}=dt();OC.exports=hJ;var eS=32768,EJ=100;async function hJ(e){let t=e.database||e.schema||"data",r=oJ()[t],n=new Date().toISOString(),s=e.tables||e.table&&[e.table];if(s){let _=r[s[0]];if(!_)throw new Error(`Can not find table ${s[0]}`);let u=_.dbisDB,d=lJ({noSync:!0,maxDbs:uJ.MAX_DBS}),E,f=d.openDB(dJ,new AC(!1)),h=u.useReadTransaction(),p=0,S=a(async function(A,N){N.encoding="binary",N.encoder=void 0;let b=d.openDB(A,N),v=u.openDB(A,N);for(let{key:P,version:q,value:M}of v.getRange({start:null,transaction:h,versions:v.useVersions}))E=b.put(P,M,q),p++%EJ===0&&(await new Promise(Q=>setTimeout(Q,20)),h.openTimer&&(h.openTimer=0))},"copyDatabase");for(let{key:A,value:N}of u.getRange({transaction:h,start:!1}))if(s.some(b=>A.startsWith?.(b+"/"))){f.put(A,N);let[,b]=A.split("/"),v=!b,P=new AC(!v,v);await S(A,P)}e.include_audit&&await S(fJ,Object.assign({},_J)),await E;let T=RC(d.path);return T.headers=l(),T.on("close",()=>{h.done(),d.close()}),T}let o=r[Object.keys(r)[0]].primaryStore,c=cJ(o.path);return o.transaction(()=>{let _=Buffer.alloc(eS);aJ(c,_,0,eS),o.resetReadTxn();let u=o.useReadTransaction();u.renew();let d=RC(null,{fd:c,start:eS}),E=new iJ.from(async function*(){yield _;for await(let f of d)u.openTimer&&(u.openTimer=0),yield f;u.done()}());return E.headers=l(),E});function l(){let _=new Map;return _.set("content-type","application/octet-stream"),_.set("content-disposition",`attachment; filename="${t}"`),_.set("date",n),_}}a(hJ,"getBackup")});var wC=g((f_e,IC)=>{"use strict";var mJ=K(),{handleHDBError:pJ}=se(),SJ=ay(),TJ=F_(),gJ=Ap(),RJ=xI(),AJ=el(),OJ=Cp(),bJ=uw(),yJ=Tw(),NJ=sl(),IJ=Iw(),wJ=xw(),CJ=Yw(),DJ=Ww(),LJ=Xw(),MJ=sC(),PJ=xp(),UJ=cC(),vJ=EC(),BJ=mC(),NC=gC(),HJ=bC(),tS=class extends SJ{static{a(this,"LMDBBridge")}async searchByConditions(t){return IJ(t)}async getDataByHash(t){return await OJ(t)}async searchByHash(t){return await bJ(t)}async getDataByValue(t,r){return await yJ(t,r)}async searchByValue(t){return await NJ(t)}async createSchema(t){return await RJ(t)}async dropSchema(t){return await wJ(t)}async createTable(t,r){return await CJ(t,r)}async dropTable(t){return await PJ(t)}async createAttribute(t){return await TJ(t)}async createRecords(t){return await gJ(t)}async updateRecords(t){return await DJ(t)}async upsertRecords(t){try{return await LJ(t)}catch(r){throw pJ(r,null,null,mJ.ERR,r)}}async deleteRecords(t){return await AJ(t)}async dropAttribute(t){return await UJ(t)}async deleteAuditLogsBefore(t){return await MJ(t)}async readAuditLog(t){return await vJ(t)}writeTransaction(t,r,n){return BJ.writeTransaction(t,r,n)}flush(t,r){return NC.flush(t,r)}resetReadTxn(t,r){return NC.resetReadTxn(t,r)}getBackup(t){return HJ(t)}};IC.exports=tS});function qJ(){FJ=setInterval(function(){for(let e of rS)if(e.stale){let t=e[ye]?.url;MC.error(`Transaction was open too long and has been aborted, from table: ${e.lmdbDb?.name+(t?" path: "+t:"")}`),e.abort()}else e.stale=!0},GJ).unref()}var nS,LC,MC,PC,UC,vC,CC,rS,xJ,ll,DC,no,dd,GJ,FJ,sS=Re(()=>{nS=x(xr()),LC=x(se()),MC=x(K());an();PC=x(ne()),UC=x(U()),vC=x(J()),CC=100,rS=new Set,xJ=(0,vC.convertToMS)(PC.get(UC.CONFIG_PARAMS.STORAGE_MAXTRANSACTIONQUEUETIME))||45e3,no=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),rS.add(this),this.readTxn}useReadTxn(){return this.getReadTxn(),this.readTxn.use(),this.readTxnsUsed++,this.readTxn}doneReadTxn(){this.readTxn&&(this.readTxn.done(),--this.readTxnsUsed===0&&(rS.delete(this),this.readTxn=null))}disregardReadTxn(){--this.readTxnRefCount===0&&this.readTxnsUsed===1&&this.doneReadTxn()}checkOverloaded(){if(ll&&!this.overloadChecked&&performance.now()-DC>xJ)throw new LC.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,nS.getNextMonotonicTime)()),t.timestamp||(t.timestamp=r);let n=t.retries||0;if(this.validated<this.writes.length)try{let d=this.validated;this.validated=this.writes.length;for(let f=d;f<this.validated;f++)this.writes[f]?.validate?.(this.timestamp);let E;for(let f=d;f<this.validated;f++){let h=this.writes[f];h&&(h.before||h.beforeIntermediate)&&(E=!0)}if(E)return(async()=>{try{for(let f=0;f<2;f++){let h;for(let p=d;p<this.validated;p++){let S=this.writes[p];if(!S)continue;let T=S[f===0?"before":"beforeIntermediate"];if(T){let A=T();h?h.push?h.push(A):h=[h,A]:h=A}}h&&await(h.push?Promise.all(h):h)}}catch(f){throw this.abort(),f}return this.commit(t)})()}catch(d){throw this.abort(),d}n||this.doneReadTxn(),this.open=t?.letItLinger?2:0;let s,i=[],o=0;this.writes=this.writes.filter(d=>d);let c=a(d=>{d.commit(r,d.entry,n)},"doWrite"),l=a(()=>{let d=this.writes[o++];if(d)if(d.key){n>0&&(d.entry=d.store.getEntry(d.key));let E=d.store.ifVersion(d.key,d.entry?.version??null,l);s=s||E}else l();else for(let E of this.writes)c(E)},"nextCondition"),_=this.lmdbDb;if(this.writes.length>0&&(_?.retryRisk&&(_.retryRisk*=.99),this.writes.length+(_?.retryRisk||0)<CC>>n?l():s=this.writes[0].store.transaction(()=>{for(let d of this.writes)d.entry=d.store.getEntry(d.key),c(d);return!0})),s)return ll||(ll=s,DC=performance.now(),ll.then(()=>{ll=null})),s.then(d=>d?(this.next&&i.push(this.next.commit(t)),t?.flush&&i.push(this.writes[0].store.flushed),this.writes=[],this.next=null,Promise.all(i).then(()=>({txnTime:r}))):(_&&(_.retryRisk=(_.retryRisk||0)+CC/2),t?t.retries=n+1:t={retries:1},this.commit(t)));let u={txnTime:r};if(this.next){let d=this.next?.commit(t);if(d?.then)return d?.then(E=>({txnTime:r,next:E}));u.next=d}return u}abort(){for(;this.readTxnsUsed>0;)this.doneReadTxn();this.open=0,this.writes=[]}},dd=class extends no{static{a(this,"ImmediateTransaction")}_timestamp;addWrite(t){super.addWrite(t),this.commit()}get timestamp(){return this._timestamp||(this._timestamp=(0,nS.getNextMonotonicTime)())}getReadTxn(){}},GJ=3e4;a(qJ,"startMonitoringTxns");qJ()});function Ze(e,t,r){if(!t)t=e,e={};else if(!e)e={};else if(e?.transaction?.open===1&&typeof t=="function")return t(e.transaction);if(typeof t!="function")throw new Error("Callback function must be provided to transaction");let n=e.transaction=new no;e.timestamp&&(n.timestamp=e.timestamp),n[ye]=e,e.resourceCache||(e.resourceCache=[]);let s;try{if(s=t(n),s?.then)return s.then(i,o)}catch(c){o(c)}return i(s);function i(c){let l=n.commit({letItLinger:r?.letItLinger});return l.then?l.then(()=>c):c}function o(c){throw n.abort({}),c}}var BC,so=Re(()=>{BC=require("../../index");an();sS();a(Ze,"transaction");(0,BC._assignPackageExport)("transaction",Ze);Ze.commit=function(e){let t=(e[ye]||e)?.transaction;if(!t)throw new Error("No active transaction is available to commit");return t.commit()};Ze.abort=function(e){let t=(e[ye]||e)?.transaction;if(!t)throw new Error("No active transaction is available to abort");return t.abort()}});var $C={};qe($C,{ResourceBridge:()=>aS});function cS({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 xC(e,t){let r=ss(e),n=cS(e,r);if(!r)throw new Pn.ClientError(`Table ${e.table} not found`);let s;n&&r.attributes.length-n.length>2&&n.length<5&&(s=!0);let i={user:e.hdb_user,onlyIfCached:e.onlyIfCached,noCacheStore:e.noCacheStore,noCache:e.noCache},o;Ze(i,()=>new Promise(_=>o=_));let c=e.ids||e.hash_values,l=0;return{[Symbol.asyncIterator](){return{async next(){if(l<c.length){let _=c[l++],u;try{u=await r.get({id:_,lazy:s,select:n},i),u=u&&Ed(u)}catch(d){u={message:d.toString()}}return t?{value:{key:_,value:u}}:{value:u}}else return o(),{done:!0}},return(_){return o(),{value:_,done:!0}},throw(_){return o(),{done:!0}}}}}}function ss(e){let t=e.database||e.schema||VJ,r=Tr()[t];if(!r)throw(0,Pn.handleHDBError)(new Error,kJ.SCHEMA_NOT_FOUND(t),404);return r[e.table]}function GC(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*FC(e,t,r){let n;for await(let s of e.getHistory(t,r)){let i=s.type;i==="put"&&(i="upsert");let{id:o,version:c,value:l}=s;n?.timestamp===c?(n.hash_values.push(o),n.records.push(l)):(n&&(yield n),n={operation:i,user_name:s.user,timestamp:c,hash_values:[o],records:[l]})}n&&(yield n)}var qC,fd,Pn,kC,Un,iS,oS,VC,kJ,VJ,$J,YJ,HC,aS,YC=Re(()=>{"use strict";qC=x(wC()),fd=x(na()),Pn=x(se());Ae();kC=x(Kc()),Un=x(U()),iS=x(bs()),oS=x(Mn()),VC=x(J());so();hd();({HDB_ERROR_MSGS:kJ}=Pn.hdb_errors),VJ="data",$J=1e4,YJ=10,aS=class extends qC.default{static{a(this,"ResourceBridge")}constructor(t){super(t),HC=this}async searchByConditions(t){t.select!==void 0&&(t.get_attributes=t.select);for(let o of t.conditions||[])o?.attribute!==void 0&&(o.search_attribute=o.attribute),o?.comparator!==void 0&&(o.search_type=o.comparator),o?.value!==void 0&&(o.search_value=o.value);let r=(0,fd.default)(t,"conditions");if(r)throw(0,Pn.handleHDBError)(r,r.message,400,void 0,void 0,!0);let n=ss(t);if(!n)throw new Pn.ClientError(`Table ${t.table} not found`);let s=t.conditions.map(i);function i(o){return o.conditions?(o.conditions=o.conditions.map(i),o):{attribute:o.search_attribute??o.attribute,comparator:o.search_type??o.comparator,value:o.search_value!==void 0?o.search_value:o.value}}return a(i,"mapCondition"),n.search({conditions:s,operator:t.operator?t.operator.toLowerCase():void 0,limit:t.limit,offset:t.offset,reverse:t.reverse,select:cS(t,n),sort:t.sort,allowFullScan:!0},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache})}async createTable(t,r){let n=r.attributes,s=!!n,i=r.primary_key||r.hash_attribute;if(n)for(let o of n)o.is_primary_key?(o.isPrimaryKey=!0,delete o.is_primary_key):o.name===i&&i&&(o.isPrimaryKey=!0);else{if(!i)throw new Pn.ClientError("A primary key must be specified with a `primary_key` property or with `attributes`");n=[{name:i,isPrimaryKey:!0},{name:"__createdtime__",indexed:!0},{name:"__updatedtime__",indexed:!0}]}ft({database:r.schema,table:r.table,attributes:n,schemaDefined:s,expiration:r.expiration})}async createAttribute(t){return await ss(t).addAttributes([{name:t.attribute,indexed:t.indexed??!0}]),`attribute ${t.schema}.${t.table}.${t.attribute} successfully created.`}async dropAttribute(t){let r=ss(t);if(await r.removeAttributes([t.attribute]),!r.schemaDefined){let n=t.attribute,s,i=a((o,c,l)=>(c=Object.assign({},c),delete c[n],r.primaryStore.ifVersion(o,l,()=>r.primaryStore.put(o,c,l)).then(_=>{if(!_){let{value:u,version:d}=r.primaryStore.getEntry(o);return i(o,u,d)}})),"deleteRecord");for(let{key:o,value:c,version:l}of r.primaryStore.getRange({start:!0,versions:!0}))s=i(o,c,l),await new Promise(_=>setImmediate(_));await s}return`successfully deleted ${t.schema}.${t.table}.${t.attribute}`}dropTable(t){ss(t).dropTable()}createSchema(t){return oa({database:t.schema,table:null}),iS.signalSchemaChange(new oS.SchemaEventMsg(process.pid,Un.OPERATIONS_ENUM.CREATE_SCHEMA,t.schema))}async dropSchema(t){await lS(t.schema),iS.signalSchemaChange(new oS.SchemaEventMsg(process.pid,Un.OPERATIONS_ENUM.DROP_SCHEMA,t.schema))}async updateRecords(t){return t.requires_existing=!0,this.upsertRecords(t)}async createRecords(t){return t.requires_no_existing=!0,HC.upsertRecords(t)}async upsertRecords(t){let{schema_table:r,attributes:n}=(0,kC.default)(t),s,i=Tr()[t.schema][t.table],o={user:t.hdb_user,expiresAt:t.expiresAt};return Ze(o,async c=>{if(!i.schemaDefined){s=[];for(let u of n)i.attributes.find(E=>E.name==u)||s.push(u);s.length>0&&await i.addAttributes(s.map(u=>({name:u,indexed:!0})))}let l=[],_=[];for(let u of t.records){let d=u[i.primaryKey],E=d!=null&&await i.get(d,o);if(t.requires_existing&&!E||t.requires_no_existing&&E){_.push(u[i.primaryKey]);continue}E&&(E=Ed(E));for(let f in u)if(Object.prototype.hasOwnProperty.call(u,f)){let h=u[f];if(typeof h=="function")try{let p=h([[E]]);Array.isArray(p)&&(h=p[0].func_val,u[f]=h)}catch(p){throw p.message+="Trying to set key "+f+" on object"+JSON.stringify(u),p}}if(E)for(let f in E)Object.prototype.hasOwnProperty.call(u,f)||(u[f]=E[f]);await(d==null?i.create(u,o):i.put(u,o)),l.push(u[i.primaryKey])}return{txn_time:c.timestamp,written_hashes:l,new_attributes:s,skipped_hashes:_}})}async deleteRecords(t){let r=Tr()[t.schema][t.table],n={user:t.hdb_user};return Ze(n,async s=>{let i=t.hash_values||t.records.map(l=>l[r.primaryKey]),o=[],c=[];for(let l of i)await r.delete(l,n)?o.push(l):c.push(l);return GC(o,c,s.timestamp)})}async deleteRecordsBefore(t){let r=Tr()[t.schema][t.table];if(!r.createdTimeProperty)throw new Pn.ClientError("Table must have a '__createdtime__' attribute or @createdTime timestamp defined to perform this operation");let n=await r.search({conditions:[{attribute:r.createdTimeProperty.name,value:Date.parse(t.date),comparator:Un.VALUE_SEARCH_COMPARATORS.LESS}]}),s=!1,i=[],o=[],c=0,l=[],_=a(async()=>{let u=await this.deleteRecords({schema:t.schema,table:t.table,hash_values:l});i.push(...u.deleted_hashes),o.push(...u.skipped_hashes),await(0,VC.async_set_timeout)(YJ),l=[],s=!0},"chunkDelete");for await(let u of n)l.push(u[r.primaryKey]),c++,c%$J===0&&await _();return l.length>0&&await _(),s?GC(i,o,void 0):{message:"No records found to delete"}}searchByHash(t){t.select!==void 0&&(t.get_attributes=t.select);let r=(0,fd.default)(t,"hashes");if(r)throw r;return xC(t)}async getDataByHash(t){let r=new Map;t._returnKeyValue=!0;for await(let{key:n,value:s}of xC(t,!0))r.set(n,s);return r}searchByValue(t,r){if(r&&Un.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r]===void 0)throw new Error(`Value search comparator - ${r} - is not valid`);t.select!==void 0&&(t.get_attributes=t.select),t.attribute!==void 0&&(t.search_attribute=condition.attribute),t.value!==void 0&&(t.search_value=condition.value);let n=(0,fd.default)(t,"value");if(n)throw n;let s=ss(t);if(!s)throw new Pn.ClientError(`Table ${t.table} not found`);let i=t.search_value;i.includes?.("*")&&(i.startsWith("*")?i.endsWith("*")?i!=="*"&&(r="contains",i=i.slice(1,-1)):(r="ends_with",i=i.slice(1)):i.endsWith("*")&&(r="starts_with",i=i.slice(0,-1))),r===Un.VALUE_SEARCH_COMPARATORS.BETWEEN&&(i=[i,t.end_value]);let o=i==="*"?[]:[{attribute:t.search_attribute,value:i,comparator:r}];return s.search({conditions:o,allowFullScan:!0,limit:t.limit,offset:t.offset,reverse:t.reverse,sort:t.sort,select:cS(t,s)},{onlyIfCached:t.onlyIfCached,noCacheStore:t.noCacheStore,noCache:t.noCache})}async getDataByValue(t,r){let n=new Map,s=ss(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){ss({schema:t,table:r})?.primaryStore.resetReadTxn()}async deleteAuditLogsBefore(t){return ss(t).deleteHistory(t.timestamp,t.cleanup_deleted_records)}async readAuditLog(t){let r=ss(t),n={};switch(t.search_type){case Un.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.HASH_VALUE:for(let i of t.search_values)n[i]=(await r.getHistoryOfRecord(i)).map(o=>{let c=o.type;return c==="put"&&(c="upsert"),{operation:c,timestamp:o.version,user_name:o.user,hash_values:[i],records:[o.value]}});return n;case Un.READ_AUDIT_LOG_SEARCH_TYPES_ENUM.USERNAME:let s=t.search_values;for await(let i of FC(r))s.includes(i.user_name)&&(n[i.user_name]||(n[i.user_name]=[])).push(i);return n;default:return FC(r,t.search_values?.[0],t.search_values?.[1])}}};a(cS,"getSelect");a(xC,"getRecords");a(ss,"getTable");a(GC,"createDeleteResponse");a(FC,"groupRecordsInHistory")});var Ln=g((w_e,KC)=>{"use strict";var{ResourceBridge:KJ}=(YC(),ie($C)),WJ=ne();WJ.initSync();var md;function QJ(){return md||(md=new KJ,md)}a(QJ,"getBridge");KC.exports=QJ()});var JC=g((D_e,zC)=>{"use strict";var WC=require("lodash"),ul=require("mathjs"),zJ=require("jsonata"),QC=J();zC.exports={distinct_array:e=>Array.isArray(e)&&e.length>1?WC.uniqWith(e,WC.isEqual):e,searchJSON:JJ,mad:_l.bind(null,ul.mad),mean:_l.bind(null,ul.mean),mode:_l.bind(null,ul.mode),prod:_l.bind(null,ul.prod),median:_l.bind(null,ul.median)};function _l(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(_l,"aggregateFunction");function JJ(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(QC.isEmpty(this.__ala__.res)&&(this.__ala__.res={}),QC.isEmpty(this.__ala__.res[r])){let n=zJ(e);this.__ala__.res[r]=n}return this.__ala__.res[r].evaluate(t)}a(JJ,"searchJSON")});var jC=g((M_e,XC)=>{"use strict";var gt=require("moment"),uS="YYYY-MM-DDTHH:mm:ss.SSSZZ";gt.suppressDeprecationWarnings=!0;XC.exports={current_date:()=>gt().utc().format("YYYY-MM-DD"),current_time:()=>gt().utc().format("HH:mm:ss.SSS"),extract:(e,t)=>{switch(t.toLowerCase()){case"year":return gt(e).utc().format("YYYY");case"month":return gt(e).utc().format("MM");case"day":return gt(e).utc().format("DD");case"hour":return gt(e).utc().format("HH");case"minute":return gt(e).utc().format("mm");case"second":return gt(e).utc().format("ss");case"millisecond":return gt(e).utc().format("SSS");default:break}},date:e=>gt(e).utc().format(uS),date_format:(e,t)=>gt(e).utc().format(t),date_add:(e,t,r)=>gt(e).utc().add(t,r).valueOf(),date_sub:(e,t,r)=>gt(e).utc().subtract(t,r).valueOf(),date_diff:(e,t,r)=>{let n=gt(e).utc(),s=gt(t).utc();return r?n.diff(s,r,!0):n.diff(s)},now:()=>gt().utc().valueOf(),get_server_time:()=>gt().format(uS),offset_utc:(e,t)=>gt(e).utc().utcOffset(t).format(uS)}});var rD=g((P_e,tD)=>{"use strict";var XJ=require("@turf/area"),jJ=require("@turf/length"),ZJ=require("@turf/circle"),e4=require("@turf/difference"),t4=require("@turf/distance"),r4=require("@turf/boolean-contains"),n4=require("@turf/boolean-equal"),s4=require("@turf/boolean-disjoint"),i4=require("@turf/helpers"),ZC=U(),Te=J(),Is=K();tD.exports={geoArea:o4,geoLength:a4,geoCircle:c4,geoDifference:l4,geoDistance:eD,geoNear:u4,geoContains:_4,geoEqual:d4,geoCrosses:f4,geoConvert:E4};function o4(e){if(Te.isEmpty(e))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e));try{return XJ.default(e)}catch(t){return Is.trace(t,e),NaN}}a(o4,"geoArea");function a4(e,t){if(Te.isEmpty(e))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e));try{return jJ.default(e,{units:t||"kilometers"})}catch(r){return Is.trace(r,e),NaN}}a(a4,"geoLength");function c4(e,t,r){if(Te.isEmpty(e))return NaN;if(Te.isEmpty(t))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e));try{return ZJ.default(e,t,{units:r||"kilometers"})}catch(n){return Is.trace(n,e,t),NaN}}a(c4,"geoCircle");function l4(e,t){if(Te.isEmpty(e))return NaN;if(Te.isEmpty(t))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return e4(e,t)}catch(r){return Is.trace(r,e,t),NaN}}a(l4,"geoDifference");function eD(e,t,r){if(Te.isEmpty(e))return NaN;if(Te.isEmpty(t))return NaN;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return t4.default(e,t,{units:r||"kilometers"})}catch(n){return Is.trace(n,e,t),NaN}}a(eD,"geoDistance");function u4(e,t,r,n){if(Te.isEmpty(e)||Te.isEmpty(t))return!1;if(Te.isEmpty(r))throw new Error("distance is required");if(typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t)),isNaN(r))throw new Error("distance must be a number");try{return eD(e,t,n)<=r}catch(s){return Is.trace(s,e,t),!1}}a(u4,"geoNear");function _4(e,t){if(Te.isEmpty(e)||Te.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return r4.default(e,t)}catch(r){return Is.trace(r,e,t),!1}}a(_4,"geoContains");function d4(e,t){if(Te.isEmpty(e)||Te.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return n4.default(e,t)}catch(r){return Is.trace(r,e,t),!1}}a(d4,"geoEqual");function f4(e,t){if(Te.isEmpty(e)||Te.isEmpty(t)||e.coordinates&&e.coordinates.includes?.(null)||t.coordinates&&t.coordinates.includes?.(null))return!1;typeof e=="string"&&(e=Te.autoCastJSON(e)),typeof t=="string"&&(t=Te.autoCastJSON(t));try{return!s4.default(e,t)}catch(r){return Is.trace(r,e,t),!1}}a(f4,"geoCrosses");function E4(e,t,r){if(Te.isEmptyOrZeroLength(e))throw new Error("coordinates is required");if(Te.isEmpty(t))throw new Error("geo_type is required");if(Te.isEmpty(ZC.GEO_CONVERSION_ENUM[t]))throw new Error(`geo_type of ${t} is invalid please use one of the following types: ${Object.keys(ZC.GEO_CONVERSION_ENUM).join(",")}`);return typeof e=="string"&&(e=Te.autoCastJSON(e)),i4[t](e,r)}a(E4,"geoConvert")});var pd=g((v_e,nD)=>{var io=JC(),Kr=jC(),is=rD();nD.exports=e=>{e.aggr.mad=e.aggr.MAD=io.mad,e.aggr.mean=e.aggr.MEAN=io.mean,e.aggr.mode=e.aggr.MODE=io.mode,e.aggr.prod=e.aggr.PROD=io.prod,e.aggr.median=e.aggr.MEDIAN=io.median,e.fn.distinct_array=e.fn.DISTINCT_ARRAY=io.distinct_array,e.fn.search_json=e.fn.SEARCH_JSON=io.searchJSON,e.fn.__ala__=e,e.fn.current_date=e.fn.CURRENT_DATE=Kr.current_date,e.fn.current_time=e.fn.CURRENT_TIME=Kr.current_time,e.fn.extract=e.fn.EXTRACT=Kr.extract,e.fn.date=e.fn.DATE=Kr.date,e.fn.date_format=e.fn.DATE_FORMAT=Kr.date_format,e.fn.date_add=e.fn.DATE_ADD=Kr.date_add,e.fn.date_sub=e.fn.DATE_SUB=Kr.date_sub,e.fn.date_diff=e.fn.DATE_DIFF=e.fn.datediff=e.fn.DATEDIFF=Kr.date_diff,e.fn.now=e.fn.NOW=Kr.now,e.fn.offset_utc=e.fn.OFFSET_UTC=Kr.offset_utc,e.fn.get_server_time=e.fn.GET_SERVER_TIME=Kr.get_server_time,e.fn.getdate=e.fn.GETDATE=Kr.now,e.fn.current_timestamp=e.fn.CURRENT_TIMESTAMP=Kr.now,e.fn.geoarea=e.fn.GEOAREA=e.fn.geoArea=is.geoArea,e.fn.geocircle=e.fn.GEOCIRCLE=e.fn.geoCircle=is.geoCircle,e.fn.geocontains=e.fn.GEOCONTAINS=e.fn.geoContains=is.geoContains,e.fn.geoconvert=e.fn.GEOCONVERT=e.fn.geoConvert=is.geoConvert,e.fn.geocrosses=e.fn.GEOCROSSES=e.fn.geoCrosses=is.geoCrosses,e.fn.geodifference=e.fn.GEODIFFERENCE=e.fn.geoDifference=is.geoDifference,e.fn.geodistance=e.fn.GEODISTANCE=e.fn.geoDistance=is.geoDistance,e.fn.geoequal=e.fn.GEOEQUAL=e.fn.geoEqual=is.geoEqual,e.fn.geolength=e.fn.GEOLENGTH=e.fn.geoLength=is.geoLength,e.fn.geonear=e.fn.GEONEAR=e.fn.geoNear=is.geoNear}});var aD=g((B_e,oD)=>{"use strict";var dl=require("lodash"),gr=require("alasql");gr.options.cache=!1;var h4=pd(),sD=require("clone"),Sd=require("recursive-iterator"),fe=K(),Le=J(),aa=Ln(),m4=U(),{hdb_errors:p4}=se(),{getDatabases:iD}=(Ae(),ie(ke)),S4="IS NULL",vn="There was a problem performing this search. Please check the logs and try again.";h4(gr);var _S=class{static{a(this,"SQLSearch")}constructor(t,r){if(Le.isEmpty(t))throw fe.error("AST statement for SQL select process cannot be empty"),"statement cannot be null";this.statement=t,this.columns={},this.all_table_attributes=r,this.fetch_attributes=[],this.exact_search_values={},this.comparator_search_values={},this.tables=[],this.data={},this.has_aggregator=!1,this.has_ordinal=!1,this.has_outer_join=!1,this._getColumns(),this._getTables(),this._conditionsToFetchAttributeValues(),this._setAliasesForColumns(),Le.backtickASTSchemaItems(this.statement)}async search(){let t;try{let n=await this._checkEmptySQL();if(!Le.isEmptyOrZeroLength(n))return fe.trace("No results returned from checkEmptySQL SQLSearch method."),n}catch(n){throw fe.error("Error thrown from checkEmptySQL in SQLSearch class method search."),fe.error(n),new Error(vn)}try{let n=await this._getFetchAttributeValues();if(n)return n}catch(n){throw fe.error("Error thrown from getFetchAttributeValues in SQLSearch class method search."),fe.error(n),new Error(vn)}if(Object.keys(this.data).length===0)return fe.trace('SQLSearch class field: "data" is empty.'),[];let r;try{r=await this._processJoins()}catch(n){throw fe.error("Error thrown from processJoins in SQLSearch class method search."),fe.error(n),new Error(vn)}try{await this._getFinalAttributeData(r.existing_attributes,r.joined_length)}catch(n){throw fe.error("Error thrown from getFinalAttributeData in SQLSearch class method search."),fe.error(n),new Error(vn)}try{return t=await this._finalSQL(),t}catch(n){throw fe.error("Error thrown from finalSQL in SQLSearch class method search."),fe.error(n),new Error(vn)}}_getColumns(){let t=new Sd(this.statement);for(let{node:r,path:n}of t)r&&r.columnid&&(this.columns[n[0]]||(this.columns[n[0]]=[]),this.columns[n[0]].push(sD(r)))}_getTables(){let t=[];this.all_table_attributes.forEach(r=>{t.push(r.table)}),this.tables=dl.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=iD()[r.databaseid][r.tableid].primaryKey,this.data[n].__merged_data={},this.data[n].__merged_attributes=[],this.data[n].__merged_attr_map={}})}_conditionsToFetchAttributeValues(){if(Le.isEmpty(this.statement.where)){fe.trace('AST "where" statement is empty.');return}let t=!1;for(let{node:r}of new Sd(this.statement.where))if(r&&r.op&&r.op==="OR"&&(t=!0),!Le.isEmpty(r)&&r.right)if(Le.isNotEmptyAndHasValue(r.right.value)){let n=Le.autoCast(r.right.value);[!0,!1].indexOf(n)>=0&&(r.right=new gr.yy.LogicValue({value:n}))}else Array.isArray(r.right)&&r.right.forEach((n,s)=>{let i=Le.autoCast(n.value);[!0,!1].indexOf(i)>=0?r.right[s]=new gr.yy.LogicValue({value:i}):n instanceof gr.yy.StringValue&&Le.autoCasterIsNumberCheck(i.toString())&&(r.right[s]=new gr.yy.NumValue({value:i}))});if(t){fe.trace('Where clause contains "OR", exact match search not performed on attributes.');return}for(let{node:r}of new Sd(this.statement.where))if(r&&r.left&&r.right&&(r.left.columnid||r.right.value)&&r.op){let n=new Set,s=r.left.columnid?r.left:r.right,i=this._findColumn(s);if(!i)continue;let o=[i.table.databaseid,i.table.tableid,i.attribute].join("/");if(!Le.isEmpty(m4.VALUE_SEARCH_COMPARATORS_REVERSE_LOOKUP[r.op])){if(Le.isEmpty(this.comparator_search_values[o])&&(this.comparator_search_values[o]={ignore:!1,comparators:[]}),!this.comparator_search_values[o].ignore){if(Le.isEmptyOrZeroLength(r.left.columnid)||Le.isEmptyOrZeroLength(r.right.value)){this.comparator_search_values[o].ignore=!0,this.comparator_search_values[o].comparators=[];continue}this.comparator_search_values[o].comparators.push({attribute:r.left.columnid,operation:r.op,search_value:r.right.value})}continue}if(Le.isEmpty(this.exact_search_values[o])&&(this.exact_search_values[o]={ignore:!1,values:new Set}),!this.exact_search_values[o].ignore){let c=!1;switch(r.op){case"=":!Le.isEmpty(r.right.value)||!Le.isEmpty(r.left.value)?n.add(Le.isEmpty(r.right.value)?r.left.value:r.right.value):c=!0;break;case"IN":let l=Array.isArray(r.right)?r.right:r.left;for(let _=0;_<l.length;_++)if(l[_].value)n.add(l[_].value);else{c=!0;break}break;default:c=!0;break}this.exact_search_values[o].ignore=c,c?this.exact_search_values[o].values=new Set:this.exact_search_values[o].values=new Set([...this.exact_search_values[o].values,...n])}}}_setAliasesForColumns(){if(Le.isEmptyOrZeroLength(this.all_table_attributes)&&Le.isEmptyOrZeroLength(this.statement.from)&&Le.isEmptyOrZeroLength(this.columns.columns))return;let t=[],r={};this.statement.columns.forEach((n,s)=>{if(n.columnid==="*"){t.push(s);return}if(n.aggregatorid&&(this.has_aggregator=!0),!n.aggregatorid&&!n.funcid)if(n.as_orig=n.as?n.as:n.columnid,this.statement.joins)if(r[n.as_orig]>=0){let i=r[n.as_orig]+1;n.as=`[${n.as_orig+i}]`,r[n.as_orig]=i}else n.as=`[${n.as_orig}]`,r[n.as_orig]=0;else n.as=`[${n.as_orig}]`;!n.aggregatorid&&n.funcid&&n.args&&(n.as_orig=n.as?n.as:n.toString().replace(/'/g,'"'),n.as=`[${n.as_orig}]`),n.aggregatorid&&n.expression.columnid!=="*"&&(n.as_orig=n.as?n.as:n.expression.tableid?`${n.aggregatorid}(${n.expression.tableid}.${n.expression.columnid})`:`${n.aggregatorid}(${n.expression.columnid})`,n.as=`[${n.as_orig}]`)}),this.statement.columns.length>1&&t.length>0&&dl.pullAt(this.statement.columns,t)}_findColumn(t){let r=this.all_table_attributes.filter(n=>{if(t.columnid_orig&&t.tableid_orig)return(n.table.as===t.tableid_orig||n.table.tableid===t.tableid_orig)&&n.attribute===t.columnid_orig;if(t.tableid)return(n.table.as===t.tableid||n.table.tableid===t.tableid)&&n.attribute===t.columnid;let s=t.columnid_orig?t.columnid_orig:t.columnid;return n.attribute===s});if(Le.isEmptyOrZeroLength(r)){let n=this.columns.columns.filter(s=>s.as?t.columnid===s.as:!1);Le.isEmptyOrZeroLength(n)||(r=this.all_table_attributes.filter(s=>s.attribute===n[0].columnid&&n[0].tableid&&n[0].tableid===(s.table.as?s.table.as:s.table.tableid)))}return r[0]}async _checkEmptySQL(){let t=[];if(Le.isEmptyOrZeroLength(this.all_table_attributes)&&!Le.isEmptyOrZeroLength(this.columns.columns))return t;if(Le.isEmptyOrZeroLength(this.all_table_attributes)&&Le.isEmptyOrZeroLength(this.statement.from))try{let r=this._buildSQL(!1);t=await gr.promise(r)}catch(r){throw fe.error("Error thrown from AlaSQL in SQLSearch class method checkEmptySQL."),fe.error(r),new Error("There was a problem with the SQL statement")}return t}_addFetchColumns(t){t&&t.length>0&&t.forEach(r=>{let n=this._findColumn(r);n&&this.fetch_attributes.push(sD(n))})}_addColumnToMergedAttributes(t,r){this.data[t].__merged_attributes.push(r),this.data[t].__merged_attr_map[r]=this.data[t].__merged_attributes.length-1}_setMergedHashAttribute(t,r){this.data[t].__merged_data[r].splice(0,1,r)}_updateMergedAttribute(t,r,n,s){let i=this.data[t].__merged_attr_map[n];this.data[t].__merged_data[r].splice(i,1,s)}async _getFetchAttributeValues(){if(Le.isEmptyOrZeroLength(Object.keys(this.columns)))return[];this._addFetchColumns(this.columns.joins);let t=null;try{t=this.statement.where?this.statement.where.toString():""}catch{throw new Error("Could not generate proper where clause")}this.columns.where&&this._addFetchColumns(this.columns.where);let r=this._isSimpleSelect();if(r?this._addFetchColumns(this.columns.columns):(!this.columns.where&&this.fetch_attributes.length===0)|t.indexOf(S4)>-1&&this.tables.forEach(s=>{let i={columnid:iD()[s.databaseid][s.tableid].primaryKey,tableid:s.tableid};this._addFetchColumns([i])}),this.statement.order&&(this._updateOrderByToAliases(),this._addNonAggregatorsToFetchColumns()),this.fetch_attributes=dl.uniqBy(this.fetch_attributes,s=>[s.table.databaseid,s.table.as?s.table.as:s.table.tableid,s.attribute].join()),r)return await this._simpleSQLQuery();let n=this.fetch_attributes.reduce((s,i)=>{let o=`${i.table.databaseid}_${i.table.as?i.table.as:i.table.tableid}`,c=this.data[o].__hash_name;return s[o]||(s[o]=[],s[o].push(null),this._addColumnToMergedAttributes(o,c)),i.attribute!==c&&(s[o].push(null),this._addColumnToMergedAttributes(o,i.attribute)),s},{});for(let s of this.fetch_attributes){let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`,o=this.data[i].__hash_name,c={schema:s.table.databaseid,table:s.table.tableid,get_attributes:[s.attribute]},l=!1,_=[s.table.databaseid,s.table.tableid,s.attribute].join("/");if(s.attribute===o&&(l=!0),!Le.isEmpty(this.exact_search_values[_])&&!this.exact_search_values[_].ignore&&!Le.isEmptyOrZeroLength(this.exact_search_values[_].values))if(l)try{c.hash_values=Array.from(this.exact_search_values[_].values);let u=await aa.getDataByHash(c);for(let d of c.hash_values)u.get(d)&&!this.data[i].__merged_data[d]&&(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d))}catch(u){throw fe.error("Error thrown from getDataByHash function in SQLSearch class method getFetchAttributeValues exact match."),fe.error(u),new Error(vn)}else try{c.search_attribute=s.attribute,await Promise.all(Array.from(this.exact_search_values[_].values).map(async u=>{let d=Object.assign({},c);d.search_value=u;let E=await aa.getDataByValue(d);for(let[f,h]of E)this.data[i].__merged_data[f]?this._updateMergedAttribute(i,f,s.attribute,h[s.attribute]):(this.data[i].__merged_data[f]=[...n[i]],this._updateMergedAttribute(i,f,s.attribute,h[s.attribute]),this._setMergedHashAttribute(i,f))}))}catch(u){throw fe.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues exact match."),fe.error(u),new Error(vn)}else if(!Le.isEmpty(this.comparator_search_values[_])&&!this.comparator_search_values[_].ignore&&!Le.isEmptyOrZeroLength(this.comparator_search_values[_].comparators))try{let u=this.comparator_search_values[_].comparators;for(let d=0,E=u.length;d<E;d++){let f=u[d];c.search_attribute=f.attribute,c.search_value=f.search_value;let h=await aa.getDataByValue(c,f.operation);if(l)for(let[p]of h)this.data[i].__merged_data[p]||(this.data[i].__merged_data[p]=[...n[i]],this._setMergedHashAttribute(i,p));else for(let[p,S]of h)this.data[i].__merged_data[p]?this._updateMergedAttribute(i,p,s.attribute,S[s.attribute]):(this.data[i].__merged_data[p]=[...n[i]],this._updateMergedAttribute(i,p,s.attribute,S[s.attribute]),this._setMergedHashAttribute(i,p))}}catch(u){throw fe.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues comparator search values."),fe.error(u),new Error(vn)}else try{c.search_attribute=s.attribute,c.search_value="*";let u=await aa.getDataByValue(c);if(l)for(let[d]of u)this.data[i].__merged_data[d]||(this.data[i].__merged_data[d]=[...n[i]],this._setMergedHashAttribute(i,d));else for(let[d,E]of u)this.data[i].__merged_data[d]?this._updateMergedAttribute(i,d,s.attribute,E[s.attribute]):(this.data[i].__merged_data[d]=[...n[i]],this._updateMergedAttribute(i,d,s.attribute,E[s.attribute]),this._setMergedHashAttribute(i,d))}catch(u){throw fe.error("Error thrown from getDataByValue function in SQLSearch class method getFetchAttributeValues no comparator search values."),fe.error(u),new Error(vn)}}}_isSimpleSelect(){let t=!0;return Object.keys(this.statement).length!==2||!this.statement.columns||!this.statement.from||this.statement.from.length!==1?(t=!1,t):(this.statement.columns.forEach(r=>{r instanceof gr.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 gr.yy.Column;s.columnid=n.as,s.columnid_orig=n.as_orig,t.expression=s}else{t.initial_select_column=Object.assign(new gr.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 gr.yy.FuncValue:new gr.yy.Column;t.initial_select_column=Object.assign(s,n)}})}_addNonAggregatorsToFetchColumns(){let r=this.statement.order.filter(n=>!n.is_aggregator&&!n.is_ordinal).map(n=>n.is_func?{columnid:n.initial_select_column.args.filter(i=>!!i.columnid_orig)[0].columnid_orig}:{columnid:n.expression.columnid_orig});this._addFetchColumns(r)}async _processJoins(){let t=[],r=[],n=this.statement.from[0],s=[n],i=["? "+(n.as?" AS "+n.as:n.tableid)];t.push(Object.values(this.data[`${n.databaseid_orig}_${n.as?n.as_orig:n.tableid_orig}`].__merged_data)),this.statement.joins&&this.statement.joins.forEach(f=>{f.joinmode&&f.joinmode!=="INNER"&&(this.has_outer_join=!0),s.push(f.table);let h=f.joinmode+" JOIN ? AS "+(f.as?f.as:f.table.tableid);f.on&&(h+=" ON "+f.on.toString()),i.push(h),t.push(Object.values(this.data[`${f.table.databaseid_orig}_${f.table.as?f.table.as_orig:f.table.tableid_orig}`].__merged_data))});let o=[],c={};s.forEach(f=>{let h=this.data[`${f.databaseid_orig}_${f.as?f.as_orig:f.tableid_orig}`].__hash_name,p=f.as?f.as_orig:f.tableid_orig;o.push({key:`'${p}.${h}'`,schema:f.databaseid_orig,table:f.as?f.as_orig:f.tableid_orig,keys:new Set}),r.push(`${f.as?f.as:f.tableid}.\`${h}\` AS "${p}.${h}"`),c[f.as?f.as_orig:f.tableid_orig]=this.data[`${f.databaseid_orig}_${f.as?f.as_orig:f.tableid_orig}`].__merged_attributes});let l=this.statement.where?"WHERE "+this.statement.where:"";l=l.replace(/NOT\(NULL\)/g,"NOT NULL");let _="";this.statement.order&&!this.has_ordinal&&!this.has_aggregator&&!this.statement.group&&this.statement.limit&&(_="ORDER BY "+this.statement.order.toString(),this.statement.order.forEach(f=>{f.is_func?r.push(f.initial_select_column.toString()):f.initial_select_column.tableid?r.push(`${f.initial_select_column.tableid}.${f.initial_select_column.columnid} AS ${f.expression.columnid}`):r.push(`${f.initial_select_column.columnid} AS ${f.expression.columnid}`)}));let u="",d="";!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&!this.statement.joins&&(u=this.statement.limit?"LIMIT "+this.statement.limit:"",d=this.statement.offset?"OFFSET "+this.statement.offset:"");let E=[];try{let f=`SELECT ${r.join(", ")} FROM ${i.join(" ")} ${l} ${_} ${u} ${d}`,h=this._convertColumnsToIndexes(f,s);E=await gr.promise(h,t),t=null}catch(f){throw fe.error("Error thrown from AlaSQL in SQLSearch class method processJoins."),fe.error(f),new Error("There was a problem processing the data.")}if(E&&E.length>0){for(let f=0,h=E.length;f<h;f++){let p=E[f];o.forEach(S=>{p[S.key]!==null&&p[S.key]!==void 0&&S.keys.add(p[S.key])})}o.forEach(f=>{let h=Object.keys(this.data[`${f.schema}_${f.table}`].__merged_data),p=dl.difference(h,[...f.keys].map(S=>S.toString()));for(let S=0,T=p.length;S<T;S++){let A=p[S];delete this.data[`${f.schema}_${f.table}`].__merged_data[A]}})}return{existing_attributes:c,joined_length:E?E.length:0}}async _getFinalAttributeData(t,r){if(r===0)return;let n=[],s=new Sd(this.columns);for(let{node:i}of s)if(i&&i.columnid){let o=this._findColumn(i);if(o){let c=o.table.as?o.table.as:o.table.tableid;(!t[c]||t[c].indexOf(o.attribute)<0)&&n.push(o)}}n=dl.uniqBy(n,i=>[i.table.databaseid,i.table.as?i.table.as:i.table.tableid,i.attribute].join());try{await this._getData(n)}catch(i){throw fe.error("Error thrown from getData in SQLSearch class method getFinalAttributeData."),fe.error(i),new Error(vn)}}async _getData(t){try{let r=t.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]?n[i].columns.push(s.attribute):n[i]={schema:s.table.databaseid,table:s.table.tableid,columns:[s.attribute]},n},{});for(let n in r){let s=r[n],i=this.data[n].__merged_data,o=[];for(let u in i)o.push(i[u][0]);this.data[n].__merged_attributes.push(...s.columns);let c={schema:s.schema,table:s.table,hash_values:o,get_attributes:s.columns},l=await aa.getDataByHash(c),_=s.columns.length;for(let u=0,d=o.length;u<d;u++){let E=o[u],f=l.get(E);for(let h=0;h<_;h++){let p=s.columns[h],S=f[p]===void 0?null:f[p];this.data[n].__merged_data[E].push(S)}}}}catch(r){throw fe.error("Error thrown from getDataByHash function in SQLSearch class method getData."),fe.error(r),r}}async _finalSQL(){let t=[],r=this.statement.from[0];t.push(Object.values(this.data[`${r.databaseid_orig}_${r.as?r.as_orig:r.tableid_orig}`].__merged_data)),r.as=r.as?r.as:r.tableid,r.databaseid="",r.tableid="?",this.statement.joins&&this.statement.joins.forEach(s=>{s.as=s.as?s.as:s.table.tableid,t.push(Object.values(this.data[`${s.table.databaseid_orig}_${s.table.as?s.table.as_orig:s.table.tableid_orig}`].__merged_data)),s.table.databaseid="",s.table.tableid="?"}),this.statement.order&&this.statement.order.forEach(s=>{if(s.is_ordinal)return;this.statement.columns.filter(o=>{let c=o.aggregatorid?o.expression:o,l=o.aggregatorid?o.as_orig:c.as_orig;return s.expression.tableid?c.columnid_orig===s.expression.columnid_orig&&c.tableid_orig===s.expression.tableid_orig:c.columnid_orig===s.expression.columnid_orig||s.expression.columnid_orig===l}).length===0&&(s.expression.columnid=s.initial_select_column.columnid)}),!this.has_aggregator&&!this.statement.group&&!this.has_ordinal&&this.statement.limit&&!this.statement.joins&&(delete this.statement.limit,delete this.statement.offset);let n;try{let s=this._buildSQL();fe.trace(`Final SQL: ${s}`),n=await gr.promise(s,t),this.has_outer_join&&(n=this._translateUndefinedValues(n)),fe.trace(`Final AlaSQL results data included ${n.length} rows`)}catch(s){throw fe.error("Error thrown from AlaSQL in SQLSearch class method finalSQL."),fe.error(s),new Error("There was a problem running the generated sql.")}return n}_translateUndefinedValues(t){try{let r=[];for(let n of t){let s=Object.create(null);Object.keys(n).forEach(i=>{n[i]===void 0?s[i]=null:s[i]=n[i]}),r.push(s)}return r}catch(r){return fe.error(p4.HDB_ERROR_MSGS.OUTER_JOIN_TRANSLATION_ERROR),fe.trace(r.stack),t}}_buildSQL(t=!0){let r=this.statement.toString();return r=r.replace(/NOT\(NULL\)/g,"NOT NULL"),this.statement.columns.forEach(n=>{if(n.funcid&&n.as){let s=n.toString().replace(" AS "+n.as,"");r=r.replace(n.toString(),s)}}),t===!0?this._convertColumnsToIndexes(r,this.tables):r}_convertColumnsToIndexes(t,r){let n=t,s={};r.forEach(i=>{i.databaseid_orig?s[`${i.databaseid_orig}_${i.as?i.as_orig:i.tableid_orig}`]=i.as?i.as:i.tableid:s[`${i.databaseid}_${i.as?i.as:i.tableid}`]=`\`${i.as?i.as:i.tableid}\``});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=s[i],_=new RegExp(`${l}.\`${o}\``,"g"),u=`${l}.[${c}]`;n=n.replace(_,u)});for(let i in this.data)this.data[i].__merged_attributes.forEach((o,c)=>{let l=new RegExp(`\`${o}\``,"g"),_=`[${c}]`;n=n.replace(l,_)});return n}async _simpleSQLQuery(){let t=this.statement.columns.reduce((n,s)=>(s.as_orig&&s.as_orig!=s.columnid_orig?n[s.columnid_orig]=s.as_orig:n[s.columnid_orig]||(n[s.columnid_orig]=s.columnid_orig),n),{}),r=this.fetch_attributes.reduce((n,s)=>{let i=`${s.table.databaseid}_${s.table.as?s.table.as:s.table.tableid}`;return n[i]||(n[i]={}),n[i][t[s.attribute]]=null,n},{});for(let n of this.fetch_attributes){let s=`${n.table.databaseid}_${n.table.as?n.table.as:n.table.tableid}`,i={schema:n.table.databaseid,table:n.table.tableid,get_attributes:[n.attribute]};try{i.search_attribute=n.attribute,i.search_value="*";let o=await aa.getDataByValue(i);for(let[c,l]of o)this.data[s].__merged_data[c]||(l[n.attribute]===void 0&&(l[n.attribute]=null),this.data[s].__merged_data[c]=Object.assign({},r[s])),this.data[s].__merged_data[c][t[n.attribute]]=l[n.attribute]??null}catch(o){throw fe.error("There was an error when processing this SQL operation. Check your logs"),fe.error(o),new Error(vn)}}return Object.values(Object.values(this.data)[0].__merged_data)}};oD.exports=_S});var kr=g((x_e,cD)=>{"use strict";var T4=iy();cD.exports={searchByConditions:R4,searchByHash:A4,searchByValue:O4,search:b4};var dS=Ln(),{transformReq:fS}=J(),g4=aD();async function R4(e){return fS(e),dS.searchByConditions(e)}a(R4,"searchByConditions");async function A4(e){fS(e),e.ids&&(e.hash_values=e.ids);let t=[];for await(let r of dS.searchByHash(e))r&&t.push(r);return t}a(A4,"searchByHash");async function O4(e){fS(e),e.hasOwnProperty("desc")===!0&&(e.reverse=e.desc);let t=[];for await(let r of dS.searchByValue(e))t.push(r);return t}a(O4,"searchByValue");function b4(e,t){try{let r=new T4(e);r.validate(),new g4(r.statement,r.attributes).search().then(s=>{t(null,s)}).catch(s=>{t(s,null)})}catch(r){return t(r)}}a(b4,"search")});var Td=g((F_e,lD)=>{"use strict";var y4=Ln();lD.exports={writeTransaction:N4};function N4(e,t,r){return y4.writeTransaction(e,t,r)}a(N4,"writeTransaction")});var fD=g((V_e,dD)=>{"use strict";var I4=kr(),w4=ii(),uD=K(),C4=un(),k_e=Td(),D4=require("clone"),hS=require("alasql"),L4=pd(),_D=require("util"),M4=_D.promisify(w4.getTableSchema),P4=_D.promisify(I4.search),U4=U(),ES=J();L4(hS);dD.exports={update:B4};var v4="There was a problem performing this update. Please check the logs and try again.";async function B4({statement:e,hdb_user:t}){let r=await M4(e.table.databaseid,e.table.tableid),n=H4(e.columns);ES.backtickASTSchemaItems(e);let{table:s,where:i}=e,o=D4(s),c=ES.isEmpty(i)?"":` WHERE ${i.toString()}`,l=`SELECT ${r.hash_attribute} FROM ${s.toString()} ${c}`,_=hS.parse(l).statements[0],u=await P4(_),d=x4(n,u);return G4(o,d,t)}a(B4,"update");function H4(e){try{let t={};return e.forEach(r=>{"value"in r.expression?t[r.column.columnid]=r.expression.value??null:t[r.column.columnid]=hS.compile(`SELECT ${r.expression.toString()} AS [${U4.FUNC_VAL}] FROM ?`)}),t}catch(t){throw uD.error(t),new Error(v4)}}a(H4,"createUpdateRecord");function x4(e,t){return ES.isEmptyOrZeroLength(t)?[]:t.map(r=>Object.assign(r,e))}a(x4,"buildUpdateRecords");async function G4(e,t,r){let n={operation:"update",schema:e.databaseid_orig,table:e.tableid_orig,records:t,hdb_user:r},s=await C4.update(n);try{delete s.new_attributes,delete s.txn_time}catch(i){uD.error(`Error delete new_attributes from update response: ${i}`)}return s}a(G4,"updateRecords")});var hD=g((W_e,ED)=>{var F4=require("alasql"),q4=kr(),k4=K(),V4=Ln(),pS=require("util"),mS=J(),$4=U(),Y4=ii(),Y_e=Td(),K_e=un(),K4="record",W4="successfully deleted",Q4=pS.callbackify(j4),z4=pS.promisify(q4.search),J4=pS.promisify(Y4.getTableSchema);ED.exports={convertDelete:Q4};function X4(e){return`${e.deleted_hashes.length} ${K4}${e.deleted_hashes.length===1?"":"s"} ${W4}`}a(X4,"generateReturnMessage");async function j4({statement:e,hdb_user:t}){let r=await J4(e.table.databaseid,e.table.tableid);mS.backtickASTSchemaItems(e);let{table:n,where:s}=e,i=mS.isEmpty(s)?"":` WHERE ${s.toString()}`,o=`SELECT ${r.hash_attribute} FROM ${n.toString()} ${i}`,c=F4.parse(o).statements[0],l={operation:$4.OPERATIONS_ENUM.DELETE,schema:n.databaseid_orig,table:n.tableid_orig,hdb_user:t};try{l.records=await z4(c);let _=await V4.deleteRecords(l);return mS.isEmptyOrZeroLength(_.message)&&(_.message=X4(_)),delete _.txn_time,_}catch(_){throw k4.error(_),_.hdb_code?_.message:_}}a(j4,"convertDelete")});var gD=g((z_e,TD)=>{"use strict";var Z4=si(),{hdb_errors:mD}=se(),{getDatabases:pD}=(Ae(),ie(ke));TD.exports={checkSchemaExists:SD,checkSchemaTableExists:e3,schema_describe:Z4};async function SD(e){if(!pD()[e])return mD.HDB_ERROR_MSGS.SCHEMA_NOT_FOUND(e)}a(SD,"checkSchemaExists");async function e3(e,t){let r=await SD(e);if(r)return r;if(!pD()[e][t])return mD.HDB_ERROR_MSGS.TABLE_NOT_FOUND(e,t)}a(e3,"checkSchemaTableExists")});var fl=g((X_e,t3)=>{t3.exports={name:"harperdb",version:"4.3.41",description:"HarperDB is a distributed database, caching service, streaming broker, and application development platform focused on performance and ease of use.",keywords:["database","nosql","api","distributed","broker","mqtt","real-time","enterprise","Fastify","NATS","HarperDB","Harper","clustering","replication","REST","WebSockets","decentralized","server-sent events","document store"],main:"harperdb.js",bin:{harperdb:"./bin/harperdb.js"},engines:{"minimum-node":"16.0.0","go-lang":"1.21.7","nats-server":"2.10.11"},exports:{".":"./index.js"},homepage:"https://www.harperdb.io/",bugs:"support@harperdb.io",author:{name:"HarperDB",email:"support@harperdb.io"},license:"SEE LICENSE IN LICENSE",scripts:{submodules:"git submodule update --init --recursive",build:"eslint -c ./.eslintbuild bin/ dataLayer/ security/ server/ sqlTranslator/ upgrade/ utility/ validation/",pretty:"eslint --fix bin/ dataLayer/ security/ server/ sqlTranslator/ upgrade/ utility/ validation/","cover:test":"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && nyc --no-clean --reporter=lcovonly npm run test:apitests && nyc --no-clean --reporter=lcovonly npm run test:resources && nyc --no-clean --reporter=lcovonly npm run test:logging && nyc --no-clean --reporter=lcovonly npm run test:upgrade && nyc --no-clean --reporter=lcovonly npm run test:nats && nyc --no-clean --reporter=lcovonly npm run test:cfserver && nyc --no-clean --reporter=lcovonly npm run test:hdbserver && nyc --no-clean --reporter=lcovonly npm run test:bin && nyc --no-clean --reporter=lcovonly npm run test:main && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license",test:"pm2 kill && rimraf ./.nyc_output/* && node utility/devops/register.js --reset_license && npm run test:apitests && npm run test:resources && npm run test:logging && npm run test:upgrade && npm run test:nats && npm run test:cfserver && npm run test:hdbserver && npm run test:bin && npm run test:main && nyc merge .nyc_output coverage.json && node ./utility/devops/register.js --reset_license","test:resources":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/resources/**/*.js' --config '../unitTests/.mocharc.json'","test:bin":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/bin/**/*.js' --config '../unitTests/.mocharc.json'","test:main":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --config '../unitTests/.mocharc-main.json'","test:lmdbbridge":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --config '../unitTests/.mocharc.json'","test:lmdbutility":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --config '../unitTests/.mocharc.json'","test:hdbserver":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --config '../unitTests/.mocharc.json'","test:cfserver":"npm run submodules && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/fastifyRoutes/customFunctionsServer-test.js' --config '../unitTests/.mocharc.json'","test:nats":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json'","test:upgrade":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --config '../unitTests/.mocharc.json'","test:apitests":"pm2 kill && cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/apiTests/**/*-test.mjs' --config '../unitTests/.mocharc.json'","test:logging":"cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/utility/logging/*.js' --config '../unitTests/.mocharc.json'","test:ci":" cd bin/ && ../node_modules/mocha/bin/_mocha '../unitTests/**/*.js' --retries 3 --config '../unitTests/.mocharc-main.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/dataLayer/harperBridge/lmdbBridge/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/utility/lmdb/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/harperdb/hdbServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/customFunctions/customFunctionsServer-test.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/upgrade/**/*.js' --parallel --retries 3 --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter && ../node_modules/mocha/bin/_mocha '../unitTests/server/nats/**/*.js' --config '../unitTests/.mocharc.json' --reporter mocha-teamcity-reporter","hdb-check":"./utility/devops/hdb-check.sh","download-prebuilds":"node ./utility/devops/build/download-prebuilds.js",prebuild:"date",postinstall:"node ./launchServiceScripts/launchInstallNATSServer.js",build_nats_dependency:"node ./utility/devops/nats/builder.js",coverage:"nyc --reporter=lcov npm test"},dependencies:{"@aws-sdk/client-s3":"3.635.0","@aws-sdk/lib-storage":"3.635.0","@endo/static-module-record":"^1.0.4","@fastify/autoload":"5.7.1","@fastify/compress":"~6.5.0","@fastify/cors":"~8.5.0","@fastify/static":"~6.12.0","@turf/area":"6.5.0","@turf/boolean-contains":"6.5.0","@turf/boolean-disjoint":"6.5.0","@turf/boolean-equal":"6.5.0","@turf/circle":"6.5.0","@turf/difference":"6.5.0","@turf/distance":"6.5.0","@turf/helpers":"6.5.0","@turf/length":"6.5.0",alasql:"4.1.10","cbor-x":"1.5.8",chalk:"4.1.2","cli-progress":"3.12.0",clone:"2.1.2","fast-glob":"3.3.2",fastify:"~4.26.2","fastify-plugin":"~4.5.1","fs-extra":"11.2.0",graphql:"^16.8.1","human-readable-ids":"1.0.4",inquirer:"8.2.6","is-number":"7.0.0",joi:"17.12.2","json-bigint-fixes":"1.1.0",json2csv:"5.0.7",jsonata:"1.8.7",jsonwebtoken:"9.0.2",lmdb:"3.2.5",lodash:"4.17.21",mathjs:"11.12.0",minimist:"1.2.8",mkcert:"1.5.1",moment:"2.30.1","mqtt-packet":"~8.2.1",msgpackr:"1.11.2",nats:"2.19.0",needle:"3.3.1","node-stream-zip":"1.15.0","node-unix-socket":"0.2.5","normalize-path":"^3.0.0",ora:"5.4.1","ordered-binary":"1.5.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:"^0.18.0","serve-static":"1.15.0",ses:"1.1.0","stream-chain":"2.2.5","stream-json":"1.8.0",systeminformation:"5.22.9","tar-fs":"2.1.1",ulidx:"0.5.0",uuid:"9.0.1","validate.js":"0.13.1",ws:"8.17.1",yaml:"2.4.1"},devDependencies:{"@tsconfig/node16":"^1.0.3","@types/node":"latest","@typescript-eslint/eslint-plugin":"^5.55.0","@typescript-eslint/parser":"^5.55.0",axios:"1.6.8",chai:"4.4.1","chai-integer":"0.1.0",esbuild:"^0.20.2",eslint:"8.22.0","eslint-config-prettier":"8.3.0","eslint-plugin-prettier":"3.4.1","eslint-plugin-radar":"0.2.1",eventsource:"^2.0.2","hook-std":"3.0.0","intercept-stdout":"0.1.2",mocha:"^10.3.0","mocha-teamcity-reporter":"3.0.0","mock-require":"3.0.3","mock-stdin":"1.0.0",mqtt:"~4.3.8",newman:"5.3.2","newman-reporter-html":"1.0.5","newman-reporter-htmlextra":"1.22.11","newman-reporter-teamcity":"0.1.12","node-fetch":"2.6.7",nyc:"15.1.0",prettier:"2.8.4",rewire:"5.0.0",rimraf:"3.0.2",sinon:"10.0.0","sinon-chai":"3.7.0","source-map-support":"^0.5.21",typescript:"^5.4.2","why-is-node-still-running":"^1.0.0"},overrides:{"eslint-plugin-radar":{eslint:"8.22.0"},alasql:{xlsx:"0.18.5"}},optionalDependencies:{bufferutil:"^4.0.7","utf-8-validate":"^5.0.10"}}});var Sl={};qe(Sl,{addAnalyticsListener:()=>pl,recordAction:()=>nr,recordActionBinary:()=>Wr,setAnalyticsEnabled:()=>r3});function r3(e){CD=e}function nr(e,t,r,n,s){if(!CD)return;let i=t+(r?"-"+r:"");n!==void 0&&(i+="-"+n),s!==void 0&&(i+="-"+s);let o=Ad.get(i);if(o)if(typeof e=="number"){let c=o.values,l=c.index++;if(l>=c.length){let _=c;o.values=c=new Float32Array(l*2),c.set(_),c.index=l+1}c[l]=e,o.total+=e}else if(typeof e=="boolean")e&&o.total++,o.count++;else if(typeof e=="function")o.count++;else throw new TypeError("Invalid metric value type "+typeof e);else{if(typeof e=="number")o={total:e,values:new Float32Array(4)},o.values.index=1,o.values[0]=e,o.total=e;else if(typeof e=="boolean")o={},o.total=e?1:0,o.count=1;else if(typeof e=="function")o={},o.count=1,o.callback=e;else throw new TypeError("Invalid metric value type "+typeof e);o.description={metric:t,path:r,method:n,type:s},Ad.set(i,o)}gd||n3()}function Wr(e,t,r,n,s){nr(!!e,t,r,n,s)}function pl(e){MD.push(e)}function n3(){gd=performance.now(),setTimeout(async()=>{let e=performance.now()-gd;gd=0;let t=[],r={time:Date.now(),period:e,threadId:oo.threadId,metrics:t};for(let[s,i]of Ad){if(i.values){let o=i.values.subarray(0,i.values.index);o.sort();let c=o.length,l=0,_=[],u;for(let d of PD){let E=Math.floor(c*d),f=o[E-1];if(E>l){let h=E-l;if(f===u){let p=_[_.length-1];typeof p=="number"?_[_.length-1]={value:p,count:1+h}:p.count+=h}else _.push(h>1?{value:f,count:h}:f),u=f;l=E}}t.push(Object.assign(i.description,{mean:i.total/c,distribution:_,count:c}))}else i.callback?t.push(Object.assign(i.description,i.callback(i))):t.push(Object.assign(i.description,{total:i.total,count:i.count}));await UD()}let n=process.memoryUsage();t.push({metric:"memory",threadId:oo.threadId,byThread:!0,...n});for(let s of MD)s(t);Ad=new Map,oo.parentPort?oo.parentPort.postMessage({type:LD,report:r}):HD({report:r})},DD).unref()}async function s3(e,t=6e4){let r=gS(),n=vD(),s=new Promise(p=>{let S=performance.now();setImmediate(()=>{let T=performance.now();T-S>5e3&&(0,El.warn)("Unusually high event queue latency on the main thread of "+Math.round(T-S)+"ms"),S=performance.now()}),n.primaryStore.prefetch([1],()=>{let T=performance.now();T-S>5e3&&(0,El.warn)("Unusually high task queue latency on the main thread of "+Math.round(T-S)+"ms"),p(T-S)})}),i;for(let p of n.primaryStore.getRange({start:1/0,end:!1,reverse:!0}))if(p.value?.time){i=p.value.time;break}if(Date.now()-t<i)return;let o,c=new Map,l=new Map,_=[],u;for(let{key:p,value:S}of r.primaryStore.getRange({start:i||!1,exclusiveStart:!0,end:1/0})){if(!S)continue;if(o){if(p>o+t)break}else o=p;u=p;let{metrics:T,threadId:A}=S;for(let N of T||[]){let{path:b,method:v,type:P,metric:q,count:M,total:Q,distribution:z,threads:j,...oe}=N;M||(M=1);let le=q+(b?"-"+b:"");v!==void 0&&(le+="-"+v),P!==void 0&&(le+="-"+P);let ue=c.get(le);if(ue){if(ue.threads){let Ne=ue.threads[A];if(Ne)ue=Ne;else{ue.threads[A]=Object.assign({},oe);continue}}ue.count||(ue.count=1);let Be=ue.count;for(let Ne in oe){let He=oe[Ne];typeof He=="number"&&(ue[Ne]=(ue[Ne]*Be+He*M)/(Be+M))}ue.count+=M,Q>=0&&(ue.total+=Q,ue.ratio=ue.total/ue.count)}else ue=Object.assign({period:t},N),delete ue.distribution,c.set(le,ue),ue.byThread&&(ue.threads=[],ue.threads[A]=Object.assign({},oe),_.push(ue));if(z){z=z.map(Ne=>typeof Ne=="number"?{value:Ne,count:1}:Ne);let Be=l.get(le);Be?Be.push(...z):l.set(le,z)}}await UD()}for(let p of _){let{path:S,method:T,type:A,metric:N,count:b,total:v,distribution:P,threads:q,...M}=p;q=q.filter(Q=>Q);for(let Q in M){if(typeof p[Q]!="number")continue;let z=0;for(let j of q){let oe=j[Q];typeof oe=="number"&&(z+=oe)}p[Q]=z}p.count=q.length,delete p.threads,delete p.byThread}for(let[p,S]of l){let T=c.get(p);S.sort((Ne,He)=>Ne.value>He.value?1:-1);let A=T.count-1,N=[],b=0,v=0,P;for(let Ne of PD){let He=A*Ne;for(;b<He;)P=S[v++],b+=P.count,v===1&&b--;let zu=S[v>1?v-2:0];P||(P=S[0]),N.push(P.value-(P.value-zu.value)*(b-He)/P.count)}let[q,M,Q,z,j,oe,le,ue,Be]=N;Object.assign(T,{p1:q,p10:M,p25:Q,median:z,p75:j,p90:oe,p95:le,p99:ue,p999:Be})}let d;for(let[p,S]of c)S.id=(0,Rd.getNextMonotonicTime)(),S.time=u,n.primaryStore.put(S.id,S,{append:!0}).then(T=>{T||n.primaryStore.put(S.id,S)}),d=!0;let E=Date.now(),{idle:f,active:h}=performance.eventLoopUtilization();if(d||h*10>f){let p=(0,Rd.getNextMonotonicTime)(),S={id:p,metric:"main-thread-utilization",idle:f-RD,active:h-AD,taskQueueLatency:await s,time:E,...process.memoryUsage()};n.primaryStore.put(p,S,{append:!0}).then(T=>{T||n.primaryStore.put(p,S)})}RD=f,AD=h}async function OD(e,t){let r=Date.now()-t;for(let n of e.primaryStore.getKeys({start:!1,end:r}))e.primaryStore.remove(n)}function gS(){return bD||(bD=ft({table:"hdb_raw_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"action"},{name:"metrics"}]}))}function vD(){return yD||(yD=ft({table:"hdb_analytics",database:"system",audit:!1,trackDeletes:!1,attributes:[{name:"id",isPrimaryKey:!0},{name:"metric"},{name:"path"},{name:"method"},{name:"type"}]}))}function a3(){BD=!0;let e=(0,ml.get)(TS.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)*1e3;e&&setInterval(async()=>{await s3(DD,e),await OD(gS(),i3),await OD(vD(),o3)},Math.min(e/2,2147483647)).unref()}function HD(e,t){let r=e.report;r.threadId=t?.threadId||oo.threadId;for(let n of r.metrics)n.metric==="bytes-sent"&&(ND+=n.mean*n.count);r.totalBytesProcessed=ND,t&&(r.metrics.push({metric:"utilization",...t.performance.eventLoopUtilization(ID.get(t))}),ID.set(t,t.performance.eventLoopUtilization())),r.id=(0,Rd.getNextMonotonicTime)(),gS().primaryStore.put(r.id,r),BD||a3(),c3&&(xD=u3(r))}async function u3(e){if(await xD,!_i){let r=(0,hl.dirname)((0,El.getLogFilePath)());try{_i=await(0,SS.open)((0,hl.join)(r,"analytics.log"),"r+")}catch{_i=await(0,SS.open)((0,hl.join)(r,"analytics.log"),"w+")}}let t=(await _i.stat()).size;if(t>l3){let r=Buffer.alloc(t);await _i.read(r,{position:0}),r=r.subarray(r.indexOf(10,r.length/2)+1),await _i.write(r,{position:0}),await _i.truncate(r.length),t=r.length}await _i.write(JSON.stringify(e)+`
|
|
10
10
|
`,t)}var oo,wD,El,hl,SS,Rd,ml,TS,Ad,CD,gd,DD,LD,MD,PD,RD,AD,UD,i3,o3,bD,yD,BD,ND,ID,c3,xD,_i,l3,ws=Re(()=>{oo=require("worker_threads"),wD=x(ot());Ae();El=x(K()),hl=require("path"),SS=require("fs/promises"),Rd=x(xr()),ml=x(ne()),TS=x(U());fr();(0,ml.initSync)();Ad=new Map,CD=(0,ml.get)(TS.CONFIG_PARAMS.ANALYTICS_AGGREGATEPERIOD)>-1;a(r3,"setAnalyticsEnabled");a(nr,"recordAction");it.recordAnalytics=nr;a(Wr,"recordActionBinary");gd=0,DD=1e3,LD="analytics-report",MD=[];a(pl,"addAnalyticsListener");PD=[.01,.1,.25,.5,.75,.9,.95,.99,.999,1];a(n3,"sendAnalytics");a(s3,"aggregation");RD=0,AD=0,UD=a(()=>new Promise(setImmediate),"rest");a(OD,"cleanup");i3=36e5,o3=31536e6;a(gS,"getRawAnalyticsTable");a(vD,"getAnalyticsTable");(0,wD.setChildListenerByType)(LD,HD);a(a3,"startScheduledTasks");ND=0,ID=new Map,c3=!1;a(HD,"recordAnalytics");l3=1e6;a(u3,"logAnalytics")});var yS=g((ude,JD)=>{"use strict";var{decode:_3}=require("msgpackr"),{isMainThread:ade,parentPort:cde,threadId:lde}=require("worker_threads"),yd=wt(),ca=ct(),OS=U(),sr=K(),AS=ne(),d3=U(),{onMessageByType:f3}=ot(),kD=Os(),{recordAction:GD,recordActionBinary:E3}=(ws(),ie(Sl)),{publishToStream:h3}=yd,{ConsumerEvents:FD}=require("nats"),m3=kr(),{promisify:p3}=require("util"),VD=p3(setTimeout),Nd=1e4,Id,bd,S3,T3,$D,Tl=new Map,la=new Map;JD.exports={initialize:YD,ingestConsumer:bS,setSubscription:g3,setIgnoreOrigin:O3,getDatabaseSubscriptions:A3,updateConsumer:KD};async function YD(){f3(OS.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,async n=>{await KD(n)}),$D=!0,sr.notify("Initializing clustering ingest service.");let{connection:e,jsm:t,js:r}=await yd.getNATSReferences();Id=e,bd=e.info.server_name,S3=t,T3=r}a(YD,"initialize");async function KD(e){if(e.status==="start"){let{js:t,jsm:r}=await WD(e.node_domain_name);bS(e.stream_name,t,r,e.node_domain_name)}else if(e.status==="stop"){let t=Tl.get(e.stream_name+e.node_domain_name);t&&(sr.notify("Closing ingest consumer for node:",e.node_domain_name,"stream:",e.stream_name),await t.close?.(),Tl.set(e.stream_name+e.node_domain_name,"close")),la.get(e.node_domain_name)==="failed"&&la.set(e.node_domain_name,"close")}}a(KD,"updateConsumer");var wd=new Map;function g3(e,t,r){let n=wd.get(e);n||wd.set(e,n=new Map),n.set(t,r),$D||YD().then(R3)}a(g3,"setSubscription");async function R3(){let e=await m3.searchByValue({database:"system",table:"hdb_nodes",search_attribute:"name",search_value:"*"});for await(let t of e){let r=t.name+ca.SERVER_SUFFIX.LEAF,n,s;for(let i of t.subscriptions)if(i.subscribe===!0){if(!n&&({js:n,jsm:s}=await WD(r),!n))break;let{schema:o,table:c}=i,l=kD.createNatsTableStreamName(o,c);bS(l,n,s,r)}}}a(R3,"accessConsumers");async function WD(e){let t,r,n=1;for(;!r;)try{t=await Id.jetstream({domain:e}),r=await Id.jetstreamManager({domain:e,checkAPI:!1})}catch(s){if(la.get(e)==="close")break;la.set(e,"failed"),n%10===1&&sr.warn("Nats ingest attempting to connect to:",e,"Nats error:",s.message);let i=n++*100<Nd?n++*100:Nd;await VD(i)}return{js:t,jsm:r}}a(WD,"connectToRemoteJS");function A3(){return wd}a(A3,"getDatabaseSubscriptions");var QD;function O3(e){QD=e}a(O3,"setIgnoreOrigin");var zD=100,qD=new Array(zD),Od=0;async function bS(e,t,r,n){let{connection:s}=await yd.getNATSReferences();Id=s,bd=s.info.server_name;let i,o=1;for(;!i;)try{i=await t.consumers.get(e,bd),sr.notify("Initializing ingest consumer for node:",n,"stream:",e)}catch(_){if(la.get(n)==="close")break;o%10===1&&sr.warn("Nats ingest error getting consumer:",n,"stream:",e,"Nats error:",_.message),_.code==="404"&&(sr.notify("Nats ingest creating consumer for node:",n,"stream:",e),i=await yd.createConsumer(r,e,bd,new Date(Date.now()).toISOString()));let u=o++*100<Nd?o++*100:Nd;await VD(u)}let c=!1,l;for(;!c;){if(Tl.get(e+n)==="close"||la.get(n)==="close"){Tl.delete(e+n),c=!0;continue}l=await i.consume({max_messages:AS.get(OS.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXCONSUMEMSGS)??100,bind:!0}),Tl.set(e+n,l);let _=!1;(async()=>{for await(let u of await l.status())if(u.type===FD.ConsumerDeleted&&(await l.close(),c=!0),u.type===FD.HeartbeatsMissed){let d=u.data;sr.trace(`${d} clustering ingest consumer heartbeats missed, node: ${n} stream: ${l.consumer.stream}`),d===100&&(sr.warn(`Restarting clustering ingest consumer due to missed heartbeat threshold being met, node: ${n} stream: ${l.consumer.stream}`),l.stop(),_=!0)}})();try{for await(let u of l)await qD[Od],qD[Od]=b3(u).catch(d=>{sr.error(d)}),++Od>=zD&&(Od=0)}catch(u){u.message==="consumer deleted"?(sr.notify("Nats consumer deleted, closing messages for node:",n,"stream:",l.consumer.stream),await l.close(),c=!0):sr.error("Error consuming clustering ingest, restarting consumer",u)}}}a(bS,"ingestConsumer");async function b3(e){let t=_3(e.data);GD(e.data.length,"bytes-received",e.subject,t.operation,"ingest"),sr.trace("Nats message processor message size:",e?.msg?._msg?.size,"bytes");let r=e.headers,n=!1,s=AS.get(OS.CONFIG_PARAMS.CLUSTERING_NODENAME);r.has(ca.MSG_HEADERS.TRANSACTED_NODES)&&r.values(ca.MSG_HEADERS.TRANSACTED_NODES).indexOf(s)>-1&&(n=!0);let i=r.get(ca.MSG_HEADERS.ORIGIN);if(n||(n=i===s&&!QD),E3(n,"echo",e.subject,t.operation,"ingest"),n){e.ack();return}r.append(ca.MSG_HEADERS.TRANSACTED_NODES,s);try{let{operation:o,schema:c,next:l,table:_,records:u,hash_values:d,__origin:E,expiresAt:f}=t;sr.trace("processing message:",o,c,_,(u?"records: "+u.map(v=>v?.id):"")+(d?"ids: "+d:""),"with sequence:",e.seq),sr.trace(`messageProcessor nats msg id: ${e.headers.get(ca.MSG_HEADERS.NATS_MSG_ID)}`);let h;u||(u=d);let p=new Promise(v=>h=v),{timestamp:S,user:T,node_name:A}=E||{},N=wd.get(c)?.get(_);if(!N)throw new Error(`Missing table for replication message: ${_}`);if(o==="define_schema")t.type=o,t.onCommit=h,N.send(t);else if(u.length===1&&!l)N.send({type:RS(o),value:u[0],id:d?.[0],expiresAt:f,timestamp:S,table:_,onCommit:h,user:T,nodeName:A});else{let v=u.map((P,q)=>({type:RS(o),value:P,expiresAt:f,id:d?.[q],table:_}));for(;l;)v.push({type:RS(l.operation),value:l.record,expiresAt:l.expiresAt,id:l.id,table:l.table}),l=l.next;N.send({type:"transaction",writes:v,table:_,timestamp:S,onCommit:h,user:T,nodeName:A})}AS.get(d3.CONFIG_PARAMS.CLUSTERING_REPUBLISHMESSAGES)!==!1&&h3(e.subject.split(".").slice(0,-1).join("."),kD.createNatsTableStreamName(c,_),e.headers,e.data),await p;let b=Date.now()-S;S&&GD(b,"replication-latency",e.subject,o,"ingest")}catch(o){sr.error(o)}e.ack()}a(b3,"messageProcessor");function RS(e){switch(e){case"insert":case"upsert":case"update":return"put"}return e}a(RS,"convertOperation")});var wt=g((pde,fL)=>{"use strict";var xt=ne();xt.initSync();var y3=require("fs-extra"),N3=require("semver"),Al=require("path"),{monotonicFactory:I3}=require("ulidx"),jD=I3(),w3=require("util"),ZD=require("child_process"),C3=w3.promisify(ZD.exec),D3=ZD.spawn,Wt=ct(),Ie=U(),Cd=J(),Bn=K(),Dd=Os(),L3=Td(),gl=hr(),{broadcast:M3,onMessageByType:P3,getWorkerIndex:U3}=ot(),{isMainThread:eL}=require("worker_threads"),{Encoder:v3,decode:CS}=require("msgpackr"),tL=new v3,{isEmpty:uo}=Cd,rL=_n(),dde=48*36e11;eL&&P3(Ie.ITC_EVENT_TYPES.RESTART,()=>{ir=void 0,lo=void 0});var{connect:B3,StorageType:H3,RetentionPolicy:x3,AckPolicy:DS,DeliverPolicy:LS,DiscardPolicy:G3,NatsConnection:fde,JetStreamManager:Ede,JetStreamClient:hde,StringCodec:mde,JSONCodec:F3,createInbox:MS,headers:q3,ErrorCode:XD}=require("nats"),{PACKAGE_ROOT:k3}=U(),V3=fl(),{recordAction:$3}=(ws(),ie(Sl)),nL=F3(),Y3="clustering",K3=V3.engines[Wt.NATS_SERVER_NAME],W3=Al.join(k3,"dependencies"),wS=Al.join(W3,`${process.platform}-${process.arch}`,Wt.NATS_BINARY_NAME),NS,IS,Rl,ao,co;fL.exports={runCommand:sL,checkNATSServerInstalled:Q3,createConnection:PS,getConnection:Ol,getJetStreamManager:bl,getJetStream:oL,getNATSReferences:os,getServerList:J3,createLocalStream:US,listStreams:aL,deleteLocalStream:X3,getServerConfig:ua,listRemoteStreams:j3,viewStream:Z3,viewStreamIterator:eX,publishToStream:tX,request:sX,reloadNATS:vS,reloadNATSHub:iX,reloadNATSLeaf:oX,extractServerName:nX,requestErrorHandler:aX,createLocalTableStream:_L,createTableStreams:uX,purgeTableStream:dL,purgeSchemaTableStreams:_X,getStreamInfo:dX,updateLocalStreams:EX,closeConnection:z3,getJsmServerName:Ld,addNatsMsgHeader:cL,clearClientCache:iL,updateRemoteConsumer:cX,createConsumer:lL,updateConsumerIterator:lX};async function sL(e,t=void 0){let{stdout:r,stderr:n}=await C3(e,{cwd:t});if(n)throw new Error(n.replace(`
|
|
11
11
|
`,""));return r.replace(`
|
|
12
12
|
`,"")}a(sL,"runCommand");async function Q3(){try{await y3.access(wS)}catch{return!1}let e=await sL(`${wS} --version`,void 0),t=e.substring(e.lastIndexOf("v")+1,e.length);return N3.eq(t,K3)}a(Q3,"checkNATSServerInstalled");async function PS(e,t,r,n=!0,s="127.0.0.1"){if(!t&&!r){let o=await rL.getClusterUser();if(uo(o))throw new Error("Unable to get nats connection. Cluster user is undefined.");t=o.username,r=o.decrypt_hash}Bn.trace("create nats connection called");let i=await B3({name:s,port:e,user:t,pass:r,maxReconnectAttempts:-1,waitOnFirstConnect:n,timeout:2e5,tls:{keyFile:xt.get(Ie.CONFIG_PARAMS.CLUSTERING_TLS_PRIVATEKEY),certFile:xt.get(Ie.CONFIG_PARAMS.CLUSTERING_TLS_CERTIFICATE),caFile:xt.get(Ie.CONFIG_PARAMS.CLUSTERING_TLS_CERT_AUTH),rejectUnauthorized:!1}});return i.protocol.transport.socket.unref(),Bn.trace("create connection established a nats client connection with id",i?.info?.client_id),i.closed().then(o=>{o&&Bn.error("Error with Nats client connection, connection closed",o),i===ir&&iL()}),i}a(PS,"createConnection");function iL(){ir=void 0,ao=void 0,co=void 0,lo=void 0}a(iL,"clearClientCache");async function z3(){ir&&(await ir.drain(),ir=void 0,ao=void 0,co=void 0,lo=void 0)}a(z3,"closeConnection");var ir,lo;async function Ol(){return lo||(lo=PS(xt.get(Ie.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),void 0,void 0),ir=await lo),ir||lo}a(Ol,"getConnection");async function bl(){if(ao)return ao;uo(ir)&&await Ol();let{domain:e}=ua(Ie.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(uo(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return ao=await ir.jetstreamManager({domain:e,timeout:6e4}),ao}a(bl,"getJetStreamManager");async function oL(){if(co)return co;uo(ir)&&await Ol();let{domain:e}=ua(Ie.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);if(uo(e))throw new Error("Error getting JetStream domain. Unable to get JetStream manager.");return co=ir.jetstream({domain:e,timeout:6e4}),co}a(oL,"getJetStream");async function os(){let e=ir||await Ol(),t=ao||await bl(),r=co||await oL();return{connection:e,jsm:t,js:r}}a(os,"getNATSReferences");async function J3(e){let t=xt.get(Ie.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),{sys_name:r,decrypt_hash:n}=await rL.getClusterUser(),s=await PS(t,r,n),i=MS(),o=s.subscribe(i),c=[],l,_=(async()=>{for await(let u of o){let d=nL.decode(u.data);d.response_time=Date.now()-l,c.push(d)}})();return l=Date.now(),await s.publish("$SYS.REQ.SERVER.PING.VARZ",void 0,{reply:i}),await s.publish("$SYS.REQ.SERVER.PING",void 0,{reply:i}),await s.flush(),await Cd.async_set_timeout(e),await o.drain(),await s.close(),await _,c}a(J3,"getServerList");async function US(e,t){let{jsm:r}=await os(),n=xt.get(Ie.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=xt.get(Ie.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);s=s===null?-1:s;let i=xt.get(Ie.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);i=i===null?-1:i,await r.streams.add({name:e,storage:H3.File,retention:x3.Limits,subjects:t,discard:G3.Old,max_msgs:s,max_bytes:i,max_age:n})}a(US,"createLocalStream");async function aL(){let{jsm:e}=await os(),t=await e.streams.list().next(),r=[];return t.forEach(n=>{r.push(n)}),r}a(aL,"listStreams");async function X3(e){let{jsm:t}=await os();await t.streams.delete(e)}a(X3,"deleteLocalStream");async function j3(e){let{connection:t}=await os(),r=[],n=MS(),s=t.subscribe(n),i=(async()=>{for await(let o of s)r.push(nL.decode(o.data))})();return await t.publish(`$JS.${e}.API.STREAM.LIST`,void 0,{reply:n}),await t.flush(),await s.drain(),await i,r}a(j3,"listRemoteStreams");async function Z3(e,t=void 0,r=void 0){let{jsm:n,js:s}=await os(),i=jD(),o={durable_name:i,ack_policy:DS.Explicit};t&&(o.deliver_policy=LS.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];let _=[];for await(let u of l){let d=CS(u.data),E={nats_timestamp:u.info.timestampNanos,nats_sequence:u.info.streamSequence,entry:d};if(u.headers&&(E.origin=u.headers.get(Wt.MSG_HEADERS.ORIGIN)),_.push(E),u.ack(),u.info.pending===0)break}return await c.delete(),_}a(Z3,"viewStream");async function*eX(e,t=void 0,r=void 0){let{jsm:n,js:s}=await os(),i=jD(),o={durable_name:i,ack_policy:DS.Explicit};t&&(o.deliver_policy=LS.StartTime,o.opt_start_time=new Date(t).toISOString()),await n.consumers.add(e,o);let c=await s.consumers.get(e,i),l=r?await c.fetch({max_messages:r,expires:2e3}):await c.consume();if(c._info.num_pending===0)return[];for await(let _ of l){let u=CS(_.data);u[0]||(u=[u]);for(let d of u){let E={nats_timestamp:_.info.timestampNanos,nats_sequence:_.info.streamSequence,entry:d};_.headers&&(E.origin=_.headers.get(Wt.MSG_HEADERS.ORIGIN)),yield E}if(_.ack(),_.info.pending===0)break}await c.delete()}a(eX,"viewStreamIterator");async function tX(e,t,r,n){Bn.trace(`publishToStream called with subject: ${e}, stream: ${t}, entries:`,n.operation),r=cL(n,r);let{js:s}=await os(),i=await Ld(),o=`${e}.${i}`,c=n instanceof Uint8Array?n:tL.encode(n);try{Bn.trace(`publishToStream publishing to subject: ${o}`),$3(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 uL(async()=>{try{await s.publish(o,c,{headers:r})}catch{if(l.code&&l.code.toString()==="503"){Bn.trace(`publishToStream creating stream: ${t}`);let u=o.split(".");u[2]="*",await US(t,[o]),await s.publish(o,c,{headers:r})}else throw l}});throw l}}a(tX,"publishToStream");function cL(e,t){t===void 0&&(t=q3());let r=xt.get(Ie.CONFIG_PARAMS.CLUSTERING_NODENAME);return!t.has(Wt.MSG_HEADERS.ORIGIN)&&r&&t.append(Wt.MSG_HEADERS.ORIGIN,r),t}a(cL,"addNatsMsgHeader");function ua(e){e=e.toLowerCase();let t=Al.join(xt.get(Ie.CONFIG_PARAMS.ROOTPATH),Y3);if(e===Ie.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())return uo(IS)&&(IS={port:gl.getConfigFromFile(Ie.CONFIG_PARAMS.CLUSTERING_HUBSERVER_NETWORK_PORT),server_name:gl.getConfigFromFile(Ie.CONFIG_PARAMS.CLUSTERING_NODENAME)+Wt.SERVER_SUFFIX.HUB,config_file:Wt.NATS_CONFIG_FILES.HUB_SERVER,pid_file_path:Al.join(t,Wt.PID_FILES.HUB),hdb_nats_path:t}),IS;if(e===Ie.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())return uo(NS)&&(NS={port:gl.getConfigFromFile(Ie.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_PORT),server_name:gl.getConfigFromFile(Ie.CONFIG_PARAMS.CLUSTERING_NODENAME)+Wt.SERVER_SUFFIX.LEAF,config_file:Wt.NATS_CONFIG_FILES.LEAF_SERVER,domain:gl.getConfigFromFile(Ie.CONFIG_PARAMS.CLUSTERING_NODENAME)+Wt.SERVER_SUFFIX.LEAF,pid_file_path:Al.join(t,Wt.PID_FILES.LEAF),hdb_nats_path:t}),NS;Bn.error(`Unable to get Nats server config. Unrecognized process: ${e}`)}a(ua,"getServerConfig");async function lL(e,t,r,n){try{await e.consumers.add(t,{ack_policy:DS.Explicit,durable_name:r,deliver_policy:LS.StartTime,opt_start_time:n})}catch(s){if(s.message!=="consumer already exists")throw s}}a(lL,"createConsumer");async function rX(e,t,r){await e.consumers.delete(t,r)}a(rX,"removeConsumer");function nX(e){return e.split(".")[1]}a(nX,"extractServerName");async function sX(e,t,r=6e4,n=MS()){if(!Cd.isObject(t))throw new Error("data param must be an object");let s=tL.encode(t),{connection:i}=await os(),o={timeout:r};n&&(o.reply=n,o.noMux=!0);let c=await i.request(e,s,o);return CS(c.data)}a(sX,"request");function vS(e){return new Promise(async(t,r)=>{let n=D3(wS,["--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(vS,"reloadNATS");async function iX(){let{pid_file_path:e}=ua(Ie.PROCESS_DESCRIPTORS.CLUSTERING_HUB);await vS(e)}a(iX,"reloadNATSHub");async function oX(){let{pid_file_path:e}=ua(Ie.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await vS(e)}a(oX,"reloadNATSLeaf");function aX(e,t,r){let n;switch(e.code){case XD.NoResponders:n=`Unable to ${t}, node '${r}' is not listening.`;break;case XD.Timeout:n=`Unable to ${t}, node '${r}' is listening but did not respond.`;break;default:n=e.message;break}return n}a(aX,"requestErrorHandler");async function cX(e,t){let r=t+Wt.SERVER_SUFFIX.LEAF,{connection:n}=await os(),{jsm:s}=await mX(r),{schema:i,table:o}=e,c=Dd.createNatsTableStreamName(i,o),l=e.start_time?e.start_time:new Date(Date.now()).toISOString();await uL(async()=>{if(e.subscribe===!0)await lL(s,c,n.info.server_name,l);else try{await rX(s,c,n.info.server_name)}catch(_){Bn.trace(_)}})}a(cX,"updateRemoteConsumer");async function lX(e,t,r,n){let s=Dd.createNatsTableStreamName(e,t),i=r+Wt.SERVER_SUFFIX.LEAF,o={type:Ie.ITC_EVENT_TYPES.NATS_CONSUMER_UPDATE,status:n,stream_name:s,node_domain_name:i};if(!eL&&U3()<xt.get(Ie.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXINGESTTHREADS)){let{updateConsumer:c}=yS();await c(o)}await M3(o),n==="stop"&&await Cd.async_set_timeout(1e3)}a(lX,"updateConsumerIterator");function uL(e){return L3.writeTransaction(Ie.SYSTEM_SCHEMA_NAME,Ie.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,e)}a(uL,"exclusiveLock");async function _L(e,t){let r=Dd.createNatsTableStreamName(e,t),n=await Ld(),s=fX(e,t,n);await US(r,[s])}a(_L,"createLocalTableStream");async function uX(e){for(let t=0,r=e.length;t<r;t++){let n=e[t].schema,s=e[t].table;await _L(n,s)}}a(uX,"createTableStreams");async function dL(e,t,r=void 0){if(xt.get(Ie.CONFIG_PARAMS.CLUSTERING_ENABLED))try{let n=Dd.createNatsTableStreamName(e,t),{domain:s}=ua(Ie.PROCESS_DESCRIPTORS.CLUSTERING_LEAF);await(await(await Ol()).jetstreamManager({domain:s,timeout:24e4})).streams.purge(n,r)}catch(n){if(n.message==="stream not found")Bn.warn(n);else throw n}}a(dL,"purgeTableStream");async function _X(e,t){if(xt.get(Ie.CONFIG_PARAMS.CLUSTERING_ENABLED))for(let r=0,n=t.length;r<n;r++)await dL(e,t[r])}a(_X,"purgeSchemaTableStreams");async function dX(e){return(await bl()).streams.info(e)}a(dX,"getStreamInfo");function fX(e,t,r){return`${Wt.SUBJECT_PREFIXES.TXN}.${e}${t?"."+t:""}.${r}`}a(fX,"createSubjectName");async function Ld(){if(Rl)return Rl;if(Rl=(await bl())?.nc?.info?.server_name,Rl===void 0)throw new Error("Unable to get jetstream manager server name");return Rl}a(Ld,"getJsmServerName");async function EX(){let e=await bl(),t=await Ld(),r=await aL();for(let n of r){let s=n.config,i=s.subjects[0];if(!i)continue;let o=hX(n),c=i.split(".");if(c[c.length-1]===t&&!o||s.name==="__HARPERDB_WORK_QUEUE__")continue;let _=i.split(".");_[_.length-1]=t;let u=_.join(".");Bn.trace(`Updating stream subject name from: ${i} to: ${u}`),s.subjects[0]=u,await e.streams.update(s.name,s)}}a(EX,"updateLocalStreams");function hX(e){let{config:t}=e,r=!1,n=xt.get(Ie.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXAGE);n=n===null?0:n*1e9;let s=xt.get(Ie.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXBYTES);s=s===null?-1:s;let i=xt.get(Ie.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_STREAMS_MAXMSGS);return i=i===null?-1:i,n!==t.max_age&&(t.max_age=n,r=!0),s!==t.max_bytes&&(t.max_bytes=s,r=!0),i!==t.max_msgs&&(t.max_msgs=i,r=!0),r}a(hX,"updateStreamLimits");async function mX(e){let t,r;try{t=await ir.jetstream({domain:e}),r=await ir.jetstreamManager({domain:e,checkAPI:!1})}catch(n){throw Bn.error("Unable to connect to:",e),n}return{js:t,jsm:r}}a(mX,"connectToRemoteJS")});var vd=g((gde,pL)=>{"use strict";var _a=x_(),da=gD(),pX=K(),SX=require("uuid").v4,Tde=require("clone"),Pd=bs(),fa=U(),TX=require("util"),di=Ln(),{handleHDBError:Rr,hdb_errors:gX}=se(),{HDB_ERROR_MSGS:Md,HTTP_STATUS_CODES:Ar}=gX,{SchemaEventMsg:Ud}=Mn(),EL=wt(),{getDatabases:RX}=(Ae(),ie(ke)),{transformReq:Ea}=J();pL.exports={createSchema:AX,createSchemaStructure:hL,createTable:OX,createTableStructure:mL,createAttribute:wX,dropSchema:bX,dropTable:yX,dropAttribute:NX,getBackup:CX};async function AX(e){let t=await hL(e);return Pd.signalSchemaChange(new Ud(process.pid,e.operation,e.schema)),t}a(AX,"createSchema");async function hL(e){let t=_a.schema_object(e);if(t)throw Rr(t,t.message,Ar.BAD_REQUEST,void 0,void 0,!0);if(Ea(e),!await da.checkSchemaExists(e.schema))throw Rr(new Error,Md.SCHEMA_EXISTS_ERR(e.schema),Ar.BAD_REQUEST,fa.LOG_LEVELS.ERROR,Md.SCHEMA_EXISTS_ERR(e.schema),!0);return await di.createSchema(e),`database '${e.schema}' successfully created`}a(hL,"createSchemaStructure");async function OX(e){return Ea(e),e.hash_attribute=e.primary_key??e.hash_attribute,await mL(e)}a(OX,"createTable");async function mL(e){let t=_a.create_table_object(e);if(t)throw Rr(t,t.message,Ar.BAD_REQUEST,void 0,void 0,!0);if(_a.validateTableResidence(e.residence),!await da.checkSchemaTableExists(e.schema,e.table))throw Rr(new Error,Md.TABLE_EXISTS_ERR(e.schema,e.table),Ar.BAD_REQUEST,fa.LOG_LEVELS.ERROR,Md.TABLE_EXISTS_ERR(e.schema,e.table),!0);let n={name:e.table,schema:e.schema,id:SX(),hash_attribute:e.hash_attribute};try{if(e.residence)if(global.clustering_on)n.residence=e.residence,await di.createTable(n,e);else throw Rr(new Error,"Clustering does not appear to be enabled. Cannot insert table with property 'residence'.",Ar.BAD_REQUEST);else await di.createTable(n,e);return`table '${e.schema}.${e.table}' successfully created.`}catch(s){throw s}}a(mL,"createTableStructure");async function bX(e){let t=!e.schema&&!e.database?new Error("database is required"):void 0,r=_a.schema_object(e),n=t??r;if(n)throw Rr(n,n.message,Ar.BAD_REQUEST,void 0,void 0,!0);Ea(e);let s=await da.checkSchemaExists(e.schema);if(s)throw Rr(new Error,s,Ar.NOT_FOUND,fa.LOG_LEVELS.ERROR,s,!0);let i=await da.schema_describe.describeSchema({schema:e.schema}),o=Object.keys(global.hdb_schema[e.schema]);return await di.dropSchema(e),Pd.signalSchemaChange(new Ud(process.pid,e.operation,e.schema)),await EL.purgeSchemaTableStreams(e.schema,o),`successfully deleted '${e.schema}'`}a(bX,"dropSchema");async function yX(e){let t=_a.table_object(e);if(t)throw Rr(t,t.message,Ar.BAD_REQUEST,void 0,void 0,!0);Ea(e);let r=await da.checkSchemaTableExists(e.schema,e.table);if(r)throw Rr(new Error,r,Ar.NOT_FOUND,fa.LOG_LEVELS.ERROR,r,!0);return await di.dropTable(e),await EL.purgeTableStream(e.schema,e.table),`successfully deleted table '${e.schema}.${e.table}'`}a(yX,"dropTable");async function NX(e){let t=_a.attribute_object(e);if(t)throw Rr(t,t.message,Ar.BAD_REQUEST,void 0,void 0,!0);Ea(e);let r=await da.checkSchemaTableExists(e.schema,e.table);if(r)throw Rr(new Error,r,Ar.NOT_FOUND,fa.LOG_LEVELS.ERROR,r,!0);if(e.attribute===global.hdb_schema[e.schema][e.table].hash_attribute)throw Rr(new Error,"You cannot drop a hash attribute",Ar.BAD_REQUEST,void 0,void 0,!0);if(fa.TIME_STAMP_NAMES.indexOf(e.attribute)>=0)throw Rr(new Error,`cannot drop internal timestamp attribute: ${e.attribute}`,Ar.BAD_REQUEST,void 0,void 0,!0);try{return await di.dropAttribute(e),IX(e),Pd.signalSchemaChange(new Ud(process.pid,e.operation,e.schema,e.table,e.attribute)),`successfully deleted attribute '${e.attribute}'`}catch(n){throw pX.error(`Got an error deleting attribute ${TX.inspect(e)}.`),n}}a(NX,"dropAttribute");function IX(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(IX,"dropAttributeFromGlobal");async function wX(e){Ea(e);let t=RX()[e.schema][e.table].attributes;for(let{name:r}of t)if(r===e.attribute)throw Rr(new Error,`attribute '${e.attribute}' already exists in ${e.schema}.${e.table}`,Ar.BAD_REQUEST,void 0,void 0,!0);return await di.createAttribute(e),Pd.signalSchemaChange(new Ud(process.pid,e.operation,e.schema,e.table,e.attribute)),`attribute '${e.schema}.${e.table}.${e.attribute}' successfully created.`}a(wX,"createAttribute");function CX(e){return di.getBackup(e)}a(CX,"getBackup")});var TL=g((Ade,SL)=>{"use strict";var{OPERATIONS_ENUM:DX}=U(),BS=class{static{a(this,"ReadAuditLogObject")}constructor(t,r,n=void 0,s=void 0){this.operation=DX.READ_AUDIT_LOG,this.schema=t,this.table=r,this.search_type=n,this.search_values=s}};SL.exports=BS});var HS=g((yde,bL)=>{"use strict";var LX=Ln(),bde=TL(),Bd=J(),Hd=U(),MX=ne(),{handleHDBError:gL,hdb_errors:PX}=se(),{HDB_ERROR_MSGS:RL,HTTP_STATUS_CODES:AL}=PX,UX=Object.values(Hd.READ_AUDIT_LOG_SEARCH_TYPES_ENUM),OL="To use this operation audit log must be enabled in harperdb-config.yaml";bL.exports=vX;async function vX(e){if(Bd.isEmpty(e.schema))throw new Error(RL.SCHEMA_REQUIRED_ERR);if(Bd.isEmpty(e.table))throw new Error(RL.TABLE_REQUIRED_ERR);if(!MX.get(Hd.CONFIG_PARAMS.LOGGING_AUDITLOG))throw gL(new Error,OL,AL.BAD_REQUEST,Hd.LOG_LEVELS.ERROR,OL,!0);let t=Bd.checkSchemaTableExist(e.schema,e.table);if(t)throw gL(new Error,t,AL.NOT_FOUND,Hd.LOG_LEVELS.ERROR,t,!0);if(!Bd.isEmpty(e.search_type)&&UX.indexOf(e.search_type)<0)throw new Error(`Invalid search_type '${e.search_type}'`);return await LX.readAuditLog(e)}a(vX,"readAuditLog")});var NL=g((Ide,yL)=>{"use strict";var{OPERATIONS_ENUM:BX}=U(),xS=class{static{a(this,"GetBackupObject")}constructor(t,r,n=void 0,s=void 0){this.operation=BX.GET_BACKUP,this.schema=t,this.table=r}};yL.exports=xS});var CL=g((Lde,wL)=>{"use strict";var HX=Ln(),Cde=NL(),GS=J(),xX=U(),Dde=ne(),{handleHDBError:GX,hdb_errors:FX}=se(),{HDB_ERROR_MSGS:IL,HTTP_STATUS_CODES:qX}=FX;wL.exports=kX;async function kX(e){if(GS.isEmpty(e.schema))throw new Error(IL.SCHEMA_REQUIRED_ERR);if(GS.isEmpty(e.table))throw new Error(IL.TABLE_REQUIRED_ERR);let t=GS.checkSchemaTableExist(e.schema,e.table);if(t)throw GX(new Error,t,qX.NOT_FOUND,xX.LOG_LEVELS.ERROR,t,!0);return await HX.getBackup(read_audit_log_object)}a(kX,"getBackup")});var vL=g((Pde,UL)=>{var fi=require("validate.js"),LL=st(),ha=U(),{handleHDBError:VX,hdb_errors:$X}=se(),{HDB_ERROR_MSGS:ht,HTTP_STATUS_CODES:YX}=$X,FS=a(()=>({role:{presence:!0,format:"[\\w\\-\\_]+"},id:{presence:!0,format:"[\\w\\-\\_]+"},permission:{presence:!0}}),"constraintsTemplate"),KX={STRUCTURE_USER:"structure_user"},DL=Object.values(ha.ROLE_TYPES_ENUM),WX="attribute_permissions",QX="attribute_name",{PERMS_CRUD_ENUM:ma}=ha,zX=[WX,...Object.values(ma)],ML=[ma.READ,ma.INSERT,ma.UPDATE],JX=[QX,...ML];function XX(e){let t=FS();return t.role.presence=!0,t.id.presence=!1,t.permission.presence=!0,PL(e,t)}a(XX,"addRoleValidation");function jX(e){let t=FS();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!0,PL(e,t)}a(jX,"alterRoleValidation");function ZX(e){let t=FS();return t.role.presence=!1,t.id.presence=!0,t.permission.presence=!1,LL.validateObject(e,t)}a(ZX,"dropRoleValidation");var ej=["operation","role","id","permission","hdb_user","hdb_auth_header"];function PL(e,t){let r={main_permissions:[],schema_permissions:{}},n=Object.keys(e),s=[];for(let o=0,c=n.length;o<c;o++)ej.includes(n[o])||s.push(n[o]);s.length>0&&Rt(ht.INVALID_ROLE_JSON_KEYS(s),r);let i=LL.validateObject(e,t);if(i&&i.message.split(",").forEach(o=>{Rt(o,r)}),e.permission){let o=tj(e);o&&Rt(o,r),DL.forEach(c=>{e.permission[c]&&!fi.isBoolean(e.permission[c])&&Rt(ht.SU_CU_ROLE_BOOLEAN_ERROR(c),r)})}for(let o in e.permission)if(DL.indexOf(o)<0){if(o===KX.STRUCTURE_USER){let l=e.permission[o];if(typeof l=="boolean")continue;if(Array.isArray(l)){for(let _=0,u=l.length;_<u;_++){let d=l[_];global.hdb_schema[d]||Rt(ht.SCHEMA_NOT_FOUND(d),r)}continue}Rt(ht.STRUCTURE_USER_ROLE_TYPE_ERROR(o),r);continue}let c=e.permission[o];if(!o||!global.hdb_schema[o]){Rt(ht.SCHEMA_NOT_FOUND(o),r);continue}if(c.tables)for(let l in c.tables){let _=c.tables[l];if(!l||!global.hdb_schema[o][l]){Rt(ht.TABLE_NOT_FOUND(o,l),r);continue}if(Object.keys(_).forEach(u=>{zX.includes(u)||Rt(ht.INVALID_PERM_KEY(u),r,o,l)}),Object.values(ma).forEach(u=>{fi.isDefined(_[u])?fi.isBoolean(_[u])||Rt(ht.TABLE_PERM_NOT_BOOLEAN(u),r,o,l):Rt(ht.TABLE_PERM_MISSING(u),r,o,l)}),fi.isDefined(_.attribute_permissions)){if(!fi.isArray(_.attribute_permissions)){Rt(ht.ATTR_PERMS_NOT_ARRAY,r,o,l);continue}}else{Rt(ht.ATTR_PERMS_ARRAY_MISSING,r,o,l);continue}if(_.attribute_permissions){let u=global.hdb_schema[o][l].attributes.map(({attribute:E})=>E),d={read:!1,insert:!1,update:!1};for(let E in _.attribute_permissions){let f=_.attribute_permissions[E];if(Object.keys(f).forEach(p=>{!JX.includes(p)&&p!==ma.DELETE&&Rt(ht.INVALID_ATTR_PERM_KEY(p),r,o,l)}),!fi.isDefined(f.attribute_name)){Rt(ht.ATTR_PERM_MISSING_NAME,r,o,l);continue}let h=f.attribute_name;if(!u.includes(h)){Rt(ht.INVALID_ATTRIBUTE_IN_PERMS(h),r,o,l);continue}ML.forEach(p=>{fi.isDefined(f[p])?fi.isBoolean(f[p])||Rt(ht.ATTR_PERM_NOT_BOOLEAN(p,h),r,o,l):Rt(ht.ATTR_PERM_MISSING(p,h),r,o,l)}),!d.read&&f.read===!0&&(d.read=!0),!d.insert&&f.insert===!0&&(d.insert=!0),!d.update&&f.update===!0&&(d.update=!0)}if(_.read===!1&&d.read===!0||_.insert===!1&&d.insert===!0||_.update===!1&&d.update===!0){let E=`${o}.${l}`;Rt(ht.MISMATCHED_TABLE_ATTR_PERMS(E),r,o,l)}}}}return rj(r)}a(PL,"customValidate");UL.exports={addRoleValidation:XX,alterRoleValidation:jX,dropRoleValidation:ZX};function tj(e){let{operation:t,permission:r}=e;if(t===ha.OPERATIONS_ENUM.ADD_ROLE||t===ha.OPERATIONS_ENUM.ALTER_ROLE){let n=r.super_user===!0,s=r.cluster_user===!0;if(Object.keys(r).length>1&&(n||s)){if(s&&n)return ht.SU_CU_ROLE_COMBINED_ERROR;{let o=r.super_user?ha.ROLE_TYPES_ENUM.SUPER_USER:ha.ROLE_TYPES_ENUM.CLUSTER_USER;return ht.SU_CU_ROLE_NO_PERMS_ALLOWED(o)}}}return null}a(tj,"validateNoSUPerms");function rj(e){let{main_permissions:t,schema_permissions:r}=e;if(t.length>0||Object.keys(r).length>0){let n={error:ht.ROLE_PERMS_ERROR,...e};return VX(new Error,n,YX.BAD_REQUEST)}else return null}a(rj,"generateRolePermResponse");function Rt(e,t,r,n){if(!r)t.main_permissions.push(e);else{let s=n?r+"_"+n:r;t.schema_permissions[s]?t.schema_permissions[s].push(e):t.schema_permissions[s]=[e]}}a(Rt,"addPermError")});var KS=g((vde,GL)=>{"use strict";var BL=un(),HL=kr(),nj=Xi(),kS=vL(),VS=bs(),sj=require("uuid").v4,ij=require("util"),xd=U(),oj=J(),$S=HL.searchByValue,aj=HL.searchByHash,cj=ij.promisify(nj.delete),lj=rs(),uj=sa(),{hdb_errors:_j,handleHDBError:_o}=se(),{HDB_ERROR_MSGS:xL,HTTP_STATUS_CODES:yl}=_j,{UserEventMsg:YS}=Mn();GL.exports={addRole:dj,alterRole:fj,dropRole:Ej,listRoles:hj};function qS(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(qS,"scrubRoleDetails");async function dj(e){let t=kS.addRoleValidation(e);if(t)throw t;e=qS(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 $S(r)||[])}catch(i){throw _o(i)}if(n&&n.length>0)throw _o(new Error,xL.ROLE_ALREADY_EXISTS(e.role),yl.CONFLICT,void 0,void 0,!0);e.id||(e.id=sj());let s={operation:"insert",schema:"system",table:"hdb_role",hash_attribute:"id",records:[e]};return await BL.insert(s),VS.signalUserChange(new YS(process.pid)),e=qS(e),e}a(dj,"addRole");async function fj(e){let t=kS.alterRoleValidation(e);if(t)throw t;e=qS(e);let r={operation:"update",schema:"system",table:"hdb_role",records:[e]},n;try{n=await BL.update(r)}catch(s){throw _o(s)}if(n&&n?.message==="updated 0 of 1 records")throw _o(new Error,"Invalid role id",yl.BAD_REQUEST,void 0,void 0,!0);return await VS.signalUserChange(new YS(process.pid)),e}a(fj,"alterRole");async function Ej(e){let t=kS.dropRoleValidation(e);if(t)throw _o(new Error,t,yl.BAD_REQUEST,void 0,void 0,!0);let r=new uj(xd.SYSTEM_SCHEMA_NAME,xd.SYSTEM_TABLE_NAMES.ROLE_TABLE_NAME,[e.id],["role"]),n=Array.from(await aj(r));if(n.length===0)throw _o(new Error,xL.ROLE_NOT_FOUND,yl.NOT_FOUND,void 0,void 0,!0);let s=new lj(xd.SYSTEM_SCHEMA_NAME,xd.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,"role",e.id,void 0,["username","active"]),i=Array.from(await $S(s)),o=!1;if(oj.isEmptyOrZeroLength(i)===!1){for(let l=0;l<i.length;l++)if(i[l].active===!0){o=!0;break}}if(o===!0)throw _o(new Error,`Cannot drop role ${n[0].role} as it has active user(s) tied to this role`,yl.CONFLICT,void 0,void 0,!0);let c={table:"hdb_role",schema:"system",hash_values:[e.id]};return await cj(c),VS.signalUserChange(new YS(process.pid)),`${n[0].role} successfully deleted`}a(Ej,"dropRole");async function hj(){return $S({table:"hdb_role",schema:"system",hash_attribute:"id",search_attribute:"id",search_value:"*",get_attributes:["*"]})}a(hj,"listRoles")});var VL=g((Hde,kL)=>{"use strict";var mj=ne(),Ei=require("joi"),pj=st(),FL=require("moment"),Sj=require("fs-extra"),WS=require("path"),Tj=require("lodash"),Nl=U(),{LOG_LEVELS:fo}=U(),gj="YYYY-MM-DD hh:mm:ss",Rj=WS.resolve(__dirname,"../logs");kL.exports=function(e){return pj.validateBySchema(e,Aj)};var Aj=Ei.object({from:Ei.custom(qL),until:Ei.custom(qL),level:Ei.valid(fo.NOTIFY,fo.FATAL,fo.ERROR,fo.WARN,fo.INFO,fo.DEBUG,fo.TRACE),order:Ei.valid("asc","desc"),limit:Ei.number().min(1),start:Ei.number().min(0),log_name:Ei.custom(Oj)});function qL(e,t){if(FL(e,FL.ISO_8601).format(gj)==="Invalid date")return t.message(`'${t.state.path[0]}' date '${e}' is invalid.`)}a(qL,"validateDatetime");function Oj(e,t){if(Tj.invert(Nl.LOG_NAMES)[e]===void 0)return t.message(`'log_name' '${e}' is invalid.`);let n=mj.get(Nl.HDB_SETTINGS_NAMES.LOG_PATH_KEY),s=e===void 0?Nl.LOG_NAMES.HDB:e,i=s===Nl.LOG_NAMES.INSTALL?WS.join(Rj,Nl.LOG_NAMES.INSTALL):WS.join(n,s);return Sj.existsSync(i)?null:t.message(`'log_name' '${e}' does not exist.`)}a(Oj,"validateReadLogPath")});var zS=g((Gde,YL)=>{"use strict";var Gd=U(),bj=K(),yj=ne(),Nj=VL(),QS=require("path"),$L=require("fs-extra"),{once:Ij}=require("events"),{handleHDBError:wj,hdb_errors:Cj}=se(),{PACKAGE_ROOT:Dj}=U(),Lj=QS.join(Dj,"logs"),Mj=1e3,Pj=200;YL.exports=Uj;async function Uj(e){let t=Nj(e);if(t)throw wj(t,t.message,Cj.HTTP_STATUS_CODES.BAD_REQUEST,void 0,void 0,!0);let r=yj.get(Gd.HDB_SETTINGS_NAMES.LOG_PATH_KEY),n=e.log_name===void 0?Gd.LOG_NAMES.HDB:e.log_name,s=n===Gd.LOG_NAMES.INSTALL?QS.join(Lj,Gd.LOG_NAMES.INSTALL):QS.join(r,n),i=e.level!==void 0,o=i?e.level:void 0,c=e.from!==void 0,l=c?new Date(e.from):void 0,_=e.until!==void 0,u=_?new Date(e.until):void 0,d=e.limit===void 0?Mj:e.limit,E=e.order===void 0?void 0:e.order,f=e.start===void 0?0:e.start,h=f+d,p=0;E==="desc"&&!l&&!u&&(p=Math.max($L.statSync(s).size-(h+5)*Pj,0));let S=$L.createReadStream(s,{start:p});S.on("error",P=>{bj.error(P)});let T=0,A=[],N="",b;S.on("data",P=>{let q=/(?:^|\n)(\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:[\d\.]+Z) \[(.+?)]: /g;P=N+P;let M=0,Q;for(;(Q=q.exec(P))&&!S.destroyed;){b&&(b.message=P.slice(M,Q.index),v(b));let[z,j,oe]=Q,le=oe.split("] ["),ue=le[0],Be=le[1];le.splice(0,2),b={timestamp:j,thread:ue,level:Be,tags:le,message:""},M=Q.index+z.length}N=P.slice(M)}),S.on("end",P=>{S.destroyed||b&&(b.message=N.trim(),v(b))}),S.resume();function v(P){let q,M,Q;switch(!0){case(i&&c&&_):q=new Date(P.timestamp),M=new Date(l),Q=new Date(u),P.level===o&&q>=M&&q<=Q&&T<f?T++:P.level===o&&q>=M&&q<=Q&&(hi(P,E,A),T++,T===h&&S.destroy());break;case(i&&c):q=new Date(P.timestamp),M=new Date(l),P.level===o&&q>=M&&T<f?T++:P.level===o&&q>=M&&(hi(P,E,A),T++,T===h&&S.destroy());break;case(i&&_):q=new Date(P.timestamp),Q=new Date(u),P.level===o&&q<=Q&&T<f?T++:P.level===o&&q<=Q&&(hi(P,E,A),T++,T===h&&S.destroy());break;case(c&&_):q=new Date(P.timestamp),M=new Date(l),Q=new Date(u),q>=M&&q<=Q&&T<f?T++:q>=M&&q<=Q&&(hi(P,E,A),T++,T===h&&S.destroy());break;case i:P.level===o&&T<f?T++:P.level===o&&(hi(P,E,A),T++,T===h&&S.destroy());break;case c:q=new Date(P.timestamp),M=new Date(l),q>=M&&T<f?T++:q>=M&&T>=f&&(hi(P,E,A),T++,T===h&&S.destroy());break;case _:q=new Date(P.timestamp),Q=new Date(u),q<=Q&&T<f?T++:q<=Q&&T>=f&&(hi(P,E,A),T++,T===h&&S.destroy());break;default:T<f?T++:(hi(P,E,A),T++,T===h&&S.destroy())}}return a(v,"onLogMessage"),await Ij(S,"close"),A}a(Uj,"readLog");function hi(e,t,r){t==="desc"?vj(e,r):t==="asc"?Bj(e,r):r.push(e)}a(hi,"pushLineToResult");function vj(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(vj,"insertDescending");function Bj(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(Bj,"insertAscending")});var Fd=g(($de,zL)=>{"use strict";var JS=require("joi"),{string:Il,boolean:KL,date:Hj}=JS.types(),xj=st(),{validateSchemaExists:qde,validateTableExists:kde,validateSchemaName:Vde}=jn(),Gj=U(),Fj=ct(),WL=ne();WL.initSync();var qj=Il.invalid(WL.get(Gj.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(Fj.NATS_TERM_CONSTRAINTS_RX).messages({"string.pattern.base":"{:#label} invalid, must not contain ., * or >","any.invalid":"'node_name' cannot be this nodes name"}).empty(null).required(),QL={operation:Il.valid("add_node","update_node","set_node_replication"),node_name:qj,subscriptions:JS.array().items({table:Il.optional(),schema:Il.optional(),database:Il.optional(),subscribe:KL.required(),publish:KL.required().custom(Vj),start_time:Hj.iso()}).min(1).required()};function kj(e){return xj.validateBySchema(e,JS.object(QL))}a(kj,"addUpdateNodeValidator");function Vj(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(Vj,"checkForFalsy");zL.exports={addUpdateNodeValidator:kj,validation_schema:QL}});var XL=g((Kde,JL)=>{var $j=st(),Yj={user:{presence:!0},schema:{presence:!0},table:{presence:!0},operation:{presence:!0}};JL.exports=function(e){return $j.validateObject(e,Yj)}});var jS=g((Wde,jL)=>{"use strict";var Kj=U().OPERATIONS_ENUM,XS=class{static{a(this,"UpdateObject")}constructor(t,r,n,s=void 0){this.operation=Kj.UPDATE,this.schema=t,this.table=r,this.records=n,this.__origin=s}};jL.exports=XS});var eM=g((zde,ZL)=>{"use strict";var Wj={OPERATION:"operation",REFRESH:"refresh"},ZS=class{static{a(this,"JWTTokens")}constructor(t,r){this.operation_token=t,this.refresh_token=r}},eT=class{static{a(this,"JWTRSAKeys")}constructor(t,r,n){this.public_key=t,this.private_key=r,this.passphrase=n}};ZL.exports={JWTTokens:ZS,TOKEN_TYPE_ENUM:Wj,JWTRSAKeys:eT}});var Dl=g((Xde,sM)=>{"use strict";var Cl=require("jsonwebtoken"),tT=require("fs-extra"),rT=J(),dn=U(),{handleHDBError:Or,hdb_errors:Qj}=se(),{HTTP_STATUS_CODES:br,AUTHENTICATION_ERROR_MSGS:yr}=Qj,wl=K(),tM=z_(),iT=_n(),zj=un().update,Jj=jS(),Xj=bs(),{UserEventMsg:jj}=Mn(),mi=ne();mi.initSync();var nT=require("path"),{JWTTokens:Zj,JWTRSAKeys:eZ,TOKEN_TYPE_ENUM:qd}=eM(),tZ=mi.get(dn.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY)?mi.get(dn.HDB_SETTINGS_NAMES.OPERATION_TOKEN_TIMEOUT_KEY):"1d",rZ=mi.get(dn.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY)?mi.get(dn.HDB_SETTINGS_NAMES.REFRESH_TOKEN_TIMEOUT_KEY):"30d",kd="RS256",sT;sM.exports={createTokens:nZ,validateOperationToken:iZ,refreshOperationToken:sZ,validateRefreshToken:nM};async function nZ(e){if(rT.isEmpty(e)||typeof e!="object")throw Or(new Error,yr.INVALID_AUTH_OBJECT,br.BAD_REQUEST,void 0,void 0,!0);if(rT.isEmpty(e.username))throw Or(new Error,yr.USERNAME_REQUIRED,br.BAD_REQUEST,void 0,void 0,!0);if(rT.isEmpty(e.password))throw Or(new Error,yr.PASSWORD_REQUIRED,br.BAD_REQUEST,void 0,void 0,!0);let t;try{if(t=await iT.findAndValidateUser(e.username,e.password),!t)throw Or(new Error,yr.INVALID_CREDENTIALS,br.UNAUTHORIZED,void 0,void 0,!0)}catch(E){throw wl.error(E),Or(new Error,yr.INVALID_CREDENTIALS,br.UNAUTHORIZED,void 0,void 0,!0)}let r=await Vd(),n=!1,s=!1;t.role&&t.role.permission&&(n=t.role.permission.super_user===!0,s=t.role.permission.cluster_user===!0);let i={username:e.username,super_user:n,cluster_user:s},o=await rM(i,r.private_key,r.passphrase),c=await Cl.sign(i,{key:r.private_key,passphrase:r.passphrase},{expiresIn:rZ,algorithm:kd,subject:qd.REFRESH}),l=tM.hash(c),_=new Jj(dn.SYSTEM_SCHEMA_NAME,dn.SYSTEM_TABLE_NAMES.USER_TABLE_NAME,[{username:e.username,refresh_token:l}]),u,d;try{u=await zj(_)}catch(E){wl.error(E),d=E}if(d!==void 0||u.skipped_hashes.length>0)throw Or(new Error,yr.REFRESH_TOKEN_SAVE_FAILED,br.INTERNAL_SERVER_ERROR);return Xj.signalUserChange(new jj(process.pid)),new Zj(o,c)}a(nZ,"createTokens");async function rM(e,t,r){return await Cl.sign(e,{key:t,passphrase:r},{expiresIn:tZ,algorithm:kd,subject:qd.OPERATION})}a(rM,"signOperationToken");async function Vd(){if(sT===void 0)try{let e=nT.join(mi.getHdbBasePath(),dn.LICENSE_KEY_DIR_NAME,dn.JWT_ENUM.JWT_PASSPHRASE_NAME),t=nT.join(mi.getHdbBasePath(),dn.LICENSE_KEY_DIR_NAME,dn.JWT_ENUM.JWT_PRIVATE_KEY_NAME),r=nT.join(mi.getHdbBasePath(),dn.LICENSE_KEY_DIR_NAME,dn.JWT_ENUM.JWT_PUBLIC_KEY_NAME),n=(await tT.readFile(e)).toString(),s=(await tT.readFile(t)).toString(),i=(await tT.readFile(r)).toString();sT=new eZ(i,s,n)}catch(e){throw wl.error(e),Or(new Error,yr.NO_ENCRYPTION_KEYS,br.INTERNAL_SERVER_ERROR)}return sT}a(Vd,"getJWTRSAKeys");async function sZ(e){if(!e)throw Or(new Error,yr.INVALID_BODY,br.BAD_REQUEST,void 0,void 0,!0);if(!e.refresh_token)throw Or(new Error,yr.REFRESH_TOKEN_REQUIRED,br.BAD_REQUEST,void 0,void 0,!0);await nM(e.refresh_token);let t=await Vd(),r=await Cl.decode(e.refresh_token);return{operation_token:await rM({username:r.username,super_user:r.super_user,cluster_user:r.cluster_user},t.private_key,t.passphrase)}}a(sZ,"refreshOperationToken");async function iZ(e){try{let t=await Vd(),r=await Cl.verify(e,t.public_key,{algorithms:kd,subject:qd.OPERATION});return await iT.findAndValidateUser(r.username,void 0,!1)}catch(t){throw wl.warn(t),t.name&&t.name==="TokenExpiredError"?Or(new Error,yr.TOKEN_EXPIRED,br.FORBIDDEN):Or(new Error,yr.INVALID_TOKEN,br.UNAUTHORIZED)}}a(iZ,"validateOperationToken");async function nM(e){let t;try{let r=await Vd(),n=await Cl.verify(e,r.public_key,{algorithms:kd,subject:qd.REFRESH});t=await iT.findAndValidateUser(n.username,void 0,!1)}catch(r){throw wl.warn(r),r.name&&r.name==="TokenExpiredError"?Or(new Error,yr.TOKEN_EXPIRED,br.FORBIDDEN):Or(new Error,yr.INVALID_TOKEN,br.UNAUTHORIZED)}if(!tM.validate(t.refresh_token,e))throw Or(new Error,yr.INVALID_TOKEN,br.UNAUTHORIZED);return t}a(nM,"validateRefreshToken")});var oT=g((efe,aM)=>{"use strict";var oZ=XL(),pa=require("passport"),aZ=require("passport-local").Strategy,cZ=require("passport-http").BasicStrategy,lZ=require("util"),uZ=_n(),oM=lZ.callbackify(uZ.findAndValidateUser),Zde=vr(),_Z=U(),iM=Dl();pa.use(new aZ(function(e,t,r){oM(e,t,r)}));pa.use(new cZ(function(e,t,r){oM(e,t,r)}));pa.serializeUser(function(e,t){t(null,e)});pa.deserializeUser(function(e,t){t(null,e)});function dZ(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":pa.authenticate("basic",{session:!1},(o,c)=>{i(o,c)})(e,t,r);break;case"Bearer":e.body?.operation&&e.body.operation===_Z.OPERATIONS_ENUM.REFRESH_OPERATION_TOKEN?iM.validateRefreshToken(s).then(o=>{e.body.refresh_token=s,r(null,o)}).catch(o=>{r(o)}):iM.validateOperationToken(s).then(o=>{r(null,o)}).catch(o=>{r(o)});break;default:pa.authenticate("local",{session:!1},function(o,c){i(o,c)})(e,t,r);break}}a(dZ,"authorize");function fZ(e,t){let r=oZ(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(fZ,"checkPermissions");aM.exports={authorize:dZ,checkPermissions:fZ}});var Sa=g((rfe,cM)=>{"use strict";var aT=class{static{a(this,"Node")}constructor(t,r,n){this.name=t,this.subscriptions=r,this.system_info=n}},cT=class{static{a(this,"NodeSubscription")}constructor(t,r,n,s){this.schema=t,this.table=r,this.publish=n,this.subscribe=s}};cM.exports={Node:aT,NodeSubscription:cT}});var uM=g((sfe,lM)=>{"use strict";var EZ=U().OPERATIONS_ENUM,lT=class{static{a(this,"UpsertObject")}constructor(t,r,n,s=void 0){this.operation=EZ.UPSERT,this.schema=t,this.table=r,this.records=n,this.__origin=s}};lM.exports=lT});var Ll=g((ofe,_M)=>{"use strict";var uT=class{static{a(this,"RemotePayloadObject")}constructor(t,r,n,s){this.operation=t,this.node_name=r,this.subscriptions=n,this.system_info=s}},_T=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)}};_M.exports={RemotePayloadObject:uT,RemotePayloadSubscription:_T}});var fM=g((cfe,dM)=>{"use strict";var dT=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}};dM.exports=dT});var mM=g((ffe,hM)=>{"use strict";var hZ=fM(),ufe=dt(),EM=We(),mZ=K(),{getSchemaPath:_fe,getTransactionAuditStorePath:dfe}=ze(),{getDatabases:pZ}=(Ae(),ie(ke));hM.exports=SZ;async function SZ(e){let t=new hZ;try{let r=pZ()[e.schema]?.[e.name],n=r.primaryStore.getStats(),s=r.auditStore?.getStats(),i=await EM.environmentDataSize(schema_path,e.name),o=await EM.environmentDataSize(txn_path,e.name);t.schema=e.schema,t.table=e.name,t.table_size=i,t.record_count=n.entryCount,t.transaction_log_size=o,t.transaction_log_record_count=s.entryCount}catch(r){mZ.warn(`unable to stat table dbi due to ${r}`)}return t}a(SZ,"lmdbGetTableSize")});var SM=g((hfe,pM)=>{"use strict";var fT=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}};pM.exports=fT});var Ta=g((Rfe,AM)=>{"use strict";var TZ=require("fs-extra"),gZ=require("path"),or=require("systeminformation"),pi=K(),TM=wt(),pfe=ct(),Yd=U(),RZ=mM(),AZ=si(),{getThreadInfo:gM}=ot(),bT=ne();bT.initSync();var OZ=SM(),{openEnvironment:Sfe}=We(),{getSchemaPath:Tfe}=ze(),{database:gfe,databases:ET}=(Ae(),ie(ke)),$d;AM.exports={getHDBProcessInfo:ST,getNetworkInfo:gT,getDiskInfo:TT,getMemoryInfo:pT,getCPUInfo:mT,getTimeInfo:hT,getSystemInformation:RT,systemInformation:bZ,getTableSize:AT,getMetrics:OT};function hT(){return or.time()}a(hT,"getTimeInfo");async function mT(){try{let{family:e,model:t,stepping:r,revision:n,voltage:s,speedmin:i,speedmax:o,governor:c,socket:l,cache:_,...u}=await or.cpu();u.cpu_speed=await or.cpuCurrentSpeed();let{raw_currentload:d,raw_currentload_idle:E,raw_currentload_irq:f,raw_currentload_nice:h,raw_currentload_system:p,raw_currentload_user:S,cpus:T,...A}=await or.currentLoad();return A.cpus=[],T.forEach(N=>{let{raw_load:b,raw_load_idle:v,raw_load_irq:P,raw_load_nice:q,raw_load_system:M,raw_load_user:Q,...z}=N;A.cpus.push(z)}),u.current_load=A,u}catch(e){return pi.error(`error in getCPUInfo: ${e}`),{}}}a(mT,"getCPUInfo");async function pT(){try{let{buffers:e,cached:t,slab:r,buffcache:n,...s}=await or.mem();return Object.assign(s,process.memoryUsage())}catch(e){return pi.error(`error in getMemoryInfo: ${e}`),{}}}a(pT,"getMemoryInfo");async function ST(){let e={core:[],clustering:[]};try{let t=await or.processes(),r;try{r=Number.parseInt(await TZ.readFile(gZ.join(bT.get(Yd.CONFIG_PARAMS.ROOTPATH),Yd.HDB_PID_FILE),"utf8"))}catch(n){if(n.code===Yd.NODE_ERROR_CODES.ENOENT)pi.warn("Unable to locate 'hdb.pid' file, try stopping and starting HarperDB. This could be because HarperDB is not running.");else throw n}t.list.forEach(n=>{n.pid===r?e.core.push(n):n.name==="nats-server"&&e.clustering.push(n)});for(let n of e.core)for(let s of t.list)s.pid===n.parentPid&&(s.name==="PM2"||s.command==="PM2")&&(n.parent="PM2");return e}catch(t){return pi.error(`error in getHDBProcessInfo: ${t}`),e}}a(ST,"getHDBProcessInfo");async function TT(){let e={};try{let{rIO_sec:t,wIO_sec:r,tIO_sec:n,ms:s,...i}=await or.disksIO();e.io=i;let{rx_sec:o,tx_sec:c,wx_sec:l,..._}=await or.fsStats();return e.read_write=_,e.size=await or.fsSize(),e}catch(t){return pi.error(`error in getDiskInfo: ${t}`),e}}a(TT,"getDiskInfo");async function gT(){let e={default_interface:null,latency:{},interfaces:[],stats:[],connections:[]};try{return e.default_interface=await or.networkInterfaceDefault(),e.latency=await or.inetChecksite("google.com"),(await or.networkInterfaces()).forEach(n=>{let{internal:s,virtual:i,mtu:o,dhcp:c,dnsSuffix:l,ieee8021xAuth:_,ieee8021xState:u,carrier_changes:d,...E}=n;e.interfaces.push(E)}),(await or.networkStats()).forEach(n=>{let{rx_sec:s,tx_sec:i,ms:o,...c}=n;e.stats.push(c)}),e}catch(t){return pi.error(`error in getNetworkInfo: ${t}`),e}}a(gT,"getNetworkInfo");async function RT(){if($d!==void 0)return $d;let e={};try{let{codepage:t,logofile:r,serial:n,build:s,servicepack:i,uefi:o,...c}=await or.osInfo();e=c;let l=await or.versions("node, npm");return e.node_version=l.node,e.npm_version=l.npm,$d=e,$d}catch(t){return pi.error(`error in getSystemInformation: ${t}`),e}}a(RT,"getSystemInformation");async function AT(){let e=[],t=await AZ.describeAll();for(let r of Object.values(t))for(let n of Object.values(r))e.push(await RZ(n));return e}a(AT,"getTableSize");async function OT(){let e={};for(let t in ET){let r=e[t]={},n=r.tables={};for(let s in ET[t])try{let i=ET[t][s];r.readers||(Object.assign(r,i.primaryStore.rootStore.getStats()),delete r.root,r.readers=i.primaryStore.rootStore.readerList().split(/\n\s+/).slice(1).map(l=>{let[_,u,d]=l.trim().split(" ");return{pid:_,thread:u,txnid:d}}),i.primaryStore.auditStore&&(r.audit=i.auditStore.getStats()));let o=i.primaryStore.getStats(),c={};for(let l of["treeDepth","treeBranchPageCount","treeLeafPageCount","entryCount","overflowPages"])c[l]=o[l];n[s]=c}catch(i){pi.notify(`Error getting stats for table ${s}: ${i}`)}}return e}a(OT,"getMetrics");async function RM(){if(bT.get(Yd.CONFIG_PARAMS.CLUSTERING_ENABLED)){let{jsm:e}=await TM.getNATSReferences(),t=await TM.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(RM,"getNatsStreamInfo");async function bZ(e){let t=new OZ;if(!Array.isArray(e.attributes)||e.attributes.length===0)return t.system=await RT(),t.time=hT(),t.cpu=await mT(),t.memory=await pT(),t.disk=await TT(),t.network=await gT(),t.harperdb_processes=await ST(),t.table_size=await AT(),t.metrics=await OT(),t.threads=await gM(),t.replication=await RM(),t;for(let r=0;r<e.attributes.length;r++)switch(e.attributes[r]){case"system":t.system=await RT();break;case"time":t.time=hT();break;case"cpu":t.cpu=await mT();break;case"memory":t.memory=await pT();break;case"disk":t.disk=await TT();break;case"network":t.network=await gT();break;case"harperdb_processes":t.harperdb_processes=await ST();break;case"table_size":t.table_size=await AT();break;case"database_metrics":case"metrics":t.metrics=await OT();break;case"threads":t.threads=await gM();break;case"replication":t.replication=await RM();break;default:break}return t}a(bZ,"systemInformation")});var Wd=g((Ofe,OM)=>{"use strict";OM.exports={version:yZ,printVersion:NZ};var Kd=fl();function yZ(){if(Kd)return Kd.version}a(yZ,"version");function NZ(){Kd&&console.log(`HarperDB Version ${Kd.version}`)}a(NZ,"printVersion")});var Cs=g((Ife,IM)=>{"use strict";var IZ=un(),yT=J(),wZ=require("util"),Eo=U(),bM=ne();bM.initSync();var CZ=oT(),yM=kr(),{Node:yfe,NodeSubscription:Nfe}=Sa(),DZ=sa(),LZ=uM(),{RemotePayloadObject:MZ,RemotePayloadSubscription:PZ}=Ll(),{handleHDBError:UZ,hdb_errors:vZ}=se(),{HTTP_STATUS_CODES:BZ,HDB_ERROR_MSGS:HZ}=vZ,xZ=rs(),GZ=Ta(),FZ=Wd(),{getDatabases:qZ}=(Ae(),ie(ke)),kZ=wZ.promisify(CZ.authorize),VZ=yM.searchByHash,$Z=yM.searchByValue;IM.exports={authHeaderToUser:YZ,isEmpty:KZ,getNodeRecord:WZ,upsertNodeRecord:QZ,buildNodePayloads:zZ,checkClusteringEnabled:JZ,getAllNodeRecords:XZ,getSystemInfo:jZ,reverseSubscription:NM};async function YZ(e){let t={headers:{authorization:e.hdb_auth_header}};return e.hdb_user=await kZ(t,null),e}a(YZ,"authHeaderToUser");function KZ(e){return e==null}a(KZ,"isEmpty");async function WZ(e){let t=new DZ(Eo.SYSTEM_SCHEMA_NAME,Eo.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e],["*"]);return VZ(t)}a(WZ,"getNodeRecord");async function QZ(e){let t=new LZ(Eo.SYSTEM_SCHEMA_NAME,Eo.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[e]);return IZ.upsert(t)}a(QZ,"upsertNodeRecord");function NM(e){if(yT.isEmpty(e.subscribe)||yT.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(NM,"reverseSubscription");function zZ(e,t,r,n){let s=[];for(let i=0,o=e.length;i<o;i++){let c=e[i],{schema:l,table:_}=c,u=yT.getTableHashAttribute(l,_),{subscribe:d,publish:E}=NM(c),f=qZ()[l]?.[_],h=new PZ(l,_,u,E,d,c.start_time,f.schemaDefined?f.attributes:void 0);s.push(h)}return new MZ(r,t,s,n)}a(zZ,"buildNodePayloads");function JZ(){if(!bM.get(Eo.CONFIG_PARAMS.CLUSTERING_ENABLED))throw UZ(new Error,HZ.CLUSTERING_NOT_ENABLED,BZ.BAD_REQUEST,void 0,void 0,!0)}a(JZ,"checkClusteringEnabled");async function XZ(){let e=new xZ(Eo.SYSTEM_SCHEMA_NAME,Eo.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,"name","*",void 0,["*"]);return Array.from(await $Z(e))}a(XZ,"getAllNodeRecords");async function jZ(){let e=await GZ.getSystemInformation();return{hdb_version:FZ.version(),node_version:e.node_version,platform:e.platform}}a(jZ,"getSystemInfo")});var NT=g((Cfe,vM)=>{"use strict";var Qd=wt(),wM=J(),CM=ct(),DM=U(),zd=K(),LM=vd(),ZZ=Fp(),{RemotePayloadObject:e5}=Ll(),{handleHDBError:MM,hdb_errors:t5}=se(),{HTTP_STATUS_CODES:PM}=t5,{NodeSubscription:UM}=Sa();vM.exports=r5;async function r5(e,t){let r;try{r=await Qd.request(`${t}.${CM.REQUEST_SUFFIX}`,new e5(DM.OPERATIONS_ENUM.DESCRIBE_ALL,t,void 0,void 0)),zd.trace("Response from remote describe all request:",r)}catch(o){zd.error(`addNode received error from describe all request to remote node: ${o}`);let c=Qd.requestErrorHandler(o,"add_node",t);throw MM(new Error,c,PM.INTERNAL_SERVER_ERROR,"error",c)}if(r.status===CM.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let o=`Error returned from remote node ${t}: ${r.message}`;throw MM(new Error,o,PM.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===DM.SYSTEM_SCHEMA_NAME){await Qd.createLocalTableStream(l,c);let h=new UM(l,c,o.publish,o.subscribe);h.start_time=o.start_time,i.push(h);continue}let _=wM.doesSchemaExist(l),u=n[l]!==void 0,d=c?wM.doesTableExist(l,c):!0,E=c?n?.[l]?.[c]!==void 0:!0;if(!_&&!u||!d&&!E){s.push(o);continue}if(!_&&u&&(zd.trace(`addNode creating schema: ${l}`),await LM.createSchema({operation:"create_schema",schema:l})),!d&&E){zd.trace(`addNode creating table: ${c} in schema: ${l} with attributes ${JSON.stringify(n[l][c].attributes)}`);let h=new ZZ(l,c,n[l][c].hash_attribute);n[l][c].attributes&&(h.attributes=n[l][c].attributes),await LM.createTable(h)}await Qd.createLocalTableStream(l,c);let f=new UM(l,c,o.publish,o.subscribe);f.start_time=o.start_time,i.push(f)}return{added:i,skipped:s}}a(r5,"reviewSubscriptions")});var Zd=g((Lfe,xM)=>{"use strict";var{handleHDBError:Jd,hdb_errors:n5}=se(),{HTTP_STATUS_CODES:Xd}=n5,{addUpdateNodeValidator:s5}=Fd(),jd=K(),HM=U(),BM=ct(),i5=J(),Ml=wt(),Pl=Cs(),o5=ne(),a5=NT(),{Node:c5,NodeSubscription:l5}=Sa(),{broadcast:u5}=ot(),_5="Unable to create subscriptions due to schema and/or tables not existing on the local or remote node",d5="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",f5=o5.get(HM.CONFIG_PARAMS.CLUSTERING_NODENAME);xM.exports=E5;async function E5(e,t=!1){jd.trace("addNode called with:",e),Pl.checkClusteringEnabled();let r=s5(e);if(r)throw Jd(r,r.message,Xd.BAD_REQUEST,void 0,void 0,!0);let n=e.node_name;if(!t){let d=await Pl.getNodeRecord(n);if(!i5.isEmptyOrZeroLength(d))throw Jd(new Error,`Node '${n}' has already been added, perform update_node to proceed.`,Xd.BAD_REQUEST,void 0,void 0,!0)}let{added:s,skipped:i}=await a5(e.subscriptions,n),o={message:void 0,added:s,skipped:i};if(s.length===0)return o.message=_5,o;let c=Pl.buildNodePayloads(s,f5,HM.OPERATIONS_ENUM.ADD_NODE,await Pl.getSystemInfo()),l=[];for(let d=0,E=s.length;d<E;d++){let f=s[d];s[d].start_time===void 0&&delete s[d].start_time,l.push(new l5(f.schema,f.table,f.publish,f.subscribe))}jd.trace("addNode sending remote payload:",c);let _;try{_=await Ml.request(`${n}.${BM.REQUEST_SUFFIX}`,c)}catch(d){jd.error(`addNode received error from request: ${d}`);for(let f=0,h=s.length;f<h;f++){let p=s[f];p.publish=!1,p.subscribe=!1,await Ml.updateRemoteConsumer(p,n)}let E=Ml.requestErrorHandler(d,"add_node",n);throw Jd(new Error,E,Xd.INTERNAL_SERVER_ERROR,"error",E)}if(_.status===BM.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let d=`Error returned from remote node ${n}: ${_.message}`;throw Jd(new Error,d,Xd.INTERNAL_SERVER_ERROR,"error",d)}jd.trace(_);for(let d=0,E=s.length;d<E;d++){let f=s[d];await Ml.updateRemoteConsumer(f,n),f.subscribe===!0&&await Ml.updateConsumerIterator(f.schema,f.table,n,"start")}let u=new c5(n,l,_.system_info);return await Pl.upsertNodeRecord(u),u5({type:"nats_update"}),i.length>0?o.message=d5:o.message=`Successfully added '${n}' to manifest`,o}a(E5,"addNode")});var CT=g((Ufe,qM)=>{"use strict";var{handleHDBError:IT,hdb_errors:h5}=se(),{HTTP_STATUS_CODES:wT}=h5,{addUpdateNodeValidator:m5}=Fd(),Ul=K(),FM=U(),GM=ct(),Pfe=J(),vl=wt(),Bl=Cs(),p5=ne(),{cloneDeep:S5}=require("lodash"),T5=NT(),{Node:g5,NodeSubscription:R5}=Sa(),{broadcast:A5}=ot(),O5="Unable to update subscriptions due to schema and/or tables not existing on the local or remote node",b5="Some subscriptions were unsuccessful due to schema and/or tables not existing on the local or remote node",y5=p5.get(FM.CONFIG_PARAMS.CLUSTERING_NODENAME);qM.exports=N5;async function N5(e){Ul.trace("updateNode called with:",e),Bl.checkClusteringEnabled();let t=m5(e);if(t)throw IT(t,t.message,wT.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n,s=await Bl.getNodeRecord(r);s.length>0&&(n=S5(s));let{added:i,skipped:o}=await T5(e.subscriptions,r),c={message:void 0,updated:i,skipped:o};if(i.length===0)return c.message=O5,c;let l=Bl.buildNodePayloads(i,y5,FM.OPERATIONS_ENUM.UPDATE_NODE,await Bl.getSystemInfo());for(let u=0,d=i.length;u<d;u++){let E=i[u];Ul.trace(`updateNode updating work stream for node: ${r} subscription:`,E),i[u].start_time===void 0&&delete i[u].start_time}Ul.trace("updateNode sending remote payload:",l);let _;try{_=await vl.request(`${r}.${GM.REQUEST_SUFFIX}`,l)}catch(u){Ul.error(`updateNode received error from request: ${u}`);let d=vl.requestErrorHandler(u,"update_node",r);throw IT(new Error,d,wT.INTERNAL_SERVER_ERROR,"error",d)}if(_.status===GM.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR){let u=`Error returned from remote node ${r}: ${_.message}`;throw IT(new Error,u,wT.INTERNAL_SERVER_ERROR,"error",u)}Ul.trace(_);for(let u=0,d=i.length;u<d;u++){let E=i[u];await vl.updateRemoteConsumer(E,r),E.subscribe===!0?await vl.updateConsumerIterator(E.schema,E.table,r,"start"):await vl.updateConsumerIterator(E.schema,E.table,r,"stop")}return n||(n=[new g5(r,[],_.system_info)]),await I5(n[0],i,_.system_info),o.length>0?c.message=b5:c.message=`Successfully updated '${r}'`,c}a(N5,"updateNode");async function I5(e,t,r){let n=e;for(let s=0,i=t.length;s<i;s++){let o=t[s],c=!1;for(let l=0,_=e.subscriptions.length;l<_;l++){let u=n.subscriptions[l];if(u.schema===o.schema&&u.table===o.table){u.publish=o.publish,u.subscribe=o.subscribe,c=!0;break}}c||n.subscriptions.push(new R5(o.schema,o.table,o.publish,o.subscribe))}n.system_info=r,await Bl.upsertNodeRecord(n),A5({type:"nats_update"})}a(I5,"updateNodeTable")});var KM=g((Bfe,YM)=>{"use strict";var $M=require("joi"),{string:kM}=$M.types(),w5=st(),VM=U(),C5=ne(),D5=ct();YM.exports=L5;function L5(e){let t=kM.invalid(C5.get(VM.CONFIG_PARAMS.CLUSTERING_NODENAME)).pattern(D5.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=$M.object({operation:kM.valid(VM.OPERATIONS_ENUM.REMOVE_NODE).required(),node_name:t});return w5.validateBySchema(e,r)}a(L5,"removeNodeValidator")});var tf=g((xfe,XM)=>{"use strict";var{handleHDBError:WM,hdb_errors:M5}=se(),{HTTP_STATUS_CODES:QM}=M5,P5=KM(),Hl=K(),zM=Cs(),U5=J(),ef=U(),JM=ct(),DT=wt(),v5=ne(),{RemotePayloadObject:B5}=Ll(),{NodeSubscription:H5}=Sa(),x5=il(),G5=Xi(),{broadcast:F5}=ot(),q5=v5.get(ef.CONFIG_PARAMS.CLUSTERING_NODENAME);XM.exports=k5;async function k5(e){Hl.trace("removeNode called with:",e),zM.checkClusteringEnabled();let t=P5(e);if(t)throw WM(t,t.message,QM.BAD_REQUEST,void 0,void 0,!0);let r=e.node_name,n=await zM.getNodeRecord(r);if(U5.isEmptyOrZeroLength(n))throw WM(new Error,`Node '${r}' was not found.`,QM.BAD_REQUEST,void 0,void 0,!0);n=n[0];let s=new B5(ef.OPERATIONS_ENUM.REMOVE_NODE,q5,[]),i,o=!1;for(let l=0,_=n.subscriptions.length;l<_;l++){let u=n.subscriptions[l];u.subscribe===!0&&await DT.updateConsumerIterator(u.schema,u.table,r,"stop");try{await DT.updateRemoteConsumer(new H5(u.schema,u.table,!1,!1),r)}catch(d){Hl.error(d)}}try{i=await DT.request(`${r}.${JM.REQUEST_SUFFIX}`,s),Hl.trace("Remove node reply from remote node:",r,i)}catch(l){Hl.error("removeNode received error from request:",l),o=!0}let c=new x5(ef.SYSTEM_SCHEMA_NAME,ef.SYSTEM_TABLE_NAMES.NODE_TABLE_NAME,[r]);return await G5.deleteRecord(c),F5({type:"nats_update"}),i?.status===JM.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR||o?(Hl.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(k5,"removeNode")});var eP=g((Ffe,ZM)=>{"use strict";var jM=require("joi"),{string:V5,array:$5}=jM.types(),Y5=st(),K5=Fd();ZM.exports=W5;function W5(e){let t=jM.object({operation:V5.valid("configure_cluster").required(),connections:$5.items(K5.validation_schema).required()});return Y5.validateBySchema(e,t)}a(W5,"configureClusterValidator")});var LT=g((kfe,iP)=>{"use strict";var Q5=U(),rf=K(),z5=J(),J5=tf(),X5=Zd(),tP=Cs(),j5=eP(),{handleHDBError:rP,hdb_errors:Z5}=se(),{HTTP_STATUS_CODES:nP}=Z5,e8="Configure cluster complete.",t8="Failed to configure the cluster. Check the logs for more details.",r8="Configure cluster was partially successful. Errors occurred when attempting to configure the following nodes. Check the logs for more details.";iP.exports=n8;async function n8(e){rf.trace("configure cluster called with:",e),tP.checkClusteringEnabled();let t=j5(e);if(t)throw rP(t,t.message,nP.BAD_REQUEST,void 0,void 0,!0);let r=await tP.getAllNodeRecords(),n=[];for(let u=0,d=r.length;u<d;u++){let E=await sP(J5,{operation:Q5.OPERATIONS_ENUM.REMOVE_NODE,node_name:r[u].name},r[u].name);n.push(E)}rf.trace("All results from configure_cluster remove node:",n);let s=[],i=e.connections.length;for(let u=0;u<i;u++){let d=e.connections[u],E=await sP(X5,d,d.node_name);s.push(E)}rf.trace("All results from configure_cluster add node:",s);let o=[],c=[],l=!1,_=n.concat(s);for(let u=0,d=_.length;u<d;u++){let E=_[u];E.status==="rejected"&&(rf.error(E),o.includes(E.node_name)||o.push(E.node_name)),(E?.result?.message?.includes?.("Successfully")||E?.result?.includes?.("Successfully"))&&(l=!0),!(typeof E.result=="string"&&E.result.includes("Successfully removed")||E.status==="rejected")&&c.push({node_name:E?.node_name,subscriptions:E?.result})}if(z5.isEmptyOrZeroLength(o))return{message:e8,connections:c};if(l)return{message:r8,failed_nodes:o,connections:c};throw rP(new Error,t8,nP.INTERNAL_SERVER_ERROR,void 0,void 0,!0)}a(n8,"configureCluster");async function sP(e,t,r){try{return{node_name:r,result:await e(t)}}catch(n){return{node_name:r,error:n,status:"rejected"}}}a(sP,"functionWrapper")});var lP=g(($fe,cP)=>{"use strict";var xl=require("joi"),s8=st(),{validateSchemaExists:oP,validateTableExists:i8,validateSchemaName:aP}=jn(),o8=xl.object({operation:xl.string().valid("purge_stream"),schema:xl.string().custom(oP).custom(aP).optional(),database:xl.string().custom(oP).custom(aP).optional(),table:xl.string().custom(i8).required()});function a8(e){return s8.validateBySchema(e,o8)}a(a8,"purgeStreamValidator");cP.exports=a8});var MT=g((Kfe,uP)=>{"use strict";var{handleHDBError:c8,hdb_errors:l8}=se(),{HTTP_STATUS_CODES:u8}=l8,_8=lP(),d8=wt(),f8=Cs();uP.exports=E8;async function E8(e){e.schema=e.schema??e.database;let t=_8(e);if(t)throw c8(t,t.message,u8.BAD_REQUEST,void 0,void 0,!0);f8.checkClusteringEnabled();let{schema:r,table:n,options:s}=e;return await d8.purgeTableStream(r,n,s),`Successfully purged table '${r}.${n}'`}a(E8,"purgeStream")});var vT=g((Qfe,mP)=>{"use strict";var UT=Cs(),h8=wt(),fP=ne(),nf=U(),ho=ct(),m8=J(),PT=K(),{RemotePayloadObject:p8}=Ll(),{ErrorCode:_P}=require("nats"),dP=fP.get(nf.CONFIG_PARAMS.CLUSTERING_ENABLED),EP=fP.get(nf.CONFIG_PARAMS.CLUSTERING_NODENAME);mP.exports={clusterStatus:S8,buildNodeStatus:hP};async function S8(){let e={node_name:EP,is_enabled:dP,connections:[]};if(!dP)return e;let t=await UT.getAllNodeRecords();if(m8.isEmptyOrZeroLength(t))return e;let r=[];for(let n=0,s=t.length;n<s;n++)r.push(hP(t[n],e.connections));return await Promise.allSettled(r),e}a(S8,"clusterStatus");async function hP(e,t){let r=e.name,n=new p8(nf.OPERATIONS_ENUM.CLUSTER_STATUS,EP,void 0,await UT.getSystemInfo()),s,i,o=ho.CLUSTER_STATUS_STATUSES.OPEN;try{let l=Date.now();s=await h8.request(ho.REQUEST_SUBJECT(r),n),i=Date.now()-l,s.status===ho.UPDATE_REMOTE_RESPONSE_STATUSES.ERROR&&(o=ho.CLUSTER_STATUS_STATUSES.CLOSED,PT.error(`Error getting node status from ${r} `,s))}catch(l){PT.warn(`Error getting node status from ${r}`,l),l.code===_P.NoResponders?o=ho.CLUSTER_STATUS_STATUSES.NO_RESPONDERS:l.code===_P.Timeout?o=ho.CLUSTER_STATUS_STATUSES.TIMEOUT:o=ho.CLUSTER_STATUS_STATUSES.CLOSED}let c=new T8(r,o,s?.message?.ports?.clustering,s?.message?.ports?.operations_api,i,s?.message?.uptime,e.subscriptions,s?.message?.system_info);try{let l={name:r,system_info:s?.message?.system_info};e.system_info?.hdb_version!==nf.PRE_4_0_0_VERSION&&await UT.upsertNodeRecord(l)}catch(l){PT.error("Cluster status encountered an error updating system info for node:",r,l)}t.push(c)}a(hP,"buildNodeStatus");function T8(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(T8,"NodeStatusObject")});var HT=g((Jfe,pP)=>{"use strict";var{handleHDBError:g8,hdb_errors:R8}=se(),{HTTP_STATUS_CODES:A8}=R8,O8=wt(),b8=Cs(),BT=J(),sf=require("joi"),y8=st(),N8=2e3,I8=sf.object({timeout:sf.number().min(1),connected_nodes:sf.boolean(),routes:sf.boolean()});pP.exports=w8;async function w8(e){b8.checkClusteringEnabled();let t=y8.validateBySchema(e,I8);if(t)throw g8(t,t.message,A8.BAD_REQUEST,void 0,void 0,!0);let{timeout:r,connected_nodes:n,routes:s}=e,i=n===void 0||BT.autoCastBoolean(n),o=s===void 0||BT.autoCastBoolean(s),c={nodes:[]},l=await O8.getServerList(r??N8),_={};if(i)for(let u=0,d=l.length;u<d;u++){let E=l[u].statsz;E&&(_[l[u].server.name]=E.routes)}for(let u=0,d=l.length;u<d;u++){if(l[u].statsz)continue;let E=l[u].server,f=l[u].data;if(E.name.endsWith("-hub")){let h={name:E.name.slice(0,-4),response_time:l[u].response_time};i&&(h.connected_nodes=[],_[E.name]&&_[E.name].forEach(p=>{h.connected_nodes.includes(p.name.slice(0,-4))||h.connected_nodes.push(p.name.slice(0,-4))})),o&&(h.routes=f.cluster?.urls?f.cluster?.urls.map(p=>({host:p.split(":")[0],port:BT.autoCast(p.split(":")[1])})):[]),c.nodes.push(h)}}return c}a(w8,"clusterNetwork")});var RP=g((jfe,gP)=>{"use strict";var xT=require("joi"),SP=st(),{route_constraints:TP}=Fh();gP.exports={setRoutesValidator:C8,deleteRoutesValidator:D8};function C8(e){let t=xT.object({server:xT.valid("hub","leaf").required(),routes:TP.required()});return SP.validateBySchema(e,t)}a(C8,"setRoutesValidator");function D8(e){let t=xT.object({routes:TP.required()});return SP.validateBySchema(e,t)}a(D8,"deleteRoutesValidator")});var FT=g((eEe,yP)=>{"use strict";var mo=hr(),GT=J(),of=U(),AP=RP(),{handleHDBError:OP,hdb_errors:L8}=se(),{HTTP_STATUS_CODES:bP}=L8,M8="cluster routes successfully set",P8="cluster routes successfully deleted";yP.exports={setRoutes:U8,getRoutes:v8,deleteRoutes:B8};function U8(e){let t=AP.setRoutesValidator(e);if(t)throw OP(t,t.message,bP.BAD_REQUEST,void 0,void 0,!0);let r=mo.getClusteringRoutes(),n=e.server==="hub"?r.hub_routes:r.leaf_routes,s=e.server==="hub"?r.leaf_routes:r.hub_routes,i=[],o=[];for(let c=0,l=e.routes.length;c<l;c++){let _=e.routes[c];_.port=GT.autoCast(_.port);let u=n.some(E=>E.host===_.host&&E.port===_.port),d=s.some(E=>E.host===_.host&&E.port===_.port);u||d?i.push(_):(n.push(_),o.push(_))}return e.server==="hub"?mo.updateConfigValue(of.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,n):mo.updateConfigValue(of.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,n),{message:M8,set:o,skipped:i}}a(U8,"setRoutes");function v8(){let e=mo.getClusteringRoutes();return{hub:e.hub_routes,leaf:e.leaf_routes}}a(v8,"getRoutes");function B8(e){let t=AP.deleteRoutesValidator(e);if(t)throw OP(t,t.message,bP.BAD_REQUEST,void 0,void 0,!0);let r=mo.getClusteringRoutes(),n=r.hub_routes,s=r.leaf_routes,i=[],o=[],c=!1,l=!1;for(let _=0,u=e.routes.length;_<u;_++){let d=e.routes[_],E=!1;for(let f=0,h=n.length;f<h;f++){let p=n[f];if(d.host===p.host&&d.port===p.port){n.splice(f,1),E=!0,c=!0,i.push(d);break}}if(!E){let f=!0;for(let h=0,p=s.length;h<p;h++){let S=s[h];if(d.host===S.host&&d.port===S.port){s.splice(h,1),l=!0,f=!1,i.push(d);break}}f&&o.push(d)}}return c&&(n=GT.isEmptyOrZeroLength(n)?null:n,mo.updateConfigValue(of.CONFIG_PARAMS.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_ROUTES,n)),l&&(s=GT.isEmptyOrZeroLength(s)?null:s,mo.updateConfigValue(of.CONFIG_PARAMS.CLUSTERING_LEAFSERVER_NETWORK_ROUTES,s)),{message:P8,deleted:i,skipped:o}}a(B8,"deleteRoutes")});var IP=g((rEe,NP)=>{"use strict";var Gl=require("alasql"),po=require("recursive-iterator"),Hn=K(),H8=J(),Fl=U(),qT=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,G8(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=>Fl.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=>!Fl.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][Fl.PERMS_CRUD_ENUM.READ]){let c;t[i].tables[o].attribute_permissions.length>0?c=x8(t[i].tables[o].attribute_permissions):c=global.hdb_schema[i][o].attributes.map(_=>({attribute_name:_.attribute}));let l=this.affected_attributes.get(i).get(o).filter(_=>!Fl.SEARCH_WILDCARDS.includes(_));c.forEach(({attribute_name:_})=>{let u=new Gl.yy.Column({columnid:_});s.tableid&&(u.tableid=s.tableid),this.ast.columns.push(u),l.includes(_)||l.push(_)}),this.affected_attributes.get(i).set(o,l)}}),this.ast}};function x8(e){return e.filter(t=>t[Fl.PERMS_CRUD_ENUM.READ])}a(x8,"filterReadRestrictedAttrs");function G8(e,t,r,n,s){F8(e,t,r,n,s)}a(G8,"interpretAST");function ql(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(ql,"addSchemaTableToMap");function F8(e,t,r,n,s){if(!e){Hn.info("getRecordAttributesAST: invalid SQL syntax tree");return}e instanceof Gl.yy.Insert?$8(e,t,r):e instanceof Gl.yy.Select?q8(e,t,r,n,s):e instanceof Gl.yy.Update?k8(e,t,r):e instanceof Gl.yy.Delete?V8(e,t,r):Hn.error("AST in getRecordAttributesAST() is not a valid SQL type.")}a(F8,"getRecordAttributesAST");function q8(e,t,r,n,s){if(!e){Hn.info("getSelectAttributes: invalid SQL syntax tree");return}if(!e.from||e.from[0]===void 0)return;let i=e.from[0].databaseid;if(H8.isEmptyOrZeroLength(i)){Hn.error("No schema specified");return}e.from.forEach(c=>{ql(c,t,r,n,s)}),e.joins&&e.joins.forEach(c=>{c.as&&(c.table.as=c.as),ql(c.table,t,r,n,s)});let o=new po(e.columns);for(let{node:c}of o)if(c&&c.columnid){let l=c.tableid,_=n.has(l)?n.get(l):i;if(l||(l=e.from[0].tableid),!t.get(_).has(l))if(r.has(l))l=r.get(l);else{Hn.info(`table specified as ${l} not found.`);return}t.get(_).get(l).indexOf(c.columnid)<0&&t.get(_).get(l).push(c.columnid)}if(e.where){let c=new po(e.where),l=e.from[0].tableid;for(let{node:_}of c)if(_&&_.columnid){let u=_.tableid?_.tableid:l;if(!t.get(i).has(u))if(r.has(u))u=r.get(u);else{Hn.info(`table specified as ${u} not found.`);continue}t.get(i).get(u).indexOf(_.columnid)<0&&t.get(i).get(u).push(_.columnid)}}if(e.joins&&e.joins.forEach(c=>{let l=new po(c.on);for(let{node:_}of l)if(_&&_.columnid){let u=_.tableid,d=s.get(u);if(!t.get(d).has(u))if(r.has(u))u=r.get(u);else{Hn.info(`table specified as ${u} not found.`);continue}t.get(d).get(u).indexOf(_.columnid)<0&&t.get(d).get(u).push(_.columnid)}}),e.order){let c=new po(e.order);for(let{node:l}of c)if(l&&l.columnid){let _=l.tableid,u=n.has(_)?n.get(_):i;if(_||(_=e.from[0].tableid),!t.get(u).has(_))if(r.has(_))_=r.get(_);else{Hn.info(`table specified as ${_} not found.`);return}t.get(u).get(_).indexOf(l.columnid)<0&&t.get(u).get(_).push(l.columnid)}}}a(q8,"getSelectAttributes");function k8(e,t,r){if(!e){Hn.info("getUpdateAttributes: invalid SQL syntax tree");return}let n=new po(e.columns),s=e.table.databaseid;ql(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&kT(e.table.tableid,s,i.columnid,t,r)}a(k8,"getUpdateAttributes");function V8(e,t,r){if(!e){Hn.info("getDeleteAttributes: invalid SQL syntax tree");return}let n=new po(e.where),s=e.table.databaseid;ql(e.table,t,r);for(let{node:i}of n)i&&i.columnid&&kT(e.table.tableid,s,i.columnid,t,r)}a(V8,"getDeleteAttributes");function $8(e,t,r){if(!e){Hn.info("getInsertAttributes: invalid SQL syntax tree");return}let n=new po(e.columns),s=e.into.databaseid;ql(e.into,t,r);for(let{node:i}of n)i&&i.columnid&&kT(e.into.tableid,s,i.columnid,t,r)}a($8,"getInsertAttributes");function kT(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(kT,"pushAttribute");NP.exports=qT});var YT=g((sEe,LP)=>{var af=ji(),wP=require("chalk"),Qr=K(),CP=require("prompt"),{promisify:Y8}=require("util"),VT=U(),K8=require("fs-extra"),W8=require("path"),Q8=J(),z8=Wd(),DP=ne();DP.initSync();var J8=require("moment"),X8=Y8(CP.get),j8=W8.join(DP.getHdbBasePath(),VT.LICENSE_KEY_DIR_NAME,VT.LICENSE_FILE_NAME,VT.LICENSE_FILE_NAME);LP.exports={getFingerprint:e6,setLicense:Z8,parseLicense:$T,register:t6,getRegistrationInfo:n6};async function Z8(e){if(e&&e.key&&e.company){try{Qr.info(`parsing license key: ${e.key} and `);let t=e.company.toString();await $T(e.key.trim(),t.trim())}catch(t){let r="There was an error parsing the license key.";throw Qr.error(r),Qr.error(t),new Error(r)}return"Wrote license key file. Registration successful."}throw new Error("Invalid key or company specified for license file.")}a(Z8,"setLicense");async function e6(){let e={};try{e=await af.generateFingerPrint()}catch(t){let r="Error generating fingerprint.";throw Qr.error(r),Qr.error(t),new Error(r)}return e}a(e6,"getFingerprint");async function $T(e,t){if(!e||!t)throw new Error("Invalid entries for License Key and Customer Company");Qr.info("Validating license input...");let r=af.validateLicense(e,t);if(Qr.info("checking for valid license..."),!r.valid_license)throw new Error("Invalid license found.");if(Qr.info("checking valid license date..."),!r.valid_date)throw new Error("This License has expired.");if(Qr.info(`checking for valid machine license ${r.valid_machine}`),!r.valid_machine)throw new Error("This license is in use on another machine.");try{Qr.info("writing license to disk"),await K8.writeFile(j8,JSON.stringify({license_key:e,company:t}))}catch(n){throw Qr.error("Failed to write License"),n}return"Registration successful."}a($T,"parseLicense");async function t6(){let e=await r6();return $T(e.HDB_LICENSE,e.CUSTOMER_COMPANY)}a(t6,"register");async function r6(){let e=await af.generateFingerPrint(),t={properties:{CUSTOMER_COMPANY:{description:wP.magenta("[COMPANY] Please enter your company name"),required:!0},HDB_LICENSE:{description:wP.magenta(`[HDB_LICENSE] Your fingerprint is ${e} Please enter your license key`),required:!0}}};try{CP.start()}catch(n){Qr.error(n)}let r;try{r=await X8(t)}catch(n){throw console.error("There was a problem prompting for registration input. Exiting."),n}return r}a(r6,"promptForRegistration");async function n6(){let e={registered:!1,version:null,ram_allocation:null,license_expiration_date:null},t;try{t=await af.getLicense()}catch(r){throw Qr.error(`There was an error when searching licenses due to: ${r.message}`),r}if(Q8.isEmptyOrZeroLength(t))throw new Error("There were no licenses found.");if(e.registered=t.enterprise,e.version=z8.version(),e.ram_allocation=t.ram_allocation,isNaN(t.exp_date))e.license_expiration_date=t.enterprise?t.exp_date:null;else{let r=J8.utc(t.exp_date).format("YYYY-MM-DD");e.license_expiration_date=t.enterprise?r:null}return e}a(n6,"getRegistrationInfo")});var PP=g((oEe,MP)=>{"use strict";var s6=ct(),KT=class{static{a(this,"HubConfigObject")}constructor(t,r,n,s,i,o,c,l,_,u,d,E,f,h){this.port=t,o===null&&(o=void 0),this.server_name=r+s6.SERVER_SUFFIX.HUB,this.pid_file=n,this.max_payload=67108864,this.reconnect_error_reports=100,this.jetstream={enabled:!1},this.tls={cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l},this.leafnodes={port:_,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c}},this.cluster={name:u,port:d,routes:E,tls:{cert_file:s,key_file:i,ca_file:o,insecure:c,verify:l}},this.accounts={SYS:{users:f},HDB:{users:h}},this.system_account="SYS"}};MP.exports=KT});var BP=g((cEe,vP)=>{"use strict";var UP=ct(),WT=class{static{a(this,"LeafConfigObject")}constructor(t,r,n,s,i,o,c,l,_,u,d){this.port=t,d===null&&(d=void 0),this.server_name=r+UP.SERVER_SUFFIX.LEAF,this.pid_file=n,this.max_payload=67108864,this.jetstream={enabled:!0,store_dir:s,domain:r+UP.SERVER_SUFFIX.LEAF},this.tls={cert_file:_,key_file:u,ca_file:d,insecure:!0},this.leafnodes={remotes:[{tls:{ca_file:d,insecure:!0},urls:i,account:"SYS"},{tls:{ca_file:d,insecure:!0},urls:o,account:"HDB"}]},this.accounts={SYS:{users:c},HDB:{users:l,jetstream:"enabled"}},this.system_account="SYS"}};vP.exports=WT});var xP=g((uEe,HP)=>{"use strict";var QT=class{static{a(this,"HdbUserObject")}constructor(t,r){this.user=t,this.password=r}};HP.exports=QT});var FP=g((dEe,GP)=>{"use strict";var i6=ct(),zT=class{static{a(this,"SysUserObject")}constructor(t,r){this.user=t+i6.SERVER_SUFFIX.ADMIN,this.password=r}};GP.exports=zT});var jT=g((EEe,VP)=>{"use strict";var ga=require("path"),uf=require("fs-extra"),o6=PP(),a6=BP(),c6=xP(),l6=FP(),JT=_n(),Aa=J(),Nr=hr(),lf=U(),kl=ct(),{CONFIG_PARAMS:mt}=lf,Oa=K(),Vl=ne(),qP=Os(),XT=wt(),Ra="clustering",u6=1e4,kP=50;VP.exports={generateNatsConfig:d6,removeNatsConfig:f6,getHubConfigPath:_6};function _6(){let e=Vl.get(mt.ROOTPATH);return ga.join(e,Ra,kl.NATS_CONFIG_FILES.HUB_SERVER)}a(_6,"getHubConfigPath");async function d6(e=!1,t=void 0){Vl.initSync();let r=Vl.get(mt.ROOTPATH),n=ga.join(r,Ra,kl.PID_FILES.HUB),s=ga.join(r,Ra,kl.PID_FILES.LEAF),i=Nr.getConfigFromFile(mt.CLUSTERING_LEAFSERVER_STREAMS_PATH),o=ga.join(r,Ra,kl.NATS_CONFIG_FILES.HUB_SERVER),c=ga.join(r,Ra,kl.NATS_CONFIG_FILES.LEAF_SERVER),l=Nr.getConfigFromFile(mt.CLUSTERING_TLS_CERTIFICATE),_=Nr.getConfigFromFile(mt.CLUSTERING_TLS_PRIVATEKEY),u=Nr.getConfigFromFile(mt.CLUSTERING_TLS_CERT_AUTH),d=Nr.getConfigFromFile(mt.CLUSTERING_TLS_INSECURE),E=Nr.getConfigFromFile(mt.CLUSTERING_TLS_VERIFY),f=Nr.getConfigFromFile(mt.CLUSTERING_NODENAME),h=Nr.getConfigFromFile(mt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT);await XT.checkNATSServerInstalled()||_f("nats-server dependency is either missing or the wrong version. Run 'npm install' to fix");let p=await JT.listUsers(),S=Nr.getConfigFromFile(mt.CLUSTERING_USER),T=await JT.getClusterUser();(Aa.isEmpty(T)||T.active!==!0)&&_f(`Invalid cluster user '${S}'. A valid user with the role 'cluster_user' must be defined under clustering.user in harperdb-config.yaml`),e||(await cf(mt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),await cf(mt.CLUSTERING_HUBSERVER_LEAFNODES_NETWORK_PORT),await cf(mt.CLUSTERING_HUBSERVER_NETWORK_PORT),await cf(mt.CLUSTERING_LEAFSERVER_NETWORK_PORT));let A=[],N=[];for(let[z,j]of p.entries())j.role?.role===lf.ROLE_TYPES_ENUM.CLUSTER_USER&&j.active&&(A.push(new l6(j.username,qP.decrypt(j.hash))),N.push(new c6(j.username,qP.decrypt(j.hash))));let b=[],{hub_routes:v}=Nr.getClusteringRoutes();if(!Aa.isEmptyOrZeroLength(v))for(let z of v)b.push(`tls://${T.sys_name_encoded}:${T.uri_encoded_d_hash}@${z.host}:${z.port}`);let P=new o6(Nr.getConfigFromFile(mt.CLUSTERING_HUBSERVER_NETWORK_PORT),f,n,l,_,u,d,E,h,Nr.getConfigFromFile(mt.CLUSTERING_HUBSERVER_CLUSTER_NAME),Nr.getConfigFromFile(mt.CLUSTERING_HUBSERVER_CLUSTER_NETWORK_PORT),b,A,N);u==null&&(delete P.tls.ca_file,delete P.leafnodes.tls.ca_file),t=Aa.isEmpty(t)?void 0:t.toLowerCase(),(t===void 0||t===lf.PROCESS_DESCRIPTORS.CLUSTERING_HUB.toLowerCase())&&(await uf.writeJson(o,P),Oa.trace(`Hub server config written to ${o}`));let q=`tls://${T.sys_name_encoded}:${T.uri_encoded_d_hash}@0.0.0.0:${h}`,M=`tls://${T.uri_encoded_name}:${T.uri_encoded_d_hash}@0.0.0.0:${h}`,Q=new a6(Nr.getConfigFromFile(mt.CLUSTERING_LEAFSERVER_NETWORK_PORT),f,s,i,[q],[M],A,N,l,_,u,d);u==null&&delete Q.tls.ca_file,(t===void 0||t===lf.PROCESS_DESCRIPTORS.CLUSTERING_LEAF.toLowerCase())&&(await uf.writeJson(c,Q),Oa.trace(`Leaf server config written to ${c}`))}a(d6,"generateNatsConfig");async function cf(e){let t=Vl.get(e);return Aa.isEmpty(t)&&_f(`port undefined for '${e}'`),await Aa.isPortTaken(t)&&_f(`'${e}' port '${t}' is is in use by another process, check to see if HarperDB is already running or another process is using this port.`),!0}a(cf,"isPortAvailable");function _f(e){let t=`Error generating clustering config: ${e}`;Oa.error(t),console.error(t),process.exit(1)}a(_f,"generateNatsConfigError");async function f6(e){let{port:t,config_file:r}=XT.getServerConfig(e),{username:n,decrypt_hash:s}=await JT.getClusterUser(),i=0,o=2e3;for(;i<kP;){try{let u=await XT.createConnection(t,n,s,!1);if(u.protocol.connected===!0){u.close();break}}catch(u){Oa.trace(`removeNatsConfig waiting for ${e}. Caught and swallowed error ${u}`)}if(i++,i>=kP)throw new Error(`Operations API timed out attempting to connect to ${e}. This is commonly caused by incorrect clustering config. Check hdb.log for further details.`);let _=o*(i*2);_>3e4&&Oa.notify("Operations API waiting for Nats server connection. This could be caused by large Nats streams or incorrect clustering config."),await Aa.async_set_timeout(_)}let c="0".repeat(u6),l=ga.join(Vl.get(mt.ROOTPATH),Ra,r);await uf.writeFile(l,c),await uf.remove(l),Oa.notify(e,"started.")}a(f6,"removeNatsConfig")});var JP={};qe(JP,{compactOnStart:()=>E6,copyDb:()=>zP});async function E6(){Si.notify("Running compact on start"),console.log("Running compact on start");let e=(0,ZT.get)(Ti.CONFIG_PARAMS.ROOTPATH),t=new Map,r=Tr();try{for(let n in r){if(n==="system")continue;let s;for(let l in r[n]){s=r[n][l].primaryStore.path;break}if(!s){console.log("Couldn't find any tables in database",n);continue}let i=(0,df.join)(e,"backup",n+".mdb"),o=(0,df.join)(e,Ti.DATABASES_DIR_NAME,n+"-copy.mdb"),c=0;try{c=await $P(n),console.log("Database",n,"before compact has a total record count of",c)}catch(l){Si.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 zP(n,o),console.log("Backing up",n,"to",i),await(0,So.move)(s,i,{overwrite:!0})}try{$l()}catch(n){Si.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,So.move)(i,s,{overwrite:!0}),await(0,So.remove)((0,df.join)(e,Ti.DATABASES_DIR_NAME,`${n}-copy.mdb-lock`));try{$l()}catch(n){Si.error("Error resetting databases after backup",n),console.error("Error resetting databases after backup",n),process.exit(0)}}catch(n){Si.error("Error compacting database, rolling back operation",n),console.error("Error compacting database, rolling back operation",n),(0,eg.updateConfigValue)(Ti.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,So.move)(o,i,{overwrite:!0})}catch(c){console.error(c)}}throw $l(),n}for(let[n,{backup_dest:s,record_count:i}]of t){let o=!0,c=await $P(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}.
|